auto_agent/backend/app/models/edge_task.py

28 lines
1.3 KiB
Python

from __future__ import annotations
from sqlalchemy import Integer, Text
from sqlalchemy.orm import Mapped, mapped_column
from app.db.base import Base
class EdgeTask(Base):
__tablename__ = "edge_task"
edge_task_id: Mapped[str] = mapped_column(Text, primary_key=True)
step_id: Mapped[str] = mapped_column(Text, nullable=False, unique=True, index=True)
task_id: Mapped[str] = mapped_column(Text, nullable=False, index=True)
edge_id: Mapped[str] = mapped_column(Text, nullable=False, index=True)
tool_name: Mapped[str] = mapped_column(Text, nullable=False)
params_json: Mapped[str] = mapped_column(Text, nullable=False)
step_status: Mapped[str] = mapped_column(Text, nullable=False, index=True)
success: Mapped[int | None] = mapped_column(Integer, nullable=True)
message: Mapped[str | None] = mapped_column(Text, nullable=True)
result_data_json: Mapped[str] = mapped_column(Text, nullable=False)
evidence_json: Mapped[str] = mapped_column(Text, nullable=False)
expire_at: Mapped[str] = mapped_column(Text, nullable=False)
started_at: Mapped[str | None] = mapped_column(Text, nullable=True)
finished_at: Mapped[str | None] = mapped_column(Text, nullable=True)
created_at: Mapped[str] = mapped_column(Text, nullable=False)
updated_at: Mapped[str] = mapped_column(Text, nullable=False)