[−][src]Enum pallet_multisig::Call
Dispatchable calls.
Each variant of this enum maps to a dispatchable function from the associated module.
Variants
Register approval for a dispatch to be made from a deterministic composite account if
approved by a total of threshold - 1
of other_signatories
.
If there are enough, then dispatch the call. Calls must each fulfil the IsCallable
filter.
Payment: DepositBase
will be reserved if this is the first approval, plus
threshold
times DepositFactor
. It is returned once this dispatch happens or
is cancelled.
The dispatch origin for this call must be Signed.
threshold
: The total number of approvals for this dispatch before it is executed.other_signatories
: The accounts (other than the sender) who can approve this dispatch. May not be empty.maybe_timepoint
: If this is the first approval, then this must beNone
. If it is not the first approval, then it must beSome
, with the timepoint (block number and transaction index) of the first approval transaction.call
: The call to be executed.
NOTE: Unless this is the final approval, you will generally want to use
approve_as_multi
instead, since it only requires a hash of the call.
Result is equivalent to the dispatched result if threshold
is exactly 1
. Otherwise
on success, result is Ok
and the result from the interior call, if it was executed,
may be found in the deposited MultisigExecuted
event.
O(S + Z + Call)
.- Up to one balance-reserve or unreserve operation.
- One passthrough operation, one insert, both
O(S)
whereS
is the number of signatories.S
is capped byMaxSignatories
, with weight being proportional. - One call encode & hash, both of complexity
O(Z)
whereZ
is tx-len. - One encode & hash, both of complexity
O(S)
. - Up to one binary search and insert (
O(logS + S)
). - I/O: 1 read
O(S)
, up to 1 mutateO(S)
. Up to one remove. - One event.
- The weight of the
call
. - Storage: inserts one item, value size bounded by
MaxSignatories
, with a deposit taken for its lifetime ofDepositBase + threshold * DepositFactor
.
- Base Weight:
- Create: 46.55 + 0.089 * S µs
- Approve: 34.03 + .112 * S µs
- Complete: 40.36 + .225 * S µs
- DB Weight:
- Reads: Multisig Storage, [Caller Account]
- Writes: Multisig Storage, [Caller Account]
- Plus Call Weight
Register approval for a dispatch to be made from a deterministic composite account if
approved by a total of threshold - 1
of other_signatories
.
Payment: DepositBase
will be reserved if this is the first approval, plus
threshold
times DepositFactor
. It is returned once this dispatch happens or
is cancelled.
The dispatch origin for this call must be Signed.
threshold
: The total number of approvals for this dispatch before it is executed.other_signatories
: The accounts (other than the sender) who can approve this dispatch. May not be empty.maybe_timepoint
: If this is the first approval, then this must beNone
. If it is not the first approval, then it must beSome
, with the timepoint (block number and transaction index) of the first approval transaction.call_hash
: The hash of the call to be executed.
NOTE: If this is the final approval, you will want to use as_multi
instead.
O(S)
.- Up to one balance-reserve or unreserve operation.
- One passthrough operation, one insert, both
O(S)
whereS
is the number of signatories.S
is capped byMaxSignatories
, with weight being proportional. - One encode & hash, both of complexity
O(S)
. - Up to one binary search and insert (
O(logS + S)
). - I/O: 1 read
O(S)
, up to 1 mutateO(S)
. Up to one remove. - One event.
- Storage: inserts one item, value size bounded by
MaxSignatories
, with a deposit taken for its lifetime ofDepositBase + threshold * DepositFactor
.
- Base Weight:
- Create: 44.71 + 0.088 * S
- Approve: 31.48 + 0.116 * S
- DB Weight:
- Read: Multisig Storage, [Caller Account]
- Write: Multisig Storage, [Caller Account]
Cancel a pre-existing, on-going multisig transaction. Any deposit reserved previously for this operation will be unreserved on success.
The dispatch origin for this call must be Signed.
threshold
: The total number of approvals for this dispatch before it is executed.other_signatories
: The accounts (other than the sender) who can approve this dispatch. May not be empty.timepoint
: The timepoint (block number and transaction index) of the first approval transaction for this dispatch.call_hash
: The hash of the call to be executed.
O(S)
.- Up to one balance-reserve or unreserve operation.
- One passthrough operation, one insert, both
O(S)
whereS
is the number of signatories.S
is capped byMaxSignatories
, with weight being proportional. - One encode & hash, both of complexity
O(S)
. - One event.
- I/O: 1 read
O(S)
, one remove. - Storage: removes one item.
- Base Weight: 37.6 + 0.084 * S
- DB Weight:
- Read: Multisig Storage, [Caller Account]
- Write: Multisig Storage, [Caller Account]
Trait Implementations
impl<T: Trait> Clone for Call<T>
[src]
fn clone(&self) -> Self
[src]
fn clone_from(&mut self, source: &Self)
1.0.0[src]
impl<T: Trait> Debug for Call<T>
[src]
impl<T: Trait> Decode for Call<T> where
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Box<<T as Trait>::Call>: Decode,
Box<<T as Trait>::Call>: Decode,
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Timepoint<T::BlockNumber>: Decode,
Timepoint<T::BlockNumber>: Decode,
[src]
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Box<<T as Trait>::Call>: Decode,
Box<<T as Trait>::Call>: Decode,
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Option<Timepoint<T::BlockNumber>>: Decode,
Vec<T::AccountId>: Decode,
Vec<T::AccountId>: Decode,
Timepoint<T::BlockNumber>: Decode,
Timepoint<T::BlockNumber>: Decode,
impl<T: Trait> Dispatchable for Call<T>
[src]
type Trait = T
...
type Origin = T::Origin
Every function call from your runtime has an origin, which specifies where the extrinsic was generated from. In the case of a signed extrinsic (transaction), the origin contains an identifier for the caller. The origin can be empty in the case of an inherent extrinsic. Read more
type Info = DispatchInfo
An opaque set of information attached to the transaction. This could be constructed anywhere down the line in a runtime. The current Substrate runtime uses a struct with the same name to represent the dispatch class and weight. Read more
type PostInfo = PostDispatchInfo
Additional information that is returned by dispatch
. Can be used to supply the caller with information about a Dispatchable
that is ownly known post dispatch. Read more
fn dispatch(self, _origin: Self::Origin) -> DispatchResultWithPostInfo
[src]
impl<T: Trait> Encode for Call<T> where
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Box<<T as Trait>::Call>: Encode,
Box<<T as Trait>::Call>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Timepoint<T::BlockNumber>: Encode,
Timepoint<T::BlockNumber>: Encode,
[src]
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Box<<T as Trait>::Call>: Encode,
Box<<T as Trait>::Call>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Timepoint<T::BlockNumber>: Encode,
Timepoint<T::BlockNumber>: Encode,
fn encode_to<EncOut: Output>(&self, dest: &mut EncOut)
[src]
fn size_hint(&self) -> usize
[src]
fn encode(&self) -> Vec<u8>
[src]
fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
[src]
F: FnOnce(&[u8]) -> R,
impl<T: Trait> EncodeLike<Call<T>> for Call<T> where
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Box<<T as Trait>::Call>: Encode,
Box<<T as Trait>::Call>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Timepoint<T::BlockNumber>: Encode,
Timepoint<T::BlockNumber>: Encode,
[src]
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Box<<T as Trait>::Call>: Encode,
Box<<T as Trait>::Call>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Option<Timepoint<T::BlockNumber>>: Encode,
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: Encode,
Timepoint<T::BlockNumber>: Encode,
Timepoint<T::BlockNumber>: Encode,
impl<T: Trait> Eq for Call<T>
[src]
impl<T: Trait> GetCallName for Call<T>
[src]
fn get_call_name(&self) -> &'static str
[src]
fn get_call_names() -> &'static [&'static str]
[src]
impl<T: Trait> GetDispatchInfo for Call<T>
[src]
fn get_dispatch_info(&self) -> DispatchInfo
[src]
impl<T: Trait> PartialEq<Call<T>> for Call<T>
[src]
Auto Trait Implementations
impl<T> RefUnwindSafe for Call<T> where
T: RefUnwindSafe,
<T as Trait>::AccountId: RefUnwindSafe,
<T as Trait>::BlockNumber: RefUnwindSafe,
<T as Trait>::Call: RefUnwindSafe,
T: RefUnwindSafe,
<T as Trait>::AccountId: RefUnwindSafe,
<T as Trait>::BlockNumber: RefUnwindSafe,
<T as Trait>::Call: RefUnwindSafe,
impl<T> Send for Call<T> where
T: Send,
<T as Trait>::AccountId: Send,
<T as Trait>::BlockNumber: Send,
<T as Trait>::Call: Send,
T: Send,
<T as Trait>::AccountId: Send,
<T as Trait>::BlockNumber: Send,
<T as Trait>::Call: Send,
impl<T> Sync for Call<T> where
T: Sync,
<T as Trait>::AccountId: Sync,
<T as Trait>::BlockNumber: Sync,
<T as Trait>::Call: Sync,
T: Sync,
<T as Trait>::AccountId: Sync,
<T as Trait>::BlockNumber: Sync,
<T as Trait>::Call: Sync,
impl<T> Unpin for Call<T> where
T: Unpin,
<T as Trait>::AccountId: Unpin,
<T as Trait>::BlockNumber: Unpin,
T: Unpin,
<T as Trait>::AccountId: Unpin,
<T as Trait>::BlockNumber: Unpin,
impl<T> UnwindSafe for Call<T> where
T: UnwindSafe,
<T as Trait>::AccountId: UnwindSafe,
<T as Trait>::BlockNumber: UnwindSafe,
<T as Trait>::Call: UnwindSafe,
T: UnwindSafe,
<T as Trait>::AccountId: UnwindSafe,
<T as Trait>::BlockNumber: UnwindSafe,
<T as Trait>::Call: UnwindSafe,
Blanket Implementations
impl<T> Any for T where
T: 'static + ?Sized,
[src]
T: 'static + ?Sized,
impl<T> Borrow<T> for T where
T: ?Sized,
[src]
T: ?Sized,
impl<T> BorrowMut<T> for T where
T: ?Sized,
[src]
T: ?Sized,
fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> CheckedConversion for T
[src]
fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
[src]
Self: TryFrom<T>,
fn checked_into<T>(self) -> Option<T> where
Self: TryInto<T>,
[src]
Self: TryInto<T>,
impl<S> Codec for S where
S: Encode + Decode,
[src]
S: Encode + Decode,
impl<T, X> Decode for X where
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>,
[src]
T: Decode + Into<X>,
X: WrapperTypeDecode<Wrapped = T>,
impl<T> DecodeAll for T where
T: Decode,
[src]
T: Decode,
impl<T, X> Encode for X where
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>,
[src]
T: Encode + ?Sized,
X: WrapperTypeEncode<Target = T>,
fn size_hint(&self) -> usize
[src]
fn using_encoded<R, F>(&self, f: F) -> R where
F: FnOnce(&[u8]) -> R,
[src]
F: FnOnce(&[u8]) -> R,
fn encode(&self) -> Vec<u8>
[src]
fn encode_to<W>(&self, dest: &mut W) where
W: Output,
[src]
W: Output,
impl<'_, '_, T> EncodeLike<&'_ &'_ T> for T where
T: Encode,
[src]
T: Encode,
impl<'_, T> EncodeLike<&'_ T> for T where
T: Encode,
[src]
T: Encode,
impl<'_, T> EncodeLike<&'_ mut T> for T where
T: Encode,
[src]
T: Encode,
impl<T> EncodeLike<Arc<T>> for T where
T: Encode,
[src]
T: Encode,
impl<T> EncodeLike<Box<T>> for T where
T: Encode,
[src]
T: Encode,
impl<'a, T> EncodeLike<Cow<'a, T>> for T where
T: Encode + ToOwned,
[src]
T: Encode + ToOwned,
impl<T> EncodeLike<Rc<T>> for T where
T: Encode,
[src]
T: Encode,
impl<T> From<T> for T
[src]
impl<S> FullCodec for S where
S: Decode + FullEncode,
[src]
S: Decode + FullEncode,
impl<S> FullEncode for S where
S: Encode + EncodeLike<S>,
[src]
S: Encode + EncodeLike<S>,
impl<T> Hashable for T where
T: Codec,
[src]
T: Codec,
fn blake2_128(&self) -> [u8; 16]
[src]
fn blake2_256(&self) -> [u8; 32]
[src]
fn blake2_128_concat(&self) -> Vec<u8>
[src]
fn twox_128(&self) -> [u8; 16]
[src]
fn twox_256(&self) -> [u8; 32]
[src]
fn twox_64_concat(&self) -> Vec<u8>
[src]
fn identity(&self) -> Vec<u8>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T, Outer> IsWrappedBy<Outer> for T where
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
[src]
Outer: AsRef<T> + AsMut<T> + From<T>,
T: From<Outer>,
fn from_ref(outer: &Outer) -> &T
[src]
Get a reference to the inner from the outer.
fn from_mut(outer: &mut Outer) -> &mut T
[src]
Get a mutable reference to the inner from the outer.
impl<T> KeyedVec for T where
T: Codec,
[src]
T: Codec,
impl<T> MaybeDebug for T where
T: Debug,
T: Debug,
impl<T> MaybeDebug for T where
T: Debug,
T: Debug,
impl<T> MaybeRefUnwindSafe for T where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> Member for T where
T: 'static + Clone + PartialEq<T> + Eq + Send + Sync + Debug,
[src]
T: 'static + Clone + PartialEq<T> + Eq + Send + Sync + Debug,
impl<T> Parameter for T where
T: Codec + EncodeLike<T> + Clone + Eq + Debug,
[src]
T: Codec + EncodeLike<T> + Clone + Eq + Debug,
impl<T> Same<T> for T
type Output = T
Should always be Self
impl<T> SaturatedConversion for T
fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
Self: UniqueSaturatedFrom<T>,
fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
Self: UniqueSaturatedInto<T>,
impl<T> ToOwned for T where
T: Clone,
[src]
T: Clone,
type Owned = T
The resulting type after obtaining ownership.
fn to_owned(&self) -> T
[src]
fn clone_into(&self, target: &mut T)
[src]
impl<T, U> TryFrom<U> for T where
U: Into<T>,
[src]
U: Into<T>,
type Error = Infallible
The type returned in the event of a conversion error.
fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>
[src]
impl<T, U> TryInto<U> for T where
U: TryFrom<T>,
[src]
U: TryFrom<T>,
type Error = <U as TryFrom<T>>::Error
The type returned in the event of a conversion error.
fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
T: UncheckedFrom<S>,
fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
S: TryInto<T>,
T: Bounded,
S: TryInto<T>,
T: Bounded,
fn unique_saturated_into(self) -> T
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,