1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161
|
.. _views:
.. module:: django_registration.views
Base view classes
=================
In order to allow the utmost flexibility in customizing and supporting
different workflows, django-registration makes use of Django's
support for `class-based views
<https://docs.djangoproject.com/en/stable/topics/class-based-views/>`_. Included
in django-registration are two base classes which can be
subclassed to implement many types of registration workflows.
The built-in workflows in django-registration provide their own
subclasses of these views, and the documentation for those workflows
will indicate customization points specific to those subclasses. The
following reference covers useful attributes and methods of the base
classes, for use in writing your own custom registration workflows.
.. class:: RegistrationView
A subclass of Django's :class:`~django.views.generic.edit.FormView`
which provides the infrastructure for supporting user registration.
Standard attributes and methods of
:class:`~django.views.generic.edit.FormView` can be overridden to
control behavior as described in Django's documentation, with the
exception of :meth:`get_success_url`, which must use the signature
documented below.
When writing your own subclass, one method is required:
.. method:: register(form)
Implement your registration logic here. `form` will be the
(already-validated) form filled out by the user during the
registration process (i.e., a valid instance of
:class:`~django_registration.forms.RegistrationForm` or a subclass of
it).
This method should return the newly-registered user instance,
and should send the signal
:data:`django_registration.signals.user_registered`. Note that this is
not automatically done for you when writing your own custom
subclass, so you must send this signal manually.
:param django_registration.forms.RegistrationForm form: The registration form to use.
:rtype: django.contrib.auth.models.AbstractUser
Useful optional places to override or customize on subclasses are:
.. attribute:: disallowed_url
The URL to redirect to when registration is disallowed. Can be a
hard-coded string, the string resulting from calling Django's
:func:`~django.urls.reverse` helper, or the lazy object produced
by Django's :func:`~django.urls.reverse_lazy` helper. Default
value is the result of calling :func:`~django.urls.reverse_lazy`
with the URL name `'registration_disallowed'`.
.. attribute:: form_class
The form class to use for user registration. Can be overridden
on a per-request basis (see below). Should be the actual class
object; by default, this class is
:class:`django_registration.forms.RegistrationForm`.
.. attribute:: success_url
The URL to redirect to after successful registration. Can be a
hard-coded string, the string resulting from calling Django's
:func:`~django.urls.reverse` helper, or the lazy object produced
by Django's :func:`~django.urls.reverse_lazy` helper. Can be
overridden on a per-request basis (see below). Default value is
`None`; subclasses must override and provide this.
.. attribute:: template_name
The template to use for user registration. Should be a
string. Default value is
`'django_registration/registration_form.html'`.
.. method:: get_form_class()
Select a form class to use on a per-request basis. If not
overridden, will use :attr:`~form_class`. Should be the actual
class object.
:rtype: django_registration.forms.RegistrationForm
.. method:: get_success_url(user)
Return a URL to redirect to after successful registration, on a
per-request or per-user basis. If not overridden, will use
:attr:`~success_url`. Should return a value of the same type as
:attr:`success_url` (see above).
:param django.contrib.auth.models.AbstractUser user: The new user account.
:rtype: str
.. method:: registration_allowed()
Should indicate whether user registration is allowed, either in
general or for this specific request. Default value is the value
of the setting :data:`~django.conf.settings.REGISTRATION_OPEN`.
:rtype: bool
.. class:: ActivationView
A subclass of Django's
:class:`~django.views.generic.base.TemplateView` which provides
support for a separate account-activation step, in workflows which
require that.
One method is required:
.. method:: activate(*args, **kwargs)
Implement your activation logic here. You are free to configure
your URL patterns to pass any set of positional or keyword
arguments to :class:`ActivationView`, and they will in turn be
passed to this method.
This method should return the newly-activated user instance (if
activation was successful), or raise
:class:`~django_registration.exceptions.ActivationError` (if
activation was not successful).
:rtype: django.contrib.auth.models.AbstractUser
:raises django_registration.exceptions.ActivationError: if activation fails.
Useful places to override or customize on an
:class:`ActivationView` subclass are:
.. attribute:: success_url
The URL to redirect to after successful activation. Can be a
hard-coded string, the string resulting from calling Django's
:func:`~django.urls.reverse` helper, or the lazy object produced
by Django's :func:`~django.urls.reverse_lazy` helper. Can be
overridden on a per-request basis (see below). Default value is
`None`; subclasses must override and provide this.
.. attribute:: template_name
The template to use after failed user activation. Should be a
string. Default value is
`'django_registration/activation_failed.html'`.
.. method:: get_success_url(user)
Return a URL to redirect to after successful activation, on a
per-request or per-user basis. If not overridden, will use
:attr:`~success_url`. Should return a value of the same type as
:attr:`success_url` (see above).
:param django.contrib.auth.models.AbstractUser user: The activated user account.
:rtype: str
|