SubstrateFinalityTarget {
/// Create new Substrate headers target.
pub fn new(
client: Client,
transaction_params: TransactionParams>,
) -> Self {
SubstrateFinalityTarget { client, transaction_params }
}
}
impl Clone for SubstrateFinalityTarget {
fn clone(&self) -> Self {
SubstrateFinalityTarget {
client: self.client.clone(),
transaction_params: self.transaction_params.clone(),
}
}
}
#[async_trait]
impl RelayClient for SubstrateFinalityTarget {
type Error = Error;
async fn reconnect(&mut self) -> Result<(), Error> {
self.client.reconnect().await
}
}
#[async_trait]
impl TargetClient>
for SubstrateFinalityTarget
where
AccountIdOf: From< as Pair>::Public>,
P::TransactionSignScheme: TransactionSignScheme,
{
async fn best_finalized_source_block_number(
&self,
) -> Result, Error> {
// we can't continue to relay finality if target node is out of sync, because
// it may have already received (some of) headers that we're going to relay
self.client.ensure_synced().await?;
Ok(crate::messages_source::read_client_state::<
P::TargetChain,
HashOf,
BlockNumberOf,
>(&self.client, P::SourceChain::BEST_FINALIZED_HEADER_ID_METHOD)
.await?
.best_finalized_peer_at_best_self
.0)
}
async fn submit_finality_proof(
&self,
header: SyncHeader>,
proof: GrandpaJustification>,
) -> Result<(), Error> {
let genesis_hash = *self.client.genesis_hash();
let transaction_params = self.transaction_params.clone();
let call =
P::SubmitFinalityProofCallBuilder::build_submit_finality_proof_call(header, proof);
self.client
.submit_signed_extrinsic(
self.transaction_params.signer.public().into(),
move |best_block_id, transaction_nonce| {
Bytes(
P::TransactionSignScheme::sign_transaction(
genesis_hash,
&transaction_params.signer,
TransactionEra::new(best_block_id, transaction_params.mortality),
UnsignedTransaction::new(call, transaction_nonce),
)
.encode(),
)
},
)
.await
.map(drop)
}
}