- `.env.production.sample`: Our sample config file is very different from upstream since it is much more complete. Upstream added documentation for a few env variables. Copied the new variables/documentation from upstream. - `app/lib/feed_manager.rb`: Upstream added a timeline type (hashtags), while glitch-soc already had an extra one (direct messages). Not really a conflict but textually close changes. Ported upstream's changes. - `app/models/custom_emoji.rb`: Upstream upped the custom emoji size limit, while glitch-soc had configurable limits. Upped the default limits accordingly. - `streaming/index.js`: Upstream reworked how hastags were normalized. Minor conflict due to glitch-soc's handling of instance-local posts. Ported upstream's changes.
		
			
				
	
	
		
			85 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			85 lines
		
	
	
	
		
			2.1 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| class FeedInsertWorker
 | |
|   include Sidekiq::Worker
 | |
| 
 | |
|   def perform(status_id, id, type = 'home', options = {})
 | |
|     @type      = type.to_sym
 | |
|     @status    = Status.find(status_id)
 | |
|     @options   = options.symbolize_keys
 | |
| 
 | |
|     case @type
 | |
|     when :home, :tags
 | |
|       @follower = Account.find(id)
 | |
|     when :list
 | |
|       @list     = List.find(id)
 | |
|       @follower = @list.account
 | |
|     when :direct
 | |
|       @account  = Account.find(id)
 | |
|     end
 | |
| 
 | |
|     check_and_insert
 | |
|   rescue ActiveRecord::RecordNotFound
 | |
|     true
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def check_and_insert
 | |
|     if feed_filtered?
 | |
|       perform_unpush if update?
 | |
|     else
 | |
|       perform_push
 | |
|       perform_notify if notify?
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def feed_filtered?
 | |
|     case @type
 | |
|     when :home
 | |
|       FeedManager.instance.filter?(:home, @status, @follower)
 | |
|     when :tags
 | |
|       FeedManager.instance.filter?(:tags, @status, @follower)
 | |
|     when :list
 | |
|       FeedManager.instance.filter?(:list, @status, @list)
 | |
|     when :direct
 | |
|       FeedManager.instance.filter?(:direct, @status, @account)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def notify?
 | |
|     return false if @type != :home || @status.reblog? || (@status.reply? && @status.in_reply_to_account_id != @status.account_id)
 | |
| 
 | |
|     Follow.find_by(account: @follower, target_account: @status.account)&.notify?
 | |
|   end
 | |
| 
 | |
|   def perform_push
 | |
|     case @type
 | |
|     when :home, :tags
 | |
|       FeedManager.instance.push_to_home(@follower, @status, update: update?)
 | |
|     when :list
 | |
|       FeedManager.instance.push_to_list(@list, @status, update: update?)
 | |
|     when :direct
 | |
|       FeedManager.instance.push_to_direct(@account, @status, update: update?)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def perform_unpush
 | |
|     case @type
 | |
|     when :home, :tags
 | |
|       FeedManager.instance.unpush_from_home(@follower, @status, update: true)
 | |
|     when :list
 | |
|       FeedManager.instance.unpush_from_list(@list, @status, update: true)
 | |
|     when :direct
 | |
|       FeedManager.instance.unpush_from_direct(@account, @status, update: true)
 | |
|     end
 | |
|   end
 | |
| 
 | |
|   def perform_notify
 | |
|     LocalNotificationWorker.perform_async(@follower.id, @status.id, 'Status', 'status')
 | |
|   end
 | |
| 
 | |
|   def update?
 | |
|     @options[:update]
 | |
|   end
 | |
| end
 |