mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 17:31:03 +00:00
bde1629f86
* Remove SOURCE_PARACHAIN_PARA_ID Remove SubstrateParachainsPipeline::SOURCE_PARACHAIN_PARA_ID * Avoid duplicate ChainBase and ParachainBase implementations * Replace ChainShadow with UnderlyingChainProvider
146 lines
5.1 KiB
Rust
146 lines
5.1 KiB
Rust
// Copyright 2019-2021 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Bridges Common.
|
|
|
|
// Parity Bridges Common is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
|
|
// Parity Bridges Common is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
|
|
// 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/>.
|
|
|
|
use crate::chains::{
|
|
rialto_parachains_to_millau::RialtoParachainToMillauCliBridge,
|
|
rococo_parachains_to_bridge_hub_wococo::BridgeHubRococoToBridgeHubWococoCliBridge,
|
|
westend_parachains_to_millau::WestmintToMillauCliBridge,
|
|
wococo_parachains_to_bridge_hub_rococo::BridgeHubWococoToBridgeHubRococoCliBridge,
|
|
};
|
|
use async_std::sync::Mutex;
|
|
use async_trait::async_trait;
|
|
use bp_polkadot_core::parachains::ParaId;
|
|
use parachains_relay::parachains_loop::{
|
|
AvailableHeader, ParachainSyncParams, SourceClient, TargetClient,
|
|
};
|
|
use relay_substrate_client::{Parachain, ParachainBase};
|
|
use relay_utils::metrics::{GlobalMetrics, StandaloneMetric};
|
|
use std::sync::Arc;
|
|
use structopt::StructOpt;
|
|
use strum::{EnumString, EnumVariantNames, VariantNames};
|
|
use substrate_relay_helper::{
|
|
parachains::{
|
|
source::ParachainsSource, target::ParachainsTarget, ParachainsPipelineAdapter,
|
|
SubstrateParachainsPipeline,
|
|
},
|
|
TransactionParams,
|
|
};
|
|
|
|
use crate::cli::{
|
|
bridge::{CliBridgeBase, ParachainToRelayHeadersCliBridge},
|
|
chain_schema::*,
|
|
PrometheusParams,
|
|
};
|
|
|
|
/// Start parachain heads relayer process.
|
|
#[derive(StructOpt)]
|
|
pub struct RelayParachains {
|
|
/// A bridge instance to relay parachains heads for.
|
|
#[structopt(possible_values = RelayParachainsBridge::VARIANTS, case_insensitive = true)]
|
|
bridge: RelayParachainsBridge,
|
|
#[structopt(flatten)]
|
|
source: SourceConnectionParams,
|
|
#[structopt(flatten)]
|
|
target: TargetConnectionParams,
|
|
#[structopt(flatten)]
|
|
target_sign: TargetSigningParams,
|
|
#[structopt(flatten)]
|
|
prometheus_params: PrometheusParams,
|
|
}
|
|
|
|
/// Parachain heads relay bridge.
|
|
#[derive(Debug, EnumString, EnumVariantNames)]
|
|
#[strum(serialize_all = "kebab_case")]
|
|
pub enum RelayParachainsBridge {
|
|
RialtoToMillau,
|
|
// TODO:check-parameter - rename to WestmintToMillau?
|
|
WestendToMillau,
|
|
BridgeHubRococoToBridgeHubWococo,
|
|
BridgeHubWococoToBridgeHubRococo,
|
|
}
|
|
|
|
#[async_trait]
|
|
trait ParachainsRelayer: ParachainToRelayHeadersCliBridge
|
|
where
|
|
ParachainsSource<Self::ParachainFinality>:
|
|
SourceClient<ParachainsPipelineAdapter<Self::ParachainFinality>>,
|
|
ParachainsTarget<Self::ParachainFinality>:
|
|
TargetClient<ParachainsPipelineAdapter<Self::ParachainFinality>>,
|
|
<Self as CliBridgeBase>::Source: Parachain,
|
|
{
|
|
async fn relay_headers(data: RelayParachains) -> anyhow::Result<()> {
|
|
let source_client = data.source.into_client::<Self::SourceRelay>().await?;
|
|
let source_client = ParachainsSource::<Self::ParachainFinality>::new(
|
|
source_client,
|
|
Arc::new(Mutex::new(AvailableHeader::Missing)),
|
|
);
|
|
|
|
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.into_client::<Self::Target>().await?;
|
|
let target_client = ParachainsTarget::<Self::ParachainFinality>::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(<Self::ParachainFinality as SubstrateParachainsPipeline>::SourceParachain::PARACHAIN_ID)
|
|
],
|
|
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 {}
|
|
|
|
impl ParachainsRelayer for WestmintToMillauCliBridge {}
|
|
|
|
impl ParachainsRelayer for BridgeHubRococoToBridgeHubWococoCliBridge {}
|
|
|
|
impl ParachainsRelayer for BridgeHubWococoToBridgeHubRococoCliBridge {}
|
|
|
|
impl RelayParachains {
|
|
/// Run the command.
|
|
pub async fn run(self) -> anyhow::Result<()> {
|
|
match self.bridge {
|
|
RelayParachainsBridge::RialtoToMillau =>
|
|
RialtoParachainToMillauCliBridge::relay_headers(self),
|
|
RelayParachainsBridge::WestendToMillau =>
|
|
WestmintToMillauCliBridge::relay_headers(self),
|
|
RelayParachainsBridge::BridgeHubRococoToBridgeHubWococo =>
|
|
BridgeHubRococoToBridgeHubWococoCliBridge::relay_headers(self),
|
|
RelayParachainsBridge::BridgeHubWococoToBridgeHubRococo =>
|
|
BridgeHubWococoToBridgeHubRococoCliBridge::relay_headers(self),
|
|
}
|
|
.await
|
|
}
|
|
}
|