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.