diff options
author | Erik Johnston <erik@matrix.org> | 2015-01-29 16:50:23 +0000 |
---|---|---|
committer | Erik Johnston <erik@matrix.org> | 2015-01-29 16:52:33 +0000 |
commit | 78015948a7febb18e000651f72f8f58830a55b93 (patch) | |
tree | 42aac1eb30b723f21074bb814f33d8713008725a /synapse/federation/transport/server.py | |
parent | Make post_json(...) actually send data. (diff) | |
download | synapse-78015948a7febb18e000651f72f8f58830a55b93.tar.xz |
Initial implementation of auth conflict resolution
Diffstat (limited to 'synapse/federation/transport/server.py')
-rw-r--r-- | synapse/federation/transport/server.py | 21 |
1 files changed, 20 insertions, 1 deletions
diff --git a/synapse/federation/transport/server.py b/synapse/federation/transport/server.py index a380a6910b..9c9f8d525b 100644 --- a/synapse/federation/transport/server.py +++ b/synapse/federation/transport/server.py @@ -42,7 +42,7 @@ class TransportLayerServer(object): content = None origin = None - if request.method == "PUT": + if request.method in ["PUT", "POST"]: # TODO: Handle other method types? other content types? try: content_bytes = request.content.read() @@ -234,6 +234,16 @@ class TransportLayerServer(object): ) ) ) + self.server.register_path( + "POST", + re.compile("^" + PREFIX + "/query_auth/([^/]*)/([^/]*)$"), + self._with_authentication( + lambda origin, content, query, context, event_id: + self._on_query_auth_request( + origin, content, event_id, + ) + ) + ) @defer.inlineCallbacks @log_function @@ -325,3 +335,12 @@ class TransportLayerServer(object): ) defer.returnValue((200, content)) + + @defer.inlineCallbacks + @log_function + def _on_query_auth_request(self, origin, content, event_id): + new_content = yield self.request_handler.on_query_auth_request( + origin, content, event_id + ) + + defer.returnValue((200, new_content)) |