from datetime import datetime
from sqlalchemy import ForeignKey, String, func
from sqlalchemy.orm import Mapped, mapped_column, relationship
class User(db.Model):
__tablename__ = "user"
id: Mapped[int] = mapped_column(primary_key=True)
username: Mapped[str] = mapped_column(String(32), unique=True, nullable=False)
created_at: Mapped[datetime] = mapped_column(server_default=func.now())
posts: Mapped[list["Post"]] = relationship(back_populates="user")
class Post(db.Model):
__tablename__ = "post"
id: Mapped[int] = mapped_column(primary_key=True)
user_id: Mapped[int] = mapped_column(ForeignKey("user.id"), nullable=False)
body: Mapped[str] = mapped_column(String(280), nullable=False)
created_at: Mapped[datetime] = mapped_column(server_default=func.now(), index=True)
user: Mapped["User"] = relationship(back_populates="posts")
class Follow(db.Model):
__tablename__ = "follow"
follower_id: Mapped[int] = mapped_column(ForeignKey("user.id"), primary_key=True)
followed_id: Mapped[int] = mapped_column(ForeignKey("user.id"), primary_key=True)
created_at: Mapped[datetime] = mapped_column(server_default=func.now())