summaryrefslogtreecommitdiff
path: root/ishtar_common/migrations/0266_migrate_cached_town.py
diff options
context:
space:
mode:
authorÉtienne Loks <etienne.loks@iggdrasil.net>2025-10-24 15:05:28 +0200
committerÉtienne Loks <etienne.loks@iggdrasil.net>2025-10-24 18:40:45 +0200
commit966b7443e1d2001d69ca5b406e2b99969adc67ca (patch)
tree028ca97674b74ebe352ecfb54e9c13f69aa0d583 /ishtar_common/migrations/0266_migrate_cached_town.py
parente6fc3223057ff1c79ad15f2f14d66dc195cffacd (diff)
downloadIshtar-966b7443e1d2001d69ca5b406e2b99969adc67ca.tar.bz2
Ishtar-966b7443e1d2001d69ca5b406e2b99969adc67ca.zip
🐛 ✨ person, organization tables: fix and optimize town name and person type list (refs #6441)
Diffstat (limited to 'ishtar_common/migrations/0266_migrate_cached_town.py')
-rw-r--r--ishtar_common/migrations/0266_migrate_cached_town.py37
1 files changed, 37 insertions, 0 deletions
diff --git a/ishtar_common/migrations/0266_migrate_cached_town.py b/ishtar_common/migrations/0266_migrate_cached_town.py
new file mode 100644
index 000000000..e5904a5c5
--- /dev/null
+++ b/ishtar_common/migrations/0266_migrate_cached_town.py
@@ -0,0 +1,37 @@
+# Generated by Django 2.2.24 on 2025-10-24 12:59
+
+from django.db import migrations
+
+
+def _generate_cached_town(Town, town):
+ if town.precise_town_id:
+ return Town.objects.get(id=town.precise_town_id).name
+ return town.town or ""
+
+
+def migrate_cached_towns(apps, __):
+ Town = apps.get_model("ishtar_common", "Town")
+ Person = apps.get_model("ishtar_common", "Person")
+ for person in Person.objects.all():
+ Person.objects.filter(pk=person.pk).update(
+ cached_town=_generate_cached_town(Town, person),
+ cached_person_types=", ".join(pt.label for pt in person.person_types.all()),
+ cached_profiles=", ".join(set([p.profile_type.label
+ for p in person.profiles.all()]))
+ )
+ Organization = apps.get_model("ishtar_common", "Organization")
+ for organization in Organization.objects.all():
+ Organization.objects.filter(pk=organization.pk).update(
+ cached_town=_generate_cached_town(Town, organization),
+ )
+
+
+class Migration(migrations.Migration):
+
+ dependencies = [
+ ('ishtar_common', '0265_cached_town'),
+ ]
+
+ operations = [
+ migrations.RunPython(migrate_cached_towns)
+ ]