| 12345678910111213141516171819202122232425262728 |
- from datetime import datetime
- from core_db import AuditMixin, Base, EntityMixin
- from core_shared import JSONValue
- from sqlalchemy import DateTime, String, Text
- from sqlalchemy import JSON
- from sqlalchemy.orm import Mapped, mapped_column
- class HumanTask(EntityMixin, AuditMixin, Base):
- __tablename__ = "human_task"
- task_type: Mapped[str] = mapped_column(String(32), index=True)
- status: Mapped[str] = mapped_column(String(32), default="pending", index=True)
- title: Mapped[str] = mapped_column(String(128))
- description: Mapped[str | None] = mapped_column(Text, nullable=True)
- source_type: Mapped[str | None] = mapped_column(String(64), nullable=True, index=True)
- source_id: Mapped[str | None] = mapped_column(String(64), nullable=True, index=True)
- run_id: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True)
- node_run_id: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True)
- requested_by: Mapped[str | None] = mapped_column(String(36), nullable=True)
- assigned_to: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True)
- claimed_by: Mapped[str | None] = mapped_column(String(36), nullable=True, index=True)
- request_payload_json: Mapped[dict[str, JSONValue]] = mapped_column(JSON, default=dict)
- response_payload_json: Mapped[dict[str, JSONValue] | None] = mapped_column(JSON, nullable=True)
- due_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True, index=True)
- claimed_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
- completed_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
|