print_queue.py 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  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. # Scheduling
  17. position: Mapped[int] = mapped_column(Integer, default=0) # Queue order
  18. scheduled_time: Mapped[datetime | None] = mapped_column(DateTime, nullable=True) # None = ASAP
  19. # Conditions
  20. require_previous_success: Mapped[bool] = mapped_column(Boolean, default=False)
  21. # Power management
  22. auto_off_after: Mapped[bool] = mapped_column(Boolean, default=False) # Power off printer after print
  23. # Status: pending, printing, completed, failed, skipped, cancelled
  24. status: Mapped[str] = mapped_column(String(20), default="pending")
  25. # Tracking
  26. started_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  27. completed_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  28. error_message: Mapped[str | None] = mapped_column(Text, nullable=True)
  29. # Timestamps
  30. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  31. # Relationships
  32. printer: Mapped["Printer"] = relationship()
  33. archive: Mapped["PrintArchive"] = relationship()
  34. from backend.app.models.printer import Printer # noqa: E402
  35. from backend.app.models.archive import PrintArchive # noqa: E402