[−][src]Enum pallet_multisig::Call
Dispatchable calls.
Each variant of this enum maps to a dispatchable function from the associated module.
Variants
Immediately dispatch a multi-signature call using a single approval from the caller.
The dispatch origin for this call must be Signed.
other_signatories
: The accounts (other than the sender) who are part of the multi-signature, but do not participate in the approval process.call
: The call to be executed.
Result is equivalent to the dispatched result.
O(Z + C) where Z is the length of the call and C its execution weight.
- DB Weight: None
- Plus Call Weight
as_multi(u16, Vec<T::AccountId>, Option<Timepoint<T::BlockNumber>>, OpaqueCall, bool, 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
.
If there are enough, then dispatch the call.
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
.
- DB Weight:
- Reads: Multisig Storage, [Caller Account], Calls (if
store_call
) - Writes: Multisig Storage, [Caller Account], Calls (if
store_call
)
- Reads: Multisig Storage, [Caller Account], Calls (if
- 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
.
- 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.
- DB Weight:
- Read: Multisig Storage, [Caller Account], Refund Account, Calls
- Write: Multisig Storage, [Caller Account], Refund Account, Calls
Trait Implementations
impl<T: Trait> Clone for Call<T>
[src]
pub fn clone(&self) -> Self
[src]
pub 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,
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,
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,
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,
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,
pub fn decode<__CodecInputEdqy: Input>(
__codec_input_edqy: &mut __CodecInputEdqy
) -> Result<Self, Error>
[src]
__codec_input_edqy: &mut __CodecInputEdqy
) -> Result<Self, Error>
impl<T: Trait> Encode for Call<T> where
Vec<T::AccountId>: Encode,
Vec<T::AccountId>: 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,
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,
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,
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,
pub fn encode_to<__CodecOutputEdqy: Output>(
&self,
__codec_dest_edqy: &mut __CodecOutputEdqy
)
[src]
&self,
__codec_dest_edqy: &mut __CodecOutputEdqy
)
pub fn size_hint(&self) -> usize
[src]
pub fn encode(&self) -> Vec<u8, Global>
[src]
pub 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,
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,
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,
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,
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]
pub fn get_call_name(&self) -> &'static str
[src]
pub fn get_call_names() -> &'static [&'static str]
[src]
impl<T: Trait> GetDispatchInfo for Call<T>
[src]
pub fn get_dispatch_info(&self) -> DispatchInfo
[src]
impl<T: Trait> PartialEq<Call<T>> for Call<T>
[src]
pub fn eq(&self, _other: &Self) -> bool
[src]
#[must_use]pub fn ne(&self, other: &Rhs) -> bool
1.0.0[src]
impl<T: Trait> UnfilteredDispatchable for Call<T>
[src]
type Origin = T::Origin
The origin type of the runtime, (i.e. frame_system::Trait::Origin
).
pub fn dispatch_bypass_filter(
self,
_origin: Self::Origin
) -> DispatchResultWithPostInfo
[src]
self,
_origin: Self::Origin
) -> DispatchResultWithPostInfo
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,
[src]
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,
[src]
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,
[src]
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,
[src]
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,
[src]
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,
pub fn borrow_mut(&mut self) -> &mut T
[src]
impl<T> CheckedConversion for T
[src]
pub fn checked_from<T>(t: T) -> Option<Self> where
Self: TryFrom<T>,
[src]
Self: TryFrom<T>,
pub 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> DecodeAll for T where
T: Decode,
[src]
T: Decode,
impl<T> DecodeLimit for T where
T: Decode,
[src]
T: Decode,
pub fn decode_all_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
[src]
pub fn decode_with_depth_limit(limit: u32, input: &[u8]) -> Result<T, Error>
[src]
impl<T> DynClone for T where
T: Clone,
[src]
T: Clone,
pub fn __clone_box(&self, Private) -> *mut ()
[src]
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, Global>> 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,
pub fn blake2_128(&self) -> [u8; 16]
[src]
pub fn blake2_256(&self) -> [u8; 32]
[src]
pub fn blake2_128_concat(&self) -> Vec<u8, Global>
[src]
pub fn twox_128(&self) -> [u8; 16]
[src]
pub fn twox_256(&self) -> [u8; 32]
[src]
pub fn twox_64_concat(&self) -> Vec<u8, Global>
[src]
pub fn identity(&self) -> Vec<u8, Global>
[src]
impl<T> Instrument for T
[src]
pub fn instrument(self, span: Span) -> Instrumented<Self>
[src]
pub fn in_current_span(self) -> Instrumented<Self>
[src]
impl<T, U> Into<U> for T where
U: From<T>,
[src]
U: From<T>,
impl<T> IsType<T> for T
[src]
pub fn from_ref(t: &T) -> &T
[src]
pub fn into_ref(&self) -> &T
[src]
pub fn from_mut(t: &mut T) -> &mut T
[src]
pub fn into_mut(&mut self) -> &mut T
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
pub fn from_ref(outer: &Outer) -> &T
[src]
Get a reference to the inner from the outer.
pub 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
pub fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
Self: UniqueSaturatedFrom<T>,
pub 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.
pub fn to_owned(&self) -> T
[src]
pub 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.
pub 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.
pub 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>,
pub fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
T: Bounded,
S: TryInto<T>,
pub fn unique_saturated_into(self) -> T
impl<V, T> VZip<V> for T where
V: MultiLane<T>,
V: MultiLane<T>,