* version: bump beta to 2.3.3 * import rpc transactions sequentially (#10051) * import rpc transactions sequentially * use impl trait in argument position, renamed ProspectiveDispatcher to WithPostSign * grouped imports * integrates PostSign with ProspectiveSigner * fix spaces, removed unnecessary type cast and duplicate polling * clean up code style * Apply suggestions from code review * Fix Windows build (#10284) * Don't run the CPP example on CI (#10285) * Don't run the CPP example on CI * Add comment * CI optimizations (#10297) * CI optimizations * fix stripping * new dockerfile * no need n submodule upd * review * moved dockerfile * it becomes large * onchain update depends on s3 * fix dependency * fix cache status * fix cache status * new cache status * fix publish job (#10317) * fix publish job * dashes and colonels * Add Statetest support for Constantinople Fix (#10323) * Update Ethereum tests repo to v6.0.0-beta.3 tag * Add spec for St.Peter's / ConstantinopleFix statetests * Properly handle check_epoch_end_signal errors (#10015) * Make check_epoch_end_signal to only use immutable data * Move check_epoch_end_signals out of commit_block * Make check_epoch_end_signals possible to fail * Actually return the error from check_epoch_end_signals * Remove a clone * Fix import error * cargo: fix compilation * fix(add helper for timestamp overflows) (#10330) * fix(add helper timestamp overflows) * fix(simplify code) * fix(make helper private) * Remove CallContract and RegistryInfo re-exports from `ethcore/client` (#10205) * Remove re-export of `CallContract` and `RegistryInfo` from `ethcore/client` * Remove CallContract and RegistryInfo re-exports again This was missed while fixing merge conflicts * fix(docker): fix not receives SIGINT (#10059) * fix(docker): fix not receives SIGINT * fix: update with reviews * update with review * update * update * snap: official image / test (#10168) * official image / test * fix / test * bit more necromancy * fix paths * add source bin/df /test * add source bin/df /test2 * something w paths /test * something w paths /test * add source-type /test * show paths /test * copy plugin /test * plugin -> nil * install rhash * no questions while installing rhash * publish snap only for release * Don't add discovery initiators to the node table (#10305) * Don't add discovery initiators to the node table * Use enums for tracking state of the nodes in discovery * Dont try to ping ourselves * Fix minor nits * Update timeouts when observing an outdated node * Extracted update_bucket_record from update_node * Fixed typo * Fix two final nits from @todr * Extract CallContract and RegistryInfo traits into their own crate (#10178) * Create call-contract crate * Add license * First attempt at using extracted CallContract trait * Remove unneeded `extern crate` calls * Move RegistryInfo trait into call-contract crate * Move service-transaction-checker from ethcore to ethcore-miner * Update Cargo.lock file * Re-export call_contract * Merge CallContract and RegistryInfo imports * Remove commented code * Add documentation to call_contract crate * Add TODO for removal of re-exports * Update call-contract crate description Co-Authored-By: HCastano <HCastano@users.noreply.github.com> * Rename call-contract crate to ethcore-call-contract * Remove CallContract and RegistryInfo re-exports from `ethcore/client` (#10205) * Remove re-export of `CallContract` and `RegistryInfo` from `ethcore/client` * Remove CallContract and RegistryInfo re-exports again This was missed while fixing merge conflicts * fixed: types::transaction::SignedTransaction; (#10229) * fix daemonize dependency * fix build * change docker image based on debian instead of ubuntu due to the chan… (#10336) * change docker image based on debian instead of ubuntu due to the changes of the build container * role back docker build image and docker deploy image to ubuntu:xenial based (#10338) * perform stripping during build (#10208) * perform stripping during build (#10208) * perform stripping during build * var RUSTFLAGS
104 lines
4.0 KiB
Rust
104 lines
4.0 KiB
Rust
// Copyright 2015-2019 Parity Technologies (UK) Ltd.
|
|
// This file is part of Parity Ethereum.
|
|
|
|
// Parity Ethereum 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 Ethereum 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 Ethereum. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
use std::sync::{Arc, Weak};
|
|
use bytes::Bytes;
|
|
use call_contract::RegistryInfo;
|
|
use common_types::transaction::{Transaction, SignedTransaction, Action};
|
|
use ethereum_types::Address;
|
|
use ethcore::client::{Client, BlockChainClient, ChainInfo, Nonce, BlockId};
|
|
use ethcore::miner::{Miner, MinerService};
|
|
use sync::SyncProvider;
|
|
use helpers::{get_confirmed_block_hash, REQUEST_CONFIRMATIONS_REQUIRED};
|
|
use {Error, NodeKeyPair, ContractAddress};
|
|
|
|
#[derive(Clone)]
|
|
/// 'Trusted' client weak reference.
|
|
pub struct TrustedClient {
|
|
/// This key server node key pair.
|
|
self_key_pair: Arc<NodeKeyPair>,
|
|
/// Blockchain client.
|
|
client: Weak<Client>,
|
|
/// Sync provider.
|
|
sync: Weak<SyncProvider>,
|
|
/// Miner service.
|
|
miner: Weak<Miner>,
|
|
}
|
|
|
|
impl TrustedClient {
|
|
/// Create new trusted client.
|
|
pub fn new(self_key_pair: Arc<NodeKeyPair>, client: Arc<Client>, sync: Arc<SyncProvider>, miner: Arc<Miner>) -> Self {
|
|
TrustedClient {
|
|
self_key_pair: self_key_pair,
|
|
client: Arc::downgrade(&client),
|
|
sync: Arc::downgrade(&sync),
|
|
miner: Arc::downgrade(&miner),
|
|
}
|
|
}
|
|
|
|
/// Get 'trusted' `Client` reference only if it is synchronized && trusted.
|
|
pub fn get(&self) -> Option<Arc<Client>> {
|
|
self.client.upgrade()
|
|
.and_then(|client| self.sync.upgrade().map(|sync| (client, sync)))
|
|
.and_then(|(client, sync)| {
|
|
let is_synced = !sync.status().is_syncing(client.queue_info());
|
|
let is_trusted = client.chain_info().security_level().is_full();
|
|
match is_synced && is_trusted {
|
|
true => Some(client),
|
|
false => None,
|
|
}
|
|
})
|
|
}
|
|
|
|
/// Get untrusted `Client` reference.
|
|
pub fn get_untrusted(&self) -> Option<Arc<Client>> {
|
|
self.client.upgrade()
|
|
}
|
|
|
|
/// Transact contract.
|
|
pub fn transact_contract(&self, contract: Address, tx_data: Bytes) -> Result<(), Error> {
|
|
let client = self.client.upgrade().ok_or_else(|| Error::Internal("cannot submit tx when client is offline".into()))?;
|
|
let miner = self.miner.upgrade().ok_or_else(|| Error::Internal("cannot submit tx when miner is offline".into()))?;
|
|
let engine = client.engine();
|
|
let transaction = Transaction {
|
|
nonce: client.latest_nonce(&self.self_key_pair.address()),
|
|
action: Action::Call(contract),
|
|
gas: miner.authoring_params().gas_range_target.0,
|
|
gas_price: miner.sensible_gas_price(),
|
|
value: Default::default(),
|
|
data: tx_data,
|
|
};
|
|
let chain_id = engine.signing_chain_id(&client.latest_env_info());
|
|
let signature = self.self_key_pair.sign(&transaction.hash(chain_id))?;
|
|
let signed = SignedTransaction::new(transaction.with_signature(signature, chain_id))?;
|
|
miner.import_own_transaction(&*client, signed.into())
|
|
.map_err(|e| Error::Internal(format!("failed to import tx: {}", e)))
|
|
}
|
|
|
|
/// Read contract address. If address source is registry, address only returned if current client state is
|
|
/// trusted. Address from registry is read from registry from block latest block with
|
|
/// REQUEST_CONFIRMATIONS_REQUIRED confirmations.
|
|
pub fn read_contract_address(&self, registry_name: String, address: &ContractAddress) -> Option<Address> {
|
|
match *address {
|
|
ContractAddress::Address(ref address) => Some(address.clone()),
|
|
ContractAddress::Registry => self.get().and_then(|client|
|
|
get_confirmed_block_hash(&*client, REQUEST_CONFIRMATIONS_REQUIRED)
|
|
.and_then(|block| client.registry_address(registry_name, BlockId::Hash(block)))
|
|
),
|
|
}
|
|
}
|
|
}
|