To check out this repository please hg clone the following URL, or open the URL using EasyMercurial or your preferred Mercurial client.
root / app / controllers / .svn / text-base / roles_controller.rb.svn-base @ 442:753f1380d6bc
History | View | Annotate | Download (2.58 KB)
| 1 | 0:513646585e45 | Chris | # redMine - project management software |
|---|---|---|---|
| 2 | # Copyright (C) 2006 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 RolesController < ApplicationController |
||
| 19 | layout 'admin' |
||
| 20 | |||
| 21 | before_filter :require_admin |
||
| 22 | |||
| 23 | verify :method => :post, :only => [ :destroy, :move ], |
||
| 24 | :redirect_to => { :action => :index }
|
||
| 25 | |||
| 26 | def index |
||
| 27 | @role_pages, @roles = paginate :roles, :per_page => 25, :order => 'builtin, position' |
||
| 28 | render :action => "index", :layout => false if request.xhr? |
||
| 29 | end |
||
| 30 | |||
| 31 | def new |
||
| 32 | # Prefills the form with 'Non member' role permissions |
||
| 33 | @role = Role.new(params[:role] || {:permissions => Role.non_member.permissions})
|
||
| 34 | if request.post? && @role.save |
||
| 35 | # workflow copy |
||
| 36 | if !params[:copy_workflow_from].blank? && (copy_from = Role.find_by_id(params[:copy_workflow_from])) |
||
| 37 | @role.workflows.copy(copy_from) |
||
| 38 | end |
||
| 39 | flash[:notice] = l(:notice_successful_create) |
||
| 40 | redirect_to :action => 'index' |
||
| 41 | 441:cbce1fd3b1b7 | Chris | else |
| 42 | @permissions = @role.setable_permissions |
||
| 43 | @roles = Role.find :all, :order => 'builtin, position' |
||
| 44 | 0:513646585e45 | Chris | end |
| 45 | end |
||
| 46 | |||
| 47 | def edit |
||
| 48 | @role = Role.find(params[:id]) |
||
| 49 | if request.post? and @role.update_attributes(params[:role]) |
||
| 50 | flash[:notice] = l(:notice_successful_update) |
||
| 51 | redirect_to :action => 'index' |
||
| 52 | 441:cbce1fd3b1b7 | Chris | else |
| 53 | @permissions = @role.setable_permissions |
||
| 54 | 0:513646585e45 | Chris | end |
| 55 | end |
||
| 56 | |||
| 57 | def destroy |
||
| 58 | @role = Role.find(params[:id]) |
||
| 59 | @role.destroy |
||
| 60 | redirect_to :action => 'index' |
||
| 61 | rescue |
||
| 62 | flash[:error] = l(:error_can_not_remove_role) |
||
| 63 | redirect_to :action => 'index' |
||
| 64 | end |
||
| 65 | |||
| 66 | def report |
||
| 67 | @roles = Role.find(:all, :order => 'builtin, position') |
||
| 68 | @permissions = Redmine::AccessControl.permissions.select { |p| !p.public? }
|
||
| 69 | if request.post? |
||
| 70 | @roles.each do |role| |
||
| 71 | role.permissions = params[:permissions][role.id.to_s] |
||
| 72 | role.save |
||
| 73 | end |
||
| 74 | flash[:notice] = l(:notice_successful_update) |
||
| 75 | redirect_to :action => 'index' |
||
| 76 | end |
||
| 77 | end |
||
| 78 | end |