89 lines
2.2 KiB
Python
89 lines
2.2 KiB
Python
|
# Copyright (C) 2018-2020 by BDE ENS Paris-Saclay
|
||
|
# SPDX-License-Identifier: GPL-3.0-or-later
|
||
|
|
||
|
from django.conf import settings
|
||
|
from django.contrib.contenttypes.models import ContentType
|
||
|
from django.core.exceptions import ValidationError
|
||
|
from django.db import models
|
||
|
from django.utils import timezone
|
||
|
from django.utils.translation import gettext_lazy as _
|
||
|
|
||
|
|
||
|
class Changelog(models.Model):
|
||
|
"""
|
||
|
Store each modification in the database (except sessions and logging),
|
||
|
including creating, editing and deleting models.
|
||
|
"""
|
||
|
|
||
|
user = models.ForeignKey(
|
||
|
settings.AUTH_USER_MODEL,
|
||
|
on_delete=models.PROTECT,
|
||
|
null=True,
|
||
|
verbose_name=_('user'),
|
||
|
)
|
||
|
|
||
|
ip = models.GenericIPAddressField(
|
||
|
null=True,
|
||
|
blank=True,
|
||
|
verbose_name=_("IP Address")
|
||
|
)
|
||
|
|
||
|
model = models.ForeignKey(
|
||
|
ContentType,
|
||
|
on_delete=models.PROTECT,
|
||
|
null=False,
|
||
|
blank=False,
|
||
|
verbose_name=_('model'),
|
||
|
)
|
||
|
|
||
|
instance_pk = models.CharField(
|
||
|
max_length=255,
|
||
|
null=False,
|
||
|
blank=False,
|
||
|
verbose_name=_('identifier'),
|
||
|
)
|
||
|
|
||
|
previous = models.TextField(
|
||
|
blank=True,
|
||
|
default="",
|
||
|
verbose_name=_('previous data'),
|
||
|
)
|
||
|
|
||
|
data = models.TextField(
|
||
|
blank=True,
|
||
|
default="",
|
||
|
verbose_name=_('new data'),
|
||
|
)
|
||
|
|
||
|
action = models.CharField( # create, edit or delete
|
||
|
max_length=16,
|
||
|
null=False,
|
||
|
blank=False,
|
||
|
choices=[
|
||
|
('create', _('create')),
|
||
|
('edit', _('edit')),
|
||
|
('delete', _('delete')),
|
||
|
],
|
||
|
default='edit',
|
||
|
verbose_name=_('action'),
|
||
|
)
|
||
|
|
||
|
timestamp = models.DateTimeField(
|
||
|
null=False,
|
||
|
blank=False,
|
||
|
default=timezone.now,
|
||
|
name='timestamp',
|
||
|
verbose_name=_('timestamp'),
|
||
|
)
|
||
|
|
||
|
def delete(self, using=None, keep_parents=False):
|
||
|
raise ValidationError(_("Logs cannot be destroyed."))
|
||
|
|
||
|
class Meta:
|
||
|
verbose_name = _("changelog")
|
||
|
verbose_name_plural = _("changelogs")
|
||
|
|
||
|
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))
|