pub struct ExecutionExtensions<Block: BlockT> { /* private fields */ }
Expand description
A producer of execution extensions for offchain calls.
This crate aggregates extensions available for the offchain calls
and is responsible for producing a correct Extensions
object.
for each call, based on required Capabilities
.
Implementations§
source§impl<Block: BlockT> ExecutionExtensions<Block>
impl<Block: BlockT> ExecutionExtensions<Block>
sourcepub fn new(
strategies: ExecutionStrategies,
keystore: Option<SyncCryptoStorePtr>,
offchain_db: Option<Box<dyn DbExternalitiesFactory>>
) -> Self
pub fn new( strategies: ExecutionStrategies, keystore: Option<SyncCryptoStorePtr>, offchain_db: Option<Box<dyn DbExternalitiesFactory>> ) -> Self
Create new ExecutionExtensions
given a keystore
and ExecutionStrategies
.
sourcepub fn strategies(&self) -> &ExecutionStrategies
pub fn strategies(&self) -> &ExecutionStrategies
Get a reference to the execution strategies.
sourcepub fn set_extensions_factory(
&self,
maker: impl ExtensionsFactory<Block> + 'static
)
pub fn set_extensions_factory( &self, maker: impl ExtensionsFactory<Block> + 'static )
Set the new extensions_factory
sourcepub fn register_transaction_pool<T>(&self, pool: &Arc<T>)where
T: OffchainSubmitTransaction<Block> + 'static,
pub fn register_transaction_pool<T>(&self, pool: &Arc<T>)where T: OffchainSubmitTransaction<Block> + 'static,
Register transaction pool extension.
sourcepub fn extensions(
&self,
block_hash: Block::Hash,
block_number: NumberFor<Block>,
context: ExecutionContext
) -> Extensions
pub fn extensions( &self, block_hash: Block::Hash, block_number: NumberFor<Block>, context: ExecutionContext ) -> Extensions
Based on the execution context and capabilities it produces the extensions object to support desired set of APIs.
sourcepub fn manager_and_extensions<E: Debug>(
&self,
block_hash: Block::Hash,
block_number: NumberFor<Block>,
context: ExecutionContext
) -> (ExecutionManager<DefaultHandler<E>>, Extensions)
pub fn manager_and_extensions<E: Debug>( &self, block_hash: Block::Hash, block_number: NumberFor<Block>, context: ExecutionContext ) -> (ExecutionManager<DefaultHandler<E>>, Extensions)
Create ExecutionManager
and Extensions
for given offchain call.
Based on the execution context and capabilities it produces the right manager and extensions object to support desired set of APIs.
Trait Implementations§
Auto Trait Implementations§
impl<Block> !RefUnwindSafe for ExecutionExtensions<Block>
impl<Block> Send for ExecutionExtensions<Block>
impl<Block> Sync for ExecutionExtensions<Block>
impl<Block> Unpin for ExecutionExtensions<Block>
impl<Block> !UnwindSafe for ExecutionExtensions<Block>
Blanket Implementations§
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§impl<T> Downcast for Twhere
T: Any,
impl<T> Downcast for Twhere T: Any,
§fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any + 'static, Global>
Convert
Box<dyn Trait>
(where Trait: Downcast
) to Box<dyn Any>
. Box<dyn Any>
can
then be further downcast
into Box<ConcreteType>
where ConcreteType
implements Trait
.§fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
fn into_any_rc(self: Rc<T>) -> Rc<dyn Any + 'static>
Convert
Rc<Trait>
(where Trait: Downcast
) to Rc<Any>
. Rc<Any>
can then be
further downcast
into Rc<ConcreteType>
where ConcreteType
implements Trait
.§fn as_any(&self) -> &(dyn Any + 'static)
fn as_any(&self) -> &(dyn Any + 'static)
Convert
&Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &Any
’s vtable from &Trait
’s.§fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)
Convert
&mut Trait
(where Trait: Downcast
) to &Any
. This is needed since Rust cannot
generate &mut Any
’s vtable from &mut Trait
’s.source§impl<T> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
source§impl<T, Outer> IsWrappedBy<Outer> for Twhere
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
impl<T, Outer> IsWrappedBy<Outer> for Twhere Outer: AsRef<T> + AsMut<T> + From<T>, T: From<Outer>,
§impl<T> Pointable for T
impl<T> Pointable for T
§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of
T
. Read moresource§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of
T
.