about summary refs log tree commit diff
path: root/app/services/remove_domains_from_followers_service.rb
diff options
context:
space:
mode:
authorClaire <claire.github-309c@sitedethib.com>2023-03-03 20:25:15 +0100
committerGitHub <noreply@github.com>2023-03-03 20:25:15 +0100
commitc2a046ded1d47e2504df05568e34bc6a2a6dc810 (patch)
tree8b36e3310d6fd141a10752752f88242f9138e876 /app/services/remove_domains_from_followers_service.rb
parent3a6451c867595fd58998ee1706589b15a69d993b (diff)
Fix “Remove all followers from the selected domains” being more destructive than it claims (#23805)
Diffstat (limited to 'app/services/remove_domains_from_followers_service.rb')
-rw-r--r--app/services/remove_domains_from_followers_service.rb23
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