gem cancan访问被拒绝的mainController#dashboard

时间:2017-06-12 10:55:52

标签: ruby-on-rails ruby localhost cancancan

我正在关注onebitcode教程但是我无法实现这个gem,我更新了数据库,我上传了种子,我重新启动了服务器,但没有任何效果,如果我在GemFile中评论gem,它会再次运行,但是没有cancancan ...浏览器中弹出错误,但我无法弄清楚如何解决它。

#Error
  

CanCan :: AccessDenied在RailsAdmin :: MainController#dashboard

中      

您无权访问此页面。

     

提取的来源(第217行):

    if cannot?(action, subject, *args)
        message ||= unauthorized_message(action, subject)
        raise AccessDenied.new(message, action, subject)
      end
      subject
     end


#Ability.rb
class Ability
  include CanCan::Ability

  def initialize(user)

 
  end
end

#rails_admin.rb
RailsAdmin.config do |config|

  ## == Devise ==
    config.authenticate_with do
       warden.authenticate! scope: :user
    end
    config.current_user_method(&:current_user)

##== Cancancan ==
   config.authorize_with :cancan

  config.actions do
    dashboard                     # mandatory
    index                         # mandatory
    new
    export
    bulk_delete
    show
    edit
    delete
    show_in_app

  end
end

#gemfile
source 'https://rubygems.org'
gem 'rails', '4.2.6'
gem 'sqlite3'
gem 'sass-rails', '~> 5.0'
gem 'uglifier', '>= 1.3.0'
gem 'coffee-rails', '~> 4.1.0'
gem 'jquery-rails'
gem 'turbolinks'
gem 'jbuilder', '~> 2.0'
gem 'sdoc', '~> 0.4.0', group: :doc
gem 'rails_admin'
gem 'devise'
gem 'cancancan'

group :development, :test do
    gem 'byebug'
end
group :development do
 gem 'web-console', '~> 2.0'
  gem 'spring'
end

#routes.rb
Rails.application.routes.draw do
  devise_for :users
  mount RailsAdmin::Engine => '/', as: 'rails_admin'
  resources :group_users
  resources :groups
  resources :users
  resources :company_sectors
  resources :sectors
  resources :companies

end

#seed.rb
#users
User.create name: 'Jose', kind: :user, email: 'user@teste.com', password: 123456
User.create name: 'Marcos', kind: :manager, email: 'manager@teste.com', password: 123456

#grupo
Group.create name: 'Grupo teste 1'
Group.create name: 'Grupo teste 2'

#Setor
Sector.create name: 'Grupo 1'
Sector.create name: 'Grupo 2'

#user.rb
class User < ActiveRecord::Base
  # Include default devise modules. Others available are:
  # :confirmable, :lockable, :timeoutable and :omniauthable
  devise :database_authenticatable, :registerable,
         :recoverable, :rememberable, :trackable, :validatable
  belongs_to :company_sector
  enum kind: [:user, :manager]
end

#users_controller.rb
class UsersController < ApplicationController
  before_action :set_user, only: [:show, :edit, :update, :destroy]

  def index
    @users = User.all
  end

  def show
  end

  def new
    @user = User.new
  end

  def edit
  end

  def create
    @user = User.new(user_params)

    respond_to do |format|
      if @user.save
        format.html { redirect_to @user, notice: 'User was successfully created.' }
        format.json { render :show, status: :created, location: @user }
      else
        format.html { render :new }
        format.json { render json: @user.errors, status: :unprocessable_entity }
      end
    end
  end

  def update
    respond_to do |format|
      if @user.update(user_params)
        format.html { redirect_to @user, notice: 'User was successfully updated.' }
        format.json { render :show, status: :ok, location: @user }
      else
        format.html { render :edit }
        format.json { render json: @user.errors, status: :unprocessable_entity }
      end
    end
  end

  def destroy
    @user.destroy
    respond_to do |format|
      format.html { redirect_to users_url, notice: 'User was successfully destroyed.' }
      format.json { head :no_content }
    end
  end

  private
    def set_user
      @user = User.find(params[:id])
    end
    def user_params
      params.require(:user).permit(:company_sector_id, :kind, :name)
    end
end

3 个答案:

答案 0 :(得分:2)

我解决了这个问题:

#Ability.rb
class Ability
  include CanCan::Ability

  def initialize(user)
        can :dashboard, :all
        can :access, :rails_admin
       #to allow access, you have to put this.
  end
end

答案 1 :(得分:0)

您必须传递can :manage, :all并使条件为true才能访问这些页面。

尝试以下代码:

class Ability
  include CanCan::Ability

    def initialize(user)
      user ||= User.new # guest user (not logged in)
      if user.email == "user@teste.com" # you can add any condition
        can :manage, :all
      end
    end
end

答案 2 :(得分:0)

我通过在Gemfile中交换gems解决了这个问题。

gem 'devise', '~> 4.3'

gem 'cancancan', '~> 1.15.0'

我的问题在于版本,我已经指定了这两个版本,现在它正在运行。