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 cost: Mapped[float | None] = mapped_column(Float) # Calculated cost for this usage event created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())