mirror of
https://github.com/zulip/zulip.git
synced 2025-11-04 14:03:30 +00:00
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.
43 lines
1.4 KiB
Python
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),
|
|
),
|
|
]
|