Enum dock_token_migration::pallet::Call
source · pub enum Call<T: Config> {
migrate {
recipients: BTreeMap<T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance>,
},
expand_migrator {
migrator: T::AccountId,
increase_migrations_by: u16,
},
contract_migrator {
migrator: T::AccountId,
decrease_migrations_by: u16,
},
add_migrator {
migrator: T::AccountId,
allowed_migrations: u16,
},
remove_migrator {
migrator: T::AccountId,
},
give_bonuses {
swap_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>,
vesting_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>,
},
claim_bonus {},
claim_bonus_for_other {
target: <T::Lookup as StaticLookup>::Source,
},
claim_swap_bonus {},
claim_swap_bonus_for_other {
target: <T::Lookup as StaticLookup>::Source,
},
claim_vesting_bonus {},
claim_vesting_bonus_for_other {
target: <T::Lookup as StaticLookup>::Source,
},
// some variants omitted
}
Expand description
The module declaration.
Variants§
migrate
Fields
Does a token migration. The migrator should have sufficient balance to give tokens to recipients The check whether it is a valid migrator is made inside the SignedExtension. Migrators are assumed to not be adversarial and not do DoS attacks on the chain. They might act in their benefit and try to send more fee txns then allowed which is guarded against. A bad migrator can flood the network with properly signed but invalid txns like trying to pay more than he has, make the network reject his txn but still spend network resources for free.
expand_migrator
Increase the migrators allowed migrations by the given number
contract_migrator
Decrease the migrators allowed migrations by the given number
add_migrator
Add a new migrator
remove_migrator
Fields
migrator: T::AccountId
Remove an existing migrator
give_bonuses
Fields
Give bonuses to recipients. Only callable by migrator. An alternate data structure of both bonus args could be a map from AccountId -> Set<(amount, offset)>
2 storage entries are touched (read and write) per recipient, its account and bonus. Repeated recipients are not counted. Locks don’t contribute to DB weight as once an account data is read from disk, locks are loaded as well Ignoring weight of in-memory operations
claim_bonus
Fields
Claim bonus if any and can be claimed
There is 1 read and write for bonus storage. Ignoring weight of in-memory operations
claim_bonus_for_other
Fields
target: <T::Lookup as StaticLookup>::Source
Similar to claim_bonus
but done for another account. The bonus does not
credit to the sending account’s free balance
There are 2 reads, one for bonus storage, one for account storage. Similarly for writes. Ignoring weight of in-memory operations
claim_swap_bonus
Fields
Claim swap bonus if any and can be claimed
There is 1 read and write for bonus storage. Ignoring weight of in-memory operations
claim_swap_bonus_for_other
Fields
target: <T::Lookup as StaticLookup>::Source
Similar to claim_swap_bonus
but done for another account. The bonus does not
credit to the sending account’s free balance
There are 2 reads, one for bonus storage, one for account storage. Similarly for writes. Ignoring weight of in-memory operations
claim_vesting_bonus
Fields
Claim vesting bonus if any and can be claimed
There is 1 read and write for bonus storage. Ignoring weight of in-memory operations
claim_vesting_bonus_for_other
Fields
target: <T::Lookup as StaticLookup>::Source
Implementations§
source§impl<T: Config> Call<T>
impl<T: Config> Call<T>
sourcepub fn new_call_variant_migrate(
recipients: BTreeMap<T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance>
) -> Self
pub fn new_call_variant_migrate( recipients: BTreeMap<T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance> ) -> Self
Create a call with the variant migrate
.
sourcepub fn new_call_variant_expand_migrator(
migrator: T::AccountId,
increase_migrations_by: u16
) -> Self
pub fn new_call_variant_expand_migrator( migrator: T::AccountId, increase_migrations_by: u16 ) -> Self
Create a call with the variant expand_migrator
.
sourcepub fn new_call_variant_contract_migrator(
migrator: T::AccountId,
decrease_migrations_by: u16
) -> Self
pub fn new_call_variant_contract_migrator( migrator: T::AccountId, decrease_migrations_by: u16 ) -> Self
Create a call with the variant contract_migrator
.
sourcepub fn new_call_variant_add_migrator(
migrator: T::AccountId,
allowed_migrations: u16
) -> Self
pub fn new_call_variant_add_migrator( migrator: T::AccountId, allowed_migrations: u16 ) -> Self
Create a call with the variant add_migrator
.
sourcepub fn new_call_variant_remove_migrator(migrator: T::AccountId) -> Self
pub fn new_call_variant_remove_migrator(migrator: T::AccountId) -> Self
Create a call with the variant remove_migrator
.
sourcepub fn new_call_variant_give_bonuses(
swap_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>,
vesting_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>
) -> Self
pub fn new_call_variant_give_bonuses( swap_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>, vesting_bonus_recips: Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)> ) -> Self
Create a call with the variant give_bonuses
.
sourcepub fn new_call_variant_claim_bonus() -> Self
pub fn new_call_variant_claim_bonus() -> Self
Create a call with the variant claim_bonus
.
sourcepub fn new_call_variant_claim_bonus_for_other(
target: <T::Lookup as StaticLookup>::Source
) -> Self
pub fn new_call_variant_claim_bonus_for_other( target: <T::Lookup as StaticLookup>::Source ) -> Self
Create a call with the variant claim_bonus_for_other
.
sourcepub fn new_call_variant_claim_swap_bonus() -> Self
pub fn new_call_variant_claim_swap_bonus() -> Self
Create a call with the variant claim_swap_bonus
.
sourcepub fn new_call_variant_claim_swap_bonus_for_other(
target: <T::Lookup as StaticLookup>::Source
) -> Self
pub fn new_call_variant_claim_swap_bonus_for_other( target: <T::Lookup as StaticLookup>::Source ) -> Self
Create a call with the variant claim_swap_bonus_for_other
.
sourcepub fn new_call_variant_claim_vesting_bonus() -> Self
pub fn new_call_variant_claim_vesting_bonus() -> Self
Create a call with the variant claim_vesting_bonus
.
sourcepub fn new_call_variant_claim_vesting_bonus_for_other(
target: <T::Lookup as StaticLookup>::Source
) -> Self
pub fn new_call_variant_claim_vesting_bonus_for_other( target: <T::Lookup as StaticLookup>::Source ) -> Self
Create a call with the variant claim_vesting_bonus_for_other
.
Trait Implementations§
source§impl<T: Config> Decode for Call<T>
impl<T: Config> Decode for Call<T>
source§fn decode<__CodecInputEdqy: Input>(
__codec_input_edqy: &mut __CodecInputEdqy
) -> Result<Self, Error>
fn decode<__CodecInputEdqy: Input>( __codec_input_edqy: &mut __CodecInputEdqy ) -> Result<Self, Error>
§fn decode_into<I>(
input: &mut I,
dst: &mut MaybeUninit<Self>
) -> Result<DecodeFinished, Error>where
I: Input,
fn decode_into<I>( input: &mut I, dst: &mut MaybeUninit<Self> ) -> Result<DecodeFinished, Error>where I: Input,
§fn skip<I>(input: &mut I) -> Result<(), Error>where
I: Input,
fn skip<I>(input: &mut I) -> Result<(), Error>where I: Input,
§fn encoded_fixed_size() -> Option<usize>
fn encoded_fixed_size() -> Option<usize>
source§impl<T: Config> Encode for Call<T>
impl<T: Config> Encode for Call<T>
source§fn size_hint(&self) -> usize
fn size_hint(&self) -> usize
source§fn encode_to<__CodecOutputEdqy: Output + ?Sized>(
&self,
__codec_dest_edqy: &mut __CodecOutputEdqy
)
fn encode_to<__CodecOutputEdqy: Output + ?Sized>( &self, __codec_dest_edqy: &mut __CodecOutputEdqy )
§fn using_encoded<R, F>(&self, f: F) -> Rwhere
F: FnOnce(&[u8]) -> R,
fn using_encoded<R, F>(&self, f: F) -> Rwhere F: FnOnce(&[u8]) -> R,
§fn encoded_size(&self) -> usize
fn encoded_size(&self) -> usize
source§impl<T: Config> GetCallName for Call<T>
impl<T: Config> GetCallName for Call<T>
source§fn get_call_name(&self) -> &'static str
fn get_call_name(&self) -> &'static str
source§fn get_call_names() -> &'static [&'static str]
fn get_call_names() -> &'static [&'static str]
source§impl<T: Config> GetDispatchInfo for Call<T>
impl<T: Config> GetDispatchInfo for Call<T>
source§fn get_dispatch_info(&self) -> DispatchInfo
fn get_dispatch_info(&self) -> DispatchInfo
DispatchInfo
, containing relevant information of this dispatch. Read moresource§impl<T: Config> PartialEq<Call<T>> for Call<T>
impl<T: Config> PartialEq<Call<T>> for Call<T>
source§impl<T> TypeInfo for Call<T>where
PhantomData<(T,)>: TypeInfo + 'static,
BTreeMap<T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance>: TypeInfo + 'static,
T::AccountId: TypeInfo + 'static,
Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>: TypeInfo + 'static,
<T::Lookup as StaticLookup>::Source: TypeInfo + 'static,
T: Config + 'static,
impl<T> TypeInfo for Call<T>where PhantomData<(T,)>: TypeInfo + 'static, BTreeMap<T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance>: TypeInfo + 'static, T::AccountId: TypeInfo + 'static, Vec<(T::AccountId, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance, u32)>: TypeInfo + 'static, <T::Lookup as StaticLookup>::Source: TypeInfo + 'static, T: Config + 'static,
source§impl<T: Config> UnfilteredDispatchable for Call<T>
impl<T: Config> UnfilteredDispatchable for Call<T>
§type Origin = <T as Config>::Origin
type Origin = <T as Config>::Origin
frame_system::Config::Origin
).source§fn dispatch_bypass_filter(
self,
origin: Self::Origin
) -> DispatchResultWithPostInfo
fn dispatch_bypass_filter( self, origin: Self::Origin ) -> DispatchResultWithPostInfo
impl<T: Config> EncodeLike<Call<T>> for Call<T>
impl<T: Config> Eq for Call<T>
Auto Trait Implementations§
impl<T> RefUnwindSafe for Call<T>where T: RefUnwindSafe, <T as Config>::AccountId: RefUnwindSafe, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance: RefUnwindSafe, <<T as Config>::Lookup as StaticLookup>::Source: RefUnwindSafe,
impl<T> Send for Call<T>where T: Send, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance: Send, <<T as Config>::Lookup as StaticLookup>::Source: Send,
impl<T> Sync for Call<T>where T: Sync, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance: Sync, <<T as Config>::Lookup as StaticLookup>::Source: Sync,
impl<T> Unpin for Call<T>where T: Unpin, <T as Config>::AccountId: Unpin, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance: Unpin, <<T as Config>::Lookup as StaticLookup>::Source: Unpin,
impl<T> UnwindSafe for Call<T>where T: UnwindSafe, <T as Config>::AccountId: UnwindSafe + RefUnwindSafe, <<T as Config>::Currency as Currency<<T as Config>::AccountId>>::Balance: UnwindSafe + RefUnwindSafe, <<T as Config>::Lookup as StaticLookup>::Source: UnwindSafe,
Blanket Implementations§
§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> DecodeAll for Twhere
T: Decode,
impl<T> DecodeAll for Twhere T: Decode,
§fn decode_all(input: &mut &[u8]) -> Result<T, Error>
fn decode_all(input: &mut &[u8]) -> Result<T, Error>
Self
and consume all of the given input data. Read more§impl<T> DecodeLimit for Twhere
T: Decode,
impl<T> DecodeLimit for Twhere T: Decode,
§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>
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>
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<Q, K> Equivalent<K> for Qwhere
Q: Eq + ?Sized,
K: Borrow<Q> + ?Sized,
impl<Q, K> Equivalent<K> for Qwhere Q: Eq + ?Sized, K: Borrow<Q> + ?Sized,
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<T> Hashable for Twhere
T: Codec,
impl<T> Hashable for Twhere T: Codec,
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
§fn in_current_span(self) -> Instrumented<Self>
fn in_current_span(self) -> Instrumented<Self>
§impl<T> IsType<T> for T
impl<T> IsType<T> for T
§impl<T> KeyedVec for Twhere
T: Codec,
impl<T> KeyedVec for Twhere T: Codec,
§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>,
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
.§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
T
.