import uuid from sqlalchemy import String, JSON from sqlalchemy.orm import Mapped, mapped_column from sqlalchemy.dialects.postgresql import UUID from app.db.session import Base from app.models.common import UUIDMixin, TimestampMixin class AuditLog(Base, UUIDMixin, TimestampMixin): __tablename__ = "audit_log" actor_admin_id: Mapped[uuid.UUID | None] = mapped_column(UUID(as_uuid=True), nullable=True) entity: Mapped[str] = mapped_column(String(80), nullable=False) entity_id: Mapped[str] = mapped_column(String(80), nullable=False) action: Mapped[str] = mapped_column(String(30), nullable=False) diff: Mapped[dict] = mapped_column(JSON, default=dict, nullable=False)