##// END OF EJS Templates
Display view permissions first....
Jean-Philippe Lang -
r15085:2691613c55c1
parent child
Show More
@@ -1,278 +1,278
1 1 # Redmine - project management software
2 2 # Copyright (C) 2006-2016 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 require 'redmine/core_ext'
19 19
20 20 begin
21 21 require 'rmagick' unless Object.const_defined?(:Magick)
22 22 rescue LoadError
23 23 # RMagick is not available
24 24 end
25 25 begin
26 26 require 'redcarpet' unless Object.const_defined?(:Redcarpet)
27 27 rescue LoadError
28 28 # Redcarpet is not available
29 29 end
30 30
31 31 require 'redmine/acts/positioned'
32 32
33 33 require 'redmine/scm/base'
34 34 require 'redmine/access_control'
35 35 require 'redmine/access_keys'
36 36 require 'redmine/activity'
37 37 require 'redmine/activity/fetcher'
38 38 require 'redmine/ciphering'
39 39 require 'redmine/codeset_util'
40 40 require 'redmine/field_format'
41 41 require 'redmine/menu_manager'
42 42 require 'redmine/notifiable'
43 43 require 'redmine/platform'
44 44 require 'redmine/mime_type'
45 45 require 'redmine/notifiable'
46 46 require 'redmine/search'
47 47 require 'redmine/syntax_highlighting'
48 48 require 'redmine/thumbnail'
49 49 require 'redmine/unified_diff'
50 50 require 'redmine/utils'
51 51 require 'redmine/version'
52 52 require 'redmine/wiki_formatting'
53 53
54 54 require 'redmine/default_data/loader'
55 55 require 'redmine/helpers/calendar'
56 56 require 'redmine/helpers/diff'
57 57 require 'redmine/helpers/gantt'
58 58 require 'redmine/helpers/time_report'
59 59 require 'redmine/views/other_formats_builder'
60 60 require 'redmine/views/labelled_form_builder'
61 61 require 'redmine/views/builders'
62 62
63 63 require 'redmine/themes'
64 64 require 'redmine/hook'
65 65 require 'redmine/hook/listener'
66 66 require 'redmine/hook/view_listener'
67 67 require 'redmine/plugin'
68 68
69 69 Redmine::Scm::Base.add "Subversion"
70 70 Redmine::Scm::Base.add "Darcs"
71 71 Redmine::Scm::Base.add "Mercurial"
72 72 Redmine::Scm::Base.add "Cvs"
73 73 Redmine::Scm::Base.add "Bazaar"
74 74 Redmine::Scm::Base.add "Git"
75 75 Redmine::Scm::Base.add "Filesystem"
76 76
77 77 # Permissions
78 78 Redmine::AccessControl.map do |map|
79 79 map.permission :view_project, {:projects => [:show], :activities => [:index]}, :public => true, :read => true
80 80 map.permission :search_project, {:search => :index}, :public => true, :read => true
81 81 map.permission :add_project, {:projects => [:new, :create]}, :require => :loggedin
82 82 map.permission :edit_project, {:projects => [:settings, :edit, :update]}, :require => :member
83 83 map.permission :close_project, {:projects => [:close, :reopen]}, :require => :member, :read => true
84 84 map.permission :select_project_modules, {:projects => :modules}, :require => :member
85 85 map.permission :view_members, {:members => [:index, :show]}, :public => true, :read => true
86 86 map.permission :manage_members, {:projects => :settings, :members => [:index, :show, :new, :create, :update, :destroy, :autocomplete]}, :require => :member
87 87 map.permission :manage_versions, {:projects => :settings, :versions => [:new, :create, :edit, :update, :close_completed, :destroy]}, :require => :member
88 88 map.permission :add_subprojects, {:projects => [:new, :create]}, :require => :member
89 89
90 90 map.project_module :issue_tracking do |map|
91 # Issue categories
92 map.permission :manage_categories, {:projects => :settings, :issue_categories => [:index, :show, :new, :create, :edit, :update, :destroy]}, :require => :member
93 91 # Issues
94 92 map.permission :view_issues, {:issues => [:index, :show],
95 93 :auto_complete => [:issues],
96 94 :context_menus => [:issues],
97 95 :versions => [:index, :show, :status_by],
98 96 :journals => [:index, :diff],
99 97 :queries => :index,
100 98 :reports => [:issue_report, :issue_report_details]},
101 99 :read => true
102 100 map.permission :add_issues, {:issues => [:new, :create], :attachments => :upload}
103 101 map.permission :edit_issues, {:issues => [:edit, :update, :bulk_edit, :bulk_update], :journals => [:new], :attachments => :upload}
104 102 map.permission :copy_issues, {:issues => [:new, :create, :bulk_edit, :bulk_update], :attachments => :upload}
105 103 map.permission :manage_issue_relations, {:issue_relations => [:index, :show, :create, :destroy]}
106 104 map.permission :manage_subtasks, {}
107 105 map.permission :set_issues_private, {}
108 106 map.permission :set_own_issues_private, {}, :require => :loggedin
109 107 map.permission :add_issue_notes, {:issues => [:edit, :update], :journals => [:new], :attachments => :upload}
110 108 map.permission :edit_issue_notes, {:journals => [:edit, :update]}, :require => :loggedin
111 109 map.permission :edit_own_issue_notes, {:journals => [:edit, :update]}, :require => :loggedin
112 110 map.permission :view_private_notes, {}, :read => true, :require => :member
113 111 map.permission :set_notes_private, {}, :require => :member
114 112 map.permission :delete_issues, {:issues => :destroy}, :require => :member
115 113 # Queries
116 114 map.permission :manage_public_queries, {:queries => [:new, :create, :edit, :update, :destroy]}, :require => :member
117 115 map.permission :save_queries, {:queries => [:new, :create, :edit, :update, :destroy]}, :require => :loggedin
118 116 # Watchers
119 117 map.permission :view_issue_watchers, {}, :read => true
120 118 map.permission :add_issue_watchers, {:watchers => [:new, :create, :append, :autocomplete_for_user]}
121 119 map.permission :delete_issue_watchers, {:watchers => :destroy}
122 120 map.permission :import_issues, {:imports => [:new, :create, :settings, :mapping, :run, :show]}
121 # Issue categories
122 map.permission :manage_categories, {:projects => :settings, :issue_categories => [:index, :show, :new, :create, :edit, :update, :destroy]}, :require => :member
123 123 end
124 124
125 125 map.project_module :time_tracking do |map|
126 map.permission :log_time, {:timelog => [:new, :create]}, :require => :loggedin
127 126 map.permission :view_time_entries, {:timelog => [:index, :report, :show]}, :read => true
127 map.permission :log_time, {:timelog => [:new, :create]}, :require => :loggedin
128 128 map.permission :edit_time_entries, {:timelog => [:edit, :update, :destroy, :bulk_edit, :bulk_update]}, :require => :member
129 129 map.permission :edit_own_time_entries, {:timelog => [:edit, :update, :destroy,:bulk_edit, :bulk_update]}, :require => :loggedin
130 130 map.permission :manage_project_activities, {:project_enumerations => [:update, :destroy]}, :require => :member
131 131 end
132 132
133 133 map.project_module :news do |map|
134 map.permission :manage_news, {:news => [:new, :create, :edit, :update, :destroy], :comments => [:destroy], :attachments => :upload}, :require => :member
135 134 map.permission :view_news, {:news => [:index, :show]}, :public => true, :read => true
135 map.permission :manage_news, {:news => [:new, :create, :edit, :update, :destroy], :comments => [:destroy], :attachments => :upload}, :require => :member
136 136 map.permission :comment_news, {:comments => :create}
137 137 end
138 138
139 139 map.project_module :documents do |map|
140 map.permission :view_documents, {:documents => [:index, :show, :download]}, :read => true
140 141 map.permission :add_documents, {:documents => [:new, :create, :add_attachment], :attachments => :upload}, :require => :loggedin
141 142 map.permission :edit_documents, {:documents => [:edit, :update, :add_attachment], :attachments => :upload}, :require => :loggedin
142 143 map.permission :delete_documents, {:documents => [:destroy]}, :require => :loggedin
143 map.permission :view_documents, {:documents => [:index, :show, :download]}, :read => true
144 144 end
145 145
146 146 map.project_module :files do |map|
147 map.permission :manage_files, {:files => [:new, :create], :attachments => :upload}, :require => :loggedin
148 147 map.permission :view_files, {:files => :index, :versions => :download}, :read => true
148 map.permission :manage_files, {:files => [:new, :create], :attachments => :upload}, :require => :loggedin
149 149 end
150 150
151 151 map.project_module :wiki do |map|
152 map.permission :manage_wiki, {:wikis => [:edit, :destroy]}, :require => :member
153 map.permission :rename_wiki_pages, {:wiki => :rename}, :require => :member
154 map.permission :delete_wiki_pages, {:wiki => [:destroy, :destroy_version]}, :require => :member
155 152 map.permission :view_wiki_pages, {:wiki => [:index, :show, :special, :date_index]}, :read => true
156 map.permission :export_wiki_pages, {:wiki => [:export]}, :read => true
157 153 map.permission :view_wiki_edits, {:wiki => [:history, :diff, :annotate]}, :read => true
154 map.permission :export_wiki_pages, {:wiki => [:export]}, :read => true
158 155 map.permission :edit_wiki_pages, :wiki => [:new, :edit, :update, :preview, :add_attachment], :attachments => :upload
156 map.permission :rename_wiki_pages, {:wiki => :rename}, :require => :member
157 map.permission :delete_wiki_pages, {:wiki => [:destroy, :destroy_version]}, :require => :member
159 158 map.permission :delete_wiki_pages_attachments, {}
160 159 map.permission :protect_wiki_pages, {:wiki => :protect}, :require => :member
160 map.permission :manage_wiki, {:wikis => [:edit, :destroy]}, :require => :member
161 161 end
162 162
163 163 map.project_module :repository do |map|
164 map.permission :manage_repository, {:repositories => [:new, :create, :edit, :update, :committers, :destroy]}, :require => :member
165 map.permission :browse_repository, {:repositories => [:show, :browse, :entry, :raw, :annotate, :changes, :diff, :stats, :graph]}, :read => true
166 164 map.permission :view_changesets, {:repositories => [:show, :revisions, :revision]}, :read => true
165 map.permission :browse_repository, {:repositories => [:show, :browse, :entry, :raw, :annotate, :changes, :diff, :stats, :graph]}, :read => true
167 166 map.permission :commit_access, {}
168 167 map.permission :manage_related_issues, {:repositories => [:add_related_issue, :remove_related_issue]}
168 map.permission :manage_repository, {:repositories => [:new, :create, :edit, :update, :committers, :destroy]}, :require => :member
169 169 end
170 170
171 171 map.project_module :boards do |map|
172 map.permission :manage_boards, {:boards => [:new, :create, :edit, :update, :destroy]}, :require => :member
173 172 map.permission :view_messages, {:boards => [:index, :show], :messages => [:show]}, :public => true, :read => true
174 173 map.permission :add_messages, {:messages => [:new, :reply, :quote], :attachments => :upload}
175 174 map.permission :edit_messages, {:messages => :edit, :attachments => :upload}, :require => :member
176 175 map.permission :edit_own_messages, {:messages => :edit, :attachments => :upload}, :require => :loggedin
177 176 map.permission :delete_messages, {:messages => :destroy}, :require => :member
178 177 map.permission :delete_own_messages, {:messages => :destroy}, :require => :loggedin
178 map.permission :manage_boards, {:boards => [:new, :create, :edit, :update, :destroy]}, :require => :member
179 179 end
180 180
181 181 map.project_module :calendar do |map|
182 182 map.permission :view_calendar, {:calendars => [:show, :update]}, :read => true
183 183 end
184 184
185 185 map.project_module :gantt do |map|
186 186 map.permission :view_gantt, {:gantts => [:show, :update]}, :read => true
187 187 end
188 188 end
189 189
190 190 Redmine::MenuManager.map :top_menu do |menu|
191 191 menu.push :home, :home_path
192 192 menu.push :my_page, { :controller => 'my', :action => 'page' }, :if => Proc.new { User.current.logged? }
193 193 menu.push :projects, { :controller => 'projects', :action => 'index' }, :caption => :label_project_plural
194 194 menu.push :administration, { :controller => 'admin', :action => 'index' }, :if => Proc.new { User.current.admin? }, :last => true
195 195 menu.push :help, Redmine::Info.help_url, :last => true
196 196 end
197 197
198 198 Redmine::MenuManager.map :account_menu do |menu|
199 199 menu.push :login, :signin_path, :if => Proc.new { !User.current.logged? }
200 200 menu.push :register, :register_path, :if => Proc.new { !User.current.logged? && Setting.self_registration? }
201 201 menu.push :my_account, { :controller => 'my', :action => 'account' }, :if => Proc.new { User.current.logged? }
202 202 menu.push :logout, :signout_path, :html => {:method => 'post'}, :if => Proc.new { User.current.logged? }
203 203 end
204 204
205 205 Redmine::MenuManager.map :application_menu do |menu|
206 206 # Empty
207 207 end
208 208
209 209 Redmine::MenuManager.map :admin_menu do |menu|
210 210 menu.push :projects, {:controller => 'admin', :action => 'projects'}, :caption => :label_project_plural
211 211 menu.push :users, {:controller => 'users'}, :caption => :label_user_plural
212 212 menu.push :groups, {:controller => 'groups'}, :caption => :label_group_plural
213 213 menu.push :roles, {:controller => 'roles'}, :caption => :label_role_and_permissions
214 214 menu.push :trackers, {:controller => 'trackers'}, :caption => :label_tracker_plural
215 215 menu.push :issue_statuses, {:controller => 'issue_statuses'}, :caption => :label_issue_status_plural,
216 216 :html => {:class => 'issue_statuses'}
217 217 menu.push :workflows, {:controller => 'workflows', :action => 'edit'}, :caption => :label_workflow
218 218 menu.push :custom_fields, {:controller => 'custom_fields'}, :caption => :label_custom_field_plural,
219 219 :html => {:class => 'custom_fields'}
220 220 menu.push :enumerations, {:controller => 'enumerations'}
221 221 menu.push :settings, {:controller => 'settings'}
222 222 menu.push :ldap_authentication, {:controller => 'auth_sources', :action => 'index'},
223 223 :html => {:class => 'server_authentication'}
224 224 menu.push :plugins, {:controller => 'admin', :action => 'plugins'}, :last => true
225 225 menu.push :info, {:controller => 'admin', :action => 'info'}, :caption => :label_information_plural, :last => true
226 226 end
227 227
228 228 Redmine::MenuManager.map :project_menu do |menu|
229 229 menu.push :overview, { :controller => 'projects', :action => 'show' }
230 230 menu.push :activity, { :controller => 'activities', :action => 'index' }
231 231 menu.push :roadmap, { :controller => 'versions', :action => 'index' }, :param => :project_id,
232 232 :if => Proc.new { |p| p.shared_versions.any? }
233 233 menu.push :issues, { :controller => 'issues', :action => 'index' }, :param => :project_id, :caption => :label_issue_plural
234 234 menu.push :new_issue, { :controller => 'issues', :action => 'new', :copy_from => nil }, :param => :project_id, :caption => :label_issue_new,
235 235 :html => { :accesskey => Redmine::AccessKeys.key_for(:new_issue) },
236 236 :if => Proc.new { |p| Setting.new_project_issue_tab_enabled? && Issue.allowed_target_trackers(p).any? },
237 237 :permission => :add_issues
238 238 menu.push :gantt, { :controller => 'gantts', :action => 'show' }, :param => :project_id, :caption => :label_gantt
239 239 menu.push :calendar, { :controller => 'calendars', :action => 'show' }, :param => :project_id, :caption => :label_calendar
240 240 menu.push :news, { :controller => 'news', :action => 'index' }, :param => :project_id, :caption => :label_news_plural
241 241 menu.push :documents, { :controller => 'documents', :action => 'index' }, :param => :project_id, :caption => :label_document_plural
242 242 menu.push :wiki, { :controller => 'wiki', :action => 'show', :id => nil }, :param => :project_id,
243 243 :if => Proc.new { |p| p.wiki && !p.wiki.new_record? }
244 244 menu.push :boards, { :controller => 'boards', :action => 'index', :id => nil }, :param => :project_id,
245 245 :if => Proc.new { |p| p.boards.any? }, :caption => :label_board_plural
246 246 menu.push :files, { :controller => 'files', :action => 'index' }, :caption => :label_file_plural, :param => :project_id
247 247 menu.push :repository, { :controller => 'repositories', :action => 'show', :repository_id => nil, :path => nil, :rev => nil },
248 248 :if => Proc.new { |p| p.repository && !p.repository.new_record? }
249 249 menu.push :settings, { :controller => 'projects', :action => 'settings' }, :last => true
250 250 end
251 251
252 252 Redmine::Activity.map do |activity|
253 253 activity.register :issues, :class_name => %w(Issue Journal)
254 254 activity.register :changesets
255 255 activity.register :news
256 256 activity.register :documents, :class_name => %w(Document Attachment)
257 257 activity.register :files, :class_name => 'Attachment'
258 258 activity.register :wiki_edits, :class_name => 'WikiContent::Version', :default => false
259 259 activity.register :messages, :default => false
260 260 activity.register :time_entries, :default => false
261 261 end
262 262
263 263 Redmine::Search.map do |search|
264 264 search.register :issues
265 265 search.register :news
266 266 search.register :documents
267 267 search.register :changesets
268 268 search.register :wiki_pages
269 269 search.register :messages
270 270 search.register :projects
271 271 end
272 272
273 273 Redmine::WikiFormatting.map do |format|
274 274 format.register :textile
275 275 format.register :markdown if Object.const_defined?(:Redcarpet)
276 276 end
277 277
278 278 ActionView::Template.register_template_handler :rsb, Redmine::Views::ApiTemplateHandler
General Comments 0
You need to be logged in to leave comments. Login now