diff options
author | Thibaut Girka <thib@sitedethib.com> | 2019-03-10 16:48:44 +0100 |
---|---|---|
committer | Thibaut Girka <thib@sitedethib.com> | 2019-03-10 16:48:44 +0100 |
commit | dfe7322922e869ae72edb9b8980b905876db9ed0 (patch) | |
tree | bf279e7af52036451cf1c1fdc68b7b5748b5921d /app/services | |
parent | 42cc93e8923a1b6cdb61574e9a86e360cba56abb (diff) | |
parent | c11dff50493ecb106390153866bea539f3587293 (diff) |
Merge branch 'master' into glitch-soc/merge-upstream
Diffstat (limited to 'app/services')
-rw-r--r-- | app/services/suspend_account_service.rb | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/app/services/suspend_account_service.rb b/app/services/suspend_account_service.rb index b2ae3a47c..24fa1be69 100644 --- a/app/services/suspend_account_service.rb +++ b/app/services/suspend_account_service.rb @@ -41,6 +41,7 @@ class SuspendAccountService < BaseService @account = account @options = options + reject_follows! purge_user! purge_profile! purge_content! @@ -48,6 +49,14 @@ class SuspendAccountService < BaseService private + def reject_follows! + return if @account.local? || !@account.activitypub? + + ActivityPub::DeliveryWorker.push_bulk(Follow.where(account: @account)) do |follow| + [build_reject_json(follow), follow.target_account_id, follow.account.inbox_url] + end + end + def purge_user! return if !@account.local? || @account.user.nil? @@ -120,6 +129,14 @@ class SuspendAccountService < BaseService @delete_actor_json = Oj.dump(ActivityPub::LinkedDataSignature.new(payload).sign!(@account)) end + def build_reject_json(follow) + ActiveModelSerializers::SerializableResource.new( + follow, + serializer: ActivityPub::RejectFollowSerializer, + adapter: ActivityPub::Adapter + ).to_json + end + def delivery_inboxes @delivery_inboxes ||= @account.followers.inboxes + Relay.enabled.pluck(:inbox_url) end |