Skip to main content

A simple Django app to track create,update and delete actions.

Project description

Build Status Coverage Status Maintainability Downloads Downloads Downloads PyPI version


drf-history is a simple django rest framework app to track actions performed in a django app and to also gets the current request. The actions being tracked are POST, DELETE, PUT and PATCH

Data being captured is

Data Description
user The current loggedin user making the request
request data(body) Data being sent (POST, PATCH and PUT)
response data response data after the request is complete
table_name name of the model the request is affecting
instance_id The id of the created, updated or deleted model instance
method The request method i.e POST, DELETE, PUT or PATCH
created_at Date time object for when the request is being carried out
path path the request is coming from

Quick start

  1. Add track_actions to your INSTALLED_APPS setting

  2. Add track_actions.requestMiddleware.RequestMiddleware in settings under middlewares

         ... ,
  3. Run python migrate track_actions to create the History model.

     `python migrate track_actions`

After this every POST, UPDATE and DELETE action will be recorded in your database under the history model.

To get the current request

To get the current request in progress anywhere in the application.

  1. Import the relevant class.

     from track_actions.requestMiddleware import RequestMiddleware

2 Get the current request object.

    current_request = RequestMiddleware.get_request_data()[1]

To access the get history endpoint

  1. In your project's url file

     `import track_actions` 
  2. Register the url in the urlpattern

     `path('track_actions/', include('track_actions.urls'))`
  3. visit the url in the browser or on postman


you should be able to see all the recorded history if you have admin priveleges and you are authenticated.


You can create your own endpoint to view all history from the History model by importing it in your views or serializers.

    `from track_actions.models import History`


This package will only work if you have a user in a request and a user model in your database.

Project details

Download files

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

Files for drf-history, version 0.0.9
Filename, size File type Python version Upload date Hashes
Filename, size drf_history-0.0.9-py3-none-any.whl (8.8 kB) File type Wheel Python version py3 Upload date Hashes View
Filename, size drf-history-0.0.9.tar.gz (6.6 kB) File type Source Python version None Upload date Hashes View

Supported by

Pingdom Pingdom Monitoring Google Google Object Storage and Download Analytics Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN DigiCert DigiCert EV certificate StatusPage StatusPage Status page