| 123456789101112131415161718192021 |
- from datetime import datetime
- from sqlalchemy import DateTime, Float, ForeignKey, Integer, String, func
- from sqlalchemy.orm import Mapped, mapped_column
- from backend.app.core.database import Base
- class SpoolUsageHistory(Base):
- """Record of filament consumption for a spool during a print."""
- __tablename__ = "spool_usage_history"
- id: Mapped[int] = mapped_column(primary_key=True)
- spool_id: Mapped[int] = mapped_column(ForeignKey("spool.id", ondelete="CASCADE"))
- printer_id: Mapped[int | None] = mapped_column(ForeignKey("printers.id", ondelete="SET NULL"))
- print_name: Mapped[str | None] = mapped_column(String(500))
- weight_used: Mapped[float] = mapped_column(Float, default=0)
- percent_used: Mapped[int] = mapped_column(Integer, default=0)
- status: Mapped[str] = mapped_column(String(20), default="completed") # completed/failed/aborted
- created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
|