| 12345678910111213141516171819202122232425262728293031323334353637383940414243 |
- # app/models/user.py
- from sqlalchemy import Column, Integer, String, Boolean, DateTime, Text
- from sqlalchemy.sql import func
-
- # 从database.py导入Base(确保是DeclarativeBase)
- from app.database import Base
-
- class User(Base):
- __tablename__ = "users"
-
- id = Column(Integer, primary_key=True, index=True)
- username = Column(String(50), unique=True, index=True, nullable=False)
- email = Column(String(100), unique=True, index=True, nullable=False)
- hashed_password = Column(String(255), nullable=False)
- full_name = Column(String(100))
- avatar = Column(String(255))
-
- # 用户状态
- is_active = Column(Boolean, default=True)
- is_verified = Column(Boolean, default=False)
- is_superuser = Column(Boolean, default=False)
- is_locked = Column(Boolean, default=False)
-
- # 个人信息
- full_name = Column(String(100), nullable=True)
- phone = Column(String(20), nullable=True)
- avatar = Column(Text, nullable=True)
-
- # 时间戳
- created_at = Column(DateTime(timezone=True), server_default=func.now())
- updated_at = Column(DateTime(timezone=True), onupdate=func.now())
- last_login = Column(DateTime, nullable=True)
- last_password_change = Column(DateTime, nullable=True)
-
- # 安全相关
- failed_login_attempts = Column(Integer, default=0)
- verification_token = Column(String(255), nullable=True)
- verification_token_expires = Column(DateTime, nullable=True)
- reset_token = Column(String(255), nullable=True)
- reset_token_expires = Column(DateTime, nullable=True)
-
- def __repr__(self):
- return f"<User {self.username}>"
|