Mercurial > hg > soundsoftware-site
comparison app/models/.svn/text-base/board.rb.svn-base @ 0:513646585e45
* Import Redmine trunk SVN rev 3859
author | Chris Cannam |
---|---|
date | Fri, 23 Jul 2010 15:52:44 +0100 |
parents | |
children | af80e5618e9b |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:513646585e45 |
---|---|
1 # redMine - project management software | |
2 # Copyright (C) 2006-2007 Jean-Philippe Lang | |
3 # | |
4 # This program is free software; you can redistribute it and/or | |
5 # modify it under the terms of the GNU General Public License | |
6 # as published by the Free Software Foundation; either version 2 | |
7 # of the License, or (at your option) any later version. | |
8 # | |
9 # This program is distributed in the hope that it will be useful, | |
10 # but WITHOUT ANY WARRANTY; without even the implied warranty of | |
11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | |
12 # GNU General Public License for more details. | |
13 # | |
14 # You should have received a copy of the GNU General Public License | |
15 # along with this program; if not, write to the Free Software | |
16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. | |
17 | |
18 class Board < ActiveRecord::Base | |
19 belongs_to :project | |
20 has_many :topics, :class_name => 'Message', :conditions => "#{Message.table_name}.parent_id IS NULL", :order => "#{Message.table_name}.created_on DESC" | |
21 has_many :messages, :dependent => :delete_all, :order => "#{Message.table_name}.created_on DESC" | |
22 belongs_to :last_message, :class_name => 'Message', :foreign_key => :last_message_id | |
23 acts_as_list :scope => :project_id | |
24 acts_as_watchable | |
25 | |
26 validates_presence_of :name, :description | |
27 validates_length_of :name, :maximum => 30 | |
28 validates_length_of :description, :maximum => 255 | |
29 | |
30 def visible?(user=User.current) | |
31 !user.nil? && user.allowed_to?(:view_messages, project) | |
32 end | |
33 | |
34 def to_s | |
35 name | |
36 end | |
37 | |
38 def reset_counters! | |
39 self.class.reset_counters!(id) | |
40 end | |
41 | |
42 # Updates topics_count, messages_count and last_message_id attributes for +board_id+ | |
43 def self.reset_counters!(board_id) | |
44 board_id = board_id.to_i | |
45 update_all("topics_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id} AND parent_id IS NULL)," + | |
46 " messages_count = (SELECT COUNT(*) FROM #{Message.table_name} WHERE board_id=#{board_id})," + | |
47 " last_message_id = (SELECT MAX(id) FROM #{Message.table_name} WHERE board_id=#{board_id})", | |
48 ["id = ?", board_id]) | |
49 end | |
50 end |