virtual_printer.py 1.8 KB

12345678910111213141516171819202122232425262728293031323334
  1. from datetime import datetime
  2. from sqlalchemy import Boolean, DateTime, ForeignKey, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from backend.app.core.database import Base
  5. class VirtualPrinter(Base):
  6. """Virtual printer configuration for multi-instance support."""
  7. __tablename__ = "virtual_printers"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. name: Mapped[str] = mapped_column(String(100), default="Bambuddy")
  10. enabled: Mapped[bool] = mapped_column(Boolean, default=False)
  11. mode: Mapped[str] = mapped_column(String(20), default="immediate") # immediate|review|print_queue|proxy
  12. auto_dispatch: Mapped[bool] = mapped_column(
  13. Boolean, server_default="true"
  14. ) # print_queue mode: auto-start or manual
  15. model: Mapped[str | None] = mapped_column(String(50), nullable=True) # SSDP model code (server mode)
  16. access_code: Mapped[str | None] = mapped_column(String(8), nullable=True) # 8 chars (server mode)
  17. target_printer_id: Mapped[int | None] = mapped_column(
  18. Integer, ForeignKey("printers.id", ondelete="SET NULL"), nullable=True
  19. ) # proxy mode
  20. bind_ip: Mapped[str | None] = mapped_column(String(45), nullable=True) # dedicated IP (proxy mode)
  21. remote_interface_ip: Mapped[str | None] = mapped_column(String(45), nullable=True) # SSDP advertise IP
  22. tailscale_disabled: Mapped[bool] = mapped_column(
  23. Boolean, server_default="true"
  24. ) # opt-in: user must explicitly enable; auto-detect only runs then
  25. serial_suffix: Mapped[str] = mapped_column(String(9), default="391800001") # unique per printer
  26. position: Mapped[int] = mapped_column(Integer, default=0)
  27. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  28. updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())