comparison app/models/.svn/text-base/tracker.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 8661b858af72
comparison
equal deleted inserted replaced
-1:000000000000 0:513646585e45
1 # redMine - project management software
2 # Copyright (C) 2006 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 Tracker < ActiveRecord::Base
19 before_destroy :check_integrity
20 has_many :issues
21 has_many :workflows, :dependent => :delete_all do
22 def copy(source_tracker)
23 Workflow.copy(source_tracker, nil, proxy_owner, nil)
24 end
25 end
26
27 has_and_belongs_to_many :projects
28 has_and_belongs_to_many :custom_fields, :class_name => 'IssueCustomField', :join_table => "#{table_name_prefix}custom_fields_trackers#{table_name_suffix}", :association_foreign_key => 'custom_field_id'
29 acts_as_list
30
31 validates_presence_of :name
32 validates_uniqueness_of :name
33 validates_length_of :name, :maximum => 30
34 validates_format_of :name, :with => /^[\w\s\'\-]*$/i
35
36 def to_s; name end
37
38 def <=>(tracker)
39 name <=> tracker.name
40 end
41
42 def self.all
43 find(:all, :order => 'position')
44 end
45
46 # Returns an array of IssueStatus that are used
47 # in the tracker's workflows
48 def issue_statuses
49 if @issue_statuses
50 return @issue_statuses
51 elsif new_record?
52 return []
53 end
54
55 ids = Workflow.
56 connection.select_rows("SELECT DISTINCT old_status_id, new_status_id FROM #{Workflow.table_name} WHERE tracker_id = #{id}").
57 flatten.
58 uniq
59
60 @issue_statuses = IssueStatus.find_all_by_id(ids).sort
61 end
62
63 private
64 def check_integrity
65 raise "Can't delete tracker" if Issue.find(:first, :conditions => ["tracker_id=?", self.id])
66 end
67 end