diff options
author | Claire <claire.github-309c@sitedethib.com> | 2023-03-03 20:25:15 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-03-03 20:25:15 +0100 |
commit | c2a046ded1d47e2504df05568e34bc6a2a6dc810 (patch) | |
tree | 8b36e3310d6fd141a10752752f88242f9138e876 /app/services | |
parent | 3a6451c867595fd58998ee1706589b15a69d993b (diff) |
Fix “Remove all followers from the selected domains” being more destructive than it claims (#23805)
Diffstat (limited to 'app/services')
-rw-r--r-- | app/services/remove_domains_from_followers_service.rb | 23 |
1 files changed, 23 insertions, 0 deletions
diff --git a/app/services/remove_domains_from_followers_service.rb b/app/services/remove_domains_from_followers_service.rb new file mode 100644 index 000000000..d76763409 --- /dev/null +++ b/app/services/remove_domains_from_followers_service.rb @@ -0,0 +1,23 @@ +# frozen_string_literal: true + +class RemoveDomainsFromFollowersService < BaseService + include Payloadable + + def call(source_account, target_domains) + source_account.passive_relationships.where(account_id: Account.where(domain: target_domains)).find_each do |follow| + follow.destroy + + create_notification(follow) if source_account.local? && !follow.account.local? && follow.account.activitypub? + end + end + + private + + def create_notification(follow) + ActivityPub::DeliveryWorker.perform_async(build_json(follow), follow.target_account_id, follow.account.inbox_url) + end + + def build_json(follow) + Oj.dump(serialize_payload(follow, ActivityPub::RejectFollowSerializer)) + end +end |