user.py 811 B

1234567891011121314151617181920
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from backend.app.core.database import Base
  5. class User(Base):
  6. """User model for authentication and authorization."""
  7. __tablename__ = "users"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. username: Mapped[str] = mapped_column(String(100), unique=True, index=True)
  10. password_hash: Mapped[str] = mapped_column(String(255))
  11. role: Mapped[str] = mapped_column(String(20), default="user") # "admin" or "user"
  12. is_active: Mapped[bool] = mapped_column(default=True)
  13. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  14. updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())