mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 19:51:02 +00:00
[CLI] Remove some macros
Refactor the implementations for the following CLI methods in order to avoid using macros: - init_bridge - relay_headers - relay_parachains Signed-off-by: Serban Iorga <serban@parity.io>
This commit is contained in:
committed by
Bastian Köcher
parent
4929493f83
commit
46c0400f26
@@ -17,7 +17,7 @@
|
|||||||
//! Westend chain specification for CLI.
|
//! Westend chain specification for CLI.
|
||||||
|
|
||||||
use crate::cli::CliChain;
|
use crate::cli::CliChain;
|
||||||
use relay_westend_client::Westend;
|
use relay_westend_client::{Westend, Westmint};
|
||||||
use sp_version::RuntimeVersion;
|
use sp_version::RuntimeVersion;
|
||||||
|
|
||||||
impl CliChain for Westend {
|
impl CliChain for Westend {
|
||||||
@@ -33,3 +33,17 @@ impl CliChain for Westend {
|
|||||||
.into()
|
.into()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl CliChain for Westmint {
|
||||||
|
const RUNTIME_VERSION: RuntimeVersion = bp_westend::VERSION;
|
||||||
|
|
||||||
|
type KeyPair = sp_core::sr25519::Pair;
|
||||||
|
type MessagePayload = Vec<u8>;
|
||||||
|
|
||||||
|
fn ss58_format() -> u16 {
|
||||||
|
sp_core::crypto::Ss58AddressFormat::from(
|
||||||
|
sp_core::crypto::Ss58AddressFormatRegistry::SubstrateAccount,
|
||||||
|
)
|
||||||
|
.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -14,7 +14,10 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use crate::cli::CliChain;
|
||||||
|
use relay_substrate_client::{AccountKeyPairOf, Chain, TransactionSignScheme};
|
||||||
use strum::{EnumString, EnumVariantNames};
|
use strum::{EnumString, EnumVariantNames};
|
||||||
|
use substrate_relay_helper::finality::SubstrateFinalitySyncPipeline;
|
||||||
|
|
||||||
#[derive(Debug, PartialEq, Eq, EnumString, EnumVariantNames)]
|
#[derive(Debug, PartialEq, Eq, EnumString, EnumVariantNames)]
|
||||||
#[strum(serialize_all = "kebab_case")]
|
#[strum(serialize_all = "kebab_case")]
|
||||||
@@ -218,3 +221,137 @@ macro_rules! select_full_bridge {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// Minimal bridge representation that can be used from the CLI.
|
||||||
|
/// It connects a source chain to a target chain.
|
||||||
|
pub trait CliBridgeBase: Sized {
|
||||||
|
/// The source chain.
|
||||||
|
type Source: Chain + CliChain;
|
||||||
|
/// The target chain.
|
||||||
|
type Target: Chain
|
||||||
|
+ TransactionSignScheme<Chain = Self::Target>
|
||||||
|
+ CliChain<KeyPair = AccountKeyPairOf<Self::Target>>;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// Bridge representation that can be used from the CLI.
|
||||||
|
pub trait CliBridge: CliBridgeBase {
|
||||||
|
/// Finality proofs synchronization pipeline.
|
||||||
|
type Finality: SubstrateFinalitySyncPipeline<
|
||||||
|
SourceChain = Self::Source,
|
||||||
|
TargetChain = Self::Target,
|
||||||
|
TransactionSignScheme = Self::Target,
|
||||||
|
>;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Millau` to `Rialto` bridge definition.
|
||||||
|
pub struct MillauToRialtoCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for MillauToRialtoCliBridge {
|
||||||
|
type Source = relay_millau_client::Millau;
|
||||||
|
type Target = relay_rialto_client::Rialto;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for MillauToRialtoCliBridge {
|
||||||
|
type Finality = crate::chains::millau_headers_to_rialto::MillauFinalityToRialto;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Rialto` to `Millau` bridge definition.
|
||||||
|
pub struct RialtoToMillauCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for RialtoToMillauCliBridge {
|
||||||
|
type Source = relay_rialto_client::Rialto;
|
||||||
|
type Target = relay_millau_client::Millau;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for RialtoToMillauCliBridge {
|
||||||
|
type Finality = crate::chains::rialto_headers_to_millau::RialtoFinalityToMillau;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Westend` to `Millau` bridge definition.
|
||||||
|
pub struct WestendToMillauCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for WestendToMillauCliBridge {
|
||||||
|
type Source = relay_westend_client::Westend;
|
||||||
|
type Target = relay_millau_client::Millau;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for WestendToMillauCliBridge {
|
||||||
|
type Finality = crate::chains::westend_headers_to_millau::WestendFinalityToMillau;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Rococo` to `Wococo` bridge definition.
|
||||||
|
pub struct RococoToWococoCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for RococoToWococoCliBridge {
|
||||||
|
type Source = relay_rococo_client::Rococo;
|
||||||
|
type Target = relay_wococo_client::Wococo;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for RococoToWococoCliBridge {
|
||||||
|
type Finality = crate::chains::rococo_headers_to_wococo::RococoFinalityToWococo;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Wococo` to `Rococo` bridge definition.
|
||||||
|
pub struct WococoToRococoCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for WococoToRococoCliBridge {
|
||||||
|
type Source = relay_wococo_client::Wococo;
|
||||||
|
type Target = relay_rococo_client::Rococo;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for WococoToRococoCliBridge {
|
||||||
|
type Finality = crate::chains::wococo_headers_to_rococo::WococoFinalityToRococo;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Kusama` to `Polkadot` bridge definition.
|
||||||
|
pub struct KusamaToPolkadotCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for KusamaToPolkadotCliBridge {
|
||||||
|
type Source = relay_kusama_client::Kusama;
|
||||||
|
type Target = relay_polkadot_client::Polkadot;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for KusamaToPolkadotCliBridge {
|
||||||
|
type Finality = crate::chains::kusama_headers_to_polkadot::KusamaFinalityToPolkadot;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Polkadot` to `Kusama` bridge definition.
|
||||||
|
pub struct PolkadotToKusamaCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for PolkadotToKusamaCliBridge {
|
||||||
|
type Source = relay_polkadot_client::Polkadot;
|
||||||
|
type Target = relay_kusama_client::Kusama;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for PolkadotToKusamaCliBridge {
|
||||||
|
type Finality = crate::chains::polkadot_headers_to_kusama::PolkadotFinalityToKusama;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `Millau` to `RialtoParachain` bridge definition.
|
||||||
|
pub struct MillauToRialtoParachainCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for MillauToRialtoParachainCliBridge {
|
||||||
|
type Source = relay_millau_client::Millau;
|
||||||
|
type Target = relay_rialto_parachain_client::RialtoParachain;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl CliBridge for MillauToRialtoParachainCliBridge {
|
||||||
|
type Finality =
|
||||||
|
crate::chains::millau_headers_to_rialto_parachain::MillauFinalityToRialtoParachain;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `RialtoParachain` to `Millau` bridge definition.
|
||||||
|
pub struct RialtoParachainToMillauCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for RialtoParachainToMillauCliBridge {
|
||||||
|
type Source = relay_rialto_parachain_client::RialtoParachain;
|
||||||
|
type Target = relay_millau_client::Millau;
|
||||||
|
}
|
||||||
|
|
||||||
|
//// `WestendParachain` to `Millau` bridge definition.
|
||||||
|
pub struct WestmintToMillauCliBridge {}
|
||||||
|
|
||||||
|
impl CliBridgeBase for WestmintToMillauCliBridge {
|
||||||
|
type Source = relay_westend_client::Westmint;
|
||||||
|
type Target = relay_millau_client::Millau;
|
||||||
|
}
|
||||||
|
|||||||
@@ -14,15 +14,25 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
use crate::cli::{SourceConnectionParams, TargetConnectionParams, TargetSigningParams};
|
use async_trait::async_trait;
|
||||||
use bp_header_chain::InitializationData;
|
|
||||||
|
use crate::cli::{
|
||||||
|
bridge::{
|
||||||
|
CliBridgeBase, KusamaToPolkadotCliBridge, MillauToRialtoCliBridge,
|
||||||
|
MillauToRialtoParachainCliBridge, PolkadotToKusamaCliBridge, RialtoToMillauCliBridge,
|
||||||
|
RococoToWococoCliBridge, WestendToMillauCliBridge, WococoToRococoCliBridge,
|
||||||
|
},
|
||||||
|
SourceConnectionParams, TargetConnectionParams, TargetSigningParams,
|
||||||
|
};
|
||||||
use bp_runtime::Chain as ChainBase;
|
use bp_runtime::Chain as ChainBase;
|
||||||
use codec::Encode;
|
use codec::Encode;
|
||||||
use relay_substrate_client::{Chain, SignParam, TransactionSignScheme, UnsignedTransaction};
|
use relay_substrate_client::{
|
||||||
|
AccountKeyPairOf, Chain, SignParam, TransactionSignScheme, UnsignedTransaction,
|
||||||
|
};
|
||||||
use sp_core::{Bytes, Pair};
|
use sp_core::{Bytes, Pair};
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
use strum::{EnumString, EnumVariantNames, VariantNames};
|
use strum::{EnumString, EnumVariantNames, VariantNames};
|
||||||
use substrate_relay_helper::finality::engine::Grandpa as GrandpaFinalityEngine;
|
use substrate_relay_helper::finality::engine::{Engine, Grandpa as GrandpaFinalityEngine};
|
||||||
|
|
||||||
/// Initialize bridge pallet.
|
/// Initialize bridge pallet.
|
||||||
#[derive(StructOpt)]
|
#[derive(StructOpt)]
|
||||||
@@ -52,198 +62,181 @@ pub enum InitBridgeName {
|
|||||||
MillauToRialtoParachain,
|
MillauToRialtoParachain,
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! select_bridge {
|
#[async_trait]
|
||||||
($bridge: expr, $generic: tt) => {
|
trait BridgeInitializer: CliBridgeBase
|
||||||
match $bridge {
|
where
|
||||||
InitBridgeName::MillauToRialto => {
|
<Self::Target as ChainBase>::AccountId: From<<AccountKeyPairOf<Self::Target> as Pair>::Public>,
|
||||||
type Source = relay_millau_client::Millau;
|
{
|
||||||
type Target = relay_rialto_client::Rialto;
|
type Engine: Engine<Self::Source>;
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
/// Get the encoded call to init the bridge.
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
fn encode_init_bridge(
|
||||||
) -> <Target as Chain>::Call {
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
rialto_runtime::SudoCall::sudo {
|
) -> <Self::Target as Chain>::Call;
|
||||||
call: Box::new(
|
|
||||||
rialto_runtime::BridgeGrandpaMillauCall::initialize { init_data }
|
/// Initialize the bridge.
|
||||||
.into(),
|
async fn init_bridge(data: InitBridge) -> anyhow::Result<()> {
|
||||||
|
let source_client = data.source.to_client::<Self::Source>().await?;
|
||||||
|
let target_client = data.target.to_client::<Self::Target>().await?;
|
||||||
|
let target_sign = data.target_sign.to_keypair::<Self::Target>()?;
|
||||||
|
|
||||||
|
let (spec_version, transaction_version) = target_client.simple_runtime_version().await?;
|
||||||
|
substrate_relay_helper::finality::initialize::initialize::<Self::Engine, _, _, _>(
|
||||||
|
source_client,
|
||||||
|
target_client.clone(),
|
||||||
|
target_sign.public().into(),
|
||||||
|
move |transaction_nonce, initialization_data| {
|
||||||
|
Ok(Bytes(
|
||||||
|
Self::Target::sign_transaction(SignParam {
|
||||||
|
spec_version,
|
||||||
|
transaction_version,
|
||||||
|
genesis_hash: *target_client.genesis_hash(),
|
||||||
|
signer: target_sign,
|
||||||
|
era: relay_substrate_client::TransactionEra::immortal(),
|
||||||
|
unsigned: UnsignedTransaction::new(
|
||||||
|
Self::encode_init_bridge(initialization_data).into(),
|
||||||
|
transaction_nonce,
|
||||||
),
|
),
|
||||||
}
|
})?
|
||||||
.into()
|
.encode(),
|
||||||
}
|
))
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
},
|
||||||
InitBridgeName::RialtoToMillau => {
|
)
|
||||||
type Source = relay_rialto_client::Rialto;
|
.await;
|
||||||
type Target = relay_millau_client::Millau;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
Ok(())
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
}
|
||||||
) -> <Target as Chain>::Call {
|
}
|
||||||
let initialize_call = millau_runtime::BridgeGrandpaCall::<
|
|
||||||
millau_runtime::Runtime,
|
|
||||||
millau_runtime::RialtoGrandpaInstance,
|
|
||||||
>::initialize {
|
|
||||||
init_data,
|
|
||||||
};
|
|
||||||
millau_runtime::SudoCall::sudo { call: Box::new(initialize_call.into()) }.into()
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
impl BridgeInitializer for MillauToRialtoCliBridge {
|
||||||
},
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
InitBridgeName::WestendToMillau => {
|
|
||||||
type Source = relay_westend_client::Westend;
|
|
||||||
type Target = relay_millau_client::Millau;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
fn encode_init_bridge(
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
) -> <Target as Chain>::Call {
|
) -> <Self::Target as Chain>::Call {
|
||||||
// at Westend -> Millau initialization we're not using sudo, because otherwise
|
rialto_runtime::SudoCall::sudo {
|
||||||
// our deployments may fail, because we need to initialize both Rialto -> Millau
|
call: Box::new(
|
||||||
// and Westend -> Millau bridge. => since there's single possible sudo account,
|
rialto_runtime::BridgeGrandpaMillauCall::initialize { init_data }.into(),
|
||||||
// one of transaction may fail with duplicate nonce error
|
),
|
||||||
millau_runtime::BridgeGrandpaCall::<
|
|
||||||
millau_runtime::Runtime,
|
|
||||||
millau_runtime::WestendGrandpaInstance,
|
|
||||||
>::initialize {
|
|
||||||
init_data,
|
|
||||||
}
|
|
||||||
.into()
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
InitBridgeName::RococoToWococo => {
|
|
||||||
type Source = relay_rococo_client::Rococo;
|
|
||||||
type Target = relay_wococo_client::Wococo;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
|
||||||
) -> <Target as Chain>::Call {
|
|
||||||
relay_wococo_client::runtime::Call::BridgeGrandpaRococo(
|
|
||||||
relay_wococo_client::runtime::BridgeGrandpaRococoCall::initialize(
|
|
||||||
init_data,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
InitBridgeName::WococoToRococo => {
|
|
||||||
type Source = relay_wococo_client::Wococo;
|
|
||||||
type Target = relay_rococo_client::Rococo;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
|
||||||
) -> <Target as Chain>::Call {
|
|
||||||
relay_rococo_client::runtime::Call::BridgeGrandpaWococo(
|
|
||||||
relay_rococo_client::runtime::BridgeGrandpaWococoCall::initialize(
|
|
||||||
init_data,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
InitBridgeName::KusamaToPolkadot => {
|
|
||||||
type Source = relay_kusama_client::Kusama;
|
|
||||||
type Target = relay_polkadot_client::Polkadot;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
|
||||||
) -> <Target as Chain>::Call {
|
|
||||||
relay_polkadot_client::runtime::Call::BridgeKusamaGrandpa(
|
|
||||||
relay_polkadot_client::runtime::BridgeKusamaGrandpaCall::initialize(
|
|
||||||
init_data,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
InitBridgeName::PolkadotToKusama => {
|
|
||||||
type Source = relay_polkadot_client::Polkadot;
|
|
||||||
type Target = relay_kusama_client::Kusama;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
|
||||||
) -> <Target as Chain>::Call {
|
|
||||||
relay_kusama_client::runtime::Call::BridgePolkadotGrandpa(
|
|
||||||
relay_kusama_client::runtime::BridgePolkadotGrandpaCall::initialize(
|
|
||||||
init_data,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
InitBridgeName::MillauToRialtoParachain => {
|
|
||||||
type Source = relay_millau_client::Millau;
|
|
||||||
type Target = relay_rialto_parachain_client::RialtoParachain;
|
|
||||||
type Engine = GrandpaFinalityEngine<Source>;
|
|
||||||
|
|
||||||
fn encode_init_bridge(
|
|
||||||
init_data: InitializationData<<Source as ChainBase>::Header>,
|
|
||||||
) -> <Target as Chain>::Call {
|
|
||||||
let initialize_call = rialto_parachain_runtime::BridgeGrandpaCall::<
|
|
||||||
rialto_parachain_runtime::Runtime,
|
|
||||||
rialto_parachain_runtime::MillauGrandpaInstance,
|
|
||||||
>::initialize {
|
|
||||||
init_data,
|
|
||||||
};
|
|
||||||
rialto_parachain_runtime::SudoCall::sudo {
|
|
||||||
call: Box::new(initialize_call.into()),
|
|
||||||
}
|
|
||||||
.into()
|
|
||||||
}
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
}
|
}
|
||||||
};
|
.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for MillauToRialtoParachainCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
let initialize_call = rialto_parachain_runtime::BridgeGrandpaCall::<
|
||||||
|
rialto_parachain_runtime::Runtime,
|
||||||
|
rialto_parachain_runtime::MillauGrandpaInstance,
|
||||||
|
>::initialize {
|
||||||
|
init_data,
|
||||||
|
};
|
||||||
|
rialto_parachain_runtime::SudoCall::sudo { call: Box::new(initialize_call.into()) }.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for RialtoToMillauCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
let initialize_call = millau_runtime::BridgeGrandpaCall::<
|
||||||
|
millau_runtime::Runtime,
|
||||||
|
millau_runtime::RialtoGrandpaInstance,
|
||||||
|
>::initialize {
|
||||||
|
init_data,
|
||||||
|
};
|
||||||
|
millau_runtime::SudoCall::sudo { call: Box::new(initialize_call.into()) }.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for WestendToMillauCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
// at Westend -> Millau initialization we're not using sudo, because otherwise
|
||||||
|
// our deployments may fail, because we need to initialize both Rialto -> Millau
|
||||||
|
// and Westend -> Millau bridge. => since there's single possible sudo account,
|
||||||
|
// one of transaction may fail with duplicate nonce error
|
||||||
|
millau_runtime::BridgeGrandpaCall::<
|
||||||
|
millau_runtime::Runtime,
|
||||||
|
millau_runtime::WestendGrandpaInstance,
|
||||||
|
>::initialize {
|
||||||
|
init_data,
|
||||||
|
}
|
||||||
|
.into()
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for RococoToWococoCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
relay_wococo_client::runtime::Call::BridgeGrandpaRococo(
|
||||||
|
relay_wococo_client::runtime::BridgeGrandpaRococoCall::initialize(init_data),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for WococoToRococoCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
relay_rococo_client::runtime::Call::BridgeGrandpaWococo(
|
||||||
|
relay_rococo_client::runtime::BridgeGrandpaWococoCall::initialize(init_data),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for KusamaToPolkadotCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
relay_polkadot_client::runtime::Call::BridgeKusamaGrandpa(
|
||||||
|
relay_polkadot_client::runtime::BridgeKusamaGrandpaCall::initialize(init_data),
|
||||||
|
)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl BridgeInitializer for PolkadotToKusamaCliBridge {
|
||||||
|
type Engine = GrandpaFinalityEngine<Self::Source>;
|
||||||
|
|
||||||
|
fn encode_init_bridge(
|
||||||
|
init_data: <Self::Engine as Engine<Self::Source>>::InitializationData,
|
||||||
|
) -> <Self::Target as Chain>::Call {
|
||||||
|
relay_kusama_client::runtime::Call::BridgePolkadotGrandpa(
|
||||||
|
relay_kusama_client::runtime::BridgePolkadotGrandpaCall::initialize(init_data),
|
||||||
|
)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
impl InitBridge {
|
impl InitBridge {
|
||||||
/// Run the command.
|
/// Run the command.
|
||||||
pub async fn run(self) -> anyhow::Result<()> {
|
pub async fn run(self) -> anyhow::Result<()> {
|
||||||
select_bridge!(self.bridge, {
|
match self.bridge {
|
||||||
let source_client = self.source.to_client::<Source>().await?;
|
InitBridgeName::MillauToRialto => MillauToRialtoCliBridge::init_bridge(self),
|
||||||
let target_client = self.target.to_client::<Target>().await?;
|
InitBridgeName::RialtoToMillau => RialtoToMillauCliBridge::init_bridge(self),
|
||||||
let target_sign = self.target_sign.to_keypair::<Target>()?;
|
InitBridgeName::WestendToMillau => WestendToMillauCliBridge::init_bridge(self),
|
||||||
|
InitBridgeName::RococoToWococo => RococoToWococoCliBridge::init_bridge(self),
|
||||||
let (spec_version, transaction_version) =
|
InitBridgeName::WococoToRococo => WococoToRococoCliBridge::init_bridge(self),
|
||||||
target_client.simple_runtime_version().await?;
|
InitBridgeName::KusamaToPolkadot => KusamaToPolkadotCliBridge::init_bridge(self),
|
||||||
substrate_relay_helper::finality::initialize::initialize::<Engine, _, _, _>(
|
InitBridgeName::PolkadotToKusama => PolkadotToKusamaCliBridge::init_bridge(self),
|
||||||
source_client,
|
InitBridgeName::MillauToRialtoParachain =>
|
||||||
target_client.clone(),
|
MillauToRialtoParachainCliBridge::init_bridge(self),
|
||||||
target_sign.public().into(),
|
}
|
||||||
move |transaction_nonce, initialization_data| {
|
.await
|
||||||
Ok(Bytes(
|
|
||||||
Target::sign_transaction(SignParam {
|
|
||||||
spec_version,
|
|
||||||
transaction_version,
|
|
||||||
genesis_hash: *target_client.genesis_hash(),
|
|
||||||
signer: target_sign,
|
|
||||||
era: relay_substrate_client::TransactionEra::immortal(),
|
|
||||||
unsigned: UnsignedTransaction::new(
|
|
||||||
encode_init_bridge(initialization_data).into(),
|
|
||||||
transaction_nonce,
|
|
||||||
),
|
|
||||||
})?
|
|
||||||
.encode(),
|
|
||||||
))
|
|
||||||
},
|
|
||||||
)
|
|
||||||
.await;
|
|
||||||
|
|
||||||
Ok(())
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,6 +14,9 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use async_trait::async_trait;
|
||||||
|
use relay_substrate_client::{AccountKeyPairOf, ChainBase};
|
||||||
|
use sp_core::Pair;
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
use strum::{EnumString, EnumVariantNames, VariantNames};
|
use strum::{EnumString, EnumVariantNames, VariantNames};
|
||||||
|
|
||||||
@@ -21,6 +24,11 @@ use relay_utils::metrics::{GlobalMetrics, StandaloneMetric};
|
|||||||
use substrate_relay_helper::finality::SubstrateFinalitySyncPipeline;
|
use substrate_relay_helper::finality::SubstrateFinalitySyncPipeline;
|
||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
|
bridge::{
|
||||||
|
CliBridge, KusamaToPolkadotCliBridge, MillauToRialtoCliBridge,
|
||||||
|
MillauToRialtoParachainCliBridge, PolkadotToKusamaCliBridge, RialtoToMillauCliBridge,
|
||||||
|
RococoToWococoCliBridge, WestendToMillauCliBridge, WococoToRococoCliBridge,
|
||||||
|
},
|
||||||
PrometheusParams, SourceConnectionParams, TargetConnectionParams, TargetSigningParams,
|
PrometheusParams, SourceConnectionParams, TargetConnectionParams, TargetSigningParams,
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -58,101 +66,66 @@ pub enum RelayHeadersBridge {
|
|||||||
MillauToRialtoParachain,
|
MillauToRialtoParachain,
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! select_bridge {
|
#[async_trait]
|
||||||
($bridge: expr, $generic: tt) => {
|
trait HeadersRelayer: CliBridge
|
||||||
match $bridge {
|
where
|
||||||
RelayHeadersBridge::MillauToRialto => {
|
<Self::Target as ChainBase>::AccountId: From<<AccountKeyPairOf<Self::Target> as Pair>::Public>,
|
||||||
type Source = relay_millau_client::Millau;
|
{
|
||||||
type Target = relay_rialto_client::Rialto;
|
/// Relay headers.
|
||||||
type Finality = crate::chains::millau_headers_to_rialto::MillauFinalityToRialto;
|
async fn relay_headers(data: RelayHeaders) -> anyhow::Result<()> {
|
||||||
|
let source_client = data.source.to_client::<Self::Source>().await?;
|
||||||
|
let target_client = data.target.to_client::<Self::Target>().await?;
|
||||||
|
let target_transactions_mortality = data.target_sign.target_transactions_mortality;
|
||||||
|
let target_sign = data.target_sign.to_keypair::<Self::Target>()?;
|
||||||
|
|
||||||
$generic
|
let metrics_params: relay_utils::metrics::MetricsParams = data.prometheus_params.into();
|
||||||
},
|
GlobalMetrics::new()?.register_and_spawn(&metrics_params.registry)?;
|
||||||
RelayHeadersBridge::RialtoToMillau => {
|
|
||||||
type Source = relay_rialto_client::Rialto;
|
|
||||||
type Target = relay_millau_client::Millau;
|
|
||||||
type Finality = crate::chains::rialto_headers_to_millau::RialtoFinalityToMillau;
|
|
||||||
|
|
||||||
$generic
|
let target_transactions_params = substrate_relay_helper::TransactionParams {
|
||||||
},
|
signer: target_sign,
|
||||||
RelayHeadersBridge::WestendToMillau => {
|
mortality: target_transactions_mortality,
|
||||||
type Source = relay_westend_client::Westend;
|
};
|
||||||
type Target = relay_millau_client::Millau;
|
Self::Finality::start_relay_guards(
|
||||||
type Finality = crate::chains::westend_headers_to_millau::WestendFinalityToMillau;
|
&target_client,
|
||||||
|
&target_transactions_params,
|
||||||
|
data.target.can_start_version_guard(),
|
||||||
|
)
|
||||||
|
.await?;
|
||||||
|
|
||||||
$generic
|
substrate_relay_helper::finality::run::<Self::Finality>(
|
||||||
},
|
source_client,
|
||||||
RelayHeadersBridge::RococoToWococo => {
|
target_client,
|
||||||
type Source = relay_rococo_client::Rococo;
|
data.only_mandatory_headers,
|
||||||
type Target = relay_wococo_client::Wococo;
|
target_transactions_params,
|
||||||
type Finality = crate::chains::rococo_headers_to_wococo::RococoFinalityToWococo;
|
metrics_params,
|
||||||
|
)
|
||||||
$generic
|
.await
|
||||||
},
|
}
|
||||||
RelayHeadersBridge::WococoToRococo => {
|
|
||||||
type Source = relay_wococo_client::Wococo;
|
|
||||||
type Target = relay_rococo_client::Rococo;
|
|
||||||
type Finality = crate::chains::wococo_headers_to_rococo::WococoFinalityToRococo;
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
RelayHeadersBridge::KusamaToPolkadot => {
|
|
||||||
type Source = relay_kusama_client::Kusama;
|
|
||||||
type Target = relay_polkadot_client::Polkadot;
|
|
||||||
type Finality = crate::chains::kusama_headers_to_polkadot::KusamaFinalityToPolkadot;
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
RelayHeadersBridge::PolkadotToKusama => {
|
|
||||||
type Source = relay_polkadot_client::Polkadot;
|
|
||||||
type Target = relay_kusama_client::Kusama;
|
|
||||||
type Finality = crate::chains::polkadot_headers_to_kusama::PolkadotFinalityToKusama;
|
|
||||||
|
|
||||||
$generic
|
|
||||||
},
|
|
||||||
RelayHeadersBridge::MillauToRialtoParachain => {
|
|
||||||
type Source = relay_millau_client::Millau;
|
|
||||||
type Target = relay_rialto_parachain_client::RialtoParachain;
|
|
||||||
type Finality = crate::chains::millau_headers_to_rialto_parachain::MillauFinalityToRialtoParachain;
|
|
||||||
|
|
||||||
$generic
|
|
||||||
|
|
||||||
},
|
|
||||||
}
|
|
||||||
};
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
impl HeadersRelayer for MillauToRialtoCliBridge {}
|
||||||
|
impl HeadersRelayer for RialtoToMillauCliBridge {}
|
||||||
|
impl HeadersRelayer for WestendToMillauCliBridge {}
|
||||||
|
impl HeadersRelayer for RococoToWococoCliBridge {}
|
||||||
|
impl HeadersRelayer for WococoToRococoCliBridge {}
|
||||||
|
impl HeadersRelayer for KusamaToPolkadotCliBridge {}
|
||||||
|
impl HeadersRelayer for PolkadotToKusamaCliBridge {}
|
||||||
|
impl HeadersRelayer for MillauToRialtoParachainCliBridge {}
|
||||||
|
|
||||||
impl RelayHeaders {
|
impl RelayHeaders {
|
||||||
/// Run the command.
|
/// Run the command.
|
||||||
pub async fn run(self) -> anyhow::Result<()> {
|
pub async fn run(self) -> anyhow::Result<()> {
|
||||||
select_bridge!(self.bridge, {
|
match self.bridge {
|
||||||
let source_client = self.source.to_client::<Source>().await?;
|
RelayHeadersBridge::MillauToRialto => MillauToRialtoCliBridge::relay_headers(self),
|
||||||
let target_client = self.target.to_client::<Target>().await?;
|
RelayHeadersBridge::RialtoToMillau => RialtoToMillauCliBridge::relay_headers(self),
|
||||||
let target_transactions_mortality = self.target_sign.target_transactions_mortality;
|
RelayHeadersBridge::WestendToMillau => WestendToMillauCliBridge::relay_headers(self),
|
||||||
let target_sign = self.target_sign.to_keypair::<Target>()?;
|
RelayHeadersBridge::RococoToWococo => RococoToWococoCliBridge::relay_headers(self),
|
||||||
|
RelayHeadersBridge::WococoToRococo => WococoToRococoCliBridge::relay_headers(self),
|
||||||
let metrics_params: relay_utils::metrics::MetricsParams = self.prometheus_params.into();
|
RelayHeadersBridge::KusamaToPolkadot => KusamaToPolkadotCliBridge::relay_headers(self),
|
||||||
GlobalMetrics::new()?.register_and_spawn(&metrics_params.registry)?;
|
RelayHeadersBridge::PolkadotToKusama => PolkadotToKusamaCliBridge::relay_headers(self),
|
||||||
|
RelayHeadersBridge::MillauToRialtoParachain =>
|
||||||
let target_transactions_params = substrate_relay_helper::TransactionParams {
|
MillauToRialtoParachainCliBridge::relay_headers(self),
|
||||||
signer: target_sign,
|
}
|
||||||
mortality: target_transactions_mortality,
|
.await
|
||||||
};
|
|
||||||
Finality::start_relay_guards(
|
|
||||||
&target_client,
|
|
||||||
&target_transactions_params,
|
|
||||||
self.target.can_start_version_guard(),
|
|
||||||
)
|
|
||||||
.await?;
|
|
||||||
|
|
||||||
substrate_relay_helper::finality::run::<Finality>(
|
|
||||||
source_client,
|
|
||||||
target_client,
|
|
||||||
self.only_mandatory_headers,
|
|
||||||
target_transactions_params,
|
|
||||||
metrics_params,
|
|
||||||
)
|
|
||||||
.await
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -14,18 +14,29 @@
|
|||||||
// You should have received a copy of the GNU General Public License
|
// You should have received a copy of the GNU General Public License
|
||||||
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
// along with Parity Bridges Common. If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
|
||||||
|
use async_trait::async_trait;
|
||||||
use bp_polkadot_core::parachains::ParaId;
|
use bp_polkadot_core::parachains::ParaId;
|
||||||
use parachains_relay::{parachains_loop::ParachainSyncParams, ParachainsPipeline};
|
use pallet_bridge_parachains::RelayBlockNumber;
|
||||||
|
use parachains_relay::{
|
||||||
|
parachains_loop::{ParachainSyncParams, SourceClient, TargetClient},
|
||||||
|
ParachainsPipeline,
|
||||||
|
};
|
||||||
|
use relay_substrate_client::{Chain, RelayChain};
|
||||||
use relay_utils::metrics::{GlobalMetrics, StandaloneMetric};
|
use relay_utils::metrics::{GlobalMetrics, StandaloneMetric};
|
||||||
use structopt::StructOpt;
|
use structopt::StructOpt;
|
||||||
use strum::{EnumString, EnumVariantNames, VariantNames};
|
use strum::{EnumString, EnumVariantNames, VariantNames};
|
||||||
use substrate_relay_helper::{
|
use substrate_relay_helper::{
|
||||||
parachains::{source::ParachainsSource, target::ParachainsTarget},
|
parachains::{
|
||||||
|
source::ParachainsSource, target::ParachainsTarget, ParachainsPipelineAdapter,
|
||||||
|
SubstrateParachainsPipeline,
|
||||||
|
},
|
||||||
TransactionParams,
|
TransactionParams,
|
||||||
};
|
};
|
||||||
|
|
||||||
use crate::cli::{
|
use crate::cli::{
|
||||||
PrometheusParams, SourceConnectionParams, TargetConnectionParams, TargetSigningParams,
|
bridge::{CliBridgeBase, RialtoParachainToMillauCliBridge, WestmintToMillauCliBridge},
|
||||||
|
CliChain, PrometheusParams, SourceConnectionParams, TargetConnectionParams,
|
||||||
|
TargetSigningParams,
|
||||||
};
|
};
|
||||||
|
|
||||||
/// Start parachain heads relayer process.
|
/// Start parachain heads relayer process.
|
||||||
@@ -52,57 +63,72 @@ pub enum RelayParachainsBridge {
|
|||||||
WestendToMillau,
|
WestendToMillau,
|
||||||
}
|
}
|
||||||
|
|
||||||
macro_rules! select_bridge {
|
#[async_trait]
|
||||||
($bridge: expr, $generic: tt) => {
|
trait ParachainsRelayer: CliBridgeBase
|
||||||
match $bridge {
|
where
|
||||||
RelayParachainsBridge::RialtoToMillau => {
|
ParachainsSource<Self::Pipeline>: SourceClient<ParachainsPipelineAdapter<Self::Pipeline>>,
|
||||||
use crate::chains::rialto_parachains_to_millau::RialtoParachainsToMillau as Pipeline;
|
ParachainsTarget<Self::Pipeline>: TargetClient<ParachainsPipelineAdapter<Self::Pipeline>>,
|
||||||
|
{
|
||||||
|
type SourceRelay: Chain<BlockNumber = RelayBlockNumber> + CliChain + RelayChain;
|
||||||
|
type Pipeline: SubstrateParachainsPipeline<
|
||||||
|
SourceParachain = Self::Source,
|
||||||
|
TargetChain = Self::Target,
|
||||||
|
SourceRelayChain = Self::SourceRelay,
|
||||||
|
TransactionSignScheme = Self::Target,
|
||||||
|
> + ParachainsPipeline<SourceChain = Self::SourceRelay, TargetChain = Self::Target>;
|
||||||
|
|
||||||
$generic
|
async fn relay_headers(data: RelayParachains) -> anyhow::Result<()> {
|
||||||
},
|
let source_client = data.source.to_client::<Self::SourceRelay>().await?;
|
||||||
RelayParachainsBridge::WestendToMillau => {
|
let source_client = ParachainsSource::<Self::Pipeline>::new(source_client, None);
|
||||||
use crate::chains::westend_parachains_to_millau::WestendParachainsToMillau as Pipeline;
|
|
||||||
|
|
||||||
$generic
|
let target_transaction_params = TransactionParams {
|
||||||
|
signer: data.target_sign.to_keypair::<Self::Target>()?,
|
||||||
|
mortality: data.target_sign.target_transactions_mortality,
|
||||||
|
};
|
||||||
|
let target_client = data.target.to_client::<Self::Target>().await?;
|
||||||
|
let target_client = ParachainsTarget::<Self::Pipeline>::new(
|
||||||
|
target_client.clone(),
|
||||||
|
target_transaction_params,
|
||||||
|
);
|
||||||
|
|
||||||
|
let metrics_params: relay_utils::metrics::MetricsParams = data.prometheus_params.into();
|
||||||
|
GlobalMetrics::new()?.register_and_spawn(&metrics_params.registry)?;
|
||||||
|
|
||||||
|
parachains_relay::parachains_loop::run(
|
||||||
|
source_client,
|
||||||
|
target_client,
|
||||||
|
ParachainSyncParams {
|
||||||
|
parachains: vec![ParaId(2000)],
|
||||||
|
stall_timeout: std::time::Duration::from_secs(60),
|
||||||
|
strategy: parachains_relay::parachains_loop::ParachainSyncStrategy::Any,
|
||||||
},
|
},
|
||||||
}
|
metrics_params,
|
||||||
};
|
futures::future::pending(),
|
||||||
|
)
|
||||||
|
.await
|
||||||
|
.map_err(|e| anyhow::format_err!("{}", e))
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ParachainsRelayer for RialtoParachainToMillauCliBridge {
|
||||||
|
type SourceRelay = relay_rialto_client::Rialto;
|
||||||
|
type Pipeline = crate::chains::rialto_parachains_to_millau::RialtoParachainsToMillau;
|
||||||
|
}
|
||||||
|
|
||||||
|
impl ParachainsRelayer for WestmintToMillauCliBridge {
|
||||||
|
type SourceRelay = relay_westend_client::Westend;
|
||||||
|
type Pipeline = crate::chains::westend_parachains_to_millau::WestendParachainsToMillau;
|
||||||
}
|
}
|
||||||
|
|
||||||
impl RelayParachains {
|
impl RelayParachains {
|
||||||
/// Run the command.
|
/// Run the command.
|
||||||
pub async fn run(self) -> anyhow::Result<()> {
|
pub async fn run(self) -> anyhow::Result<()> {
|
||||||
select_bridge!(self.bridge, {
|
match self.bridge {
|
||||||
type SourceChain = <Pipeline as ParachainsPipeline>::SourceChain;
|
RelayParachainsBridge::RialtoToMillau =>
|
||||||
type TargetChain = <Pipeline as ParachainsPipeline>::TargetChain;
|
RialtoParachainToMillauCliBridge::relay_headers(self),
|
||||||
|
RelayParachainsBridge::WestendToMillau =>
|
||||||
let source_client = self.source.to_client::<SourceChain>().await?;
|
WestmintToMillauCliBridge::relay_headers(self),
|
||||||
let source_client = ParachainsSource::<Pipeline>::new(source_client, None);
|
}
|
||||||
|
.await
|
||||||
let taret_transaction_params = TransactionParams {
|
|
||||||
signer: self.target_sign.to_keypair::<TargetChain>()?,
|
|
||||||
mortality: self.target_sign.target_transactions_mortality,
|
|
||||||
};
|
|
||||||
let target_client = self.target.to_client::<TargetChain>().await?;
|
|
||||||
let target_client =
|
|
||||||
ParachainsTarget::<Pipeline>::new(target_client.clone(), taret_transaction_params);
|
|
||||||
|
|
||||||
let metrics_params: relay_utils::metrics::MetricsParams = self.prometheus_params.into();
|
|
||||||
GlobalMetrics::new()?.register_and_spawn(&metrics_params.registry)?;
|
|
||||||
|
|
||||||
parachains_relay::parachains_loop::run(
|
|
||||||
source_client,
|
|
||||||
target_client,
|
|
||||||
ParachainSyncParams {
|
|
||||||
parachains: vec![ParaId(2000)],
|
|
||||||
stall_timeout: std::time::Duration::from_secs(60),
|
|
||||||
strategy: parachains_relay::parachains_loop::ParachainSyncStrategy::Any,
|
|
||||||
},
|
|
||||||
metrics_params,
|
|
||||||
futures::future::pending(),
|
|
||||||
)
|
|
||||||
.await
|
|
||||||
.map_err(|e| anyhow::format_err!("{}", e))
|
|
||||||
})
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user