diff options
author | Erik Johnston <erikj@jki.re> | 2016-08-04 14:38:59 +0100 |
---|---|---|
committer | GitHub <noreply@github.com> | 2016-08-04 14:38:59 +0100 |
commit | 1b5436ad782218bb7c31958ff5939a1458d39b4d (patch) | |
tree | 966b68430857e3fe505f4dcc285bb07c850963c3 /synapse/federation/transport/client.py | |
parent | Merge pull request #982 from matrix-org/erikj/fix_port_script (diff) | |
parent | Fix typos. (diff) | |
download | synapse-1b5436ad782218bb7c31958ff5939a1458d39b4d.tar.xz |
Merge pull request #979 from matrix-org/erikj/state_ids_api
Add /state_ids federation API
Diffstat (limited to 'synapse/federation/transport/client.py')
-rw-r--r-- | synapse/federation/transport/client.py | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/synapse/federation/transport/client.py b/synapse/federation/transport/client.py index ebb698e278..3d088e43cb 100644 --- a/synapse/federation/transport/client.py +++ b/synapse/federation/transport/client.py @@ -55,6 +55,28 @@ class TransportLayerClient(object): ) @log_function + def get_room_state_ids(self, destination, room_id, event_id): + """ Requests all state for a given room from the given server at the + given event. Returns the state's event_id's + + Args: + destination (str): The host name of the remote home server we want + to get the state from. + context (str): The name of the context we want the state of + event_id (str): The event we want the context at. + + Returns: + Deferred: Results in a dict received from the remote homeserver. + """ + logger.debug("get_room_state_ids dest=%s, room=%s", + destination, room_id) + + path = PREFIX + "/state_ids/%s/" % room_id + return self.client.get_json( + destination, path=path, args={"event_id": event_id}, + ) + + @log_function def get_event(self, destination, event_id, timeout=None): """ Requests the pdu with give id and origin from the given server. |