diff options
author | Kegan Dougal <kegan@matrix.org> | 2014-08-27 10:33:01 +0100 |
---|---|---|
committer | Kegan Dougal <kegan@matrix.org> | 2014-08-27 10:33:01 +0100 |
commit | c65885e1668d4a241a04a7cb3b970a0d6833a5ad (patch) | |
tree | 10e823a6b6dccc7770be0de5de1922e09695a1eb /synapse/rest/events.py | |
parent | Modified /join/$identifier to support $identifier being a room ID in addition... (diff) | |
download | synapse-c65885e1668d4a241a04a7cb3b970a0d6833a5ad.tar.xz |
Added support for GET /events/$eventid with auth checks.
Diffstat (limited to 'synapse/rest/events.py')
-rw-r--r-- | synapse/rest/events.py | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/synapse/rest/events.py b/synapse/rest/events.py index ca2f6978e5..d89dfc193c 100644 --- a/synapse/rest/events.py +++ b/synapse/rest/events.py @@ -47,5 +47,22 @@ class EventStreamRestServlet(RestServlet): return (200, {}) +# TODO: Unit test gets, with and without auth, with different kinds of events. +class EventRestServlet(RestServlet): + PATTERN = client_path_pattern("/events/(?P<event_id>[^/]*)$") + + @defer.inlineCallbacks + def on_GET(self, request, event_id): + auth_user = yield self.auth.get_user_by_req(request) + handler = self.handlers.event_handler + event = yield handler.get_event(auth_user, event_id) + + if event: + defer.returnValue((200, event.get_dict())) + else: + defer.returnValue((404, "Event not found.")) + + def register_servlets(hs, http_server): EventStreamRestServlet(hs).register(http_server) + EventRestServlet(hs).register(http_server) |