archive.py 2.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. from datetime import datetime
  2. from sqlalchemy import String, Integer, Float, DateTime, ForeignKey, Text, JSON, Boolean, func
  3. from sqlalchemy.orm import Mapped, mapped_column, relationship
  4. from backend.app.core.database import Base
  5. class PrintArchive(Base):
  6. __tablename__ = "print_archives"
  7. id: Mapped[int] = mapped_column(primary_key=True)
  8. printer_id: Mapped[int | None] = mapped_column(ForeignKey("printers.id"), nullable=True)
  9. # File info
  10. filename: Mapped[str] = mapped_column(String(255))
  11. file_path: Mapped[str] = mapped_column(String(500))
  12. file_size: Mapped[int] = mapped_column(Integer)
  13. content_hash: Mapped[str | None] = mapped_column(String(64)) # SHA256 hash for duplicate detection
  14. thumbnail_path: Mapped[str | None] = mapped_column(String(500))
  15. timelapse_path: Mapped[str | None] = mapped_column(String(500))
  16. # Print details from 3MF / printer
  17. print_name: Mapped[str | None] = mapped_column(String(255))
  18. print_time_seconds: Mapped[int | None] = mapped_column(Integer)
  19. filament_used_grams: Mapped[float | None] = mapped_column(Float)
  20. filament_type: Mapped[str | None] = mapped_column(String(50))
  21. filament_color: Mapped[str | None] = mapped_column(String(50))
  22. layer_height: Mapped[float | None] = mapped_column(Float)
  23. total_layers: Mapped[int | None] = mapped_column(Integer)
  24. nozzle_diameter: Mapped[float | None] = mapped_column(Float)
  25. bed_temperature: Mapped[int | None] = mapped_column(Integer)
  26. nozzle_temperature: Mapped[int | None] = mapped_column(Integer)
  27. # Print result
  28. status: Mapped[str] = mapped_column(String(20), default="completed")
  29. started_at: Mapped[datetime | None] = mapped_column(DateTime)
  30. completed_at: Mapped[datetime | None] = mapped_column(DateTime)
  31. # Extended metadata (JSON blob for flexibility)
  32. extra_data: Mapped[dict | None] = mapped_column(JSON)
  33. # MakerWorld info
  34. makerworld_url: Mapped[str | None] = mapped_column(String(500))
  35. designer: Mapped[str | None] = mapped_column(String(255))
  36. # User additions
  37. is_favorite: Mapped[bool] = mapped_column(Boolean, default=False)
  38. tags: Mapped[str | None] = mapped_column(Text)
  39. notes: Mapped[str | None] = mapped_column(Text)
  40. cost: Mapped[float | None] = mapped_column(Float)
  41. photos: Mapped[list | None] = mapped_column(JSON) # List of photo filenames
  42. failure_reason: Mapped[str | None] = mapped_column(String(100)) # For failed prints
  43. # Energy tracking
  44. energy_kwh: Mapped[float | None] = mapped_column(Float) # Energy consumed in kWh
  45. energy_cost: Mapped[float | None] = mapped_column(Float) # Cost of energy consumed
  46. # Timestamps
  47. created_at: Mapped[datetime] = mapped_column(
  48. DateTime, server_default=func.now()
  49. )
  50. # Relationships
  51. printer: Mapped["Printer | None"] = relationship(back_populates="archives")
  52. from backend.app.models.printer import Printer # noqa: E402, F811