Merge branch 'master' of github.com:ethcore/parity into trace_err
This commit is contained in:
		
						commit
						506ca15a15
					
				
							
								
								
									
										35
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										35
									
								
								Cargo.lock
									
									
									
										generated
									
									
									
								
							| @ -356,10 +356,15 @@ dependencies = [ | |||||||
|  "jsonrpc-core 2.0.4 (registry+https://github.com/rust-lang/crates.io-index)", |  "jsonrpc-core 2.0.4 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "jsonrpc-http-server 5.1.0 (git+https://github.com/ethcore/jsonrpc-http-server.git)", |  "jsonrpc-http-server 5.1.0 (git+https://github.com/ethcore/jsonrpc-http-server.git)", | ||||||
|  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", |  "log 0.3.6 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "parity-idmanager 0.1.3 (git+https://github.com/ethcore/parity-idmanager-rs.git)", |  "parity-idmanager 0.2.2 (git+https://github.com/ethcore/parity-idmanager-rs.git)", | ||||||
|  "parity-status 0.4.1 (git+https://github.com/ethcore/parity-status.git)", |  "parity-status 0.4.3 (git+https://github.com/ethcore/parity-status.git)", | ||||||
|  "parity-wallet 0.3.0 (git+https://github.com/ethcore/parity-wallet.git)", |  "parity-wallet 0.4.0 (git+https://github.com/ethcore/parity-wallet.git)", | ||||||
|  "parity-webapp 0.1.0 (git+https://github.com/ethcore/parity-webapp.git)", |  "parity-webapp 0.2.0 (git+https://github.com/ethcore/parity-webapp.git)", | ||||||
|  |  "rustc-serialize 0.3.19 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde_codegen 0.7.4 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "serde_json 0.7.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  |  "syntex 0.32.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
|  "url 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", |  "url 1.0.0 (registry+https://github.com/rust-lang/crates.io-index)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| @ -831,32 +836,32 @@ source = "registry+https://github.com/rust-lang/crates.io-index" | |||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "parity-idmanager" | name = "parity-idmanager" | ||||||
| version = "0.1.3" | version = "0.2.2" | ||||||
| source = "git+https://github.com/ethcore/parity-idmanager-rs.git#efb69592b87854f41d8882de75982c8f1e748666" | source = "git+https://github.com/ethcore/parity-idmanager-rs.git#e93ef48a78722561d52ab88c3dfcc5c1465558ac" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "parity-webapp 0.1.0 (git+https://github.com/ethcore/parity-webapp.git)", |  "parity-webapp 0.2.0 (git+https://github.com/ethcore/parity-webapp.git)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "parity-status" | name = "parity-status" | ||||||
| version = "0.4.1" | version = "0.4.3" | ||||||
| source = "git+https://github.com/ethcore/parity-status.git#f121ebd1f49986545d9fc262ba210cdf07039e6d" | source = "git+https://github.com/ethcore/parity-status.git#1d383d74010f6ebcd712b60b8fc5ff547b44f4e5" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "parity-webapp 0.1.0 (git+https://github.com/ethcore/parity-webapp.git)", |  "parity-webapp 0.2.0 (git+https://github.com/ethcore/parity-webapp.git)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "parity-wallet" | name = "parity-wallet" | ||||||
| version = "0.3.0" | version = "0.4.0" | ||||||
| source = "git+https://github.com/ethcore/parity-wallet.git#664fd2b85dd94ca184868bd3965e14a4ba68c03f" | source = "git+https://github.com/ethcore/parity-wallet.git#5391a89dc5dbf162d1beeba555f03c24bfd619bd" | ||||||
| dependencies = [ | dependencies = [ | ||||||
|  "parity-webapp 0.1.0 (git+https://github.com/ethcore/parity-webapp.git)", |  "parity-webapp 0.2.0 (git+https://github.com/ethcore/parity-webapp.git)", | ||||||
| ] | ] | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "parity-webapp" | name = "parity-webapp" | ||||||
| version = "0.1.0" | version = "0.2.0" | ||||||
| source = "git+https://github.com/ethcore/parity-webapp.git#0bf133f193863ba0e88b0b824a5c330037cce3f1" | source = "git+https://github.com/ethcore/parity-webapp.git#f31681af69631bcadfbef89a7e60dcc49552f7c6" | ||||||
| 
 | 
 | ||||||
| [[package]] | [[package]] | ||||||
| name = "primal" | name = "primal" | ||||||
|  | |||||||
| @ -436,10 +436,6 @@ impl<V> BlockChainClient for Client<V> where V: Verifier { | |||||||
| 		block.try_seal(self.engine.deref().deref(), seal) | 		block.try_seal(self.engine.deref().deref(), seal) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn engine(&self) -> &Engine { |  | ||||||
| 		self.engine.deref().deref() |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	fn vm_factory(&self) -> &EvmFactory { | 	fn vm_factory(&self) -> &EvmFactory { | ||||||
| 		&self.vm_factory | 		&self.vm_factory | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -35,17 +35,15 @@ use std::collections::HashSet; | |||||||
| use util::bytes::Bytes; | use util::bytes::Bytes; | ||||||
| use util::hash::{Address, H256, H2048}; | use util::hash::{Address, H256, H2048}; | ||||||
| use util::numbers::U256; | use util::numbers::U256; | ||||||
| use util::keys::store::AccountProvider; |  | ||||||
| use blockchain::TreeRoute; | use blockchain::TreeRoute; | ||||||
| use block_queue::BlockQueueInfo; | use block_queue::BlockQueueInfo; | ||||||
| use block::{ExecutedBlock, ClosedBlock, LockedBlock, SealedBlock}; | use block::{ClosedBlock, LockedBlock, SealedBlock}; | ||||||
| use header::{BlockNumber, Header}; | use header::{BlockNumber, Header}; | ||||||
| use transaction::{LocalizedTransaction, SignedTransaction}; | use transaction::{LocalizedTransaction, SignedTransaction}; | ||||||
| use log_entry::LocalizedLogEntry; | use log_entry::LocalizedLogEntry; | ||||||
| use filter::Filter; | use filter::Filter; | ||||||
| use error::{ImportResult, ExecutionError}; | use error::{ImportResult, ExecutionError}; | ||||||
| use receipt::LocalizedReceipt; | use receipt::LocalizedReceipt; | ||||||
| use engine::{Engine}; |  | ||||||
| use trace::LocalizedTrace; | use trace::LocalizedTrace; | ||||||
| use evm::Factory as EvmFactory; | use evm::Factory as EvmFactory; | ||||||
| 
 | 
 | ||||||
| @ -137,12 +135,6 @@ pub trait BlockChainClient : Sync + Send { | |||||||
| 	/// Makes a non-persistent transaction call.
 | 	/// Makes a non-persistent transaction call.
 | ||||||
| 	fn call(&self, t: &SignedTransaction) -> Result<Executed, ExecutionError>; | 	fn call(&self, t: &SignedTransaction) -> Result<Executed, ExecutionError>; | ||||||
| 
 | 
 | ||||||
| 	/// Attempt to seal the block internally. See `Engine`.
 |  | ||||||
| 	fn generate_seal(&self, block: &ExecutedBlock, accounts: Option<&AccountProvider>) -> Option<Vec<Bytes>> { self.engine().generate_seal(block, accounts) } |  | ||||||
| 
 |  | ||||||
| 	/// Executes a function providing it with a reference to an engine.
 |  | ||||||
| 	fn engine(&self) -> &Engine; |  | ||||||
| 
 |  | ||||||
| 	/// Returns EvmFactory.
 | 	/// Returns EvmFactory.
 | ||||||
| 	fn vm_factory(&self) -> &EvmFactory; | 	fn vm_factory(&self) -> &EvmFactory; | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -33,7 +33,6 @@ use block_queue::BlockQueueInfo; | |||||||
| use block::{SealedBlock, ClosedBlock, LockedBlock}; | use block::{SealedBlock, ClosedBlock, LockedBlock}; | ||||||
| use executive::Executed; | use executive::Executed; | ||||||
| use error::{ExecutionError}; | use error::{ExecutionError}; | ||||||
| use engine::Engine; |  | ||||||
| use trace::LocalizedTrace; | use trace::LocalizedTrace; | ||||||
| 
 | 
 | ||||||
| /// Test client.
 | /// Test client.
 | ||||||
| @ -431,10 +430,6 @@ impl BlockChainClient for TestBlockChainClient { | |||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn engine(&self) -> &Engine { |  | ||||||
| 		unimplemented!(); |  | ||||||
| 	} |  | ||||||
| 
 |  | ||||||
| 	fn vm_factory(&self) -> &EvmFactory { | 	fn vm_factory(&self) -> &EvmFactory { | ||||||
| 		unimplemented!(); | 		unimplemented!(); | ||||||
| 	} | 	} | ||||||
|  | |||||||
| @ -14,6 +14,8 @@ | |||||||
| // You should have received a copy of the GNU General Public License
 | // You should have received a copy of the GNU General Public License
 | ||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
|  | //! Consensus engine specification
 | ||||||
|  | 
 | ||||||
| use common::*; | use common::*; | ||||||
| use util::keys::store::AccountProvider; | use util::keys::store::AccountProvider; | ||||||
| use block::ExecutedBlock; | use block::ExecutedBlock; | ||||||
|  | |||||||
| @ -107,6 +107,7 @@ pub mod trace; | |||||||
| pub mod spec; | pub mod spec; | ||||||
| pub mod views; | pub mod views; | ||||||
| pub mod pod_state; | pub mod pod_state; | ||||||
|  | pub mod engine; | ||||||
| 
 | 
 | ||||||
| mod db; | mod db; | ||||||
| mod common; | mod common; | ||||||
| @ -116,7 +117,6 @@ mod env_info; | |||||||
| mod pod_account; | mod pod_account; | ||||||
| mod account_diff; | mod account_diff; | ||||||
| mod state_diff; | mod state_diff; | ||||||
| mod engine; |  | ||||||
| mod state; | mod state; | ||||||
| mod account; | mod account; | ||||||
| mod account_db; | mod account_db; | ||||||
|  | |||||||
| @ -25,6 +25,8 @@ use ethcore::block::{ClosedBlock, IsBlock}; | |||||||
| use ethcore::error::*; | use ethcore::error::*; | ||||||
| use ethcore::client::{Executive, Executed, EnvInfo, TransactOptions}; | use ethcore::client::{Executive, Executed, EnvInfo, TransactOptions}; | ||||||
| use ethcore::transaction::SignedTransaction; | use ethcore::transaction::SignedTransaction; | ||||||
|  | use ethcore::spec::Spec; | ||||||
|  | use ethcore::engine::Engine; | ||||||
| use super::{MinerService, MinerStatus, TransactionQueue, AccountDetails, TransactionImportResult, TransactionOrigin}; | use super::{MinerService, MinerStatus, TransactionQueue, AccountDetails, TransactionImportResult, TransactionOrigin}; | ||||||
| 
 | 
 | ||||||
| /// Keeps track of transactions using priority queue and holds currently mined block.
 | /// Keeps track of transactions using priority queue and holds currently mined block.
 | ||||||
| @ -39,6 +41,7 @@ pub struct Miner { | |||||||
| 	gas_floor_target: RwLock<U256>, | 	gas_floor_target: RwLock<U256>, | ||||||
| 	author: RwLock<Address>, | 	author: RwLock<Address>, | ||||||
| 	extra_data: RwLock<Bytes>, | 	extra_data: RwLock<Bytes>, | ||||||
|  | 	spec: Spec, | ||||||
| 
 | 
 | ||||||
| 	accounts: RwLock<Option<Arc<AccountService>>>,		// TODO: this is horrible since AccountService already contains a single RwLock field. refactor.
 | 	accounts: RwLock<Option<Arc<AccountService>>>,		// TODO: this is horrible since AccountService already contains a single RwLock field. refactor.
 | ||||||
| } | } | ||||||
| @ -55,13 +58,14 @@ impl Default for Miner { | |||||||
| 			author: RwLock::new(Address::default()), | 			author: RwLock::new(Address::default()), | ||||||
| 			extra_data: RwLock::new(Vec::new()), | 			extra_data: RwLock::new(Vec::new()), | ||||||
| 			accounts: RwLock::new(None), | 			accounts: RwLock::new(None), | ||||||
|  | 			spec: Spec::new_test(), | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Miner { | impl Miner { | ||||||
| 	/// Creates new instance of miner
 | 	/// Creates new instance of miner
 | ||||||
| 	pub fn new(force_sealing: bool) -> Arc<Miner> { | 	pub fn new(force_sealing: bool, spec: Spec) -> Arc<Miner> { | ||||||
| 		Arc::new(Miner { | 		Arc::new(Miner { | ||||||
| 			transaction_queue: Mutex::new(TransactionQueue::new()), | 			transaction_queue: Mutex::new(TransactionQueue::new()), | ||||||
| 			force_sealing: force_sealing, | 			force_sealing: force_sealing, | ||||||
| @ -72,11 +76,12 @@ impl Miner { | |||||||
| 			author: RwLock::new(Address::default()), | 			author: RwLock::new(Address::default()), | ||||||
| 			extra_data: RwLock::new(Vec::new()), | 			extra_data: RwLock::new(Vec::new()), | ||||||
| 			accounts: RwLock::new(None), | 			accounts: RwLock::new(None), | ||||||
|  | 			spec: spec, | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	/// Creates new instance of miner
 | 	/// Creates new instance of miner
 | ||||||
| 	pub fn with_accounts(force_sealing: bool, accounts: Arc<AccountService>) -> Arc<Miner> { | 	pub fn with_accounts(force_sealing: bool, spec: Spec, accounts: Arc<AccountService>) -> Arc<Miner> { | ||||||
| 		Arc::new(Miner { | 		Arc::new(Miner { | ||||||
| 			transaction_queue: Mutex::new(TransactionQueue::new()), | 			transaction_queue: Mutex::new(TransactionQueue::new()), | ||||||
| 			force_sealing: force_sealing, | 			force_sealing: force_sealing, | ||||||
| @ -87,9 +92,14 @@ impl Miner { | |||||||
| 			author: RwLock::new(Address::default()), | 			author: RwLock::new(Address::default()), | ||||||
| 			extra_data: RwLock::new(Vec::new()), | 			extra_data: RwLock::new(Vec::new()), | ||||||
| 			accounts: RwLock::new(Some(accounts)), | 			accounts: RwLock::new(Some(accounts)), | ||||||
|  | 			spec: spec, | ||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
|  | 	fn engine(&self) -> &Engine { | ||||||
|  | 		self.spec.engine.deref() | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	/// Prepares new block for sealing including top transactions from queue.
 | 	/// Prepares new block for sealing including top transactions from queue.
 | ||||||
| 	#[cfg_attr(feature="dev", allow(match_same_arms))] | 	#[cfg_attr(feature="dev", allow(match_same_arms))] | ||||||
| 	fn prepare_sealing(&self, chain: &BlockChainClient) { | 	fn prepare_sealing(&self, chain: &BlockChainClient) { | ||||||
| @ -111,7 +121,7 @@ impl Miner { | |||||||
| 			Some(old_block) => { | 			Some(old_block) => { | ||||||
| 				trace!(target: "miner", "Already have previous work; updating and returning"); | 				trace!(target: "miner", "Already have previous work; updating and returning"); | ||||||
| 				// add transactions to old_block
 | 				// add transactions to old_block
 | ||||||
| 				let e = chain.engine(); | 				let e = self.engine(); | ||||||
| 				let mut invalid_transactions = HashSet::new(); | 				let mut invalid_transactions = HashSet::new(); | ||||||
| 				let mut block = old_block.reopen(e, chain.vm_factory()); | 				let mut block = old_block.reopen(e, chain.vm_factory()); | ||||||
| 				let block_number = block.block().fields().header.number(); | 				let block_number = block.block().fields().header.number(); | ||||||
| @ -166,7 +176,7 @@ impl Miner { | |||||||
| 				trace!(target: "miner", "prepare_sealing: block has transaction - attempting internal seal."); | 				trace!(target: "miner", "prepare_sealing: block has transaction - attempting internal seal."); | ||||||
| 				// block with transactions - see if we can seal immediately.
 | 				// block with transactions - see if we can seal immediately.
 | ||||||
| 				let a = self.accounts.read().unwrap(); | 				let a = self.accounts.read().unwrap(); | ||||||
| 				let s = chain.generate_seal(block.block(), match *a.deref() { | 				let s = self.engine().generate_seal(block.block(), match *a.deref() { | ||||||
| 					Some(ref x) => Some(x.deref() as &AccountProvider), | 					Some(ref x) => Some(x.deref() as &AccountProvider), | ||||||
| 					None => None, | 					None => None, | ||||||
| 				}); | 				}); | ||||||
| @ -267,7 +277,8 @@ impl MinerService for Miner { | |||||||
| 				state.sub_balance(&sender, &balance); | 				state.sub_balance(&sender, &balance); | ||||||
| 				state.add_balance(&sender, &U256::max_value()); | 				state.add_balance(&sender, &U256::max_value()); | ||||||
| 				let options = TransactOptions { tracing: false, check_nonce: false }; | 				let options = TransactOptions { tracing: false, check_nonce: false }; | ||||||
| 				Executive::new(&mut state, &env_info, chain.engine(), chain.vm_factory()).transact(t, options) | 
 | ||||||
|  | 				Executive::new(&mut state, &env_info, self.engine(), chain.vm_factory()).transact(t, options) | ||||||
| 			}, | 			}, | ||||||
| 			None => { | 			None => { | ||||||
| 				chain.call(t) | 				chain.call(t) | ||||||
|  | |||||||
| @ -145,7 +145,7 @@ fn execute_client(conf: Configuration) { | |||||||
| 	let client = service.client(); | 	let client = service.client(); | ||||||
| 
 | 
 | ||||||
| 	// Miner
 | 	// Miner
 | ||||||
| 	let miner = Miner::with_accounts(conf.args.flag_force_sealing, account_service.clone()); | 	let miner = Miner::with_accounts(conf.args.flag_force_sealing, conf.spec(), account_service.clone()); | ||||||
| 	miner.set_author(conf.author()); | 	miner.set_author(conf.author()); | ||||||
| 	miner.set_gas_floor_target(conf.gas_floor_target()); | 	miner.set_gas_floor_target(conf.gas_floor_target()); | ||||||
| 	miner.set_extra_data(conf.extra_data()); | 	miner.set_extra_data(conf.extra_data()); | ||||||
|  | |||||||
| @ -45,7 +45,7 @@ | |||||||
| //! 	let mut service = NetworkService::start(NetworkConfiguration::new()).unwrap();
 | //! 	let mut service = NetworkService::start(NetworkConfiguration::new()).unwrap();
 | ||||||
| //! 	let dir = env::temp_dir();
 | //! 	let dir = env::temp_dir();
 | ||||||
| //! 	let client = Client::new(ClientConfig::default(), ethereum::new_frontier(), &dir, service.io().channel()).unwrap();
 | //! 	let client = Client::new(ClientConfig::default(), ethereum::new_frontier(), &dir, service.io().channel()).unwrap();
 | ||||||
| //! 	let miner = Miner::new(false);
 | //! 	let miner = Miner::new(false, ethereum::new_frontier());
 | ||||||
| //! 	EthSync::register(&mut service, SyncConfig::default(), client, miner);
 | //! 	EthSync::register(&mut service, SyncConfig::default(), client, miner);
 | ||||||
| //! }
 | //! }
 | ||||||
| //! ```
 | //! ```
 | ||||||
|  | |||||||
| @ -16,6 +16,7 @@ | |||||||
| 
 | 
 | ||||||
| use util::*; | use util::*; | ||||||
| use ethcore::client::{TestBlockChainClient, BlockChainClient}; | use ethcore::client::{TestBlockChainClient, BlockChainClient}; | ||||||
|  | use ethcore::spec::Spec; | ||||||
| use io::SyncIo; | use io::SyncIo; | ||||||
| use chain::ChainSync; | use chain::ChainSync; | ||||||
| use ethminer::Miner; | use ethminer::Miner; | ||||||
| @ -93,7 +94,7 @@ impl TestNet { | |||||||
| 		for _ in 0..n { | 		for _ in 0..n { | ||||||
| 			net.peers.push(TestPeer { | 			net.peers.push(TestPeer { | ||||||
| 				chain: TestBlockChainClient::new(), | 				chain: TestBlockChainClient::new(), | ||||||
| 				sync: ChainSync::new(SyncConfig::default(), Miner::new(false)), | 				sync: ChainSync::new(SyncConfig::default(), Miner::new(false, Spec::new_test())), | ||||||
| 				queue: VecDeque::new(), | 				queue: VecDeque::new(), | ||||||
| 			}); | 			}); | ||||||
| 		} | 		} | ||||||
|  | |||||||
| @ -4,6 +4,7 @@ name = "ethcore-webapp" | |||||||
| version = "1.2.0" | version = "1.2.0" | ||||||
| license = "GPL-3.0" | license = "GPL-3.0" | ||||||
| authors = ["Ethcore <admin@ethcore.io"] | authors = ["Ethcore <admin@ethcore.io"] | ||||||
|  | build = "build.rs" | ||||||
| 
 | 
 | ||||||
| [lib] | [lib] | ||||||
| 
 | 
 | ||||||
| @ -13,15 +14,24 @@ jsonrpc-core = "2.0" | |||||||
| jsonrpc-http-server = { git = "https://github.com/ethcore/jsonrpc-http-server.git" } | jsonrpc-http-server = { git = "https://github.com/ethcore/jsonrpc-http-server.git" } | ||||||
| hyper = { default-features = false, git = "https://github.com/ethcore/hyper" } | hyper = { default-features = false, git = "https://github.com/ethcore/hyper" } | ||||||
| url = "1.0" | url = "1.0" | ||||||
|  | rustc-serialize = "0.3" | ||||||
|  | serde = "0.7.0" | ||||||
|  | serde_json = "0.7.0" | ||||||
|  | serde_macros = { version = "0.7.0", optional = true } | ||||||
| ethcore-rpc = { path = "../rpc" } | ethcore-rpc = { path = "../rpc" } | ||||||
| ethcore-util = { path = "../util" } | ethcore-util = { path = "../util" } | ||||||
| parity-webapp = { git = "https://github.com/ethcore/parity-webapp.git" } | parity-webapp = { git = "https://github.com/ethcore/parity-webapp.git", version = "0.2" } | ||||||
| # List of apps | # List of apps | ||||||
| parity-status = { git = "https://github.com/ethcore/parity-status.git", version = "0.4.1" } | parity-status = { git = "https://github.com/ethcore/parity-status.git", version = "0.4.3" } | ||||||
| parity-idmanager = { git = "https://github.com/ethcore/parity-idmanager-rs.git", version = "0.1.3" } | parity-idmanager = { git = "https://github.com/ethcore/parity-idmanager-rs.git", version = "0.2.2" } | ||||||
| parity-wallet = { git = "https://github.com/ethcore/parity-wallet.git", version = "0.3.0", optional = true } | parity-wallet = { git = "https://github.com/ethcore/parity-wallet.git", version = "0.4.0", optional = true } | ||||||
| clippy = { version = "0.0.67", optional = true} | clippy = { version = "0.0.67", optional = true} | ||||||
| 
 | 
 | ||||||
|  | [build-dependencies] | ||||||
|  | serde_codegen = { version = "0.7.0", optional = true } | ||||||
|  | syntex = "0.32.0" | ||||||
|  | 
 | ||||||
| [features] | [features] | ||||||
| default = ["parity-wallet"] | default = ["parity-wallet", "serde_codegen"] | ||||||
|  | nightly = ["serde_macros"] | ||||||
| dev = ["clippy", "ethcore-rpc/dev", "ethcore-util/dev"] | dev = ["clippy", "ethcore-rpc/dev", "ethcore-util/dev"] | ||||||
|  | |||||||
							
								
								
									
										45
									
								
								webapp/build.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										45
									
								
								webapp/build.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,45 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | #[cfg(not(feature = "serde_macros"))] | ||||||
|  | mod inner { | ||||||
|  |     extern crate syntex; | ||||||
|  |     extern crate serde_codegen; | ||||||
|  | 
 | ||||||
|  |     use std::env; | ||||||
|  |     use std::path::Path; | ||||||
|  | 
 | ||||||
|  |     pub fn main() { | ||||||
|  |         let out_dir = env::var_os("OUT_DIR").unwrap(); | ||||||
|  | 
 | ||||||
|  |         let src = Path::new("./src/api/mod.rs.in"); | ||||||
|  |         let dst = Path::new(&out_dir).join("mod.rs"); | ||||||
|  | 
 | ||||||
|  |         let mut registry = syntex::Registry::new(); | ||||||
|  | 
 | ||||||
|  |         serde_codegen::register(&mut registry); | ||||||
|  |         registry.expand("", &src, &dst).unwrap(); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | #[cfg(feature = "serde_macros")] | ||||||
|  | mod inner { | ||||||
|  |     pub fn main() {} | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | fn main() { | ||||||
|  |     inner::main(); | ||||||
|  | } | ||||||
| @ -14,15 +14,26 @@ | |||||||
| // You should have received a copy of the GNU General Public License
 | // You should have received a copy of the GNU General Public License
 | ||||||
| // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
| 
 | 
 | ||||||
| //! Simple REST API
 |  | ||||||
| 
 |  | ||||||
| use std::sync::Arc; | use std::sync::Arc; | ||||||
| use endpoint::{Endpoint, Endpoints, ContentHandler, Handler, EndpointPath}; | use endpoint::{Endpoint, Endpoints, Handler, EndpointPath}; | ||||||
|  | 
 | ||||||
|  | use api::response::as_json; | ||||||
| 
 | 
 | ||||||
| pub struct RestApi { | pub struct RestApi { | ||||||
| 	endpoints: Arc<Endpoints>, | 	endpoints: Arc<Endpoints>, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #[derive(Debug, PartialEq, Serialize)] | ||||||
|  | struct App { | ||||||
|  | 	pub id: String, | ||||||
|  | 	pub name: String, | ||||||
|  | 	pub description: String, | ||||||
|  | 	pub version: String, | ||||||
|  | 	pub author: String, | ||||||
|  | 	#[serde(rename="iconUrl")] | ||||||
|  | 	pub icon_url: String, | ||||||
|  | } | ||||||
|  | 
 | ||||||
| impl RestApi { | impl RestApi { | ||||||
| 	pub fn new(endpoints: Arc<Endpoints>) -> Box<Endpoint> { | 	pub fn new(endpoints: Arc<Endpoints>) -> Box<Endpoint> { | ||||||
| 		Box::new(RestApi { | 		Box::new(RestApi { | ||||||
| @ -30,20 +41,23 @@ impl RestApi { | |||||||
| 		}) | 		}) | ||||||
| 	} | 	} | ||||||
| 
 | 
 | ||||||
| 	fn list_pages(&self) -> String { | 	fn list_apps(&self) -> Vec<App> { | ||||||
| 		let mut s = "[".to_owned(); | 		self.endpoints.iter().filter_map(|(ref k, ref e)| { | ||||||
| 		for name in self.endpoints.keys() { | 			e.info().map(|ref info| App { | ||||||
| 			s.push_str(&format!("\"{}\",", name)); | 				id: k.to_owned().clone(), | ||||||
| 		} | 				name: info.name.clone(), | ||||||
| 		s.push_str("\"rpc\""); | 				description: info.description.clone(), | ||||||
| 		s.push_str("]"); | 				version: info.version.clone(), | ||||||
| 		s | 				author: info.author.clone(), | ||||||
|  | 				icon_url: info.icon_url.clone(), | ||||||
|  | 			}) | ||||||
|  | 		}).collect() | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl Endpoint for RestApi { | impl Endpoint for RestApi { | ||||||
| 	fn to_handler(&self, _path: EndpointPath) -> Box<Handler> { | 	fn to_handler(&self, _path: EndpointPath) -> Box<Handler> { | ||||||
| 		Box::new(ContentHandler::new(self.list_pages(), "application/json".to_owned())) | 		as_json(&self.list_apps()) | ||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
							
								
								
									
										28
									
								
								webapp/src/api/mod.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								webapp/src/api/mod.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,28 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | //! REST API
 | ||||||
|  | 
 | ||||||
|  | #![warn(missing_docs)] | ||||||
|  | #![cfg_attr(feature="nightly", feature(custom_derive, custom_attribute, plugin))] | ||||||
|  | #![cfg_attr(feature="nightly", plugin(serde_macros, clippy))] | ||||||
|  | 
 | ||||||
|  | #[cfg(feature = "serde_macros")] | ||||||
|  | include!("mod.rs.in"); | ||||||
|  | 
 | ||||||
|  | #[cfg(not(feature = "serde_macros"))] | ||||||
|  | include!(concat!(env!("OUT_DIR"), "/mod.rs")); | ||||||
|  | 
 | ||||||
							
								
								
									
										20
									
								
								webapp/src/api/mod.rs.in
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										20
									
								
								webapp/src/api/mod.rs.in
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,20 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | mod api; | ||||||
|  | mod response; | ||||||
|  | 
 | ||||||
|  | pub use self::api::RestApi; | ||||||
							
								
								
									
										23
									
								
								webapp/src/api/response.rs
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										23
									
								
								webapp/src/api/response.rs
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,23 @@ | |||||||
|  | // Copyright 2015, 2016 Ethcore (UK) Ltd.
 | ||||||
|  | // This file is part of Parity.
 | ||||||
|  | 
 | ||||||
|  | // Parity is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | 
 | ||||||
|  | // Parity is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | 
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with Parity.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | 
 | ||||||
|  | use serde::Serialize; | ||||||
|  | use serde_json; | ||||||
|  | use endpoint::{ContentHandler, Handler}; | ||||||
|  | 
 | ||||||
|  | pub fn as_json<T : Serialize>(val: &T) -> Box<Handler> { | ||||||
|  | 	Box::new(ContentHandler::new(serde_json::to_string(val).unwrap(), "application/json".to_owned())) | ||||||
|  | } | ||||||
| @ -30,7 +30,7 @@ pub const API_PATH : &'static str =  "api"; | |||||||
| pub const UTILS_PATH : &'static str =  "parity-utils"; | pub const UTILS_PATH : &'static str =  "parity-utils"; | ||||||
| 
 | 
 | ||||||
| pub fn main_page() -> &'static str { | pub fn main_page() -> &'static str { | ||||||
| 	"/status/" | 	"/home/" | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| pub fn utils() -> Box<Endpoint> { | pub fn utils() -> Box<Endpoint> { | ||||||
| @ -43,6 +43,7 @@ pub fn all_endpoints() -> Endpoints { | |||||||
| 
 | 
 | ||||||
| 	insert::<parity_status::App>(&mut pages, "status"); | 	insert::<parity_status::App>(&mut pages, "status"); | ||||||
| 	insert::<parity_status::App>(&mut pages, "parity"); | 	insert::<parity_status::App>(&mut pages, "parity"); | ||||||
|  | 	insert::<parity_idmanager::App>(&mut pages, "home"); | ||||||
| 
 | 
 | ||||||
| 	wallet_page(&mut pages); | 	wallet_page(&mut pages); | ||||||
| 	pages | 	pages | ||||||
|  | |||||||
| @ -30,7 +30,18 @@ pub struct EndpointPath { | |||||||
| 	pub port: u16, | 	pub port: u16, | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | #[derive(Debug, PartialEq)] | ||||||
|  | pub struct EndpointInfo { | ||||||
|  | 	pub name: String, | ||||||
|  | 	pub description: String, | ||||||
|  | 	pub version: String, | ||||||
|  | 	pub author: String, | ||||||
|  | 	pub icon_url: String, | ||||||
|  | } | ||||||
|  | 
 | ||||||
| pub trait Endpoint : Send + Sync { | pub trait Endpoint : Send + Sync { | ||||||
|  | 	fn info(&self) -> Option<EndpointInfo> { None } | ||||||
|  | 
 | ||||||
| 	fn to_handler(&self, path: EndpointPath) -> Box<server::Handler<HttpStream>>; | 	fn to_handler(&self, path: EndpointPath) -> Box<server::Handler<HttpStream>>; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -47,6 +47,8 @@ | |||||||
| extern crate log; | extern crate log; | ||||||
| extern crate url; | extern crate url; | ||||||
| extern crate hyper; | extern crate hyper; | ||||||
|  | extern crate serde; | ||||||
|  | extern crate serde_json; | ||||||
| extern crate jsonrpc_core; | extern crate jsonrpc_core; | ||||||
| extern crate jsonrpc_http_server; | extern crate jsonrpc_http_server; | ||||||
| extern crate parity_webapp; | extern crate parity_webapp; | ||||||
|  | |||||||
| @ -22,8 +22,8 @@ use hyper::header; | |||||||
| use hyper::status::StatusCode; | use hyper::status::StatusCode; | ||||||
| use hyper::net::HttpStream; | use hyper::net::HttpStream; | ||||||
| use hyper::{Decoder, Encoder, Next}; | use hyper::{Decoder, Encoder, Next}; | ||||||
| use endpoint::{Endpoint, EndpointPath}; | use endpoint::{Endpoint, EndpointInfo, EndpointPath}; | ||||||
| use parity_webapp::WebApp; | use parity_webapp::{WebApp, Info}; | ||||||
| 
 | 
 | ||||||
| pub struct PageEndpoint<T : WebApp + 'static> { | pub struct PageEndpoint<T : WebApp + 'static> { | ||||||
| 	/// Content of the files
 | 	/// Content of the files
 | ||||||
| @ -39,6 +39,7 @@ impl<T: WebApp + 'static> PageEndpoint<T> { | |||||||
| 			prefix: None, | 			prefix: None, | ||||||
| 		} | 		} | ||||||
| 	} | 	} | ||||||
|  | 
 | ||||||
| 	pub fn with_prefix(app: T, prefix: String) -> Self { | 	pub fn with_prefix(app: T, prefix: String) -> Self { | ||||||
| 		PageEndpoint { | 		PageEndpoint { | ||||||
| 			app: Arc::new(app), | 			app: Arc::new(app), | ||||||
| @ -48,6 +49,11 @@ impl<T: WebApp + 'static> PageEndpoint<T> { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| impl<T: WebApp> Endpoint for PageEndpoint<T> { | impl<T: WebApp> Endpoint for PageEndpoint<T> { | ||||||
|  | 
 | ||||||
|  | 	fn info(&self) -> Option<EndpointInfo> { | ||||||
|  | 		Some(EndpointInfo::from(self.app.info())) | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
| 	fn to_handler(&self, path: EndpointPath) -> Box<server::Handler<HttpStream>> { | 	fn to_handler(&self, path: EndpointPath) -> Box<server::Handler<HttpStream>> { | ||||||
| 		Box::new(PageHandler { | 		Box::new(PageHandler { | ||||||
| 			app: self.app.clone(), | 			app: self.app.clone(), | ||||||
| @ -59,6 +65,18 @@ impl<T: WebApp> Endpoint for PageEndpoint<T> { | |||||||
| 	} | 	} | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | impl From<Info> for EndpointInfo { | ||||||
|  | 	fn from(info: Info) -> Self { | ||||||
|  | 		EndpointInfo { | ||||||
|  | 			name: info.name, | ||||||
|  | 			description: info.description, | ||||||
|  | 			author: info.author, | ||||||
|  | 			icon_url: info.icon_url, | ||||||
|  | 			version: info.version, | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | 
 | ||||||
| struct PageHandler<T: WebApp + 'static> { | struct PageHandler<T: WebApp + 'static> { | ||||||
| 	app: Arc<T>, | 	app: Arc<T>, | ||||||
| 	prefix: Option<String>, | 	prefix: Option<String>, | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user