# backend/models/base.py from datetime import datetime, timezone import uuid from sqlalchemy.ext.declarative import declarative_base from sqlalchemy import Column, DateTime, Boolean from sqlalchemy.dialects.postgresql import UUID Base = declarative_base() class TimestampMixin: created_at = Column(DateTime(timezone=True), default=lambda: datetime.now(timezone.utc), nullable=False) updated_at = Column(DateTime(timezone=True), default=lambda: datetime.now(timezone.utc), onupdate=lambda: datetime.now(timezone.utc), nullable=False) class UUIDMixin: id = Column(UUID(as_uuid=True), primary_key=True, default=uuid.uuid4)