| 1234567891011121314151617181920212223242526272829 |
- from datetime import datetime
- from sqlalchemy import DateTime, String, Text
- from sqlalchemy.dialects.sqlite import JSON
- from sqlalchemy.orm import Mapped, mapped_column
- from core_db import AuditMixin, Base, TenantMixin, VersionMixin
- from core_shared import JSONValue
- class HumanTask(TenantMixin, AuditMixin, VersionMixin, 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)
|