summaryrefslogtreecommitdiff
path: root/app/workers/authorized_projects_worker.rb
blob: 09559e3b6968ef0e8f4e4d95c6093064a528a025 (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
class AuthorizedProjectsWorker
  include ApplicationWorker

  # Schedules multiple jobs and waits for them to be completed.
  def self.bulk_perform_and_wait(args_list)
    # Short-circuit: it's more efficient to do small numbers of jobs inline
    return bulk_perform_inline(args_list) if args_list.size <= 3

    waiter = Gitlab::JobWaiter.new(args_list.size)

    # Point all the bulk jobs at the same JobWaiter. Converts, [[1], [2], [3]]
    # into [[1, "key"], [2, "key"], [3, "key"]]
    waiting_args_list = args_list.map { |args| [*args, waiter.key] }
    bulk_perform_async(waiting_args_list)

    waiter.wait
  end

  # Performs multiple jobs directly. Failed jobs will be put into sidekiq so
  # they can benefit from retries
  def self.bulk_perform_inline(args_list)
    failed = []

    args_list.each do |args|
      begin
        new.perform(*args)
      rescue
        failed << args
      end
    end

    bulk_perform_async(failed) if failed.present?
  end

  def perform(user_id, notify_key = nil)
    user = User.find_by(id: user_id)

    user&.refresh_authorized_projects
  ensure
    Gitlab::JobWaiter.notify(notify_key, jid) if notify_key
  end
end