diff options
author | Paul "LeoNerd" Evans <paul@matrix.org> | 2016-09-09 15:09:46 +0100 |
---|---|---|
committer | Paul "LeoNerd" Evans <paul@matrix.org> | 2016-09-09 15:11:31 +0100 |
commit | 776594f99dc082a9a933ec6db6955b56ecd1363b (patch) | |
tree | 0b8ca3d2ab718419ad7dd50cc4878fbbc05a2e46 /synapse/appservice | |
parent | Reject malformed 3PE query metadata results earlier in AS API handling code (diff) | |
download | synapse-776594f99dc082a9a933ec6db6955b56ecd1363b.tar.xz |
Log if rejecting 3PE query metadata result due to type check
Diffstat (limited to 'synapse/appservice')
-rw-r--r-- | synapse/appservice/api.py | 15 |
1 files changed, 11 insertions, 4 deletions
diff --git a/synapse/appservice/api.py b/synapse/appservice/api.py index afc64ed267..b0eb0c6d9d 100644 --- a/synapse/appservice/api.py +++ b/synapse/appservice/api.py @@ -32,6 +32,14 @@ HOUR_IN_MS = 60 * 60 * 1000 APP_SERVICE_PREFIX = "/_matrix/app/unstable" +def _is_valid_3pe_metadata(info): + if "instances" not in info: + return False + if not isinstance(info["instances"], list): + return False + return True + + def _is_valid_3pe_result(r, field): if not isinstance(r, dict): return False @@ -164,10 +172,9 @@ class ApplicationServiceApi(SimpleHttpClient): try: info = yield self.get_json(uri, {}) - # Ignore any result that doesn't contain an "instances" list - if "instances" not in info: - defer.returnValue(None) - if not isinstance(info["instances"], list): + if not _is_valid_3pe_metadata(info): + logger.warning("query_3pe_protocol to %s did not return a" + " valid result", uri) defer.returnValue(None) defer.returnValue(info) |