2019-03-30 08:32:32 +00:00
|
|
|
mod attestation;
|
2019-02-14 01:09:18 +00:00
|
|
|
mod beacon_block;
|
2019-03-22 02:37:24 +00:00
|
|
|
mod beacon_node;
|
2019-03-19 12:47:58 +00:00
|
|
|
pub mod config;
|
2019-02-14 01:09:18 +00:00
|
|
|
mod validator;
|
|
|
|
|
2019-03-30 08:32:32 +00:00
|
|
|
use self::attestation::AttestationServiceInstance;
|
2019-02-14 01:09:18 +00:00
|
|
|
use self::beacon_block::BeaconBlockServiceInstance;
|
2019-03-22 02:37:24 +00:00
|
|
|
use self::beacon_node::BeaconNodeServiceInstance;
|
2019-02-14 01:09:18 +00:00
|
|
|
use self::validator::ValidatorServiceInstance;
|
2019-05-30 08:35:27 +00:00
|
|
|
use beacon_chain::{BeaconChain, BeaconChainTypes};
|
2019-03-19 12:47:58 +00:00
|
|
|
pub use config::Config as RPCConfig;
|
2019-03-30 08:32:32 +00:00
|
|
|
use futures::Future;
|
|
|
|
use grpcio::{Environment, ServerBuilder};
|
2019-03-25 12:39:39 +00:00
|
|
|
use network::NetworkMessage;
|
2019-03-22 02:37:24 +00:00
|
|
|
use protos::services_grpc::{
|
2019-03-30 08:32:32 +00:00
|
|
|
create_attestation_service, create_beacon_block_service, create_beacon_node_service,
|
|
|
|
create_validator_service,
|
2019-03-22 02:37:24 +00:00
|
|
|
};
|
2019-03-22 05:46:52 +00:00
|
|
|
use slog::{info, o, warn};
|
2019-02-14 01:09:18 +00:00
|
|
|
use std::sync::Arc;
|
2019-03-22 05:46:52 +00:00
|
|
|
use tokio::runtime::TaskExecutor;
|
2019-02-14 01:09:18 +00:00
|
|
|
|
2019-05-25 10:51:15 +00:00
|
|
|
pub fn start_server<T: BeaconChainTypes + Clone + 'static>(
|
2019-03-22 02:37:24 +00:00
|
|
|
config: &RPCConfig,
|
2019-03-22 05:46:52 +00:00
|
|
|
executor: &TaskExecutor,
|
2019-03-25 11:00:11 +00:00
|
|
|
network_chan: crossbeam_channel::Sender<NetworkMessage>,
|
2019-05-25 10:51:15 +00:00
|
|
|
beacon_chain: Arc<BeaconChain<T>>,
|
2019-03-22 02:37:24 +00:00
|
|
|
log: &slog::Logger,
|
2019-06-13 16:21:09 +00:00
|
|
|
) -> exit_future::Signal {
|
2019-03-19 12:47:58 +00:00
|
|
|
let log = log.new(o!("Service"=>"RPC"));
|
2019-02-14 01:09:18 +00:00
|
|
|
let env = Arc::new(Environment::new(1));
|
|
|
|
|
2019-03-22 05:46:52 +00:00
|
|
|
// build a channel to kill the rpc server
|
|
|
|
let (rpc_exit_signal, rpc_exit) = exit_future::signal();
|
2019-03-22 02:37:24 +00:00
|
|
|
|
2019-03-22 05:46:52 +00:00
|
|
|
// build the individual rpc services
|
2019-03-22 02:37:24 +00:00
|
|
|
let beacon_node_service = {
|
|
|
|
let instance = BeaconNodeServiceInstance {
|
|
|
|
chain: beacon_chain.clone(),
|
|
|
|
log: log.clone(),
|
|
|
|
};
|
|
|
|
create_beacon_node_service(instance)
|
|
|
|
};
|
|
|
|
|
2019-02-14 01:09:18 +00:00
|
|
|
let beacon_block_service = {
|
2019-03-25 11:00:11 +00:00
|
|
|
let instance = BeaconBlockServiceInstance {
|
2019-03-26 04:26:05 +00:00
|
|
|
chain: beacon_chain.clone(),
|
2019-06-04 06:33:35 +00:00
|
|
|
network_chan: network_chan.clone(),
|
2019-03-25 12:39:39 +00:00
|
|
|
log: log.clone(),
|
|
|
|
};
|
2019-02-14 01:09:18 +00:00
|
|
|
create_beacon_block_service(instance)
|
|
|
|
};
|
|
|
|
let validator_service = {
|
2019-03-27 10:08:28 +00:00
|
|
|
let instance = ValidatorServiceInstance {
|
|
|
|
chain: beacon_chain.clone(),
|
|
|
|
log: log.clone(),
|
|
|
|
};
|
2019-02-14 01:09:18 +00:00
|
|
|
create_validator_service(instance)
|
|
|
|
};
|
2019-03-30 08:32:32 +00:00
|
|
|
let attestation_service = {
|
|
|
|
let instance = AttestationServiceInstance {
|
2019-04-03 00:20:13 +00:00
|
|
|
network_chan,
|
2019-03-30 08:32:32 +00:00
|
|
|
chain: beacon_chain.clone(),
|
|
|
|
log: log.clone(),
|
|
|
|
};
|
|
|
|
create_attestation_service(instance)
|
|
|
|
};
|
2019-02-14 01:09:18 +00:00
|
|
|
|
|
|
|
let mut server = ServerBuilder::new(env)
|
|
|
|
.register_service(beacon_block_service)
|
|
|
|
.register_service(validator_service)
|
2019-03-22 05:56:54 +00:00
|
|
|
.register_service(beacon_node_service)
|
2019-03-30 08:32:32 +00:00
|
|
|
.register_service(attestation_service)
|
2019-03-19 12:47:58 +00:00
|
|
|
.bind(config.listen_address.to_string(), config.port)
|
2019-02-14 01:09:18 +00:00
|
|
|
.build()
|
|
|
|
.unwrap();
|
2019-03-22 05:46:52 +00:00
|
|
|
|
|
|
|
let spawn_rpc = {
|
|
|
|
server.start();
|
|
|
|
for &(ref host, port) in server.bind_addrs() {
|
|
|
|
info!(log, "gRPC listening on {}:{}", host, port);
|
|
|
|
}
|
|
|
|
rpc_exit.and_then(move |_| {
|
|
|
|
info!(log, "RPC Server shutting down");
|
|
|
|
server
|
|
|
|
.shutdown()
|
|
|
|
.wait()
|
|
|
|
.map(|_| ())
|
|
|
|
.map_err(|e| warn!(log, "RPC server failed to shutdown: {:?}", e))?;
|
|
|
|
Ok(())
|
|
|
|
})
|
|
|
|
};
|
|
|
|
executor.spawn(spawn_rpc);
|
|
|
|
rpc_exit_signal
|
2019-02-14 01:09:18 +00:00
|
|
|
}
|