diff options
author | David Robertson <davidr@element.io> | 2021-11-12 19:56:00 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2021-11-12 19:56:00 +0000 |
commit | bea815cec82096efc15e75875d3b8372fcb4f28b (patch) | |
tree | bb857004acb0fb10a0665bf70f19e71aa45e894b /synapse/handlers | |
parent | Change display names/avatar URLs to None if they contain null bytes before st... (diff) | |
download | synapse-bea815cec82096efc15e75875d3b8372fcb4f28b.tar.xz |
Test room alias deletion (#11327)
* Prefer `HTTPStatus` over plain `int` This is an Opinion that no-one has seemed to object to yet. * `--disallow-untyped-defs` for `tests.rest.client.test_directory` * Improve synapse's annotations for deleting aliases * Test case for deleting a room alias * Changelog
Diffstat (limited to 'synapse/handlers')
-rw-r--r-- | synapse/handlers/directory.py | 6 |
1 files changed, 5 insertions, 1 deletions
diff --git a/synapse/handlers/directory.py b/synapse/handlers/directory.py index 8ca5f60b1c..7ee5c47fd9 100644 --- a/synapse/handlers/directory.py +++ b/synapse/handlers/directory.py @@ -204,6 +204,10 @@ class DirectoryHandler: ) room_id = await self._delete_association(room_alias) + if room_id is None: + # It's possible someone else deleted the association after the + # checks above, but before we did the deletion. + raise NotFoundError("Unknown room alias") try: await self._update_canonical_alias(requester, user_id, room_id, room_alias) @@ -225,7 +229,7 @@ class DirectoryHandler: ) await self._delete_association(room_alias) - async def _delete_association(self, room_alias: RoomAlias) -> str: + async def _delete_association(self, room_alias: RoomAlias) -> Optional[str]: if not self.hs.is_mine(room_alias): raise SynapseError(400, "Room alias must be local") |