[django] 수퍼 유저를위한 django @login_required 데코레이터

사용자가 수퍼 유저인지 테스트하는 @login_required와 유사한 데코레이터가 django에 있습니까?

감사



답변

user_passes_test데코레이터 사용 :

from django.contrib.auth.decorators import user_passes_test

@user_passes_test(lambda u: u.is_superuser)
def my_view(request):
    ...


답변

경우 직원 회원은 충분 당신은 할 수 없습니다 당신이 사용할 수있는, 사용자가 수퍼 유저인지 여부를 확인해야 @staff_member_required데코레이터 :

from django.contrib.admin.views.decorators import staff_member_required

@staff_member_required
def my_view(request):
    ...


답변

@staff_member_required와 유사한 기능을 원한다면 자신 만의 데코레이터를 쉽게 작성할 수 있습니다. @staff_member를 예로 들어 다음과 같이 할 수 있습니다.

from django.contrib.auth import REDIRECT_FIELD_NAME
from django.contrib.admin.views.decorators import user_passes_test

def superuser_required(view_func=None, redirect_field_name=REDIRECT_FIELD_NAME,
                   login_url='account_login_url'):
    """
    Decorator for views that checks that the user is logged in and is a
    superuser, redirecting to the login page if necessary.
    """
    actual_decorator = user_passes_test(
        lambda u: u.is_active and u.is_superuser,
        login_url=login_url,
        redirect_field_name=redirect_field_name
    )
    if view_func:
        return actual_decorator(view_func)
    return actual_decorator

이 예제는 수정 된 staff_member_required로 람다에서 한 번의 확인 만 변경했습니다.


답변

클래스 기반 뷰의 경우 재사용 가능한 데코레이터 생성 :

from django.contrib.auth.mixins import UserPassesTestMixin
from django.views.generic import View


def superuser_required():
    def wrapper(wrapped):
        class WrappedClass(UserPassesTestMixin, wrapped):
            def test_func(self):
                return self.request.user.is_superuser

        return WrappedClass
    return wrapper

@superuser_required()
class MyClassBasedView(View):
    def get(self, request):
        # ...


답변

Mixins를 사용하는 것이 좋습니다. 예 :

from django.contrib.auth.mixins import UserPassesTestMixin


class SuperUserCheck(UserPassesTestMixin, View):
    def test_func(self):
        return self.request.user.is_superuser

그럼 당신은 추가 할 수 있습니다 SuperUserCheckView클래스 :

class MyView(SuperUserCheck, View):


답변

사용자 프로필이 있으면 간단히 할 수 있습니다.

@login_required
@user_passes_test(lambda u: True if u.profile.role==2 else False )
def add_listing(request):
    #...


답변

새 코드를 작성하지 않고 클래스 기반 뷰에서 수퍼 유저를 요구하려면 :

from django.utils.decorators import method_decorator
from django.contrib.auth.decorators import user_passes_test

@method_decorator(user_passes_test(lambda u: u.is_superuser), name='dispatch')
class AdminCreateUserView(LoginRequiredMixin, FormView):
    ...
    ...
    ...