Project

General

Profile

RE: Error after migrating DB » workflow_transition.rb

Hector Estevez, 2012-08-24 16:09

 
1
# Redmine - project management software
2
# Copyright (C) 2006-2012  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 WorkflowTransition < WorkflowRule
19
  validates_presence_of :new_status
20

    
21
  # Returns workflow transitions count by tracker and role
22
  def self.count_by_tracker_and_role
23
    counts = connection.select_all("SELECT role_id, tracker_id, count(id) AS c FROM #{table_name} WHERE type = 'WorkflowTransition' GROUP BY role_id, tracker_id")
24
    roles = Role.sorted.all
25
    trackers = Tracker.sorted.all
26

    
27
    result = []
28
    trackers.each do |tracker|
29
      t = []
30
      roles.each do |role|
31
        row = counts.detect {|c| c['role_id'].to_s == role.id.to_s && c['tracker_id'].to_s == tracker.id.to_s}
32
        t << [role, (row.nil? ? 0 : row['c'].to_i)]
33
      end
34
      result << [tracker, t]
35
    end
36

    
37
    result
38
  end
39
end
(3-3/3)