lighthouse-pulse/lighthouse/sync/sync_future.rs

49 lines
1.2 KiB
Rust
Raw Normal View History

2018-09-09 14:36:00 +00:00
use super::tokio;
use super::futures::{ Future, Stream };
use super::futures::sync::mpsc::{
UnboundedReceiver,
UnboundedSender,
};
use super::network_libp2p::message::{
NetworkEvent,
OutgoingMessage,
};
use super::network::handle_network_event;
2018-09-14 05:52:49 +00:00
use std::sync::Arc;
use super::db::ClientDB;
2018-09-09 14:36:00 +00:00
use slog::Logger;
type NetworkSender = UnboundedSender<OutgoingMessage>;
type NetworkReceiver = UnboundedReceiver<NetworkEvent>;
type SyncSender = UnboundedSender<Vec<u8>>;
type SyncReceiver = UnboundedReceiver<Vec<u8>>;
/// Start a syncing tokio future.
///
2018-09-09 16:28:36 +00:00
/// Uses green-threading to process messages
/// from the network and the RPC and update
/// the state.
2018-09-09 14:36:00 +00:00
pub fn run_sync_future(
db: Arc<ClientDB>,
2018-09-09 14:36:00 +00:00
network_tx: NetworkSender,
network_rx: NetworkReceiver,
2018-09-21 22:17:31 +00:00
_sync_tx: &SyncSender,
_sync_rx: &SyncReceiver,
2018-09-09 16:28:36 +00:00
log: Logger)
{
2018-09-09 14:36:00 +00:00
let network_future = {
network_rx
.for_each(move |event| {
handle_network_event(
event,
2018-09-21 22:17:31 +00:00
&db.clone(),
&network_tx.clone(),
&log.clone())
2018-09-09 14:36:00 +00:00
})
.map_err(|_| panic!("rx failed"))
};
tokio::run(network_future);
}