diff options
author | Kegan Dougal <kegan@matrix.org> | 2014-09-23 15:35:58 +0100 |
---|---|---|
committer | Kegan Dougal <kegan@matrix.org> | 2014-09-23 15:35:58 +0100 |
commit | 0c4ae63ad52a0bbe6a7a0cc519686b57f655e254 (patch) | |
tree | 4846c6d2376172460d3c7c287c890247cc74fb8a /synapse/handlers/message.py | |
parent | Partial fix of SYWEB-28: If members do not have last_active_ago, compare thei... (diff) | |
download | synapse-0c4ae63ad52a0bbe6a7a0cc519686b57f655e254.tar.xz |
Implemented /rooms/$roomid/state API.
Diffstat (limited to 'synapse/handlers/message.py')
-rw-r--r-- | synapse/handlers/message.py | 16 |
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. |