diff --git a/src/event.rs b/src/event.rs index f5d5be77d..557e3125c 100644 --- a/src/event.rs +++ b/src/event.rs @@ -1,8 +1,11 @@ use crate::types::{DynStore, Sweeper, Wallet}; + use crate::{ hex_utils, ChannelManager, Config, Error, NetworkGraph, PeerInfo, PeerStore, UserChannelId, }; +use crate::connection::ConnectionManager; + use crate::payment::payment_store::{ PaymentDetails, PaymentDetailsUpdate, PaymentDirection, PaymentStatus, PaymentStore, }; @@ -295,6 +298,7 @@ where event_queue: Arc>, wallet: Arc, channel_manager: Arc, + connection_manager: Arc>, output_sweeper: Arc, network_graph: Arc, payment_store: Arc>, @@ -310,14 +314,16 @@ where { pub fn new( event_queue: Arc>, wallet: Arc, channel_manager: Arc, - output_sweeper: Arc, network_graph: Arc, - payment_store: Arc>, peer_store: Arc>, - runtime: Arc>>, logger: L, config: Arc, + connection_manager: Arc>, output_sweeper: Arc, + network_graph: Arc, payment_store: Arc>, + peer_store: Arc>, runtime: Arc>>, + logger: L, config: Arc, ) -> Self { Self { event_queue, wallet, channel_manager, + connection_manager, output_sweeper, network_graph, payment_store, @@ -872,7 +878,34 @@ where LdkEvent::HTLCIntercepted { .. } => {}, LdkEvent::BumpTransaction(_) => {}, LdkEvent::InvoiceRequestFailed { .. } => {}, - LdkEvent::ConnectionNeeded { .. } => {}, + LdkEvent::ConnectionNeeded { node_id, addresses } => { + let runtime_lock = self.runtime.read().unwrap(); + debug_assert!(runtime_lock.is_some()); + + if let Some(runtime) = runtime_lock.as_ref() { + let spawn_logger = self.logger.clone(); + let spawn_cm = Arc::clone(&self.connection_manager); + let addresses = addresses.clone(); + runtime.spawn(async move { + for addr in &addresses { + match spawn_cm.connect_peer_if_necessary(node_id, addr.clone()).await { + Ok(()) => { + return; + }, + Err(e) => { + log_error!( + spawn_logger, + "Failed to establish connection to peer {}@{}: {}", + node_id, + addr, + e + ); + }, + } + } + }); + } + }, } } } diff --git a/src/lib.rs b/src/lib.rs index cacaaa7a1..a45ef4b7d 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -578,6 +578,7 @@ impl Node { Arc::clone(&self.event_queue), Arc::clone(&self.wallet), Arc::clone(&self.channel_manager), + Arc::clone(&self.connection_manager), Arc::clone(&self.output_sweeper), Arc::clone(&self.network_graph), Arc::clone(&self.payment_store),