diff options
author | Erik Johnston <erik@matrix.org> | 2017-09-26 15:52:41 +0100 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2017-09-26 15:52:41 +0100 |
commit | 17b8e2bd02ad0abbd25103b637eb8490f3a53507 (patch) | |
tree | 889b3b1cbfc30181fe7c9e67e122d3c0f1cc5d03 /synapse/federation/transport/server.py | |
parent | Add unique index to group_rooms table (diff) | |
download | synapse-17b8e2bd02ad0abbd25103b637eb8490f3a53507.tar.xz |
Add remove room API
Diffstat (limited to 'synapse/federation/transport/server.py')
-rw-r--r-- | synapse/federation/transport/server.py | 14 |
1 files changed, 13 insertions, 1 deletions
diff --git a/synapse/federation/transport/server.py b/synapse/federation/transport/server.py index b5f07c50bf..c7565e0737 100644 --- a/synapse/federation/transport/server.py +++ b/synapse/federation/transport/server.py @@ -674,7 +674,7 @@ class FederationGroupsRoomsServlet(BaseFederationServlet): class FederationGroupsAddRoomsServlet(BaseFederationServlet): - """Add room to group + """Add/remove room from group """ PATH = "/groups/(?P<group_id>[^/]*)/room/(?<room_id>)$" @@ -690,6 +690,18 @@ class FederationGroupsAddRoomsServlet(BaseFederationServlet): defer.returnValue((200, new_content)) + @defer.inlineCallbacks + def on_DELETE(self, origin, content, query, group_id, room_id): + requester_user_id = parse_string_from_args(query, "requester_user_id") + if get_domain_from_id(requester_user_id) != origin: + raise SynapseError(403, "requester_user_id doesn't match origin") + + new_content = yield self.handler.remove_room_from_group( + group_id, requester_user_id, room_id, + ) + + defer.returnValue((200, new_content)) + class FederationGroupsUsersServlet(BaseFederationServlet): """Get the users in a group on behalf of a user |