Chris@0: # Redmine - project management software Chris@1494: # Copyright (C) 2006-2014 Jean-Philippe Lang Chris@0: # Chris@0: # This program is free software; you can redistribute it and/or Chris@0: # modify it under the terms of the GNU General Public License Chris@0: # as published by the Free Software Foundation; either version 2 Chris@0: # of the License, or (at your option) any later version. Chris@909: # Chris@0: # This program is distributed in the hope that it will be useful, Chris@0: # but WITHOUT ANY WARRANTY; without even the implied warranty of Chris@0: # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the Chris@0: # GNU General Public License for more details. Chris@909: # Chris@0: # You should have received a copy of the GNU General Public License Chris@0: # along with this program; if not, write to the Free Software Chris@0: # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. Chris@0: Chris@0: class WorkflowsController < ApplicationController Chris@0: layout 'admin' Chris@909: Chris@1115: before_filter :require_admin, :find_roles, :find_trackers Chris@909: Chris@0: def index Chris@1115: @workflow_counts = WorkflowTransition.count_by_tracker_and_role Chris@0: end Chris@909: Chris@0: def edit Chris@1115: @role = Role.find_by_id(params[:role_id]) if params[:role_id] Chris@1115: @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id] Chris@909: Chris@0: if request.post? Chris@1115: WorkflowTransition.destroy_all( ["role_id=? and tracker_id=?", @role.id, @tracker.id]) Chris@245: (params[:issue_status] || []).each { |status_id, transitions| Chris@245: transitions.each { |new_status_id, options| Chris@245: author = options.is_a?(Array) && options.include?('author') && !options.include?('always') Chris@245: assignee = options.is_a?(Array) && options.include?('assignee') && !options.include?('always') Chris@1115: 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) Chris@0: } Chris@0: } Chris@0: if @role.save Chris@1464: redirect_to workflows_edit_path(:role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]) Chris@245: return Chris@0: end Chris@0: end Chris@909: Chris@0: @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true) Chris@0: if @tracker && @used_statuses_only && @tracker.issue_statuses.any? Chris@0: @statuses = @tracker.issue_statuses Chris@0: end Chris@1115: @statuses ||= IssueStatus.sorted.all Chris@909: Chris@245: if @tracker && @role && @statuses.any? Chris@1115: workflows = WorkflowTransition.where(:role_id => @role.id, :tracker_id => @tracker.id).all Chris@245: @workflows = {} Chris@245: @workflows['always'] = workflows.select {|w| !w.author && !w.assignee} Chris@245: @workflows['author'] = workflows.select {|w| w.author} Chris@245: @workflows['assignee'] = workflows.select {|w| w.assignee} Chris@245: end Chris@0: end Chris@909: Chris@1115: def permissions Chris@1115: @role = Role.find_by_id(params[:role_id]) if params[:role_id] Chris@1115: @tracker = Tracker.find_by_id(params[:tracker_id]) if params[:tracker_id] Chris@1115: Chris@1115: if request.post? && @role && @tracker Chris@1115: WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {}) Chris@1464: redirect_to workflows_permissions_path(:role_id => @role, :tracker_id => @tracker, :used_statuses_only => params[:used_statuses_only]) Chris@1115: return Chris@1115: end Chris@1115: Chris@1115: @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true) Chris@1115: if @tracker && @used_statuses_only && @tracker.issue_statuses.any? Chris@1115: @statuses = @tracker.issue_statuses Chris@1115: end Chris@1115: @statuses ||= IssueStatus.sorted.all Chris@1115: Chris@1115: if @role && @tracker Chris@1115: @fields = (Tracker::CORE_FIELDS_ALL - @tracker.disabled_core_fields).map {|field| [field, l("field_"+field.sub(/_id$/, ''))]} Chris@1115: @custom_fields = @tracker.custom_fields Chris@1115: Chris@1115: @permissions = WorkflowPermission.where(:tracker_id => @tracker.id, :role_id => @role.id).all.inject({}) do |h, w| Chris@1115: h[w.old_status_id] ||= {} Chris@1115: h[w.old_status_id][w.field_name] = w.rule Chris@1115: h Chris@1115: end Chris@1115: @statuses.each {|status| @permissions[status.id] ||= {}} Chris@1115: end Chris@1115: end Chris@1115: Chris@0: def copy Chris@909: Chris@0: if params[:source_tracker_id].blank? || params[:source_tracker_id] == 'any' Chris@0: @source_tracker = nil Chris@0: else Chris@0: @source_tracker = Tracker.find_by_id(params[:source_tracker_id].to_i) Chris@0: end Chris@0: if params[:source_role_id].blank? || params[:source_role_id] == 'any' Chris@0: @source_role = nil Chris@0: else Chris@0: @source_role = Role.find_by_id(params[:source_role_id].to_i) Chris@0: end Chris@909: Chris@0: @target_trackers = params[:target_tracker_ids].blank? ? nil : Tracker.find_all_by_id(params[:target_tracker_ids]) Chris@0: @target_roles = params[:target_role_ids].blank? ? nil : Role.find_all_by_id(params[:target_role_ids]) Chris@909: Chris@0: if request.post? Chris@0: if params[:source_tracker_id].blank? || params[:source_role_id].blank? || (@source_tracker.nil? && @source_role.nil?) Chris@0: flash.now[:error] = l(:error_workflow_copy_source) Chris@1464: elsif @target_trackers.blank? || @target_roles.blank? Chris@0: flash.now[:error] = l(:error_workflow_copy_target) Chris@0: else Chris@1115: WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles) Chris@0: flash[:notice] = l(:notice_successful_update) Chris@1464: redirect_to workflows_copy_path(:source_tracker_id => @source_tracker, :source_role_id => @source_role) Chris@0: end Chris@0: end Chris@0: end Chris@0: Chris@0: private Chris@0: Chris@0: def find_roles Chris@1115: @roles = Role.sorted.all Chris@0: end Chris@909: Chris@0: def find_trackers Chris@1115: @trackers = Tracker.sorted.all Chris@0: end Chris@0: end