To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.

Statistics Download as Zip
| Branch: | Tag: | Revision:

root / app / controllers / workflows_controller.rb @ 1354:fc0fecf09eb9

History | View | Annotate | Download (5.07 KB)

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 WorkflowsController < ApplicationController
19
  layout 'admin'
20

    
21
  before_filter :require_admin, :find_roles, :find_trackers
22

    
23
  def index
24
    @workflow_counts = WorkflowTransition.count_by_tracker_and_role
25
  end
26

    
27
  def edit
28
    @role = Role.find_by_id(params[:role_id]) if params[:role_id]
29
    @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
30

    
31
    if request.post?
32
      WorkflowTransition.destroy_all( ["role_id=? and tracker_id=?", @role.id, @tracker.id])
33
      (params[:issue_status] || []).each { |status_id, transitions|
34
        transitions.each { |new_status_id, options|
35
          author = options.is_a?(Array) && options.include?('author') && !options.include?('always')
36
          assignee = options.is_a?(Array) && options.include?('assignee') && !options.include?('always')
37
          WorkflowTransition.create(:role_id => @role.id, :tracker_id => @tracker.id, :old_status_id => status_id, :new_status_id => new_status_id, :author => author, :assignee => assignee)
38
        }
39
      }
40
      if @role.save
41
        redirect_to :action => 'edit', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]
42
        return
43
      end
44
    end
45

    
46
    @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
47
    if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
48
      @statuses = @tracker.issue_statuses
49
    end
50
    @statuses ||= IssueStatus.sorted.all
51

    
52
    if @tracker && @role && @statuses.any?
53
      workflows = WorkflowTransition.where(:role_id => @role.id, :tracker_id => @tracker.id).all
54
      @workflows = {}
55
      @workflows['always'] = workflows.select {|w| !w.author && !w.assignee}
56
      @workflows['author'] = workflows.select {|w| w.author}
57
      @workflows['assignee'] = workflows.select {|w| w.assignee}
58
    end
59
  end
60

    
61
  def permissions
62
    @role = Role.find_by_id(params[:role_id]) if params[:role_id]
63
    @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id]
64

    
65
    if request.post? && @role && @tracker
66
      WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {})
67
      redirect_to :action => 'permissions', :role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]
68
      return
69
    end
70

    
71
    @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
72
    if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
73
      @statuses = @tracker.issue_statuses
74
    end
75
    @statuses ||= IssueStatus.sorted.all
76

    
77
    if @role && @tracker
78
      @fields = (Tracker::CORE_FIELDS_ALL - @tracker.disabled_core_fields).map {|field| [field, l("field_"+field.sub(/_id$/, ''))]}
79
      @custom_fields = @tracker.custom_fields
80

    
81
      @permissions = WorkflowPermission.where(:tracker_id => @tracker.id, :role_id => @role.id).all.inject({}) do |h, w|
82
        h[w.old_status_id] ||= {}
83
        h[w.old_status_id][w.field_name] = w.rule
84
        h
85
      end
86
      @statuses.each {|status| @permissions[status.id] ||= {}}
87
    end
88
  end
89

    
90
  def copy
91

    
92
    if params[:source_tracker_id].blank? || params[:source_tracker_id] == 'any'
93
      @source_tracker = nil
94
    else
95
      @source_tracker = Tracker.find_by_id(params[:source_tracker_id].to_i)
96
    end
97
    if params[:source_role_id].blank? || params[:source_role_id] == 'any'
98
      @source_role = nil
99
    else
100
      @source_role = Role.find_by_id(params[:source_role_id].to_i)
101
    end
102

    
103
    @target_trackers = params[:target_tracker_ids].blank? ? nil : Tracker.find_all_by_id(params[:target_tracker_ids])
104
    @target_roles = params[:target_role_ids].blank? ? nil : Role.find_all_by_id(params[:target_role_ids])
105

    
106
    if request.post?
107
      if params[:source_tracker_id].blank? || params[:source_role_id].blank? || (@source_tracker.nil? && @source_role.nil?)
108
        flash.now[:error] = l(:error_workflow_copy_source)
109
      elsif @target_trackers.nil? || @target_roles.nil?
110
        flash.now[:error] = l(:error_workflow_copy_target)
111
      else
112
        WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles)
113
        flash[:notice] = l(:notice_successful_update)
114
        redirect_to :action => 'copy', :source_tracker_id => @source_tracker, :source_role_id => @source_role
115
      end
116
    end
117
  end
118

    
119
  private
120

    
121
  def find_roles
122
    @roles = Role.sorted.all
123
  end
124

    
125
  def find_trackers
126
    @trackers = Tracker.sorted.all
127
  end
128
end