Files
zulip/zerver/migrations/0037_disallow_null_string_id.py
Tim Abbott 8e7ce7cc79 python: Sort migrations/management command imports with isort.
This is a preparatory commit for using isort for sorting all of our
imports, merging changes to files where we can easily review the
changes as something we're happy with.

These are also files with relatively little active development, which
means we don't expect much merge conflict risk from these changes.
2020-01-14 13:07:47 -08:00

43 lines
1.4 KiB
Python

# -*- coding: utf-8 -*-
from django.db import migrations, models
from django.db.backends.postgresql_psycopg2.schema import DatabaseSchemaEditor
from django.db.migrations.state import StateApps
from django.db.utils import IntegrityError
def set_string_id_using_domain(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> None:
Realm = apps.get_model('zerver', 'Realm')
for realm in Realm.objects.all():
if not realm.string_id:
prefix = realm.domain.split('.')[0]
try:
realm.string_id = prefix
realm.save(update_fields=["string_id"])
continue
except IntegrityError:
pass
for i in range(1, 100):
try:
realm.string_id = prefix + str(i)
realm.save(update_fields=["string_id"])
continue
except IntegrityError:
pass
raise RuntimeError("Unable to find a good string_id for realm %s" % (realm,))
class Migration(migrations.Migration):
dependencies = [
('zerver', '0036_rename_subdomain_to_string_id'),
]
operations = [
migrations.RunPython(set_string_id_using_domain),
migrations.AlterField(
model_name='realm',
name='string_id',
field=models.CharField(unique=True, max_length=40),
),
]