github_backup.py 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465
  1. """GitHub backup configuration and log models."""
  2. from datetime import datetime
  3. from sqlalchemy import Boolean, DateTime, ForeignKey, Integer, String, Text, func
  4. from sqlalchemy.orm import Mapped, mapped_column, relationship
  5. from backend.app.core.database import Base
  6. class GitHubBackupConfig(Base):
  7. """Configuration for GitHub profile backup."""
  8. __tablename__ = "github_backup_config"
  9. id: Mapped[int] = mapped_column(primary_key=True)
  10. repository_url: Mapped[str] = mapped_column(String(500)) # Full GitHub URL
  11. access_token: Mapped[str] = mapped_column(Text) # Personal Access Token
  12. branch: Mapped[str] = mapped_column(String(100), default="main")
  13. # Schedule configuration
  14. schedule_enabled: Mapped[bool] = mapped_column(Boolean, default=False)
  15. schedule_type: Mapped[str] = mapped_column(String(20), default="daily") # hourly/daily/weekly
  16. schedule_cron: Mapped[str | None] = mapped_column(String(100), nullable=True) # For future cron support
  17. # What to backup
  18. backup_kprofiles: Mapped[bool] = mapped_column(Boolean, default=True)
  19. backup_cloud_profiles: Mapped[bool] = mapped_column(Boolean, default=True)
  20. backup_settings: Mapped[bool] = mapped_column(Boolean, default=False)
  21. # Status tracking
  22. enabled: Mapped[bool] = mapped_column(Boolean, default=True)
  23. last_backup_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  24. last_backup_status: Mapped[str | None] = mapped_column(String(20), nullable=True) # success/failed/skipped
  25. last_backup_message: Mapped[str | None] = mapped_column(Text, nullable=True)
  26. last_backup_commit_sha: Mapped[str | None] = mapped_column(String(40), nullable=True)
  27. next_scheduled_run: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  28. # Timestamps
  29. created_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  30. updated_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now(), onupdate=func.now())
  31. # Relationships
  32. logs: Mapped[list["GitHubBackupLog"]] = relationship(back_populates="config", cascade="all, delete-orphan")
  33. class GitHubBackupLog(Base):
  34. """Log entry for GitHub backup runs."""
  35. __tablename__ = "github_backup_logs"
  36. id: Mapped[int] = mapped_column(primary_key=True)
  37. config_id: Mapped[int] = mapped_column(ForeignKey("github_backup_config.id", ondelete="CASCADE"))
  38. started_at: Mapped[datetime] = mapped_column(DateTime, server_default=func.now())
  39. completed_at: Mapped[datetime | None] = mapped_column(DateTime, nullable=True)
  40. status: Mapped[str] = mapped_column(String(20)) # running/success/failed/skipped
  41. trigger: Mapped[str] = mapped_column(String(20)) # manual/scheduled
  42. commit_sha: Mapped[str | None] = mapped_column(String(40), nullable=True)
  43. files_changed: Mapped[int] = mapped_column(Integer, default=0)
  44. error_message: Mapped[str | None] = mapped_column(Text, nullable=True)
  45. # Relationships
  46. config: Mapped["GitHubBackupConfig"] = relationship(back_populates="logs")