user.py 1.3 KB

12345678910111213141516171819202122232425262728293031323334
  1. import enum
  2. from sqlalchemy import Column, Integer, String, Enum, DateTime
  3. from sqlalchemy.sql import func
  4. from app.core.database import Base
  5. class UserStatus(str, enum.Enum):
  6. PENDING = "PENDING" # Waiting for approval
  7. ACTIVE = "ACTIVE" # Approved and active
  8. DISABLED = "DISABLED" # Manually disabled by admin
  9. class UserRole(str, enum.Enum):
  10. SUPER_ADMIN = "SUPER_ADMIN"
  11. DEVELOPER = "DEVELOPER"
  12. ORDINARY_USER = "ORDINARY_USER"
  13. class User(Base):
  14. __tablename__ = "users"
  15. id = Column(Integer, primary_key=True, index=True)
  16. mobile = Column(String(20), unique=True, index=True, nullable=False)
  17. password_hash = Column(String(128), nullable=False)
  18. salt = Column(String(64), nullable=True)
  19. name = Column(String(100), nullable=True, comment="User Chinese Name")
  20. english_name = Column(String(100), nullable=True, comment="User English Name (Pinyin)")
  21. status = Column(Enum(UserStatus), default=UserStatus.PENDING, nullable=False)
  22. role = Column(Enum(UserRole), default=UserRole.DEVELOPER, nullable=False)
  23. is_deleted = Column(Integer, default=0, nullable=False) # 0: False, 1: True (Soft Delete)
  24. created_at = Column(DateTime(timezone=True), server_default=func.now())
  25. updated_at = Column(DateTime(timezone=True), onupdate=func.now(), server_default=func.now())