A super-simple user analytics tool that tracks user behaviour based on web requests to your Django app.
Project description
A super-simple user analytics tool that tracks user behaviour based on web requests to your Django app.
It’s intended for use with libraries such as htmx, which generally make a web request for each user interaction. It also includes a JavaScript function for tracking purely client-side actions (e.g. things you might use Alpine.js for). The UI is designed for small projects where understanding individual user behaviour is useful.
Features
(optional) Automatic tracking of all web requests - no additional code needed in your project
JavaScript function for tracking client-side actions
Separate reporting of authenticated and anonymous sessions
Shows top platforms, top user-agents (using user-agents), top viewport sizes, and new users, for each month
Tracking cookies can be disabled (you just won’t see viewport size data)
All data is stored in a single table with no relations to your project’s tables
Requirements
Django 4.2+ and Python 3.8+
Installation
pip install django-silent-mammoth-whistle
Add to INSTALLED_APPS setting - ideally just above the main app:
INSTALLED_APPS = [ ..., "silent_mammoth_whistle", ..., ]
Add middleware. At the end is fine:
MIDDLEWARE = [ ..., 'silent_mammoth_whistle.middleware.SilentMammothWhistleMiddleware', ]
Include the silent mammoth whistle URLconf in your project urls.py. The URL (e.g. /mammoth) can be anything you like:
urlpatterns = [ ..., path('/mammoth', include('silent_mammoth_whistle.urls')), ..., ]
Add <script src="{% static 'silent_mammoth_whistle/js/whistle.js' %}"></script> to your templates
Run migrations ./manage.py migrate silent_mammoth_whistle
Configuration
All configuration is optional
settings.py
WHISTLE_USER_ID_FIELD
Defaults to 'id'
The name of a User model attribute that is used as the unqiue user identifier. It is displayed in the UI and is used for determining which web requests belong to which users.
WHISTLE_AUTO_LOG
Defaults to True
When True, all web requests are tracked. Disable this feature if you want to record only specific requests.
WHISTLE_CLIENT_EVENT_PATH
Defaults to '/whistle'
The url used by the whistle function in whistle.js to make web requests using JavaScript.
WHISTLE_COOKIES
Defaults to True
When True, a cookie is added to clients and is used with some JavaScript to record viewport dimensions. I don’t think this constitutes a “tracking cookie”, but if you think it does, and you don’t want that, just set this to False.
Usage
By default, silent mammoth whistle will record all web requests (specifically the HTTP method and the URL for each).
You can also record additional data for a request.
request.whistle.request('put a string here')
You can record as much data as you like, and you can make as many of these request.whistle.request() calls as you like. Silent mammoth whistle is super-simple and all data is cast to strings using str() before saving. Silent mammoth whistle will merge the strings from all the calls into a single string, separated by a tab when rendered.
Practical example time! This line will record the fields present in a POST request. This could be useful if your form has many optional fields and you want to know which ones were included by the user.
request.whistle.request('fields=' + ", ".join(request.POST.dict().keys()))
When viewing session details in silent mammoth whistle, you’ll see 3 columns: time, request, and response. Request is the obvious column to use, but you might like to separate tracking of what the user requested from how the server responded. E.g.
request.whistle.response('fields in error=' + ", ".join(form.errors.dict().keys()))
These calls all start with request. because silent mammoth whistle adds a whistle object to the standard Django request object.
The JavaScript API is similar
whistle('Edit dialog box open')
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
Hashes for django_silent_mammoth_whistle-2.0.0.tar.gz
Algorithm | Hash digest | |
---|---|---|
SHA256 | 67299c3404f8a3a7244fc52d5c2217611a62005307026ee771bcb29a98fefdf0 |
|
MD5 | c2aadf773d109255556c821c1e1c7520 |
|
BLAKE2b-256 | 16286f06670a38c7e681a0ffcafef9e522e8ddc40b79a2ae822aa7e48db66343 |
Hashes for django_silent_mammoth_whistle-2.0.0-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 250f91929761f5a7131f04eab4a6ae4d541a60205a1d69642f7fb730ddcd813d |
|
MD5 | 458c381994097bca29b5702723c4b609 |
|
BLAKE2b-256 | d03d12223ec9ba5488b370e09a6dac7fffd08ab53de09599495d9ddcbd7508b9 |