spoolbuddy_device.py 2.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. from datetime import datetime
  2. from sqlalchemy import Boolean, DateTime, Float, Integer, String, Text, 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. nfc_reader_type: Mapped[str | None] = mapped_column(String(20))
  18. nfc_connection: Mapped[str | None] = mapped_column(String(20))
  19. backend_url: Mapped[str | None] = mapped_column(String(255), nullable=True)
  20. display_brightness: Mapped[int] = mapped_column(Integer, default=100)
  21. display_blank_timeout: Mapped[int] = mapped_column(Integer, default=0)
  22. has_backlight: Mapped[bool] = mapped_column(Boolean, default=False)
  23. last_calibrated_at: Mapped[datetime | None] = mapped_column(DateTime)
  24. last_seen: Mapped[datetime | None] = mapped_column(DateTime)
  25. pending_command: Mapped[str | None] = mapped_column(String(50))
  26. pending_write_payload: Mapped[str | None] = mapped_column(Text, nullable=True)
  27. update_status: Mapped[str | None] = mapped_column(String(20), nullable=True)
  28. update_message: Mapped[str | None] = mapped_column(String(255), nullable=True)
  29. pending_system_payload: Mapped[str | None] = mapped_column(Text, nullable=True)
  30. nfc_ok: Mapped[bool] = mapped_column(Boolean, default=False)
  31. scale_ok: Mapped[bool] = mapped_column(Boolean, default=False)
  32. uptime_s: Mapped[int] = mapped_column(Integer, default=0)
  33. system_stats: Mapped[str | None] = mapped_column(Text, nullable=True)
  34. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  35. updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())