arkan-api / app /models /user.py
masry86's picture
initial commit - arkan backend
de0f1ef
raw
history blame contribute delete
944 Bytes
from datetime import datetime
from sqlalchemy import Boolean, DateTime, String
from sqlalchemy.orm import Mapped, mapped_column
from app.models.base import Base, TimestampMixin
VALID_ROLES = frozenset({"admin", "staff", "client"})
class User(Base, TimestampMixin):
__tablename__ = "users"
id: Mapped[int] = mapped_column(primary_key=True, index=True)
username: Mapped[str] = mapped_column(
String(100), unique=True, index=True, nullable=False
)
email: Mapped[str | None] = mapped_column(
String(255), unique=True, index=True, nullable=True
)
password_hash: Mapped[str] = mapped_column(String(255), nullable=False)
role: Mapped[str] = mapped_column(String(50), default="client", nullable=False)
is_active: Mapped[bool] = mapped_column(Boolean, default=True, nullable=False)
last_login_at: Mapped[datetime | None] = mapped_column(
DateTime(timezone=True), nullable=True
)