print_queue.py 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. from datetime import datetime
  2. from sqlalchemy import String, Boolean, Integer, DateTime, ForeignKey, Text, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class PrintQueueItem(Base):
  6. """Print queue item for scheduled/queued prints."""
  7. __tablename__ = "print_queue"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. # Links
  10. printer_id: Mapped[int] = mapped_column(
  11. ForeignKey("printers.id", ondelete="CASCADE")
  12. )
  13. archive_id: Mapped[int] = mapped_column(
  14. ForeignKey("print_archives.id", ondelete="CASCADE")
  15. )
  16. project_id: Mapped[int | None] = mapped_column(
  17. ForeignKey("projects.id", ondelete="SET NULL"), nullable=True
  18. )
  19. # Scheduling
  20. position: Mapped[int] = mapped_column(Integer, default=0) # Queue order
  21. scheduled_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) # None = ASAP
  22. # Conditions
  23. require_previous_success: Mapped[bool] = mapped_column(Boolean, default=False)
  24. # Power management
  25. auto_off_after: Mapped[bool] = mapped_column(Boolean, default=False) # Power off printer after print
  26. # Status: pending, printing, completed, failed, skipped, cancelled
  27. status: Mapped[str] = mapped_column(String(20), default="pending")
  28. # Tracking
  29. started_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  30. completed_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  31. error_message: Mapped[str | None] = mapped_column(Text, nullable=True)
  32. # Timestamps
  33. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  34. # Relationships
  35. printer: Mapped["Printer"] = relationship()
  36. archive: Mapped["PrintArchive"] = relationship()
  37. project: Mapped["Project | None"] = relationship(back_populates="queue_items")
  38. from backend.app.models.printer import Printer # noqa: E402
  39. from backend.app.models.archive import PrintArchive # noqa: E402
  40. from backend.app.models.project import Project # noqa: E402