2019-07-24 08:37:13 +02:00
|
|
|
from django.conf import settings
|
|
|
|
from django.db import migrations
|
2023-03-04 01:40:40 +01:00
|
|
|
from django.db.backends.base.schema import BaseDatabaseSchemaEditor
|
2019-07-24 08:37:13 +02:00
|
|
|
from django.db.migrations.state import StateApps
|
|
|
|
|
2020-01-14 21:59:46 +01:00
|
|
|
|
2021-02-12 08:19:30 +01:00
|
|
|
def rename_zulip_realm_to_zulipinternal(
|
2022-05-27 23:33:51 +02:00
|
|
|
apps: StateApps, schema_editor: BaseDatabaseSchemaEditor
|
2021-02-12 08:19:30 +01:00
|
|
|
) -> None:
|
2019-07-24 08:37:13 +02:00
|
|
|
if not settings.PRODUCTION:
|
|
|
|
return
|
|
|
|
|
2021-02-12 08:20:45 +01:00
|
|
|
Realm = apps.get_model("zerver", "Realm")
|
|
|
|
UserProfile = apps.get_model("zerver", "UserProfile")
|
2019-07-24 08:37:13 +02:00
|
|
|
|
2023-09-07 18:22:41 +02:00
|
|
|
if not Realm.objects.exists():
|
2019-07-24 08:37:13 +02:00
|
|
|
# Database not yet populated, do nothing:
|
|
|
|
return
|
|
|
|
|
|
|
|
if Realm.objects.filter(string_id="zulipinternal").exists():
|
|
|
|
return
|
2020-01-15 22:59:31 +01:00
|
|
|
if not Realm.objects.filter(string_id="zulip").exists():
|
|
|
|
# If the user renamed the `zulip` system bot realm (or deleted
|
|
|
|
# it), there's nothing for us to do.
|
|
|
|
return
|
2019-07-24 08:37:13 +02:00
|
|
|
|
|
|
|
internal_realm = Realm.objects.get(string_id="zulip")
|
|
|
|
|
|
|
|
# For safety, as a sanity check, verify that "internal_realm" is indeed the realm for system bots:
|
|
|
|
welcome_bot = UserProfile.objects.get(email="welcome-bot@zulip.com")
|
|
|
|
assert welcome_bot.realm.id == internal_realm.id
|
|
|
|
|
|
|
|
internal_realm.string_id = "zulipinternal"
|
|
|
|
internal_realm.name = "System use only"
|
|
|
|
internal_realm.save()
|
|
|
|
|
2021-02-12 08:19:30 +01:00
|
|
|
|
2019-07-24 08:37:13 +02:00
|
|
|
class Migration(migrations.Migration):
|
|
|
|
dependencies = [
|
2021-02-12 08:20:45 +01:00
|
|
|
("zerver", "0236_remove_illegal_characters_email_full"),
|
2019-07-24 08:37:13 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
operations = [
|
python: Use trailing commas consistently.
Automatically generated by the following script, based on the output
of lint with flake8-comma:
import re
import sys
last_filename = None
last_row = None
lines = []
for msg in sys.stdin:
m = re.match(
r"\x1b\[35mflake8 \|\x1b\[0m \x1b\[1;31m(.+):(\d+):(\d+): (\w+)", msg
)
if m:
filename, row_str, col_str, err = m.groups()
row, col = int(row_str), int(col_str)
if filename == last_filename:
assert last_row != row
else:
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
with open(filename) as f:
lines = f.readlines()
last_filename = filename
last_row = row
line = lines[row - 1]
if err in ["C812", "C815"]:
lines[row - 1] = line[: col - 1] + "," + line[col - 1 :]
elif err in ["C819"]:
assert line[col - 2] == ","
lines[row - 1] = line[: col - 2] + line[col - 1 :].lstrip(" ")
if last_filename is not None:
with open(last_filename, "w") as f:
f.writelines(lines)
Signed-off-by: Anders Kaseorg <anders@zulipchat.com>
2020-04-10 05:23:40 +02:00
|
|
|
migrations.RunPython(rename_zulip_realm_to_zulipinternal, elidable=True),
|
2019-07-24 08:37:13 +02:00
|
|
|
]
|