Don't put Move handler on cooldown if it didn't run. Skip unmerging from timelines to save unnecessary work.
		
			
				
	
	
		
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			51 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class ActivityPub::Activity::Move < ActivityPub::Activity
 | |
|   PROCESSING_COOLDOWN = 7.days.seconds
 | |
| 
 | |
|   def perform
 | |
|     return if origin_account.uri != object_uri || processed?
 | |
| 
 | |
|     mark_as_processing!
 | |
| 
 | |
|     target_account = ActivityPub::FetchRemoteAccountService.new.call(target_uri)
 | |
| 
 | |
|     if target_account.nil? || target_account.suspended? || !target_account.also_known_as.include?(origin_account.uri)
 | |
|       unmark_as_processing!
 | |
|       return
 | |
|     end
 | |
| 
 | |
|     # In case for some reason we didn't have a redirect for the profile already, set it
 | |
|     origin_account.update(moved_to_account: target_account)
 | |
| 
 | |
|     # Initiate a re-follow for each follower
 | |
|     origin_account.followers.local.select(:id).find_in_batches do |follower_accounts|
 | |
|       UnfollowFollowWorker.push_bulk(follower_accounts.map(&:id)) do |follower_account_id|
 | |
|         [follower_account_id, origin_account.id, target_account.id]
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def origin_account
 | |
|     @account
 | |
|   end
 | |
| 
 | |
|   def target_uri
 | |
|     value_or_id(@json['target'])
 | |
|   end
 | |
| 
 | |
|   def processed?
 | |
|     redis.exists("move_in_progress:#{@account.id}")
 | |
|   end
 | |
| 
 | |
|   def mark_as_processing!
 | |
|     redis.setex("move_in_progress:#{@account.id}", PROCESSING_COOLDOWN, true)
 | |
|   end
 | |
| 
 | |
|   def unmark_as_processing!
 | |
|     redis.del("move_in_progress:#{@account.id}")
 | |
|   end
 | |
| end
 |