2022-10-24 04:43:25 -04:00
|
|
|
use std::{sync::Arc, collections::HashMap};
|
2022-10-22 02:15:22 -04:00
|
|
|
|
|
|
|
|
use async_trait::async_trait;
|
|
|
|
|
|
|
|
|
|
use sp_inherents::CreateInherentDataProviders;
|
|
|
|
|
use sp_runtime::traits::Block;
|
2022-10-24 04:43:25 -04:00
|
|
|
use sp_api::TransactionFor;
|
2022-10-22 02:15:22 -04:00
|
|
|
|
|
|
|
|
use sp_consensus::{Error, CacheKeyId, Environment};
|
|
|
|
|
use sc_consensus::{BlockCheckParams, BlockImportParams, ImportResult, BlockImport};
|
|
|
|
|
|
2022-10-24 04:43:25 -04:00
|
|
|
use sc_client_api::Backend;
|
2022-10-22 02:15:22 -04:00
|
|
|
|
2022-10-24 04:43:25 -04:00
|
|
|
use crate::{
|
|
|
|
|
tendermint::{TendermintClient, TendermintImport},
|
|
|
|
|
Announce,
|
|
|
|
|
};
|
2022-10-22 02:15:22 -04:00
|
|
|
|
|
|
|
|
#[async_trait]
|
|
|
|
|
impl<
|
|
|
|
|
B: Block,
|
|
|
|
|
Be: Backend<B> + 'static,
|
2022-10-24 04:43:25 -04:00
|
|
|
C: TendermintClient<B, Be>,
|
2022-10-22 02:15:22 -04:00
|
|
|
CIDP: CreateInherentDataProviders<B, ()> + 'static,
|
|
|
|
|
E: Send + Sync + Environment<B> + 'static,
|
2022-10-22 07:36:13 -04:00
|
|
|
A: Announce<B>,
|
2022-10-24 04:43:25 -04:00
|
|
|
> BlockImport<B> for TendermintImport<B, Be, C, CIDP, E, A>
|
2022-10-22 02:15:22 -04:00
|
|
|
where
|
|
|
|
|
TransactionFor<C, B>: Send + Sync + 'static,
|
2022-10-24 04:43:25 -04:00
|
|
|
Arc<C>: BlockImport<B, Transaction = TransactionFor<C, B>>,
|
|
|
|
|
<Arc<C> as BlockImport<B>>::Error: Into<Error>,
|
2022-10-22 02:15:22 -04:00
|
|
|
{
|
|
|
|
|
type Error = Error;
|
|
|
|
|
type Transaction = TransactionFor<C, B>;
|
|
|
|
|
|
|
|
|
|
// TODO: Is there a DoS where you send a block without justifications, causing it to error,
|
|
|
|
|
// yet adding it to the blacklist in the process preventing further syncing?
|
|
|
|
|
async fn check_block(
|
|
|
|
|
&mut self,
|
|
|
|
|
mut block: BlockCheckParams<B>,
|
|
|
|
|
) -> Result<ImportResult, Self::Error> {
|
|
|
|
|
self.verify_order(block.parent_hash, block.number)?;
|
|
|
|
|
|
|
|
|
|
// Does not verify origin here as origin only applies to unfinalized blocks
|
|
|
|
|
// We don't have context on if this block has justifications or not
|
|
|
|
|
|
|
|
|
|
block.allow_missing_state = false;
|
|
|
|
|
block.allow_missing_parent = false;
|
|
|
|
|
|
2022-10-24 04:43:25 -04:00
|
|
|
self.client.check_block(block).await.map_err(Into::into)
|
2022-10-22 02:15:22 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
async fn import_block(
|
|
|
|
|
&mut self,
|
|
|
|
|
mut block: BlockImportParams<B, TransactionFor<C, B>>,
|
|
|
|
|
new_cache: HashMap<CacheKeyId, Vec<u8>>,
|
|
|
|
|
) -> Result<ImportResult, Self::Error> {
|
|
|
|
|
self.check(&mut block).await?;
|
2022-10-24 04:43:25 -04:00
|
|
|
self.client.import_block(block, new_cache).await.map_err(Into::into)
|
2022-10-24 05:37:43 -04:00
|
|
|
|
|
|
|
|
// TODO: If we're a validator who just successfully synced a block, recreate the tendermint
|
|
|
|
|
// machine with the new height
|
2022-10-22 02:15:22 -04:00
|
|
|
}
|
|
|
|
|
}
|