mirror of
https://github.com/pezkuwichain/pezkuwi-subxt.git
synced 2026-05-30 21:01:02 +00:00
feefc34567
23dda62 Rococo <> Wococo messages relay (#1030) bcde21d Update the wasm builder to substrate master (#1029) a8318ce Make target signer optional when sending message. (#1018) f8602e1 Fix insufficient balance when send message. (#1020) d95c0a7 greedy relayer don't need message dispatch to be prepaid if dispatch is supposed to be paid at the target chain (#1016) ad5876f Update types. (#1027) 116cbbc CI: fix starting the pipeline (#1022) 7e0fadd Add temporary `canary` job (#1019) 6787091 Update types to contain dispatch_fee_payment (#1017) 03f79ad Allow Root to assume SourceAccount. (#1011) 372d019 Return dispatch_fee_payment from message details RPC (#1014) 604eb1c Relay basic single-bit message dispatch results back to the source chain (#935) bf52fff Use plain source_queue view when selecting nonces for delivery (#1010) fc5cf7d pay dispatch fee at target chain (#911) 1e35477 Bump Substrate to `286d7ce` (#1006) 7ad07b3 Add --only-mandatory-headers mode (#1004) 5351dc9 Messages relayer operating mode (#995) 9bc29a7 Rococo <> Wococo relayer balance guard (#998) bc17341 rename messages_dispatch_weight -> message_details (#996) 95be244 Bump Rococo and Wococo spec versions (#999) c35567b Move ChainWithBalances::NativeBalance -> Chain::Balance (#990) 1bfece1 Fix some nits (#988) 334ea0f Increase pause before starting relays again (#989) 7fb8248 Fix clippy in test code (#993) d60ae50 fix clippy issues (#991) 75ca813 Make sure GRANDPA shares state with RPC. (#987) da2a38a Bump Substrate (#986) 5a9862f Update submit finality proof weight formula (#981) 69df513 Flag for rejecting all outbound messages (#982) 14d0506 Add script to setup bench machine. (#984) e74e8ab Move CI from GitHub Actions to GitLab (#814) c5ca5dd Custom justification verification (#979) 643f10d Always run on-demand headers relay in complex relay (#975) a35b0ef Add JSON type definitions for Rococo<>Wococo bridge (#977) 0eb83f2 Update cargo.deny (#980) e1d1f4c Bump Rococo/Wococo spec_version (#976) deac90d increase pause before starting relays (#974) 68d6d79 Revert to use InspectCmd, bump substrate `6bef4f4` (#966) 66e1508 Avoid hashing headers twice in verify_justification (#973) a31844f Bump `environmental` dependency (#972) 2a4c29a in auto-relays keep trying to connect to nodes until connection is established (#971) 0e767b3 removed stray file (#969) b9545dc Serve multiple lanes with single complex relay instance (#964) 73419f4 Correct type error (#968) bac256f Start finality relay spec-version guards for Rococo <> Wococo finality relays (#965) bfd7037 pass source and target chain ids to account_ownership_proof (#963) 8436073 Upstream changes from Polkadot repo (#961) e58d851 Increase account endowment amount (#960) git-subtree-dir: bridges git-subtree-split: 23dda6248236b27f20d76cbedc30e189cc6f736c
159 lines
5.6 KiB
Rust
159 lines
5.6 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/>.
|
|
|
|
//! Substrate-to-Substrate headers sync entrypoint.
|
|
|
|
use crate::finality_target::SubstrateFinalityTarget;
|
|
|
|
use bp_header_chain::justification::GrandpaJustification;
|
|
use finality_relay::{FinalitySyncParams, FinalitySyncPipeline};
|
|
use relay_substrate_client::{finality_source::FinalitySource, BlockNumberOf, Chain, Client, HashOf, SyncHeader};
|
|
use relay_utils::{metrics::MetricsParams, BlockNumberBase};
|
|
use sp_core::Bytes;
|
|
use std::{fmt::Debug, marker::PhantomData, time::Duration};
|
|
|
|
/// Default synchronization loop timeout.
|
|
pub(crate) const STALL_TIMEOUT: Duration = Duration::from_secs(120);
|
|
/// Default limit of recent finality proofs.
|
|
///
|
|
/// Finality delay of 4096 blocks is unlikely to happen in practice in
|
|
/// Substrate+GRANDPA based chains (good to know).
|
|
pub(crate) const RECENT_FINALITY_PROOFS_LIMIT: usize = 4096;
|
|
|
|
/// Headers sync pipeline for Substrate <-> Substrate relays.
|
|
pub trait SubstrateFinalitySyncPipeline: FinalitySyncPipeline {
|
|
/// Name of the runtime method that returns id of best finalized source header at target chain.
|
|
const BEST_FINALIZED_SOURCE_HEADER_ID_AT_TARGET: &'static str;
|
|
|
|
/// Chain with GRANDPA bridge pallet.
|
|
type TargetChain: Chain;
|
|
|
|
/// Customize metrics exposed by headers sync loop.
|
|
fn customize_metrics(params: MetricsParams) -> anyhow::Result<MetricsParams> {
|
|
Ok(params)
|
|
}
|
|
|
|
/// Start finality relay guards.
|
|
///
|
|
/// Different finality bridges may have different set of guards - e.g. on ephemeral chains we
|
|
/// don't need version guards, on test chains we don't care that much about relayer account
|
|
/// balance, ... So the implementation is left to the specific bridges.
|
|
fn start_relay_guards(&self) {}
|
|
|
|
/// Returns id of account that we're using to sign transactions at target chain.
|
|
fn transactions_author(&self) -> <Self::TargetChain as Chain>::AccountId;
|
|
|
|
/// Make submit header transaction.
|
|
fn make_submit_finality_proof_transaction(
|
|
&self,
|
|
transaction_nonce: <Self::TargetChain as Chain>::Index,
|
|
header: Self::Header,
|
|
proof: Self::FinalityProof,
|
|
) -> Bytes;
|
|
}
|
|
|
|
/// Substrate-to-Substrate finality proof pipeline.
|
|
#[derive(Clone)]
|
|
pub struct SubstrateFinalityToSubstrate<SourceChain, TargetChain: Chain, TargetSign> {
|
|
/// Client for the target chain.
|
|
pub(crate) target_client: Client<TargetChain>,
|
|
/// Data required to sign target chain transactions.
|
|
pub(crate) target_sign: TargetSign,
|
|
/// Unused generic arguments dump.
|
|
_marker: PhantomData<SourceChain>,
|
|
}
|
|
|
|
impl<SourceChain, TargetChain: Chain, TargetSign> Debug
|
|
for SubstrateFinalityToSubstrate<SourceChain, TargetChain, TargetSign>
|
|
{
|
|
fn fmt(&self, f: &mut std::fmt::Formatter) -> std::fmt::Result {
|
|
f.debug_struct("SubstrateFinalityToSubstrate")
|
|
.field("target_client", &self.target_client)
|
|
.finish()
|
|
}
|
|
}
|
|
|
|
impl<SourceChain, TargetChain: Chain, TargetSign> SubstrateFinalityToSubstrate<SourceChain, TargetChain, TargetSign> {
|
|
/// Create new Substrate-to-Substrate headers pipeline.
|
|
pub fn new(target_client: Client<TargetChain>, target_sign: TargetSign) -> Self {
|
|
SubstrateFinalityToSubstrate {
|
|
target_client,
|
|
target_sign,
|
|
_marker: Default::default(),
|
|
}
|
|
}
|
|
}
|
|
|
|
impl<SourceChain, TargetChain, TargetSign> FinalitySyncPipeline
|
|
for SubstrateFinalityToSubstrate<SourceChain, TargetChain, TargetSign>
|
|
where
|
|
SourceChain: Clone + Chain + Debug,
|
|
BlockNumberOf<SourceChain>: BlockNumberBase,
|
|
TargetChain: Clone + Chain + Debug,
|
|
TargetSign: 'static + Clone + Send + Sync,
|
|
{
|
|
const SOURCE_NAME: &'static str = SourceChain::NAME;
|
|
const TARGET_NAME: &'static str = TargetChain::NAME;
|
|
|
|
type Hash = HashOf<SourceChain>;
|
|
type Number = BlockNumberOf<SourceChain>;
|
|
type Header = SyncHeader<SourceChain::Header>;
|
|
type FinalityProof = GrandpaJustification<SourceChain::Header>;
|
|
}
|
|
|
|
/// Run Substrate-to-Substrate finality sync.
|
|
pub async fn run<SourceChain, TargetChain, P>(
|
|
pipeline: P,
|
|
source_client: Client<SourceChain>,
|
|
target_client: Client<TargetChain>,
|
|
only_mandatory_headers: bool,
|
|
metrics_params: MetricsParams,
|
|
) -> anyhow::Result<()>
|
|
where
|
|
P: SubstrateFinalitySyncPipeline<
|
|
Hash = HashOf<SourceChain>,
|
|
Number = BlockNumberOf<SourceChain>,
|
|
Header = SyncHeader<SourceChain::Header>,
|
|
FinalityProof = GrandpaJustification<SourceChain::Header>,
|
|
TargetChain = TargetChain,
|
|
>,
|
|
SourceChain: Clone + Chain,
|
|
BlockNumberOf<SourceChain>: BlockNumberBase,
|
|
TargetChain: Clone + Chain,
|
|
{
|
|
log::info!(
|
|
target: "bridge",
|
|
"Starting {} -> {} finality proof relay",
|
|
SourceChain::NAME,
|
|
TargetChain::NAME,
|
|
);
|
|
|
|
finality_relay::run(
|
|
FinalitySource::new(source_client, None),
|
|
SubstrateFinalityTarget::new(target_client, pipeline),
|
|
FinalitySyncParams {
|
|
tick: std::cmp::max(SourceChain::AVERAGE_BLOCK_INTERVAL, TargetChain::AVERAGE_BLOCK_INTERVAL),
|
|
recent_finality_proofs_limit: RECENT_FINALITY_PROOFS_LIMIT,
|
|
stall_timeout: STALL_TIMEOUT,
|
|
only_mandatory_headers,
|
|
},
|
|
metrics_params,
|
|
futures::future::pending(),
|
|
)
|
|
.await
|
|
.map_err(|e| anyhow::format_err!("{}", e))
|
|
}
|