diff options
author | Richard van der Hoff <1389908+richvdh@users.noreply.github.com> | 2020-02-18 16:23:25 +0000 |
---|---|---|
committer | GitHub <noreply@github.com> | 2020-02-18 16:23:25 +0000 |
commit | adfaea8c698a38ffe14ac682a946abc9f8152635 (patch) | |
tree | f390c7a0b92912f5b0c86bdbab563a60362fb3f3 /synapse/handlers | |
parent | Merge pull request #6872 from matrix-org/rav/dictproperty (diff) | |
download | synapse-adfaea8c698a38ffe14ac682a946abc9f8152635.tar.xz |
Implement GET /_matrix/client/r0/rooms/{roomId}/aliases (#6939)
per matrix-org/matrix-doc#2432
Diffstat (limited to 'synapse/handlers')
-rw-r--r-- | synapse/handlers/directory.py | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/synapse/handlers/directory.py b/synapse/handlers/directory.py index f718388884..3f8c792149 100644 --- a/synapse/handlers/directory.py +++ b/synapse/handlers/directory.py @@ -16,6 +16,7 @@ import logging import string +from typing import List from twisted.internet import defer @@ -28,7 +29,7 @@ from synapse.api.errors import ( StoreError, SynapseError, ) -from synapse.types import RoomAlias, UserID, get_domain_from_id +from synapse.types import Requester, RoomAlias, UserID, get_domain_from_id from ._base import BaseHandler @@ -452,3 +453,17 @@ class DirectoryHandler(BaseHandler): yield self.store.set_room_is_public_appservice( room_id, appservice_id, network_id, visibility == "public" ) + + async def get_aliases_for_room( + self, requester: Requester, room_id: str + ) -> List[str]: + """ + Get a list of the aliases that currently point to this room on this server + """ + # allow access to server admins and current members of the room + is_admin = await self.auth.is_server_admin(requester.user) + if not is_admin: + await self.auth.check_joined_room(room_id, requester.user.to_string()) + + aliases = await self.store.get_aliases_for_room(room_id) + return aliases |