move sign_and_send_transaction implementation to personal
This commit is contained in:
		
							parent
							
								
									db2efe8485
								
							
						
					
					
						commit
						c9efb56e19
					
				| @ -197,7 +197,7 @@ impl<C, S, A, M, EM> EthClient<C, S, A, M, EM> where | |||||||
| 			let client = take_weak!(self.client); | 			let client = take_weak!(self.client); | ||||||
| 			let miner = take_weak!(self.miner); | 			let miner = take_weak!(self.miner); | ||||||
| 
 | 
 | ||||||
| 			miner.import_own_transaction(client.deref(), signed_transaction, |a: &Address| { | 			miner.import_own_transaction(&*client, signed_transaction, |a: &Address| { | ||||||
| 				AccountDetails { | 				AccountDetails { | ||||||
| 					nonce: client.latest_nonce(&a), | 					nonce: client.latest_nonce(&a), | ||||||
| 					balance: client.latest_balance(&a), | 					balance: client.latest_balance(&a), | ||||||
| @ -550,17 +550,6 @@ impl<C, S, A, M, EM> Eth for EthClient<C, S, A, M, EM> where | |||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn sign_and_send_transaction(&self, params: Params) -> Result<Value, Error> { |  | ||||||
| 		from_params::<(TransactionRequest, String)>(params) |  | ||||||
| 			.and_then(|(request, password)| { |  | ||||||
| 				let accounts = take_weak!(self.accounts); |  | ||||||
| 				match accounts.locked_account_secret(&request.from, &password) { |  | ||||||
| 					Ok(secret) => self.sign_and_dispatch(request, secret), |  | ||||||
| 					Err(_) => to_value(&H256::zero()), |  | ||||||
| 				} |  | ||||||
| 		}) |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	fn send_raw_transaction(&self, params: Params) -> Result<Value, Error> { | 	fn send_raw_transaction(&self, params: Params) -> Result<Value, Error> { | ||||||
| 		from_params::<(Bytes, )>(params) | 		from_params::<(Bytes, )>(params) | ||||||
| 			.and_then(|(raw_transaction, )| { | 			.and_then(|(raw_transaction, )| { | ||||||
|  | |||||||
| @ -18,24 +18,82 @@ | |||||||
| use std::sync::{Arc, Weak}; | use std::sync::{Arc, Weak}; | ||||||
| use jsonrpc_core::*; | use jsonrpc_core::*; | ||||||
| use v1::traits::Personal; | use v1::traits::Personal; | ||||||
|  | use v1::types::TransactionRequest; | ||||||
|  | use util::bytes::ToPretty; | ||||||
| use util::keys::store::*; | use util::keys::store::*; | ||||||
| use util::Address; | use util::numbers::*; | ||||||
|  | use util::rlp::encode; | ||||||
|  | use ethcore::client::BlockChainClient; | ||||||
|  | use ethcore::transaction::{Action, SignedTransaction, Transaction as EthTransaction}; | ||||||
|  | use ethminer::{AccountDetails, MinerService}; | ||||||
| 
 | 
 | ||||||
| /// Account management (personal) rpc implementation.
 | /// Account management (personal) rpc implementation.
 | ||||||
| pub struct PersonalClient<A> where A: AccountProvider { | pub struct PersonalClient<A, C, M> | ||||||
|  | 	where A: AccountProvider, C: BlockChainClient, M: MinerService { | ||||||
| 	accounts: Weak<A>, | 	accounts: Weak<A>, | ||||||
|  | 	client: Weak<C>, | ||||||
|  | 	miner: Weak<M>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<A> PersonalClient<A> where A: AccountProvider { | impl<A, C, M> PersonalClient<A, C, M> | ||||||
|  | 	where A: AccountProvider, C: BlockChainClient, M: MinerService { | ||||||
| 	/// Creates new PersonalClient
 | 	/// Creates new PersonalClient
 | ||||||
| 	pub fn new(store: &Arc<A>) -> Self { | 	pub fn new(store: &Arc<A>, client: &Arc<C>, miner: &Arc<M>) -> Self { | ||||||
| 		PersonalClient { | 		PersonalClient { | ||||||
| 			accounts: Arc::downgrade(store), | 			accounts: Arc::downgrade(store), | ||||||
|  | 			client: Arc::downgrade(client), | ||||||
|  | 			miner: Arc::downgrade(miner), | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	fn dispatch_transaction(&self, signed_transaction: SignedTransaction) -> Result<Value, Error> { | ||||||
|  | 		let hash = signed_transaction.hash(); | ||||||
|  | 
 | ||||||
|  | 		let import = { | ||||||
|  | 			let client = take_weak!(self.client); | ||||||
|  | 			let miner = take_weak!(self.miner); | ||||||
|  | 
 | ||||||
|  | 			miner.import_own_transaction(&*client, signed_transaction, |a: &Address| { | ||||||
|  | 				AccountDetails { | ||||||
|  | 					nonce: client.nonce(&a), | ||||||
|  | 					balance: client.balance(&a), | ||||||
|  | 				} | ||||||
|  | 			}) | ||||||
|  | 		}; | ||||||
|  | 
 | ||||||
|  | 		match import { | ||||||
|  | 			Ok(_) => to_value(&hash), | ||||||
|  | 			Err(e) => { | ||||||
|  | 				warn!("Error sending transaction: {:?}", e); | ||||||
|  | 				to_value(&H256::zero()) | ||||||
| 			} | 			} | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| impl<A> Personal for PersonalClient<A> where A: AccountProvider + 'static { | 	fn sign_and_dispatch(&self, request: TransactionRequest, secret: H256) -> Result<Value, Error> { | ||||||
|  | 		let signed_transaction = { | ||||||
|  | 			let client = take_weak!(self.client); | ||||||
|  | 			let miner = take_weak!(self.miner); | ||||||
|  | 			EthTransaction { | ||||||
|  | 				nonce: request.nonce | ||||||
|  | 					.or_else(|| miner | ||||||
|  | 							 .last_nonce(&request.from) | ||||||
|  | 							 .map(|nonce| nonce + U256::one())) | ||||||
|  | 					.unwrap_or_else(|| client.nonce(&request.from)), | ||||||
|  | 					action: request.to.map_or(Action::Create, Action::Call), | ||||||
|  | 					gas: request.gas.unwrap_or_else(|| miner.sensible_gas_limit()), | ||||||
|  | 					gas_price: request.gas_price.unwrap_or_else(|| miner.sensible_gas_price()), | ||||||
|  | 					value: request.value.unwrap_or_else(U256::zero), | ||||||
|  | 					data: request.data.map_or_else(Vec::new, |b| b.to_vec()), | ||||||
|  | 			}.sign(&secret) | ||||||
|  | 		}; | ||||||
|  | 		trace!(target: "miner", "send_transaction: dispatching tx: {}", encode(&signed_transaction).to_vec().pretty()); | ||||||
|  | 		self.dispatch_transaction(signed_transaction) | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | impl<A: 'static, C: 'static, M: 'static> Personal for PersonalClient<A, C, M> | ||||||
|  | 	where A: AccountProvider, C: BlockChainClient, M: MinerService { | ||||||
| 	fn accounts(&self, _: Params) -> Result<Value, Error> { | 	fn accounts(&self, _: Params) -> Result<Value, Error> { | ||||||
| 		let store = take_weak!(self.accounts); | 		let store = take_weak!(self.accounts); | ||||||
| 		match store.accounts() { | 		match store.accounts() { | ||||||
| @ -66,4 +124,15 @@ impl<A> Personal for PersonalClient<A> where A: AccountProvider + 'static { | |||||||
| 				} | 				} | ||||||
| 			}) | 			}) | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
|  | 	fn sign_and_send_transaction(&self, params: Params) -> Result<Value, Error> { | ||||||
|  | 		from_params::<(TransactionRequest, String)>(params) | ||||||
|  | 			.and_then(|(request, password)| { | ||||||
|  | 				let accounts = take_weak!(self.accounts); | ||||||
|  | 				match accounts.locked_account_secret(&request.from, &password) { | ||||||
|  | 					Ok(secret) => self.sign_and_dispatch(request, secret), | ||||||
|  | 					Err(_) => to_value(&H256::zero()), | ||||||
|  | 				} | ||||||
|  | 		}) | ||||||
|  | 	} | ||||||
| } | } | ||||||
|  | |||||||
| @ -28,7 +28,7 @@ impl Bytes { | |||||||
| 	pub fn new(bytes: Vec<u8>) -> Bytes { | 	pub fn new(bytes: Vec<u8>) -> Bytes { | ||||||
| 		Bytes(bytes) | 		Bytes(bytes) | ||||||
| 	} | 	} | ||||||
| 	pub fn to_vec(self) -> Vec<u8> { let Bytes(x) = self; x } | 	pub fn to_vec(self) -> Vec<u8> { self.0 } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Serialize for Bytes { | impl Serialize for Bytes { | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user