mirror of
https://github.com/mastodon/mastodon.git
synced 2025-07-12 15:33:14 +00:00

Some checks are pending
Bundler Audit / security (push) Waiting to run
Check i18n / check-i18n (push) Waiting to run
CodeQL / Analyze (javascript) (push) Waiting to run
CodeQL / Analyze (ruby) (push) Waiting to run
Crowdin / Upload translations / upload-translations (push) Waiting to run
Check formatting / lint (push) Waiting to run
CSS Linting / lint (push) Waiting to run
Haml Linting / lint (push) Waiting to run
JavaScript Linting / lint (push) Waiting to run
Ruby Linting / lint (push) Waiting to run
JavaScript Testing / test (push) Waiting to run
Historical data migration test / test (14-alpine) (push) Waiting to run
Historical data migration test / test (15-alpine) (push) Waiting to run
Historical data migration test / test (16-alpine) (push) Waiting to run
Historical data migration test / test (17-alpine) (push) Waiting to run
Ruby Testing / build (production) (push) Waiting to run
Ruby Testing / build (test) (push) Waiting to run
Ruby Testing / test (.ruby-version) (push) Blocked by required conditions
Ruby Testing / test (3.2) (push) Blocked by required conditions
Ruby Testing / test (3.3) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (.ruby-version) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.2) (push) Blocked by required conditions
Ruby Testing / ImageMagick tests (3.3) (push) Blocked by required conditions
Ruby Testing / End to End testing (.ruby-version) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.2) (push) Blocked by required conditions
Ruby Testing / End to End testing (3.3) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, docker.elastic.co/elasticsearch/elasticsearch:8.10.2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (.ruby-version, opensearchproject/opensearch:2) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.2, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
Ruby Testing / Elastic Search integration testing (3.3, docker.elastic.co/elasticsearch/elasticsearch:7.17.13) (push) Blocked by required conditions
73 lines
2.3 KiB
Ruby
73 lines
2.3 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
class Scheduler::SelfDestructScheduler
|
|
include Sidekiq::Worker
|
|
include SelfDestructHelper
|
|
|
|
MAX_ENQUEUED = 10_000
|
|
MAX_REDIS_MEM_USAGE = 0.5
|
|
MAX_ACCOUNT_DELETIONS_PER_JOB = 50
|
|
|
|
sidekiq_options retry: 0, lock: :until_executed, lock_ttl: 1.day.to_i
|
|
|
|
def perform
|
|
return unless self_destruct?
|
|
return if sidekiq_overwhelmed?
|
|
|
|
delete_accounts!
|
|
end
|
|
|
|
private
|
|
|
|
def sidekiq_overwhelmed?
|
|
redis_mem_info = Sidekiq.default_configuration.redis_info
|
|
|
|
Sidekiq::Stats.new.enqueued > MAX_ENQUEUED || redis_mem_info['used_memory'].to_f > redis_mem_info['total_system_memory'].to_f * MAX_REDIS_MEM_USAGE
|
|
end
|
|
|
|
def delete_accounts!
|
|
# We currently do not distinguish between deleted accounts and suspended
|
|
# accounts, and we do not want to remove the records in this scheduler, as
|
|
# we still rely on it for account delivery and don't want to perform
|
|
# needless work when the database can be outright dropped after the
|
|
# self-destruct.
|
|
# Deleted accounts are suspended accounts that do not have a pending
|
|
# deletion request.
|
|
|
|
# This targets accounts that have not been deleted nor marked for deletion yet
|
|
Account.local.without_suspended.reorder(id: :asc).take(MAX_ACCOUNT_DELETIONS_PER_JOB).each do |account|
|
|
delete_account!(account)
|
|
end
|
|
|
|
return if sidekiq_overwhelmed?
|
|
|
|
# This targets accounts that have been marked for deletion but have not been
|
|
# deleted yet
|
|
Account.local.suspended.joins(:deletion_request).take(MAX_ACCOUNT_DELETIONS_PER_JOB).each do |account|
|
|
delete_account!(account)
|
|
account.deletion_request&.destroy
|
|
end
|
|
end
|
|
|
|
def inboxes
|
|
@inboxes ||= Account.inboxes
|
|
end
|
|
|
|
def delete_account!(account)
|
|
payload = ActiveModelSerializers::SerializableResource.new(
|
|
account,
|
|
serializer: ActivityPub::DeleteActorSerializer,
|
|
adapter: ActivityPub::Adapter
|
|
).as_json
|
|
|
|
json = Oj.dump(ActivityPub::LinkedDataSignature.new(payload).sign!(account))
|
|
|
|
ActivityPub::DeliveryWorker.push_bulk(inboxes, limit: 1_000) do |inbox_url|
|
|
[json, account.id, inbox_url]
|
|
end
|
|
|
|
# Do not call `Account#suspend!` because we don't want to issue a deletion request
|
|
account.update!(suspended_at: Time.now.utc, suspension_origin: :local)
|
|
end
|
|
end
|