首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >让PermissionRequiredMixin也检查对象级别的权限

让PermissionRequiredMixin也检查对象级别的权限
EN

Stack Overflow用户
提问于 2021-08-18 13:18:42
回答 1查看 533关注 0票数 1

我使用Django Guardian具有对象级权限和全局权限。有些用户拥有具有全局权限的组,而有些则具有对象级权限.这样,我似乎需要修改PermissionRequiredMixin以检查对象级别的权限。

views.py

代码语言:javascript
运行
复制
class MainPageView(PermissionRequiredMixin, TemplateView):
    permission_required = "app.view_mainpage"
    template_name = "web/mainpage.html"

如果用户拥有全局权限,但如果用户在具有对象级权限的组下,则不能使用此权限。使用卫士,要检查对象级权限,还必须传递对象实例。

示例:

代码语言:javascript
运行
复制
self.request.user.has_perm('view_mainpage', obj)

PermissionRequiredMixin上,检查只这样进行,self.request.user.has_perms(perms)

因此,如果用户拥有一个具有特定对象的view_mainpage权限的组,我如何也检查它?顺便说一下,我所有的权限都是相同的content_type。有什么办法可以让我执行吗?就像我必须将对象实例传递给PermissionRequiredMixin (如果用户位于对象级别组下)和None (如果用户位于全局组下)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-08-18 13:38:17

您可以自己实现这样的混合:

代码语言:javascript
运行
复制
from django.core.exceptions import PermissionDenied

class ObjectPermissionRequiredMixin:
    object_permission_required = None
    object_permission_denied_message = None

    def has_object_permission(self, obj):
        return self.request.user.has_perm(self.object_permission_required, obj)

    def get_object_permission_denied_message(self):
        return self.object_permission_denied_message

    def handle_no_object_permission(self):
        raise PermissionDenied(self.get_object_permission_denied_message())

    def get_object(self, *args, **kwargs):
        obj = super().get_object(*args, **kwargs)
        if not self.has_object_permission(obj)
            return self.handle_no_object_permission()
        return obj

然后,您可以将此混合器混合到视图中,例如:

代码语言:javascript
运行
复制
class MyUpdateView(ObjectPermissionRequiredMixin, UpdateView):
    model = MyModel
    object_permission_required = 'app.update_my_model'
    object_permission_denied_message = 'You can not edit this object'

这将适用于所有使用 [Django-doc] [Django-doc],如DetailViewUpdateViewDeleteView

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/68833195

复制
相关文章

相似问题

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