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.
ownership: RegisterView<C, ChainOwnership>Ownership of the chain.
balance: RegisterView<C, Amount>Balance of the chain. (Available to any user able to create blocks in the chain.)
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>
impl<C> SystemExecutionStateView<C>
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<(RawExecutionOutcome<SystemMessage>, Option<(UserApplicationId, Vec<u8>)>), SystemExecutionError>
pub async fn execute_operation( &mut self, context: OperationContext, operation: SystemOperation ) -> Result<(RawExecutionOutcome<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<RawExecutionOutcome<SystemMessage>, SystemExecutionError>
pub async fn execute_message( &mut self, context: MessageContext, message: SystemMessage ) -> Result<RawExecutionOutcome<SystemMessage>, SystemExecutionError>
Executes a cross-chain message that represents the recipient’s side of an operation.
sourcepub fn open_chain(
&mut self,
message_id: MessageId,
ownership: ChainOwnership,
epoch: Epoch,
committees: BTreeMap<Epoch, Committee>,
admin_id: ChainId,
timestamp: Timestamp,
balance: Amount
)
pub fn open_chain( &mut self, message_id: MessageId, ownership: ChainOwnership, epoch: Epoch, committees: BTreeMap<Epoch, Committee>, admin_id: ChainId, timestamp: Timestamp, balance: Amount )
Initializes the system application state on a newly opened chain.
pub async fn handle_query( &mut self, context: QueryContext, _query: SystemQuery ) -> Result<SystemResponse, SystemExecutionError>
Trait Implementations§
source§impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>
impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>
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>
fn collect_all_fields<'a>( &'a self, ctx: &ContextBase<'a, &'a Positioned<SelectionSet>>, fields: &mut Fields<'a> ) -> Result<(), ServerError>
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>
impl<C> HashableView<C> for SystemExecutionStateView<C>
source§impl<C: Send + Sync + Context> OutputType for SystemExecutionStateView<C>
impl<C: Send + Sync + Context> OutputType for SystemExecutionStateView<C>
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>
impl<C> View<C> for SystemExecutionStateView<C>
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.