Reject existing Follows when suspending a remote account (#10230)
* Reject existing Follows when suspending a remote account Partial fix to #10229 * Add testsgh/stable
parent
dbeab5a036
commit
c11dff5049
|
@ -41,6 +41,7 @@ class SuspendAccountService < BaseService
|
||||||
@account = account
|
@account = account
|
||||||
@options = options
|
@options = options
|
||||||
|
|
||||||
|
reject_follows!
|
||||||
purge_user!
|
purge_user!
|
||||||
purge_profile!
|
purge_profile!
|
||||||
purge_content!
|
purge_content!
|
||||||
|
@ -48,6 +49,14 @@ class SuspendAccountService < BaseService
|
||||||
|
|
||||||
private
|
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!
|
def purge_user!
|
||||||
return if !@account.local? || @account.user.nil?
|
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))
|
@delete_actor_json = Oj.dump(ActivityPub::LinkedDataSignature.new(payload).sign!(@account))
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def build_reject_json(follow)
|
||||||
|
ActiveModelSerializers::SerializableResource.new(
|
||||||
|
follow,
|
||||||
|
serializer: ActivityPub::RejectFollowSerializer,
|
||||||
|
adapter: ActivityPub::Adapter
|
||||||
|
).to_json
|
||||||
|
end
|
||||||
|
|
||||||
def delivery_inboxes
|
def delivery_inboxes
|
||||||
@delivery_inboxes ||= @account.followers.inboxes + Relay.enabled.pluck(:inbox_url)
|
@delivery_inboxes ||= @account.followers.inboxes + Relay.enabled.pluck(:inbox_url)
|
||||||
end
|
end
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
require 'rails_helper'
|
require 'rails_helper'
|
||||||
|
|
||||||
RSpec.describe SuspendAccountService, type: :service do
|
RSpec.describe SuspendAccountService, type: :service do
|
||||||
describe '#call' do
|
describe '#call on local account' do
|
||||||
before do
|
before do
|
||||||
stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
|
stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
|
||||||
stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
|
stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
|
||||||
|
@ -43,4 +43,46 @@ RSpec.describe SuspendAccountService, type: :service do
|
||||||
expect(a_request(:post, "https://bob.com/inbox")).to have_been_made.once
|
expect(a_request(:post, "https://bob.com/inbox")).to have_been_made.once
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
describe '#call on remote account' do
|
||||||
|
before do
|
||||||
|
stub_request(:post, "https://alice.com/inbox").to_return(status: 201)
|
||||||
|
stub_request(:post, "https://bob.com/inbox").to_return(status: 201)
|
||||||
|
end
|
||||||
|
|
||||||
|
subject do
|
||||||
|
-> { described_class.new.call(remote_bob) }
|
||||||
|
end
|
||||||
|
|
||||||
|
let!(:account) { Fabricate(:account) }
|
||||||
|
let!(:remote_alice) { Fabricate(:account, inbox_url: 'https://alice.com/inbox', protocol: :activitypub) }
|
||||||
|
let!(:remote_bob) { Fabricate(:account, inbox_url: 'https://bob.com/inbox', protocol: :activitypub) }
|
||||||
|
let!(:status) { Fabricate(:status, account: remote_bob) }
|
||||||
|
let!(:media_attachment) { Fabricate(:media_attachment, account: remote_bob) }
|
||||||
|
let!(:notification) { Fabricate(:notification, account: remote_bob) }
|
||||||
|
let!(:favourite) { Fabricate(:favourite, account: remote_bob) }
|
||||||
|
let!(:active_relationship) { Fabricate(:follow, account: remote_bob, target_account: account) }
|
||||||
|
let!(:passive_relationship) { Fabricate(:follow, target_account: remote_bob) }
|
||||||
|
let!(:subscription) { Fabricate(:subscription, account: remote_bob) }
|
||||||
|
|
||||||
|
it 'deletes associated records' do
|
||||||
|
is_expected.to change {
|
||||||
|
[
|
||||||
|
remote_bob.statuses,
|
||||||
|
remote_bob.media_attachments,
|
||||||
|
remote_bob.stream_entries,
|
||||||
|
remote_bob.notifications,
|
||||||
|
remote_bob.favourites,
|
||||||
|
remote_bob.active_relationships,
|
||||||
|
remote_bob.passive_relationships,
|
||||||
|
remote_bob.subscriptions
|
||||||
|
].map(&:count)
|
||||||
|
}.from([1, 1, 1, 1, 1, 1, 1, 1]).to([0, 0, 0, 0, 0, 0, 0, 0])
|
||||||
|
end
|
||||||
|
|
||||||
|
it 'sends a reject follow to follwer inboxes' do
|
||||||
|
subject.call
|
||||||
|
expect(a_request(:post, remote_bob.inbox_url)).to have_been_made.once
|
||||||
|
end
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Reference in New Issue