1

在阅读指南并搜索谷歌一段时间后,我无法在 CASL 中找到解决我的用例的方法。

预期的

  • 普通用户只能修补他的约会。
  • 普通用户只能appointment.status从“已创建”修补到“已取消”(而不是其他值,例如“保留”)。

status字段可能具有以下值之一:'created'、'cancelled'、'kept'、'broken'...但某些值(如 'k​​ept、broken')只能由具有特殊角色的用户更新,例如 'supervisor' ,而不是普通用户。)

我的代码

// define rules
async function defineAbilitiesFor(user) {
    if(user) {
        can('patch', 'appointments', { user_id: user.id, status: 'created' });
        // No where to define rule for limit status to be patched
    }
}

// test rules
const appointment = {..., user_id:1, status:'created' };
const toPatch = { status: 'cancelled' };
ability.can('patch', appointment); // No where to check `toPatch` data

$in不适合我的情况

can('patch', 'appointments', { user_id: user.id, status: {$in: ['created','cancelled'] }); 不能解决两个问题:

  • 普通用户仍然可以将约会更新为其他状态,例如“中断”;(因为约会只能由主管用户设置)
  • 普通用户可以将约会从“取消”更新为“已创建”;(因为预约只能取消一次。)
4

0 回答 0