39 lines
1.3 KiB
Ruby
39 lines
1.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Scheduler::SuspendedUserCleanupScheduler
|
|
include Sidekiq::Worker
|
|
|
|
# Each processed deletion request may enqueue an enormous
|
|
# amount of jobs in the `pull` queue, so only enqueue when
|
|
# the queue is empty or close to being so.
|
|
MAX_PULL_SIZE = 50
|
|
|
|
# Since account deletion is very expensive, we want to avoid
|
|
# overloading the server by queuing too much at once.
|
|
# This job runs approximately once per 2 minutes, so with a
|
|
# value of `MAX_DELETIONS_PER_JOB` of 10, a server can
|
|
# handle the deletion of 7200 accounts per day, provided it
|
|
# has the capacity for it.
|
|
MAX_DELETIONS_PER_JOB = 10
|
|
|
|
sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.day.to_i
|
|
|
|
def perform
|
|
return if Sidekiq::Queue.new('pull').size > MAX_PULL_SIZE
|
|
|
|
process_deletion_requests!
|
|
end
|
|
|
|
private
|
|
|
|
def process_deletion_requests!
|
|
# This should be fine because we only process a small amount of deletion requests at once and
|
|
# `id` and `created_at` should follow the same order.
|
|
AccountDeletionRequest.reorder(id: :asc).take(MAX_DELETIONS_PER_JOB).each do |deletion_request|
|
|
next unless deletion_request.created_at < AccountDeletionRequest::DELAY_TO_DELETION.ago
|
|
|
|
Admin::AccountDeletionWorker.perform_async(deletion_request.account_id)
|
|
end
|
|
end
|
|
end
|