summaryrefslogtreecommitdiff
path: root/app/workers/project_migrate_hashed_storage_worker.rb
blob: e3ecd6bc950a86cb3b52a9a898ef55642374c2f9 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
class ProjectMigrateHashedStorageWorker
  include Sidekiq::Worker
  include DedicatedSidekiqQueue

  LEASE_TIMEOUT = 30.seconds.to_i

  def perform(project_id)
    project = Project.find_by(id: project_id)
    return if project.nil? || project.pending_delete?

    uuid = try_obtain_lease_for(project_id)
    if uuid
      ::Projects::HashedStorageMigrationService.new(project, logger).execute
    else
      false
    end
  rescue => ex
    cancel_lease_for(project_id, uuid)
    raise ex
  end

  private

  def try_obtain_lease_for(project_id)
    Gitlab::ExclusiveLease.new(lease_key(project_id), timeout: LEASE_TIMEOUT).try_obtain
  end

  def lease_key(project_id)
    "project_migrate_hashed_storage_worker:#{project_id}"
  end

  def cancel_lease_for(project_id, uuid)
    Gitlab::ExclusiveLease.cancel(lease_key(project_id), uuid)
  end
end