- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将 cancan 合并到我的第一个 Ruby on Rails 应用程序中。
我在入门时遇到问题...这肯定是一些基本问题。
我的应用程序有一个项目列表,用户可能有权也可能没有权限查看其中任意数量的项目。
我将其添加到我的 ProjectsController 中:
class ProjectsController < ApplicationController
load_and_authorize_resource
我的初始化方法如下所示:
def initialize(user)
user ||= User.new # guest user
puts "******** Evaluating cancan permissions for: " + user.inspect
can :read, Project do |project|
puts "******** Evaluating project permissions for: " + project.inspect
# project.try(project_users).any?{|project_user| project_user.user == user}
1 == 1 #POC test!
end
end
当我看到这个时,会出现项目索引页面,但没有列出任何项目。
我有两个问题:
如果我将初始化方法更改为:
def initialize(user)
user ||= User.new # guest user
puts "******** Evaluating cancan permissions for: " + user.inspect
can :read, Project
end
...我看到的所有项目都符合我的预期
如果我删除 can :read, Project 行,我会在尝试访问项目索引页时遇到安全异常......这也是我所期望的。
最佳答案
仅当项目实例可用时才会评估传递给 :read 功能的 block (@project
)。因为您正在讨论索引操作,所以只有集合可用(@projects
)。这解释了为什么你的第二个 put 语句永远不会出现。为了限制索引操作,您需要将条件哈希传递到 can
方法中,或者使用作用域(除了 block 之外)。 Github 上的 CanCan wiki 中清楚地概述了所有这些信息。
因此,看跌期权
问题是可以解释的。没有意义的是没有项目显示。在评估索引操作时,CanCan 实际上会默认完全忽略该 block 。这意味着您的能力本质上是can :read, Project
(即使在第一个示例中)对于索引操作。
我有兴趣让您尝试添加一个简单的范围,只是为了看看它是否有效。尝试:
can :read, Project, Project.scoped do |project|
true
end
然后看看索引操作会发生什么。
编辑:
鉴于您现在可以在索引中查看项目,似乎您需要将范围以及 block 传递到功能中。请阅读this Github issue其中 Ryan 解释了为什么不根据索引操作评估该 block 。
Blocks are only intended to be used for defining abilities based on an object's attributes. [...] That is the only case when a block should be used because the block is only executed when an object is available. All other conditions should be defined outside the block.
请记住,如果您的能力对于条件散列而言不太复杂,则应该使用它。条件散列在 this CanCan wiki page on Github. 上进行了解释。如果您确实需要范围,则需要传入范围和 block 。假设您具有上面显示的能力。
@project
) 不可用。相反,它将返回给定范围内的项目,在本例中为 Project.scoped
(即所有项目)。 @project
可用,因此 CanCan 将评估该 block ,并在该 block 评估为 true 时允许该操作。因此,您需要传递两者的原因是 CanCan 可以同时处理索引和显示操作。在大多数情况下,您的 block 将定义与范围相同的内容,只有 block 将用 Ruby 编写,而您的范围将使用 Rails 的 ActiveRecord 语法编写。您可以在这里了解更多信息:Defining Abilities with Blocks .
关于ruby-on-rails - cancan 不评估实例级别的能力检查,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15704730/
目前,由于生成变量的评估,我的Makefile遇到了问题。我降低了复杂性,仅保留了导致问题的基本要素。 读取Makefile时, $(LIST)被评估为文件列表。 在步骤1中,其中一个文件被删除。 在
为什么这 eval 没有调用alert("Summer") ? eval('(caption="Summer";alert(caption))'); 和《夏天》里的台词有关系吗? 最佳答案 Uncau
我正在努力让以下工作正常进行。最初似乎可以工作,但不知何故它停止工作了 var setCommonAttr = "1_row1_common"; var val = document.getEleme
eval('({"suc":true})') 以上错误,应该是: eval('{"suc":true}') 为什么? 最佳答案 当尝试评估时,解释器会看到大括号并认为它是一个 block 开头。将其括
我的页面 A 发出了 ajax 调用并引入了片段 B。该片段被添加到 DOM 中,并且该片段中的所有脚本都经过了评估。在该代码片段中,我有 2 个脚本标签: function doOptions()
这里是javascript代码: var test = { "h" : function (a) {return a;}, "say" : "hello" }; 第一次运行: test
我正在查看一些工作代码,并遇到了这一行: eval("\$element = \"$element\";"); 我真的很困惑为什么任何 PHP 开发人员都会写这一行。除了给自己设置一个变量之外,这还有
谁能帮我解决以下问题: 我有这样的代码: if(cond1 && cond2 && .. && cond10) 这里,cond1 是昂贵的操作,其输出是 boolean 值。 现在我的问题是,当 co
**摘要:**华为AppCube应用魔方顺利通过信通院评估,被认证为具备 “低代码开发平台通用能力”的企业服务平台。 本文分享自华为云社区《华为AppCube通过中国信通院“低代码开发平台通用能力要求
我正在尝试通过 PHP 从图像的 EXIF 数据中获取焦距。 这是我目前得到的代码: $exif = exif_read_data("$photo"); $length10 = $exif['Foca
我想使用id =“key”将一个类添加到元素中,但是为什么不起作用?我是js的初学者:这是代码: audio.classList.add('yellow'); 这是错误: null is not an
这是我的 XML: QueWay Password Recovery 现在我想用 php 用 xpath 选择文本“QueWay”。到目前为止我所拥有的一切都很好: $xml =
使用下面的代码,即使我输入的数字大于 18,我也会得到这个结果。 运行:你今年多大? 21你还没有达到成年年龄!构建成功(总时间:3 秒) 我是java新手,正在尝试自学,有人可以帮忙吗? impor
我正在阅读 http://www.cran.r-project.org/doc/manuals/R-lang.pdf手册第 4.3 章,我就是不明白。也许有人可以给我一个快速的解释,为什么 R 的行为
在这个实现中,每次都会评估 hand 并返回另一个列表吗? foreach (Card card in hand.Cards) { } 我们应该用下面的实现替换上面的实现吗? var cards =
我正在制作 LINQ lambda 表达式: Expression> add = (x, y) => x + y; 但现在我将如何评估它,比如说找到 2+3? 最佳答案 这应该适合你: var su
我正在制作一个语言解释器,我已经到了需要评估 if 语句的地步。起初我认为这很简单,我能够让我的解释器评估简单的 if 条件,10 == 10 但是当我试图让它评估更复杂的条件时, 10 == 10
我正在尝试以下代码,该代码向 RDD 中的每一行添加一个数字,并使用 PySpark 返回 RDD 列表。 from pyspark.context import SparkContext file
在阅读了很多关于 Lisp eval-when 运算符的文档后,我仍然无法理解它的用途,我知道使用这个运算符我可以控制表达式的计算时间,但我做不到找出任何可能适用的示例? 最好的问候,utxee. 最
关闭。这个问题不符合Stack Overflow guidelines .它目前不接受答案。 要求我们推荐或查找工具、库或最喜欢的场外资源的问题对于 Stack Overflow 来说是偏离主题的,
我是一名优秀的程序员,十分优秀!