spool_assignment.py 1.5 KB

1234567891011121314151617181920212223242526272829303132333435
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, ForeignKey, Integer, String, UniqueConstraint, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class SpoolAssignment(Base):
  6. """Assignment of a spool to a specific AMS slot on a printer."""
  7. __tablename__ = "spool_assignment"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. spool_id: Mapped[int] = mapped_column(ForeignKey("spool.id", ondelete="CASCADE"))
  10. printer_id: Mapped[int] = mapped_column(ForeignKey("printers.id", ondelete="CASCADE"))
  11. ams_id: Mapped[int] = mapped_column(Integer) # 0-3, 128+ (HT), 254/255 (ext)
  12. tray_id: Mapped[int] = mapped_column(Integer) # 0-3
  13. fingerprint_color: Mapped[str | None] = mapped_column(String(8)) # tray_color snapshot
  14. fingerprint_type: Mapped[str | None] = mapped_column(String(50)) # tray_type snapshot
  15. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  16. spool: Mapped["Spool"] = relationship(back_populates="assignments")
  17. printer: Mapped["Printer"] = relationship()
  18. __table_args__ = (UniqueConstraint("printer_id", "ams_id", "tray_id"),)
  19. @property
  20. def printer_name(self) -> str | None:
  21. """Get printer name from loaded relationship."""
  22. return self.printer.name if self.printer else None
  23. from backend.app.models.printer import Printer # noqa: E402, F401
  24. from backend.app.models.spool import Spool # noqa: E402, F401