pub struct ChainState<PersistedState: ChainStore> { /* private fields */ }

Implementations§

source§

impl<PersistedState: ChainStore> ChainState<PersistedState>

source

pub fn push_headers( &self, headers: Vec<BlockHeader>, height: u32 ) -> Result<(), BlockchainError>

Just adds headers to the chainstate, without validating them.

source

pub fn new( chainstore: PersistedState, network: Network, assume_valid: AssumeValidArg ) -> ChainState<PersistedState>

source

pub fn load_chain_state( chainstore: KvChainStore<'_>, network: Network, assume_valid: AssumeValidArg ) -> Result<ChainState<KvChainStore<'_>>, BlockchainError>

source

pub fn acc(&self) -> Stump

source

pub fn get_bip34_height(&self, block: &Block) -> Option<u32>

source

pub fn validate_block_no_acc( &self, block: &Block, height: u32, inputs: HashMap<OutPoint, TxOut> ) -> Result<(), BlockchainError>

Validates the block without checking whether the inputs are present in the UTXO set. This function contains the core validation logic.

The methods BlockchainInterface::validate_block and UpdatableChainstate::connect_block call this and additionally verify the inclusion proof (i.e., they perform full validation).

Trait Implementations§

source§

impl<PersistedState: ChainStore> BlockchainInterface for ChainState<PersistedState>

§

type Error = BlockchainError

source§

fn get_params(&self) -> Params

source§

fn get_fork_point(&self, block: BlockHash) -> Result<BlockHash, Self::Error>

source§

fn update_acc( &self, acc: Stump, block: UtreexoBlock, height: u32, proof: Proof, del_hashes: Vec<Hash> ) -> Result<Stump, Self::Error>

source§

fn get_chain_tips(&self) -> Result<Vec<BlockHash>, Self::Error>

source§

fn validate_block( &self, block: &Block, proof: Proof, inputs: HashMap<OutPoint, TxOut>, del_hashes: Vec<Hash>, acc: Stump ) -> Result<(), Self::Error>

source§

fn get_block_locator_for_tip( &self, tip: BlockHash ) -> Result<Vec<BlockHash>, BlockchainError>

Returns a block locator from a given tip Read more
source§

fn is_in_idb(&self) -> bool

Tells whether or not we are on ibd
source§

fn get_block_height(&self, hash: &BlockHash) -> Result<Option<u32>, Self::Error>

Returns the height of a block, given it’s hash
source§

fn get_block_hash(&self, height: u32) -> Result<BlockHash, Self::Error>

Returns the block with a given height in our current tip.
source§

fn get_tx(&self, _txid: &Txid) -> Result<Option<Transaction>, Self::Error>

Returns a bitcoin Transaction given it’s txid.
source§

fn get_height(&self) -> Result<u32, Self::Error>

Get the height of our best know chain.
source§

fn broadcast(&self, tx: &Transaction) -> Result<(), Self::Error>

Broadcasts a transaction to the network.
source§

fn estimate_fee(&self, target: usize) -> Result<f64, Self::Error>

Returns fee estimation for inclusion in target blocks.
source§

fn get_block(&self, _hash: &BlockHash) -> Result<Block, Self::Error>

Returns a block with a given hash if any.
source§

fn get_best_block(&self) -> Result<(u32, BlockHash), Self::Error>

Returns the best known block
source§

fn get_block_header(&self, hash: &BlockHash) -> Result<Header, Self::Error>

Returns associated header for block with hash
source§

fn subscribe(&self, tx: Arc<dyn BlockConsumer>)

Register for receiving notifications for some event. Right now it only works for new blocks, but may work with transactions in the future too. if a module performs some heavy-lifting on the block’s data, it should pass in a vector or a channel where data can be transfered to the atual worker, otherwise chainstate will be stuck for as long as you have work to do.
source§

fn get_block_locator(&self) -> Result<Vec<BlockHash>, BlockchainError>

Returns a block locator
source§

fn get_validation_index(&self) -> Result<u32, Self::Error>

Returns the last block we validated
source§

fn is_coinbase_mature( &self, height: u32, block: BlockHash ) -> Result<bool, Self::Error>

Checks if a coinbase is mature
source§

fn get_unbroadcasted(&self) -> Vec<Transaction>

Returns the list of unbroadcasted transactions.
source§

impl<T: ChainStore> From<ChainStateBuilder<T>> for ChainState<T>

source§

fn from(builder: ChainStateBuilder<T>) -> Self

Converts to this type from the input type.
source§

impl<PersistedState: ChainStore> UpdatableChainstate for ChainState<PersistedState>

source§

fn switch_chain(&self, new_tip: BlockHash) -> Result<(), BlockchainError>

source§

fn mark_block_as_valid(&self, block: BlockHash) -> Result<(), BlockchainError>

Marks one block as being fully validated, this overrides a block that was explicitly marked as invalid.
source§

fn mark_chain_as_assumed( &self, acc: Stump, assumed_hash: BlockHash ) -> Result<bool, BlockchainError>

Marks a chain as fully-valid Read more
source§

fn invalidate_block(&self, block: BlockHash) -> Result<(), BlockchainError>

Tells this blockchain to consider this block invalid, and not build on top of it
source§

fn toggle_ibd(&self, is_ibd: bool)

Toggle ibd on/off
source§

fn connect_block( &self, block: &Block, proof: Proof, inputs: HashMap<OutPoint, TxOut>, del_hashes: Vec<Hash> ) -> Result<u32, BlockchainError>

This is one of the most important methods for a ChainState, it gets a block and some utreexo data, validates this block and connects to our chain of blocks. This function is meant to be atomic and prone of running in parallel.
source§

fn handle_transaction(&self) -> Result<(), BlockchainError>

Not used for now, but in a future blockchain with mempool, we can process transactions that are not in a block yet.
source§

fn flush(&self) -> Result<(), BlockchainError>

Persists our data. Should be invoked periodically.
source§

fn accept_header(&self, header: BlockHeader) -> Result<(), BlockchainError>

Accepts a new header to our chain. This method is called before connect_block, and makes some basic checks on a header and saves it on disk. We only accept a block as valid after calling connect_block. Read more
source§

fn get_root_hashes(&self) -> Vec<NodeHash>

Returns the root hashes of our utreexo forest
source§

fn get_partial_chain( &self, initial_height: u32, final_height: u32, acc: Stump ) -> Result<PartialChainState, BlockchainError>

Returns a partial chainstate from a range of blocks. Read more

Auto Trait Implementations§

§

impl<PersistedState> !RefUnwindSafe for ChainState<PersistedState>

§

impl<PersistedState> Send for ChainState<PersistedState>where PersistedState: Send,

§

impl<PersistedState> Sync for ChainState<PersistedState>where PersistedState: Send + Sync,

§

impl<PersistedState> Unpin for ChainState<PersistedState>where PersistedState: Unpin,

§

impl<PersistedState> !UnwindSafe for ChainState<PersistedState>

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Pointable for T

source§

const ALIGN: usize = _

The alignment of pointer.
§

type Init = T

The type for initializers.
source§

unsafe fn init(init: <T as Pointable>::Init) -> usize

Initializes a with the given initializer. Read more
source§

unsafe fn deref<'a>(ptr: usize) -> &'a T

Dereferences the given pointer. Read more
source§

unsafe fn deref_mut<'a>(ptr: usize) -> &'a mut T

Mutably dereferences the given pointer. Read more
source§

unsafe fn drop(ptr: usize)

Drops the object pointed to by the given pointer. Read more
source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.