首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Rails验证pundit策略中的参数

Rails验证pundit策略中的参数
EN

Stack Overflow用户
提问于 2020-06-30 23:39:46
回答 1查看 161关注 0票数 0

我正在创建一个trello风格的应用程序,用户可以在列表之间拖动卡。我正在处理js端的所有重新排序逻辑,并将list_idposition发布到我的控制器中的rails更新操作:

代码语言:javascript
复制
card = authorize Card.find(params[:id])
card.update(card_params)

由pundit提供授权方法如下所示:

代码语言:javascript
复制
def update?
  user.can_edit?(card.board)
end

这仅检查用户是否有权编辑电路板。因为我允许list_id属性,所以用户可以很好地发布帖子,将一张卡移动到他无权访问的列表中。为了解决这个问题,我在我的控制器中添加了这个条件:

代码语言:javascript
复制
if current_user.can_edit? List.find(params[:list_id]).board
  // update card
else 
  // handle error
end

这个解决方案可以完成这项工作,但是我不想在我的控制器中引入任何授权。我的专家策略不能访问card_params,模型也不能访问devise current_user,所以这似乎是唯一的方法。有没有办法让我把这个逻辑放到政策中?

EN

回答 1

Stack Overflow用户

发布于 2020-07-01 00:10:22

我找到了解决方案,我只需要通过列表策略授权新的列表:

代码语言:javascript
复制
authorize List.find(params[:list_id])
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/62661171

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档