Моя цель - ограничить доступ к «Группе персонала», которую я пытаюсь сделать с помощью decorators.py, но когда я это делаю, это ограничивает каждого зарегистрированного пользователя, а не только персонал. Когда я вхожу с администратором, он дает мне «вы не авторизованы», который должен быть только для «персонала», который должен видеть только один шаблон платформы.
Здесь изображение также моей страницы администратора.
core / decorators.py
from django.http import HttpResponse
from django.shortcuts import redirect
def allowed_user(allowed_roles=[]):
def decorator(view_func):
def wrapper_func(request, *args, **kwargs):
group = None
if request.user.groups.exists():
group = request.user.groups.all()
if group in allowed_roles:
return view_func(request, *args, **kwargs)
else:
return HttpResponse(' You are not Authorized!')
return wrapper_func
return decorator
core / views.py
from django.shortcuts import render, get_object_or_404
from django.contrib.auth.models import User
from django.contrib.auth.mixins import LoginRequiredMixin
from django.views.generic.list import ListView
from .decorators import allowed_user
# Create your views here.
from quiz.models import Questions
from jobs.models import post_job
@allowed_user(allowed_roles=['Admin, Students'])
def homepage(request):
return render(request, 'core/homepage.html')
@allowed_user(allowed_roles=['Admin, Students'])
def userProfileView(request, username):
user= get_object_or_404(User, username=username)
jobs = post_job.objects.all()
categories = Questions.CAT_CHOICES
scores = []
for category in categories:
score = Questions.objects.filter(category=category[0], student= user).count()
scores.append(score)
context = {
'user' : user, 'categories_scores' : zip( categories,scores),
'jobs': jobs
}
return render(request, 'core/user_profile.html' , context)
class UserList(LoginRequiredMixin, ListView):
model = User
template_name = 'core/users.html'
account / views.py
from django.shortcuts import render, HttpResponseRedirect
from django.contrib.auth import authenticate, login
from django.contrib.auth.models import User
from accounts.forms import FormRegistrazione
from .decorators import allowed_user
# Create your views here.
def registrazioneView(request):
if request.method == "POST":
form = FormRegistrazione(request.POST)
if form.is_valid():
username = form.cleaned_data["username"]
email = form.cleaned_data["email"]
password = form.cleaned_data["password1"]
User.objects.create_user(username=username, password=password, email=email)
user = authenticate(username=username, password=password)
login(request, user)
return HttpResponseRedirect("/")
else:
form = FormRegistrazione()
context = {"form": form}
return render(request, 'accounts/registrazione.html', context)