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

python – Django规则对象权限

发布时间:2020-12-16 22:28:22 所属栏目:Python 来源:网络整理
导读:我正在尝试使用django rules在django和django管理界面中配置对象权限. 现在,当我添加权限规则时,它们将始终仅使用第一个参数调用,但对象始终为None. 例如,我是否会创建此谓词: @rules.predicatedef is_book_author(user,book): return book.author == user

我正在尝试使用django rules在django和django管理界面中配置对象权限.

现在,当我添加权限规则时,它们将始终仅使用第一个参数调用,但对象始终为None.

例如,我是否会创建此谓词:

@rules.predicate
def is_book_author(user,book):
    return book.author == user

然后将其添加到django权限集:

rules.add_perm('books.view_book',is_book_author)

现在,当我与用户登录管理界面时,将使用用户和None调用is_book_author.它将被多次调用(每个对象一次),但对象始终为None.

我正在使用规则2.0.0与django 2.1.1和python 3.7.

如果我做错了什么或如何配置django以使用单个对象调用谓词,任何想法?

最佳答案
正如django-rules documentation所述:

Django Admin does not support object-permissions,in the sense that it will never ask for permission to perform an action on an object,only whether a user is allowed to act on (any) instances of a model.

如果您想告诉Django用户是否拥有特定对象的权限,您必须覆盖模型的ModelAdmin的以下方法:

has_view_permission(user,obj=None)
has_change_permission(user,obj=None)
has_delete_permission(user,obj=None)

规则附带一个自定义的ModelAdmin子类rules.contrib.admin.ObjectPermissionsModelAdmin,它覆盖这些方法以将已编辑的模型实例传递给授权后端,从而在Admin中启用每个对象的权限:

# books/admin.py
from django.contrib import admin
from rules.contrib.admin import ObjectPermissionsModelAdmin
from .models import Book

class BookAdmin(ObjectPermissionsModelAdmin):
    pass

admin.site.register(Book,BookAdmin)

现在,这允许您指定如下权限:

rules.add_perm('books',rules.always_allow)
rules.add_perm('books.add_book',has_author_profile)
rules.add_perm('books.change_book',is_book_author_or_editor)
rules.add_perm('books.delete_book',is_book_author)

为了保持向后兼容性,Django将要求查看或更改权限.为了获得最大的灵活性,规则的行为略有不同:当且仅当视图权限不存在规则时,规则才会要求更改权限.

(编辑:李大同)

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

    推荐文章
      热点阅读