* 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
 |