Я использую CanCan 1.6.10 с Rails 3.2.13Как написать CanCan-способность с соединением?
Я настраиваю свои способности для модели моего персонала (а не пользователя). У меня есть:
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)))
SQL, из последнего .to_sql запроса показывает, как:
SELECT `users`.* FROM `users` WHERE (1=0)
тогда User.joins (: заказы => {: delivery_slot => :. водитель}), где ("? 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)
Опубликовано решение, можете ли вы проверить, работает ли это? – Subhas