From c335a4d46bcb86ebf7d358bd1b2c737f3e40f4ad Mon Sep 17 00:00:00 2001 From: Jimmy Chen Date: Mon, 3 Jun 2024 12:51:39 +1000 Subject: [PATCH] Allow all RPC messages on disconnect (#5876) Squashed commit of the following: commit 6d42ebcc19504691d749ef588744e8d22f68448f Author: Age Manning Date: Fri May 31 20:21:26 2024 +1000 Permit rpc messages on disconnect --- .../lighthouse_network/src/service/mod.rs | 31 +++++++------------ 1 file changed, 11 insertions(+), 20 deletions(-) diff --git a/beacon_node/lighthouse_network/src/service/mod.rs b/beacon_node/lighthouse_network/src/service/mod.rs index 3870fb6572d..1ed8df64c51 100644 --- a/beacon_node/lighthouse_network/src/service/mod.rs +++ b/beacon_node/lighthouse_network/src/service/mod.rs @@ -1389,26 +1389,17 @@ impl Network { ) -> Option> { let peer_id = event.peer_id; - if !self.peer_manager().is_connected(&peer_id) { - // Sync expects a RPCError::Disconnected to drop associated lookups with this peer. - // Silencing this event breaks the API contract with RPC where every request ends with - // - A stream termination event, or - // - An RPCError event - return if let HandlerEvent::Err(HandlerErr::Outbound { - id: RequestId::Application(id), - error, - .. - }) = event.event - { - Some(NetworkEvent::RPCFailed { peer_id, id, error }) - } else { - debug!( - self.log, - "Ignoring rpc message of disconnecting peer"; - event - ); - None - }; + if !self.peer_manager().is_connected(&peer_id) + // Do not permit Inbound events from peers that are being disconnected + && matches!(event.event, HandlerEvent::Err(HandlerErr::Inbound { .. })) + && matches!(event.event, HandlerEvent::Ok(RPCReceived::Request(..))) + { + debug!( + self.log, + "Ignoring rpc message of disconnecting peer"; + event + ); + return None; } let handler_id = event.conn_id;