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