mirror of https://github.com/tootsuite/mastodon
				
				
				
			
		
			
				
	
	
		
			68 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
			
		
		
	
	
			68 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			Ruby
		
	
	
| # frozen_string_literal: true
 | |
| 
 | |
| module Admin
 | |
|   class RolesController < BaseController
 | |
|     before_action :set_role, except: [:index, :new, :create]
 | |
| 
 | |
|     def index
 | |
|       authorize :user_role, :index?
 | |
| 
 | |
|       @roles = UserRole.order(position: :desc).page(params[:page])
 | |
|     end
 | |
| 
 | |
|     def new
 | |
|       authorize :user_role, :create?
 | |
| 
 | |
|       @role = UserRole.new
 | |
|     end
 | |
| 
 | |
|     def edit
 | |
|       authorize @role, :update?
 | |
|     end
 | |
| 
 | |
|     def create
 | |
|       authorize :user_role, :create?
 | |
| 
 | |
|       @role = UserRole.new(resource_params)
 | |
|       @role.current_account = current_account
 | |
| 
 | |
|       if @role.save
 | |
|         log_action :create, @role
 | |
|         redirect_to admin_roles_path
 | |
|       else
 | |
|         render :new
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     def update
 | |
|       authorize @role, :update?
 | |
| 
 | |
|       @role.current_account = current_account
 | |
| 
 | |
|       if @role.update(resource_params)
 | |
|         log_action :update, @role
 | |
|         redirect_to admin_roles_path
 | |
|       else
 | |
|         render :edit
 | |
|       end
 | |
|     end
 | |
| 
 | |
|     def destroy
 | |
|       authorize @role, :destroy?
 | |
|       @role.destroy!
 | |
|       log_action :destroy, @role
 | |
|       redirect_to admin_roles_path
 | |
|     end
 | |
| 
 | |
|     private
 | |
| 
 | |
|     def set_role
 | |
|       @role = UserRole.find(params[:id])
 | |
|     end
 | |
| 
 | |
|     def resource_params
 | |
|       params.require(:user_role).permit(:name, :color, :highlighted, :position, permissions_as_keys: [])
 | |
|     end
 | |
|   end
 | |
| end
 |