22 lines
931 B
Python
22 lines
931 B
Python
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)
|