Trait Config

Source
pub trait Config: Config {
    type RuntimeEvent: From<Event> + IsType<<Self as Config>::RuntimeEvent>;
    type ValidatorId: Member + Parameter + MaybeSerializeDeserialize + MaxEncodedLen + Into<Self::AccountId>;
    type ShouldEndSession: ShouldEndSession<BlockNumberFor<Self>>;
    type NextSessionRotation: EstimateNextSessionRotation<BlockNumberFor<Self>>;
    type SessionManager: SessionManager<Self::ValidatorId, Self::Keys>;
    type SessionHandler: SessionHandler<Self::ValidatorId>;
    type Keys: OpaqueKeys + Member + Parameter + MaybeSerializeDeserialize;
}
Expand description

Configuration trait of this pallet.

The main purpose of this trait is to act as an interface between this pallet and the runtime in which it is embedded in. A type, function, or constant in this trait is essentially left to be configured by the runtime that includes this pallet.

Consequently, a runtime that wants to include this pallet must implement this trait.

Required Associated Types§

Source

type RuntimeEvent: From<Event> + IsType<<Self as Config>::RuntimeEvent>

The overarching event type.

Source

type ValidatorId: Member + Parameter + MaybeSerializeDeserialize + MaxEncodedLen + Into<Self::AccountId>

A stable ID for a validator.

Source

type ShouldEndSession: ShouldEndSession<BlockNumberFor<Self>>

Indicator for when to end the session.

Source

type NextSessionRotation: EstimateNextSessionRotation<BlockNumberFor<Self>>

Something that can predict the next session rotation. This should typically come from the same logical unit that provides ShouldEndSession, yet, it gives a best effort estimate. It is helpful to implement [EstimateNextNewSession].

Source

type SessionManager: SessionManager<Self::ValidatorId, Self::Keys>

Handler for managing new session.

Source

type SessionHandler: SessionHandler<Self::ValidatorId>

Handler when a session has changed.

Source

type Keys: OpaqueKeys + Member + Parameter + MaybeSerializeDeserialize

The keys.

Dyn Compatibility§

This trait is not dyn compatible.

In older versions of Rust, dyn compatibility was called "object safety", so this trait is not object safe.

Implementors§