change broadcast interface, add basic message handling
This commit is contained in:
		
							parent
							
								
									207f9d02f2
								
							
						
					
					
						commit
						99a143eb37
					
				| @ -42,7 +42,7 @@ pub trait ChainNotify : Send + Sync { | |||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/// fires when chain broadcasts a message
 | 	/// fires when chain broadcasts a message
 | ||||||
| 	fn broadcast(&self, _data: Vec<u8>) { | 	fn broadcast(&self, _data: &[u8]) { | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -25,6 +25,7 @@ use time::precise_time_ns; | |||||||
| use util::{journaldb, rlp, Bytes, View, PerfTimer, Itertools, Mutex, RwLock}; | use util::{journaldb, rlp, Bytes, View, PerfTimer, Itertools, Mutex, RwLock}; | ||||||
| use util::journaldb::JournalDB; | use util::journaldb::JournalDB; | ||||||
| use util::rlp::{UntrustedRlp}; | use util::rlp::{UntrustedRlp}; | ||||||
|  | use util::ec::recover; | ||||||
| use util::{U256, H256, Address, H2048, Uint}; | use util::{U256, H256, Address, H2048, Uint}; | ||||||
| use util::sha3::*; | use util::sha3::*; | ||||||
| use util::kvdb::*; | use util::kvdb::*; | ||||||
| @ -1021,8 +1022,15 @@ impl BlockChainClient for Client { | |||||||
| 		self.miner.pending_transactions() | 		self.miner.pending_transactions() | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn queue_infinity_message(&self, _message: Bytes) { | 	fn queue_infinity_message(&self, message: Bytes) { | ||||||
| 		//TODO: handle message here
 | 		let full_rlp = UntrustedRlp::new(&message); | ||||||
|  | 		let signature = full_rlp.val_at(0).unwrap_or(return); | ||||||
|  | 		let message: Vec<_> = full_rlp.val_at(1).unwrap_or(return); | ||||||
|  | 		let message_rlp = UntrustedRlp::new(&message); | ||||||
|  | 		let pub_key = recover(&signature, &message.sha3()).unwrap_or(return); | ||||||
|  | 		if let Some(new_message) = self.engine.handle_message(pub_key.sha3().into(), message_rlp) { | ||||||
|  | 			self.notify(|notify| notify.broadcast(new_message.as_raw())); | ||||||
|  | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -30,7 +30,7 @@ pub use self::tendermint::Tendermint; | |||||||
| pub use self::signed_vote::{SignedVote, VoteError}; | pub use self::signed_vote::{SignedVote, VoteError}; | ||||||
| pub use self::propose_collect::{ProposeCollect}; | pub use self::propose_collect::{ProposeCollect}; | ||||||
| 
 | 
 | ||||||
| use common::{HashMap, SemanticVersion, Header, EnvInfo, Address, Builtin, BTreeMap, U256, Bytes, SignedTransaction, Error}; | use common::{HashMap, SemanticVersion, Header, EnvInfo, Address, Builtin, BTreeMap, U256, Bytes, SignedTransaction, Error, UntrustedRlp}; | ||||||
| use account_provider::AccountProvider; | use account_provider::AccountProvider; | ||||||
| use block::ExecutedBlock; | use block::ExecutedBlock; | ||||||
| use spec::CommonParams; | use spec::CommonParams; | ||||||
| @ -121,7 +121,7 @@ pub trait Engine : Sync + Send { | |||||||
| 
 | 
 | ||||||
| 	/// Handle any potential consensus messages;
 | 	/// Handle any potential consensus messages;
 | ||||||
| 	/// updating consensus state and potentially issuing a new one.
 | 	/// updating consensus state and potentially issuing a new one.
 | ||||||
| 	fn handle_message(&self, sender: Address, message: Bytes) -> Option<Vec<u8>> { None } | 	fn handle_message(&self, sender: Address, message: UntrustedRlp) -> Option<UntrustedRlp> { None } | ||||||
| 
 | 
 | ||||||
| 	// TODO: builtin contract routing - to do this properly, it will require removing the built-in configuration-reading logic
 | 	// TODO: builtin contract routing - to do this properly, it will require removing the built-in configuration-reading logic
 | ||||||
| 	// from Spec into here and removing the Spec::builtins field.
 | 	// from Spec into here and removing the Spec::builtins field.
 | ||||||
|  | |||||||
| @ -88,6 +88,10 @@ impl Tendermint { | |||||||
| 		let ref p = self.our_params; | 		let ref p = self.our_params; | ||||||
| 		p.validators.get(p.proposer_nonce%p.validator_n).unwrap().clone() | 		p.validators.get(p.proposer_nonce%p.validator_n).unwrap().clone() | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	fn propose_message(&self, message: UntrustedRlp) -> Option<UntrustedRlp> { | ||||||
|  | 		None | ||||||
|  | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Engine for Tendermint { | impl Engine for Tendermint { | ||||||
| @ -140,13 +144,11 @@ impl Engine for Tendermint { | |||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn handle_message(&self, sender: Address, message: Bytes) -> Option<Vec<u8>> { | 	fn handle_message(&self, sender: Address, message: UntrustedRlp) -> Option<UntrustedRlp> { | ||||||
| 		match message[0] { | 		match message.val_at(0).unwrap_or(return None) { | ||||||
| 			0 => println!("0"), | 			0u8 if sender == self.proposer() => self.propose_message(message), | ||||||
| 			_ => println!("unknown"), | 			_ => None, | ||||||
| 		} | 		} | ||||||
| 		//let sig: Signature = message.into();
 |  | ||||||
| 		None |  | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn verify_block_basic(&self, header: &Header, _block: Option<&[u8]>) -> result::Result<(), Error> { | 	fn verify_block_basic(&self, header: &Header, _block: Option<&[u8]>) -> result::Result<(), Error> { | ||||||
|  | |||||||
| @ -189,7 +189,7 @@ impl ChainNotify for EthSync { | |||||||
| 		self.network.stop().unwrap_or_else(|e| warn!("Error stopping network: {:?}", e)); | 		self.network.stop().unwrap_or_else(|e| warn!("Error stopping network: {:?}", e)); | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn broadcast(&self, message: Vec<u8>) { | 	fn broadcast(&self, message: &[u8]) { | ||||||
| 		self.network.with_context(ETH_PROTOCOL, |context| { | 		self.network.with_context(ETH_PROTOCOL, |context| { | ||||||
| 			let mut sync_io = NetSyncIo::new(context, &*self.eth_handler.chain); | 			let mut sync_io = NetSyncIo::new(context, &*self.eth_handler.chain); | ||||||
| 			self.inf_handler.sync.write().propagate_packet(&mut sync_io, message.clone()); | 			self.inf_handler.sync.write().propagate_packet(&mut sync_io, message.clone()); | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user