print_log.py 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. from datetime import datetime
  2. from sqlalchemy import DateTime, Float, ForeignKey, Integer, String, func
  3. from sqlalchemy.orm import Mapped, mapped_column
  4. from backend.app.core.database import Base
  5. class PrintLogEntry(Base):
  6. """Independent print log entry. Written when print events occur.
  7. This is a separate table from archives/queue — clearing the log
  8. never touches archives or queue items.
  9. archive_id is a nullable FK so log entries survive archive deletion (ON
  10. DELETE SET NULL). Aggregating runs per archive — for the per-archive
  11. "Print Log" view and for statistics that should not double-count
  12. overwritten archives (#1378) — is done via WHERE archive_id = X.
  13. """
  14. __tablename__ = "print_log_entries"
  15. id: Mapped[int] = mapped_column(primary_key=True)
  16. archive_id: Mapped[int | None] = mapped_column(
  17. ForeignKey("print_archives.id", ondelete="SET NULL"), nullable=True, index=True
  18. )
  19. print_name: Mapped[str | None] = mapped_column(String(255))
  20. printer_name: Mapped[str | None] = mapped_column(String(255))
  21. printer_id: Mapped[int | None] = mapped_column(Integer)
  22. status: Mapped[str] = mapped_column(String(20)) # completed, failed, stopped, cancelled, skipped
  23. started_at: Mapped[datetime | None] = mapped_column(DateTime)
  24. completed_at: Mapped[datetime | None] = mapped_column(DateTime)
  25. duration_seconds: Mapped[int | None] = mapped_column(Integer)
  26. filament_type: Mapped[str | None] = mapped_column(String(50))
  27. filament_color: Mapped[str | None] = mapped_column(String(50))
  28. filament_used_grams: Mapped[float | None] = mapped_column(Float)
  29. cost: Mapped[float | None] = mapped_column(Float)
  30. energy_kwh: Mapped[float | None] = mapped_column(Float)
  31. energy_cost: Mapped[float | None] = mapped_column(Float)
  32. failure_reason: Mapped[str | None] = mapped_column(String(100))
  33. thumbnail_path: Mapped[str | None] = mapped_column(String(500))
  34. created_by_id: Mapped[int | None] = mapped_column(ForeignKey("users.id", ondelete="SET NULL"), nullable=True)
  35. created_by_username: Mapped[str | None] = mapped_column(String(100))
  36. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())