diff options
-rw-r--r-- | ishtar_common/migrations/0247_document_cached_authors.py | 37 | ||||
-rw-r--r-- | ishtar_common/models.py | 15 |
2 files changed, 49 insertions, 3 deletions
diff --git a/ishtar_common/migrations/0247_document_cached_authors.py b/ishtar_common/migrations/0247_document_cached_authors.py new file mode 100644 index 000000000..862dc036b --- /dev/null +++ b/ishtar_common/migrations/0247_document_cached_authors.py @@ -0,0 +1,37 @@ +# Generated by Django 2.2.24 on 2024-06-07 17:22 + +from django.db import migrations, models + + +def generate_cache_authors(apps, __): + Document = apps.get_model('ishtar_common', 'Document') + for doc in Document.objects.all(): + doc.cache_authors = " ; ".join([author.cached_label for author in doc.authors.all()]) + doc.skip_history_when_saving = True + doc.no_post_process() + doc.save() + + +class Migration(migrations.Migration): + + dependencies = [ + ('ishtar_common', '0246_profile_rel_engine_default_changed_to_cache_tables'), + ] + + operations = [ + migrations.AlterModelOptions( + name='jsondatasection', + options={'ordering': ['order', 'name'], 'verbose_name': 'Custom data - Section', 'verbose_name_plural': 'Custom data - Sections'}, + ), + migrations.AddField( + model_name='document', + name='cache_authors', + field=models.TextField(blank=True, db_index=True, default='', help_text='Cached value - do not edit', verbose_name='Authors'), + ), + migrations.AddField( + model_name='historicaldocument', + name='cache_authors', + field=models.TextField(blank=True, db_index=True, default='', help_text='Cached value - do not edit', verbose_name='Authors'), + ), + migrations.RunPython(generate_cache_authors) + ] diff --git a/ishtar_common/models.py b/ishtar_common/models.py index c098eee02..ed7df17c2 100644 --- a/ishtar_common/models.py +++ b/ishtar_common/models.py @@ -4229,7 +4229,7 @@ class Document( "title", "source_type__label", "cache_related_label", - "authors__cached_label", + "cache_authors", "associated_url", ] NEW_QUERY_ENGINE = True @@ -4273,7 +4273,7 @@ class Document( "source_type__label": _("Type"), } - CACHED_LABELS = ["cache_related_label"] + CACHED_LABELS = ["cache_related_label", "cache_authors"] CACHED_COMPLETE_ID = "" EXTRA_REQUEST_KEYS = { "operations": "operations__pk", @@ -4568,7 +4568,6 @@ class Document( ] SERIALIZATION_FILES = ["image", "thumbnail", "associated_file"] SERIALIZE_PROPERTIES = ["external_id", "images_number"] - SELECT_GROUP_BY = True # v4.0 patch title = models.TextField(_("Title"), blank=True, default="") associated_file = models.FileField( @@ -4709,6 +4708,13 @@ class Document( db_index=True, help_text=_("Cached value - do not edit"), ) + cache_authors = models.TextField( + _("Authors"), + blank=True, + default="", + db_index=True, + help_text=_("Cached value - do not edit"), + ) history = HistoricalRecords(inherit=True) class Meta: @@ -5135,6 +5141,9 @@ class Document( def _generate_cache_related_label(self): return self.related_label()[:1000] + def _generate_cache_authors(self): + return " ; ".join([author.cached_label for author in self.authors.all()]) + @classmethod def get_next_index(cls): q = cls.objects.values("index").filter(index__isnull=False).order_by("-index") |