mirror of
				https://github.com/zulip/zulip.git
				synced 2025-11-03 21:43:21 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			71 lines
		
	
	
		
			2.6 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
from django.db import migrations, models
 | 
						|
from django.db.backends.postgresql.schema import DatabaseSchemaEditor
 | 
						|
from django.db.migrations.state import StateApps
 | 
						|
from django.db.models import Max
 | 
						|
from django.utils.timezone import now as timezone_now
 | 
						|
 | 
						|
 | 
						|
def backfill_subscription_log_events(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> None:
 | 
						|
    migration_time = timezone_now()
 | 
						|
    RealmAuditLog = apps.get_model("zerver", "RealmAuditLog")
 | 
						|
    Subscription = apps.get_model("zerver", "Subscription")
 | 
						|
    Message = apps.get_model("zerver", "Message")
 | 
						|
    objects_to_create = []
 | 
						|
 | 
						|
    subs_query = Subscription.objects.select_related(
 | 
						|
        "user_profile", "user_profile__realm", "recipient"
 | 
						|
    ).filter(recipient__type=2)
 | 
						|
    for sub in subs_query:
 | 
						|
        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 = []
 | 
						|
 | 
						|
    event_last_message_id = Message.objects.aggregate(Max("id"))["id__max"]
 | 
						|
    migration_time_for_deactivation = timezone_now()
 | 
						|
    for sub in subs_query.filter(active=False):
 | 
						|
        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 = []
 | 
						|
 | 
						|
 | 
						|
def reverse_code(apps: StateApps, schema_editor: 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 = [
 | 
						|
        ("zerver", "0092_create_scheduledemail"),
 | 
						|
    ]
 | 
						|
 | 
						|
    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, elidable=True
 | 
						|
        ),
 | 
						|
    ]
 |