spoolbuddy_device.py 1.4 KB

1234567891011121314151617181920212223242526272829
  1. from datetime import datetime
  2. from sqlalchemy import Boolean, DateTime, Float, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from backend.app.core.database import Base
  5. class SpoolBuddyDevice(Base):
  6. """SpoolBuddy device registration for RPi-based filament management stations."""
  7. __tablename__ = "spoolbuddy_devices"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. device_id: Mapped[str] = mapped_column(String(50), unique=True, index=True)
  10. hostname: Mapped[str] = mapped_column(String(100))
  11. ip_address: Mapped[str] = mapped_column(String(45))
  12. firmware_version: Mapped[str | None] = mapped_column(String(20))
  13. has_nfc: Mapped[bool] = mapped_column(Boolean, default=True)
  14. has_scale: Mapped[bool] = mapped_column(Boolean, default=True)
  15. tare_offset: Mapped[int] = mapped_column(Integer, default=0)
  16. calibration_factor: Mapped[float] = mapped_column(Float, default=1.0)
  17. last_seen: Mapped[datetime | None] = mapped_column(DateTime)
  18. pending_command: Mapped[str | None] = mapped_column(String(50))
  19. nfc_ok: Mapped[bool] = mapped_column(Boolean, default=False)
  20. scale_ok: Mapped[bool] = mapped_column(Boolean, default=False)
  21. uptime_s: Mapped[int] = mapped_column(Integer, default=0)
  22. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  23. updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())