spool_k_profile.py 1.5 KB

12345678910111213141516171819202122232425262728293031
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, Float, ForeignKey, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class SpoolKProfile(Base):
  6. """K-value calibration profile for a spool on a specific printer/nozzle combo."""
  7. __tablename__ = "spool_k_profile"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. spool_id: Mapped[int] = mapped_column(ForeignKey("spool.id", ondelete="CASCADE"))
  10. printer_id: Mapped[int] = mapped_column(ForeignKey("printers.id", ondelete="CASCADE"))
  11. extruder: Mapped[int] = mapped_column(Integer, default=0) # 0 or 1 (H2D)
  12. nozzle_diameter: Mapped[str] = mapped_column(String(10), default="0.4") # "0.4", "0.6"
  13. nozzle_type: Mapped[str | None] = mapped_column(String(50))
  14. k_value: Mapped[float] = mapped_column(Float) # e.g. 0.020
  15. name: Mapped[str | None] = mapped_column(String(100)) # Profile display name
  16. cali_idx: Mapped[int | None] = mapped_column(Integer) # Calibration index on printer
  17. setting_id: Mapped[str | None] = mapped_column(String(50)) # Full setting ID
  18. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  19. spool: Mapped["Spool"] = relationship(back_populates="k_profiles")
  20. printer: Mapped["Printer"] = relationship()
  21. from backend.app.models.printer import Printer # noqa: E402, F401
  22. from backend.app.models.spool import Spool # noqa: E402, F401