mirror of
https://github.com/ENSL/ensl.org.git
synced 2024-12-31 23:10:44 +00:00
116 lines
2.8 KiB
Ruby
116 lines
2.8 KiB
Ruby
# == Schema Information
|
|
#
|
|
# Table name: topics
|
|
#
|
|
# id :integer not null, primary key
|
|
# title :string(255)
|
|
# user_id :integer
|
|
# forum_id :integer
|
|
# created_at :datetime
|
|
# updated_at :datetime
|
|
# state :integer default(0), not null
|
|
#
|
|
|
|
class Topic < ActiveRecord::Base
|
|
POSTS_PAGE = 30
|
|
STATE_NORMAL = 0
|
|
STATE_STICKY = 1
|
|
LATEST_PER_PAGE = 5
|
|
|
|
RULES = 12
|
|
|
|
include Extra
|
|
attr_protected :id, :updated_at, :created_at
|
|
attr_accessor :first_post
|
|
|
|
belongs_to :user
|
|
belongs_to :forum
|
|
has_one :lock, :as => :lockable
|
|
has_one :latest, :class_name => "Post", :order => "id DESC"
|
|
has_many :posts, :order => "id ASC", :dependent => :destroy
|
|
has_many :view_counts, :as => :viewable, :dependent => :destroy
|
|
|
|
scope :basic, :include => [:latest, { forum: :forumer }, :user]
|
|
scope :ordered, :order => "state DESC, posts.id DESC"
|
|
scope :recent,
|
|
:conditions => "forumers.id IS NULL AND posts.id = (SELECT id FROM posts AS P WHERE P.topic_id = topics.id ORDER BY id DESC LIMIT 1)",
|
|
:order => "posts.id DESC",
|
|
:group => "topics.id"
|
|
scope :latest_page,
|
|
lambda { |page| {:limit => "#{(page-1)*LATEST_PER_PAGE}, #{(page-1)*LATEST_PER_PAGE+LATEST_PER_PAGE}"} }
|
|
|
|
validates_presence_of :user_id, :forum_id
|
|
validates_length_of :title, :in => 1..50
|
|
validates_length_of :first_post, :in => 1..10000, :on => :create
|
|
|
|
after_create :make_post
|
|
|
|
acts_as_readable
|
|
|
|
def self.recent_topics
|
|
Post.order('id desc').select('DISTINCT topic_id').limit(5).map(&:topic)
|
|
end
|
|
|
|
def to_s
|
|
title
|
|
end
|
|
|
|
def record_view_count(ip_address, logged_in = false)
|
|
self.view_counts.create(:viewable => self, :ip_address => ip_address, :logged_in => logged_in)
|
|
self
|
|
end
|
|
|
|
def view_count
|
|
view_counts.length
|
|
end
|
|
|
|
def cache_key(key)
|
|
"/topics/#{id}/#{key}"
|
|
end
|
|
|
|
def cached_view_count
|
|
Rails.cache.fetch(cache_key('view_count'), expires_in: 1.hours) do
|
|
self.view_count
|
|
end
|
|
end
|
|
|
|
def cached_posts_count
|
|
Rails.cache.fetch(cache_key('posts'), expires_in: 10.minutes) do
|
|
posts.count - 1
|
|
end
|
|
end
|
|
|
|
def make_post
|
|
c = posts.build
|
|
c.text = first_post
|
|
c.user = user
|
|
c.save!
|
|
end
|
|
|
|
def can_show? cuser
|
|
forum.can_show? cuser
|
|
end
|
|
|
|
def can_create? cuser
|
|
return false unless cuser
|
|
errors.add :bans, I18n.t(:bans_mute) if cuser.banned?(Ban::TYPE_MUTE) and forum != Forum::BANS
|
|
errors.add :bans, I18n.t(:registered_for_week) unless cuser.verified?
|
|
(Forum.available_to(cuser, Forumer::ACCESS_TOPIC).of_forum(forum).first and errors.size == 0)
|
|
end
|
|
|
|
def can_update? cuser
|
|
cuser and cuser.admin?
|
|
end
|
|
|
|
def can_destroy? cuser
|
|
cuser and cuser.admin?
|
|
end
|
|
|
|
def last_page
|
|
[((posts.count - 1) / POSTS_PAGE) + 1, 1].max
|
|
end
|
|
|
|
def states
|
|
{STATE_NORMAL => "Normal", STATE_STICKY => "Sticky"}
|
|
end
|
|
end
|