Skip to content

Commit 14b5600

Browse files
anoadragon453phil-flex
authored andcommitted
Transfer alias mappings when joining an upgraded room (matrix-org#6946)
1 parent 29edf71 commit 14b5600

File tree

3 files changed

+27
-3
lines changed

3 files changed

+27
-3
lines changed

changelog.d/6946.bugfix

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1 @@
1+
Transfer alias mappings on room upgrade.

synapse/handlers/room_member.py

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -519,6 +519,9 @@ def transfer_room_state_on_room_upgrade(self, old_room_id, room_id):
519519
yield self.store.set_room_is_public(old_room_id, False)
520520
yield self.store.set_room_is_public(room_id, True)
521521

522+
# Transfer alias mappings in the room directory
523+
yield self.store.update_aliases_for_room(old_room_id, room_id)
524+
522525
# Check if any groups we own contain the predecessor room
523526
local_group_ids = yield self.store.get_local_groups_for_room(old_room_id)
524527
for group_id in local_group_ids:

synapse/storage/data_stores/main/directory.py

Lines changed: 23 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@
1414
# limitations under the License.
1515

1616
from collections import namedtuple
17+
from typing import Optional
1718

1819
from twisted.internet import defer
1920

@@ -159,10 +160,29 @@ def _delete_room_alias_txn(self, txn, room_alias):
159160

160161
return room_id
161162

162-
def update_aliases_for_room(self, old_room_id, new_room_id, creator):
163+
def update_aliases_for_room(
164+
self, old_room_id: str, new_room_id: str, creator: Optional[str] = None,
165+
):
166+
"""Repoint all of the aliases for a given room, to a different room.
167+
168+
Args:
169+
old_room_id:
170+
new_room_id:
171+
creator: The user to record as the creator of the new mapping.
172+
If None, the creator will be left unchanged.
173+
"""
174+
163175
def _update_aliases_for_room_txn(txn):
164-
sql = "UPDATE room_aliases SET room_id = ?, creator = ? WHERE room_id = ?"
165-
txn.execute(sql, (new_room_id, creator, old_room_id))
176+
update_creator_sql = ""
177+
sql_params = (new_room_id, old_room_id)
178+
if creator:
179+
update_creator_sql = ", creator = ?"
180+
sql_params = (new_room_id, creator, old_room_id)
181+
182+
sql = "UPDATE room_aliases SET room_id = ? %s WHERE room_id = ?" % (
183+
update_creator_sql,
184+
)
185+
txn.execute(sql, sql_params)
166186
self._invalidate_cache_and_stream(
167187
txn, self.get_aliases_for_room, (old_room_id,)
168188
)

0 commit comments

Comments
 (0)