mirror of
https://github.com/serai-dex/serai.git
synced 2025-01-26 04:25:57 +00:00
Only recheck blocks with non-fatal inherent transaction errors
This commit is contained in:
parent
7d46daa36e
commit
6f74bade8b
2 changed files with 23 additions and 7 deletions
|
@ -1,6 +1,7 @@
|
||||||
use std::{
|
use std::{
|
||||||
sync::{Arc, RwLock},
|
sync::{Arc, RwLock},
|
||||||
time::{UNIX_EPOCH, SystemTime, Duration},
|
time::{UNIX_EPOCH, SystemTime, Duration},
|
||||||
|
collections::HashSet,
|
||||||
};
|
};
|
||||||
|
|
||||||
use async_trait::async_trait;
|
use async_trait::async_trait;
|
||||||
|
@ -318,8 +319,7 @@ impl<T: TendermintValidator> Network for TendermintAuthority<T> {
|
||||||
origin: None,
|
origin: None,
|
||||||
allow_missing_state: false,
|
allow_missing_state: false,
|
||||||
skip_execution: false,
|
skip_execution: false,
|
||||||
// TODO: Only set to true if block was rejected due to its inherents
|
import_existing: self.import.recheck.read().unwrap().contains(&hash),
|
||||||
import_existing: true,
|
|
||||||
state: None,
|
state: None,
|
||||||
}],
|
}],
|
||||||
);
|
);
|
||||||
|
@ -354,6 +354,9 @@ impl<T: TendermintValidator> Network for TendermintAuthority<T> {
|
||||||
.map_err(|_| Error::InvalidJustification)
|
.map_err(|_| Error::InvalidJustification)
|
||||||
.unwrap();
|
.unwrap();
|
||||||
|
|
||||||
|
// Clear any blocks for the previous height we were willing to recheck
|
||||||
|
*self.import.recheck.write().unwrap() = HashSet::new();
|
||||||
|
|
||||||
let number: u64 = match (*block.header().number()).try_into() {
|
let number: u64 = match (*block.header().number()).try_into() {
|
||||||
Ok(number) => number,
|
Ok(number) => number,
|
||||||
Err(_) => panic!("BlockNumber exceeded u64"),
|
Err(_) => panic!("BlockNumber exceeded u64"),
|
||||||
|
|
|
@ -1,4 +1,7 @@
|
||||||
use std::sync::{Arc, RwLock};
|
use std::{
|
||||||
|
sync::{Arc, RwLock},
|
||||||
|
collections::HashSet,
|
||||||
|
};
|
||||||
|
|
||||||
use log::warn;
|
use log::warn;
|
||||||
|
|
||||||
|
@ -31,6 +34,7 @@ pub struct TendermintImport<T: TendermintValidator> {
|
||||||
|
|
||||||
pub(crate) providers: Arc<AsyncRwLock<Option<T::CIDP>>>,
|
pub(crate) providers: Arc<AsyncRwLock<Option<T::CIDP>>>,
|
||||||
pub(crate) importing_block: Arc<RwLock<Option<<T::Block as Block>::Hash>>>,
|
pub(crate) importing_block: Arc<RwLock<Option<<T::Block as Block>::Hash>>>,
|
||||||
|
pub(crate) recheck: Arc<RwLock<HashSet<<T::Block as Block>::Hash>>>,
|
||||||
|
|
||||||
pub(crate) client: Arc<T::Client>,
|
pub(crate) client: Arc<T::Client>,
|
||||||
pub(crate) queue:
|
pub(crate) queue:
|
||||||
|
@ -44,6 +48,7 @@ impl<T: TendermintValidator> Clone for TendermintImport<T> {
|
||||||
|
|
||||||
providers: self.providers.clone(),
|
providers: self.providers.clone(),
|
||||||
importing_block: self.importing_block.clone(),
|
importing_block: self.importing_block.clone(),
|
||||||
|
recheck: self.recheck.clone(),
|
||||||
|
|
||||||
client: self.client.clone(),
|
client: self.client.clone(),
|
||||||
queue: self.queue.clone(),
|
queue: self.queue.clone(),
|
||||||
|
@ -58,6 +63,7 @@ impl<T: TendermintValidator> TendermintImport<T> {
|
||||||
|
|
||||||
providers: Arc::new(AsyncRwLock::new(None)),
|
providers: Arc::new(AsyncRwLock::new(None)),
|
||||||
importing_block: Arc::new(RwLock::new(None)),
|
importing_block: Arc::new(RwLock::new(None)),
|
||||||
|
recheck: Arc::new(RwLock::new(HashSet::new())),
|
||||||
|
|
||||||
client,
|
client,
|
||||||
queue: Arc::new(AsyncRwLock::new(None)),
|
queue: Arc::new(AsyncRwLock::new(None)),
|
||||||
|
@ -89,7 +95,11 @@ impl<T: TendermintValidator> TendermintImport<T> {
|
||||||
.unwrap_or_else(InherentData::new)
|
.unwrap_or_else(InherentData::new)
|
||||||
}
|
}
|
||||||
|
|
||||||
async fn check_inherents(&self, block: T::Block) -> Result<(), Error> {
|
async fn check_inherents(
|
||||||
|
&mut self,
|
||||||
|
hash: <T::Block as Block>::Hash,
|
||||||
|
block: T::Block,
|
||||||
|
) -> Result<(), Error> {
|
||||||
let inherent_data = self.inherent_data(*block.header().parent_hash()).await;
|
let inherent_data = self.inherent_data(*block.header().parent_hash()).await;
|
||||||
let err = self
|
let err = self
|
||||||
.client
|
.client
|
||||||
|
@ -98,10 +108,12 @@ impl<T: TendermintValidator> TendermintImport<T> {
|
||||||
.map_err(|_| Error::Other(BlockError::Fatal.into()))?;
|
.map_err(|_| Error::Other(BlockError::Fatal.into()))?;
|
||||||
|
|
||||||
if err.ok() {
|
if err.ok() {
|
||||||
|
self.recheck.write().unwrap().remove(&hash);
|
||||||
Ok(())
|
Ok(())
|
||||||
} else if err.fatal_error() {
|
} else if err.fatal_error() {
|
||||||
Err(Error::Other(BlockError::Fatal.into()))
|
Err(Error::Other(BlockError::Fatal.into()))
|
||||||
} else {
|
} else {
|
||||||
|
self.recheck.write().unwrap().insert(hash);
|
||||||
Err(Error::Other(BlockError::Temporal.into()))
|
Err(Error::Other(BlockError::Temporal.into()))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -173,7 +185,7 @@ impl<T: TendermintValidator> TendermintImport<T> {
|
||||||
}
|
}
|
||||||
|
|
||||||
pub(crate) async fn check<BT>(
|
pub(crate) async fn check<BT>(
|
||||||
&self,
|
&mut self,
|
||||||
block: &mut BlockImportParams<T::Block, BT>,
|
block: &mut BlockImportParams<T::Block, BT>,
|
||||||
) -> Result<(), Error> {
|
) -> Result<(), Error> {
|
||||||
if block.finalized {
|
if block.finalized {
|
||||||
|
@ -194,9 +206,10 @@ impl<T: TendermintValidator> TendermintImport<T> {
|
||||||
|
|
||||||
// If the block wasn't finalized, verify the origin and validity of its inherents
|
// If the block wasn't finalized, verify the origin and validity of its inherents
|
||||||
if !block.finalized {
|
if !block.finalized {
|
||||||
self.verify_origin(block.header.hash())?;
|
let hash = block.header.hash();
|
||||||
|
self.verify_origin(hash)?;
|
||||||
if let Some(body) = block.body.clone() {
|
if let Some(body) = block.body.clone() {
|
||||||
self.check_inherents(T::Block::new(block.header.clone(), body)).await?;
|
self.check_inherents(hash, T::Block::new(block.header.clone(), body)).await?;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue