Struct linera_execution::system::SystemExecutionStateView
source · pub struct SystemExecutionStateView<C> {
pub description: RegisterView<C, Option<ChainDescription>>,
pub epoch: RegisterView<C, Option<Epoch>>,
pub admin_id: RegisterView<C, Option<ChainId>>,
pub subscriptions: SetView<C, ChannelSubscription>,
pub committees: RegisterView<C, BTreeMap<Epoch, Committee>>,
pub ownership: RegisterView<C, ChainOwnership>,
pub balance: RegisterView<C, Amount>,
pub balances: MapView<C, Owner, Amount>,
pub timestamp: RegisterView<C, Timestamp>,
pub registry: ApplicationRegistryView<C>,
}
Expand description
A view accessing the execution state of the system of a chain.
Fields§
§description: RegisterView<C, Option<ChainDescription>>
How the chain was created. May be unknown for inactive chains.
epoch: RegisterView<C, Option<Epoch>>
The number identifying the current configuration.
admin_id: RegisterView<C, Option<ChainId>>
The admin of the chain.
subscriptions: SetView<C, ChannelSubscription>
Track the channels that we have subscribed to.
committees: RegisterView<C, BTreeMap<Epoch, Committee>>
The committees that we trust, indexed by epoch number.
Not using a MapView
because the set active of committees is supposed to be
small. Plus, currently, we would create the BTreeMap
anyway in various places
(e.g. the OpenChain
operation).
ownership: RegisterView<C, ChainOwnership>
Ownership of the chain.
balance: RegisterView<C, Amount>
Balance of the chain (unattributed).
balances: MapView<C, Owner, Amount>
Balances attributed to a given owner.
timestamp: RegisterView<C, Timestamp>
The timestamp of the most recent block.
registry: ApplicationRegistryView<C>
Track the locations of known bytecodes as well as the descriptions of known applications.
Implementations§
source§impl<C> SystemExecutionStateView<C>where
C: Context + Clone + Send + Sync + 'static,
ViewError: From<C::Error>,
impl<C> SystemExecutionStateView<C>where C: Context + Clone + Send + Sync + 'static, ViewError: From<C::Error>,
sourcepub fn current_committee(&self) -> Option<(Epoch, &Committee)>
pub fn current_committee(&self) -> Option<(Epoch, &Committee)>
Returns the current committee, if any.
sourcepub async fn execute_operation(
&mut self,
context: &OperationContext,
operation: &SystemOperation
) -> Result<(RawExecutionResult<SystemMessage>, Option<(UserApplicationId, Vec<u8>)>), SystemExecutionError>
pub async fn execute_operation( &mut self, context: &OperationContext, operation: &SystemOperation ) -> Result<(RawExecutionResult<SystemMessage>, Option<(UserApplicationId, Vec<u8>)>), SystemExecutionError>
Executes the sender’s side of an operation and returns a list of actions to be taken.
sourcepub async fn execute_message(
&mut self,
context: &MessageContext,
message: &SystemMessage
) -> Result<RawExecutionResult<SystemMessage>, SystemExecutionError>
pub async fn execute_message( &mut self, context: &MessageContext, message: &SystemMessage ) -> Result<RawExecutionResult<SystemMessage>, SystemExecutionError>
Executes a cross-chain message that represents the recipient’s side of an operation.
-
Messages should not return an error unless it is a temporary failure (e.g. storage) or a global system failure. An error will fail the entire cross-chain request, allowing it to be retried later.
-
If execution is impossible for a deterministic reason (e.g. insufficient funds), messages should fail silently and be skipped (similar to a transaction in traditional blockchains).
sourcepub fn open_chain(
&mut self,
message_id: MessageId,
ownership: ChainOwnership,
epoch: Epoch,
committees: BTreeMap<Epoch, Committee>,
admin_id: ChainId,
timestamp: Timestamp
)
pub fn open_chain( &mut self, message_id: MessageId, ownership: ChainOwnership, epoch: Epoch, committees: BTreeMap<Epoch, Committee>, admin_id: ChainId, timestamp: Timestamp )
Initializes the system application state on a newly opened chain.
pub async fn query_application( &mut self, context: &QueryContext, _query: &SystemQuery ) -> Result<SystemResponse, SystemExecutionError>
Trait Implementations§
source§impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>where
ViewError: From<C::Error>,
impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>where ViewError: From<C::Error>,
source§fn resolve_field<'life0, 'life1, 'life2, 'async_trait>(
&'life0 self,
ctx: &'life1 Context<'life2>
) -> Pin<Box<dyn Future<Output = ServerResult<Option<Value>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
fn resolve_field<'life0, 'life1, 'life2, 'async_trait>( &'life0 self, ctx: &'life1 Context<'life2> ) -> Pin<Box<dyn Future<Output = ServerResult<Option<Value>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait,
async_graphql::Value
. Read moresource§fn find_entity<'life0, 'life1, 'life2, 'life3, 'async_trait>(
&'life0 self,
ctx: &'life1 Context<'life2>,
params: &'life3 Value
) -> Pin<Box<dyn Future<Output = ServerResult<Option<Value>>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
'life3: 'async_trait,
fn find_entity<'life0, 'life1, 'life2, 'life3, 'async_trait>( &'life0 self, ctx: &'life1 Context<'life2>, params: &'life3 Value ) -> Pin<Box<dyn Future<Output = ServerResult<Option<Value>>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, 'life3: 'async_trait,
source§fn collect_all_fields<'a>(
&'a self,
ctx: &ContextBase<'a, &'a Positioned<SelectionSet>>,
fields: &mut Fields<'a>
) -> Result<(), ServerError>where
Self: Send + Sync,
fn collect_all_fields<'a>( &'a self, ctx: &ContextBase<'a, &'a Positioned<SelectionSet>>, fields: &mut Fields<'a> ) -> Result<(), ServerError>where Self: Send + Sync,
source§impl<C> Debug for SystemExecutionStateView<C>where
RegisterView<C, Option<ChainDescription>>: Debug,
RegisterView<C, Option<Epoch>>: Debug,
RegisterView<C, Option<ChainId>>: Debug,
SetView<C, ChannelSubscription>: Debug,
RegisterView<C, BTreeMap<Epoch, Committee>>: Debug,
RegisterView<C, ChainOwnership>: Debug,
RegisterView<C, Amount>: Debug,
MapView<C, Owner, Amount>: Debug,
RegisterView<C, Timestamp>: Debug,
ApplicationRegistryView<C>: Debug,
impl<C> Debug for SystemExecutionStateView<C>where RegisterView<C, Option<ChainDescription>>: Debug, RegisterView<C, Option<Epoch>>: Debug, RegisterView<C, Option<ChainId>>: Debug, SetView<C, ChannelSubscription>: Debug, RegisterView<C, BTreeMap<Epoch, Committee>>: Debug, RegisterView<C, ChainOwnership>: Debug, RegisterView<C, Amount>: Debug, MapView<C, Owner, Amount>: Debug, RegisterView<C, Timestamp>: Debug, ApplicationRegistryView<C>: Debug,
source§impl<C> HashableView<C> for SystemExecutionStateView<C>where
C: Context + Send + Sync + Clone + 'static,
ViewError: From<C::Error>,
impl<C> HashableView<C> for SystemExecutionStateView<C>where C: Context + Send + Sync + Clone + 'static, ViewError: From<C::Error>,
source§impl<C: Send + Sync + Context> OutputType for SystemExecutionStateView<C>where
ViewError: From<C::Error>,
impl<C: Send + Sync + Context> OutputType for SystemExecutionStateView<C>where ViewError: From<C::Error>,
source§fn create_type_info(registry: &mut Registry) -> String
fn create_type_info(registry: &mut Registry) -> String
source§fn resolve<'life0, 'life1, 'life2, 'life3, 'async_trait>(
&'life0 self,
ctx: &'life1 ContextSelectionSet<'life2>,
_field: &'life3 Positioned<Field>
) -> Pin<Box<dyn Future<Output = ServerResult<Value>> + Send + 'async_trait>>where
Self: 'async_trait,
'life0: 'async_trait,
'life1: 'async_trait,
'life2: 'async_trait,
'life3: 'async_trait,
fn resolve<'life0, 'life1, 'life2, 'life3, 'async_trait>( &'life0 self, ctx: &'life1 ContextSelectionSet<'life2>, _field: &'life3 Positioned<Field> ) -> Pin<Box<dyn Future<Output = ServerResult<Value>> + Send + 'async_trait>>where Self: 'async_trait, 'life0: 'async_trait, 'life1: 'async_trait, 'life2: 'async_trait, 'life3: 'async_trait,
async_graphql::Value
.source§fn qualified_type_name() -> String
fn qualified_type_name() -> String
source§impl<C> View<C> for SystemExecutionStateView<C>where
C: Context + Send + Sync + Clone + 'static,
ViewError: From<C::Error>,
impl<C> View<C> for SystemExecutionStateView<C>where C: Context + Send + Sync + Clone + 'static, ViewError: From<C::Error>,
source§fn load<'async_trait>(
context: C
) -> Pin<Box<dyn Future<Output = Result<Self, ViewError>> + Send + 'async_trait>>where
Self: 'async_trait,
fn load<'async_trait>( context: C ) -> Pin<Box<dyn Future<Output = Result<Self, ViewError>> + Send + 'async_trait>>where Self: 'async_trait,
source§fn rollback(&mut self)
fn rollback(&mut self)
flush
should have no effect to storage.source§fn flush(&mut self, batch: &mut Batch) -> Result<(), ViewError>
fn flush(&mut self, batch: &mut Batch) -> Result<(), ViewError>
batch
variable first. If the view is dropped without calling flush
, staged
changes are simply lost.source§fn delete(self, batch: &mut Batch)
fn delete(self, batch: &mut Batch)
batch
variable first.
No data/metadata at all is left after deletion. The view is consumed by delete
.