django user_passes_test декоратор - PullRequest
29 голосов
/ 10 ноября 2011

Как мне реализовать декоратор @user_passes_test(lambda u: u.is_superuser) для представлений на основе классов?Я использовал это раньше для представлений, основанных на функциях, и у меня есть обходной путь, но он кажется неестественным.

Разве это не должно быть покрыто методом отправки?

Ответы [ 4 ]

36 голосов
/ 10 ноября 2011

Вы используете @method_decorator для dispatch метода класса:

from django.views.generic import View
from django.utils.decorators import method_decorator
from django.contrib.auth.decorators import user_passes_test

class MyView(View):
    @method_decorator(user_passes_test(lambda u: u.is_superuser))
    def dispatch(self, *args, **kwargs):
        return super(MyView, self).dispatch(*args, **kwargs)
22 голосов
/ 09 июля 2013

Опираясь на ответ @Chris Pratt, вы, вероятно, захотите сделать это в нескольких классах представлений, поэтому имеет смысл превратить его в миксин.

class SuperuserRequiredMixin(object):
    @method_decorator(user_passes_test(lambda u: u.is_superuser))
    def dispatch(self, *args, **kwargs):
        return super(SuperuserRequiredMixin, self).dispatch(*args, **kwargs)

Использование

class MyView(SuperuserRequiredMixin, View):
    def get(self, request):
        ...

Чтобы предотвратить непредвиденные ошибки MRO , убедитесь, что mixin является первым унаследованным классом.

Таким же образом вы можете реализовать LoginRequiredMixin или любые другие общие тесты, которые вы используете в своем приложении.

Редактировать: Django 1.9 добавляет AccessMixin, LoginRequiredMixin, PermissionRequiredMixin и UserPassesTestMixin

1 голос
/ 23 августа 2015

Вы должны взглянуть на django-фигурные скобки и его UserPassesTestMixin .

1 голос
/ 11 ноября 2011

Я использовал @view_decorator из этого фрагмента: http://djangosnippets.org/snippets/2505/, чтобы обернуть мои обычные функциональные декораторы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...