summaryrefslogtreecommitdiff
path: root/app/workers/repository_update_remote_mirror_worker.rb
blob: c0bae08ba8525ef4a1fa97efe91ac48e87f7b327 (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
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
# frozen_string_literal: true

class RepositoryUpdateRemoteMirrorWorker
  UpdateAlreadyInProgressError = Class.new(StandardError)
  UpdateError = Class.new(StandardError)

  include ApplicationWorker

  sidekiq_options 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(remote_mirror_id, scheduled_time)
    remote_mirror = RemoteMirrorFinder.new(id: remote_mirror_id).execute
    return if remote_mirror.updated_since?(scheduled_time)

    raise UpdateAlreadyInProgressError if remote_mirror.update_in_progress?

    remote_mirror.update_start

    project = remote_mirror.project
    current_user = project.creator
    result = Projects::UpdateRemoteMirrorService.new(project, current_user).execute(remote_mirror)
    raise UpdateError, result[:message] if result[:status] == :error

    remote_mirror.update_finish
  rescue UpdateAlreadyInProgressError
    raise
  rescue UpdateError => ex
    fail_remote_mirror(remote_mirror, ex.message)
    raise
  rescue => ex
    return unless remote_mirror

    fail_remote_mirror(remote_mirror, ex.message)
    raise UpdateError, "#{ex.class}: #{ex.message}"
  end

  private

  def fail_remote_mirror(remote_mirror, message)
    remote_mirror.mark_as_failed(message)

    Rails.logger.error(message)
  end
end