- For some reason, :if option on before_action did not work. It got executed every time, returned false, and the action run anyway, which led to the current_sign_in_at and sign_in_count being updated on every request - Return "do not filter" early in FeedManager#filter_from_home? if the status is authored by receiver. Usually this method is not called for own statuses at all, but it is called when Feed#get uses the database - Return early if #reload_stale_associations! has nothing to load to save a database query with WHERE 1=0
		
			
				
	
	
		
			37 lines
		
	
	
	
		
			994 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
	
		
			994 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| module UserTrackingConcern
 | |
|   extend ActiveSupport::Concern
 | |
| 
 | |
|   REGENERATE_FEED_DAYS = 14
 | |
|   UPDATE_SIGN_IN_HOURS = 24
 | |
| 
 | |
|   included do
 | |
|     before_action :set_user_activity
 | |
|   end
 | |
| 
 | |
|   private
 | |
| 
 | |
|   def set_user_activity
 | |
|     return unless user_needs_sign_in_update?
 | |
| 
 | |
|     # Mark as signed-in today
 | |
|     current_user.update_tracked_fields!(request)
 | |
| 
 | |
|     # Regenerate feed if needed
 | |
|     regenerate_feed! if user_needs_feed_update?
 | |
|   end
 | |
| 
 | |
|   def user_needs_sign_in_update?
 | |
|     user_signed_in? && (current_user.current_sign_in_at.nil? || current_user.current_sign_in_at < UPDATE_SIGN_IN_HOURS.hours.ago)
 | |
|   end
 | |
| 
 | |
|   def user_needs_feed_update?
 | |
|     current_user.last_sign_in_at < REGENERATE_FEED_DAYS.days.ago
 | |
|   end
 | |
| 
 | |
|   def regenerate_feed!
 | |
|     Redis.current.setnx("account:#{current_user.account_id}:regeneration", true) == 1 && Redis.current.expire("account:#{current_user.account_id}:regeneration", 3_600 * 24)
 | |
|     RegenerationWorker.perform_async(current_user.account_id)
 | |
|   end
 | |
| end
 |