| 1234567891011121314151617181920212223242526272829303132333435363738 |
- from datetime import datetime
- from sqlalchemy import Boolean, DateTime, Float, Integer, String, Text, func
- from sqlalchemy.orm import Mapped, mapped_column
- from backend.app.core.database import Base
- class SpoolBuddyDevice(Base):
- """SpoolBuddy device registration for RPi-based filament management stations."""
- __tablename__ = "spoolbuddy_devices"
- id: Mapped[int] = mapped_column(primary_key=True)
- device_id: Mapped[str] = mapped_column(String(50), unique=True, index=True)
- hostname: Mapped[str] = mapped_column(String(100))
- ip_address: Mapped[str] = mapped_column(String(45))
- firmware_version: Mapped[str | None] = mapped_column(String(20))
- has_nfc: Mapped[bool] = mapped_column(Boolean, default=True)
- has_scale: Mapped[bool] = mapped_column(Boolean, default=True)
- tare_offset: Mapped[int] = mapped_column(Integer, default=0)
- calibration_factor: Mapped[float] = mapped_column(Float, default=1.0)
- nfc_reader_type: Mapped[str | None] = mapped_column(String(20))
- nfc_connection: Mapped[str | None] = mapped_column(String(20))
- display_brightness: Mapped[int] = mapped_column(Integer, default=100)
- display_blank_timeout: Mapped[int] = mapped_column(Integer, default=0)
- has_backlight: Mapped[bool] = mapped_column(Boolean, default=False)
- last_calibrated_at: Mapped[datetime | None] = mapped_column(DateTime)
- last_seen: Mapped[datetime | None] = mapped_column(DateTime)
- pending_command: Mapped[str | None] = mapped_column(String(50))
- pending_write_payload: Mapped[str | None] = mapped_column(Text, nullable=True)
- update_status: Mapped[str | None] = mapped_column(String(20), nullable=True)
- update_message: Mapped[str | None] = mapped_column(String(255), nullable=True)
- nfc_ok: Mapped[bool] = mapped_column(Boolean, default=False)
- scale_ok: Mapped[bool] = mapped_column(Boolean, default=False)
- uptime_s: Mapped[int] = mapped_column(Integer, default=0)
- created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
- updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())
|