Skip to main content

Simple Google Analytics integration for Django projects

Project description

django-ga-tracking is a simple Django pluggable app that provides a context processor and template for adding Google Analytics tracking code to your pages.

Alternatives and differences

There are alternatives like django-google-analytics and Django Analytics Middleware, but this project begun as both solutions seem to introduce unnecessary complexity and/or lack the ability to configure analytics via Django settings module. The latter factor was particularly important for this project because hard-coding configuration or storing configuration in a databaes column was something we absolutely wanted to avoid.

Installation

Install using pip:

pip install django-ga-tracking

Basic usage

Add ga_tracking to INSTALLED_APPS.

Next, add the ga_tracking_id context processor to TEMPLATE_CONTEXT_PROCESSORS:

TEMPLATE_CONTEXT_PROCESSORS = (
    ....
    'ga_tracking.context_processors.ga_tracking_id',
)

Define a GA_TRACKING_ID setting and assign your tracking ID to it. For example:

GA_TRACKING_ID = 'UA-12345678-9'

Finally, add the tracker code template somewhere in your own template:

{% include "ga_tracking/ga.html" %}

New tracking code

Google Analytics offers an alternative tracking code (analytics.js). This code is also available in django-ga-tracking. Since the tracking code uses both the property ID and the top level domain, you will need to specify both. So, add this to your settings:

GA_TRACKING_ID = 'UA-12345678-9'
GA_DOMAIN = 'example.com'

Next, include the alternative template:

{% include "ga_tracking/ga_new.html" %}

Customization

Because django-ga-tracking uses a simple template to add the code, you can customize it simply by overriding the template with your own. The ga.html template contains the default <script> block as provided by Google.

The script block is not rendered at all if the GA_TRACKING_ID setting is not present, so you can, for example, set the setting only in production to avoid development sites from being tracked, or use different tracking codes on different deployments. For example:

# in settings.py
import os

GA_TRACKING_ID = os.environ.get('GA_TRACKING_ID')

Reporting bugs

Please report bugs to Bitbucket issue tracker.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

django-ga-tracking-0.0.2.zip (6.7 kB view details)

Uploaded Source

django-ga-tracking-0.0.2.tar.gz (4.0 kB view details)

Uploaded Source

File details

Details for the file django-ga-tracking-0.0.2.zip.

File metadata

File hashes

Hashes for django-ga-tracking-0.0.2.zip
Algorithm Hash digest
SHA256 573518ec02d61c08a5e44489f064953041c88af697c0554b337e61b96643980d
MD5 edf929777df664ce5eb3d936d7d5dda3
BLAKE2b-256 6b3ae1ca7bd18ff5ea5acf4e470935ca16542d85794b569c23adbaccccdd7bbc

See more details on using hashes here.

File details

Details for the file django-ga-tracking-0.0.2.tar.gz.

File metadata

File hashes

Hashes for django-ga-tracking-0.0.2.tar.gz
Algorithm Hash digest
SHA256 09fa78bcd1f2a9ca537104a72f8605724c5fe57ff7f1ac5fc5864d5e6e9bae73
MD5 bc4e707e5dd7caaeaa3c47847ad8309d
BLAKE2b-256 4ada326de6505772d0ff8cabb0bdd7600a6c30bcc1700cbac7e1adb94c24e77f

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page