fix: Lookup the genesis hash based on the network

This commit is contained in:
teor 2020-07-22 12:22:43 +10:00 committed by Deirdre Connolly
parent 41225660fb
commit c95c825707
3 changed files with 25 additions and 28 deletions

View File

@ -1,6 +1,7 @@
//! `connect` subcommand - test stub for talking to zcashd //! `connect` subcommand - test stub for talking to zcashd
use crate::{components::tokio::TokioComponent, prelude::*}; use crate::{components::tokio::TokioComponent, prelude::*};
use abscissa_core::{Command, Options, Runnable}; use abscissa_core::{Command, Options, Runnable};
use color_eyre::eyre::{eyre, Report, WrapErr}; use color_eyre::eyre::{eyre, Report, WrapErr};
use futures::{ use futures::{
@ -9,13 +10,9 @@ use futures::{
}; };
use std::collections::BTreeSet; use std::collections::BTreeSet;
use tower::{buffer::Buffer, service_fn, Service, ServiceExt}; use tower::{buffer::Buffer, service_fn, Service, ServiceExt};
use zebra_chain::{block::BlockHeaderHash, types::BlockHeight};
// genesis use zebra_chain::{block::BlockHeaderHash, types::BlockHeight};
static GENESIS: BlockHeaderHash = BlockHeaderHash([ use zebra_consensus::parameters;
8, 206, 61, 151, 49, 176, 0, 192, 131, 56, 69, 92, 138, 74, 107, 208, 93, 161, 110, 38, 177,
29, 170, 27, 145, 113, 132, 236, 232, 15, 4, 0,
]);
/// `connect` subcommand /// `connect` subcommand
#[derive(Command, Debug, Options)] #[derive(Command, Debug, Options)]
@ -33,6 +30,9 @@ impl Runnable for ConnectCmd {
fn run(&self) { fn run(&self) {
info!(connect.addr = ?self.addr); info!(connect.addr = ?self.addr);
let network = app_config().network.network;
let genesis_hash = parameters::genesis_hash(network);
let rt = app_writer() let rt = app_writer()
.state_mut() .state_mut()
.components .components
@ -43,7 +43,7 @@ impl Runnable for ConnectCmd {
let result = rt let result = rt
.expect("runtime should not already be taken") .expect("runtime should not already be taken")
.block_on(self.connect()); .block_on(self.connect(genesis_hash));
match result { match result {
Ok(()) => {} Ok(()) => {}
@ -56,7 +56,7 @@ impl Runnable for ConnectCmd {
} }
impl ConnectCmd { impl ConnectCmd {
async fn connect(&self) -> Result<(), Report> { async fn connect(&self, genesis_hash: BlockHeaderHash) -> Result<(), Report> {
info!(?self, "begin tower-based peer handling test stub"); info!(?self, "begin tower-based peer handling test stub");
// The service that our node uses to respond to requests by peers // The service that our node uses to respond to requests by peers
@ -85,7 +85,7 @@ impl ConnectCmd {
retry_peer_set, retry_peer_set,
peer_set, peer_set,
state, state,
tip: GENESIS, tip: genesis_hash,
block_requests: FuturesUnordered::new(), block_requests: FuturesUnordered::new(),
requested_block_heights: 0, requested_block_heights: 0,
downloaded_block_heights, downloaded_block_heights,

View File

@ -26,16 +26,8 @@ use abscissa_core::{config, Command, FrameworkError, Options, Runnable};
use color_eyre::eyre::Report; use color_eyre::eyre::Report;
use tower::{buffer::Buffer, service_fn}; use tower::{buffer::Buffer, service_fn};
use zebra_chain::block::BlockHeaderHash;
mod sync; mod sync;
// genesis
const GENESIS: BlockHeaderHash = BlockHeaderHash([
8, 206, 61, 151, 49, 176, 0, 192, 131, 56, 69, 92, 138, 74, 107, 208, 93, 161, 110, 38, 177,
29, 170, 27, 145, 113, 132, 236, 232, 15, 4, 0,
]);
/// `start` subcommand /// `start` subcommand
#[derive(Command, Debug, Options)] #[derive(Command, Debug, Options)]
pub struct StartCmd { pub struct StartCmd {
@ -61,7 +53,7 @@ impl StartCmd {
let (peer_set, _address_book) = zebra_network::init(config.network.clone(), node).await; let (peer_set, _address_book) = zebra_network::init(config.network.clone(), node).await;
let verifier = zebra_consensus::chain::init(config.network.network, state.clone()); let verifier = zebra_consensus::chain::init(config.network.network, state.clone());
let mut syncer = sync::Syncer::new(peer_set, state, verifier); let mut syncer = sync::Syncer::new(config.network.network, peer_set, state, verifier);
syncer.sync().await syncer.sync().await
} }

View File

@ -11,8 +11,9 @@ use zebra_chain::{
Network, Network,
}; };
use zebra_consensus::checkpoint; use zebra_consensus::checkpoint;
use zebra_consensus::parameters;
use zebra_network::{self as zn, RetryLimit}; use zebra_network::{self as zn, RetryLimit};
use zebra_state::{self as zs}; use zebra_state as zs;
// XXX in the future, we may not be able to access the checkpoint module. // XXX in the future, we may not be able to access the checkpoint module.
const FANOUT: usize = checkpoint::MAX_QUEUED_BLOCKS_PER_HEIGHT; const FANOUT: usize = checkpoint::MAX_QUEUED_BLOCKS_PER_HEIGHT;
@ -40,6 +41,7 @@ where
prospective_tips: HashSet<BlockHeaderHash>, prospective_tips: HashSet<BlockHeaderHash>,
pending_blocks: pending_blocks:
Pin<Box<FuturesUnordered<Instrumented<JoinHandle<Result<BlockHeaderHash, Error>>>>>>, Pin<Box<FuturesUnordered<Instrumented<JoinHandle<Result<BlockHeaderHash, Error>>>>>>,
genesis_hash: BlockHeaderHash,
} }
impl<ZN, ZS, ZV> Syncer<ZN, ZS, ZV> impl<ZN, ZS, ZV> Syncer<ZN, ZS, ZV>
@ -51,15 +53,21 @@ where
ZV: Service<Arc<Block>, Response = BlockHeaderHash, Error = Error> + Send + Clone + 'static, ZV: Service<Arc<Block>, Response = BlockHeaderHash, Error = Error> + Send + Clone + 'static,
ZV::Future: Send, ZV::Future: Send,
{ {
pub fn new(network: ZN, state: ZS, verifier: ZV) -> Self { /// Returns a new syncer instance, using:
let retry_network = Retry::new(RetryLimit::new(3), network.clone()); /// - chain: the zebra-chain `Network` to download (Mainnet or Testnet)
/// - peers: the zebra-network peers to contact for downloads
/// - state: the zebra-state that stores the chain
/// - verifier: the zebra-consensus verifier that checks the chain
pub fn new(chain: Network, peers: ZN, state: ZS, verifier: ZV) -> Self {
let retry_peers = Retry::new(RetryLimit::new(3), peers.clone());
Self { Self {
tip_network: network, tip_network: peers,
block_network: retry_network, block_network: retry_peers,
state, state,
verifier, verifier,
prospective_tips: HashSet::new(), prospective_tips: HashSet::new(),
pending_blocks: Box::pin(FuturesUnordered::new()), pending_blocks: Box::pin(FuturesUnordered::new()),
genesis_hash: parameters::genesis_hash(chain),
} }
} }
@ -133,16 +141,13 @@ where
// //
// Query the current state to construct the sequence of hashes: handled by // Query the current state to construct the sequence of hashes: handled by
// the caller // the caller
//
// TODO(teor): get the real network
let network = Network::Mainnet;
let block_locator = self let block_locator = self
.state .state
.ready_and() .ready_and()
.await .await
.map_err(|e| eyre!(e))? .map_err(|e| eyre!(e))?
.call(zebra_state::Request::GetBlockLocator { .call(zebra_state::Request::GetBlockLocator {
genesis: zebra_consensus::parameters::genesis_hash(network), genesis: self.genesis_hash,
}) })
.await .await
.map(|response| match response { .map(|response| match response {
@ -303,7 +308,7 @@ where
tracing::debug!("skipping length-1 response, in case it's an unsolicited inv message"); tracing::debug!("skipping length-1 response, in case it's an unsolicited inv message");
continue; continue;
} }
(Some(&super::GENESIS), _) => { (Some(hash), _) if (hash == &self.genesis_hash) => {
tracing::debug!("skipping response, peer could not extend the tip"); tracing::debug!("skipping response, peer could not extend the tip");
continue; continue;
} }