Fix remote reporters not receiving suspend/unsuspend activities (#16050)
This commit is contained in:
parent
480d7c9478
commit
6d6000f61f
25
app/lib/account_reach_finder.rb
Normal file
25
app/lib/account_reach_finder.rb
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
# frozen_string_literal: true
|
||||||
|
|
||||||
|
class AccountReachFinder
|
||||||
|
def initialize(account)
|
||||||
|
@account = account
|
||||||
|
end
|
||||||
|
|
||||||
|
def inboxes
|
||||||
|
(followers_inboxes + reporters_inboxes + relay_inboxes).uniq
|
||||||
|
end
|
||||||
|
|
||||||
|
private
|
||||||
|
|
||||||
|
def followers_inboxes
|
||||||
|
@account.followers.inboxes
|
||||||
|
end
|
||||||
|
|
||||||
|
def reporters_inboxes
|
||||||
|
Account.where(id: @account.targeted_reports.select(:account_id)).inboxes
|
||||||
|
end
|
||||||
|
|
||||||
|
def relay_inboxes
|
||||||
|
Relay.enabled.pluck(:inbox_url)
|
||||||
|
end
|
||||||
|
end
|
|
@ -42,7 +42,13 @@ class SuspendAccountService < BaseService
|
||||||
end
|
end
|
||||||
|
|
||||||
def distribute_update_actor!
|
def distribute_update_actor!
|
||||||
ActivityPub::UpdateDistributionWorker.perform_async(@account.id) if @account.local?
|
return unless @account.local?
|
||||||
|
|
||||||
|
account_reach_finder = AccountReachFinder.new(@account)
|
||||||
|
|
||||||
|
ActivityPub::DeliveryWorker.push_bulk(account_reach_finder.inboxes) do |inbox_url|
|
||||||
|
[signed_activity_json, @account.id, inbox_url]
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
def unmerge_from_home_timelines!
|
def unmerge_from_home_timelines!
|
||||||
|
@ -90,4 +96,8 @@ class SuspendAccountService < BaseService
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def signed_activity_json
|
||||||
|
@signed_activity_json ||= Oj.dump(serialize_payload(@account, ActivityPub::UpdateSerializer, signer: @account))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -12,6 +12,7 @@ class UnsuspendAccountService < BaseService
|
||||||
merge_into_home_timelines!
|
merge_into_home_timelines!
|
||||||
merge_into_list_timelines!
|
merge_into_list_timelines!
|
||||||
publish_media_attachments!
|
publish_media_attachments!
|
||||||
|
distribute_update_actor!
|
||||||
end
|
end
|
||||||
|
|
||||||
private
|
private
|
||||||
|
@ -36,6 +37,16 @@ class UnsuspendAccountService < BaseService
|
||||||
# @account would now be nil.
|
# @account would now be nil.
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def distribute_update_actor!
|
||||||
|
return unless @account.local?
|
||||||
|
|
||||||
|
account_reach_finder = AccountReachFinder.new(@account)
|
||||||
|
|
||||||
|
ActivityPub::DeliveryWorker.push_bulk(account_reach_finder.inboxes) do |inbox_url|
|
||||||
|
[signed_activity_json, @account.id, inbox_url]
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def merge_into_home_timelines!
|
def merge_into_home_timelines!
|
||||||
@account.followers_for_local_distribution.find_each do |follower|
|
@account.followers_for_local_distribution.find_each do |follower|
|
||||||
FeedManager.instance.merge_into_home(@account, follower)
|
FeedManager.instance.merge_into_home(@account, follower)
|
||||||
|
@ -81,4 +92,8 @@ class UnsuspendAccountService < BaseService
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def signed_activity_json
|
||||||
|
@signed_activity_json ||= Oj.dump(serialize_payload(@account, ActivityPub::UpdateSerializer, signer: @account))
|
||||||
|
end
|
||||||
end
|
end
|
||||||
|
|
Loading…
Reference in a new issue