A Django app to transparently identify users with the ThumbmarkJS library.
Project description
django-thumbmark
Django app to transparently identify users with the ThumbmarkJS library.
This app includes a decorator that mimics the built-in login_required
decorator provided by Django. Views using this decorator will have unidentified users transparently redirected through a page where the ThumbmarkJS library is used to generate a unique identifier for the client. This unique identifier is then mapped to a Django user and associated with the HttpRequest
object.
Common use cases include public forms that should be limited to one submission per user, without requring a username/password login.
- Survey Submissions
- Feedback Forms
- Anonymous Polls
Usage
Add the included decorator to your function- or class-based view:
from django.views.generic import TemplateView
from django.utils.decorators import method_decorator
from django_thumbmark.decorators import login_required_thumbmark
@login_required_thumbmark
def my_function_based_view(request):
# ...
print(request.user) # <-- The User attribute will be populated
### --- or --- ###
@method_decorator(login_required_thumbmark, name='dispatch')
class MyClassBasedView(TemplateView):
# ...
def get(self, request):
print(request.user) # <-- The User attribute will be populated
Standard Installation
Add django_thumbmark
to your INSTALLED_APPS
:
INSTALLED_APPS = [
# ...
'django_thumbmark',
]
To use the app as written (without customization) add these two views in your app's urls.py
file.
[!IMPORTANT] The names of these two URLs must be
tm
andtmlogin
as shown.
# myapp/urls.py
from django_thumbmark.views import DjTmLoginView, DjTmScriptView
urlpatterns = [
# ...
path("tm/", DjTmScriptView.as_view(), name="tm"),
path("login/", DjTmLoginView.as_view(), name="tmlogin"),
]
Installation with Customizations
To use the app with customization, overwrite the included DjTmScriptView as needed. Then add this modified DjTmScriptView and the included DjTmLoginView to your app-specific urls.py
file.
[!IMPORTANT] The names of these two URLs in your app-specific
urls.py
file must betm
andtmlogin
as shown.
# myapp/views.py
from django_thumbmark.views import DjTmScriptView
from django.utils import timezone # ... as an example of customized usage
# ...
class MyDjTmScriptView(DjTmScriptView):
def get_first_name(self, request, *args, **kwargs):
return "CustomFirstName"
def get_username(self, request, *args, **kwargs):
tmid = kwargs["tmid"]
path = request.path
time = timezone.now().strftime("%Y-%m-%dT%H:%M:%S")
return f"{tmid}-{path}-{time}"
# myapp/urls.py
from myapp import views
from django_thumbmark.views import DjTmLoginView
urlpatterns = [
# ...
path("tm/", views.MyDjTmScriptView.as_view(), name="tm"), # The URL name is "tm"
path("login/", DjTmLoginView.as_view(), name="tmlogin"), # The URL name is "tmlogin"
]
To modify the included HTML template, overwrite the django_thumbmark/login.html
template within your app's templates directory.
├── manage.py
├── project_root
│ ├── __init__.py
│ ├── asgi.py
│ ├── settings.py
│ ├── urls.py
│ └── wsgi.py
├── requirements.txt
└── myapp
├── __init__.py
├── admin.py
├── apps.py
├── forms.py
├── migrations
│ ├── 0001_initial.py
├── models.py
├── templates
│ ├── django_thumbmark ## Create this directory
│ │ └── login.html ## Add this file
│ └── myapp
│ ├── index.html
│ └── success.html
├── tests.py
├── urls.py
└── views.py
The options with which this overwritten template file can be modified are shown in the Customization section below.
Details
When a view uses this decorator
- If the user is already authenticated, nothing happens.
- If the user hasn't been authenticated they are redirected to a new login page named
tmlogin
. This login page contains the ThumbmarkJS script to generate a unique ID. - The unique ID is sent by Javascript via a GET request to a second view named
tm
. - The second view uses the unique ID to search for an existing User object. A new User object is created if no object is found.
- The user is logged in and associated with the request.
- The user is redirected back to their original page.
Customization
New User First/Last Names
By default, if a new User object is created, the first and last names are set to "Test" and "User," respectively. These can be modified by overwriting the DjTmScriptView.get_first_name()
and DjTmScriptView.get_last_name()
functions.
New User Username
By default, if a new User object is created, the username is set to the unique ID generated by ThumbmarkJS. This can be modified by overwriting the DjTmScriptView.get_username()
function.
New User Object
By default, Django's get_or_create()
function is used to find/create a User object directly, which is then logged in and associated with the request. To modify how that user is discovered and/or created, you can overwrite the DjTmScriptView.get_user_object_()
function.
JavaScript Disabled Output
By default, if the browser doesn't have JavaScript enabled, a static text string will be shown to the user instructing them to enable Javascript to use this site. This text can be changed by overwriting the django_thumbprint/login.html
template and modifying this block:
{% block no-js-message %}Please, pretty please, won't you enable JavaScript?{% endblock %}
ThumbmarkJS Source
By default the ThumbmarkJS library is loaded from cdn.jsdelivr.net. This can be changed (to reference a static, self-hosted copy or similar) by overwriting the django_thumbprint/login.html
template and modifying this block:
{% block js-source %}<script src="https://cdn.jsdelivr.net/npm/@thumbmarkjs/thumbmarkjs/dist/thumbmark.umd.js"></script>{% endblock %}
ThumbmarkJS Script
By default the ThumbmarkJS script is run using this example from its homepage. The contents of that script can be changed by overwriting the django_thumbprint/login.html template
and modifying this block:
{% block js-script %}<script>console.log('This is my new script')</script>{% endblock %}
[!IMPORTANT] Take extreme caution when modifying this template block to ensure dynamic values are properly escaped.
Versioning
This package uses Semantic Versioning.
TL;DR you are safe to use compatible release version specifier ~=MAJOR.MINOR
in your pyproject.toml
or requirements.txt
.
Release process
python -m pip install build
python -m pip install twine
python -m build
python -m twine upload dist/*
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file django_thumbmark-0.2.tar.gz
.
File metadata
- Download URL: django_thumbmark-0.2.tar.gz
- Upload date:
- Size: 20.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d3165ecbade5027116a88cb7b437a4d42683fc6f06ca7ae964650788b94fdf4d |
|
MD5 | 6afbbcb0af9217ceacc53de33d525ff9 |
|
BLAKE2b-256 | fd7b7de49386a9720280e831e73dccaf87fac9c9aa77b44a1a83b1b06cd98e99 |
File details
Details for the file django_thumbmark-0.2-py3-none-any.whl
.
File metadata
- Download URL: django_thumbmark-0.2-py3-none-any.whl
- Upload date:
- Size: 19.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.12.3
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5ec443cf6dbf949ac966822a8e09f84d1d658446e3ec311a74933bd6f051da20 |
|
MD5 | f9f5f59c0eb5832c6abb4443ad8f2bb4 |
|
BLAKE2b-256 | eb42d62bc69b33359d0287a8e710a01c27e1bf99fdfac7977b809960da354651 |