2018-07-28 00:02:45 +00:00
|
|
|
#[macro_use]
|
|
|
|
extern crate slog;
|
|
|
|
extern crate slog_term;
|
|
|
|
extern crate slog_async;
|
|
|
|
extern crate clap;
|
|
|
|
extern crate libp2p_peerstore;
|
|
|
|
|
|
|
|
pub mod p2p;
|
|
|
|
pub mod pubkeystore;
|
|
|
|
pub mod state;
|
|
|
|
pub mod utils;
|
|
|
|
|
2018-08-01 00:27:05 +00:00
|
|
|
use std::path::PathBuf;
|
|
|
|
|
2018-07-28 00:02:45 +00:00
|
|
|
use slog::Drain;
|
2018-08-01 00:27:05 +00:00
|
|
|
use clap::{ Arg, App, SubCommand};
|
2018-07-29 05:06:42 +00:00
|
|
|
use p2p::config::NetworkConfig;
|
|
|
|
use p2p::floodsub;
|
|
|
|
use p2p::state::NetworkState;
|
2018-07-28 00:02:45 +00:00
|
|
|
|
|
|
|
fn main() {
|
|
|
|
let decorator = slog_term::TermDecorator::new().build();
|
|
|
|
let drain = slog_term::CompactFormat::new(decorator).build().fuse();
|
|
|
|
let drain = slog_async::Async::new(drain).build().fuse();
|
|
|
|
let log = slog::Logger::root(drain, o!());
|
|
|
|
|
|
|
|
let matches = App::new("Lighthouse")
|
|
|
|
.version("0.0.1")
|
2018-08-01 00:27:05 +00:00
|
|
|
.author("Sigma Prime <paul@sigmaprime.io>")
|
2018-07-28 00:02:45 +00:00
|
|
|
.about("Eth 2.0 Client")
|
2018-08-01 00:27:05 +00:00
|
|
|
.arg(Arg::with_name("datadir")
|
|
|
|
.value_name("DIR")
|
|
|
|
.help("Data directory for keys and databases."))
|
2018-07-28 00:02:45 +00:00
|
|
|
.subcommand(SubCommand::with_name("generate-keys"))
|
|
|
|
.about("Generates a new set of random keys for p2p dev.")
|
|
|
|
.get_matches();
|
|
|
|
|
2018-08-01 00:27:05 +00:00
|
|
|
let mut config = NetworkConfig::default();
|
|
|
|
if let Some(dir) = matches.value_of("datadir") {
|
|
|
|
config.data_dir = PathBuf::from(dir.to_string());
|
|
|
|
}
|
|
|
|
info!(log, ""; "data_dir" => &config.data_dir.to_str());
|
2018-07-28 00:02:45 +00:00
|
|
|
if let Some(_) = matches.subcommand_matches("generate-keys") {
|
2018-07-29 05:06:42 +00:00
|
|
|
// keys::generate_keys(&log).expect("Failed to generate keys");
|
2018-07-28 00:02:45 +00:00
|
|
|
} else {
|
2018-08-01 00:27:05 +00:00
|
|
|
let state = NetworkState::new(config, &log).expect("setup failed");
|
2018-07-29 05:06:42 +00:00
|
|
|
floodsub::listen(state, &log);
|
2018-07-28 00:02:45 +00:00
|
|
|
}
|
|
|
|
info!(log, "Exiting.");
|
|
|
|
}
|