From ae806d5d7056f4d136fa6a1e6ef25e7a98d1f556 Mon Sep 17 00:00:00 2001 From: Anders <6058745+ddabble@users.noreply.github.com> Date: Sun, 8 Sep 2024 15:07:50 +0200 Subject: [PATCH] Documented overriding create_historical_record() ...as a more fine-grained alternative to the other ways of disabling historical record creation. --- docs/disabling_history.rst | 23 +++++++++++++++++++++++ simple_history/models.py | 4 +++- 2 files changed, 26 insertions(+), 1 deletion(-) diff --git a/docs/disabling_history.rst b/docs/disabling_history.rst index adafd9df..e2938948 100644 --- a/docs/disabling_history.rst +++ b/docs/disabling_history.rst @@ -43,6 +43,29 @@ See some examples below: Poll.objects.create(question="ignore this") Poll.objects.create(question="what's up?") +Overriding ``create_historical_record()`` +----------------------------------------- + +For even more fine-grained control, you can subclass ``HistoricalRecords`` and override +its ``create_historical_record()`` method, for example like this: + +.. code-block:: python + + class CustomHistoricalRecords(HistoricalRecords): + def create_historical_record( + self, instance: models.Model, history_type: str, *args, **kwargs + ) -> None: + # Don't create records for "ignore" polls that are being deleted + if "ignore" in poll.question and history_type == "-": + return + + super().create_historical_record(instance, history_type, *args, **kwargs) + + + class Poll(models.Model): + # ... + history = CustomHistoricalRecords() + The ``SIMPLE_HISTORY_ENABLED`` setting -------------------------------------- diff --git a/simple_history/models.py b/simple_history/models.py index d612b00b..1c590a29 100644 --- a/simple_history/models.py +++ b/simple_history/models.py @@ -768,7 +768,9 @@ def create_historical_record_m2ms(self, history_instance, instance): field=field, ) - def create_historical_record(self, instance, history_type, using=None): + def create_historical_record( + self, instance: models.Model, history_type: str, using: str = None + ) -> None: using = using if self.use_base_model_db else None history_date = getattr(instance, "_history_date", timezone.now()) history_user = self.get_history_user(instance)