如何通过在Ruby on Rails项目中集成CanCan来增强权限控制功能?

2026-04-11 16:482阅读0评论SEO问题
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计279个文字,预计阅读时间需要2分钟。

如何通过在Ruby on Rails项目中集成CanCan来增强权限控制功能?

我正在使用CanCan 1.6.10和Rails 3.2.13。为我的员工(而非用户)模型设置权限。我有以下类:

rubyclass Ability include CanCan::Ability

def initialize(staff) if staff.role? can :read, User.joins(:orders=> { :delive=> true }) end endend

我正在使用CanCan 1.6.10和Rails 3.2.13

我正在为我的员工(而非用户)模型设置我的能力.我有:

class Ability include CanCan::Ability def initialize(staff) if staff.role? :driver can :read, User.joins(:orders => {:delivery_slot => :driver}).where("driver_id = ?", staff.id)

我测试了控制台中的连接,它返回7条记录.当我测试它的能力时,它无法返回任何:

User.accessible_by(Ability.new(Staff.find(7)))

上一个查询.to_sql中的SQL显示为:

SELECT `users`.* FROM `users` WHERE (1=0)

而User.joins(:orders => {:delivery_slot =>:driver}).其中(“driver_id =?”,7)给出:

SELECT `users`.* FROM `users` INNER JOIN `orders` ON `orders`.`user_id` = `users`.`id` INNER JOIN `delivery_slots` ON `delivery_slots`.`id` = `orders`.`delivery_slot_id` INNER JOIN `staff` ON `staff`.`id` = `delivery_slots`.`driver_id` WHERE (driver_id = 7) 你尝试过 hash of conditions而不是明确的连接吗?

如何通过在Ruby on Rails项目中集成CanCan来增强权限控制功能?

can :read, User, :orders=>{:delivery_slot=>{:driver=>{:id => staff.id}}}

本文共计279个文字,预计阅读时间需要2分钟。

如何通过在Ruby on Rails项目中集成CanCan来增强权限控制功能?

我正在使用CanCan 1.6.10和Rails 3.2.13。为我的员工(而非用户)模型设置权限。我有以下类:

rubyclass Ability include CanCan::Ability

def initialize(staff) if staff.role? can :read, User.joins(:orders=> { :delive=> true }) end endend

我正在使用CanCan 1.6.10和Rails 3.2.13

我正在为我的员工(而非用户)模型设置我的能力.我有:

class Ability include CanCan::Ability def initialize(staff) if staff.role? :driver can :read, User.joins(:orders => {:delivery_slot => :driver}).where("driver_id = ?", staff.id)

我测试了控制台中的连接,它返回7条记录.当我测试它的能力时,它无法返回任何:

User.accessible_by(Ability.new(Staff.find(7)))

上一个查询.to_sql中的SQL显示为:

SELECT `users`.* FROM `users` WHERE (1=0)

而User.joins(:orders => {:delivery_slot =>:driver}).其中(“driver_id =?”,7)给出:

SELECT `users`.* FROM `users` INNER JOIN `orders` ON `orders`.`user_id` = `users`.`id` INNER JOIN `delivery_slots` ON `delivery_slots`.`id` = `orders`.`delivery_slot_id` INNER JOIN `staff` ON `staff`.`id` = `delivery_slots`.`driver_id` WHERE (driver_id = 7) 你尝试过 hash of conditions而不是明确的连接吗?

如何通过在Ruby on Rails项目中集成CanCan来增强权限控制功能?

can :read, User, :orders=>{:delivery_slot=>{:driver=>{:id => staff.id}}}