diff options
author | Andrew Morgan <andrew@amorgan.xyz> | 2020-04-17 11:36:08 +0100 |
---|---|---|
committer | Andrew Morgan <andrew@amorgan.xyz> | 2020-04-17 11:36:08 +0100 |
commit | 2c881bf8a4d33b1e3da08e2690d5f12be1abee2d (patch) | |
tree | 0c0f95e310a4d9e8c50695c5082f37416b6b8981 | |
parent | Fix log statements, docstrings (diff) | |
download | synapse-2c881bf8a4d33b1e3da08e2690d5f12be1abee2d.tar.xz |
Remove extraneous items from remote query try/except
-rw-r--r-- | synapse/handlers/e2e_keys.py | 24 |
1 files changed, 14 insertions, 10 deletions
diff --git a/synapse/handlers/e2e_keys.py b/synapse/handlers/e2e_keys.py index 6094c6e259..863898cdf4 100644 --- a/synapse/handlers/e2e_keys.py +++ b/synapse/handlers/e2e_keys.py @@ -989,6 +989,7 @@ class E2eKeysHandler(object): user_id, desired_key_type, from_user_id ) + # If we still can't find the key, and we're looking for keys of another user, # then attempt to fetch the missing key from the remote user's server. # @@ -996,19 +997,30 @@ class E2eKeysHandler(object): # cross-sign a remote user, but does not share any rooms with them yet. # Thus, we would not have their key list yet. We fetch the key here and # store it just in case. + supported_remote_key_types = ["master", "self_signing"] if ( key is None and not self.is_mine(user) # We only get "master" and "self_signing" keys from remote servers - and desired_key_type in ["master", "self_signing"] + and desired_key_type in supported_remote_key_types ): + remote_result = None try: remote_result = yield self.federation.query_user_devices( user.domain, user_id ) + except Exception as e: + logger.warning( + "Unable to query %s for cross-signing keys of user %s: %s %s", + user.domain, + user_id, + type(e), + e, + ) + if remote_result is not None: # Process each of the retrieved cross-signing keys - for key_type in ["master", "self_signing"]: + for key_type in supported_remote_key_types: key_content = remote_result.get(key_type + "_key") if not key_content: continue @@ -1022,14 +1034,6 @@ class E2eKeysHandler(object): yield self.store.set_e2e_cross_signing_key( user_id, key_type, key_content ) - except Exception as e: - logger.warning( - "Unable to query %s for cross-signing keys of user %s: %s %s", - user.domain, - user_id, - type(e), - e, - ) if key is None: logger.debug("No %s key found for %s", desired_key_type, user_id) |