from datetime import datetime from sqlalchemy.orm import DeclarativeBase from sqlalchemy.orm import mapped_column, Mapped from sqlalchemy import String import ulid class BaseModel(DeclarativeBase): pass class UserAccount(BaseModel): __tablename__ = "user_account" id: Mapped[str] = mapped_column(String(26), primary_key=True, insert_default=ulid.new().str) username: Mapped[str] = mapped_column(String(20), unique=True) email: Mapped[str] = mapped_column(String, unique=True) password: Mapped[str] = mapped_column(String(60)) updated_at: Mapped[datetime] = mapped_column(default=datetime.now) created_at: Mapped[datetime] = mapped_column(default=datetime.now, onupdate=datetime.now) def __repr__(self): return f'UserAccount(username={self.username}, email={self.email})' def to_json(self) -> dict: return { 'username': self.username, 'email': self.email, }