Companion for paritytech/substrate#12764 (#1930)

* Companion for paritytech/substrate#12764

* Remove `async-trait`

* Fix trait

* update lockfile for {"substrate", "polkadot"}

Co-authored-by: parity-processbot <>
This commit is contained in:
Aaro Altonen
2022-12-10 10:26:02 +02:00
committed by GitHub
parent 4d3895a167
commit 4922b91ad7
7 changed files with 265 additions and 325 deletions
+190 -187
View File
File diff suppressed because it is too large Load Diff
+5 -6
View File
@@ -42,7 +42,7 @@
//! make sure that the blocks are imported in the correct order. //! make sure that the blocks are imported in the correct order.
use sc_client_api::{BlockBackend, BlockchainEvents, UsageProvider}; use sc_client_api::{BlockBackend, BlockchainEvents, UsageProvider};
use sc_consensus::import_queue::{ImportQueue, IncomingBlock}; use sc_consensus::import_queue::{ImportQueueService, IncomingBlock};
use sp_consensus::{BlockOrigin, BlockStatus}; use sp_consensus::{BlockOrigin, BlockStatus};
use sp_runtime::{ use sp_runtime::{
generic::BlockId, generic::BlockId,
@@ -103,7 +103,7 @@ impl RecoveryDelay {
} }
/// Encapsulates the logic of the pov recovery. /// Encapsulates the logic of the pov recovery.
pub struct PoVRecovery<Block: BlockT, PC, IQ, RC> { pub struct PoVRecovery<Block: BlockT, PC, RC> {
/// All the pending candidates that we are waiting for to be imported or that need to be /// All the pending candidates that we are waiting for to be imported or that need to be
/// recovered when `next_candidate_to_recover` tells us to do so. /// recovered when `next_candidate_to_recover` tells us to do so.
pending_candidates: HashMap<Block::Hash, PendingCandidate<Block>>, pending_candidates: HashMap<Block::Hash, PendingCandidate<Block>>,
@@ -119,23 +119,22 @@ pub struct PoVRecovery<Block: BlockT, PC, IQ, RC> {
waiting_for_parent: HashMap<Block::Hash, Vec<Block>>, waiting_for_parent: HashMap<Block::Hash, Vec<Block>>,
recovery_delay: RecoveryDelay, recovery_delay: RecoveryDelay,
parachain_client: Arc<PC>, parachain_client: Arc<PC>,
parachain_import_queue: IQ, parachain_import_queue: Box<dyn ImportQueueService<Block>>,
relay_chain_interface: RC, relay_chain_interface: RC,
para_id: ParaId, para_id: ParaId,
} }
impl<Block: BlockT, PC, IQ, RCInterface> PoVRecovery<Block, PC, IQ, RCInterface> impl<Block: BlockT, PC, RCInterface> PoVRecovery<Block, PC, RCInterface>
where where
PC: BlockBackend<Block> + BlockchainEvents<Block> + UsageProvider<Block>, PC: BlockBackend<Block> + BlockchainEvents<Block> + UsageProvider<Block>,
RCInterface: RelayChainInterface + Clone, RCInterface: RelayChainInterface + Clone,
IQ: ImportQueue<Block>,
{ {
/// Create a new instance. /// Create a new instance.
pub fn new( pub fn new(
overseer_handle: OverseerHandle, overseer_handle: OverseerHandle,
recovery_delay: RecoveryDelay, recovery_delay: RecoveryDelay,
parachain_client: Arc<PC>, parachain_client: Arc<PC>,
parachain_import_queue: IQ, parachain_import_queue: Box<dyn ImportQueueService<Block>>,
relay_chain_interface: RCInterface, relay_chain_interface: RCInterface,
para_id: ParaId, para_id: ParaId,
) -> Self { ) -> Self {
@@ -21,6 +21,7 @@ use polkadot_node_network_protocol::PeerId;
use sc_network::{NetworkService, SyncState}; use sc_network::{NetworkService, SyncState};
use sc_client_api::HeaderBackend; use sc_client_api::HeaderBackend;
use sc_consensus::{BlockImportError, BlockImportStatus, JustificationSyncLink, Link};
use sc_network_common::{ use sc_network_common::{
config::{ config::{
NonDefaultSetConfig, NonReservedPeerMode, NotificationHandshake, ProtocolId, SetConfig, NonDefaultSetConfig, NonReservedPeerMode, NotificationHandshake, ProtocolId, SetConfig,
@@ -29,12 +30,10 @@ use sc_network_common::{
service::NetworkSyncForkRequest, service::NetworkSyncForkRequest,
sync::{ sync::{
message::{BlockAnnouncesHandshake, BlockRequest}, message::{BlockAnnouncesHandshake, BlockRequest},
Metrics, SyncStatus, BadPeer, Metrics, OnBlockData, PollBlockAnnounceValidation, SyncStatus,
}, },
}; };
use sc_service::{error::Error, Configuration, NetworkStarter, SpawnTaskHandle}; use sc_service::{error::Error, Configuration, NetworkStarter, SpawnTaskHandle};
use sp_consensus::BlockOrigin;
use sp_runtime::Justifications;
use std::{iter, sync::Arc}; use std::{iter, sync::Arc};
@@ -80,7 +79,6 @@ pub(crate) fn build_collator_network(
chain_sync: Box::new(chain_sync), chain_sync: Box::new(chain_sync),
network_config: config.network.clone(), network_config: config.network.clone(),
chain: client.clone(), chain: client.clone(),
import_queue: Box::new(DummyImportQueue),
protocol_id, protocol_id,
metrics_registry: config.prometheus_config.as_ref().map(|config| config.registry.clone()), metrics_registry: config.prometheus_config.as_ref().map(|config| config.registry.clone()),
block_announce_config, block_announce_config,
@@ -253,28 +251,6 @@ impl<B: BlockT> sc_network_common::sync::ChainSync<B> for DummyChainSync {
unimplemented!("Not supported on the RPC collator") unimplemented!("Not supported on the RPC collator")
} }
fn on_blocks_processed(
&mut self,
_imported: usize,
_count: usize,
_results: Vec<(
Result<
sc_consensus::BlockImportStatus<polkadot_service::NumberFor<B>>,
sc_consensus::BlockImportError,
>,
<B as BlockT>::Hash,
)>,
) -> Box<
dyn Iterator<
Item = Result<
(PeerId, sc_network_common::sync::message::BlockRequest<B>),
sc_network_common::sync::BadPeer,
>,
>,
> {
Box::new(std::iter::empty())
}
fn on_justification_import( fn on_justification_import(
&mut self, &mut self,
_hash: <B as BlockT>::Hash, _hash: <B as BlockT>::Hash,
@@ -307,12 +283,7 @@ impl<B: BlockT> sc_network_common::sync::ChainSync<B> for DummyChainSync {
std::task::Poll::Pending std::task::Poll::Pending
} }
fn peer_disconnected( fn peer_disconnected(&mut self, _who: &PeerId) {}
&mut self,
_who: &PeerId,
) -> Option<sc_network_common::sync::OnBlockData<B>> {
None
}
fn metrics(&self) -> sc_network_common::sync::Metrics { fn metrics(&self) -> sc_network_common::sync::Metrics {
Metrics { Metrics {
@@ -338,7 +309,7 @@ impl<B: BlockT> sc_network_common::sync::ChainSync<B> for DummyChainSync {
fn poll( fn poll(
&mut self, &mut self,
_cx: &mut std::task::Context, _cx: &mut std::task::Context,
) -> std::task::Poll<sc_network_common::sync::PollResult<B>> { ) -> std::task::Poll<PollBlockAnnounceValidation<B::Header>> {
std::task::Poll::Pending std::task::Poll::Pending
} }
@@ -349,33 +320,8 @@ impl<B: BlockT> sc_network_common::sync::ChainSync<B> for DummyChainSync {
fn num_active_peers(&self) -> usize { fn num_active_peers(&self) -> usize {
0 0
} }
}
struct DummyImportQueue; fn process_block_response_data(&mut self, _blocks_to_import: Result<OnBlockData<B>, BadPeer>) {}
impl sc_service::ImportQueue<Block> for DummyImportQueue {
fn import_blocks(
&mut self,
_origin: BlockOrigin,
_blocks: Vec<sc_consensus::IncomingBlock<Block>>,
) {
}
fn import_justifications(
&mut self,
_who: PeerId,
_hash: Hash,
_number: NumberFor<Block>,
_justifications: Justifications,
) {
}
fn poll_actions(
&mut self,
_cx: &mut futures::task::Context,
_link: &mut dyn sc_consensus::import_queue::Link<Block>,
) {
}
} }
struct DummyChainSyncService<B>(std::marker::PhantomData<B>); struct DummyChainSyncService<B>(std::marker::PhantomData<B>);
@@ -383,3 +329,30 @@ struct DummyChainSyncService<B>(std::marker::PhantomData<B>);
impl<B: BlockT> NetworkSyncForkRequest<B::Hash, NumberFor<B>> for DummyChainSyncService<B> { impl<B: BlockT> NetworkSyncForkRequest<B::Hash, NumberFor<B>> for DummyChainSyncService<B> {
fn set_sync_fork_request(&self, _peers: Vec<PeerId>, _hash: B::Hash, _number: NumberFor<B>) {} fn set_sync_fork_request(&self, _peers: Vec<PeerId>, _hash: B::Hash, _number: NumberFor<B>) {}
} }
impl<B: BlockT> JustificationSyncLink<B> for DummyChainSyncService<B> {
fn request_justification(&self, _hash: &B::Hash, _number: NumberFor<B>) {}
fn clear_justification_requests(&self) {}
}
impl<B: BlockT> Link<B> for DummyChainSyncService<B> {
fn blocks_processed(
&mut self,
_imported: usize,
_count: usize,
_results: Vec<(Result<BlockImportStatus<NumberFor<B>>, BlockImportError>, B::Hash)>,
) {
}
fn justification_imported(
&mut self,
_who: PeerId,
_hash: &B::Hash,
_number: NumberFor<B>,
_success: bool,
) {
}
fn request_justification(&mut self, _hash: &B::Hash, _number: NumberFor<B>) {}
}
+10 -52
View File
@@ -25,23 +25,16 @@ use polkadot_primitives::v2::CollatorPair;
use sc_client_api::{ use sc_client_api::{
Backend as BackendT, BlockBackend, BlockchainEvents, Finalizer, UsageProvider, Backend as BackendT, BlockBackend, BlockchainEvents, Finalizer, UsageProvider,
}; };
use sc_consensus::{ use sc_consensus::{import_queue::ImportQueueService, BlockImport};
import_queue::{ImportQueue, IncomingBlock, Link, RuntimeOrigin},
BlockImport,
};
use sc_service::{Configuration, TaskManager}; use sc_service::{Configuration, TaskManager};
use sp_api::ProvideRuntimeApi; use sp_api::ProvideRuntimeApi;
use sp_blockchain::HeaderBackend; use sp_blockchain::HeaderBackend;
use sp_consensus::BlockOrigin;
use sp_core::traits::SpawnNamed; use sp_core::traits::SpawnNamed;
use sp_runtime::{ use sp_runtime::traits::Block as BlockT;
traits::{Block as BlockT, NumberFor},
Justifications,
};
use std::{sync::Arc, time::Duration}; use std::{sync::Arc, time::Duration};
/// Parameters given to [`start_collator`]. /// Parameters given to [`start_collator`].
pub struct StartCollatorParams<'a, Block: BlockT, BS, Client, RCInterface, Spawner, IQ> { pub struct StartCollatorParams<'a, Block: BlockT, BS, Client, RCInterface, Spawner> {
pub block_status: Arc<BS>, pub block_status: Arc<BS>,
pub client: Arc<Client>, pub client: Arc<Client>,
pub announce_block: Arc<dyn Fn(Block::Hash, Option<Vec<u8>>) + Send + Sync>, pub announce_block: Arc<dyn Fn(Block::Hash, Option<Vec<u8>>) + Send + Sync>,
@@ -50,7 +43,7 @@ pub struct StartCollatorParams<'a, Block: BlockT, BS, Client, RCInterface, Spawn
pub relay_chain_interface: RCInterface, pub relay_chain_interface: RCInterface,
pub task_manager: &'a mut TaskManager, pub task_manager: &'a mut TaskManager,
pub parachain_consensus: Box<dyn ParachainConsensus<Block>>, pub parachain_consensus: Box<dyn ParachainConsensus<Block>>,
pub import_queue: IQ, pub import_queue: Box<dyn ImportQueueService<Block>>,
pub collator_key: CollatorPair, pub collator_key: CollatorPair,
pub relay_chain_slot_duration: Duration, pub relay_chain_slot_duration: Duration,
} }
@@ -60,7 +53,7 @@ pub struct StartCollatorParams<'a, Block: BlockT, BS, Client, RCInterface, Spawn
/// A collator is similar to a validator in a normal blockchain. /// A collator is similar to a validator in a normal blockchain.
/// It is responsible for producing blocks and sending the blocks to a /// It is responsible for producing blocks and sending the blocks to a
/// parachain validator for validation and inclusion into the relay chain. /// parachain validator for validation and inclusion into the relay chain.
pub async fn start_collator<'a, Block, BS, Client, Backend, RCInterface, Spawner, IQ>( pub async fn start_collator<'a, Block, BS, Client, Backend, RCInterface, Spawner>(
StartCollatorParams { StartCollatorParams {
block_status, block_status,
client, client,
@@ -73,7 +66,7 @@ pub async fn start_collator<'a, Block, BS, Client, Backend, RCInterface, Spawner
import_queue, import_queue,
collator_key, collator_key,
relay_chain_slot_duration, relay_chain_slot_duration,
}: StartCollatorParams<'a, Block, BS, Client, RCInterface, Spawner, IQ>, }: StartCollatorParams<'a, Block, BS, Client, RCInterface, Spawner>,
) -> sc_service::error::Result<()> ) -> sc_service::error::Result<()>
where where
Block: BlockT, Block: BlockT,
@@ -92,7 +85,6 @@ where
Spawner: SpawnNamed + Clone + Send + Sync + 'static, Spawner: SpawnNamed + Clone + Send + Sync + 'static,
RCInterface: RelayChainInterface + Clone + 'static, RCInterface: RelayChainInterface + Clone + 'static,
Backend: BackendT<Block> + 'static, Backend: BackendT<Block> + 'static,
IQ: ImportQueue<Block> + 'static,
{ {
let consensus = cumulus_client_consensus_common::run_parachain_consensus( let consensus = cumulus_client_consensus_common::run_parachain_consensus(
para_id, para_id,
@@ -139,21 +131,21 @@ where
} }
/// Parameters given to [`start_full_node`]. /// Parameters given to [`start_full_node`].
pub struct StartFullNodeParams<'a, Block: BlockT, Client, RCInterface, IQ> { pub struct StartFullNodeParams<'a, Block: BlockT, Client, RCInterface> {
pub para_id: ParaId, pub para_id: ParaId,
pub client: Arc<Client>, pub client: Arc<Client>,
pub relay_chain_interface: RCInterface, pub relay_chain_interface: RCInterface,
pub task_manager: &'a mut TaskManager, pub task_manager: &'a mut TaskManager,
pub announce_block: Arc<dyn Fn(Block::Hash, Option<Vec<u8>>) + Send + Sync>, pub announce_block: Arc<dyn Fn(Block::Hash, Option<Vec<u8>>) + Send + Sync>,
pub relay_chain_slot_duration: Duration, pub relay_chain_slot_duration: Duration,
pub import_queue: IQ, pub import_queue: Box<dyn ImportQueueService<Block>>,
} }
/// Start a full node for a parachain. /// Start a full node for a parachain.
/// ///
/// A full node will only sync the given parachain and will follow the /// A full node will only sync the given parachain and will follow the
/// tip of the chain. /// tip of the chain.
pub fn start_full_node<Block, Client, Backend, RCInterface, IQ>( pub fn start_full_node<Block, Client, Backend, RCInterface>(
StartFullNodeParams { StartFullNodeParams {
client, client,
announce_block, announce_block,
@@ -162,7 +154,7 @@ pub fn start_full_node<Block, Client, Backend, RCInterface, IQ>(
para_id, para_id,
relay_chain_slot_duration, relay_chain_slot_duration,
import_queue, import_queue,
}: StartFullNodeParams<Block, Client, RCInterface, IQ>, }: StartFullNodeParams<Block, Client, RCInterface>,
) -> sc_service::error::Result<()> ) -> sc_service::error::Result<()>
where where
Block: BlockT, Block: BlockT,
@@ -176,7 +168,6 @@ where
for<'a> &'a Client: BlockImport<Block>, for<'a> &'a Client: BlockImport<Block>,
Backend: BackendT<Block> + 'static, Backend: BackendT<Block> + 'static,
RCInterface: RelayChainInterface + Clone + 'static, RCInterface: RelayChainInterface + Clone + 'static,
IQ: ImportQueue<Block> + 'static,
{ {
let consensus = cumulus_client_consensus_common::run_parachain_consensus( let consensus = cumulus_client_consensus_common::run_parachain_consensus(
para_id, para_id,
@@ -226,36 +217,3 @@ pub fn prepare_node_config(mut parachain_config: Configuration) -> Configuration
parachain_config parachain_config
} }
/// A shared import queue
///
/// This is basically a hack until the Substrate side is implemented properly.
#[derive(Clone)]
pub struct SharedImportQueue<Block: BlockT>(Arc<parking_lot::Mutex<dyn ImportQueue<Block>>>);
impl<Block: BlockT> SharedImportQueue<Block> {
/// Create a new instance of the shared import queue.
pub fn new<IQ: ImportQueue<Block> + 'static>(import_queue: IQ) -> Self {
Self(Arc::new(parking_lot::Mutex::new(import_queue)))
}
}
impl<Block: BlockT> ImportQueue<Block> for SharedImportQueue<Block> {
fn import_blocks(&mut self, origin: BlockOrigin, blocks: Vec<IncomingBlock<Block>>) {
self.0.lock().import_blocks(origin, blocks)
}
fn import_justifications(
&mut self,
who: RuntimeOrigin,
hash: Block::Hash,
number: NumberFor<Block>,
justifications: Justifications,
) {
self.0.lock().import_justifications(who, hash, number, justifications)
}
fn poll_actions(&mut self, cx: &mut std::task::Context, link: &mut dyn Link<Block>) {
self.0.lock().poll_actions(cx, link)
}
}
@@ -22,6 +22,7 @@ use cumulus_relay_chain_interface::{RelayChainError, RelayChainInterface, RelayC
use cumulus_relay_chain_minimal_node::build_minimal_relay_chain_node; use cumulus_relay_chain_minimal_node::build_minimal_relay_chain_node;
// Substrate Imports // Substrate Imports
use sc_consensus::ImportQueue;
use sc_executor::NativeElseWasmExecutor; use sc_executor::NativeElseWasmExecutor;
use sc_network::NetworkService; use sc_network::NetworkService;
use sc_network_common::service::NetworkBlock; use sc_network_common::service::NetworkBlock;
@@ -196,14 +197,15 @@ async fn start_node_impl(
let validator = parachain_config.role.is_authority(); let validator = parachain_config.role.is_authority();
let prometheus_registry = parachain_config.prometheus_registry().cloned(); let prometheus_registry = parachain_config.prometheus_registry().cloned();
let transaction_pool = params.transaction_pool.clone(); let transaction_pool = params.transaction_pool.clone();
let import_queue = cumulus_client_service::SharedImportQueue::new(params.import_queue); let import_queue_service = params.import_queue.service();
let (network, system_rpc_tx, tx_handler_controller, start_network) = let (network, system_rpc_tx, tx_handler_controller, start_network) =
sc_service::build_network(sc_service::BuildNetworkParams { sc_service::build_network(sc_service::BuildNetworkParams {
config: &parachain_config, config: &parachain_config,
client: client.clone(), client: client.clone(),
transaction_pool: transaction_pool.clone(), transaction_pool: transaction_pool.clone(),
spawn_handle: task_manager.spawn_handle(), spawn_handle: task_manager.spawn_handle(),
import_queue: import_queue.clone(), import_queue: params.import_queue,
block_announce_validator_builder: Some(Box::new(|_| { block_announce_validator_builder: Some(Box::new(|_| {
Box::new(block_announce_validator) Box::new(block_announce_validator)
})), })),
@@ -293,7 +295,7 @@ async fn start_node_impl(
relay_chain_interface, relay_chain_interface,
spawner, spawner,
parachain_consensus, parachain_consensus,
import_queue, import_queue: import_queue_service,
collator_key: collator_key.expect("Command line arguments do not allow this. qed"), collator_key: collator_key.expect("Command line arguments do not allow this. qed"),
relay_chain_slot_duration, relay_chain_slot_duration,
}; };
@@ -307,7 +309,7 @@ async fn start_node_impl(
para_id: id, para_id: id,
relay_chain_interface, relay_chain_interface,
relay_chain_slot_duration, relay_chain_slot_duration,
import_queue, import_queue: import_queue_service,
}; };
start_full_node(params)?; start_full_node(params)?;
+16 -13
View File
@@ -43,7 +43,7 @@ use cumulus_client_consensus_relay_chain::Verifier as RelayChainVerifier;
use futures::lock::Mutex; use futures::lock::Mutex;
use sc_consensus::{ use sc_consensus::{
import_queue::{BasicQueue, Verifier as VerifierT}, import_queue::{BasicQueue, Verifier as VerifierT},
BlockImportParams, BlockImportParams, ImportQueue,
}; };
use sc_executor::WasmExecutor; use sc_executor::WasmExecutor;
use sc_network::NetworkService; use sc_network::NetworkService;
@@ -404,14 +404,15 @@ where
let validator = parachain_config.role.is_authority(); let validator = parachain_config.role.is_authority();
let prometheus_registry = parachain_config.prometheus_registry().cloned(); let prometheus_registry = parachain_config.prometheus_registry().cloned();
let transaction_pool = params.transaction_pool.clone(); let transaction_pool = params.transaction_pool.clone();
let import_queue = cumulus_client_service::SharedImportQueue::new(params.import_queue); let import_queue_service = params.import_queue.service();
let (network, system_rpc_tx, tx_handler_controller, start_network) = let (network, system_rpc_tx, tx_handler_controller, start_network) =
sc_service::build_network(sc_service::BuildNetworkParams { sc_service::build_network(sc_service::BuildNetworkParams {
config: &parachain_config, config: &parachain_config,
client: client.clone(), client: client.clone(),
transaction_pool: transaction_pool.clone(), transaction_pool: transaction_pool.clone(),
spawn_handle: task_manager.spawn_handle(), spawn_handle: task_manager.spawn_handle(),
import_queue: import_queue.clone(), import_queue: params.import_queue,
block_announce_validator_builder: Some(Box::new(|_| { block_announce_validator_builder: Some(Box::new(|_| {
Box::new(block_announce_validator) Box::new(block_announce_validator)
})), })),
@@ -480,7 +481,7 @@ where
relay_chain_interface, relay_chain_interface,
spawner, spawner,
parachain_consensus, parachain_consensus,
import_queue, import_queue: import_queue_service,
collator_key: collator_key.expect("Command line arguments do not allow this. qed"), collator_key: collator_key.expect("Command line arguments do not allow this. qed"),
relay_chain_slot_duration, relay_chain_slot_duration,
}; };
@@ -494,7 +495,7 @@ where
para_id, para_id,
relay_chain_interface, relay_chain_interface,
relay_chain_slot_duration, relay_chain_slot_duration,
import_queue, import_queue: import_queue_service,
}; };
start_full_node(params)?; start_full_node(params)?;
@@ -587,14 +588,15 @@ where
let validator = parachain_config.role.is_authority(); let validator = parachain_config.role.is_authority();
let prometheus_registry = parachain_config.prometheus_registry().cloned(); let prometheus_registry = parachain_config.prometheus_registry().cloned();
let transaction_pool = params.transaction_pool.clone(); let transaction_pool = params.transaction_pool.clone();
let import_queue = cumulus_client_service::SharedImportQueue::new(params.import_queue); let import_queue_service = params.import_queue.service();
let (network, system_rpc_tx, tx_handler_controller, start_network) = let (network, system_rpc_tx, tx_handler_controller, start_network) =
sc_service::build_network(sc_service::BuildNetworkParams { sc_service::build_network(sc_service::BuildNetworkParams {
config: &parachain_config, config: &parachain_config,
client: client.clone(), client: client.clone(),
transaction_pool: transaction_pool.clone(), transaction_pool: transaction_pool.clone(),
spawn_handle: task_manager.spawn_handle(), spawn_handle: task_manager.spawn_handle(),
import_queue: import_queue.clone(), import_queue: params.import_queue,
block_announce_validator_builder: Some(Box::new(|_| { block_announce_validator_builder: Some(Box::new(|_| {
Box::new(block_announce_validator) Box::new(block_announce_validator)
})), })),
@@ -676,7 +678,7 @@ where
relay_chain_interface: relay_chain_interface.clone(), relay_chain_interface: relay_chain_interface.clone(),
spawner, spawner,
parachain_consensus, parachain_consensus,
import_queue, import_queue: import_queue_service,
collator_key: collator_key.expect("Command line arguments do not allow this. qed"), collator_key: collator_key.expect("Command line arguments do not allow this. qed"),
relay_chain_slot_duration, relay_chain_slot_duration,
}; };
@@ -690,7 +692,7 @@ where
para_id, para_id,
relay_chain_interface, relay_chain_interface,
relay_chain_slot_duration, relay_chain_slot_duration,
import_queue, import_queue: import_queue_service,
}; };
start_full_node(params)?; start_full_node(params)?;
@@ -1356,14 +1358,15 @@ where
let validator = parachain_config.role.is_authority(); let validator = parachain_config.role.is_authority();
let prometheus_registry = parachain_config.prometheus_registry().cloned(); let prometheus_registry = parachain_config.prometheus_registry().cloned();
let transaction_pool = params.transaction_pool.clone(); let transaction_pool = params.transaction_pool.clone();
let import_queue = cumulus_client_service::SharedImportQueue::new(params.import_queue); let import_queue_service = params.import_queue.service();
let (network, system_rpc_tx, tx_handler_controller, start_network) = let (network, system_rpc_tx, tx_handler_controller, start_network) =
sc_service::build_network(sc_service::BuildNetworkParams { sc_service::build_network(sc_service::BuildNetworkParams {
config: &parachain_config, config: &parachain_config,
client: client.clone(), client: client.clone(),
transaction_pool: transaction_pool.clone(), transaction_pool: transaction_pool.clone(),
spawn_handle: task_manager.spawn_handle(), spawn_handle: task_manager.spawn_handle(),
import_queue: import_queue.clone(), import_queue: params.import_queue,
block_announce_validator_builder: Some(Box::new(|_| { block_announce_validator_builder: Some(Box::new(|_| {
Box::new(block_announce_validator) Box::new(block_announce_validator)
})), })),
@@ -1444,7 +1447,7 @@ where
relay_chain_interface, relay_chain_interface,
spawner, spawner,
parachain_consensus, parachain_consensus,
import_queue, import_queue: import_queue_service,
collator_key: collator_key.expect("Command line arguments do not allow this. qed"), collator_key: collator_key.expect("Command line arguments do not allow this. qed"),
relay_chain_slot_duration, relay_chain_slot_duration,
}; };
@@ -1458,7 +1461,7 @@ where
para_id, para_id,
relay_chain_interface, relay_chain_interface,
relay_chain_slot_duration, relay_chain_slot_duration,
import_queue, import_queue: import_queue_service,
}; };
start_full_node(params)?; start_full_node(params)?;
+6 -4
View File
@@ -48,6 +48,7 @@ use frame_system_rpc_runtime_api::AccountNonceApi;
use polkadot_primitives::v2::{CollatorPair, Hash as PHash, PersistedValidationData}; use polkadot_primitives::v2::{CollatorPair, Hash as PHash, PersistedValidationData};
use polkadot_service::ProvideRuntimeApi; use polkadot_service::ProvideRuntimeApi;
use sc_client_api::execution_extensions::ExecutionStrategies; use sc_client_api::execution_extensions::ExecutionStrategies;
use sc_consensus::ImportQueue;
use sc_network::{multiaddr, NetworkBlock, NetworkService}; use sc_network::{multiaddr, NetworkBlock, NetworkService};
use sc_network_common::{config::TransportConfig, service::NetworkStateInfo}; use sc_network_common::{config::TransportConfig, service::NetworkStateInfo};
use sc_service::{ use sc_service::{
@@ -269,14 +270,15 @@ where
let block_announce_validator_builder = move |_| Box::new(block_announce_validator) as Box<_>; let block_announce_validator_builder = move |_| Box::new(block_announce_validator) as Box<_>;
let prometheus_registry = parachain_config.prometheus_registry().cloned(); let prometheus_registry = parachain_config.prometheus_registry().cloned();
let import_queue = cumulus_client_service::SharedImportQueue::new(params.import_queue); let import_queue_service = params.import_queue.service();
let (network, system_rpc_tx, tx_handler_controller, start_network) = let (network, system_rpc_tx, tx_handler_controller, start_network) =
sc_service::build_network(sc_service::BuildNetworkParams { sc_service::build_network(sc_service::BuildNetworkParams {
config: &parachain_config, config: &parachain_config,
client: client.clone(), client: client.clone(),
transaction_pool: transaction_pool.clone(), transaction_pool: transaction_pool.clone(),
spawn_handle: task_manager.spawn_handle(), spawn_handle: task_manager.spawn_handle(),
import_queue: import_queue.clone(), import_queue: params.import_queue,
block_announce_validator_builder: Some(Box::new(block_announce_validator_builder)), block_announce_validator_builder: Some(Box::new(block_announce_validator_builder)),
warp_sync: None, warp_sync: None,
})?; })?;
@@ -362,7 +364,7 @@ where
parachain_consensus, parachain_consensus,
relay_chain_interface, relay_chain_interface,
collator_key, collator_key,
import_queue, import_queue: import_queue_service,
relay_chain_slot_duration: Duration::from_secs(6), relay_chain_slot_duration: Duration::from_secs(6),
}; };
@@ -374,7 +376,7 @@ where
task_manager: &mut task_manager, task_manager: &mut task_manager,
para_id, para_id,
relay_chain_interface, relay_chain_interface,
import_queue, import_queue: import_queue_service,
// The slot duration is currently used internally only to configure // The slot duration is currently used internally only to configure
// the recovery delay of pov-recovery. We don't want to wait for too // the recovery delay of pov-recovery. We don't want to wait for too
// long on the full node to recover, so we reduce this time here. // long on the full node to recover, so we reduce this time here.