Add model fields to track creation and modification dates, users and more on save.
Project description
django-audit-fields
Installation
pip install django_audit_fields
Add both django_audit_fields and django_revision to INSTALLED_APPS:
.. code-block:: python
- 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 HistoricalRecord
class MyModel(AuditUuidModelMixin, models.Model):
...
history = HistoricalRecord()
Notes
User created and modified fields behave as follows:
created is only set on pre-save add
modified is always updated
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 Distributions
Built Distribution
Hashes for django_audit_fields-0.3.1-py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 71be4f804cbc449f4f5b57a2fbdf3a4a3693adad4e71f3a689051c8424d81d2b |
|
MD5 | 02a0cce6f6b42b6be463d3303dd13fda |
|
BLAKE2b-256 | d41ccfed2a217092e9b681a333677e006838165e76c8befa3787f7203712b4c3 |