print_batch.py 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, ForeignKey, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class PrintBatch(Base):
  6. """Batch grouping for multiple queue items created from the same file."""
  7. __tablename__ = "print_batches"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. name: Mapped[str] = mapped_column(String(255))
  10. # Source file (one of these)
  11. archive_id: Mapped[int | None] = mapped_column(ForeignKey("print_archives.id", ondelete="SET NULL"), nullable=True)
  12. library_file_id: Mapped[int | None] = mapped_column(
  13. ForeignKey("library_files.id", ondelete="SET NULL"), nullable=True
  14. )
  15. # Total requested quantity (for display — actual items may differ if cancelled)
  16. quantity: Mapped[int] = mapped_column(Integer, default=1)
  17. # Status: active, completed, cancelled
  18. status: Mapped[str] = mapped_column(String(20), default="active")
  19. # Timestamps
  20. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  21. # User tracking
  22. created_by_id: Mapped[int | None] = mapped_column(ForeignKey("users.id", ondelete="SET NULL"), nullable=True)
  23. # Relationships
  24. archive: Mapped["PrintArchive | None"] = relationship()
  25. library_file: Mapped["LibraryFile | None"] = relationship()
  26. created_by: Mapped["User | None"] = relationship()
  27. queue_items: Mapped[list["PrintQueueItem"]] = relationship(back_populates="batch")
  28. from backend.app.models.archive import PrintArchive # noqa: E402
  29. from backend.app.models.library import LibraryFile # noqa: E402
  30. from backend.app.models.print_queue import PrintQueueItem # noqa: E402
  31. from backend.app.models.user import User # noqa: E402