Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
Diffstat (limited to 'app/workers/geo/project_sync_worker.rb')
-rw-r--r--app/workers/geo/project_sync_worker.rb35
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