X-Git-Url: http://git.bitcoin.ninja/index.cgi?a=blobdiff_plain;f=lightning%2Fsrc%2Fonion_message%2Fmessenger.rs;h=7743270e257b039301b4eaa9cdab681e242590b3;hb=c80d9a74b5437dd7c82fab40806adeb995219fc2;hp=c0db6096b995744c8dac86a90031eb8982ece9a6;hpb=97049daac211b65cf6113960059fedaad12397b4;p=rust-lightning diff --git a/lightning/src/onion_message/messenger.rs b/lightning/src/onion_message/messenger.rs index c0db6096..7743270e 100644 --- a/lightning/src/onion_message/messenger.rs +++ b/lightning/src/onion_message/messenger.rs @@ -350,16 +350,16 @@ where const MIN_PEER_CHANNELS: usize = 3; let network_graph = self.network_graph.deref().read_only(); - let paths = peers.into_iter() + let paths = peers.iter() // Limit to peers with announced channels .filter(|pubkey| network_graph - .node(&NodeId::from_pubkey(&pubkey)) + .node(&NodeId::from_pubkey(pubkey)) .map(|info| &info.channels[..]) .map(|channels| channels.len() >= MIN_PEER_CHANNELS) .unwrap_or(false) ) - .map(|pubkey| vec![pubkey, recipient]) + .map(|pubkey| vec![*pubkey, recipient]) .map(|node_pks| BlindedPath::new_for_message(&node_pks, entropy_source, secp_ctx)) .take(MAX_PATHS) .collect::, _>>(); @@ -367,8 +367,12 @@ where match paths { Ok(paths) if !paths.is_empty() => Ok(paths), _ => { - BlindedPath::one_hop_for_message(recipient, entropy_source, secp_ctx) - .map(|path| vec![path]) + if network_graph.nodes().contains_key(&NodeId::from_pubkey(&recipient)) { + BlindedPath::one_hop_for_message(recipient, entropy_source, secp_ctx) + .map(|path| vec![path]) + } else { + Err(()) + } }, } }