Question

Is there any solutions to use captcha with django-allauth? I want to use captcha on registration form for standard email+password registrations.

Was it helpful?

Solution

I too needed to do this with django-allauth and found that implementing the django-recaptcha package to be relatively simple.

Configure django-recaptcha

Sign up for a recaptcha account.

Plug your settings in

# settings.py

RECAPTCHA_PUBLIC_KEY = 'xyz'
RECAPTCHA_PRIVATE_KEY = 'xyz'

RECAPTCHA_USE_SSL = True     # Defaults to False

Customize SignupForm

After installing django-recaptcha, I followed someguidelines for customizing the SignupForm.

from django import forms
from captcha.fields import ReCaptchaField

class AllAuthSignupForm(forms.Form):

    captcha = ReCaptchaField()

    def save(self, request, user):
        user = super(AllAuthSignupForm, self).save(request)
        return user

You also need to tell allauth to inherit from this form in settings.py

ACCOUNT_SIGNUP_FORM_CLASS = 'myapp.forms.AllAuthSignupForm'

Wire up signup form template

{{ form.captcha }} and {{ form.captcha.errors }} should be available on the signup template context at this point.

That was it! Seems like all the validation logic is tucked into the ReCaptchaField.

OTHER TIPS

To get the ReCaptcha field to the bottom of the form, simply add the other fields before the captcha field. So what was user, email, captcha, password1, password2 becomes user, email, password1, password2, captcha with this form:

from allauth.account.forms import SignupForm, PasswordField
from django.utils.translation import ugettext_lazy as _
from captcha.fields import ReCaptchaField

class UpdatedSignUpForm(SignupForm):
    password1 = PasswordField(label=_("Password"))
    password2 = PasswordField(label=_("Password (again)"))
    captcha = ReCaptchaField()

    def save(self, request):
        user = super(UpdatedSignUpForm, self).save(request)
        return user

You then just need to add this form into the settings.py file as described in the previous answer.

You can also take a look at Form.field_order.

So a simple sign up form using django-allauth, with captcha and the fields ordered as you wish, would look like this:

from allauth.account.forms import SignupForm
from captcha.fields import ReCaptchaField


class MyCustomSignupForm(SignupForm):
    captcha = ReCaptchaField()

    field_order = ['email', 'password1', 'captcha']

In this case, the captcha will be at the very end.

The accepted answer is mostly fine, but produced this error for me when submitting the sign up form:

save() missing 1 required positional argument: 'user'

To fix this, your custom form could look like this

class AllAuthSignupForm(forms.Form):

    captcha = ReCaptchaField()

    def signup(self, request, user):
        pass

NOTE: django-allauth also warns if the custom signup form does not have signup method.

Licensed under: CC-BY-SA with attribution
Not affiliated with StackOverflow
scroll top