ibc_core_client::context::prelude

Trait ClientExecutionContext

Source
pub trait ClientExecutionContext: ClientValidationContext<ClientStateRef = Self::ClientStateMut> {
    type ClientStateMut: ClientStateExecution<Self>;

    // Required methods
    fn store_client_state(
        &mut self,
        client_state_path: ClientStatePath,
        client_state: Self::ClientStateRef,
    ) -> Result<(), HostError>;
    fn store_consensus_state(
        &mut self,
        consensus_state_path: ClientConsensusStatePath,
        consensus_state: Self::ConsensusStateRef,
    ) -> Result<(), HostError>;
    fn delete_consensus_state(
        &mut self,
        consensus_state_path: ClientConsensusStatePath,
    ) -> Result<(), HostError>;
    fn store_update_meta(
        &mut self,
        client_id: ClientId,
        height: Height,
        host_timestamp: Timestamp,
        host_height: Height,
    ) -> Result<(), HostError>;
    fn delete_update_meta(
        &mut self,
        client_id: ClientId,
        height: Height,
    ) -> Result<(), HostError>;

    // Provided method
    fn client_state_mut(
        &self,
        client_id: &ClientId,
    ) -> Result<Self::ClientStateMut, HostError> { ... }
}
Expand description

Defines the methods that all client ExecutionContexts (precisely the generic parameter of crate::client_state::ClientStateExecution ) must implement.

Specifically, clients have the responsibility to store their client state and consensus states. This trait defines a uniform interface to do that for all clients.

Required Associated Types§

Required Methods§

Source

fn store_client_state( &mut self, client_state_path: ClientStatePath, client_state: Self::ClientStateRef, ) -> Result<(), HostError>

Called upon successful client creation and update

Source

fn store_consensus_state( &mut self, consensus_state_path: ClientConsensusStatePath, consensus_state: Self::ConsensusStateRef, ) -> Result<(), HostError>

Called upon successful client creation and update

Source

fn delete_consensus_state( &mut self, consensus_state_path: ClientConsensusStatePath, ) -> Result<(), HostError>

Delete the consensus state from the store located at the given ClientConsensusStatePath

Source

fn store_update_meta( &mut self, client_id: ClientId, height: Height, host_timestamp: Timestamp, host_height: Height, ) -> Result<(), HostError>

Called upon successful client update.

Implementations are expected to use this to record the specified time and height as the time at which this update (or header) was processed.

Source

fn delete_update_meta( &mut self, client_id: ClientId, height: Height, ) -> Result<(), HostError>

Delete the update time and height associated with the client at the specified height.

This update time should be associated with a consensus state through the specified height.

Note that this timestamp is determined by the host.

Provided Methods§

Source

fn client_state_mut( &self, client_id: &ClientId, ) -> Result<Self::ClientStateMut, HostError>

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§