from datetime import datetime from core_db import AuditMixin, Base, EntityMixin, VersionMixin from core_shared import JSONValue from sqlalchemy import DateTime, String, Text from sqlalchemy.dialects.sqlite import JSON from sqlalchemy.orm import Mapped, mapped_column class AgentRun(EntityMixin, AuditMixin, VersionMixin, Base): __tablename__ = "agent_run" agent_id: Mapped[str] = mapped_column(String(36), index=True) agent_version_id: Mapped[str] = mapped_column(String(36), index=True) session_id: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True) status: Mapped[str] = mapped_column(String(32), default="queued", index=True) worker_key: Mapped[str | None] = mapped_column(String(128), nullable=True) queued_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) lease_expire_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) input_text: Mapped[str | None] = mapped_column(Text, nullable=True) input_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True) output_text: Mapped[str | None] = mapped_column(Text, nullable=True) output_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True) started_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) finished_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) error_code: Mapped[str | None] = mapped_column(String(64), nullable=True) error_message: Mapped[str | None] = mapped_column(Text, nullable=True)