summary refs log tree commit diff
path: root/synapse/rest
diff options
context:
space:
mode:
authorKegan Dougal <kegan@matrix.org>2014-08-27 10:33:01 +0100
committerKegan Dougal <kegan@matrix.org>2014-08-27 10:33:01 +0100
commitc65885e1668d4a241a04a7cb3b970a0d6833a5ad (patch)
tree10e823a6b6dccc7770be0de5de1922e09695a1eb /synapse/rest
parentModified /join/$identifier to support $identifier being a room ID in addition... (diff)
downloadsynapse-c65885e1668d4a241a04a7cb3b970a0d6833a5ad.tar.xz
Added support for GET /events/$eventid with auth checks.
Diffstat (limited to 'synapse/rest')
-rw-r--r--synapse/rest/events.py17
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)