Skip to content

Integration between Django and Amplitude to help send events via the Amplitude HTTP API (v2)

License

Notifications You must be signed in to change notification settings

9128305/django-amplitude

 
 

Repository files navigation

Django Amplitude

Integration between Django and Amplitude.com to help send events via the Amplitude HTTP API (v2)

Quick start

Installation

pip install django-amplitude

Add amplitude to your INSTALLED_APPS. If they are not already the Django sessions app must also be added:

INSTALLED_APPS = [
    ...
    'django.contrib.sessions',
    ...
    'amplitude',
]

If you do not have it already you must also add the Django django.contrib.sessions.middleware.SessionMiddleware. Then add the ampliturde SessionInfo middleware after the SessionMiddleware:

MIDDLEWARE = [
    ...
    'django.contrib.sessions.middleware.SessionMiddleware',
    ...
    'amplitude.middleware.SessionInfo',
]

Now set your Amplitude API key and user / group options in your settings.py:

# Settings > Projects > <Your project> > General > API Key
AMPLITUDE_API_KEY = '<amplitude-project-api-key>'

# You can also choose if you want to include user and group data (Default False)
AMPLITUDE_INCLUDE_USER_DATA = False
AMPLITUDE_INCLUDE_GROUP_DATA = False

Note: If you want to include user or group data you must ensure the Django auth is setup correctly. This includes adding django.contrib.auth and django.contrib.contenttypes to INSTALLED_APPS and django.contrib.auth.middleware.AuthenticationMiddleware to MIDDLEWARE.

For more information on the above settings see the configuration settings section.

Usage

Page view events

If you want to send an event to Amplitude on every page view you can use the django-amplitude SendPageViewEvent middleware to your MIDDLEWARE in your Django settings.

This will automatically create an event called Page view with all the information it's possible to pull from the Django request object such as URL path and parameters, user agent info, IP info, user info etc.

It must be placed after the amplitude.middleware.SessionInfo middleware:

MIDDLEWARE = [
    'django.contrib.sessions.middleware.SessionMiddleware',
    ...
    'amplitude.middleware.SessionInfo',
    'amplitude.middleware.SendPageViewEvent',
]

While using SendPageViewEvent if there are certain URLs that you do not want to update Amplitude with you can use the AMPLITUDE_IGNORE_URLS setting. This setting take a list of relative urls or URL names. Relative URLS most match exactly so need to start with a forward slash (/)

AMPLITUDE_IGNORE_URLS = ['my_url_name', '/testurl']

Sending events manually

If you want to send your own events:

from amplitude import Amplitude

amplitude = Amplitude()
event_data = amplitude.build_event_data(
    event_type='Some event type',
    request=request,
)
amplitude.send_events([event_data])

The above request will include URL and HTTP header info in the event_properties. If you want to override the event properties you can pass them through to build_event_data:

event_data = amplitude.build_event_data(
    event_type='User purchase',
    request=request,
    event_properties={'products': ['laptop', 'phone']}
)

build_event_data missing event data keys

The build_event_data method (and in extension the SendPageViewEvent middleware) currently does not send the following keys from UploadRequestBody type in Amplitude HTTP API (v2):

  • event_id
  • app_version
  • carrier
  • price
  • quantity
  • revenue
  • productId
  • revenueType
  • idfa
  • idfv
  • adid
  • android_id
  • dma
  • insert_id

If you want to record an event in Amplitude with any of these keys you must use build and send your own event data using amplitude.build_event_data where you can pass any of the above as kwargs:

amplitude = Amplitude()
event_data = amplitude.build_event_data(
    event_type='Some event type',
    request=request,
    app_version='1.0.0',
)
amplitude.send_events([event_data])

Building you own event

If you are not happy with the data from build_event_data you can build you own event data based on the UploadRequestBody type in Amplitude HTTP API (v2). If you want to do this There are a few helper functions to build different parts of the event data from the Django request object:

amplitude.event_properties_from_request(request)  # Gets URL and HTTP header data
amplitude.device_data_from_request(request)  # Gets device info from user agent
amplitude.user_properties_from_request(request)  # Gets info from user model
amplitude.group_from_request(request)  # Gets the list of groups a user is in

amplitude.location_data_from_ip_address(ip_address)  # Gets location data from IP if GeoIP2 is setup
  • user_properties_from_request will return an empty dict if AMPLITUDE_INCLUDE_USER_DATA is False
  • group_from_request will return an empty dict if AMPLITUDE_INCLUDE_GROUP_DATA is False

Configuration settings

Below are the different settings that can be overridden. To do so place the setting into your settings.py.

# This variable is required when amplitude is added to INSTALLED_APPS
AMPLITUDE_API_KEY = '<amplitude-project-api-key>'

# If the users Django user information is included in the Amplitude event.
# This includes - username, email, full_name, is_staff, is_superuser
AMPLITUDE_INCLUDE_USER_DATA = False

# If the groups the user is a member of is included in the Amplitude event.
# A list of the group names will be sent in the request.
AMPLITUDE_INCLUDE_GROUP_DATA = False

# A list of URLs which `SendPageViewEvent` middleware should not run for.
# Each item in the list can be either a URL or url name
AMPLITUDE_IGNORE_URLS = ['home', '/please/ignore/']

# The minimum permitted length for user_id & device_id fields
# https://developers.amplitude.com/docs/http-api-v2#properties-2
AMPLITUDE_MIN_ID_LENGTH = None

About

Integration between Django and Amplitude to help send events via the Amplitude HTTP API (v2)

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 100.0%