mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-25 09:03:57 +00:00 
			
		
		
		
	migrations: Fix Python-looped SQL in 0376; don’t crash if no user found.
Signed-off-by: Anders Kaseorg <anders@zulip.com>
This commit is contained in:
		
				
					committed by
					
						 Tim Abbott
						Tim Abbott
					
				
			
			
				
	
			
			
			
						parent
						
							85e2738a00
						
					
				
				
					commit
					cb8ba561d9
				
			| @@ -1,6 +1,7 @@ | |||||||
| from django.db import migrations | from django.db import migrations | ||||||
| from django.db.backends.postgresql.schema import DatabaseSchemaEditor | from django.db.backends.postgresql.schema import DatabaseSchemaEditor | ||||||
| from django.db.migrations.state import StateApps | from django.db.migrations.state import StateApps | ||||||
|  | from django.db.models import OuterRef, Subquery | ||||||
|  |  | ||||||
|  |  | ||||||
| def set_emoji_author(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> None: | def set_emoji_author(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> None: | ||||||
| @@ -13,20 +14,15 @@ def set_emoji_author(apps: StateApps, schema_editor: DatabaseSchemaEditor) -> No | |||||||
|     UserProfile = apps.get_model("zerver", "UserProfile") |     UserProfile = apps.get_model("zerver", "UserProfile") | ||||||
|     ROLE_REALM_OWNER = 100 |     ROLE_REALM_OWNER = 100 | ||||||
|  |  | ||||||
|     realm_emoji_to_update = [] |     RealmEmoji.objects.filter(author=None).update( | ||||||
|     for realm_emoji in RealmEmoji.objects.all(): |         author=Subquery( | ||||||
|         if realm_emoji.author_id is None: |  | ||||||
|             user_profile = ( |  | ||||||
|             UserProfile.objects.filter( |             UserProfile.objects.filter( | ||||||
|                     realm_id=realm_emoji.realm_id, is_active=True, role=ROLE_REALM_OWNER |                 realm=OuterRef("realm"), is_active=True, role=ROLE_REALM_OWNER | ||||||
|  |             ) | ||||||
|  |             .order_by("id")[:1] | ||||||
|  |             .values("pk") | ||||||
|         ) |         ) | ||||||
|                 .order_by("id") |  | ||||||
|                 .first() |  | ||||||
|     ) |     ) | ||||||
|             realm_emoji.author_id = user_profile.id |  | ||||||
|             realm_emoji_to_update.append(realm_emoji) |  | ||||||
|  |  | ||||||
|     RealmEmoji.objects.bulk_update(realm_emoji_to_update, ["author_id"]) |  | ||||||
|  |  | ||||||
|     # Previously, this also pushed `reupload_realm_emoji` events onto |     # Previously, this also pushed `reupload_realm_emoji` events onto | ||||||
|     # the `deferred_work` queue; however, |     # the `deferred_work` queue; however, | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user