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
 |