##// END OF EJS Templates
Updated permissions for r4034...
Eric Davis -
r3921:dfcb5a666f79
parent child
Show More
@@ -1,230 +1,231
1 1 require 'redmine/access_control'
2 2 require 'redmine/menu_manager'
3 3 require 'redmine/activity'
4 4 require 'redmine/search'
5 5 require 'redmine/custom_field_format'
6 6 require 'redmine/mime_type'
7 7 require 'redmine/core_ext'
8 8 require 'redmine/themes'
9 9 require 'redmine/hook'
10 10 require 'redmine/plugin'
11 11 require 'redmine/wiki_formatting'
12 12 require 'redmine/scm/base'
13 13
14 14 begin
15 15 require_library_or_gem 'RMagick' unless Object.const_defined?(:Magick)
16 16 rescue LoadError
17 17 # RMagick is not available
18 18 end
19 19
20 20 if RUBY_VERSION < '1.9'
21 21 require 'faster_csv'
22 22 else
23 23 require 'csv'
24 24 FCSV = CSV
25 25 end
26 26
27 27 Redmine::Scm::Base.add "Subversion"
28 28 Redmine::Scm::Base.add "Darcs"
29 29 Redmine::Scm::Base.add "Mercurial"
30 30 Redmine::Scm::Base.add "Cvs"
31 31 Redmine::Scm::Base.add "Bazaar"
32 32 Redmine::Scm::Base.add "Git"
33 33 Redmine::Scm::Base.add "Filesystem"
34 34
35 35 Redmine::CustomFieldFormat.map do |fields|
36 36 fields.register Redmine::CustomFieldFormat.new('string', :label => :label_string, :order => 1)
37 37 fields.register Redmine::CustomFieldFormat.new('text', :label => :label_text, :order => 2)
38 38 fields.register Redmine::CustomFieldFormat.new('int', :label => :label_integer, :order => 3)
39 39 fields.register Redmine::CustomFieldFormat.new('float', :label => :label_float, :order => 4)
40 40 fields.register Redmine::CustomFieldFormat.new('list', :label => :label_list, :order => 5)
41 41 fields.register Redmine::CustomFieldFormat.new('date', :label => :label_date, :order => 6)
42 42 fields.register Redmine::CustomFieldFormat.new('bool', :label => :label_boolean, :order => 7)
43 43 end
44 44
45 45 # Permissions
46 46 Redmine::AccessControl.map do |map|
47 47 map.permission :view_project, {:projects => [:show, :activity]}, :public => true
48 48 map.permission :search_project, {:search => :index}, :public => true
49 49 map.permission :add_project, {:projects => :add}, :require => :loggedin
50 50 map.permission :edit_project, {:projects => [:settings, :edit]}, :require => :member
51 51 map.permission :select_project_modules, {:projects => :modules}, :require => :member
52 52 map.permission :manage_members, {:projects => :settings, :members => [:new, :edit, :destroy, :autocomplete_for_member]}, :require => :member
53 53 map.permission :manage_versions, {:projects => :settings, :versions => [:new, :edit, :close_completed, :destroy]}, :require => :member
54 54 map.permission :add_subprojects, {:projects => :add}, :require => :member
55 55
56 56 map.project_module :issue_tracking do |map|
57 57 # Issue categories
58 58 map.permission :manage_categories, {:projects => :settings, :issue_categories => [:new, :edit, :destroy]}, :require => :member
59 59 # Issues
60 60 map.permission :view_issues, {:projects => :roadmap,
61 :issues => [:index, :changes, :show],
61 :issues => [:index, :show],
62 62 :auto_complete => [:issues],
63 63 :context_menus => [:issues],
64 64 :versions => [:show, :status_by],
65 :journals => :index,
65 66 :queries => :index,
66 67 :reports => [:issue_report, :issue_report_details]}
67 68 map.permission :add_issues, {:issues => [:new, :create, :update_form]}
68 69 map.permission :edit_issues, {:issues => [:edit, :update, :bulk_edit, :update_form], :journals => [:new]}
69 70 map.permission :manage_issue_relations, {:issue_relations => [:new, :destroy]}
70 71 map.permission :manage_subtasks, {}
71 72 map.permission :add_issue_notes, {:issues => [:edit, :update], :journals => [:new]}
72 73 map.permission :edit_issue_notes, {:journals => :edit}, :require => :loggedin
73 74 map.permission :edit_own_issue_notes, {:journals => :edit}, :require => :loggedin
74 75 map.permission :move_issues, {:issue_moves => [:new, :create]}, :require => :loggedin
75 76 map.permission :delete_issues, {:issues => :destroy}, :require => :member
76 77 # Queries
77 78 map.permission :manage_public_queries, {:queries => [:new, :edit, :destroy]}, :require => :member
78 79 map.permission :save_queries, {:queries => [:new, :edit, :destroy]}, :require => :loggedin
79 80 # Watchers
80 81 map.permission :view_issue_watchers, {}
81 82 map.permission :add_issue_watchers, {:watchers => :new}
82 83 map.permission :delete_issue_watchers, {:watchers => :destroy}
83 84 end
84 85
85 86 map.project_module :time_tracking do |map|
86 87 map.permission :log_time, {:timelog => :edit}, :require => :loggedin
87 88 map.permission :view_time_entries, :timelog => [:details, :report]
88 89 map.permission :edit_time_entries, {:timelog => [:edit, :destroy]}, :require => :member
89 90 map.permission :edit_own_time_entries, {:timelog => [:edit, :destroy]}, :require => :loggedin
90 91 map.permission :manage_project_activities, {:projects => [:save_activities, :reset_activities]}, :require => :member
91 92 end
92 93
93 94 map.project_module :news do |map|
94 95 map.permission :manage_news, {:news => [:new, :edit, :destroy, :destroy_comment]}, :require => :member
95 96 map.permission :view_news, {:news => [:index, :show]}, :public => true
96 97 map.permission :comment_news, {:news => :add_comment}
97 98 end
98 99
99 100 map.project_module :documents do |map|
100 101 map.permission :manage_documents, {:documents => [:new, :edit, :destroy, :add_attachment]}, :require => :loggedin
101 102 map.permission :view_documents, :documents => [:index, :show, :download]
102 103 end
103 104
104 105 map.project_module :files do |map|
105 106 map.permission :manage_files, {:projects => :add_file}, :require => :loggedin
106 107 map.permission :view_files, :projects => :list_files, :versions => :download
107 108 end
108 109
109 110 map.project_module :wiki do |map|
110 111 map.permission :manage_wiki, {:wikis => [:edit, :destroy]}, :require => :member
111 112 map.permission :rename_wiki_pages, {:wiki => :rename}, :require => :member
112 113 map.permission :delete_wiki_pages, {:wiki => :destroy}, :require => :member
113 114 map.permission :view_wiki_pages, :wiki => [:index, :special]
114 115 map.permission :export_wiki_pages, {}
115 116 map.permission :view_wiki_edits, :wiki => [:history, :diff, :annotate]
116 117 map.permission :edit_wiki_pages, :wiki => [:edit, :preview, :add_attachment]
117 118 map.permission :delete_wiki_pages_attachments, {}
118 119 map.permission :protect_wiki_pages, {:wiki => :protect}, :require => :member
119 120 end
120 121
121 122 map.project_module :repository do |map|
122 123 map.permission :manage_repository, {:repositories => [:edit, :committers, :destroy]}, :require => :member
123 124 map.permission :browse_repository, :repositories => [:show, :browse, :entry, :annotate, :changes, :diff, :stats, :graph]
124 125 map.permission :view_changesets, :repositories => [:show, :revisions, :revision]
125 126 map.permission :commit_access, {}
126 127 end
127 128
128 129 map.project_module :boards do |map|
129 130 map.permission :manage_boards, {:boards => [:new, :edit, :destroy]}, :require => :member
130 131 map.permission :view_messages, {:boards => [:index, :show], :messages => [:show]}, :public => true
131 132 map.permission :add_messages, {:messages => [:new, :reply, :quote]}
132 133 map.permission :edit_messages, {:messages => :edit}, :require => :member
133 134 map.permission :edit_own_messages, {:messages => :edit}, :require => :loggedin
134 135 map.permission :delete_messages, {:messages => :destroy}, :require => :member
135 136 map.permission :delete_own_messages, {:messages => :destroy}, :require => :loggedin
136 137 end
137 138
138 139 map.project_module :calendar do |map|
139 140 map.permission :view_calendar, :calendars => :show
140 141 end
141 142
142 143 map.project_module :gantt do |map|
143 144 map.permission :view_gantt, :gantts => :show
144 145 end
145 146 end
146 147
147 148 Redmine::MenuManager.map :top_menu do |menu|
148 149 menu.push :home, :home_path
149 150 menu.push :my_page, { :controller => 'my', :action => 'page' }, :if => Proc.new { User.current.logged? }
150 151 menu.push :projects, { :controller => 'projects', :action => 'index' }, :caption => :label_project_plural
151 152 menu.push :administration, { :controller => 'admin', :action => 'index' }, :if => Proc.new { User.current.admin? }, :last => true
152 153 menu.push :help, Redmine::Info.help_url, :last => true
153 154 end
154 155
155 156 Redmine::MenuManager.map :account_menu do |menu|
156 157 menu.push :login, :signin_path, :if => Proc.new { !User.current.logged? }
157 158 menu.push :register, { :controller => 'account', :action => 'register' }, :if => Proc.new { !User.current.logged? && Setting.self_registration? }
158 159 menu.push :my_account, { :controller => 'my', :action => 'account' }, :if => Proc.new { User.current.logged? }
159 160 menu.push :logout, :signout_path, :if => Proc.new { User.current.logged? }
160 161 end
161 162
162 163 Redmine::MenuManager.map :application_menu do |menu|
163 164 # Empty
164 165 end
165 166
166 167 Redmine::MenuManager.map :admin_menu do |menu|
167 168 menu.push :projects, {:controller => 'admin', :action => 'projects'}, :caption => :label_project_plural
168 169 menu.push :users, {:controller => 'users'}, :caption => :label_user_plural
169 170 menu.push :groups, {:controller => 'groups'}, :caption => :label_group_plural
170 171 menu.push :roles, {:controller => 'roles'}, :caption => :label_role_and_permissions
171 172 menu.push :trackers, {:controller => 'trackers'}, :caption => :label_tracker_plural
172 173 menu.push :issue_statuses, {:controller => 'issue_statuses'}, :caption => :label_issue_status_plural,
173 174 :html => {:class => 'issue_statuses'}
174 175 menu.push :workflows, {:controller => 'workflows', :action => 'edit'}, :caption => :label_workflow
175 176 menu.push :custom_fields, {:controller => 'custom_fields'}, :caption => :label_custom_field_plural,
176 177 :html => {:class => 'custom_fields'}
177 178 menu.push :enumerations, {:controller => 'enumerations'}
178 179 menu.push :settings, {:controller => 'settings'}
179 180 menu.push :ldap_authentication, {:controller => 'ldap_auth_sources', :action => 'index'},
180 181 :html => {:class => 'server_authentication'}
181 182 menu.push :plugins, {:controller => 'admin', :action => 'plugins'}, :last => true
182 183 menu.push :info, {:controller => 'admin', :action => 'info'}, :caption => :label_information_plural, :last => true
183 184 end
184 185
185 186 Redmine::MenuManager.map :project_menu do |menu|
186 187 menu.push :overview, { :controller => 'projects', :action => 'show' }
187 188 menu.push :activity, { :controller => 'projects', :action => 'activity' }
188 189 menu.push :roadmap, { :controller => 'projects', :action => 'roadmap' },
189 190 :if => Proc.new { |p| p.shared_versions.any? }
190 191 menu.push :issues, { :controller => 'issues', :action => 'index' }, :param => :project_id, :caption => :label_issue_plural
191 192 menu.push :new_issue, { :controller => 'issues', :action => 'new' }, :param => :project_id, :caption => :label_issue_new,
192 193 :html => { :accesskey => Redmine::AccessKeys.key_for(:new_issue) }
193 194 menu.push :gantt, { :controller => 'gantts', :action => 'show' }, :param => :project_id, :caption => :label_gantt
194 195 menu.push :calendar, { :controller => 'calendars', :action => 'show' }, :param => :project_id, :caption => :label_calendar
195 196 menu.push :news, { :controller => 'news', :action => 'index' }, :param => :project_id, :caption => :label_news_plural
196 197 menu.push :documents, { :controller => 'documents', :action => 'index' }, :param => :project_id, :caption => :label_document_plural
197 198 menu.push :wiki, { :controller => 'wiki', :action => 'index', :page => nil },
198 199 :if => Proc.new { |p| p.wiki && !p.wiki.new_record? }
199 200 menu.push :boards, { :controller => 'boards', :action => 'index', :id => nil }, :param => :project_id,
200 201 :if => Proc.new { |p| p.boards.any? }, :caption => :label_board_plural
201 202 menu.push :files, { :controller => 'projects', :action => 'list_files' }, :caption => :label_file_plural
202 203 menu.push :repository, { :controller => 'repositories', :action => 'show' },
203 204 :if => Proc.new { |p| p.repository && !p.repository.new_record? }
204 205 menu.push :settings, { :controller => 'projects', :action => 'settings' }, :last => true
205 206 end
206 207
207 208 Redmine::Activity.map do |activity|
208 209 activity.register :issues, :class_name => %w(Issue Journal)
209 210 activity.register :changesets
210 211 activity.register :news
211 212 activity.register :documents, :class_name => %w(Document Attachment)
212 213 activity.register :files, :class_name => 'Attachment'
213 214 activity.register :wiki_edits, :class_name => 'WikiContent::Version', :default => false
214 215 activity.register :messages, :default => false
215 216 activity.register :time_entries, :default => false
216 217 end
217 218
218 219 Redmine::Search.map do |search|
219 220 search.register :issues
220 221 search.register :news
221 222 search.register :documents
222 223 search.register :changesets
223 224 search.register :wiki_pages
224 225 search.register :messages
225 226 search.register :projects
226 227 end
227 228
228 229 Redmine::WikiFormatting.map do |format|
229 230 format.register :textile, Redmine::WikiFormatting::Textile::Formatter, Redmine::WikiFormatting::Textile::Helper
230 231 end
General Comments 0
You need to be logged in to leave comments. Login now