Avoid duplicate work by merging ReplyDistributionWorker into DistributionWorker (#9660)
parent
b2f4114550
commit
6fb6a53938
@ -1,42 +0,0 @@ |
|||||||
# frozen_string_literal: true |
|
||||||
|
|
||||||
class ActivityPub::ReplyDistributionWorker |
|
||||||
include Sidekiq::Worker |
|
||||||
|
|
||||||
sidekiq_options queue: 'push' |
|
||||||
|
|
||||||
def perform(status_id) |
|
||||||
@status = Status.find(status_id) |
|
||||||
@account = @status.thread&.account |
|
||||||
|
|
||||||
return unless @account.present? && @status.distributable? |
|
||||||
|
|
||||||
ActivityPub::DeliveryWorker.push_bulk(inboxes) do |inbox_url| |
|
||||||
[payload, @status.account_id, inbox_url] |
|
||||||
end |
|
||||||
rescue ActiveRecord::RecordNotFound |
|
||||||
true |
|
||||||
end |
|
||||||
|
|
||||||
private |
|
||||||
|
|
||||||
def inboxes |
|
||||||
@inboxes ||= @account.followers.inboxes |
|
||||||
end |
|
||||||
|
|
||||||
def signed_payload |
|
||||||
Oj.dump(ActivityPub::LinkedDataSignature.new(unsigned_payload).sign!(@status.account)) |
|
||||||
end |
|
||||||
|
|
||||||
def unsigned_payload |
|
||||||
ActiveModelSerializers::SerializableResource.new( |
|
||||||
@status, |
|
||||||
serializer: ActivityPub::ActivitySerializer, |
|
||||||
adapter: ActivityPub::Adapter |
|
||||||
).as_json |
|
||||||
end |
|
||||||
|
|
||||||
def payload |
|
||||||
@payload ||= @status.distributable? ? signed_payload : Oj.dump(unsigned_payload) |
|
||||||
end |
|
||||||
end |
|
Loading…
Reference in new issue