agent_run.py 1.5 KB

12345678910111213141516171819202122232425262728
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, String, Text
  3. from sqlalchemy.dialects.sqlite import JSON
  4. from sqlalchemy.orm import Mapped, mapped_column
  5. from core_db import AuditMixin, Base, TenantMixin, VersionMixin
  6. from core_shared import JSONValue
  7. class AgentRun(TenantMixin, AuditMixin, VersionMixin, Base):
  8. __tablename__ = "agent_run"
  9. agent_id: Mapped[str] = mapped_column(String(36), index=True)
  10. agent_version_id: Mapped[str] = mapped_column(String(36), index=True)
  11. session_id: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True)
  12. status: Mapped[str] = mapped_column(String(32), default="queued", index=True)
  13. worker_key: Mapped[str | None] = mapped_column(String(128), nullable=True)
  14. queued_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  15. lease_expire_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  16. input_text: Mapped[str | None] = mapped_column(Text, nullable=True)
  17. input_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True)
  18. output_text: Mapped[str | None] = mapped_column(Text, nullable=True)
  19. output_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True)
  20. started_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  21. finished_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  22. error_code: Mapped[str | None] = mapped_column(String(64), nullable=True)
  23. error_message: Mapped[str | None] = mapped_column(Text, nullable=True)