ruby-on-rails – CanCan:除了MainApp之外的命名空间中的load_and_authorize_resource

前端之家收集整理的这篇文章主要介绍了ruby-on-rails – CanCan:除了MainApp之外的命名空间中的load_and_authorize_resource前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在我的Rails应用程序中使用CanCan获取权限,我在其中为一些通用表单功能构建了自己的引擎.我想锁定系统中的权限,以便用户无法自由访问我的引擎控制器的操作.这些控制器大多只使用7个REST动作,所以我想在每个控制器的顶部使用CanCan的load_and_authorize_resource.

但是,当我像这样编写代码时:

module MyEngine
      class FormController < ApplicationController
        load_and_authorize_resource
        ...
      end
    end

我收到此错误

uninitialized constant Form

我的猜测是load_and_authorize_resource中的自动加载器与我的MainApp命名空间绑定,并且不识别我在不同的命名空间中调用它,因此调用Form.find(params [:id])而不是MyEngine: :Form.find(PARAMS [:ID]).

如果是这种情况,我该如何解决这个问题?这不是一件大事,因为授权!仍然可以正常工作,所以我可以单独定义每个操作中的授权,但如果我能够使用load_and_authorize_resource方法,它会感觉更清洁.

解决方法

它似乎是CanCan :: ControllerResource#namespace中的一个错误
def namespace
  @params[:controller].split("::")[0..-2]
end

如您所见,它试图通过::分割控制器路径,但它以my_engine / my_controller的形式出现.

所以修复很简单:

def namespace
  @params[:controller].split("/")[0..-2]
end

想知道他们怎么会错过这么长时间的这种愚蠢的虫子.应该向他们发送拉取请求.

附:刚刚注册回答8)

猜你在找的Ruby相关文章