加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

ruby-on-rails – 如何通过加入编写CanCan功能?

发布时间:2020-12-17 01:29:49 所属栏目:百科 来源:网络整理
导读:我正在使用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("dr
我正在使用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而不是明确的连接吗?

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读