Sha256: fa370376e7d75e792bd8d87204e629bcf925733c867153fbc5cc3fa5a1049e60

Contents?: true

Size: 1.3 KB

Versions: 5

Compression:

Stored size: 1.3 KB

Contents

class RolesController < ApplicationController
  before_action :set_role, only: [:show, :edit, :update, :destroy]
  before_action :check_policy, only: [:index, :new, :create]

  # GET /roles
  # GET /roles.json
  def index
    @roles = Role.order(:position)

    respond_to do |format|
      format.html # index.html.erb
      format.json { render json: @roles }
    end
  end

  # GET /roles/1
  # GET /roles/1.json
  def show
    respond_to do |format|
      format.html # show.html.erb
      format.json { render json: @role }
    end
  end

  # GET /roles/1/edit
  def edit
  end

  # PUT /roles/1
  # PUT /roles/1.json
  def update
    if params[:move]
      move_position(@role, params[:move])
      return
    end

    respond_to do |format|
      if @role.update(role_params)
        format.html { redirect_to @role, notice: t('controller.successfully_updated', model: t('activerecord.models.role')) }
        format.json { head :no_content }
      else
        format.html { render action: "edit" }
        format.json { render json: @role.errors, status: :unprocessable_entity }
      end
    end
  end

  private
  def set_role
    @role = Role.find(params[:id])
    authorize @role
  end

  def check_policy
    authorize Role
  end

  def role_params
    params.require(:role).permit(:name, :display_name, :note)
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
enju_seed-0.3.6 app/controllers/roles_controller.rb
enju_seed-0.3.5 app/controllers/roles_controller.rb
enju_seed-0.4.0.rc.2 app/controllers/roles_controller.rb
enju_seed-0.3.4 app/controllers/roles_controller.rb
enju_seed-0.3.3 app/controllers/roles_controller.rb