Type Alias sp_api::ProofRecorder

source ·
pub type ProofRecorder<B> = Recorder<HashingFor<B>>;
Expand description

A type that records all accessed trie nodes and generates a proof out of it.

Aliased Type§

struct ProofRecorder<B> { /* private fields */ }

Implementations

source§

impl<H> Recorder<H>
where H: Hasher,

source

pub fn recorded_keys( &self, ) -> HashMap<<H as Hasher>::Out, HashMap<Arc<[u8]>, RecordedForKey>>

Returns RecordedForKey per recorded key per trie.

There are multiple tries when working with e.g. child tries.

source

pub fn as_trie_recorder( &self, storage_root: <H as Hasher>::Out, ) -> TrieRecorder<'_, H>

Returns the recorder as TrieRecorder compatible type.

  • storage_root: The storage root of the trie for which accesses are recorded. This is important when recording access to different tries at once (like top and child tries).

NOTE: This locks a mutex that stays locked until the return value is dropped.

source

pub fn drain_storage_proof(self) -> StorageProof

Drain the recording into a StorageProof.

While a recorder can be cloned, all share the same internal state. After calling this function, all other instances will have their internal state reset as well.

If you don’t want to drain the recorded state, use Self::to_storage_proof.

Returns the StorageProof.

source

pub fn to_storage_proof(&self) -> StorageProof

Convert the recording to a StorageProof.

In contrast to Self::drain_storage_proof this doesn’t consume and doesn’t clear the recordings.

Returns the StorageProof.

source

pub fn estimate_encoded_size(&self) -> usize

Returns the estimated encoded size of the proof.

The estimation is based on all the nodes that were accessed until now while accessing the trie.

source

pub fn reset(&self)

Reset the state.

This discards all recorded data.

source

pub fn start_transaction(&self)

Start a new transaction.

source

pub fn rollback_transaction(&self) -> Result<(), ()>

Rollback the latest transaction.

Returns an error if there wasn’t any active transaction.

source

pub fn commit_transaction(&self) -> Result<(), ()>

Commit the latest transaction.

Returns an error if there wasn’t any active transaction.

Trait Implementations

source§

impl<H> Clone for Recorder<H>
where H: Hasher,

source§

fn clone(&self) -> Recorder<H>

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
source§

impl<H> Default for Recorder<H>
where H: Hasher,

source§

fn default() -> Recorder<H>

Returns the “default value” for a type. Read more
source§

impl<H> ProofSizeProvider for Recorder<H>
where H: Hasher,

source§

fn estimate_encoded_size(&self) -> usize

Returns the storage proof size.
source§

impl<H> TrieRecorderProvider<H> for Recorder<H>
where H: Hasher,

§

type Recorder<'a> = TrieRecorder<'a, H> where H: 'a

Recorder type that is going to be returned by implementors of this trait.
source§

fn drain_storage_proof(self) -> Option<StorageProof>

Create a StorageProof derived from the internal state.
source§

fn as_trie_recorder( &self, storage_root: <H as Hasher>::Out, ) -> <Recorder<H> as TrieRecorderProvider<H>>::Recorder<'_>

Provide a recorder implementing trie_db::TrieRecorder.