from sqlalchemy import Column, Integer, String, DateTime, Boolean, Text, JSON, ForeignKey, UniqueConstraint from sqlalchemy.orm import relationship import datetime from .base import Base class IntentDB(Base): __tablename__ = "intents" id = Column(Integer, primary_key=True, index=True) deterministic_id = Column(String(64), unique=True, index=True, nullable=False) intent_type = Column(String(64), nullable=False) payload = Column(JSON, nullable=False) oss_payload = Column(JSON, nullable=True) environment = Column(String(32), nullable=True) created_at = Column(DateTime, default=datetime.datetime.utcnow, nullable=False) evaluated_at = Column(DateTime, nullable=True) risk_score = Column(String(32), nullable=True) outcomes = relationship("OutcomeDB", back_populates="intent", cascade="all, delete-orphan") class OutcomeDB(Base): __tablename__ = "intent_outcomes" id = Column(Integer, primary_key=True, index=True) intent_id = Column(Integer, ForeignKey("intents.id", ondelete="CASCADE"), nullable=False) success = Column(Boolean, nullable=False) recorded_by = Column(String(128), nullable=True) notes = Column(Text, nullable=True) recorded_at = Column(DateTime, default=datetime.datetime.utcnow, nullable=False) intent = relationship("IntentDB", back_populates="outcomes") __table_args__ = ( UniqueConstraint("intent_id", name="uq_outcome_intentid"), )