Struct polkadot_service::Overseer
pub struct Overseer<S, SupportsParachains> {
pub activation_external_listeners: HashMap<H256, Vec<Sender<Result<(), SubsystemError>>>>,
pub active_leaves: HashMap<H256, u32>,
pub supports_parachains: SupportsParachains,
pub metrics: Metrics,
/* private fields */
}
Expand description
The orchestra.
Fields§
§activation_external_listeners: HashMap<H256, Vec<Sender<Result<(), SubsystemError>>>>
A user specified addendum field.
active_leaves: HashMap<H256, u32>
A user specified addendum field.
supports_parachains: SupportsParachains
A user specified addendum field.
metrics: Metrics
A user specified addendum field.
Implementations§
§impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
S: Spawner,
impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
S: Spawner,
pub async fn wait_terminate(
&mut self,
signal: OverseerSignal,
timeout: Duration,
) -> Result<(), SubsystemError>
pub async fn wait_terminate( &mut self, signal: OverseerSignal, timeout: Duration, ) -> Result<(), SubsystemError>
Send the given signal, a termination signal, to all subsystems and wait for all subsystems to go down.
The definition of a termination signal is up to the user and implementation specific.
pub async fn broadcast_signal<'a>(
&'a mut self,
signal: OverseerSignal,
) -> Result<(), SubsystemError>
pub async fn broadcast_signal<'a>( &'a mut self, signal: OverseerSignal, ) -> Result<(), SubsystemError>
Broadcast a signal to all subsystems.
pub async fn route_message(
&mut self,
message: AllMessages,
origin: &'static str,
) -> Result<(), SubsystemError>
pub async fn route_message( &mut self, message: AllMessages, origin: &'static str, ) -> Result<(), SubsystemError>
Route a particular message to a subsystem that consumes the message.
pub fn map_subsystems<'a, Mapper, Output>(
&'a self,
mapper: Mapper,
) -> Vec<Output>where
Mapper: MapSubsystem<&'a OrchestratedSubsystem<CandidateValidationMessage>, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output> + MapSubsystem<&'a OrchestratedSubsystem<PvfCheckerMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CandidateBackingMessage>> + MapSubsystem<&'a OrchestratedSubsystem<StatementDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityRecoveryMessage>> + MapSubsystem<&'a OrchestratedSubsystem<BitfieldSigningMessage>> + MapSubsystem<&'a OrchestratedSubsystem<BitfieldDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ProvisionerMessage>> + MapSubsystem<&'a OrchestratedSubsystem<RuntimeApiMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityStoreMessage>> + MapSubsystem<&'a OrchestratedSubsystem<NetworkBridgeRxMessage>> + MapSubsystem<&'a OrchestratedSubsystem<NetworkBridgeTxMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ChainApiMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CollationGenerationMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CollatorProtocolMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalVotingMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalVotingParallelMessage>> + MapSubsystem<&'a OrchestratedSubsystem<GossipSupportMessage>> + MapSubsystem<&'a OrchestratedSubsystem<DisputeCoordinatorMessage>> + MapSubsystem<&'a OrchestratedSubsystem<DisputeDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ChainSelectionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ProspectiveParachainsMessage>>,
pub fn map_subsystems<'a, Mapper, Output>(
&'a self,
mapper: Mapper,
) -> Vec<Output>where
Mapper: MapSubsystem<&'a OrchestratedSubsystem<CandidateValidationMessage>, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output, Output = Output> + MapSubsystem<&'a OrchestratedSubsystem<PvfCheckerMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CandidateBackingMessage>> + MapSubsystem<&'a OrchestratedSubsystem<StatementDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityRecoveryMessage>> + MapSubsystem<&'a OrchestratedSubsystem<BitfieldSigningMessage>> + MapSubsystem<&'a OrchestratedSubsystem<BitfieldDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ProvisionerMessage>> + MapSubsystem<&'a OrchestratedSubsystem<RuntimeApiMessage>> + MapSubsystem<&'a OrchestratedSubsystem<AvailabilityStoreMessage>> + MapSubsystem<&'a OrchestratedSubsystem<NetworkBridgeRxMessage>> + MapSubsystem<&'a OrchestratedSubsystem<NetworkBridgeTxMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ChainApiMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CollationGenerationMessage>> + MapSubsystem<&'a OrchestratedSubsystem<CollatorProtocolMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalVotingMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ApprovalVotingParallelMessage>> + MapSubsystem<&'a OrchestratedSubsystem<GossipSupportMessage>> + MapSubsystem<&'a OrchestratedSubsystem<DisputeCoordinatorMessage>> + MapSubsystem<&'a OrchestratedSubsystem<DisputeDistributionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ChainSelectionMessage>> + MapSubsystem<&'a OrchestratedSubsystem<ProspectiveParachainsMessage>>,
Extract information from each subsystem.
§impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
S: Spawner,
impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
S: Spawner,
pub fn builder<CandidateValidation, PvfChecker, CandidateBacking, StatementDistribution, AvailabilityDistribution, AvailabilityRecovery, BitfieldSigning, BitfieldDistribution, Provisioner, RuntimeApi, AvailabilityStore, NetworkBridgeRx, NetworkBridgeTx, ChainApi, CollationGeneration, CollatorProtocol, ApprovalDistribution, ApprovalVoting, ApprovalVotingParallel, GossipSupport, DisputeCoordinator, DisputeDistribution, ChainSelection, ProspectiveParachains>() -> OverseerBuilder<Missing<S>, Missing<CandidateValidation>, Missing<PvfChecker>, Missing<CandidateBacking>, Missing<StatementDistribution>, Missing<AvailabilityDistribution>, Missing<AvailabilityRecovery>, Missing<BitfieldSigning>, Missing<BitfieldDistribution>, Missing<Provisioner>, Missing<RuntimeApi>, Missing<AvailabilityStore>, Missing<NetworkBridgeRx>, Missing<NetworkBridgeTx>, Missing<ChainApi>, Missing<CollationGeneration>, Missing<CollatorProtocol>, Missing<ApprovalDistribution>, Missing<ApprovalVoting>, Missing<ApprovalVotingParallel>, Missing<GossipSupport>, Missing<DisputeCoordinator>, Missing<DisputeDistribution>, Missing<ChainSelection>, Missing<ProspectiveParachains>, Missing<HashMap<H256, Vec<Sender<Result<(), SubsystemError>>>>>, Missing<HashMap<H256, u32>>, Missing<SupportsParachains>, Missing<Metrics>>where
CandidateValidation: Subsystem<OverseerSubsystemContext<CandidateValidationMessage>, SubsystemError>,
<OverseerSubsystemContext<CandidateValidationMessage> as CandidateValidationContextTrait>::Sender: CandidateValidationSenderTrait,
OverseerSubsystemContext<CandidateValidationMessage>: CandidateValidationContextTrait,
PvfChecker: Subsystem<OverseerSubsystemContext<PvfCheckerMessage>, SubsystemError>,
<OverseerSubsystemContext<PvfCheckerMessage> as PvfCheckerContextTrait>::Sender: PvfCheckerSenderTrait,
OverseerSubsystemContext<PvfCheckerMessage>: PvfCheckerContextTrait,
CandidateBacking: Subsystem<OverseerSubsystemContext<CandidateBackingMessage>, SubsystemError>,
<OverseerSubsystemContext<CandidateBackingMessage> as CandidateBackingContextTrait>::Sender: CandidateBackingSenderTrait,
OverseerSubsystemContext<CandidateBackingMessage>: CandidateBackingContextTrait,
StatementDistribution: Subsystem<OverseerSubsystemContext<StatementDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<StatementDistributionMessage> as StatementDistributionContextTrait>::Sender: StatementDistributionSenderTrait,
OverseerSubsystemContext<StatementDistributionMessage>: StatementDistributionContextTrait,
AvailabilityDistribution: Subsystem<OverseerSubsystemContext<AvailabilityDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityDistributionMessage> as AvailabilityDistributionContextTrait>::Sender: AvailabilityDistributionSenderTrait,
OverseerSubsystemContext<AvailabilityDistributionMessage>: AvailabilityDistributionContextTrait,
AvailabilityRecovery: Subsystem<OverseerSubsystemContext<AvailabilityRecoveryMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityRecoveryMessage> as AvailabilityRecoveryContextTrait>::Sender: AvailabilityRecoverySenderTrait,
OverseerSubsystemContext<AvailabilityRecoveryMessage>: AvailabilityRecoveryContextTrait,
BitfieldSigning: Subsystem<OverseerSubsystemContext<BitfieldSigningMessage>, SubsystemError>,
<OverseerSubsystemContext<BitfieldSigningMessage> as BitfieldSigningContextTrait>::Sender: BitfieldSigningSenderTrait,
OverseerSubsystemContext<BitfieldSigningMessage>: BitfieldSigningContextTrait,
BitfieldDistribution: Subsystem<OverseerSubsystemContext<BitfieldDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<BitfieldDistributionMessage> as BitfieldDistributionContextTrait>::Sender: BitfieldDistributionSenderTrait,
OverseerSubsystemContext<BitfieldDistributionMessage>: BitfieldDistributionContextTrait,
Provisioner: Subsystem<OverseerSubsystemContext<ProvisionerMessage>, SubsystemError>,
<OverseerSubsystemContext<ProvisionerMessage> as ProvisionerContextTrait>::Sender: ProvisionerSenderTrait,
OverseerSubsystemContext<ProvisionerMessage>: ProvisionerContextTrait,
RuntimeApi: Subsystem<OverseerSubsystemContext<RuntimeApiMessage>, SubsystemError>,
<OverseerSubsystemContext<RuntimeApiMessage> as RuntimeApiContextTrait>::Sender: RuntimeApiSenderTrait,
OverseerSubsystemContext<RuntimeApiMessage>: RuntimeApiContextTrait,
AvailabilityStore: Subsystem<OverseerSubsystemContext<AvailabilityStoreMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityStoreMessage> as AvailabilityStoreContextTrait>::Sender: AvailabilityStoreSenderTrait,
OverseerSubsystemContext<AvailabilityStoreMessage>: AvailabilityStoreContextTrait,
NetworkBridgeRx: Subsystem<OverseerSubsystemContext<NetworkBridgeRxMessage>, SubsystemError>,
<OverseerSubsystemContext<NetworkBridgeRxMessage> as NetworkBridgeRxContextTrait>::Sender: NetworkBridgeRxSenderTrait,
OverseerSubsystemContext<NetworkBridgeRxMessage>: NetworkBridgeRxContextTrait,
NetworkBridgeTx: Subsystem<OverseerSubsystemContext<NetworkBridgeTxMessage>, SubsystemError>,
<OverseerSubsystemContext<NetworkBridgeTxMessage> as NetworkBridgeTxContextTrait>::Sender: NetworkBridgeTxSenderTrait,
OverseerSubsystemContext<NetworkBridgeTxMessage>: NetworkBridgeTxContextTrait,
ChainApi: Subsystem<OverseerSubsystemContext<ChainApiMessage>, SubsystemError>,
<OverseerSubsystemContext<ChainApiMessage> as ChainApiContextTrait>::Sender: ChainApiSenderTrait,
OverseerSubsystemContext<ChainApiMessage>: ChainApiContextTrait,
CollationGeneration: Subsystem<OverseerSubsystemContext<CollationGenerationMessage>, SubsystemError>,
<OverseerSubsystemContext<CollationGenerationMessage> as CollationGenerationContextTrait>::Sender: CollationGenerationSenderTrait,
OverseerSubsystemContext<CollationGenerationMessage>: CollationGenerationContextTrait,
CollatorProtocol: Subsystem<OverseerSubsystemContext<CollatorProtocolMessage>, SubsystemError>,
<OverseerSubsystemContext<CollatorProtocolMessage> as CollatorProtocolContextTrait>::Sender: CollatorProtocolSenderTrait,
OverseerSubsystemContext<CollatorProtocolMessage>: CollatorProtocolContextTrait,
ApprovalDistribution: Subsystem<OverseerSubsystemContext<ApprovalDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalDistributionMessage> as ApprovalDistributionContextTrait>::Sender: ApprovalDistributionSenderTrait,
OverseerSubsystemContext<ApprovalDistributionMessage>: ApprovalDistributionContextTrait,
ApprovalVoting: Subsystem<OverseerSubsystemContext<ApprovalVotingMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalVotingMessage> as ApprovalVotingContextTrait>::Sender: ApprovalVotingSenderTrait,
OverseerSubsystemContext<ApprovalVotingMessage>: ApprovalVotingContextTrait,
ApprovalVotingParallel: Subsystem<OverseerSubsystemContext<ApprovalVotingParallelMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalVotingParallelMessage> as ApprovalVotingParallelContextTrait>::Sender: ApprovalVotingParallelSenderTrait,
OverseerSubsystemContext<ApprovalVotingParallelMessage>: ApprovalVotingParallelContextTrait,
GossipSupport: Subsystem<OverseerSubsystemContext<GossipSupportMessage>, SubsystemError>,
<OverseerSubsystemContext<GossipSupportMessage> as GossipSupportContextTrait>::Sender: GossipSupportSenderTrait,
OverseerSubsystemContext<GossipSupportMessage>: GossipSupportContextTrait,
DisputeCoordinator: Subsystem<OverseerSubsystemContext<DisputeCoordinatorMessage>, SubsystemError>,
<OverseerSubsystemContext<DisputeCoordinatorMessage> as DisputeCoordinatorContextTrait>::Sender: DisputeCoordinatorSenderTrait,
OverseerSubsystemContext<DisputeCoordinatorMessage>: DisputeCoordinatorContextTrait,
DisputeDistribution: Subsystem<OverseerSubsystemContext<DisputeDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<DisputeDistributionMessage> as DisputeDistributionContextTrait>::Sender: DisputeDistributionSenderTrait,
OverseerSubsystemContext<DisputeDistributionMessage>: DisputeDistributionContextTrait,
ChainSelection: Subsystem<OverseerSubsystemContext<ChainSelectionMessage>, SubsystemError>,
<OverseerSubsystemContext<ChainSelectionMessage> as ChainSelectionContextTrait>::Sender: ChainSelectionSenderTrait,
OverseerSubsystemContext<ChainSelectionMessage>: ChainSelectionContextTrait,
ProspectiveParachains: Subsystem<OverseerSubsystemContext<ProspectiveParachainsMessage>, SubsystemError>,
<OverseerSubsystemContext<ProspectiveParachainsMessage> as ProspectiveParachainsContextTrait>::Sender: ProspectiveParachainsSenderTrait,
OverseerSubsystemContext<ProspectiveParachainsMessage>: ProspectiveParachainsContextTrait,
pub fn builder<CandidateValidation, PvfChecker, CandidateBacking, StatementDistribution, AvailabilityDistribution, AvailabilityRecovery, BitfieldSigning, BitfieldDistribution, Provisioner, RuntimeApi, AvailabilityStore, NetworkBridgeRx, NetworkBridgeTx, ChainApi, CollationGeneration, CollatorProtocol, ApprovalDistribution, ApprovalVoting, ApprovalVotingParallel, GossipSupport, DisputeCoordinator, DisputeDistribution, ChainSelection, ProspectiveParachains>() -> OverseerBuilder<Missing<S>, Missing<CandidateValidation>, Missing<PvfChecker>, Missing<CandidateBacking>, Missing<StatementDistribution>, Missing<AvailabilityDistribution>, Missing<AvailabilityRecovery>, Missing<BitfieldSigning>, Missing<BitfieldDistribution>, Missing<Provisioner>, Missing<RuntimeApi>, Missing<AvailabilityStore>, Missing<NetworkBridgeRx>, Missing<NetworkBridgeTx>, Missing<ChainApi>, Missing<CollationGeneration>, Missing<CollatorProtocol>, Missing<ApprovalDistribution>, Missing<ApprovalVoting>, Missing<ApprovalVotingParallel>, Missing<GossipSupport>, Missing<DisputeCoordinator>, Missing<DisputeDistribution>, Missing<ChainSelection>, Missing<ProspectiveParachains>, Missing<HashMap<H256, Vec<Sender<Result<(), SubsystemError>>>>>, Missing<HashMap<H256, u32>>, Missing<SupportsParachains>, Missing<Metrics>>where
CandidateValidation: Subsystem<OverseerSubsystemContext<CandidateValidationMessage>, SubsystemError>,
<OverseerSubsystemContext<CandidateValidationMessage> as CandidateValidationContextTrait>::Sender: CandidateValidationSenderTrait,
OverseerSubsystemContext<CandidateValidationMessage>: CandidateValidationContextTrait,
PvfChecker: Subsystem<OverseerSubsystemContext<PvfCheckerMessage>, SubsystemError>,
<OverseerSubsystemContext<PvfCheckerMessage> as PvfCheckerContextTrait>::Sender: PvfCheckerSenderTrait,
OverseerSubsystemContext<PvfCheckerMessage>: PvfCheckerContextTrait,
CandidateBacking: Subsystem<OverseerSubsystemContext<CandidateBackingMessage>, SubsystemError>,
<OverseerSubsystemContext<CandidateBackingMessage> as CandidateBackingContextTrait>::Sender: CandidateBackingSenderTrait,
OverseerSubsystemContext<CandidateBackingMessage>: CandidateBackingContextTrait,
StatementDistribution: Subsystem<OverseerSubsystemContext<StatementDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<StatementDistributionMessage> as StatementDistributionContextTrait>::Sender: StatementDistributionSenderTrait,
OverseerSubsystemContext<StatementDistributionMessage>: StatementDistributionContextTrait,
AvailabilityDistribution: Subsystem<OverseerSubsystemContext<AvailabilityDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityDistributionMessage> as AvailabilityDistributionContextTrait>::Sender: AvailabilityDistributionSenderTrait,
OverseerSubsystemContext<AvailabilityDistributionMessage>: AvailabilityDistributionContextTrait,
AvailabilityRecovery: Subsystem<OverseerSubsystemContext<AvailabilityRecoveryMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityRecoveryMessage> as AvailabilityRecoveryContextTrait>::Sender: AvailabilityRecoverySenderTrait,
OverseerSubsystemContext<AvailabilityRecoveryMessage>: AvailabilityRecoveryContextTrait,
BitfieldSigning: Subsystem<OverseerSubsystemContext<BitfieldSigningMessage>, SubsystemError>,
<OverseerSubsystemContext<BitfieldSigningMessage> as BitfieldSigningContextTrait>::Sender: BitfieldSigningSenderTrait,
OverseerSubsystemContext<BitfieldSigningMessage>: BitfieldSigningContextTrait,
BitfieldDistribution: Subsystem<OverseerSubsystemContext<BitfieldDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<BitfieldDistributionMessage> as BitfieldDistributionContextTrait>::Sender: BitfieldDistributionSenderTrait,
OverseerSubsystemContext<BitfieldDistributionMessage>: BitfieldDistributionContextTrait,
Provisioner: Subsystem<OverseerSubsystemContext<ProvisionerMessage>, SubsystemError>,
<OverseerSubsystemContext<ProvisionerMessage> as ProvisionerContextTrait>::Sender: ProvisionerSenderTrait,
OverseerSubsystemContext<ProvisionerMessage>: ProvisionerContextTrait,
RuntimeApi: Subsystem<OverseerSubsystemContext<RuntimeApiMessage>, SubsystemError>,
<OverseerSubsystemContext<RuntimeApiMessage> as RuntimeApiContextTrait>::Sender: RuntimeApiSenderTrait,
OverseerSubsystemContext<RuntimeApiMessage>: RuntimeApiContextTrait,
AvailabilityStore: Subsystem<OverseerSubsystemContext<AvailabilityStoreMessage>, SubsystemError>,
<OverseerSubsystemContext<AvailabilityStoreMessage> as AvailabilityStoreContextTrait>::Sender: AvailabilityStoreSenderTrait,
OverseerSubsystemContext<AvailabilityStoreMessage>: AvailabilityStoreContextTrait,
NetworkBridgeRx: Subsystem<OverseerSubsystemContext<NetworkBridgeRxMessage>, SubsystemError>,
<OverseerSubsystemContext<NetworkBridgeRxMessage> as NetworkBridgeRxContextTrait>::Sender: NetworkBridgeRxSenderTrait,
OverseerSubsystemContext<NetworkBridgeRxMessage>: NetworkBridgeRxContextTrait,
NetworkBridgeTx: Subsystem<OverseerSubsystemContext<NetworkBridgeTxMessage>, SubsystemError>,
<OverseerSubsystemContext<NetworkBridgeTxMessage> as NetworkBridgeTxContextTrait>::Sender: NetworkBridgeTxSenderTrait,
OverseerSubsystemContext<NetworkBridgeTxMessage>: NetworkBridgeTxContextTrait,
ChainApi: Subsystem<OverseerSubsystemContext<ChainApiMessage>, SubsystemError>,
<OverseerSubsystemContext<ChainApiMessage> as ChainApiContextTrait>::Sender: ChainApiSenderTrait,
OverseerSubsystemContext<ChainApiMessage>: ChainApiContextTrait,
CollationGeneration: Subsystem<OverseerSubsystemContext<CollationGenerationMessage>, SubsystemError>,
<OverseerSubsystemContext<CollationGenerationMessage> as CollationGenerationContextTrait>::Sender: CollationGenerationSenderTrait,
OverseerSubsystemContext<CollationGenerationMessage>: CollationGenerationContextTrait,
CollatorProtocol: Subsystem<OverseerSubsystemContext<CollatorProtocolMessage>, SubsystemError>,
<OverseerSubsystemContext<CollatorProtocolMessage> as CollatorProtocolContextTrait>::Sender: CollatorProtocolSenderTrait,
OverseerSubsystemContext<CollatorProtocolMessage>: CollatorProtocolContextTrait,
ApprovalDistribution: Subsystem<OverseerSubsystemContext<ApprovalDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalDistributionMessage> as ApprovalDistributionContextTrait>::Sender: ApprovalDistributionSenderTrait,
OverseerSubsystemContext<ApprovalDistributionMessage>: ApprovalDistributionContextTrait,
ApprovalVoting: Subsystem<OverseerSubsystemContext<ApprovalVotingMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalVotingMessage> as ApprovalVotingContextTrait>::Sender: ApprovalVotingSenderTrait,
OverseerSubsystemContext<ApprovalVotingMessage>: ApprovalVotingContextTrait,
ApprovalVotingParallel: Subsystem<OverseerSubsystemContext<ApprovalVotingParallelMessage>, SubsystemError>,
<OverseerSubsystemContext<ApprovalVotingParallelMessage> as ApprovalVotingParallelContextTrait>::Sender: ApprovalVotingParallelSenderTrait,
OverseerSubsystemContext<ApprovalVotingParallelMessage>: ApprovalVotingParallelContextTrait,
GossipSupport: Subsystem<OverseerSubsystemContext<GossipSupportMessage>, SubsystemError>,
<OverseerSubsystemContext<GossipSupportMessage> as GossipSupportContextTrait>::Sender: GossipSupportSenderTrait,
OverseerSubsystemContext<GossipSupportMessage>: GossipSupportContextTrait,
DisputeCoordinator: Subsystem<OverseerSubsystemContext<DisputeCoordinatorMessage>, SubsystemError>,
<OverseerSubsystemContext<DisputeCoordinatorMessage> as DisputeCoordinatorContextTrait>::Sender: DisputeCoordinatorSenderTrait,
OverseerSubsystemContext<DisputeCoordinatorMessage>: DisputeCoordinatorContextTrait,
DisputeDistribution: Subsystem<OverseerSubsystemContext<DisputeDistributionMessage>, SubsystemError>,
<OverseerSubsystemContext<DisputeDistributionMessage> as DisputeDistributionContextTrait>::Sender: DisputeDistributionSenderTrait,
OverseerSubsystemContext<DisputeDistributionMessage>: DisputeDistributionContextTrait,
ChainSelection: Subsystem<OverseerSubsystemContext<ChainSelectionMessage>, SubsystemError>,
<OverseerSubsystemContext<ChainSelectionMessage> as ChainSelectionContextTrait>::Sender: ChainSelectionSenderTrait,
OverseerSubsystemContext<ChainSelectionMessage>: ChainSelectionContextTrait,
ProspectiveParachains: Subsystem<OverseerSubsystemContext<ProspectiveParachainsMessage>, SubsystemError>,
<OverseerSubsystemContext<ProspectiveParachainsMessage> as ProspectiveParachainsContextTrait>::Sender: ProspectiveParachainsSenderTrait,
OverseerSubsystemContext<ProspectiveParachainsMessage>: ProspectiveParachainsContextTrait,
Create a new orchestra utilizing the builder.
§impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
SupportsParachains: HeadSupportsParachains,
S: Spawner,
impl<S, SupportsParachains> Overseer<S, SupportsParachains>where
SupportsParachains: HeadSupportsParachains,
S: Spawner,
pub async fn run(self)
pub async fn run(self)
Run the Overseer
.
Logging any errors.
Auto Trait Implementations§
impl<S, SupportsParachains> !Freeze for Overseer<S, SupportsParachains>
impl<S, SupportsParachains> !RefUnwindSafe for Overseer<S, SupportsParachains>
impl<S, SupportsParachains> Send for Overseer<S, SupportsParachains>
impl<S, SupportsParachains> !Sync for Overseer<S, SupportsParachains>
impl<S, SupportsParachains> Unpin for Overseer<S, SupportsParachains>
impl<S, SupportsParachains> !UnwindSafe for Overseer<S, SupportsParachains>
Blanket Implementations§
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
Mutably borrows from an owned value. Read more
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
source§impl<T> CheckedConversion for T
impl<T> CheckedConversion for T
§impl<T> Conv for T
impl<T> Conv for T
§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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Causes
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,
Formats each item in a sequence. Read more
§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> Instrument for T
impl<T> Instrument for T
source§fn instrument(self, span: Span) -> Instrumented<Self>
fn instrument(self, span: Span) -> Instrumented<Self>
source§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>
Converts
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>
Converts
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<Src, Dest> IntoTuple<Dest> for Srcwhere
Dest: FromTuple<Src>,
impl<Src, Dest> IntoTuple<Dest> for Srcwhere
Dest: FromTuple<Src>,
fn into_tuple(self) -> Dest
source§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
source§impl<T, Outer> IsWrappedBy<Outer> for T
impl<T, Outer> IsWrappedBy<Outer> for T
§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,
Pipes by value. This is generally the method you want to use. Read more
§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,
Borrows
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,
Mutably borrows
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
Borrows
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
Mutably borrows
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
Borrows
self
, then passes self.deref()
into the pipe function.§impl<T> Pointable for T
impl<T> Pointable for T
source§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of
T
. Read moresource§impl<T> SaturatedConversion for T
impl<T> SaturatedConversion for T
source§fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
fn saturated_from<T>(t: T) -> Selfwhere
Self: UniqueSaturatedFrom<T>,
source§fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
fn saturated_into<T>(self) -> Twhere
Self: UniqueSaturatedInto<T>,
Consume self to return an equivalent value of
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>
The inverse inclusion map: attempts to construct
self
from the equivalent element of its
superset. Read more§fn is_in_subset(&self) -> bool
fn is_in_subset(&self) -> bool
Checks if
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
Use with care! Same as
self.to_subset
but without any property checks. Always succeeds.§fn from_subset(element: &SS) -> SP
fn from_subset(element: &SS) -> SP
The inclusion map: converts
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
Immutable access to the
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
Mutable access to the
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
Immutable access to the
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
Mutable access to the
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
Immutable access to the
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
Mutable access to the
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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.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
Calls
.tap_deref()
only in debug builds, and is erased in release
builds.§impl<T> TryConv for T
impl<T> TryConv for T
source§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>
source§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.source§impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
impl<S, T> UncheckedInto<T> for Swhere
T: UncheckedFrom<S>,
source§fn unchecked_into(self) -> T
fn unchecked_into(self) -> T
The counterpart to
unchecked_from
.source§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of
T
.source§impl<T, S> UniqueSaturatedInto<T> for S
impl<T, S> UniqueSaturatedInto<T> for S
source§fn unique_saturated_into(self) -> T
fn unique_saturated_into(self) -> T
Consume self to return an equivalent value of
T
.