pub struct PolymeshContractsCallApi<'api> { /* private fields */ }Implementations§
source§impl<'api> PolymeshContractsCallApi<'api>
impl<'api> PolymeshContractsCallApi<'api>
sourcepub fn instantiate_with_code_perms(
&self,
endowment: u128,
gas_limit: Weight,
storage_deposit_limit: Option<u128>,
code: Vec<u8>,
data: Vec<u8>,
salt: Vec<u8>,
perms: Permissions
) -> Result<WrappedCall<'api>>
pub fn instantiate_with_code_perms( &self, endowment: u128, gas_limit: Weight, storage_deposit_limit: Option<u128>, code: Vec<u8>, data: Vec<u8>, salt: Vec<u8>, perms: Permissions ) -> Result<WrappedCall<'api>>
Instantiates a smart contract defining it with the given code and salt.
The contract will be attached as a secondary key,
with perms as its permissions, to origin’s identity.
The contract is transferred endowment amount of POLYX.
This is distinct from the gas_limit,
which controls how much gas the deployment code may at most consume.
Arguments
endowmentamount of POLYX to transfer to the contract.gas_limitfor how much gas thedeploycode in the contract may at most consume.storage_deposit_limitThe maximum amount of balance that can be charged/reserved from the caller to pay for the storage consumed.codewith the WASM binary defining the smart contract.dataThe input data to pass to the contract constructor.saltused for contract address derivation. By varying this, the samecodecan be used under the same identity.permsthat the new secondary key will have.
Errors
- All the errors in
pallet_contracts::Call::instantiate_with_codecan also happen here. - CDD/Permissions are checked, unlike in
pallet_contracts. - Errors that arise when adding a new secondary key can also occur here.
sourcepub fn instantiate_with_hash_perms(
&self,
endowment: u128,
gas_limit: Weight,
storage_deposit_limit: Option<u128>,
code_hash: H256,
data: Vec<u8>,
salt: Vec<u8>,
perms: Permissions
) -> Result<WrappedCall<'api>>
pub fn instantiate_with_hash_perms( &self, endowment: u128, gas_limit: Weight, storage_deposit_limit: Option<u128>, code_hash: H256, data: Vec<u8>, salt: Vec<u8>, perms: Permissions ) -> Result<WrappedCall<'api>>
Instantiates a smart contract defining using the given code_hash and salt.
Unlike instantiate_with_code,
this assumes that at least one contract with the same WASM code has already been uploaded.
The contract will be attached as a secondary key,
with perms as its permissions, to origin’s identity.
The contract is transferred endowment amount of POLYX.
This is distinct from the gas_limit,
which controls how much gas the deployment code may at most consume.
Arguments
endowmentamount of POLYX to transfer to the contract.gas_limitfor how much gas thedeploycode in the contract may at most consume.storage_deposit_limitThe maximum amount of balance that can be charged/reserved from the caller to pay for the storage consumed.code_hashof an already uploaded WASM binary.dataThe input data to pass to the contract constructor.saltused for contract address derivation. By varying this, the samecodecan be used under the same identity.permsthat the new secondary key will have.
Errors
- All the errors in
pallet_contracts::Call::instantiatecan also happen here. - CDD/Permissions are checked, unlike in
pallet_contracts. - Errors that arise when adding a new secondary key can also occur here.
sourcepub fn update_call_runtime_whitelist(
&self,
updates: Vec<(ExtrinsicId, bool)>
) -> Result<WrappedCall<'api>>
pub fn update_call_runtime_whitelist( &self, updates: Vec<(ExtrinsicId, bool)> ) -> Result<WrappedCall<'api>>
Trait Implementations§
source§impl<'api> Clone for PolymeshContractsCallApi<'api>
impl<'api> Clone for PolymeshContractsCallApi<'api>
source§fn clone(&self) -> PolymeshContractsCallApi<'api>
fn clone(&self) -> PolymeshContractsCallApi<'api>
1.0.0 · source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source. Read moreAuto Trait Implementations§
impl<'api> !RefUnwindSafe for PolymeshContractsCallApi<'api>
impl<'api> Send for PolymeshContractsCallApi<'api>
impl<'api> Sync for PolymeshContractsCallApi<'api>
impl<'api> Unpin for PolymeshContractsCallApi<'api>
impl<'api> !UnwindSafe for PolymeshContractsCallApi<'api>
Blanket Implementations§
source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere T: ?Sized,
source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§fn checked_from<T>(t: T) -> Option<Self>where
Self: TryFrom<T>,
fn checked_from<T>(t: T) -> Option<Self>where Self: TryFrom<T>,
§fn checked_into<T>(self) -> Option<T>where
Self: TryInto<T>,
fn checked_into<T>(self) -> Option<T>where Self: TryInto<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, Global>
fn into_any(self: Box<T, Global>) -> Box<dyn Any, Global>
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, Global>) -> Rc<dyn Any, Global>
fn into_any_rc(self: Rc<T, Global>) -> Rc<dyn Any, Global>
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)
&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)
&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> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
T. Read moresource§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere Self: UniqueSaturatedInto<T>,
T. Read more§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere T: UncheckedFrom<S>,
§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
unchecked_from.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T.source§impl<T, S> UniqueSaturatedInto<T> for Swhere
T: Bounded,
S: TryInto<T>,
impl<T, S> UniqueSaturatedInto<T> for Swhere T: Bounded, S: TryInto<T>,
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T.