verifier is no longer a template type of client (#1467)
* verifier is no longer a template type of client * added missing ,
This commit is contained in:
		
							parent
							
								
									39307b2bea
								
							
						
					
					
						commit
						af891f65a7
					
				| @ -16,7 +16,6 @@ | |||||||
| 
 | 
 | ||||||
| //! Blockchain database client.
 | //! Blockchain database client.
 | ||||||
| 
 | 
 | ||||||
| use std::marker::PhantomData; |  | ||||||
| use std::path::PathBuf; | use std::path::PathBuf; | ||||||
| use std::sync::atomic::{AtomicUsize, Ordering as AtomicOrdering}; | use std::sync::atomic::{AtomicUsize, Ordering as AtomicOrdering}; | ||||||
| use util::*; | use util::*; | ||||||
| @ -30,7 +29,8 @@ use engine::Engine; | |||||||
| use views::HeaderView; | use views::HeaderView; | ||||||
| use service::{NetSyncMessage, SyncMessage}; | use service::{NetSyncMessage, SyncMessage}; | ||||||
| use env_info::LastHashes; | use env_info::LastHashes; | ||||||
| use verification::*; | use verification; | ||||||
|  | use verification::{PreverifiedBlock, Verifier}; | ||||||
| use block::*; | use block::*; | ||||||
| use transaction::{LocalizedTransaction, SignedTransaction, Action}; | use transaction::{LocalizedTransaction, SignedTransaction, Action}; | ||||||
| use blockchain::extras::TransactionAddress; | use blockchain::extras::TransactionAddress; | ||||||
| @ -83,7 +83,7 @@ impl ClientReport { | |||||||
| 
 | 
 | ||||||
| /// Blockchain database client backed by a persistent database. Owns and manages a blockchain and a block queue.
 | /// Blockchain database client backed by a persistent database. Owns and manages a blockchain and a block queue.
 | ||||||
| /// Call `import_block()` to import a block asynchronously; `flush_queue()` flushes the queue.
 | /// Call `import_block()` to import a block asynchronously; `flush_queue()` flushes the queue.
 | ||||||
| pub struct Client<V = CanonVerifier> where V: Verifier { | pub struct Client { | ||||||
| 	chain: Arc<BlockChain>, | 	chain: Arc<BlockChain>, | ||||||
| 	tracedb: Arc<TraceDB<BlockChain>>, | 	tracedb: Arc<TraceDB<BlockChain>>, | ||||||
| 	engine: Arc<Box<Engine>>, | 	engine: Arc<Box<Engine>>, | ||||||
| @ -92,7 +92,7 @@ pub struct Client<V = CanonVerifier> where V: Verifier { | |||||||
| 	report: RwLock<ClientReport>, | 	report: RwLock<ClientReport>, | ||||||
| 	import_lock: Mutex<()>, | 	import_lock: Mutex<()>, | ||||||
| 	panic_handler: Arc<PanicHandler>, | 	panic_handler: Arc<PanicHandler>, | ||||||
| 	verifier: PhantomData<V>, | 	verifier: Box<Verifier>, | ||||||
| 	vm_factory: Arc<EvmFactory>, | 	vm_factory: Arc<EvmFactory>, | ||||||
| 	miner: Arc<Miner>, | 	miner: Arc<Miner>, | ||||||
| 	io_channel: IoChannel<NetSyncMessage>, | 	io_channel: IoChannel<NetSyncMessage>, | ||||||
| @ -107,13 +107,6 @@ const HISTORY: u64 = 1200; | |||||||
| // of which you actually want force an upgrade.
 | // of which you actually want force an upgrade.
 | ||||||
| const CLIENT_DB_VER_STR: &'static str = "5.3"; | const CLIENT_DB_VER_STR: &'static str = "5.3"; | ||||||
| 
 | 
 | ||||||
| impl Client<CanonVerifier> { |  | ||||||
| 	/// Create a new client with given spec and DB path.
 |  | ||||||
| 	pub fn new(config: ClientConfig, spec: Spec, path: &Path, miner: Arc<Miner>, message_channel: IoChannel<NetSyncMessage> ) -> Result<Arc<Client>, ClientError> { |  | ||||||
| 		Client::<CanonVerifier>::new_with_verifier(config, spec, path, miner, message_channel) |  | ||||||
| 	} |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| /// Get the path for the databases given the root path and information on the databases.
 | /// Get the path for the databases given the root path and information on the databases.
 | ||||||
| pub fn get_db_path(path: &Path, pruning: journaldb::Algorithm, genesis_hash: H256) -> PathBuf { | pub fn get_db_path(path: &Path, pruning: journaldb::Algorithm, genesis_hash: H256) -> PathBuf { | ||||||
| 	let mut dir = path.to_path_buf(); | 	let mut dir = path.to_path_buf(); | ||||||
| @ -131,15 +124,15 @@ pub fn append_path(path: &Path, item: &str) -> String { | |||||||
| 	p.to_str().unwrap().to_owned() | 	p.to_str().unwrap().to_owned() | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<V> Client<V> where V: Verifier { | impl Client { | ||||||
| 	///  Create a new client with given spec and DB path and custom verifier.
 | 	///  Create a new client with given spec and DB path and custom verifier.
 | ||||||
| 	pub fn new_with_verifier( | 	pub fn new( | ||||||
| 		config: ClientConfig, | 		config: ClientConfig, | ||||||
| 		spec: Spec, | 		spec: Spec, | ||||||
| 		path: &Path, | 		path: &Path, | ||||||
| 		miner: Arc<Miner>, | 		miner: Arc<Miner>, | ||||||
| 		message_channel: IoChannel<NetSyncMessage>) | 		message_channel: IoChannel<NetSyncMessage>) | ||||||
| 		-> Result<Arc<Client<V>>, ClientError> | 		-> Result<Arc<Client>, ClientError> | ||||||
| 	{ | 	{ | ||||||
| 		let path = get_db_path(path, config.pruning, spec.genesis_header().hash()); | 		let path = get_db_path(path, config.pruning, spec.genesis_header().hash()); | ||||||
| 		let gb = spec.genesis_block(); | 		let gb = spec.genesis_block(); | ||||||
| @ -180,7 +173,7 @@ impl<V> Client<V> where V: Verifier { | |||||||
| 			report: RwLock::new(Default::default()), | 			report: RwLock::new(Default::default()), | ||||||
| 			import_lock: Mutex::new(()), | 			import_lock: Mutex::new(()), | ||||||
| 			panic_handler: panic_handler, | 			panic_handler: panic_handler, | ||||||
| 			verifier: PhantomData, | 			verifier: verification::new(config.verifier_type), | ||||||
| 			vm_factory: Arc::new(EvmFactory::new(config.vm_type)), | 			vm_factory: Arc::new(EvmFactory::new(config.vm_type)), | ||||||
| 			miner: miner, | 			miner: miner, | ||||||
| 			io_channel: message_channel, | 			io_channel: message_channel, | ||||||
| @ -222,7 +215,7 @@ impl<V> Client<V> where V: Verifier { | |||||||
| 		} | 		} | ||||||
| 
 | 
 | ||||||
| 		// Verify Block Family
 | 		// Verify Block Family
 | ||||||
| 		let verify_family_result = V::verify_block_family(&header, &block.bytes, engine, self.chain.deref()); | 		let verify_family_result = self.verifier.verify_block_family(&header, &block.bytes, engine, self.chain.deref()); | ||||||
| 		if let Err(e) = verify_family_result { | 		if let Err(e) = verify_family_result { | ||||||
| 			warn!(target: "client", "Stage 3 block verification failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | 			warn!(target: "client", "Stage 3 block verification failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | ||||||
| 			return Err(()); | 			return Err(()); | ||||||
| @ -248,7 +241,7 @@ impl<V> Client<V> where V: Verifier { | |||||||
| 
 | 
 | ||||||
| 		// Final Verification
 | 		// Final Verification
 | ||||||
| 		let locked_block = enact_result.unwrap(); | 		let locked_block = enact_result.unwrap(); | ||||||
| 		if let Err(e) = V::verify_block_final(&header, locked_block.block().header()) { | 		if let Err(e) = self.verifier.verify_block_final(&header, locked_block.block().header()) { | ||||||
| 			warn!(target: "client", "Stage 4 block verification failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | 			warn!(target: "client", "Stage 4 block verification failed for #{} ({})\nError: {:?}", header.number(), header.hash(), e); | ||||||
| 			return Err(()); | 			return Err(()); | ||||||
| 		} | 		} | ||||||
| @ -483,7 +476,7 @@ impl<V> Client<V> where V: Verifier { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<V> BlockChainClient for Client<V> where V: Verifier { | impl BlockChainClient for Client { | ||||||
| 	fn call(&self, t: &SignedTransaction, analytics: CallAnalytics) -> Result<Executed, ExecutionError> { | 	fn call(&self, t: &SignedTransaction, analytics: CallAnalytics) -> Result<Executed, ExecutionError> { | ||||||
| 		let header = self.block_header(BlockID::Latest).unwrap(); | 		let header = self.block_header(BlockID::Latest).unwrap(); | ||||||
| 		let view = HeaderView::new(&header); | 		let view = HeaderView::new(&header); | ||||||
| @ -806,7 +799,7 @@ impl<V> BlockChainClient for Client<V> where V: Verifier { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<V> MiningBlockChainClient for Client<V> where V: Verifier { | impl MiningBlockChainClient for Client { | ||||||
| 	fn prepare_open_block(&self, author: Address, gas_range_target: (U256, U256), extra_data: Bytes) -> OpenBlock { | 	fn prepare_open_block(&self, author: Address, gas_range_target: (U256, U256), extra_data: Bytes) -> OpenBlock { | ||||||
| 		let engine = self.engine.deref().deref(); | 		let engine = self.engine.deref().deref(); | ||||||
| 		let h = self.chain.best_block_hash(); | 		let h = self.chain.best_block_hash(); | ||||||
|  | |||||||
| @ -18,6 +18,7 @@ pub use block_queue::BlockQueueConfig; | |||||||
| pub use blockchain::Config as BlockChainConfig; | pub use blockchain::Config as BlockChainConfig; | ||||||
| pub use trace::{Config as TraceConfig, Switch}; | pub use trace::{Config as TraceConfig, Switch}; | ||||||
| pub use evm::VMType; | pub use evm::VMType; | ||||||
|  | pub use verification::VerifierType; | ||||||
| use util::journaldb; | use util::journaldb; | ||||||
| 
 | 
 | ||||||
| /// Client state db compaction profile
 | /// Client state db compaction profile
 | ||||||
| @ -52,4 +53,6 @@ pub struct ClientConfig { | |||||||
| 	pub db_cache_size: Option<usize>, | 	pub db_cache_size: Option<usize>, | ||||||
| 	/// State db compaction profile
 | 	/// State db compaction profile
 | ||||||
| 	pub db_compaction: DatabaseCompactionProfile, | 	pub db_compaction: DatabaseCompactionProfile, | ||||||
|  | 	/// Type of block verifier used by client.
 | ||||||
|  | 	pub verifier_type: VerifierType, | ||||||
| } | } | ||||||
|  | |||||||
| @ -24,11 +24,11 @@ use super::verification; | |||||||
| pub struct CanonVerifier; | pub struct CanonVerifier; | ||||||
| 
 | 
 | ||||||
| impl Verifier for CanonVerifier { | impl Verifier for CanonVerifier { | ||||||
| 	fn verify_block_family(header: &Header, bytes: &[u8], engine: &Engine, bc: &BlockProvider) -> Result<(), Error> { | 	fn verify_block_family(&self, header: &Header, bytes: &[u8], engine: &Engine, bc: &BlockProvider) -> Result<(), Error> { | ||||||
| 		verification::verify_block_family(header, bytes, engine, bc) | 		verification::verify_block_family(header, bytes, engine, bc) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn verify_block_final(expected: &Header, got: &Header) -> Result<(), Error> { | 	fn verify_block_final(&self, expected: &Header, got: &Header) -> Result<(), Error> { | ||||||
| 		verification::verify_block_final(expected, got) | 		verification::verify_block_final(expected, got) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -17,11 +17,32 @@ | |||||||
| pub mod verification; | pub mod verification; | ||||||
| pub mod verifier; | pub mod verifier; | ||||||
| mod canon_verifier; | mod canon_verifier; | ||||||
| #[cfg(test)] |  | ||||||
| mod noop_verifier; | mod noop_verifier; | ||||||
| 
 | 
 | ||||||
| pub use self::verification::*; | pub use self::verification::*; | ||||||
| pub use self::verifier::Verifier; | pub use self::verifier::Verifier; | ||||||
| pub use self::canon_verifier::CanonVerifier; | pub use self::canon_verifier::CanonVerifier; | ||||||
| #[cfg(test)] |  | ||||||
| pub use self::noop_verifier::NoopVerifier; | pub use self::noop_verifier::NoopVerifier; | ||||||
|  | 
 | ||||||
|  | /// Verifier type.
 | ||||||
|  | #[derive(Debug)] | ||||||
|  | pub enum VerifierType { | ||||||
|  | 	/// Verifies block normally.
 | ||||||
|  | 	Canon, | ||||||
|  | 	/// Does not verify block at all.
 | ||||||
|  | 	/// Used in tests.
 | ||||||
|  | 	Noop, | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl Default for VerifierType { | ||||||
|  | 	fn default() -> Self { | ||||||
|  | 		VerifierType::Canon | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | pub fn new(v: VerifierType) -> Box<Verifier> { | ||||||
|  | 	match v { | ||||||
|  | 		VerifierType::Canon => Box::new(CanonVerifier), | ||||||
|  | 		VerifierType::Noop => Box::new(NoopVerifier), | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | |||||||
| @ -24,11 +24,11 @@ use super::Verifier; | |||||||
| pub struct NoopVerifier; | pub struct NoopVerifier; | ||||||
| 
 | 
 | ||||||
| impl Verifier for NoopVerifier { | impl Verifier for NoopVerifier { | ||||||
| 	fn verify_block_family(_header: &Header, _bytes: &[u8], _engine: &Engine, _bc: &BlockProvider) -> Result<(), Error> { | 	fn verify_block_family(&self, _header: &Header, _bytes: &[u8], _engine: &Engine, _bc: &BlockProvider) -> Result<(), Error> { | ||||||
| 		Ok(()) | 		Ok(()) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn verify_block_final(_expected: &Header, _got: &Header) -> Result<(), Error> { | 	fn verify_block_final(&self, _expected: &Header, _got: &Header) -> Result<(), Error> { | ||||||
| 		Ok(()) | 		Ok(()) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -21,6 +21,6 @@ use header::Header; | |||||||
| 
 | 
 | ||||||
| /// Should be used to verify blocks.
 | /// Should be used to verify blocks.
 | ||||||
| pub trait Verifier: Send + Sync { | pub trait Verifier: Send + Sync { | ||||||
| 	fn verify_block_family(header: &Header, bytes: &[u8], engine: &Engine, bc: &BlockProvider) -> Result<(), Error>; | 	fn verify_block_family(&self, header: &Header, bytes: &[u8], engine: &Engine, bc: &BlockProvider) -> Result<(), Error>; | ||||||
| 	fn verify_block_final(expected: &Header, got: &Header) -> Result<(), Error>; | 	fn verify_block_final(&self, expected: &Header, got: &Header) -> Result<(), Error>; | ||||||
| } | } | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user