2024-01-11 16:32:37 +01:00
|
|
|
# Copyright (C) 2018-2024 by BDE ENS Paris-Saclay
|
2020-02-24 18:18:44 +01:00
|
|
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
|
|
|
|
|
|
|
from django.conf import settings
|
2020-03-07 22:28:59 +01:00
|
|
|
from django.contrib.contenttypes.models import ContentType
|
2020-02-24 18:18:44 +01:00
|
|
|
from django.core.exceptions import ValidationError
|
|
|
|
from django.db import models
|
2020-08-01 17:49:23 +02:00
|
|
|
from django.utils import timezone
|
2020-03-07 22:28:59 +01:00
|
|
|
from django.utils.translation import gettext_lazy as _
|
2020-02-24 18:18:44 +01:00
|
|
|
|
|
|
|
|
|
|
|
class Changelog(models.Model):
|
|
|
|
"""
|
2020-03-08 23:17:55 +01:00
|
|
|
Store each modification in the database (except sessions and logging),
|
2020-02-24 18:18:44 +01:00
|
|
|
including creating, editing and deleting models.
|
|
|
|
"""
|
|
|
|
|
|
|
|
user = models.ForeignKey(
|
|
|
|
settings.AUTH_USER_MODEL,
|
|
|
|
on_delete=models.PROTECT,
|
|
|
|
null=True,
|
|
|
|
verbose_name=_('user'),
|
|
|
|
)
|
|
|
|
|
2020-02-27 14:47:34 +01:00
|
|
|
ip = models.GenericIPAddressField(
|
|
|
|
null=True,
|
|
|
|
blank=True,
|
|
|
|
verbose_name=_("IP Address")
|
|
|
|
)
|
|
|
|
|
2020-02-26 23:34:27 +01:00
|
|
|
model = models.ForeignKey(
|
|
|
|
ContentType,
|
|
|
|
on_delete=models.PROTECT,
|
2020-02-24 18:18:44 +01:00
|
|
|
null=False,
|
|
|
|
blank=False,
|
|
|
|
verbose_name=_('model'),
|
|
|
|
)
|
|
|
|
|
|
|
|
instance_pk = models.CharField(
|
|
|
|
max_length=255,
|
|
|
|
null=False,
|
|
|
|
blank=False,
|
|
|
|
verbose_name=_('identifier'),
|
|
|
|
)
|
|
|
|
|
|
|
|
previous = models.TextField(
|
2020-09-07 01:06:22 +02:00
|
|
|
blank=True,
|
|
|
|
default="",
|
2020-02-24 18:18:44 +01:00
|
|
|
verbose_name=_('previous data'),
|
|
|
|
)
|
|
|
|
|
|
|
|
data = models.TextField(
|
2020-09-07 01:06:22 +02:00
|
|
|
blank=True,
|
|
|
|
default="",
|
2020-02-24 18:18:44 +01:00
|
|
|
verbose_name=_('new data'),
|
|
|
|
)
|
|
|
|
|
|
|
|
action = models.CharField( # create, edit or delete
|
|
|
|
max_length=16,
|
|
|
|
null=False,
|
|
|
|
blank=False,
|
2020-03-11 10:08:28 +01:00
|
|
|
choices=[
|
|
|
|
('create', _('create')),
|
|
|
|
('edit', _('edit')),
|
|
|
|
('delete', _('delete')),
|
|
|
|
],
|
|
|
|
default='edit',
|
2020-02-24 18:18:44 +01:00
|
|
|
verbose_name=_('action'),
|
|
|
|
)
|
|
|
|
|
|
|
|
timestamp = models.DateTimeField(
|
|
|
|
null=False,
|
|
|
|
blank=False,
|
2020-08-01 17:49:23 +02:00
|
|
|
default=timezone.now,
|
2020-02-24 18:18:44 +01:00
|
|
|
name='timestamp',
|
|
|
|
verbose_name=_('timestamp'),
|
|
|
|
)
|
|
|
|
|
2020-04-06 10:58:16 +02:00
|
|
|
class Meta:
|
|
|
|
verbose_name = _("changelog")
|
|
|
|
verbose_name_plural = _("changelogs")
|
2020-09-07 01:06:22 +02:00
|
|
|
|
|
|
|
def __str__(self):
|
|
|
|
return _("Changelog of type \"{action}\" for model {model} at {timestamp}").format(
|
|
|
|
action=self.get_action_display(), model=str(self.model), timestamp=str(self.timestamp))
|
2024-01-11 16:32:37 +01:00
|
|
|
|
|
|
|
def delete(self, using=None, keep_parents=False):
|
|
|
|
raise ValidationError(_("Logs cannot be destroyed."))
|