♑✏️
- feature access/refresh tokens auth
This commit is contained in:
@@ -13,11 +13,11 @@ class User(Base):
|
||||
hashed_password = Column(String(60))
|
||||
full_name = Column(String(100), nullable=True)
|
||||
phone = Column(String(20), nullable=True)
|
||||
is_agent = Column(Boolean, default=False)
|
||||
created_at = Column(DateTime, default=lambda: datetime.now(timezone.utc))
|
||||
|
||||
properties = relationship("Property", back_populates="owner")
|
||||
favorites = relationship("Favorite", back_populates="user")
|
||||
refresh_tokens = relationship("RefreshToken", back_populates="user")
|
||||
|
||||
|
||||
class Property(Base):
|
||||
@@ -74,3 +74,16 @@ class Favorite(Base):
|
||||
property = relationship("Property", back_populates="favorites")
|
||||
|
||||
__table_args__ = (UniqueConstraint("user_id", "property_id", name="uq_user_property"),)
|
||||
|
||||
|
||||
class RefreshToken(Base):
|
||||
__tablename__ = "refresh_tokens"
|
||||
|
||||
id = Column(Integer, primary_key=True, index=True)
|
||||
user_id = Column(Integer, ForeignKey("users.id"), nullable=False)
|
||||
token = Column(String(500), unique=True, nullable=False, index=True)
|
||||
expires_at = Column(DateTime, nullable=False)
|
||||
revoked = Column(Boolean, default=False)
|
||||
created_at = Column(DateTime, default=lambda: datetime.now(timezone.utc))
|
||||
|
||||
user = relationship("User", back_populates="refresh_tokens")
|
||||
|
||||
Reference in New Issue
Block a user