Django-Simple-History: Избегайте избыточных записей истории и отслеживайте общие отношения

Мы используем django-simple-history для отслеживания изменений в наших моделях, включая отношения «многие-ко-многим» (m2m) и общие отношения.

Модель:

class BandProfile(BaseModel):

    class Meta:
        db_table = "band_profiles"

    name = models.CharField(max_length=255)
    types = models.ManyToManyField(
        Choices,
        related_name="types",
        limit_choices_to={"category": "type"},
        blank=True,
    )
    description = models.TextField(null=True, blank=True)

    history = HistoricalRecords(
        table_name="history_band_profiles",
        history_user_setter=set_historical_user_from_request,
        history_user_getter=get_historical_user_from_request,
        history_user_id_field=models.CharField(max_length=36, null=True),
        m2m_fields=[types],  # Many-to-many tracking
    )

    def __str__(self):
        return f"Band Profile for {self.name}"

Сериализатор:

    def create(self, validated_data):
        """
        Create method for BandProfile with handling for related fields.
        """
        types = validated_data.pop("type_ids", [])

        band_profile = BandProfile.objects.create(**validated_data)
        band_profile.types.set(types)

Вопросы:

При создании или обновлении ресурсов django-simple-history генерируется множество избыточных записей в истории, что приводит к неправильному отслеживанию истории.

Ниже показаны избыточные записи.

Смотрите лишние записи

Ожидаемый формат ответа: Нам нужен структурированный ответ, включающий исторические записи ресурса, его отношения «многие-ко-многим» и общие отношения, примерно так (названия полей приведены в качестве примера):

[
    {
        "id": 101,
        "name": "Resource A",
        "history_date": "2025-03-20T10:00:00Z",
        "change_type": "update",
        "types": [
            {
                "id": 201,
                "name": "Sector X",
                "history_date": "2025-03-19T15:00:00Z",
                "change_type": "create"
            },
            {
                "id": 202,
                "name": "Sector Y",
                "history_date": "2025-03-20T16:00:00Z",
                "change_type": "update"
            }
        ],
        "generic_relation": [
            {
                "id": 301,
                "type": "Document",
                "title": "Policy Document A",
                "history_date": "2025-03-18T11:00:00Z",
                "change_type": "create"
            },
            {
                "id": 302,
                "type": "Document",
                "title": "Policy Document B",
                "history_date": "2025-03-20T14:00:00Z",
                "change_type": "delete"
            }
        ]
    }
]

Вопросы:

Как предотвратить избыточные записи истории при создании и обновлении отношений «многие-ко-многим»? Может быть, мы что-то упустили в нашей конфигурации?

Примечания:

  • Мы пробовали использовать сквозную модель для отношений «многие-ко-многим», но записи истории не поддерживают связь между основной моделью и связанными объектами

This is a known issue with django-simple-history. It is documented here. You need to run the clean_duplicate_history management command regularly, for example with a cron job, in order to clean up those redundant history records.

Вернуться на верх