mirror of
https://git.bsd.gay/fef/nyastodon.git
synced 2024-12-29 13:43:41 +01:00
b8db386e05
- 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
|