Refactor User#update_last_seen! and User#update_tracked_topics

This commit is contained in:
Navin Keswani 2013-10-23 23:24:50 +02:00
parent 8aab2253d0
commit 6ce80fd148
2 changed files with 39 additions and 24 deletions

View File

@ -276,26 +276,18 @@ class User < ActiveRecord::Base
end
end
def update_last_seen!(now=nil)
now ||= Time.zone.now
def update_last_seen!(now=Time.zone.now)
now_date = now.to_date
# Only update last seen once every minute
redis_key = "user:#{self.id}:#{now_date}"
if $redis.setnx(redis_key, "1")
redis_key = "user:#{id}:#{now_date}"
return unless $redis.setnx(redis_key, "1")
$redis.expire(redis_key, SiteSetting.active_user_rate_limit_secs)
update_visit_record!(now_date)
update_previous_visit(now)
# using update_column to avoid the AR transaction
# Keep track of our last visit
if seen_before? && (self.last_seen_at < (now - SiteSetting.previous_visit_timeout_hours.hours))
previous_visit_at = last_seen_at
update_column(:previous_visit_at, previous_visit_at)
end
update_column(:last_seen_at, now)
end
end
def self.gravatar_template(email)
email_hash = self.email_hash(email)
@ -505,14 +497,7 @@ class User < ActiveRecord::Base
def update_tracked_topics
return unless auto_track_topics_after_msecs_changed?
where_conditions = {notifications_reason_id: nil, user_id: id}
if auto_track_topics_after_msecs < 0
TopicUser.where(where_conditions).update_all({notification_level: TopicUser.notification_levels[:regular]})
else
TopicUser.where(where_conditions).update_all(["notification_level = CASE WHEN total_msecs_viewed < ? THEN ? ELSE ? END",
auto_track_topics_after_msecs, TopicUser.notification_levels[:regular], TopicUser.notification_levels[:tracking]])
end
TrackedTopicsUpdater.new(id, auto_track_topics_after_msecs).call
end
def create_user_stat
@ -584,6 +569,18 @@ class User < ActiveRecord::Base
private
def previous_visit_at_update_required?(timestamp)
seen_before? &&
(last_seen_at < (timestamp - SiteSetting.previous_visit_timeout_hours.hours))
end
def update_previous_visit(timestamp)
update_visit_record!(timestamp.to_date)
if previous_visit_at_update_required?(timestamp)
update_column(:previous_visit_at, last_seen_at)
end
end
end
# == Schema Information

View File

@ -0,0 +1,18 @@
class TrackedTopicsUpdater
def initialize(user_id, threshold)
@id = user_id
@threshold = threshold
end
def call
topic_users = TopicUser.where(notifications_reason_id: nil, user_id: @id)
if @threshold < 0
topic_users.update_all({notification_level: TopicUser.notification_levels[:regular]})
else
topic_users.update_all(["notification_level = CASE WHEN total_msecs_viewed < ? THEN ? ELSE ? END",
@threshold, TopicUser.notification_levels[:regular], TopicUser.notification_levels[:tracking]])
end
end
end