This reusable TOM Toolkit app provides support for two user registration flows in the TOM Toolkit.
The two registration flows are as follows:
-
Open Registration - In this flow, the user fills in a registration form and is immediately able to access the TOM as a member of the Public Group.
-
Approval Registration - In this flow, the user fills in a registration form, and is inactive until an administrator reviews and approves their registration.
- Install the package into your TOM environment:
pip install tom_registration
-
In your project
settings.py
, addtom_registration
to yourINSTALLED_APPS
setting:INSTALLED_APPS = [ ... 'tom_registration', ]
And add the follow setting, with appropriate values for your use case:
TOM_REGISTRATION = { 'REGISTRATION_AUTHENTICATION_BACKEND': 'django.contrib.auth.backends.ModelBackend', 'REGISTRATION_REDIRECT_PATTERN': 'home', 'REGISTRATION_STRATEGY': 'open', # ['open', 'approval_required'] 'SEND_APPROVAL_EMAILS': True, # Optional email behavior if `REGISTRATION_STRATEGY = 'approval_required'`, default is False 'APPROVAL_SUBJECT': f'Your {TOM_NAME} registration has been approved!', # Optional subject line of approval email, (Default Shown) 'APPROVAL_MESSAGE': f'Your {TOM_NAME} registration has been approved. You can log in <a href="mytom.com/login">here</a>.' # Optional html-enabled body for approval email, (Default Shown) }
To prevent logged-in users from accessing the registration page, add
RedirectAuthenticatedUsersFromRegisterMiddleware
to theMIDDLEWARE
settings:MIDDLEWARE = [ ... 'tom_common.middleware.AuthStrategyMiddleware', 'tom_registration.middleware.RedirectAuthenticatedUsersFromRegisterMiddleware', ]
-
If you're using approval registration and you would like a message informing the user that their account is pending approval if they try to log in prior to approval, you'll need to make the following changes:
First, in your
settings.py
, set the first item of yourAUTHENTICATION_BACKENDS
:AUTHENTICATION_BACKENDS = ( 'django.contrib.auth.backends.AllowAllUsersModelBackend', 'guardian.backends.ObjectPermissionBackend' )
Then, change the value of
REGISTRATION_AUTHENTICATION_BACKEND
in theTOM_REGISTRATION
setting that was just created:TOM_REGISTRATION = { 'REGISTRATION_AUTHENTICATION_BACKEND': 'django.contrib.auth.backends.AllowAllUsersModelBackend', ... }
In the approval required registration flow, there is available behavior to send basic emails notifying moderators
of a registration request, and notifying users of registration approval. Administrators are determined by the
Django MANAGERS setting.
Email behavior can be enabled or disabled with SEND_APPROVAL_EMAILS
.
The configuration of an email backend is a topic covered in depth by the Django docs. There are a number of required settings that will need to be added. An example of how the most important settings should look something like the following:
MANAGERS = [('Manager1', 'manager@my_tom.com')] # List of managers who should receive registration emails
EMAIL_SUBJECT_PREFIX = f'[{TOM_NAME}]' # Optional prefix for all approval requests to managers
EMAIL_HOST = 'smtp.gmail.com' # SMTP server for sending emails (this example is for gmail)
EMAIL_PORT = 587 # Port for the SMTP server
EMAIL_HOST_USER = '[email protected]' # Email address for the account sending emails
EMAIL_HOST_PASSWORD = '******************' # Password for the account sending emails (app password for gmail)
EMAIL_BACKEND = "django.core.mail.backends.smtp.EmailBackend"
EMAIL_USE_TLS = True # this is needed for gmail, other services may vary
EMAIL_USE_SSL = False # this is needed for gmail, other services may vary
SERVER_EMAIL = "[email protected]" # Email address used as the "from" address if EMAIL_HOST_USER is not needed
Note if using gmail: the EMAIL_HOST_PASSWORD
above is not the account email password associated with EMAIL_HOST_USER
,
but an app password generated by the account owner. This can be generated from the account settings page by searching for "app passwords".
In order to run the tests, run the following in your virtualenv:
python tom_registration/tests/run_tests.py
For options see
python tom_registration/tests/run_tests.py --help