from __future__ import annotations from sqlalchemy import Text from sqlalchemy.orm import Mapped, mapped_column from app.db.base import Base class AuditLog(Base): __tablename__ = "audit_log" audit_id: Mapped[str] = mapped_column(Text, primary_key=True) task_id: Mapped[str] = mapped_column(Text, nullable=False, index=True) request_id: Mapped[str | None] = mapped_column(Text, nullable=True, index=True) action: Mapped[str] = mapped_column(Text, nullable=False, index=True) operator_user_id: Mapped[str | None] = mapped_column(Text, nullable=True) operator_user_name: Mapped[str | None] = mapped_column(Text, nullable=True) target: Mapped[str | None] = mapped_column(Text, nullable=True) result: Mapped[str] = mapped_column(Text, nullable=False) detail_json: Mapped[str] = mapped_column(Text, nullable=False) timestamp: Mapped[str] = mapped_column(Text, nullable=False, index=True)