use beacon_chain::BeaconChain as RawBeaconChain; use beacon_chain::{ db::ClientDB, fork_choice::ForkChoice, parking_lot::RwLockReadGuard, slot_clock::SlotClock, types::{BeaconState, ChainSpec}, AggregationOutcome, CheckPoint, }; use eth2_libp2p::HelloMessage; use types::{Attestation, BeaconBlock, BeaconBlockBody, BeaconBlockHeader, Epoch, Hash256, Slot}; pub use beacon_chain::{BeaconChainError, BlockProcessingOutcome}; /// The network's API to the beacon chain. pub trait BeaconChain: Send + Sync { fn get_spec(&self) -> &ChainSpec; fn get_state(&self) -> RwLockReadGuard; fn slot(&self) -> Slot; fn head(&self) -> RwLockReadGuard; fn get_block(&self, block_root: &Hash256) -> Result, BeaconChainError>; fn best_slot(&self) -> Slot; fn best_block_root(&self) -> Hash256; fn finalized_head(&self) -> RwLockReadGuard; fn finalized_epoch(&self) -> Epoch; fn hello_message(&self) -> HelloMessage; fn process_block(&self, block: BeaconBlock) -> Result; fn process_attestation( &self, attestation: Attestation, ) -> Result; fn get_block_roots( &self, start_slot: Slot, count: usize, skip: usize, ) -> Result, BeaconChainError>; fn get_block_headers( &self, start_slot: Slot, count: usize, skip: usize, ) -> Result, BeaconChainError>; fn get_block_bodies(&self, roots: &[Hash256]) -> Result, BeaconChainError>; fn is_new_block_root(&self, beacon_block_root: &Hash256) -> Result; } impl BeaconChain for RawBeaconChain where T: ClientDB + Sized, U: SlotClock, F: ForkChoice, { fn get_spec(&self) -> &ChainSpec { &self.spec } fn get_state(&self) -> RwLockReadGuard { self.state.read() } fn slot(&self) -> Slot { self.get_state().slot } fn head(&self) -> RwLockReadGuard { self.head() } fn get_block(&self, block_root: &Hash256) -> Result, BeaconChainError> { self.get_block(block_root) } fn finalized_epoch(&self) -> Epoch { self.get_state().finalized_epoch } fn finalized_head(&self) -> RwLockReadGuard { self.finalized_head() } fn best_slot(&self) -> Slot { self.head().beacon_block.slot } fn best_block_root(&self) -> Hash256 { self.head().beacon_block_root } fn hello_message(&self) -> HelloMessage { let spec = self.get_spec(); let state = self.get_state(); HelloMessage { network_id: spec.network_id, latest_finalized_root: state.finalized_root, latest_finalized_epoch: state.finalized_epoch, best_root: self.best_block_root(), best_slot: self.best_slot(), } } fn process_block( &self, block: BeaconBlock, ) -> Result { self.process_block(block) } fn process_attestation( &self, _attestation: Attestation, ) -> Result { // Awaiting a proper operations pool before we can import attestations. // // Returning a useless error for now. // // https://github.com/sigp/lighthouse/issues/281 return Err(BeaconChainError::DBInconsistent("CANNOT PROCESS".into())); } fn get_block_roots( &self, start_slot: Slot, count: usize, skip: usize, ) -> Result, BeaconChainError> { self.get_block_roots(start_slot, count, skip) } fn get_block_headers( &self, start_slot: Slot, count: usize, skip: usize, ) -> Result, BeaconChainError> { let roots = self.get_block_roots(start_slot, count, skip)?; self.get_block_headers(&roots) } fn get_block_bodies( &self, roots: &[Hash256], ) -> Result, BeaconChainError> { self.get_block_bodies(roots) } fn is_new_block_root(&self, beacon_block_root: &Hash256) -> Result { self.is_new_block_root(beacon_block_root) } }