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