在 Casbin 中,可以使用模式将 p.obj 与角色进行匹配吗?

huangapple go评论115阅读模式
英文:

Is it possible to match p.obj with role by pattern in casbin?

问题

这是我正在使用的model.conf文件:

  1. [request_definition]
  2. r = sub, obj, act
  3. [policy_definition]
  4. p = sub, obj, act, eft
  5. [role_definition]
  6. g = _, _
  7. g2 = _, _
  8. [policy_effect]
  9. e = some(where (p.eft == allow)) && !some(where (p.eft == deny))
  10. [matchers]
  11. m = g(r.sub, p.sub) && g2(r.obj, p.obj) && regexMatch(r.act, p.act)

这是相关的策略(用户可以阅读自己的帖子,管理员可以阅读所有帖子):

  1. p, admin, /posts/:id/attachments, GET, allow
  2. p, alice, /posts/1/attachments, GET, allow
  3. g, bob, admin
  4. g2, /files/1.jpg, /posts/1/attachments

这些请求的结果应该是true

  1. alice, /files/1.jpg, GET
  2. bob, /files/1.jpg, GET

目前,我可以通过添加规则g, /posts/1/attachments, /posts/:id/attachments使策略生效,但我想知道是否可以通过模式匹配来匹配这些角色名称,这样我就不必为每个帖子创建规则了。

(我找到的最接近的示例是AddNamedMatchingFunc("g","KeyMatch2",util.KeyMatch2)方法,我尝试在g2上使用它,但似乎它只匹配r.obj和角色上的模式。)

英文:

This is the model.conf I'm using:

  1. [request_definition]
  2. r = sub, obj, act
  3. [policy_definition]
  4. p = sub, obj, act, eft
  5. [role_definition]
  6. g = _, _
  7. g2 = _, _
  8. [policy_effect]
  9. e = some(where (p.eft == allow)) && !some(where (p.eft == deny))
  10. [matchers]
  11. m = g(r.sub, p.sub) && g2(r.obj, p.obj) && regexMatch(r.act, p.act)

This is the relevant policy (The users can read their own posts, and admins can read all posts.):

  1. p, admin, /posts/:id/attachments, GET, allow
  2. p, alice, /posts/1/attachments, GET, allow
  3. g, bob, admin
  4. g2, /files/1.jpg, /posts/1/attachments

The result of these requests are expected to be true:

  1. alice, /files/1.jpg, GET
  2. bob, /files/1.jpg, GET

Currently, I can make the policy work by adding the rule g, /posts/1/attachments, /posts/:id/attachments, but I want to know whether it's possible to match these role names by pattern, so that I wouldn't have to create a rule for every post.

(The closest example I found is the AddNamedMatchingFunc("g","KeyMatch2",util.KeyMatch2) method, and I tried to use it on g2, but it seems that it only matches the pattern on r.obj and the roles.)

答案1

得分: 1

g的第二个参数不支持使用模式。但是这里有一个解决方法,可以使用多个g来达到相同的效果:

  1. g,模式1,角色1
  2. g,角色1,模式2

与以下代码等效:

  1. g,模式1,模式2
英文:

The 2nd arg of g is not supported to be pattern. But here's a workaround to use multiple g to have the same effect:

  1. g, pattern1, role1
  2. g, role1, pattern2

is the same as:

  1. g, pattern1, pattern2

huangapple
  • 本文由 发表于 2021年12月27日 19:26:23
  • 转载请务必保留本文链接:https://go.coder-hub.com/70494861.html
匿名

发表评论

匿名网友

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定