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)