This is custom backend for django-registration.
Features of backend:
- requires invitation code to proceed,
- requires TOS (Terms of Service) accepted by user.
Invitation codes are useful for e.g. service beta testing. Also, since backend is fully compatibile with default backend, when your service is going public and you decide not to use invitation codes, all you need to do is turn "default" backend on.
Copy invitation directory contents to your django-registration backends - such as registration/backends/invitation/
In settings.py INSTALLED_APPS section add 'registration.backends.invitation' after 'registration':
INSTALLED_APPS = ( 'registration', 'registration.backends.invitation', )
You must change your urls.py where you are invoking registration (check project main urls.py):
(r'^accounts/', include('registration.backends.invitation.urls'), ),
Run syncdb or south schemamigration if you use it:
./manage.py syncdb
Application created InvitationCode model for codes. Invitation codes can be anything you want - here there are 5 random characters.
InvitationCode model also stores information about who and when used specific code so you can track it.
You can make invitation code as long as you want (change max_length in InvitationCode model if you want it to be longer than 5).
Sample code for generation:
import string import random def generate_random_string(): chars = string.letters + string.digits return "".join(random.sample(chars, 5))
Application provides translation for languages:
- Polish (pl)
To create new translation simply run:
django-admin.py makemessages -l <language_code>