@@ -2,7 +2,6 @@ class ForumTopicsController < ApplicationController
|
||||
respond_to :html, :xml, :json
|
||||
before_filter :member_only, :except => [:index, :show]
|
||||
before_filter :normalize_search, :only => :index
|
||||
after_filter :update_last_forum_read_at, :only => [:show]
|
||||
|
||||
def new
|
||||
@forum_topic = ForumTopic.new
|
||||
@@ -17,8 +16,10 @@ class ForumTopicsController < ApplicationController
|
||||
end
|
||||
|
||||
def index
|
||||
# session[:read_forum_topics] = ""
|
||||
@query = ForumTopic.active.search(params[:search])
|
||||
@forum_topics = @query.order("is_sticky DESC, updated_at DESC").paginate(params[:page], :limit => params[:limit], :search_count => params[:search])
|
||||
@read_forum_topic_ids = read_forum_topic_ids
|
||||
respond_with(@forum_topics) do |format|
|
||||
format.xml do
|
||||
render :xml => @forum_topics.to_xml(:root => "forum-topics")
|
||||
@@ -31,6 +32,7 @@ class ForumTopicsController < ApplicationController
|
||||
@forum_posts = ForumPost.search(:topic_id => @forum_topic.id).order("forum_posts.id").paginate(params[:page])
|
||||
@forum_posts.all
|
||||
respond_with(@forum_topic)
|
||||
session[:read_forum_topics] = @forum_topic.mark_as_read(read_forum_topic_ids)
|
||||
end
|
||||
|
||||
def create
|
||||
@@ -67,14 +69,6 @@ class ForumTopicsController < ApplicationController
|
||||
end
|
||||
|
||||
private
|
||||
def update_last_forum_read_at
|
||||
return if CurrentUser.is_anonymous?
|
||||
|
||||
if CurrentUser.last_forum_read_at.nil? || CurrentUser.last_forum_read_at < @forum_topic.updated_at
|
||||
CurrentUser.update_column(:last_forum_read_at, @forum_topic.updated_at)
|
||||
end
|
||||
end
|
||||
|
||||
def normalize_search
|
||||
if params[:title_matches]
|
||||
params[:search] ||= {}
|
||||
@@ -87,6 +81,14 @@ private
|
||||
end
|
||||
end
|
||||
|
||||
def read_forum_topics
|
||||
session[:read_forum_topics].to_s
|
||||
end
|
||||
|
||||
def read_forum_topic_ids
|
||||
read_forum_topics.scan(/(\S+) (\S+)/)
|
||||
end
|
||||
|
||||
def check_privilege(forum_topic)
|
||||
if !forum_topic.editable_by?(CurrentUser.user)
|
||||
raise User::PrivilegeError
|
||||
|
||||
@@ -13,7 +13,6 @@ class SessionCreator
|
||||
def authenticate
|
||||
if User.authenticate(name, password)
|
||||
user = User.find_by_name(name)
|
||||
user.update_column(:last_logged_in_at, Time.now)
|
||||
|
||||
if remember.present?
|
||||
cookies.permanent.signed[:user_name] = {
|
||||
|
||||
@@ -13,6 +13,10 @@ class SessionLoader
|
||||
load_session_user
|
||||
elsif cookie_password_hash_valid?
|
||||
load_cookie_user
|
||||
|
||||
# this means a new session is being created, so assume
|
||||
# all the old forum topics can be marked as read
|
||||
update_forum_last_read_at
|
||||
else
|
||||
load_session_for_api
|
||||
end
|
||||
@@ -72,6 +76,7 @@ private
|
||||
def load_cookie_user
|
||||
CurrentUser.user = User.find_by_name(cookies.signed[:user_name])
|
||||
CurrentUser.ip_addr = request.remote_ip
|
||||
session[:user_id] = CurrentUser.user.id
|
||||
end
|
||||
|
||||
def ban_expired?
|
||||
@@ -99,5 +104,12 @@ private
|
||||
def set_time_zone
|
||||
Time.zone = CurrentUser.user.time_zone
|
||||
end
|
||||
|
||||
def update_forum_last_read_at
|
||||
unless CurrentUser.user.is_anonymous?
|
||||
CurrentUser.user.update_column(:last_forum_read_at, CurrentUser.user.last_logged_in_at)
|
||||
CurrentUser.user.update_column(:last_logged_in_at, Time.now)
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
@@ -104,4 +104,30 @@ class ForumTopic < ActiveRecord::Base
|
||||
def hidden_attributes
|
||||
super + [:text_index]
|
||||
end
|
||||
|
||||
def read_by?(user, read_forum_topic_ids)
|
||||
if read_forum_topic_ids.any? {|topic_id, timestamp| id.to_s == topic_id && updated_at.to_i > timestamp.to_i}
|
||||
return false
|
||||
end
|
||||
if read_forum_topic_ids.any? {|topic_id, timestamp| id.to_s == topic_id && updated_at.to_i <= timestamp.to_i}
|
||||
return true
|
||||
end
|
||||
return false if user.last_forum_read_at.nil?
|
||||
return true if updated_at < user.last_forum_read_at
|
||||
return false
|
||||
end
|
||||
|
||||
def mark_as_read(read_forum_topic_ids)
|
||||
hash = read_forum_topic_ids.inject({}) do |hash, x|
|
||||
hash[x[0].to_s] = x[1].to_s
|
||||
hash
|
||||
end
|
||||
hash[id.to_s] = updated_at.to_i.to_s
|
||||
result = hash.to_a.flatten.join(" ")
|
||||
if result.size > 3000
|
||||
ids = result.scan(/\S+/)
|
||||
result = ids[(ids.size / 2)..-1].join(" ")
|
||||
end
|
||||
result
|
||||
end
|
||||
end
|
||||
|
||||
@@ -24,7 +24,7 @@
|
||||
<span class="sticky">Sticky:</span>
|
||||
<% end %>
|
||||
|
||||
<% if topic.updated_at > (CurrentUser.last_forum_read_at || Time.now) %>
|
||||
<% unless topic.read_by?(CurrentUser.user, @read_forum_topic_ids) %>
|
||||
<span class="new">NEW</span>
|
||||
<% end %>
|
||||
|
||||
|
||||
Reference in New Issue
Block a user