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,
    public_key: PublicKey,
    epoch: Epoch,
    committees: BTreeMap<Epoch, Committee>,
    admin_id: ChainId,
    timestamp: Timestamp
)
 
pub fn open_chain( &mut self, message_id: MessageId, public_key: PublicKey, 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 delete. The view is consumed by delete
and cannot be used in any way after delete.