auto_backup.go 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146
  1. package cron
  2. import (
  3. "fmt"
  4. "sync"
  5. "github.com/0xJacky/Nginx-UI/internal/backup"
  6. "github.com/go-co-op/gocron/v2"
  7. "github.com/uozi-tech/cosy/logger"
  8. )
  9. var (
  10. autoBackupJobs = make(map[uint64]gocron.Job)
  11. autoBackupMu sync.RWMutex
  12. )
  13. // setupAutoBackupJobs initializes all auto backup jobs from database
  14. func setupAutoBackupJobs(s gocron.Scheduler) error {
  15. autoBackups, err := backup.GetEnabledAutoBackups()
  16. if err != nil {
  17. return fmt.Errorf("failed to get enabled auto backups: %w", err)
  18. }
  19. for _, autoBackup := range autoBackups {
  20. err := addAutoBackupJob(s, autoBackup.ID, autoBackup.CronExpression)
  21. if err != nil {
  22. logger.Errorf("Failed to add auto backup job for %s: %v", autoBackup.Name, err)
  23. }
  24. }
  25. return nil
  26. }
  27. // addAutoBackupJob adds a single auto backup job to the scheduler
  28. func addAutoBackupJob(s gocron.Scheduler, backupID uint64, cronExpression string) error {
  29. autoBackupMu.Lock()
  30. defer autoBackupMu.Unlock()
  31. // Remove existing job if it exists
  32. if existingJob, exists := autoBackupJobs[backupID]; exists {
  33. err := s.RemoveJob(existingJob.ID())
  34. if err != nil {
  35. logger.Errorf("Failed to remove existing auto backup job %d: %v", backupID, err)
  36. }
  37. delete(autoBackupJobs, backupID)
  38. }
  39. // Create new job
  40. job, err := s.NewJob(
  41. gocron.CronJob(cronExpression, false),
  42. gocron.NewTask(executeAutoBackupTask, backupID),
  43. gocron.WithName(fmt.Sprintf("auto_backup_%d", backupID)),
  44. )
  45. if err != nil {
  46. return fmt.Errorf("failed to create auto backup job: %w", err)
  47. }
  48. autoBackupJobs[backupID] = job
  49. logger.Infof("Added auto backup job %d with cron expression: %s", backupID, cronExpression)
  50. return nil
  51. }
  52. // removeAutoBackupJob removes an auto backup job from the scheduler
  53. func removeAutoBackupJob(s gocron.Scheduler, backupID uint64) error {
  54. autoBackupMu.Lock()
  55. defer autoBackupMu.Unlock()
  56. if job, exists := autoBackupJobs[backupID]; exists {
  57. err := s.RemoveJob(job.ID())
  58. if err != nil {
  59. return fmt.Errorf("failed to remove auto backup job: %w", err)
  60. }
  61. delete(autoBackupJobs, backupID)
  62. logger.Infof("Removed auto backup job %d", backupID)
  63. }
  64. return nil
  65. }
  66. // executeAutoBackupTask executes a single auto backup task
  67. func executeAutoBackupTask(backupID uint64) {
  68. logger.Infof("Executing auto backup task %d", backupID)
  69. // Get backup configuration
  70. autoBackup, err := backup.GetAutoBackupByID(backupID)
  71. if err != nil {
  72. logger.Errorf("Failed to get auto backup configuration %d: %v", backupID, err)
  73. return
  74. }
  75. // Check if backup is still enabled
  76. if !autoBackup.Enabled {
  77. removeAutoBackupJob(s, backupID)
  78. logger.Infof("Auto backup %d is disabled, skipping execution", backupID)
  79. return
  80. }
  81. // Execute backup
  82. err = backup.ExecuteAutoBackup(autoBackup)
  83. if err != nil {
  84. logger.Errorf("Auto backup task %d failed: %v", backupID, err)
  85. } else {
  86. logger.Infof("Auto backup task %d completed successfully", backupID)
  87. }
  88. }
  89. // RestartAutoBackupJobs restarts all auto backup jobs
  90. func RestartAutoBackupJobs() error {
  91. logger.Info("Restarting auto backup jobs...")
  92. autoBackupMu.Lock()
  93. defer autoBackupMu.Unlock()
  94. // Remove all existing jobs
  95. for backupID, job := range autoBackupJobs {
  96. err := s.RemoveJob(job.ID())
  97. if err != nil {
  98. logger.Errorf("Failed to remove auto backup job %d: %v", backupID, err)
  99. }
  100. }
  101. autoBackupJobs = make(map[uint64]gocron.Job)
  102. // Re-add all enabled jobs
  103. err := setupAutoBackupJobs(s)
  104. if err != nil {
  105. return fmt.Errorf("failed to restart auto backup jobs: %w", err)
  106. }
  107. logger.Info("Auto backup jobs restarted successfully")
  108. return nil
  109. }
  110. // AddAutoBackupJob adds or updates an auto backup job (public API)
  111. func AddAutoBackupJob(backupID uint64, cronExpression string) error {
  112. return addAutoBackupJob(s, backupID, cronExpression)
  113. }
  114. // RemoveAutoBackupJob removes an auto backup job (public API)
  115. func RemoveAutoBackupJob(backupID uint64) error {
  116. return removeAutoBackupJob(s, backupID)
  117. }
  118. // UpdateAutoBackupJob updates an auto backup job (public API)
  119. func UpdateAutoBackupJob(backupID uint64, cronExpression string) error {
  120. return addAutoBackupJob(s, backupID, cronExpression)
  121. }