Могу ли я использовать django-nonrel и пользовательский бэкэнд аутентификации? - PullRequest
0 голосов
/ 28 февраля 2012

Я пытаюсь использовать пользовательский бэкэнд для авторизации пользователя с помощью django-nonrel (адреса электронной почты вместо имен пользователей, ничего особенного), и он просто не работает.Все звонки на authenticate() не возвращаются.Вот мой бэкэнд:

from django.contrib.auth.models import User, check_password

    class EmailAuthBackend(object):
        """
        Email Authentication Backend

        Allows a user to sign in using an email/password pair rather than
        a username/password pair.
        """
        supports_anonymous_user = False
        supports_object_permissions = True


        def authenticate(self, email=None, password=None):
            """ Authenticate a user based on email address as the user name. """
            try:
                user = User.objects.get(email=email)
                if user.check_password(password):
                    return user
            except User.DoesNotExist:
                return None

        def get_user(self, user_id):
            """ Get a User object from the user_id. """
            try:
                return User.objects.get(pk=user_id)
            except User.DoesNotExist:
                return None

И представление (я пытаюсь войти в систему сразу после регистрации).new_user всегда None:

def create_new_user(request):
    if request.method == 'POST':
        data = request.POST.copy()
        data['username'] = ''.join([choice(letters) for i in xrange(30)])
        data['password'] = data['password1']
        form = CustomUserCreationForm(data)
        if form.is_valid(): 
            user = form.save(commit=False)
            # user must be active for login to work
            user.is_active = True
            user.save() #not sure if this is actually saving
            new_user = authenticate(username=data['username'],\
                    password=data['password'])
            if new_user is None:
                messages.error(request,"God damn it.")
            login(request, new_user)

            messages.info(request, "Thanks for registering! You are\
                                                            now logged in.")
            return render_to_response('invoicer/welcome.html',
                                                     {'user':new_user})

        else:
            messages.error(request, form._errors)
            return HttpResponseRedirect('//')

Может кто-нибудь подсказать мне, почему мой звонок на authenticate() не работает?


Редактировать: Кроме того, когдаразвернутая форма регистрации определенно создает пользователей, которых можно увидеть в средстве просмотра данных на appengine.google.com

1 Ответ

1 голос
/ 29 февраля 2012

Оказывается, все, что мне нужно было сделать, это изменить

Аутентификация (имя пользователя = адрес электронной почты

в представлении:

Аутентифицировать (электронная почта = адрес электронной почты

Моему бэкэнду не было отправлено электронное письмо, поэтому по умолчанию оно отсутствовало. Мне стыдно. Однако, поскольку я использую стандартную форму входа в систему django, она передаст имена username и password моему бэкэнду, поэтому я должен иметь возможность обрабатывать как имя пользователя (которое фактически является адресом электронной почты пользователя), так и электронная почта в качестве именованных ключевых слов.

Пока что я просто делаю это в своем бэкэнде:

def authenticate(self, username=None, email=None, password=None):
        """ Authenticate a user based on email address as the user name. """
        if username:
            might_be_email = username
        elif email:
            might_be_email = email

Попытка найти пользователя по might_be_email.

...