2017-07-12 17:28:27 +02:00
|
|
|
# -*- coding: utf-8 -*-
|
|
|
|
|
|
|
|
from django.db.backends.postgresql_psycopg2.schema import DatabaseSchemaEditor
|
|
|
|
from django.db.migrations.state import StateApps
|
|
|
|
from django.db.models import Max
|
|
|
|
from django.db import migrations, models
|
|
|
|
|
|
|
|
from django.utils.timezone import now as timezone_now
|
|
|
|
|
2017-07-18 20:36:18 +02:00
|
|
|
from typing import List
|
|
|
|
|
2017-07-12 17:28:27 +02:00
|
|
|
def backfill_subscription_log_events(apps, schema_editor):
|
|
|
|
# type: (StateApps, DatabaseSchemaEditor) -> None
|
|
|
|
migration_time = timezone_now()
|
|
|
|
RealmAuditLog = apps.get_model('zerver', 'RealmAuditLog')
|
|
|
|
Subscription = apps.get_model('zerver', 'Subscription')
|
|
|
|
Message = apps.get_model('zerver', 'Message')
|
2017-07-18 21:56:23 +02:00
|
|
|
objects_to_create = []
|
2017-07-12 17:28:27 +02:00
|
|
|
|
2017-07-18 20:31:02 +02:00
|
|
|
subs_query = Subscription.objects.select_related(
|
|
|
|
"user_profile", "user_profile__realm", "recipient").filter(recipient__type=2)
|
|
|
|
for sub in subs_query:
|
2017-07-18 20:36:18 +02:00
|
|
|
entry = RealmAuditLog(
|
|
|
|
realm=sub.user_profile.realm,
|
|
|
|
modified_user=sub.user_profile,
|
|
|
|
modified_stream_id=sub.recipient.type_id,
|
|
|
|
event_last_message_id=0,
|
|
|
|
event_type='subscription_created',
|
|
|
|
event_time=migration_time,
|
|
|
|
backfilled=True)
|
|
|
|
objects_to_create.append(entry)
|
|
|
|
RealmAuditLog.objects.bulk_create(objects_to_create)
|
|
|
|
objects_to_create = []
|
2017-07-12 17:28:27 +02:00
|
|
|
|
|
|
|
event_last_message_id = Message.objects.aggregate(Max('id'))['id__max']
|
|
|
|
migration_time_for_deactivation = timezone_now()
|
2017-07-18 20:31:02 +02:00
|
|
|
for sub in subs_query.filter(active=False):
|
2017-07-18 20:36:18 +02:00
|
|
|
entry = RealmAuditLog(
|
|
|
|
realm=sub.user_profile.realm,
|
|
|
|
modified_user=sub.user_profile,
|
|
|
|
modified_stream_id=sub.recipient.type_id,
|
|
|
|
event_last_message_id=event_last_message_id,
|
|
|
|
event_type='subscription_deactivated',
|
|
|
|
event_time=migration_time_for_deactivation,
|
|
|
|
backfilled=True)
|
|
|
|
objects_to_create.append(entry)
|
|
|
|
RealmAuditLog.objects.bulk_create(objects_to_create)
|
|
|
|
objects_to_create = []
|
2017-07-12 17:28:27 +02:00
|
|
|
|
|
|
|
def reverse_code(apps, schema_editor):
|
|
|
|
# type: (StateApps, DatabaseSchemaEditor) -> None
|
|
|
|
RealmAuditLog = apps.get_model('zerver', 'RealmAuditLog')
|
|
|
|
RealmAuditLog.objects.filter(event_type='subscription_created').delete()
|
|
|
|
RealmAuditLog.objects.filter(event_type='subscription_deactivated').delete()
|
|
|
|
|
|
|
|
|
|
|
|
class Migration(migrations.Migration):
|
|
|
|
|
|
|
|
dependencies = [
|
2017-07-18 06:38:10 +02:00
|
|
|
('zerver', '0092_create_scheduledemail'),
|
2017-07-12 17:28:27 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
operations = [
|
|
|
|
migrations.AddField(
|
|
|
|
model_name='realmauditlog',
|
|
|
|
name='event_last_message_id',
|
|
|
|
field=models.IntegerField(null=True),
|
|
|
|
),
|
|
|
|
migrations.RunPython(backfill_subscription_log_events,
|
|
|
|
reverse_code=reverse_code),
|
|
|
|
]
|