Добавил нового пользователя ( кроме суперюзера ), создал группу, добавил в эту группу права только на просмотр+1модель на изменение. Добавил созданному пользователю эту группу. Как я понимаю, теперь у этого пользователя есть только эти права. Есть представление для авторизации:
def userlogin(request):
form = LoginForm()
if request.method == 'POST':
logout(request)
username = request.POST.get('u')
password = request.POST.get('p')
print(username+' '+password)
now_user = authenticate(username=username, password=password)
if now_user is not None:
if now_user.is_active:
login(request, now_user)
print('пользователь успешно залогинелся')
return redirect('index')
return render(request, 'mainapp/login.html', {'form': form})
После ввода логина и пароля на странице входа идет перенаправление на главную страницу (при попытке ввойти Django admin – джанго просит ввести логин и пароль от админа – так я понимаю, что текущий пользователь теперь не суперюзер).
Теперь для ограничения пользователя добавил декоратор перед функцией представления:
…
from django.contrib.auth.decorators import login_required
…
@login_required
def edit_question(request, element, element_id):
В этой функции совершается изменения модели на изменение которой у пользователя нет прав. Что я делаю не так?