pub trait StateProvider {
    type Error;
    type Reader: StateReader<Key, StoredValue, Error = Self::Error>;
    // Required methods
    fn checkout(
        &self,
        state_hash: Digest
    ) -> Result<Option<Self::Reader>, Self::Error>;
    fn empty_root(&self) -> Digest;
    fn get_trie(
        &self,
        correlation_id: CorrelationId,
        trie_key: &Digest
    ) -> Result<Option<Trie<Key, StoredValue>>, Self::Error>;
    fn put_trie(
        &self,
        correlation_id: CorrelationId,
        trie: &Trie<Key, StoredValue>
    ) -> Result<Digest, Self::Error>;
    fn missing_trie_keys(
        &self,
        correlation_id: CorrelationId,
        trie_keys: Vec<Digest>
    ) -> Result<Vec<Digest>, Self::Error>;
}Expand description
A trait expressing operations over the trie.
Required Associated Types§
sourcetype Reader: StateReader<Key, StoredValue, Error = Self::Error>
 
type Reader: StateReader<Key, StoredValue, Error = Self::Error>
Associated reader type for StateProvider.
Required Methods§
sourcefn checkout(
    &self,
    state_hash: Digest
) -> Result<Option<Self::Reader>, Self::Error>
 
fn checkout( &self, state_hash: Digest ) -> Result<Option<Self::Reader>, Self::Error>
Checkouts to the post state of a specific block.
sourcefn empty_root(&self) -> Digest
 
fn empty_root(&self) -> Digest
Returns an empty root hash.
sourcefn get_trie(
    &self,
    correlation_id: CorrelationId,
    trie_key: &Digest
) -> Result<Option<Trie<Key, StoredValue>>, Self::Error>
 
fn get_trie( &self, correlation_id: CorrelationId, trie_key: &Digest ) -> Result<Option<Trie<Key, StoredValue>>, Self::Error>
Reads a Trie from the state if it is present
sourcefn put_trie(
    &self,
    correlation_id: CorrelationId,
    trie: &Trie<Key, StoredValue>
) -> Result<Digest, Self::Error>
 
fn put_trie( &self, correlation_id: CorrelationId, trie: &Trie<Key, StoredValue> ) -> Result<Digest, Self::Error>
Insert a trie node into the trie
sourcefn missing_trie_keys(
    &self,
    correlation_id: CorrelationId,
    trie_keys: Vec<Digest>
) -> Result<Vec<Digest>, Self::Error>
 
fn missing_trie_keys( &self, correlation_id: CorrelationId, trie_keys: Vec<Digest> ) -> Result<Vec<Digest>, Self::Error>
Finds all of the missing or corrupt keys of which are descendants of trie_key