diff options
Diffstat (limited to 'app/workers/geo/project_sync_worker.rb')
-rw-r--r-- | app/workers/geo/project_sync_worker.rb | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/app/workers/geo/project_sync_worker.rb b/app/workers/geo/project_sync_worker.rb new file mode 100644 index 00000000000..9530b013980 --- /dev/null +++ b/app/workers/geo/project_sync_worker.rb @@ -0,0 +1,35 @@ +module Geo + class ProjectSyncWorker + include Sidekiq::Worker + + sidekiq_options queue: :geo, retry: 3, dead: false + + sidekiq_retry_in { |count| 30 * count } + + sidekiq_retries_exhausted do |msg, _| + Sidekiq.logger.warn "Failed #{msg['class']} with #{msg['args']}: #{msg['error_message']}" + end + + def perform(project_id, scheduled_time) + project = Project.find(project_id) + registry = Geo::ProjectRegistry.find_or_initialize_by(project_id: project_id) + + Geo::RepositorySyncService.new(project).execute if sync_repository?(registry, scheduled_time) + Geo::WikiSyncService.new(project).execute if sync_wiki?(registry, scheduled_time) + rescue ActiveRecord::RecordNotFound + logger.error("Couldn't find project with ID=#{project_id}, skipping syncing") + end + + private + + def sync_repository?(registry, scheduled_time) + !registry.repository_synced_since?(scheduled_time) && + registry.resync_repository? + end + + def sync_wiki?(registry, scheduled_time) + !registry.wiki_synced_since?(scheduled_time) && + registry.resync_wiki? + end + end +end |