from sqlalchemy.orm import Mapped, mapped_column, relationship from sqlalchemy import String, Text, ForeignKey, Enum as SAEnum import enum from backend.models.base import Base, TimestampMixin class ActionStatut(str, enum.Enum): ouvert = "ouvert" en_cours = "en_cours" resolu = "resolu" class Action(Base, TimestampMixin): __tablename__ = "actions" id: Mapped[int] = mapped_column(primary_key=True, index=True) vulnerabilite_id: Mapped[int] = mapped_column(ForeignKey("vulnerabilites.id"), nullable=False, index=True) statut: Mapped[ActionStatut] = mapped_column(SAEnum(ActionStatut), default=ActionStatut.ouvert, nullable=False) assigne_a: Mapped[str | None] = mapped_column(String(255), nullable=True) note: Mapped[str | None] = mapped_column(Text, nullable=True) vulnerabilite: Mapped["Vulnerabilite"] = relationship("Vulnerabilite", back_populates="actions")