diff options
author | Andrew Morgan <andrew@amorgan.xyz> | 2019-01-30 16:33:51 +0000 |
---|---|---|
committer | Andrew Morgan <andrew@amorgan.xyz> | 2019-01-30 16:33:51 +0000 |
commit | d621c5562ea6bce4fd8282da642b3123ae016d94 (patch) | |
tree | 0a833afa853d92655a869cc0cd4cdf9724b3b615 | |
parent | Merge pull request #4472 from matrix-org/neilj/room_capabilities (diff) | |
download | synapse-d621c5562ea6bce4fd8282da642b3123ae016d94.tar.xz |
Copy over non-federatable trait on room upgrade
-rw-r--r-- | synapse/handlers/room.py | 14 |
1 files changed, 14 insertions, 0 deletions
diff --git a/synapse/handlers/room.py b/synapse/handlers/room.py index 13ba9291b0..c04ba3a0c5 100644 --- a/synapse/handlers/room.py +++ b/synapse/handlers/room.py @@ -263,6 +263,20 @@ class RoomCreationHandler(BaseHandler): } } + # Check if old room was non-federatable + + # Get old room's create event + old_room_create_event_ids = yield self.store.get_filtered_current_state_ids( + old_room_id, StateFilter.from_types(((EventTypes.Create, ""),)), + ) + old_room_create_event_dict = yield self.store.get_events(old_room_create_event_ids.values()) + old_room_create_event = list(old_room_create_event_dict.values())[0] + + # Check if the create event specified a non-federatable room + if old_room_create_event.content.get("m.federate", True) == False: + # If so, mark the new room as non-federatable as well + creation_content["m.federate"] = False + initial_state = dict() # Replicate relevant room events |