Struct pallet_grandpa::Module [−][src]
pub struct Module<T: Config>(_);
Implementations
impl<T: Config + 'static> Module<T>
[src]
impl<T: Config + 'static> Module<T>
[src]pub fn state() -> StoredState<T::BlockNumber>
[src]
State of the current authority set.
pub fn pending_change() -> Option<StoredPendingChange<T::BlockNumber>>
[src]
Pending change: (signaled at, scheduled change).
pub fn next_forced() -> Option<T::BlockNumber>
[src]
next block number where we can force a change.
pub fn stalled() -> Option<(T::BlockNumber, T::BlockNumber)>
[src]
true
if we are currently stalled.
pub fn current_set_id() -> SetId
[src]
The number of changes (both in terms of keys and underlying economic responsibilities) in the “set” of Grandpa validators from genesis.
pub fn session_for_set<K: EncodeLike<SetId>>(key: K) -> Option<SessionIndex>
[src]
A mapping from grandpa set ID to the index of the most recent session for which its members were responsible.
TWOX-NOTE: SetId
is not under user control.
impl<T: Config> Module<T>
[src]
impl<T: Config> Module<T>
[src]pub fn grandpa_authorities() -> AuthorityList
[src]
Get the current set of authorities, along with their respective weights.
pub fn schedule_pause(in_blocks: T::BlockNumber) -> DispatchResult
[src]
Schedule GRANDPA to pause starting in the given number of blocks. Cannot be done when already paused.
pub fn schedule_resume(in_blocks: T::BlockNumber) -> DispatchResult
[src]
Schedule a resume of GRANDPA after pausing.
pub fn schedule_change(
next_authorities: AuthorityList,
in_blocks: T::BlockNumber,
forced: Option<T::BlockNumber>
) -> DispatchResult
[src]
next_authorities: AuthorityList,
in_blocks: T::BlockNumber,
forced: Option<T::BlockNumber>
) -> DispatchResult
Schedule a change in the authorities.
The change will be applied at the end of execution of the block
in_blocks
after the current block. This value may be 0, in which
case the change is applied at the end of the current block.
If the forced
parameter is defined, this indicates that the current
set has been synchronously determined to be offline and that after
in_blocks
the given change should be applied. The given block number
indicates the median last finalized block number and it should be used
as the canon block when starting the new grandpa voter.
No change should be signaled while any change is pending. Returns an error if a change is already pending.
pub fn submit_unsigned_equivocation_report(
equivocation_proof: EquivocationProof<T::Hash, T::BlockNumber>,
key_owner_proof: T::KeyOwnerProof
) -> Option<()>
[src]
equivocation_proof: EquivocationProof<T::Hash, T::BlockNumber>,
key_owner_proof: T::KeyOwnerProof
) -> Option<()>
Submits an extrinsic to report an equivocation. This method will create
an unsigned extrinsic with a call to report_equivocation_unsigned
and
will push the transaction to the pool. Only useful in an offchain
context.
Trait Implementations
impl<T: Config> BoundToRuntimeAppPublic for Module<T>
[src]
impl<T: Config> BoundToRuntimeAppPublic for Module<T>
[src]type Public = AuthorityId
The RuntimeAppPublic
this type is bound to.
impl<T: Config> GetPalletVersion for Module<T>
[src]
impl<T: Config> GetPalletVersion for Module<T>
[src]fn current_version() -> PalletVersion
[src]
fn storage_version() -> Option<PalletVersion>
[src]
impl<T: Config> IntegrityTest for Module<T>
[src]
impl<T: Config> IntegrityTest for Module<T>
[src]pub fn integrity_test()
[src]
impl<T: Config> ModuleErrorMetadata for Module<T>
[src]
impl<T: Config> ModuleErrorMetadata for Module<T>
[src]impl<T: Config + Config> OffchainWorker<<T as Config>::BlockNumber> for Module<T>
[src]
impl<T: Config + Config> OffchainWorker<<T as Config>::BlockNumber> for Module<T>
[src]pub fn offchain_worker(_n: BlockNumber)
[src]
impl<T: Config + Config> OnFinalize<<T as Config>::BlockNumber> for Module<T>
[src]
impl<T: Config + Config> OnFinalize<<T as Config>::BlockNumber> for Module<T>
[src]fn on_finalize(block_number: T::BlockNumber)
[src]
impl<T: Config + Config> OnInitialize<<T as Config>::BlockNumber> for Module<T>
[src]
impl<T: Config + Config> OnInitialize<<T as Config>::BlockNumber> for Module<T>
[src]pub fn on_initialize(_n: BlockNumber) -> u64
[src]
impl<T: Config> OnRuntimeUpgrade for Module<T>
[src]
impl<T: Config> OnRuntimeUpgrade for Module<T>
[src]fn on_runtime_upgrade() -> Weight
[src]
impl<T: Config> OneSessionHandler<<T as Config>::AccountId> for Module<T> where
T: Config,
[src]
impl<T: Config> OneSessionHandler<<T as Config>::AccountId> for Module<T> where
T: Config,
[src]type Key = AuthorityId
The key type expected.
fn on_genesis_session<'a, I: 'a>(validators: I) where
I: Iterator<Item = (&'a T::AccountId, AuthorityId)>,
[src]
I: Iterator<Item = (&'a T::AccountId, AuthorityId)>,
fn on_new_session<'a, I: 'a>(
changed: bool,
validators: I,
_queued_validators: I
) where
I: Iterator<Item = (&'a T::AccountId, AuthorityId)>,
[src]
changed: bool,
validators: I,
_queued_validators: I
) where
I: Iterator<Item = (&'a T::AccountId, AuthorityId)>,
fn on_disabled(i: usize)
[src]
pub fn on_before_session_ending()
[src]
impl<T: Config> ValidateUnsigned for Module<T>
[src]
impl<T: Config> ValidateUnsigned for Module<T>
[src]A ValidateUnsigned
implementation that restricts calls to report_equivocation_unsigned
to local calls (i.e. extrinsics generated on this node) or that already in a block. This
guarantees that only block authors can include unsigned equivocation reports.
type Call = Call<T>
The call to validate
fn validate_unsigned(
source: TransactionSource,
call: &Self::Call
) -> TransactionValidity
[src]
source: TransactionSource,
call: &Self::Call
) -> TransactionValidity
fn pre_dispatch(call: &Self::Call) -> Result<(), TransactionValidityError>
[src]
impl<T: Copy + Config> Copy for Module<T>
[src]
impl<T: Eq + Config> Eq for Module<T>
[src]
impl<T: Config> StructuralEq for Module<T>
[src]
impl<T: Config> StructuralPartialEq for Module<T>
[src]
Auto Trait Implementations
impl<T> RefUnwindSafe for Module<T> where
T: RefUnwindSafe,
T: RefUnwindSafe,
impl<T> Send for Module<T> where
T: Send,
T: Send,
impl<T> Sync for Module<T> where
T: Sync,
T: Sync,
impl<T> Unpin for Module<T> where
T: Unpin,
T: Unpin,
impl<T> UnwindSafe for Module<T> where
T: UnwindSafe,
T: UnwindSafe,
Blanket Implementations
impl<T> CheckedConversion for 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<Q, K> Equivalent<K> for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
[src]
impl<Q, K> Equivalent<K> for Q where
K: Borrow<Q> + ?Sized,
Q: Eq + ?Sized,
[src]pub fn equivalent(&self, key: &K) -> bool
[src]
impl<T> Instrument for T
[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, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]
impl<T, Outer> IsWrappedBy<Outer> for T where
T: From<Outer>,
Outer: AsRef<T> + AsMut<T> + From<T>,
[src]impl<T> SaturatedConversion for T
[src]
impl<T> SaturatedConversion for T
[src]pub fn saturated_from<T>(t: T) -> Self where
Self: UniqueSaturatedFrom<T>,
[src]
Self: UniqueSaturatedFrom<T>,
pub fn saturated_into<T>(self) -> T where
Self: UniqueSaturatedInto<T>,
[src]
Self: UniqueSaturatedInto<T>,
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]
impl<S, T> UncheckedInto<T> for S where
T: UncheckedFrom<S>,
[src]pub fn unchecked_into(self) -> T
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]
impl<T, S> UniqueSaturatedInto<T> for S where
T: Bounded,
S: TryInto<T>,
[src]pub fn unique_saturated_into(self) -> T
[src]
impl<T> MaybeDebug for T where
T: Debug,
[src]
T: Debug,
impl<T> MaybeDebug for T where
T: Debug,
[src]
T: Debug,
impl<T> MaybeRefUnwindSafe for T where
T: RefUnwindSafe,
[src]
T: RefUnwindSafe,
impl<T> Member for T where
T: 'static + Send + Sync + Debug + Eq + PartialEq<T> + Clone,
[src]
T: 'static + Send + Sync + Debug + Eq + PartialEq<T> + Clone,