spoolman_k_profile.py 1.4 KB

12345678910111213141516171819202122232425262728293031323334
  1. from datetime import datetime
  2. from sqlalchemy import CheckConstraint, DateTime, Float, ForeignKey, Integer, String, UniqueConstraint, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class SpoolmanKProfile(Base):
  6. """K-value calibration profile for a Spoolman spool on a specific printer/nozzle combo."""
  7. __tablename__ = "spoolman_k_profile"
  8. __table_args__ = (
  9. UniqueConstraint("spoolman_spool_id", "printer_id", "extruder", "nozzle_diameter"),
  10. CheckConstraint("extruder >= 0 AND extruder <= 1", name="ck_extruder_range"),
  11. )
  12. id: Mapped[int] = mapped_column(primary_key=True)
  13. spoolman_spool_id: Mapped[int] = mapped_column(Integer, nullable=False)
  14. printer_id: Mapped[int] = mapped_column(ForeignKey("printers.id", ondelete="CASCADE"))
  15. extruder: Mapped[int] = mapped_column(Integer, default=0)
  16. nozzle_diameter: Mapped[str] = mapped_column(String(10), default="0.4")
  17. nozzle_type: Mapped[str | None] = mapped_column(String(50))
  18. k_value: Mapped[float] = mapped_column(Float)
  19. name: Mapped[str | None] = mapped_column(String(100))
  20. cali_idx: Mapped[int | None] = mapped_column(Integer)
  21. setting_id: Mapped[str | None] = mapped_column(String(50))
  22. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  23. printer: Mapped["Printer"] = relationship()
  24. from backend.app.models.printer import Printer # noqa: E402, F401