use std::time::{Duration, Instant};
use bitcoin::hashes::hex::ToHex;
-use bitcoin::secp256k1::{PublicKey, SecretKey};
+use bitcoin::secp256k1::PublicKey;
use lightning;
use lightning::ln::peer_handler::{
ErroringMessageHandler, IgnoringMessageHandler, MessageHandler, PeerManager,
};
use lightning::routing::gossip::NetworkGraph;
+use lightning::sign::KeysManager;
use tokio::sync::mpsc;
use crate::{config, TestLogger};
rand_hasher.write_u8(2);
random_data[0..8].copy_from_slice(&rand_hasher.finish().to_ne_bytes());
- let our_node_secret = SecretKey::from_slice(&key).unwrap();
+ let keys_manager = Arc::new(KeysManager::new(&key, 0xdeadbeef, 0xdeadbeef));
+
let router = Arc::new(GossipRouter::new(network_graph, persistence_sender.clone()));
let message_handler = MessageHandler {
chan_handler: ErroringMessageHandler::new(),
route_handler: Arc::clone(&router),
onion_message_handler: IgnoringMessageHandler {},
+ custom_message_handler: IgnoringMessageHandler {},
};
let peer_handler = Arc::new(PeerManager::new(
message_handler,
- our_node_secret,
0xdeadbeef,
&random_data,
TestLogger::new(),
- IgnoringMessageHandler {},
+ keys_manager,
));
+ router.set_pm(Arc::clone(&peer_handler));
+
+ let ph_timer = Arc::clone(&peer_handler);
+ tokio::spawn(async move {
+ let mut intvl = tokio::time::interval(Duration::from_secs(10));
+ loop {
+ intvl.tick().await;
+ ph_timer.timer_tick_occurred();
+ }
+ });
println!("Connecting to Lightning peers...");
let peers = config::ln_peers();
current_peer.1,
).await {
disconnection_future.await;
- } else {
- tokio::time::sleep(Duration::from_secs(10)).await;
}
+ tokio::time::sleep(Duration::from_secs(10)).await;
}
});
true