Class: RolesController
- Inherits:
-
ApplicationController
- Object
- ActionController::Base
- ApplicationController
- RolesController
- Includes:
- RolesHelper
- Defined in:
- app/controllers/roles_controller.rb
Overview
Redmine - project management software Copyright © 2006-2022 Jean-Philippe Lang
This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.
You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
Constant Summary
Constants included from ApplicationHelper
ApplicationHelper::ATTACHMENT_CONTAINER_LINK, ApplicationHelper::HEADING_RE, ApplicationHelper::LINKS_RE, ApplicationHelper::MACROS_RE, ApplicationHelper::MACRO_SUB_RE, ApplicationHelper::RECORD_LINK, ApplicationHelper::TOC_RE
Instance Method Summary collapse
- #create ⇒ Object
- #destroy ⇒ Object
- #edit ⇒ Object
- #index ⇒ Object
- #new ⇒ Object
- #permissions ⇒ Object
- #show ⇒ Object
- #update ⇒ Object
- #update_permissions ⇒ Object
Methods included from RolesHelper
Methods included from ApplicationHelper
#accesskey, #actions_dropdown, #anchor, #api_meta, #authoring, #authorize_for, #back_url_hidden_field_tag, #body_css_classes, #breadcrumb, #bulk_edit_error_messages, #calendar_for, #cancel_button_tag, #catch_macros, #check_all_links, #checked_image, #context_menu, #copy_object_url_link, #default_search_project_scope, #delete_link, #due_date_distance_in_words, #email_delivery_enabled?, #error_messages_for, #export_csv_encoding_select_tag, #favicon, #favicon_path, #favicon_url, #form_tag_html, #format_activity_day, #format_activity_description, #format_activity_title, #format_changeset_comments, #format_object, #format_version_name, #get_tab_action, #heads_for_auto_complete, #html_hours, #html_title, #image_tag, #include_calendar_headers_tags, #include_in_api_response?, #inject_macros, #javascript_heads, #javascript_include_tag, #labelled_fields_for, #labelled_form_for, #lang_options_for_select, #link_to_attachment, #link_to_attachment_container, #link_to_context_menu, #link_to_function, #link_to_group, #link_to_if_authorized, #link_to_issue, #link_to_message, #link_to_month, #link_to_next_month, #link_to_previous_month, #link_to_principal, #link_to_project, #link_to_project_settings, #link_to_record, #link_to_revision, #link_to_user, #link_to_version, #markdown_formatter, #option_tag, #other_formats_links, #page_header_title, #parse_headings, #parse_hires_images, #parse_inline_attachments, #parse_non_pre_blocks, #parse_redmine_links, #parse_sections, #parse_wiki_links, #principals_check_box_tags, #principals_options_for_select, #progress_bar, #project_tree, #project_tree_options_for_select, #projects_for_jump_box, #raw_json, #render_error_messages, #render_flash_messages, #render_if_exist, #render_page_hierarchy, #render_project_jump_box, #render_project_nested_lists, #render_projects_for_jump_box, #render_tabs, #reorder_handle, #replace_toc, #robot_exclusion_tag, #sanitize_anchor_name, #sidebar_content?, #simple_format_without_paragraph, #stylesheet_link_tag, #syntax_highlight, #syntax_highlight_lines, #textilizable, #thumbnail_tag, #time_tag, #title, #to_path_param, #toggle_checkboxes_link, #toggle_link, #truncate_lines, #truncate_single_line_raw, #update_data_sources_for_auto_complete, #view_layouts_base_sidebar_hook_response, #wiki_page_path
Methods included from Redmine::Helpers::URL
#uri_with_link_safe_scheme?, #uri_with_safe_scheme?
Methods included from Redmine::Hook::Helper
Methods included from Redmine::Themes::Helper
#current_theme, #heads_for_theme
Methods included from Redmine::SudoMode::Helper
Methods included from Redmine::Pagination::Helper
#pagination_links_each, #pagination_links_full, #per_page_links, #per_page_options
Methods included from Redmine::I18n
#current_language, #day_letter, #day_name, #find_language, #format_date, #format_hours, #format_time, included, #l, #l_hours, #l_hours_short, #l_or_humanize, #languages_options, #ll, #lu, #month_name, #set_language_if_valid, #valid_languages
Methods included from Redmine::WikiFormatting::Macros::Definitions
#exec_macro, #extract_macro_options, #macro_exists?
Methods inherited from ApplicationController
#_include_layout?, accept_api_auth, #accept_api_auth?, accept_rss_auth, #accept_rss_auth?, #api_key_from_request, #api_offset_and_limit, #api_request?, #api_switch_user_from_request, #authorize, #authorize_global, #autologin_cookie_name, #back_url, #check_if_login_required, #check_password_change, #check_project_privacy, #check_twofa_activation, #deny_access, #filename_for_content_disposition, #find_attachments, #find_current_user, #find_issue, #find_issues, #find_model_object, #find_optional_project, #find_optional_project_by_id, #find_project, #find_project_by_project_id, #find_project_from_association, #handle_unverified_request, #init_twofa_pairing_and_send_code_for, #logged_user=, #logout_user, #missing_template, model_object, #parse_params_for_bulk_update, #parse_qvalues, #per_page_option, #query_error, #query_statement_invalid, #record_project_usage, #redirect_back_or_default, #redirect_to_referer_or, #render_403, #render_404, #render_api_errors, #render_api_head, #render_api_ok, #render_attachment_warning_if_needed, #render_error, #render_feed, #render_validation_errors, #replace_none_values_with_blank, #require_admin, #require_admin_or_api_request, #require_login, #session_expiration, #session_expired?, #set_localization, #start_user_session, #try_to_autologin, #use_layout, #user_setup, #verify_authenticity_token
Methods included from Redmine::SudoMode::Controller
#process_sudo_form, #render_sudo_form, #require_sudo_mode, #sudo_mode, #sudo_timestamp_valid?, #update_sudo_timestamp!
Methods included from Redmine::MenuManager::MenuController
#current_menu, #current_menu_item, included, #menu_items, #redirect_to_menu_item, #redirect_to_project_menu_item
Methods included from Redmine::Search::Controller
#default_search_scope, #default_search_scopes, included
Methods included from AvatarsHelper
#assignee_avatar, #author_avatar, #avatar, #avatar_edit_link
Methods included from GravatarHelper::PublicMethods
#gravatar, #gravatar_api_url, #gravatar_for, #gravatar_url
Methods included from RoutesHelper
#_bulk_update_issues_path, #_new_project_issue_path, #_new_time_entry_path, #_project_calendar_path, #_project_gantt_path, #_project_issues_path, #_project_issues_url, #_project_news_path, #_report_time_entries_path, #_time_entries_path, #board_path
Methods included from Redmine::Pagination
Instance Method Details
#create ⇒ Object
61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 |
# File 'app/controllers/roles_controller.rb', line 61 def create @role = Role.new @role.safe_attributes = params[:role] if request.post? && @role.save # workflow copy if !params[:copy_workflow_from].blank? && (copy_from = Role.find_by_id(params[:copy_workflow_from])) @role.copy_workflow_rules(copy_from) end flash[:notice] = l(:notice_successful_create) redirect_to roles_path else @roles = Role.sorted.to_a render :action => 'new' end end |
#destroy ⇒ Object
98 99 100 101 102 103 104 105 |
# File 'app/controllers/roles_controller.rb', line 98 def destroy begin @role.destroy rescue flash[:error] = l(:error_can_not_remove_role) end redirect_to roles_path end |
#edit ⇒ Object
77 78 |
# File 'app/controllers/roles_controller.rb', line 77 def edit end |
#index ⇒ Object
33 34 35 36 37 38 39 40 41 42 43 |
# File 'app/controllers/roles_controller.rb', line 33 def index respond_to do |format| format.html do @roles = Role.sorted.to_a render :layout => false if request.xhr? end format.api do @roles = Role.givable.to_a end end end |
#new ⇒ Object
51 52 53 54 55 56 57 58 59 |
# File 'app/controllers/roles_controller.rb', line 51 def new # Prefills the form with 'Non member' role permissions by default @role = Role.new @role.safe_attributes = params[:role] || {:permissions => Role.non_member.} if params[:copy].present? && @copy_from = Role.find_by_id(params[:copy]) @role.copy_from(@copy_from) end @roles = Role.sorted.to_a end |
#permissions ⇒ Object
107 108 109 110 111 112 113 114 115 116 117 118 119 120 |
# File 'app/controllers/roles_controller.rb', line 107 def scope = Role.sorted if params[:ids].present? scope = scope.where(:id => params[:ids]) end @roles = scope.to_a @permissions = Redmine::AccessControl..reject(&:public?) respond_to do |format| format.html format.csv do send_data((@roles, @permissions), :type => 'text/csv; header=present', :filename => 'permissions.csv') end end end |
#show ⇒ Object
45 46 47 48 49 |
# File 'app/controllers/roles_controller.rb', line 45 def show respond_to do |format| format.api end end |
#update ⇒ Object
80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 |
# File 'app/controllers/roles_controller.rb', line 80 def update @role.safe_attributes = params[:role] if @role.save respond_to do |format| format.html do flash[:notice] = l(:notice_successful_update) redirect_to roles_path(:page => params[:page]) end format.js {head 200} end else respond_to do |format| format.html {render :action => 'edit'} format.js {head 422} end end end |
#update_permissions ⇒ Object
122 123 124 125 126 127 128 129 130 |
# File 'app/controllers/roles_controller.rb', line 122 def @roles = Role.where(:id => params[:permissions].keys) @roles.each do |role| role. = params[:permissions][role.id.to_s] role.save end flash[:notice] = l(:notice_successful_update) redirect_to roles_path end |