zulip/zerver/migrations/0128_scheduledemail_realm.py

56 lines
2.0 KiB
Python
Raw Normal View History

# Generated by Django 1.11.6 on 2017-12-05 01:08
import django.db.models.deletion
from django.db import migrations, models
from django.db.backends.postgresql.schema import BaseDatabaseSchemaEditor
from django.db.migrations.state import StateApps
def set_realm_for_existing_scheduledemails(
apps: StateApps, schema_editor: BaseDatabaseSchemaEditor
) -> None:
scheduledemail_model = apps.get_model("zerver", "ScheduledEmail")
preregistrationuser_model = apps.get_model("zerver", "PreregistrationUser")
for scheduledemail in scheduledemail_model.objects.all():
if scheduledemail.type == 3: # ScheduledEmail.INVITATION_REMINDER
# Don't think this can be None, but just be safe
prereg = preregistrationuser_model.objects.filter(email=scheduledemail.address).first()
if prereg is not None:
scheduledemail.realm = prereg.realm
else:
scheduledemail.realm = scheduledemail.user.realm
scheduledemail.save(update_fields=["realm"])
# Shouldn't be needed, but just in case
scheduledemail_model.objects.filter(realm=None).delete()
class Migration(migrations.Migration):
dependencies = [
("zerver", "0127_disallow_chars_in_stream_and_user_name"),
]
operations = [
# Start with ScheduledEmail.realm being non-null
migrations.AddField(
model_name="scheduledemail",
name="realm",
field=models.ForeignKey(
null=True, on_delete=django.db.models.deletion.CASCADE, to="zerver.Realm"
),
),
# Sets realm for existing ScheduledEmails
migrations.RunPython(
set_realm_for_existing_scheduledemails,
reverse_code=migrations.RunPython.noop,
elidable=True,
),
# Require ScheduledEmail.realm to be non-null
migrations.AlterField(
model_name="scheduledemail",
name="realm",
field=models.ForeignKey(on_delete=django.db.models.deletion.CASCADE, to="zerver.Realm"),
),
]