summary refs log tree commit diff
path: root/synapse/handlers
diff options
context:
space:
mode:
authorKegan Dougal <kegan@matrix.org>2014-09-23 15:35:58 +0100
committerKegan Dougal <kegan@matrix.org>2014-09-23 15:35:58 +0100
commit0c4ae63ad52a0bbe6a7a0cc519686b57f655e254 (patch)
tree4846c6d2376172460d3c7c287c890247cc74fb8a /synapse/handlers
parentPartial fix of SYWEB-28: If members do not have last_active_ago, compare thei... (diff)
downloadsynapse-0c4ae63ad52a0bbe6a7a0cc519686b57f655e254.tar.xz
Implemented /rooms/$roomid/state API.
Diffstat (limited to 'synapse/handlers')
-rw-r--r--synapse/handlers/message.py16
1 files changed, 16 insertions, 0 deletions
diff --git a/synapse/handlers/message.py b/synapse/handlers/message.py
index 14fae689f2..317ef2c80c 100644
--- a/synapse/handlers/message.py
+++ b/synapse/handlers/message.py
@@ -233,6 +233,22 @@ class MessageHandler(BaseHandler):
         yield self._on_new_room_event(event, snapshot)
 
     @defer.inlineCallbacks
+    def get_state_events(self, user_id, room_id):
+        """Retrieve all state events for a given room.
+
+        Args:
+            user_id(str): The user requesting state events.
+            room_id(str): The room ID to get all state events from.
+        Returns:
+            A list of dicts representing state events. [{}, {}, {}]
+        """
+        yield self.auth.check_joined_room(room_id, user_id)
+
+        # TODO: This is duplicating logic from snapshot_all_rooms
+        current_state = yield self.store.get_current_state(room_id)
+        defer.returnValue([self.hs.serialize_event(c) for c in current_state])
+
+    @defer.inlineCallbacks
     def snapshot_all_rooms(self, user_id=None, pagin_config=None,
                            feedback=False):
         """Retrieve a snapshot of all rooms the user is invited or has joined.