Skip to main content

Track Django Model Objects over time

Project description

django-model-tracker

Track model object changes over time so that you know who done what.

PyPI version Downloads

Installation

  • Install the package

    • For Django<4.0
       pip install 'django-model-tracker jsonfield'
      
    • For Django>=4.0
       pip install 'django-model-tracker'
      
  • Add Application to your project's INSTALLED_APPs

INSTALLED_APPS = (
     '....',
    'ModelTracker',
    )
  • Add the following line to your urls.py
import ModelTracker
urlpatterns = patterns('',
...
url(r'^track/', include('ModelTracker.urls')),
...
)
  • Run Migrations
   python manage.py migrate ModelTracker 
  • Add the following line to your models.py file
from ModelTracker import Tracker
  • Convert each Model you want to track to inhert from Tracker.ModelTracker instead of models.Model

Old Code

   class Employee(models.Model):
     name=models.CharField(max_length=255)
     address=models.CharField(max_length=255)
     age=models.IntegerField()

New Code

 class Employee(Tracker.ModelTracker):
   name=models.CharField(max_length=255)
   address=models.CharField(max_length=255)
   age=models.IntegerField()
  • For each save() call, add the user the username
    • Old Code
   emp=Employee()
   emp.save()
 * New Code
       emp=Employee()
       emp.save(request.user.username)
  • Starting from version of 0.5, you can pass a event_name parameter to mark change as an event

    • New Code
       emp=Employee()
       emp.save(request.user.username,event_name="Created the user")

Using The Middleware

You can add ModelTracker.middleware.ModelTrackerMiddleware to your Middleware classes to get the username automatically from the request.

MIDDLEWARE_CLASSES = (
     '....',
    'ModelTracker.middleware.ModelTrackerMiddleware',
    )

Note: If you pass username as None then the change won't be saved.

Showing Record History

There are 3 ways to see the history of a record

  1. go to ModelTracker url and select Table and enter id.
  2. call showModelChanges by POST and send csrftokenmiddleware to return history as html.
  3. call getModelChanges which returns history as Json.

Django Admin

There is 2 ways to update an object by django admin

  1. Handle save and delete in ModelAdmin as follows
    def save_model(self, request, obj, form, change):
         obj.save(request.user.username,"Editing From admin interface")
    
    def delete_model(self, request, obj):
         obj.delete(username=request.user.username, event_name="Deleting From admin interface")
    
  2. Inhert from TrackerAdmin rather ModelAdmin
    from ModelTracker.Tracker import TrackerAdmin 
    admin.site.register(employee, TrackerAdmin)
    

Download files

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

Source Distribution

django-model-tracker-2.0.4.tar.gz (62.0 kB view details)

Uploaded Source

File details

Details for the file django-model-tracker-2.0.4.tar.gz.

File metadata

  • Download URL: django-model-tracker-2.0.4.tar.gz
  • Upload date:
  • Size: 62.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.8.0 colorama/0.4.5 importlib-metadata/4.6.4 keyring/23.5.0 pkginfo/1.8.2 readme-renderer/34.0 requests-toolbelt/0.9.1 requests/2.28.1 rfc3986/1.5.0 tqdm/4.57.0 urllib3/1.25.10 CPython/3.10.6

File hashes

Hashes for django-model-tracker-2.0.4.tar.gz
Algorithm Hash digest
SHA256 2da94b112b0ea4dd85b2a8e56bec21fddc28569cc1946e8a35215089ea62eba2
MD5 8a6a38143c091a771eb32fcca8a68d2c
BLAKE2b-256 3d551c3a34615abc5474a65218a6b18884c3a8803dcaab12128c78efac4d7ab6

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