##// END OF EJS Templates
Moved code for replacing permissions to WorkflowPermission model....
Jean-Philippe Lang -
r9804:9e06942ef01e
parent child
Show More
@@ -1,132 +1,125
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 class WorkflowsController < ApplicationController
19 19 layout 'admin'
20 20
21 21 before_filter :require_admin
22 22 before_filter :find_roles
23 23 before_filter :find_trackers
24 24
25 25 def index
26 26 @workflow_counts = WorkflowTransition.count_by_tracker_and_role
27 27 end
28 28
29 29 def edit
30 30 @role = Role.find_by_id(params[:role_id])
31 31 @tracker = Tracker.find_by_id(params[:tracker_id])
32 32
33 33 if request.post?
34 34 WorkflowTransition.destroy_all( ["role_id=? and tracker_id=?", @role.id, @tracker.id])
35 35 (params[:issue_status] || []).each { |status_id, transitions|
36 36 transitions.each { |new_status_id, options|
37 37 author = options.is_a?(Array) && options.include?('author') && !options.include?('always')
38 38 assignee = options.is_a?(Array) && options.include?('assignee') && !options.include?('always')
39 39 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)
40 40 }
41 41 }
42 42 if @role.save
43 43 redirect_to :action => 'edit', :role_id => @role, :tracker_id => @tracker
44 44 return
45 45 end
46 46 end
47 47
48 48 @used_statuses_only = (params[:used_statuses_only] == '0' ? false : true)
49 49 if @tracker && @used_statuses_only && @tracker.issue_statuses.any?
50 50 @statuses = @tracker.issue_statuses
51 51 end
52 52 @statuses ||= IssueStatus.find(:all, :order => 'position')
53 53
54 54 if @tracker && @role && @statuses.any?
55 55 workflows = WorkflowTransition.all(:conditions => {:role_id => @role.id, :tracker_id => @tracker.id})
56 56 @workflows = {}
57 57 @workflows['always'] = workflows.select {|w| !w.author && !w.assignee}
58 58 @workflows['author'] = workflows.select {|w| w.author}
59 59 @workflows['assignee'] = workflows.select {|w| w.assignee}
60 60 end
61 61 end
62 62
63 63 def permissions
64 64 @role = Role.find_by_id(params[:role_id])
65 65 @tracker = Tracker.find_by_id(params[:tracker_id])
66 66
67 67 if @role && @tracker
68 68 if request.post?
69 WorkflowPermission.destroy_all({:role_id => @role.id, :tracker_id => @tracker.id})
70 (params[:permissions] || {}).each { |field, rule_by_status_id|
71 rule_by_status_id.each { |status_id, rule|
72 if rule.present?
73 WorkflowPermission.create(:role_id => @role.id, :tracker_id => @tracker.id, :old_status_id => status_id, :field_name => field, :rule => rule)
74 end
75 }
76 }
69 WorkflowPermission.replace_permissions(@tracker, @role, params[:permissions] || {})
77 70 redirect_to :action => 'permissions', :role_id => @role, :tracker_id => @tracker
78 71 return
79 72 end
80 73
81 74 @statuses = @tracker.issue_statuses
82 75 @fields = (Tracker::CORE_FIELDS_ALL - @tracker.disabled_core_fields).map {|field| [field, l("field_"+field.sub(/_id$/, ''))]}
83 76 @custom_fields = @tracker.custom_fields
84 77
85 78 @permissions = WorkflowPermission.where(:tracker_id => @tracker.id, :role_id => @role.id).all.inject({}) do |h, w|
86 79 h[w.old_status_id] ||= {}
87 80 h[w.old_status_id][w.field_name] = w.rule
88 81 h
89 82 end
90 83 @statuses.each {|status| @permissions[status.id] ||= {}}
91 84 end
92 85 end
93 86
94 87 def copy
95 88
96 89 if params[:source_tracker_id].blank? || params[:source_tracker_id] == 'any'
97 90 @source_tracker = nil
98 91 else
99 92 @source_tracker = Tracker.find_by_id(params[:source_tracker_id].to_i)
100 93 end
101 94 if params[:source_role_id].blank? || params[:source_role_id] == 'any'
102 95 @source_role = nil
103 96 else
104 97 @source_role = Role.find_by_id(params[:source_role_id].to_i)
105 98 end
106 99
107 100 @target_trackers = params[:target_tracker_ids].blank? ? nil : Tracker.find_all_by_id(params[:target_tracker_ids])
108 101 @target_roles = params[:target_role_ids].blank? ? nil : Role.find_all_by_id(params[:target_role_ids])
109 102
110 103 if request.post?
111 104 if params[:source_tracker_id].blank? || params[:source_role_id].blank? || (@source_tracker.nil? && @source_role.nil?)
112 105 flash.now[:error] = l(:error_workflow_copy_source)
113 106 elsif @target_trackers.nil? || @target_roles.nil?
114 107 flash.now[:error] = l(:error_workflow_copy_target)
115 108 else
116 109 WorkflowRule.copy(@source_tracker, @source_role, @target_trackers, @target_roles)
117 110 flash[:notice] = l(:notice_successful_update)
118 111 redirect_to :action => 'copy', :source_tracker_id => @source_tracker, :source_role_id => @source_role
119 112 end
120 113 end
121 114 end
122 115
123 116 private
124 117
125 118 def find_roles
126 119 @roles = Role.find(:all, :order => 'builtin, position')
127 120 end
128 121
129 122 def find_trackers
130 123 @trackers = Tracker.find(:all, :order => 'position')
131 124 end
132 125 end
@@ -1,29 +1,45
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2012 Jean-Philippe Lang
3 3 #
4 4 # This program is free software; you can redistribute it and/or
5 5 # modify it under the terms of the GNU General Public License
6 6 # as published by the Free Software Foundation; either version 2
7 7 # of the License, or (at your option) any later version.
8 8 #
9 9 # This program is distributed in the hope that it will be useful,
10 10 # but WITHOUT ANY WARRANTY; without even the implied warranty of
11 11 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 12 # GNU General Public License for more details.
13 13 #
14 14 # You should have received a copy of the GNU General Public License
15 15 # along with this program; if not, write to the Free Software
16 16 # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
17 17
18 18 class WorkflowPermission < WorkflowRule
19 19 validates_inclusion_of :rule, :in => %w(readonly required)
20 20 validate :validate_field_name
21 21
22 # Replaces the workflow permissions for the given tracker and role
23 #
24 # Example:
25 # WorkflowPermission.replace_permissions role, tracker, {'due_date' => {'1' => 'readonly', '2' => 'required'}}
26 def self.replace_permissions(tracker, role, permissions)
27 destroy_all(:tracker_id => tracker.id, :role_id => role.id)
28
29 permissions.each { |field, rule_by_status_id|
30 rule_by_status_id.each { |status_id, rule|
31 if rule.present?
32 WorkflowPermission.create(:role_id => role.id, :tracker_id => tracker.id, :old_status_id => status_id, :field_name => field, :rule => rule)
33 end
34 }
35 }
36 end
37
22 38 protected
23 39
24 40 def validate_field_name
25 41 unless Tracker::CORE_FIELDS_ALL.include?(field_name) || field_name.to_s.match(/^\d+$/)
26 42 errors.add :field_name, :invalid
27 43 end
28 44 end
29 45 end
General Comments 0
You need to be logged in to leave comments. Login now