mirror of
				https://github.com/zulip/zulip.git
				synced 2025-10-31 03:53:50 +00:00 
			
		
		
		
	I encountered at least one scenario where the previous logic would fail due to migration state confusion, but this could also be a bit faster.
		
			
				
	
	
		
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			59 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| import hashlib
 | |
| 
 | |
| from django.db import migrations
 | |
| from django.db.backends.base.schema import BaseDatabaseSchemaEditor
 | |
| from django.db.migrations.state import StateApps
 | |
| 
 | |
| 
 | |
| def remove_prefix_from_archived_streams(
 | |
|     apps: StateApps, schema_editor: BaseDatabaseSchemaEditor
 | |
| ) -> None:
 | |
|     Stream = apps.get_model("zerver", "Stream")
 | |
|     archived_streams = Stream.objects.filter(deactivated=True)
 | |
| 
 | |
|     for archived_stream in archived_streams:
 | |
|         old_prefix = "!DEACTIVATED:"
 | |
|         streamID = str(archived_stream.id)
 | |
|         stream_id_hash_object = hashlib.sha512(streamID.encode())
 | |
|         hashed_stream_id = stream_id_hash_object.hexdigest()[0:7]
 | |
|         prefix = hashed_stream_id + old_prefix
 | |
|         prefix_length = len(prefix)
 | |
|         old_name = archived_stream.name
 | |
|         new_name = old_name
 | |
|         if old_name.startswith(prefix):
 | |
|             new_name = old_name[prefix_length:]
 | |
| 
 | |
|         # Check for archived streams before commit 1b6f68b.
 | |
|         elif old_prefix in old_name:
 | |
|             prefix_end_index = old_name.find(old_prefix) + len(old_prefix)
 | |
|             new_name = old_name[prefix_end_index:]
 | |
| 
 | |
|         else:
 | |
|             continue
 | |
| 
 | |
|         # Check if there's an active stream or another archived stream with the new name
 | |
|         if not Stream.objects.filter(
 | |
|             realm_id=archived_stream.realm_id, name__iexact=new_name
 | |
|         ).exists():
 | |
|             archived_stream.name = new_name
 | |
|             archived_stream.save(update_fields=["name"])
 | |
| 
 | |
| 
 | |
| class Migration(migrations.Migration):
 | |
|     atomic = False
 | |
| 
 | |
|     dependencies = [
 | |
|         (
 | |
|             "zerver",
 | |
|             "0616_userprofile_can_change_user_emails",
 | |
|         ),
 | |
|     ]
 | |
| 
 | |
|     operations = [
 | |
|         migrations.RunPython(
 | |
|             remove_prefix_from_archived_streams,
 | |
|             reverse_code=migrations.RunPython.noop,
 | |
|             elidable=True,
 | |
|         ),
 | |
|     ]
 |