diff options
author | Andrew Morgan <andrew@amorgan.xyz> | 2020-09-18 11:07:05 +0100 |
---|---|---|
committer | Andrew Morgan <andrew@amorgan.xyz> | 2020-09-18 12:07:16 +0100 |
commit | 3faa0974bea4f9a8b0d1e0e83ae7068e0937167d (patch) | |
tree | e8c0a09e9b7b336d29b078eb674427faafd02844 | |
parent | Intelligently select extremities used in backfill. (diff) | |
download | synapse-3faa0974bea4f9a8b0d1e0e83ae7068e0937167d.tar.xz |
Use _check_sigs_and_hash_and_fetch to validate backfill requests github/anoa/backfill_release anoa/backfill_release
I believe this method drops pdus (or at least returns None instead) which allows backfill to continue working even when an event has an invalid signature
-rw-r--r-- | synapse/federation/federation_client.py | 7 |
1 files changed, 2 insertions, 5 deletions
diff --git a/synapse/federation/federation_client.py b/synapse/federation/federation_client.py index a2e8d96ea2..e6388a2050 100644 --- a/synapse/federation/federation_client.py +++ b/synapse/federation/federation_client.py @@ -217,11 +217,8 @@ class FederationClient(FederationBase): for p in transaction_data["pdus"] ] - # FIXME: We should handle signature failures more gracefully. - pdus[:] = await make_deferred_yieldable( - defer.gatherResults( - self._check_sigs_and_hashes(room_version, pdus), consumeErrors=True, - ).addErrback(unwrapFirstError) + pdus[:] = await self._check_sigs_and_hash_and_fetch( + dest, pdus, outlier=True, room_version=room_version ) return pdus |