Chciałbym utworzyć backend uwierzytelniania, który pozwala użytkownikom log_in tylko za pomocą ich e-mail (bez nazwy użytkownika, bez hasła).Backend niestandardowego uwierzytelniania. Django
Oto, co próbowałem.
backends.py:
from django.conf import settings
from django.contrib.auth.models import User
class EmailAuthBackend(object):
def authenticate(self, username=None, password=None):
try:
user = User.objects.get(email=username)
if user:
return user
except User.DoesNotExist:
return None
settings.py:
AUTHENTICATION_BACKENDS = (
'path_to.backends.EmailAuthBackend',
'django.contrib.auth.backends.ModelBackend',
)
HTML:
<form method="post" action="{% url myproject.views.test %}">
{% csrf_token %}
<input type="text" name="email" value=""/>
<button type="submit">Valider</button>
</form>
Wygląd:
def test(request):
email = ''
if 'email' in request.POST:
email = request.POST.get('email')
if not User.objects.filter(email=email):
User.objects.create(email=email)
user = authenticate(username=email)
if user is not None:
if user.is_active:
auth_login(request, user)
return HttpResponseRedirect(reverse('home'))
To nie działa, użytkownik nie jest uwierzytelniony. A ja też mam ten błąd, gdy idę do/admin:
AttributeError at /admin/logout/
'EmailAuthBackend' object has no attribute 'get_user'
DZIĘKUJEMY. Akceptuję odpowiedź jak najszybciej. – Marcolac