from typing import Any from sqlalchemy import Column, DateTime from sqlalchemy.ext.declarative import as_declarative, declared_attr from sqlalchemy.sql import func @as_declarative() class Base: id: Any __name__: str # Generate __tablename__ automatically @declared_attr def __tablename__(cls) -> str: return cls.__name__.lower() # Common columns for all models created_at = Column(DateTime(timezone=True), server_default=func.now(), nullable=False) updated_at = Column(DateTime(timezone=True), server_default=func.now(), onupdate=func.now(), nullable=False)