summaryrefslogtreecommitdiff
path: root/app/services/authorized_project_update/periodic_recalculate_service.rb
blob: 16dc76eb4cf73e1ee7507f876bc3ec7c8784b6ad (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
# frozen_string_literal: true

module AuthorizedProjectUpdate
  class PeriodicRecalculateService
    BATCH_SIZE = 450
    DELAY_INTERVAL = 50.seconds.to_i

    def execute
      # Using this approach (instead of eg. User.each_batch) keeps the arguments
      # the same for AuthorizedProjectUpdate::UserRefreshOverUserRangeWorker
      # even if the user list changes, so we can deduplicate these jobs.

      # Since UserRefreshOverUserRangeWorker has set data_consistency to delayed,
      # a job enqueued without a delay could fail because the replica could not catch up with the primary.
      # To prevent this, we start the index from `1` instead of `0` so as to ensure that
      # no UserRefreshOverUserRangeWorker job is enqueued without a delay.
      (1..User.maximum(:id)).each_slice(BATCH_SIZE).with_index(1) do |batch, index|
        delay = DELAY_INTERVAL * index
        AuthorizedProjectUpdate::UserRefreshOverUserRangeWorker.perform_in(delay, *batch.minmax)
      end
    end
  end
end