Struct linera_execution::system::SystemExecutionStateView
source · pub struct SystemExecutionStateView<C> {
pub description: HashedRegisterView<C, Option<ChainDescription>>,
pub epoch: HashedRegisterView<C, Option<Epoch>>,
pub admin_id: HashedRegisterView<C, Option<ChainId>>,
pub subscriptions: HashedSetView<C, ChannelSubscription>,
pub committees: HashedRegisterView<C, BTreeMap<Epoch, Committee>>,
pub ownership: HashedRegisterView<C, ChainOwnership>,
pub balance: HashedRegisterView<C, Amount>,
pub balances: HashedMapView<C, Owner, Amount>,
pub timestamp: HashedRegisterView<C, Timestamp>,
pub registry: ApplicationRegistryView<C>,
pub closed: HashedRegisterView<C, bool>,
pub application_permissions: HashedRegisterView<C, ApplicationPermissions>,
}Expand description
A view accessing the execution state of the system of a chain.
Fields§
§description: HashedRegisterView<C, Option<ChainDescription>>How the chain was created. May be unknown for inactive chains.
epoch: HashedRegisterView<C, Option<Epoch>>The number identifying the current configuration.
admin_id: HashedRegisterView<C, Option<ChainId>>The admin of the chain.
subscriptions: HashedSetView<C, ChannelSubscription>Track the channels that we have subscribed to.
committees: HashedRegisterView<C, BTreeMap<Epoch, Committee>>The committees that we trust, indexed by epoch number.
ownership: HashedRegisterView<C, ChainOwnership>Ownership of the chain.
balance: HashedRegisterView<C, Amount>Balance of the chain. (Available to any user able to create blocks in the chain.)
balances: HashedMapView<C, Owner, Amount>Balances attributed to a given owner.
timestamp: HashedRegisterView<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.
closed: HashedRegisterView<C, bool>Whether this chain has been closed.
application_permissions: HashedRegisterView<C, ApplicationPermissions>Permissions for applications on this chain.
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, Amount>, Option<(UserApplicationId, Vec<u8>)>), SystemExecutionError>
pub async fn execute_operation( &mut self, context: OperationContext, operation: SystemOperation ) -> Result<(RawExecutionOutcome<SystemMessage, Amount>, Option<(UserApplicationId, Vec<u8>)>), SystemExecutionError>
Executes the sender’s side of an operation and returns a list of actions to be taken.
pub async fn transfer( &mut self, authenticated_signer: Option<Owner>, owner: Option<Owner>, recipient: Recipient, amount: Amount ) -> Result<Option<RawOutgoingMessage<SystemMessage, Amount>>, SystemExecutionError>
pub async fn claim( &self, authenticated_signer: Option<Owner>, owner: Owner, target_id: ChainId, recipient: Recipient, amount: Amount, user_data: UserData ) -> Result<RawOutgoingMessage<SystemMessage, Amount>, SystemExecutionError>
sourcepub async fn execute_message(
&mut self,
context: MessageContext,
message: SystemMessage
) -> Result<RawExecutionOutcome<SystemMessage, Amount>, SystemExecutionError>
pub async fn execute_message( &mut self, context: MessageContext, message: SystemMessage ) -> Result<RawExecutionOutcome<SystemMessage, Amount>, SystemExecutionError>
Executes a cross-chain message that represents the recipient’s side of an operation.
sourcepub fn initialize_chain(
&mut self,
message_id: MessageId,
timestamp: Timestamp,
config: OpenChainConfig
)
pub fn initialize_chain( &mut self, message_id: MessageId, timestamp: Timestamp, config: OpenChainConfig )
Initializes the system application state on a newly opened chain.
pub async fn handle_query( &mut self, context: QueryContext, _query: SystemQuery ) -> Result<SystemResponse, SystemExecutionError>
sourcepub fn open_chain(
&mut self,
config: OpenChainConfig,
next_message_id: MessageId
) -> Result<[RawOutgoingMessage<SystemMessage, Amount>; 2], SystemExecutionError>
pub fn open_chain( &mut self, config: OpenChainConfig, next_message_id: MessageId ) -> Result<[RawOutgoingMessage<SystemMessage, Amount>; 2], SystemExecutionError>
Returns the messages to open a new chain, and subtracts the new chain’s balance from this chain’s.
pub async fn close_chain( &mut self, id: ChainId ) -> Result<Vec<RawOutgoingMessage<SystemMessage, Amount>>, SystemExecutionError>
Trait Implementations§
source§impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>
impl<C: Send + Sync + Context> ContainerType for SystemExecutionStateView<C>
source§async fn resolve_field(&self, ctx: &Context<'_>) -> ServerResult<Option<Value>>
async fn resolve_field(&self, ctx: &Context<'_>) -> ServerResult<Option<Value>>
async_graphql::Value. Read moresource§async fn find_entity(
&self,
ctx: &Context<'_>,
params: &Value
) -> ServerResult<Option<Value>>
async fn find_entity( &self, ctx: &Context<'_>, params: &Value ) -> ServerResult<Option<Value>>
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
HashedRegisterView<C, Option<ChainDescription>>: Debug,
HashedRegisterView<C, Option<Epoch>>: Debug,
HashedRegisterView<C, Option<ChainId>>: Debug,
HashedSetView<C, ChannelSubscription>: Debug,
HashedRegisterView<C, BTreeMap<Epoch, Committee>>: Debug,
HashedRegisterView<C, ChainOwnership>: Debug,
HashedRegisterView<C, Amount>: Debug,
HashedMapView<C, Owner, Amount>: Debug,
HashedRegisterView<C, Timestamp>: Debug,
ApplicationRegistryView<C>: Debug,
HashedRegisterView<C, bool>: Debug,
HashedRegisterView<C, ApplicationPermissions>: Debug,
impl<C> Debug for SystemExecutionStateView<C>where
HashedRegisterView<C, Option<ChainDescription>>: Debug,
HashedRegisterView<C, Option<Epoch>>: Debug,
HashedRegisterView<C, Option<ChainId>>: Debug,
HashedSetView<C, ChannelSubscription>: Debug,
HashedRegisterView<C, BTreeMap<Epoch, Committee>>: Debug,
HashedRegisterView<C, ChainOwnership>: Debug,
HashedRegisterView<C, Amount>: Debug,
HashedMapView<C, Owner, Amount>: Debug,
HashedRegisterView<C, Timestamp>: Debug,
ApplicationRegistryView<C>: Debug,
HashedRegisterView<C, bool>: Debug,
HashedRegisterView<C, ApplicationPermissions>: Debug,
source§impl<C> HashableView<C> for SystemExecutionStateView<C>
impl<C> HashableView<C> for SystemExecutionStateView<C>
§type Hasher = CoreWrapper<Sha3_256Core>
type Hasher = CoreWrapper<Sha3_256Core>
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§async fn resolve(
&self,
ctx: &ContextSelectionSet<'_>,
_field: &Positioned<Field>
) -> ServerResult<Value>
async fn resolve( &self, ctx: &ContextSelectionSet<'_>, _field: &Positioned<Field> ) -> ServerResult<Value>
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<bool, ViewError>
fn flush(&mut self, batch: &mut Batch) -> Result<bool, ViewError>
batch variable first. If the view is dropped without calling flush, staged
changes are simply lost.
The returned boolean indicates whether the operation removes the view or not.