Skip to content

Easy app for recording activities/events happening on your site. Similar to google analytics or mixpanel but to be stored in your own DB

Notifications You must be signed in to change notification settings

vangale/django-activity

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

5 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation


Django-Activity
==================

A simple app that makes it easy to store user activities (events) on your site such as page visits, model edits, etc.

This is similar to Google Analytics or Mixpanel, except its stored in your own database and no requests to outside services are needed.


Why?
========

Because its important to start collecting data, even if you don't have the capabilities to start plotting and understanding it yet.

Because it has to be simple.

Because storing these metrics in a local database is much faster than pinging an external service.

Because storing the data localy gives ultimate control and privacy.

Because danger never takes a vacation!


Usage
=======

Storing a new activity record is incredibly easy.  Simply create and save a new activity object
giving it the request object, a subject and two optional values.

from djangactivity import Activity
Activity(request, subject, value1, value2).save()

See Examples below.


Installation
============

Download this source code to somewhere in your python path and rename it to 'activity'.

git clone [email protected]:godavemon/django-activity.git
mv django-activity activity

Next add 'djangoactivity' to your INSTALLED_APPS tuple in your settings.py 


Bonus Installation! 
===================

We're working on creating some easy hooks for common activities to be recorded.  For now there is one:

Page Visits:  If you'd like to keep track of the pages your users are viewing and the pages they're coming from simply add 'activity.middleware.PageActivity' to the MIDDLEWARE_CLASSES tuple in settings.py

MIDDLEWARE_CLASSES = (
    'django.middleware.common.CommonMiddleware',
    'django.contrib.sessions.middleware.SessionMiddleware',
    'django.contrib.auth.middleware.AuthenticationMiddleware',
    'django.middleware.doc.XViewMiddleware',

    'djangoactivity.middleware.PageActivity',
)





Details
=========

The Activity object automatically pulls out ipaddr, session and user_id (if they are logged in) from the request object.  

The created djangoactivity_activity table looks like this 

+---------+--------------+------+-----+---------+----------------+
| Field   | Type         | Null | Key | Default | Extra          |
+---------+--------------+------+-----+---------+----------------+
| id      | int(11)      | NO   | PRI | NULL    | auto_increment | 
| ipaddr  | varchar(39)  | NO   |     | NULL    |                | 
| session | varchar(40)  | NO   |     | NULL    |                | 
| user_id | int(11)      | YES  | MUL | NULL    |                | 
| date    | datetime     | NO   |     | NULL    |                | 
| subject | varchar(100) | NO   |     | NULL    |                | 
| value1  | varchar(200) | YES  |     | NULL    |                | 
| value2  | varchar(200) | YES  |     | NULL    |                | 
+---------+--------------+------+-----+---------+----------------+


Examples 
==========

# Record a page view and its referer
Activity(request, 'pageview', request.get_full_path(), request.META.get("HTTPREFERER", "")).save()

# Record that the user edited their profile
Activity(request, 'profile-edit')

# Record a phase in a singup funnel
Activity(request, 'signup-funnel', 3, 'submitteddetails')  

# Record that a song was played
Activity(request, 'song-played', 'Hey Jude')




JavaScript
============


Include the djangoactivity/media/action.js file in your page and you can store Activities in Javascript as well.

User request information is stored automatically along with the activity record.



<script src="yourpathto/activity.js" text="text/javascript"></script>

<script type='text/javascript'>

Activity("somesubject", 'optional value', 'optional second value');

function openlightbox() {
	 ... do stuff
	 
	 Activity("lightbox opened")
}
</script>

About

Easy app for recording activities/events happening on your site. Similar to google analytics or mixpanel but to be stored in your own DB

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published