2017-07-24 16:17:55 +02:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class Scheduler::UserCleanupScheduler
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2021-03-15 11:17:43 +01:00
|
|
|
sidekiq_options retry: 0
|
2018-08-19 15:48:29 +02:00
|
|
|
|
2017-07-24 16:17:55 +02:00
|
|
|
def perform
|
2020-09-15 14:37:58 +02:00
|
|
|
clean_unconfirmed_accounts!
|
|
|
|
clean_suspended_accounts!
|
2022-01-17 09:41:33 +01:00
|
|
|
clean_discarded_statuses!
|
2020-09-15 14:37:58 +02:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def clean_unconfirmed_accounts!
|
2018-08-21 12:25:50 +02:00
|
|
|
User.where('confirmed_at is NULL AND confirmation_sent_at <= ?', 2.days.ago).reorder(nil).find_in_batches do |batch|
|
2023-02-09 21:01:38 +01:00
|
|
|
# We have to do it separately because of missing database constraints
|
|
|
|
AccountModerationNote.where(target_account_id: batch.map(&:account_id)).delete_all
|
2017-07-24 16:17:55 +02:00
|
|
|
Account.where(id: batch.map(&:account_id)).delete_all
|
|
|
|
User.where(id: batch.map(&:id)).delete_all
|
|
|
|
end
|
|
|
|
end
|
2020-09-15 14:37:58 +02:00
|
|
|
|
|
|
|
def clean_suspended_accounts!
|
|
|
|
AccountDeletionRequest.where('created_at <= ?', AccountDeletionRequest::DELAY_TO_DELETION.ago).reorder(nil).find_each do |deletion_request|
|
|
|
|
Admin::AccountDeletionWorker.perform_async(deletion_request.account_id)
|
|
|
|
end
|
|
|
|
end
|
2022-01-17 09:41:33 +01:00
|
|
|
|
|
|
|
def clean_discarded_statuses!
|
2022-03-19 17:24:08 +09:00
|
|
|
Status.unscoped.discarded.where('deleted_at <= ?', 30.days.ago).find_in_batches do |statuses|
|
2022-01-17 09:41:33 +01:00
|
|
|
RemovalWorker.push_bulk(statuses) do |status|
|
2023-06-20 18:04:35 +02:00
|
|
|
[status.id, { 'immediate' => true, 'skip_streaming' => true }]
|
2022-01-17 09:41:33 +01:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-07-24 16:17:55 +02:00
|
|
|
end
|