Skip to main content

Add model fields to track creation and modification dates, users and more on save.

Project description

pypi actions codecov downloads

django-audit-fields

VERSION

  • <=0.3.3 (DJ 3.1, py 3.7, 3.8)

  • >=0.3.4 (DJ 3.2+, py 3.9+)

  • >=0.3.14 (DJ4.2, py3.11) includes locale

Installation

pip install django_audit_fields

Add both django_audit_fields and django_revision to INSTALLED_APPS

INSTALLED_APPS = [
    "...",
    "django_revision.apps.AppConfig",
    "django_audit_fields.apps.AppConfig",
    "..."]

Usage

Add model fields to track creation and modification dates, users and more on save.

Declare your model using AuditModelMixin

from django_audit_fields.model_mixins import AuditModelMixin

class MyModel(AuditModelMixin,  models.Model):
    ...
    class Meta(AuditModelMixin.Meta):
        pass

Preferably, use a UUID as primary key by declaring your model using AuditUuidModelMixin

from django_audit_fields.model_mixins import AuditUuidModelMixin

class MyModel(AuditUuidModelMixin, models.Model):
    ...
    class Meta(AuditUuidModelMixin.Meta):
        pass

The model mixins AuditModelMixin and AuditUuidModelMixin:

  • add audit fields (created, modified, user_created, user_modified, hostname_created, hostname_modified);

The model mixin AuditUuidModelMixin also

  • sets the id fields to a UUIDField instead of an integer;

Most models require an audit trail. If so, add the HistoricalRecord model manager from django-simple-history:

from simple_history.models import HistoricalRecords

class MyModel(AuditUuidModelMixin, models.Model):
    ...
    history = HistoricalRecords()

Notes

User created and modified fields behave as follows:

  • created is only set on pre-save add

  • modified is always updated

Project details


Download files

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

Source Distribution

django-audit-fields-0.3.16.tar.gz (25.6 kB view details)

Uploaded Source

Built Distribution

django_audit_fields-0.3.16-py3-none-any.whl (24.2 kB view details)

Uploaded Python 3

File details

Details for the file django-audit-fields-0.3.16.tar.gz.

File metadata

  • Download URL: django-audit-fields-0.3.16.tar.gz
  • Upload date:
  • Size: 25.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.4

File hashes

Hashes for django-audit-fields-0.3.16.tar.gz
Algorithm Hash digest
SHA256 d90195f7f15426bc7437c0503ef01cb65db27d2a4beb655296bbc760240a4786
MD5 9f4ed7708b719d3b017563607c35ac98
BLAKE2b-256 c247368cc273fde74a802baaf7ece4dea7216a55e6d3040ee3559d50f7b659ca

See more details on using hashes here.

File details

Details for the file django_audit_fields-0.3.16-py3-none-any.whl.

File metadata

File hashes

Hashes for django_audit_fields-0.3.16-py3-none-any.whl
Algorithm Hash digest
SHA256 91c78f0d004139bfdf85cc29968bbea768c6083ee9d9ea53dd70574071cdaf58
MD5 498ad39b716e5cb802c3a5f836167bb8
BLAKE2b-256 43748fb1aa28f069645463bdb0e9f3f6e7dcdabe06ea354d9ce5e5ee2a78716a

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