6

我正在做一个 RoR 项目,我对这个推荐用于我的目的的新 gem 有点困惑,Rolify。据我了解, rolify 与 CanCan 的功能几乎相同,只是它将能力(rolify 的角色)保存到数据库中。但是,在整个 Rolify wiki 上,我看到了有关将 Rolify 与 CanCan 一起使用的说明。

所以基本上,我想知道 Rolify 和 CanCan 有什么区别?我什么时候应该使用一个而不是另一个?

4

2 回答 2

7

CanCan 用于从应用程序的角度管理授权,它允许您将 X 控制器/操作限制为 X 用户。

当您想深入到更细粒度的控制时,您可以使用 Rolify。Rolify,超越简单

if user.role == :super_admin
  # do something pretty cool stuff
elsif user.role == :admin
  # do some more awesome stuff

通过允许您向资源添加角色。假设您有一个论坛应用程序,您希望用户能够在游戏板上担任主持人角色。你会使用 rolify 来

user = User.find(2)
user.add_role :moderator, Forum.where(type: 'Gaming')

Rolify 还允许您通过使用类本身而不是实例来对类执行此操作(如果您希望用户成为所有板的版主)

user = User.find(2)
user.add_role :moderator, Forum

之后,它可以让您轻松查询资源/类以找出谁可以访问什么。除了帮助您管理角色范围之外。

于 2014-01-27T21:22:24.187 回答
5

CanCan 是一个授权库,允许您设置关于谁可以或不能执行某些操作的规则。

Rolify 是一个角色库,可帮助您创建角色,然后您可以在 Cancan 授权规则中使用这些角色。

于 2014-01-27T21:20:25.773 回答