diff options
author | Paul "LeoNerd" Evans <paul@matrix.org> | 2016-08-18 15:40:41 +0100 |
---|---|---|
committer | Paul "LeoNerd" Evans <paul@matrix.org> | 2016-08-18 15:40:41 +0100 |
commit | 80f4740c8f638e7d07b72d87fcb608435f3f9c15 (patch) | |
tree | 50bdb8dec51282e21d87e56cabf616a27eb5f2a1 /synapse/handlers | |
parent | Filter 3PU lookups by only ASes that declare knowledge of that protocol (diff) | |
download | synapse-80f4740c8f638e7d07b72d87fcb608435f3f9c15.tar.xz |
Scattergather the call out to ASes; validate received results
Diffstat (limited to '')
-rw-r--r-- | synapse/handlers/appservice.py | 41 |
1 files changed, 34 insertions, 7 deletions
diff --git a/synapse/handlers/appservice.py b/synapse/handlers/appservice.py index e0a6c9f19d..cd55f6b7f1 100644 --- a/synapse/handlers/appservice.py +++ b/synapse/handlers/appservice.py @@ -34,6 +34,26 @@ def log_failure(failure): ) ) +def _is_valid_3pu_result(r): + if not isinstance(r, dict): + return False + + for k in ("userid", "protocol"): + if k not in r: + return False + if not isinstance(r[k], str): + return False + + if "fields" not in r: + return False + fields = r["fields"] + if not isinstance(fields, dict): + return False + for k in fields.keys(): + if not isinstance(fields[k], str): + return False + + return True class ApplicationServicesHandler(object): @@ -150,16 +170,23 @@ class ApplicationServicesHandler(object): def query_3pu(self, protocol, fields): services = yield self._get_services_for_3pn(protocol) - # TODO(paul): scattergather - results = [] + deferreds = [] for service in services: - result = yield self.appservice_api.query_3pu( + deferreds.append(self.appservice_api.query_3pu( service, protocol, fields - ) - if result: - results.extend(result) + )) + + results = yield defer.DeferredList(deferreds, consumeErrors=True) + + ret = [] + for (success, result) in results: + if not success: + continue + if not isinstance(result, list): + continue + ret.extend(r for r in result if _is_valid_3pu_result(r)) - defer.returnValue(results) + defer.returnValue(ret) @defer.inlineCallbacks def _get_services_for_event(self, event): |