diff options
author | Erik Johnston <erik@matrix.org> | 2016-12-08 11:39:03 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2016-12-08 11:39:03 +0000 |
commit | de796f27e65797a791787f4e23a09f52cc2e43ee (patch) | |
tree | cedd370da9e5513e0e319a1c938cc214be799f6d /synapse | |
parent | Merge pull request #1672 from williamleuschner/develop (diff) | |
download | synapse-de796f27e65797a791787f4e23a09f52cc2e43ee.tar.xz |
Add joined_rooms servlet
Diffstat (limited to 'synapse')
-rw-r--r-- | synapse/rest/client/v1/room.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/synapse/rest/client/v1/room.py b/synapse/rest/client/v1/room.py index 3fb1f2deb3..3040f94867 100644 --- a/synapse/rest/client/v1/room.py +++ b/synapse/rest/client/v1/room.py @@ -692,6 +692,22 @@ class SearchRestServlet(ClientV1RestServlet): defer.returnValue((200, results)) +class JoinedRoomsRestServlet(ClientV1RestServlet): + PATTERNS = client_path_patterns("/joined_rooms$") + + def __init__(self, hs): + super(JoinedRoomsRestServlet, self).__init__(hs) + self.store = hs.get_datastore() + + @defer.inlineCallbacks + def on_GET(self, request): + requester = yield self.auth.get_user_by_req(request, allow_guest=True) + + rooms = yield self.store.get_rooms_for_user(requester.user.to_string()) + room_ids = set(r.room_id for r in rooms) # Ensure they're unique. + defer.returnValue((200, {"joined_rooms": list(room_ids)})) + + def register_txn_path(servlet, regex_string, http_server, with_get=False): """Registers a transaction-based path. @@ -738,4 +754,5 @@ def register_servlets(hs, http_server): RoomRedactEventRestServlet(hs).register(http_server) RoomTypingRestServlet(hs).register(http_server) SearchRestServlet(hs).register(http_server) + JoinedRoomsRestServlet(hs).register(http_server) RoomEventContext(hs).register(http_server) |