From f09e25c81316f393884217422b8a26f83bff389c Mon Sep 17 00:00:00 2001 From: Alexandru Vasile Date: Thu, 21 Nov 2024 12:59:45 +0200 Subject: [PATCH] network/types: Ensure peerID functionality Signed-off-by: Alexandru Vasile --- substrate/client/network/types/src/multiaddr.rs | 17 +++++++++++++++++ 1 file changed, 17 insertions(+) diff --git a/substrate/client/network/types/src/multiaddr.rs b/substrate/client/network/types/src/multiaddr.rs index 6121db908d42..e86da94f22ee 100644 --- a/substrate/client/network/types/src/multiaddr.rs +++ b/substrate/client/network/types/src/multiaddr.rs @@ -112,6 +112,23 @@ impl Multiaddr { Ok(()) } + + /// Ensure the peer ID is present in the multiaddress. + /// + /// Returns None when the peer ID of the address is different from the local peer ID. + pub fn ensure_peer_id(self, local_peer_id: PeerId) -> Option { + if let Some(Protocol::P2p(peer_id)) = self.iter().last() { + // Invalid address if the reported peer ID is not the local peer ID. + if peer_id != *local_peer_id.as_ref() { + return None + } + + return Some(self) + } + + // Ensure the address contains the local peer ID. + Some(self.with(Protocol::P2p(local_peer_id.into()))) + } } impl Display for Multiaddr {