2017-07-24 14:17:55 +00:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
class Scheduler::UserCleanupScheduler
|
|
|
|
include Sidekiq::Worker
|
|
|
|
|
2024-05-15 08:27:34 +00:00
|
|
|
UNCONFIRMED_ACCOUNTS_MAX_AGE_DAYS = 7
|
|
|
|
DISCARDED_STATUSES_MAX_AGE_DAYS = 30
|
|
|
|
|
2023-08-03 09:04:05 +00:00
|
|
|
sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.day.to_i
|
2018-08-19 13:48:29 +00:00
|
|
|
|
2017-07-24 14:17:55 +00:00
|
|
|
def perform
|
2020-09-15 12:37:58 +00:00
|
|
|
clean_unconfirmed_accounts!
|
2022-01-17 08:41:33 +00:00
|
|
|
clean_discarded_statuses!
|
2020-09-15 12:37:58 +00:00
|
|
|
end
|
|
|
|
|
|
|
|
private
|
|
|
|
|
|
|
|
def clean_unconfirmed_accounts!
|
2024-10-02 12:26:16 +00:00
|
|
|
User.unconfirmed.where(confirmation_sent_at: ..UNCONFIRMED_ACCOUNTS_MAX_AGE_DAYS.days.ago).find_in_batches do |batch|
|
2022-11-01 11:59:23 +00:00
|
|
|
# We have to do it separately because of missing database constraints
|
2023-02-07 00:14:44 +00:00
|
|
|
AccountModerationNote.where(target_account_id: batch.map(&:account_id)).delete_all
|
2024-12-05 09:38:48 +00:00
|
|
|
WebauthnCredential.where(user_id: batch.map(&:id)).delete_all
|
2017-07-24 14:17:55 +00:00
|
|
|
Account.where(id: batch.map(&:account_id)).delete_all
|
|
|
|
User.where(id: batch.map(&:id)).delete_all
|
|
|
|
end
|
|
|
|
end
|
2020-09-15 12:37:58 +00:00
|
|
|
|
2022-01-17 08:41:33 +00:00
|
|
|
def clean_discarded_statuses!
|
2024-05-20 09:37:36 +00:00
|
|
|
Status.unscoped.discarded.where(deleted_at: ..DISCARDED_STATUSES_MAX_AGE_DAYS.days.ago).find_in_batches do |statuses|
|
2022-01-17 08:41:33 +00:00
|
|
|
RemovalWorker.push_bulk(statuses) do |status|
|
2023-06-20 16:04:35 +00:00
|
|
|
[status.id, { 'immediate' => true, 'skip_streaming' => true }]
|
2022-01-17 08:41:33 +00:00
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|
2017-07-24 14:17:55 +00:00
|
|
|
end
|