03d59340da
* Fix Sidekiq warnings about JSON serialization This occurs on every symbol argument we pass, and every symbol key in hashes, because Sidekiq expects strings instead. See https://github.com/mperham/sidekiq/pull/5071 We do not need to change how workers parse their arguments because this has not changed and we were already converting to symbols adequately or using `with_indifferent_access`. * Set Sidekiq to raise on unsafe arguments in test mode In order to more easily catch issues that would produce warnings in production code.
32 lines
792 B
Ruby
32 lines
792 B
Ruby
# frozen_string_literal: true
|
|
|
|
class ActivityPub::DistributionWorker < ActivityPub::RawDistributionWorker
|
|
# Distribute a new status or an edit of a status to all the places
|
|
# where the status is supposed to go or where it was interacted with
|
|
def perform(status_id)
|
|
@status = Status.find(status_id)
|
|
@account = @status.account
|
|
|
|
distribute!
|
|
rescue ActiveRecord::RecordNotFound
|
|
true
|
|
end
|
|
|
|
protected
|
|
|
|
def inboxes
|
|
@inboxes ||= StatusReachFinder.new(@status).inboxes
|
|
end
|
|
|
|
def payload
|
|
@payload ||= Oj.dump(serialize_payload(activity, ActivityPub::ActivitySerializer, signer: @account))
|
|
end
|
|
|
|
def activity
|
|
ActivityPub::ActivityPresenter.from_status(@status)
|
|
end
|
|
|
|
def options
|
|
{ 'synchronize_followers' => @status.private_visibility? }
|
|
end
|
|
end
|