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)

相关文章

validates:conclusion,:presence=>true,:inclusion=>{...
一、redis集群搭建redis3.0以前,提供了Sentinel工具来监控各...
分享一下我老师大神的人工智能教程。零基础!通俗易懂!风趣...
上一篇博文 ruby传参之引用类型 里边定义了一个方法名 mo...
一编程与编程语言 什么是编程语言? 能够被计算机所识别的表...
Ruby类和对象Ruby是一种完美的面向对象编程语言。面向对象编...