Track Django Model Objects over time
Project description
django-model-tracker
Track model object changes over time so that you know who done what.
Installation
-
Install the package
- For Django<4.0
pip install 'django-model-tracker jsonfield'
- For Django>=4.0
pip install 'django-model-tracker'
- For Django<4.0
-
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 ofmodels.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
- go to
ModelTracker
url and selectTable
and enterid
. - call
showModelChanges
by POST and sendcsrftokenmiddleware
to return history as html. - call
getModelChanges
which returns history as Json.
Django Admin
There is 2 ways to update an object by django admin
- 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")
- Inhert from TrackerAdmin rather ModelAdmin
from ModelTracker.Tracker import TrackerAdmin admin.site.register(employee, TrackerAdmin)
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
File details
Details for the file django-model-tracker-2.0.3.tar.gz
.
File metadata
- Download URL: django-model-tracker-2.0.3.tar.gz
- Upload date:
- Size: 61.9 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
Algorithm | Hash digest | |
---|---|---|
SHA256 | 2aaa515ea204d0ab6628be60852b9f2fccf8656c90e623f707154a7a438dfd46 |
|
MD5 | 3e28ec86c0eb626f55c5ff6a7a12e495 |
|
BLAKE2b-256 | 5fda0a0904221616cfc31b6431197efca88f346631414fe14facfcce37a6d1af |