ams_history.py 1.2 KB

12345678910111213141516171819202122232425262728293031
  1. from datetime import datetime
  2. from sqlalchemy import Integer, Float, DateTime, ForeignKey, String, func, Index
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class AMSSensorHistory(Base):
  6. """Historical sensor data from AMS units (humidity and temperature)."""
  7. __tablename__ = "ams_sensor_history"
  8. id: Mapped[int] = mapped_column(primary_key=True)
  9. printer_id: Mapped[int] = mapped_column(ForeignKey("printers.id", ondelete="CASCADE"))
  10. ams_id: Mapped[int] = mapped_column(Integer) # AMS unit index (0, 1, 2, 3)
  11. humidity: Mapped[float | None] = mapped_column(Float) # Humidity percentage
  12. humidity_raw: Mapped[float | None] = mapped_column(Float) # Raw humidity value
  13. temperature: Mapped[float | None] = mapped_column(Float) # Temperature in Celsius
  14. recorded_at: Mapped[datetime] = mapped_column(
  15. DateTime, server_default=func.now(), index=True
  16. )
  17. # Indexes for efficient querying
  18. __table_args__ = (
  19. Index('ix_ams_history_printer_ams_time', 'printer_id', 'ams_id', 'recorded_at'),
  20. )
  21. # Relationship
  22. printer: Mapped["Printer"] = relationship(back_populates="ams_history")
  23. from backend.app.models.printer import Printer # noqa: E402