Struct pallet_scheduler::pallet::Pallet
source · pub struct Pallet<T>(PhantomData<T>);
Expand description
The Pallet
struct, the main type that implements traits and standalone
functions within the pallet.
Tuple Fields§
§0: PhantomData<T>
Implementations§
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn schedule(
origin: OriginFor<T>,
when: BlockNumberFor<T>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
call: Box<<T as Config>::RuntimeCall>,
) -> DispatchResult
pub fn schedule( origin: OriginFor<T>, when: BlockNumberFor<T>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, call: Box<<T as Config>::RuntimeCall>, ) -> DispatchResult
Anonymously schedule a task.
sourcepub fn cancel(
origin: OriginFor<T>,
when: BlockNumberFor<T>,
index: u32,
) -> DispatchResult
pub fn cancel( origin: OriginFor<T>, when: BlockNumberFor<T>, index: u32, ) -> DispatchResult
Cancel an anonymously scheduled task.
sourcepub fn schedule_named(
origin: OriginFor<T>,
id: TaskName,
when: BlockNumberFor<T>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
call: Box<<T as Config>::RuntimeCall>,
) -> DispatchResult
pub fn schedule_named( origin: OriginFor<T>, id: TaskName, when: BlockNumberFor<T>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, call: Box<<T as Config>::RuntimeCall>, ) -> DispatchResult
Schedule a named task.
sourcepub fn cancel_named(origin: OriginFor<T>, id: TaskName) -> DispatchResult
pub fn cancel_named(origin: OriginFor<T>, id: TaskName) -> DispatchResult
Cancel a named scheduled task.
sourcepub fn schedule_after(
origin: OriginFor<T>,
after: BlockNumberFor<T>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
call: Box<<T as Config>::RuntimeCall>,
) -> DispatchResult
pub fn schedule_after( origin: OriginFor<T>, after: BlockNumberFor<T>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, call: Box<<T as Config>::RuntimeCall>, ) -> DispatchResult
Anonymously schedule a task after a delay.
sourcepub fn schedule_named_after(
origin: OriginFor<T>,
id: TaskName,
after: BlockNumberFor<T>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
call: Box<<T as Config>::RuntimeCall>,
) -> DispatchResult
pub fn schedule_named_after( origin: OriginFor<T>, id: TaskName, after: BlockNumberFor<T>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, call: Box<<T as Config>::RuntimeCall>, ) -> DispatchResult
Schedule a named task after a delay.
sourcepub fn set_retry(
origin: OriginFor<T>,
task: TaskAddress<BlockNumberFor<T>>,
retries: u8,
period: BlockNumberFor<T>,
) -> DispatchResult
pub fn set_retry( origin: OriginFor<T>, task: TaskAddress<BlockNumberFor<T>>, retries: u8, period: BlockNumberFor<T>, ) -> DispatchResult
Set a retry configuration for a task so that, in case its scheduled run fails, it will
be retried after period
blocks, for a total amount of retries
retries or until it
succeeds.
Tasks which need to be scheduled for a retry are still subject to weight metering and agenda space, same as a regular task. If a periodic task fails, it will be scheduled normally while the task is retrying.
Tasks scheduled as a result of a retry for a periodic task are unnamed, non-periodic
clones of the original task. Their retry configuration will be derived from the
original task’s configuration, but will have a lower value for remaining
than the
original total_retries
.
sourcepub fn set_retry_named(
origin: OriginFor<T>,
id: TaskName,
retries: u8,
period: BlockNumberFor<T>,
) -> DispatchResult
pub fn set_retry_named( origin: OriginFor<T>, id: TaskName, retries: u8, period: BlockNumberFor<T>, ) -> DispatchResult
Set a retry configuration for a named task so that, in case its scheduled run fails, it
will be retried after period
blocks, for a total amount of retries
retries or until
it succeeds.
Tasks which need to be scheduled for a retry are still subject to weight metering and agenda space, same as a regular task. If a periodic task fails, it will be scheduled normally while the task is retrying.
Tasks scheduled as a result of a retry for a periodic task are unnamed, non-periodic
clones of the original task. Their retry configuration will be derived from the
original task’s configuration, but will have a lower value for remaining
than the
original total_retries
.
sourcepub fn cancel_retry(
origin: OriginFor<T>,
task: TaskAddress<BlockNumberFor<T>>,
) -> DispatchResult
pub fn cancel_retry( origin: OriginFor<T>, task: TaskAddress<BlockNumberFor<T>>, ) -> DispatchResult
Removes the retry configuration of a task.
sourcepub fn cancel_retry_named(origin: OriginFor<T>, id: TaskName) -> DispatchResult
pub fn cancel_retry_named(origin: OriginFor<T>, id: TaskName) -> DispatchResult
Cancel the retry configuration of a named task.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn migrate_v1_to_v4() -> Weight
pub fn migrate_v1_to_v4() -> Weight
Migrate storage format from V1 to V4.
Returns the weight consumed by this migration.
sourcepub fn migrate_v2_to_v4() -> Weight
pub fn migrate_v2_to_v4() -> Weight
Migrate storage format from V2 to V4.
Returns the weight consumed by this migration.
sourcepub fn migrate_v3_to_v4() -> Weight
pub fn migrate_v3_to_v4() -> Weight
Migrate storage format from V3 to V4.
Returns the weight consumed by this migration.
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub fn migrate_origin<OldOrigin: Into<T::PalletsOrigin> + Decode>()
pub fn migrate_origin<OldOrigin: Into<T::PalletsOrigin> + Decode>()
Helper to migrate scheduler when the pallet origin type has changed.
pub(crate) fn resolve_time( when: DispatchTime<BlockNumberFor<T>>, ) -> Result<BlockNumberFor<T>, DispatchError>
pub(crate) fn place_task( when: BlockNumberFor<T>, what: ScheduledOf<T>, ) -> Result<TaskAddress<BlockNumberFor<T>>, (DispatchError, ScheduledOf<T>)>
pub(crate) fn push_to_agenda( when: BlockNumberFor<T>, what: ScheduledOf<T>, ) -> Result<u32, (DispatchError, ScheduledOf<T>)>
sourcepub(crate) fn cleanup_agenda(when: BlockNumberFor<T>)
pub(crate) fn cleanup_agenda(when: BlockNumberFor<T>)
Remove trailing None
items of an agenda at when
. If all items are None
remove the
agenda record entirely.
pub(crate) fn do_schedule( when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: BoundedCallOf<T>, ) -> Result<TaskAddress<BlockNumberFor<T>>, DispatchError>
pub(crate) fn do_cancel( origin: Option<T::PalletsOrigin>, (when, index): TaskAddress<BlockNumberFor<T>>, ) -> Result<(), DispatchError>
pub(crate) fn do_reschedule( (when, index): TaskAddress<BlockNumberFor<T>>, new_time: DispatchTime<BlockNumberFor<T>>, ) -> Result<TaskAddress<BlockNumberFor<T>>, DispatchError>
pub(crate) fn do_schedule_named( id: TaskName, when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: BoundedCallOf<T>, ) -> Result<TaskAddress<BlockNumberFor<T>>, DispatchError>
pub(crate) fn do_cancel_named( origin: Option<T::PalletsOrigin>, id: TaskName, ) -> DispatchResult
pub(crate) fn do_reschedule_named( id: TaskName, new_time: DispatchTime<BlockNumberFor<T>>, ) -> Result<TaskAddress<BlockNumberFor<T>>, DispatchError>
pub(crate) fn do_cancel_retry( origin: &T::PalletsOrigin, (when, index): TaskAddress<BlockNumberFor<T>>, ) -> Result<(), DispatchError>
source§impl<T: Config> Pallet<T>
impl<T: Config> Pallet<T>
sourcepub(crate) fn service_agendas(
weight: &mut WeightMeter,
now: BlockNumberFor<T>,
max: u32,
)
pub(crate) fn service_agendas( weight: &mut WeightMeter, now: BlockNumberFor<T>, max: u32, )
Service up to max
agendas queue starting from earliest incompletely executed agenda.
sourcepub(crate) fn service_agenda(
weight: &mut WeightMeter,
executed: &mut u32,
now: BlockNumberFor<T>,
when: BlockNumberFor<T>,
max: u32,
) -> bool
pub(crate) fn service_agenda( weight: &mut WeightMeter, executed: &mut u32, now: BlockNumberFor<T>, when: BlockNumberFor<T>, max: u32, ) -> bool
Returns true
if the agenda was fully completed, false
if it should be revisited at a
later block.
sourcepub(crate) fn service_task(
weight: &mut WeightMeter,
now: BlockNumberFor<T>,
when: BlockNumberFor<T>,
agenda_index: u32,
is_first: bool,
task: ScheduledOf<T>,
) -> Result<(), (ServiceTaskError, Option<ScheduledOf<T>>)>
pub(crate) fn service_task( weight: &mut WeightMeter, now: BlockNumberFor<T>, when: BlockNumberFor<T>, agenda_index: u32, is_first: bool, task: ScheduledOf<T>, ) -> Result<(), (ServiceTaskError, Option<ScheduledOf<T>>)>
Service (i.e. execute) the given task, being careful not to overflow the weight
counter.
This involves:
- removing and potentially replacing the
Lookup
entry for the task. - realizing the task’s call which can include a preimage lookup.
- Rescheduling the task for execution in a later agenda if periodic.
sourcepub(crate) fn execute_dispatch(
weight: &mut WeightMeter,
origin: T::PalletsOrigin,
call: <T as Config>::RuntimeCall,
) -> Result<DispatchResult, ()>
pub(crate) fn execute_dispatch( weight: &mut WeightMeter, origin: T::PalletsOrigin, call: <T as Config>::RuntimeCall, ) -> Result<DispatchResult, ()>
Make a dispatch to the given call
from the given origin
, ensuring that the weight
counter does not exceed its limit and that it is counted accurately (e.g. accounted using
post info if available).
NOTE: Only the weight for this function will be counted (origin lookup, dispatch and the call itself).
Returns an error if the call is overweight.
sourcepub(crate) fn schedule_retry(
weight: &mut WeightMeter,
now: BlockNumberFor<T>,
when: BlockNumberFor<T>,
agenda_index: u32,
task: &ScheduledOf<T>,
retry_config: RetryConfig<BlockNumberFor<T>>,
)
pub(crate) fn schedule_retry( weight: &mut WeightMeter, now: BlockNumberFor<T>, when: BlockNumberFor<T>, agenda_index: u32, task: &ScheduledOf<T>, retry_config: RetryConfig<BlockNumberFor<T>>, )
Check if a task has a retry configuration in place and, if so, try to reschedule it.
Possible causes for failure to schedule a retry for a task:
- there wasn’t enough weight to run the task reschedule logic
- there was no retry configuration in place
- there were no more retry attempts left
- the agenda was full.
sourcepub(crate) fn ensure_privilege(
left: &<T as Config>::PalletsOrigin,
right: &<T as Config>::PalletsOrigin,
) -> Result<(), DispatchError>
pub(crate) fn ensure_privilege( left: &<T as Config>::PalletsOrigin, right: &<T as Config>::PalletsOrigin, ) -> Result<(), DispatchError>
Ensure that left
has at least the same level of privilege or higher than right
.
Returns an error if left
has a lower level of privilege or the two cannot be compared.
Trait Implementations§
source§impl<T: Config> Anon<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
impl<T: Config> Anon<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
§type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
v3
instead. Will be removed after September 2024.§type Hash = <T as Config>::Hash
type Hash = <T as Config>::Hash
v3
instead. Will be removed after September 2024.source§fn schedule(
when: DispatchTime<BlockNumberFor<T>>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
origin: T::PalletsOrigin,
call: CallOrHashOf<T>,
) -> Result<Self::Address, DispatchError>
fn schedule( when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: CallOrHashOf<T>, ) -> Result<Self::Address, DispatchError>
v3
instead. Will be removed after September 2024.source§fn cancel((when, index): Self::Address) -> Result<(), ()>
fn cancel((when, index): Self::Address) -> Result<(), ()>
v3
instead. Will be removed after September 2024.source§fn reschedule(
address: Self::Address,
when: DispatchTime<BlockNumberFor<T>>,
) -> Result<Self::Address, DispatchError>
fn reschedule( address: Self::Address, when: DispatchTime<BlockNumberFor<T>>, ) -> Result<Self::Address, DispatchError>
v3
instead. Will be removed after September 2024.reschedule_named
. Read moresource§impl<T: Config> Anon<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
impl<T: Config> Anon<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
§type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
source§fn schedule(
when: DispatchTime<BlockNumberFor<T>>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
origin: T::PalletsOrigin,
call: BoundedCallOf<T>,
) -> Result<Self::Address, DispatchError>
fn schedule( when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: BoundedCallOf<T>, ) -> Result<Self::Address, DispatchError>
source§fn cancel((when, index): Self::Address) -> Result<(), DispatchError>
fn cancel((when, index): Self::Address) -> Result<(), DispatchError>
source§fn reschedule(
address: Self::Address,
when: DispatchTime<BlockNumberFor<T>>,
) -> Result<Self::Address, DispatchError>
fn reschedule( address: Self::Address, when: DispatchTime<BlockNumberFor<T>>, ) -> Result<Self::Address, DispatchError>
reschedule_named
. Read moresource§fn next_dispatch_time(
(when, index): Self::Address,
) -> Result<BlockNumberFor<T>, DispatchError>
fn next_dispatch_time( (when, index): Self::Address, ) -> Result<BlockNumberFor<T>, DispatchError>
source§impl<T: Config> BeforeAllRuntimeMigrations for Pallet<T>
impl<T: Config> BeforeAllRuntimeMigrations for Pallet<T>
source§fn before_all_runtime_migrations() -> Weight
fn before_all_runtime_migrations() -> Weight
source§impl<T> Benchmarking for Pallet<T>where
T: Config + Config,
impl<T> Benchmarking for Pallet<T>where
T: Config + Config,
source§impl<T: Config> GetStorageVersion for Pallet<T>
impl<T: Config> GetStorageVersion for Pallet<T>
§type InCodeStorageVersion = StorageVersion
type InCodeStorageVersion = StorageVersion
source§fn in_code_storage_version() -> Self::InCodeStorageVersion
fn in_code_storage_version() -> Self::InCodeStorageVersion
storage_version
attribute, or
[NoStorageVersionSet
] if the attribute is missing.source§fn on_chain_storage_version() -> StorageVersion
fn on_chain_storage_version() -> StorageVersion
§fn current_storage_version() -> Self::InCodeStorageVersion
fn current_storage_version() -> Self::InCodeStorageVersion
in_code_storage_version
and will be removed after March 2024.Self::current_storage_version
] instead. Read moresource§impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> Hooks<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_initialize(now: BlockNumberFor<T>) -> Weight
fn on_initialize(now: BlockNumberFor<T>) -> Weight
Execute the scheduled calls
§fn on_finalize(_n: BlockNumber)
fn on_finalize(_n: BlockNumber)
§fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
fn on_idle(_n: BlockNumber, _remaining_weight: Weight) -> Weight
Hooks::on_finalize
]). Read more§fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)
fn on_poll(_n: BlockNumber, _weight: &mut WeightMeter)
§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Executive
pallet. Read more§fn offchain_worker(_n: BlockNumber)
fn offchain_worker(_n: BlockNumber)
§fn integrity_test()
fn integrity_test()
source§impl<T: Config> IntegrityTest for Pallet<T>
impl<T: Config> IntegrityTest for Pallet<T>
source§fn integrity_test()
fn integrity_test()
Hooks::integrity_test
].source§impl<T: Config> Named<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
impl<T: Config> Named<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
§type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
source§fn schedule_named(
id: TaskName,
when: DispatchTime<BlockNumberFor<T>>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
origin: T::PalletsOrigin,
call: BoundedCallOf<T>,
) -> Result<Self::Address, DispatchError>
fn schedule_named( id: TaskName, when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: BoundedCallOf<T>, ) -> Result<Self::Address, DispatchError>
source§fn cancel_named(id: TaskName) -> Result<(), DispatchError>
fn cancel_named(id: TaskName) -> Result<(), DispatchError>
source§fn reschedule_named(
id: TaskName,
when: DispatchTime<BlockNumberFor<T>>,
) -> Result<Self::Address, DispatchError>
fn reschedule_named( id: TaskName, when: DispatchTime<BlockNumberFor<T>>, ) -> Result<Self::Address, DispatchError>
source§fn next_dispatch_time(id: TaskName) -> Result<BlockNumberFor<T>, DispatchError>
fn next_dispatch_time(id: TaskName) -> Result<BlockNumberFor<T>, DispatchError>
source§impl<T: Config> Named<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
impl<T: Config> Named<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, <T as Config>::RuntimeCall, <T as Config>::PalletsOrigin> for Pallet<T>
§type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
type Address = (<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number, u32)
v3
instead. Will be removed after September 2024.§type Hash = <T as Config>::Hash
type Hash = <T as Config>::Hash
v3
instead. Will be removed after September 2024.source§fn schedule_named(
id: Vec<u8>,
when: DispatchTime<BlockNumberFor<T>>,
maybe_periodic: Option<Period<BlockNumberFor<T>>>,
priority: Priority,
origin: T::PalletsOrigin,
call: CallOrHashOf<T>,
) -> Result<Self::Address, ()>
fn schedule_named( id: Vec<u8>, when: DispatchTime<BlockNumberFor<T>>, maybe_periodic: Option<Period<BlockNumberFor<T>>>, priority: Priority, origin: T::PalletsOrigin, call: CallOrHashOf<T>, ) -> Result<Self::Address, ()>
v3
instead. Will be removed after September 2024.source§fn cancel_named(id: Vec<u8>) -> Result<(), ()>
fn cancel_named(id: Vec<u8>) -> Result<(), ()>
v3
instead. Will be removed after September 2024.source§fn reschedule_named(
id: Vec<u8>,
when: DispatchTime<BlockNumberFor<T>>,
) -> Result<Self::Address, DispatchError>
fn reschedule_named( id: Vec<u8>, when: DispatchTime<BlockNumberFor<T>>, ) -> Result<Self::Address, DispatchError>
v3
instead. Will be removed after September 2024.source§impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OffchainWorker<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn offchain_worker(n: BlockNumberFor<T>)
fn offchain_worker(n: BlockNumberFor<T>)
source§impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnFinalize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_finalize(n: BlockNumberFor<T>)
fn on_finalize(n: BlockNumberFor<T>)
Hooks::on_finalize
].source§impl<T: Config> OnGenesis for Pallet<T>
impl<T: Config> OnGenesis for Pallet<T>
source§fn on_genesis()
fn on_genesis()
source§impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnIdle<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnInitialize<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§fn on_initialize(n: BlockNumberFor<T>) -> Weight
fn on_initialize(n: BlockNumberFor<T>) -> Weight
Hooks::on_initialize
].source§impl<T: Config> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
impl<T: Config> OnPoll<<<<T as Config>::Block as HeaderProvider>::HeaderT as Header>::Number> for Pallet<T>
source§impl<T: Config> OnRuntimeUpgrade for Pallet<T>
impl<T: Config> OnRuntimeUpgrade for Pallet<T>
source§fn on_runtime_upgrade() -> Weight
fn on_runtime_upgrade() -> Weight
Hooks::on_runtime_upgrade
].source§impl<T: Config> PalletInfoAccess for Pallet<T>
impl<T: Config> PalletInfoAccess for Pallet<T>
source§fn module_name() -> &'static str
fn module_name() -> &'static str
source§fn crate_version() -> CrateVersion
fn crate_version() -> CrateVersion
source§impl<T> PartialEq for Pallet<T>
impl<T> PartialEq for Pallet<T>
source§impl<T: Config> WhitelistedStorageKeys for Pallet<T>
impl<T: Config> WhitelistedStorageKeys for Pallet<T>
source§fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
fn whitelisted_storage_keys() -> Vec<TrackedStorageKey>
Vec<TrackedStorageKey>
indicating the storage keys that
should be whitelisted during benchmarking. This means that those keys
will be excluded from the benchmarking performance calculation.impl<T> Eq for Pallet<T>
Auto Trait Implementations§
impl<T> Freeze for Pallet<T>
impl<T> RefUnwindSafe for Pallet<T>where
T: RefUnwindSafe,
impl<T> Send for Pallet<T>where
T: Send,
impl<T> Sync for Pallet<T>where
T: Sync,
impl<T> Unpin for Pallet<T>where
T: Unpin,
impl<T> UnwindSafe for Pallet<T>where
T: UnwindSafe,
Blanket Implementations§
§impl<T, BlockNumber, Call, RuntimeOrigin> Anon<BlockNumber, Call, RuntimeOrigin> for Twhere
T: Anon<BlockNumber, Call, RuntimeOrigin>,
impl<T, BlockNumber, Call, RuntimeOrigin> Anon<BlockNumber, Call, RuntimeOrigin> for Twhere
T: Anon<BlockNumber, Call, RuntimeOrigin>,
§type Address = <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address
type Address = <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address
v3
instead. Will be removed after September 2024.§fn schedule(
when: DispatchTime<BlockNumber>,
maybe_periodic: Option<(BlockNumber, u32)>,
priority: u8,
origin: RuntimeOrigin,
call: Call,
) -> Result<<T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
fn schedule( when: DispatchTime<BlockNumber>, maybe_periodic: Option<(BlockNumber, u32)>, priority: u8, origin: RuntimeOrigin, call: Call, ) -> Result<<T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
v3
instead. Will be removed after September 2024.§fn cancel(
address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address,
) -> Result<(), ()>
fn cancel( address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, ) -> Result<(), ()>
v3
instead. Will be removed after September 2024.§fn reschedule(
address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address,
when: DispatchTime<BlockNumber>,
) -> Result<<T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
fn reschedule( address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, when: DispatchTime<BlockNumber>, ) -> Result<<T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
v3
instead. Will be removed after September 2024.reschedule_named
. Read more§fn next_dispatch_time(
address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address,
) -> Result<BlockNumber, ()>
fn next_dispatch_time( address: <T as Anon<BlockNumber, Call, RuntimeOrigin>>::Address, ) -> Result<BlockNumber, ()>
v3
instead. Will be removed after September 2024.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>,
source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
source§default unsafe fn clone_to_uninit(&self, dst: *mut T)
default unsafe fn clone_to_uninit(&self, dst: *mut T)
clone_to_uninit
)§impl<T> Conv for T
impl<T> Conv for T
source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> FmtForward for T
impl<T> FmtForward for T
§fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
fn fmt_binary(self) -> FmtBinary<Self>where
Self: Binary,
self
to use its Binary
implementation when Debug
-formatted.§fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
fn fmt_display(self) -> FmtDisplay<Self>where
Self: Display,
self
to use its Display
implementation when
Debug
-formatted.§fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
fn fmt_lower_exp(self) -> FmtLowerExp<Self>where
Self: LowerExp,
self
to use its LowerExp
implementation when
Debug
-formatted.§fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
fn fmt_lower_hex(self) -> FmtLowerHex<Self>where
Self: LowerHex,
self
to use its LowerHex
implementation when
Debug
-formatted.§fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
fn fmt_octal(self) -> FmtOctal<Self>where
Self: Octal,
self
to use its Octal
implementation when Debug
-formatted.§fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
fn fmt_pointer(self) -> FmtPointer<Self>where
Self: Pointer,
self
to use its Pointer
implementation when
Debug
-formatted.§fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
fn fmt_upper_exp(self) -> FmtUpperExp<Self>where
Self: UpperExp,
self
to use its UpperExp
implementation when
Debug
-formatted.§fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
fn fmt_upper_hex(self) -> FmtUpperHex<Self>where
Self: UpperHex,
self
to use its UpperHex
implementation when
Debug
-formatted.§fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
fn fmt_list(self) -> FmtList<Self>where
&'a Self: for<'a> IntoIterator,
§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>
source§impl<T> IntoEither for T
impl<T> IntoEither for T
source§fn into_either(self, into_left: bool) -> Either<Self, Self>
fn into_either(self, into_left: bool) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left
is true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read moresource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
self
into a Left
variant of Either<Self, Self>
if into_left(&self)
returns true
.
Converts self
into a Right
variant of Either<Self, Self>
otherwise. Read more§impl<T> IsType<T> for T
impl<T> IsType<T> for T
§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§impl<T, BlockNumber, Call, RuntimeOrigin> Named<BlockNumber, Call, RuntimeOrigin> for Twhere
T: Named<BlockNumber, Call, RuntimeOrigin>,
impl<T, BlockNumber, Call, RuntimeOrigin> Named<BlockNumber, Call, RuntimeOrigin> for Twhere
T: Named<BlockNumber, Call, RuntimeOrigin>,
§type Address = <T as Named<BlockNumber, Call, RuntimeOrigin>>::Address
type Address = <T as Named<BlockNumber, Call, RuntimeOrigin>>::Address
v3
instead. Will be removed after September 2024.§fn schedule_named(
id: Vec<u8>,
when: DispatchTime<BlockNumber>,
maybe_periodic: Option<(BlockNumber, u32)>,
priority: u8,
origin: RuntimeOrigin,
call: Call,
) -> Result<<T as Named<BlockNumber, Call, RuntimeOrigin>>::Address, ()>
fn schedule_named( id: Vec<u8>, when: DispatchTime<BlockNumber>, maybe_periodic: Option<(BlockNumber, u32)>, priority: u8, origin: RuntimeOrigin, call: Call, ) -> Result<<T as Named<BlockNumber, Call, RuntimeOrigin>>::Address, ()>
v3
instead. Will be removed after September 2024.§fn cancel_named(id: Vec<u8>) -> Result<(), ()>
fn cancel_named(id: Vec<u8>) -> Result<(), ()>
v3
instead. Will be removed after September 2024.§fn reschedule_named(
id: Vec<u8>,
when: DispatchTime<BlockNumber>,
) -> Result<<T as Named<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
fn reschedule_named( id: Vec<u8>, when: DispatchTime<BlockNumber>, ) -> Result<<T as Named<BlockNumber, Call, RuntimeOrigin>>::Address, DispatchError>
v3
instead. Will be removed after September 2024.§impl<T> Pipe for Twhere
T: ?Sized,
impl<T> Pipe for Twhere
T: ?Sized,
§fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
fn pipe<R>(self, func: impl FnOnce(Self) -> R) -> Rwhere
Self: Sized,
§fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref<'a, R>(&'a self, func: impl FnOnce(&'a Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
fn pipe_ref_mut<'a, R>(&'a mut self, func: impl FnOnce(&'a mut Self) -> R) -> Rwhere
R: 'a,
self
and passes that borrow into the pipe function. Read more§fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
fn pipe_borrow<'a, B, R>(&'a self, func: impl FnOnce(&'a B) -> R) -> R
§fn pipe_borrow_mut<'a, B, R>(
&'a mut self,
func: impl FnOnce(&'a mut B) -> R,
) -> R
fn pipe_borrow_mut<'a, B, R>( &'a mut self, func: impl FnOnce(&'a mut B) -> R, ) -> R
§fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
fn pipe_as_ref<'a, U, R>(&'a self, func: impl FnOnce(&'a U) -> R) -> R
self
, then passes self.as_ref()
into the pipe function.§fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
fn pipe_as_mut<'a, U, R>(&'a mut self, func: impl FnOnce(&'a mut U) -> R) -> R
self
, then passes self.as_mut()
into the pipe
function.§fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
fn pipe_deref<'a, T, R>(&'a self, func: impl FnOnce(&'a T) -> R) -> R
self
, then passes self.deref()
into the pipe function.§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<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
impl<SS, SP> SupersetOf<SS> for SPwhere
SS: SubsetOf<SP>,
§fn to_subset(&self) -> Option<SS>
fn to_subset(&self) -> Option<SS>
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
self
is actually part of its subset T
(and can be converted to it).§fn to_subset_unchecked(&self) -> SS
fn to_subset_unchecked(&self) -> SS
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
self
to the equivalent element of its superset.§impl<T> Tap for T
impl<T> Tap for T
§fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow<B>(self, func: impl FnOnce(&B)) -> Self
Borrow<B>
of a value. Read more§fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut<B>(self, func: impl FnOnce(&mut B)) -> Self
BorrowMut<B>
of a value. Read more§fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref<R>(self, func: impl FnOnce(&R)) -> Self
AsRef<R>
view of a value. Read more§fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut<R>(self, func: impl FnOnce(&mut R)) -> Self
AsMut<R>
view of a value. Read more§fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref<T>(self, func: impl FnOnce(&T)) -> Self
Deref::Target
of a value. Read more§fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
fn tap_deref_mut<T>(self, func: impl FnOnce(&mut T)) -> Self
Deref::Target
of a value. Read more§fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
fn tap_dbg(self, func: impl FnOnce(&Self)) -> Self
.tap()
only in debug builds, and is erased in release builds.§fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
fn tap_mut_dbg(self, func: impl FnOnce(&mut Self)) -> Self
.tap_mut()
only in debug builds, and is erased in release
builds.§fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
fn tap_borrow_dbg<B>(self, func: impl FnOnce(&B)) -> Self
.tap_borrow()
only in debug builds, and is erased in release
builds.§fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
fn tap_borrow_mut_dbg<B>(self, func: impl FnOnce(&mut B)) -> Self
.tap_borrow_mut()
only in debug builds, and is erased in release
builds.§fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
fn tap_ref_dbg<R>(self, func: impl FnOnce(&R)) -> Self
.tap_ref()
only in debug builds, and is erased in release
builds.§fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
fn tap_ref_mut_dbg<R>(self, func: impl FnOnce(&mut R)) -> Self
.tap_ref_mut()
only in debug builds, and is erased in release
builds.§fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
fn tap_deref_dbg<T>(self, func: impl FnOnce(&T)) -> Self
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
§impl<T, U> TryIntoKey<U> for Twhere
U: TryFromKey<T>,
impl<T, U> TryIntoKey<U> for Twhere
U: TryFromKey<T>,
type Error = <U as TryFromKey<T>>::Error
fn try_into_key(self) -> Result<U, <U as TryFromKey<T>>::Error>
§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 S
impl<T, S> UniqueSaturatedInto<T> for S
§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
T
.