2017-06-29 14:19:33 +00:00
|
|
|
import uuid
|
|
|
|
|
|
2017-09-13 14:57:47 +00:00
|
|
|
from django.contrib.postgres.fields import ArrayField
|
2022-12-30 07:28:55 +00:00
|
|
|
from django.core.serializers.json import DjangoJSONEncoder
|
2013-10-21 19:46:31 +00:00
|
|
|
from django.db import models
|
2020-12-06 20:36:46 +00:00
|
|
|
|
2013-11-07 16:02:31 +00:00
|
|
|
from auditlog.models import AuditlogHistoryField
|
2022-06-08 15:09:27 +00:00
|
|
|
from auditlog.registry import AuditlogModelRegistry, auditlog
|
|
|
|
|
|
|
|
|
|
m2m_only_auditlog = AuditlogModelRegistry(create=False, update=False, delete=False)
|
2013-10-21 19:46:31 +00:00
|
|
|
|
|
|
|
|
|
2017-02-11 03:02:22 +00:00
|
|
|
@auditlog.register()
|
2013-10-21 19:46:31 +00:00
|
|
|
class SimpleModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A simple model with no special things going on.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
text = models.TextField(blank=True)
|
|
|
|
|
boolean = models.BooleanField(default=False)
|
|
|
|
|
integer = models.IntegerField(blank=True, null=True)
|
|
|
|
|
datetime = models.DateTimeField(auto_now=True)
|
|
|
|
|
|
2013-11-07 16:02:31 +00:00
|
|
|
history = AuditlogHistoryField()
|
2013-10-21 19:46:31 +00:00
|
|
|
|
2022-12-28 08:51:44 +00:00
|
|
|
def __str__(self):
|
|
|
|
|
return self.text
|
|
|
|
|
|
2013-10-21 19:46:31 +00:00
|
|
|
|
|
|
|
|
class AltPrimaryKeyModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model with a non-standard primary key.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
key = models.CharField(max_length=100, primary_key=True)
|
|
|
|
|
|
2013-10-23 15:10:59 +00:00
|
|
|
text = models.TextField(blank=True)
|
|
|
|
|
boolean = models.BooleanField(default=False)
|
|
|
|
|
integer = models.IntegerField(blank=True, null=True)
|
|
|
|
|
datetime = models.DateTimeField(auto_now=True)
|
|
|
|
|
|
2013-11-07 16:02:31 +00:00
|
|
|
history = AuditlogHistoryField(pk_indexable=False)
|
2013-10-21 19:46:31 +00:00
|
|
|
|
|
|
|
|
|
2017-06-29 14:19:33 +00:00
|
|
|
class UUIDPrimaryKeyModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model with a UUID primary key.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
id = models.UUIDField(primary_key=True, default=uuid.uuid4, editable=False)
|
|
|
|
|
|
|
|
|
|
text = models.TextField(blank=True)
|
|
|
|
|
boolean = models.BooleanField(default=False)
|
|
|
|
|
integer = models.IntegerField(blank=True, null=True)
|
|
|
|
|
datetime = models.DateTimeField(auto_now=True)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(pk_indexable=False)
|
|
|
|
|
|
|
|
|
|
|
2013-10-21 19:46:31 +00:00
|
|
|
class ProxyModel(SimpleModel):
|
|
|
|
|
"""
|
|
|
|
|
A model that is a proxy for another model.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
class Meta:
|
|
|
|
|
proxy = True
|
|
|
|
|
|
|
|
|
|
|
2022-05-31 07:32:32 +00:00
|
|
|
class RelatedModelParent(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
Use multi table inheritance to make a OneToOneRel field
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class RelatedModel(RelatedModelParent):
|
2013-10-21 19:46:31 +00:00
|
|
|
"""
|
|
|
|
|
A model with a foreign key.
|
|
|
|
|
"""
|
|
|
|
|
|
2022-06-24 14:27:50 +00:00
|
|
|
related = models.ForeignKey(
|
|
|
|
|
"SimpleModel", related_name="related_models", on_delete=models.CASCADE
|
|
|
|
|
)
|
2022-05-31 07:32:32 +00:00
|
|
|
one_to_one = models.OneToOneField(
|
|
|
|
|
to="SimpleModel", on_delete=models.CASCADE, related_name="reverse_one_to_one"
|
|
|
|
|
)
|
2013-10-21 19:46:31 +00:00
|
|
|
|
2013-11-07 16:02:31 +00:00
|
|
|
history = AuditlogHistoryField()
|
2013-10-21 19:46:31 +00:00
|
|
|
|
|
|
|
|
|
|
|
|
|
class ManyRelatedModel(models.Model):
|
|
|
|
|
"""
|
2022-06-08 15:09:27 +00:00
|
|
|
A model with many-to-many relations.
|
2013-10-21 19:46:31 +00:00
|
|
|
"""
|
|
|
|
|
|
2022-06-08 15:09:27 +00:00
|
|
|
recursive = models.ManyToManyField("self")
|
|
|
|
|
related = models.ManyToManyField("ManyRelatedOtherModel", related_name="related")
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
def get_additional_data(self):
|
|
|
|
|
related = self.related.first()
|
|
|
|
|
return {"related_model_id": related.id if related else None}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ManyRelatedOtherModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model related to ManyRelatedModel as many-to-many.
|
|
|
|
|
"""
|
2013-10-21 19:46:31 +00:00
|
|
|
|
2013-11-07 16:02:31 +00:00
|
|
|
history = AuditlogHistoryField()
|
2013-10-21 19:46:31 +00:00
|
|
|
|
|
|
|
|
|
2020-12-06 20:29:24 +00:00
|
|
|
@auditlog.register(include_fields=["label"])
|
2014-10-06 09:16:23 +00:00
|
|
|
class SimpleIncludeModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A simple model used for register's include_fields kwarg
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
label = models.CharField(max_length=100)
|
|
|
|
|
text = models.TextField(blank=True)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SimpleExcludeModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A simple model used for register's exclude_fields kwarg
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
label = models.CharField(max_length=100)
|
|
|
|
|
text = models.TextField(blank=True)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
2017-09-13 14:57:47 +00:00
|
|
|
class SimpleMappingModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A simple model used for register's mapping_fields kwarg
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
sku = models.CharField(max_length=100)
|
2020-12-06 20:29:24 +00:00
|
|
|
vtxt = models.CharField(verbose_name="Version", max_length=100)
|
2017-09-13 14:57:47 +00:00
|
|
|
not_mapped = models.CharField(max_length=100)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
2022-03-10 13:17:50 +00:00
|
|
|
@auditlog.register(mask_fields=["address"])
|
|
|
|
|
class SimpleMaskedModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A simple model used for register's mask_fields kwarg
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
address = models.CharField(max_length=100)
|
|
|
|
|
text = models.TextField()
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
2015-06-03 15:49:03 +00:00
|
|
|
class AdditionalDataIncludedModel(models.Model):
|
2015-06-01 18:01:40 +00:00
|
|
|
"""
|
|
|
|
|
A model where get_additional_data is defined which allows for logging extra
|
|
|
|
|
information about the model in JSON
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
label = models.CharField(max_length=100)
|
|
|
|
|
text = models.TextField(blank=True)
|
2018-01-02 18:50:45 +00:00
|
|
|
related = models.ForeignKey(to=SimpleModel, on_delete=models.CASCADE)
|
2015-06-01 18:01:40 +00:00
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
def get_additional_data(self):
|
|
|
|
|
"""
|
|
|
|
|
Returns JSON that captures a snapshot of additional details of the
|
|
|
|
|
model instance. This method, if defined, is accessed by auditlog
|
|
|
|
|
manager and added to each logentry instance on creation.
|
|
|
|
|
"""
|
|
|
|
|
object_details = {
|
2020-12-06 20:29:24 +00:00
|
|
|
"related_model_id": self.related.id,
|
|
|
|
|
"related_model_text": self.related.text,
|
2015-06-01 18:01:40 +00:00
|
|
|
}
|
|
|
|
|
return object_details
|
|
|
|
|
|
2017-01-11 19:07:10 +00:00
|
|
|
|
|
|
|
|
class DateTimeFieldModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model with a DateTimeField, used to test DateTimeField
|
|
|
|
|
changes are detected properly.
|
|
|
|
|
"""
|
2020-12-06 20:29:24 +00:00
|
|
|
|
2017-01-11 19:07:10 +00:00
|
|
|
label = models.CharField(max_length=100)
|
|
|
|
|
timestamp = models.DateTimeField()
|
2017-09-13 14:57:47 +00:00
|
|
|
date = models.DateField()
|
|
|
|
|
time = models.TimeField()
|
2018-01-04 18:43:23 +00:00
|
|
|
naive_dt = models.DateTimeField(null=True, blank=True)
|
2017-09-13 14:57:47 +00:00
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class ChoicesFieldModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model with a CharField restricted to a set of choices.
|
|
|
|
|
This model is used to test the changes_display_dict method.
|
|
|
|
|
"""
|
2020-12-06 20:29:24 +00:00
|
|
|
|
|
|
|
|
RED = "r"
|
|
|
|
|
YELLOW = "y"
|
|
|
|
|
GREEN = "g"
|
2017-09-13 14:57:47 +00:00
|
|
|
|
|
|
|
|
STATUS_CHOICES = (
|
2020-12-06 20:29:24 +00:00
|
|
|
(RED, "Red"),
|
|
|
|
|
(YELLOW, "Yellow"),
|
|
|
|
|
(GREEN, "Green"),
|
2017-09-13 14:57:47 +00:00
|
|
|
)
|
|
|
|
|
|
|
|
|
|
status = models.CharField(max_length=1, choices=STATUS_CHOICES)
|
2019-11-06 17:12:05 +00:00
|
|
|
multiplechoice = models.CharField(max_length=255, choices=STATUS_CHOICES)
|
2017-09-13 14:57:47 +00:00
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class CharfieldTextfieldModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
A model with a max length CharField and a Textfield.
|
|
|
|
|
This model is used to test the changes_display_dict
|
|
|
|
|
method's ability to truncate long text.
|
|
|
|
|
"""
|
|
|
|
|
|
|
|
|
|
longchar = models.CharField(max_length=255)
|
|
|
|
|
longtextfield = models.TextField()
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class PostgresArrayFieldModel(models.Model):
|
|
|
|
|
"""
|
|
|
|
|
Test auditlog with Postgres's ArrayField
|
|
|
|
|
"""
|
2020-12-06 20:29:24 +00:00
|
|
|
|
|
|
|
|
RED = "r"
|
|
|
|
|
YELLOW = "y"
|
|
|
|
|
GREEN = "g"
|
2017-09-13 14:57:47 +00:00
|
|
|
|
|
|
|
|
STATUS_CHOICES = (
|
2020-12-06 20:29:24 +00:00
|
|
|
(RED, "Red"),
|
|
|
|
|
(YELLOW, "Yellow"),
|
|
|
|
|
(GREEN, "Green"),
|
2017-09-13 14:57:47 +00:00
|
|
|
)
|
|
|
|
|
|
2020-12-06 20:29:24 +00:00
|
|
|
arrayfield = ArrayField(
|
|
|
|
|
models.CharField(max_length=1, choices=STATUS_CHOICES), size=3
|
|
|
|
|
)
|
2017-01-11 19:07:10 +00:00
|
|
|
|
|
|
|
|
history = AuditlogHistoryField()
|
|
|
|
|
|
|
|
|
|
|
2018-03-27 18:42:36 +00:00
|
|
|
class NoDeleteHistoryModel(models.Model):
|
|
|
|
|
integer = models.IntegerField(blank=True, null=True)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
|
2022-05-10 03:53:18 +00:00
|
|
|
class JSONModel(models.Model):
|
2022-12-30 07:28:55 +00:00
|
|
|
json = models.JSONField(default=dict, encoder=DjangoJSONEncoder)
|
2022-05-10 03:53:18 +00:00
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
|
2022-08-21 19:45:50 +00:00
|
|
|
class SerializeThisModel(models.Model):
|
|
|
|
|
label = models.CharField(max_length=24, unique=True)
|
|
|
|
|
timestamp = models.DateTimeField()
|
|
|
|
|
nullable = models.IntegerField(null=True)
|
|
|
|
|
nested = models.JSONField()
|
|
|
|
|
mask_me = models.CharField(max_length=255, null=True)
|
|
|
|
|
code = models.UUIDField(null=True)
|
|
|
|
|
date = models.DateField(null=True)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
def natural_key(self):
|
|
|
|
|
return self.label
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SerializeOnlySomeOfThisModel(models.Model):
|
|
|
|
|
this = models.CharField(max_length=24)
|
|
|
|
|
not_this = models.CharField(max_length=24)
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SerializePrimaryKeyRelatedModel(models.Model):
|
|
|
|
|
serialize_this = models.ForeignKey(to=SerializeThisModel, on_delete=models.CASCADE)
|
|
|
|
|
subheading = models.CharField(max_length=255)
|
|
|
|
|
value = models.IntegerField()
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
class SerializeNaturalKeyRelatedModel(models.Model):
|
|
|
|
|
serialize_this = models.ForeignKey(to=SerializeThisModel, on_delete=models.CASCADE)
|
|
|
|
|
subheading = models.CharField(max_length=255)
|
|
|
|
|
value = models.IntegerField()
|
|
|
|
|
|
|
|
|
|
history = AuditlogHistoryField(delete_related=False)
|
|
|
|
|
|
|
|
|
|
|
2013-10-23 15:10:59 +00:00
|
|
|
auditlog.register(AltPrimaryKeyModel)
|
2017-06-29 14:19:33 +00:00
|
|
|
auditlog.register(UUIDPrimaryKeyModel)
|
2013-10-23 15:10:59 +00:00
|
|
|
auditlog.register(ProxyModel)
|
2015-05-15 13:14:57 +00:00
|
|
|
auditlog.register(RelatedModel)
|
|
|
|
|
auditlog.register(ManyRelatedModel)
|
2022-06-08 15:09:27 +00:00
|
|
|
auditlog.register(ManyRelatedModel.recursive.through)
|
|
|
|
|
m2m_only_auditlog.register(ManyRelatedModel, m2m_fields={"related"})
|
2020-12-06 20:29:24 +00:00
|
|
|
auditlog.register(SimpleExcludeModel, exclude_fields=["text"])
|
|
|
|
|
auditlog.register(SimpleMappingModel, mapping_fields={"sku": "Product No."})
|
2015-06-03 15:49:03 +00:00
|
|
|
auditlog.register(AdditionalDataIncludedModel)
|
2017-01-11 19:07:10 +00:00
|
|
|
auditlog.register(DateTimeFieldModel)
|
2017-09-13 14:57:47 +00:00
|
|
|
auditlog.register(ChoicesFieldModel)
|
|
|
|
|
auditlog.register(CharfieldTextfieldModel)
|
|
|
|
|
auditlog.register(PostgresArrayFieldModel)
|
2018-03-27 18:42:36 +00:00
|
|
|
auditlog.register(NoDeleteHistoryModel)
|
2022-05-10 03:53:18 +00:00
|
|
|
auditlog.register(JSONModel)
|
2022-08-21 19:45:50 +00:00
|
|
|
auditlog.register(
|
|
|
|
|
SerializeThisModel,
|
|
|
|
|
serialize_data=True,
|
|
|
|
|
mask_fields=["mask_me"],
|
|
|
|
|
)
|
|
|
|
|
auditlog.register(
|
|
|
|
|
SerializeOnlySomeOfThisModel,
|
|
|
|
|
serialize_data=True,
|
|
|
|
|
serialize_auditlog_fields_only=True,
|
|
|
|
|
exclude_fields=["not_this"],
|
|
|
|
|
)
|
|
|
|
|
auditlog.register(SerializePrimaryKeyRelatedModel, serialize_data=True)
|
|
|
|
|
auditlog.register(
|
|
|
|
|
SerializeNaturalKeyRelatedModel,
|
|
|
|
|
serialize_data=True,
|
|
|
|
|
serialize_kwargs={"use_natural_foreign_keys": True},
|
|
|
|
|
)
|