2017-01-25 18:51:41 +01:00
|
|
|
// Copyright 2015-2017 Parity Technologies (UK) Ltd.
|
2016-03-10 11:32:10 +01:00
|
|
|
// 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/>.
|
|
|
|
|
2016-07-25 16:09:47 +02:00
|
|
|
use std::str::FromStr;
|
2016-10-21 23:21:57 +02:00
|
|
|
use std::path::Path;
|
2016-11-05 10:38:00 +01:00
|
|
|
use std::fmt::{Display, Formatter, Error as FmtError};
|
2017-07-12 13:09:17 +02:00
|
|
|
|
|
|
|
use mode::Mode as IpcMode;
|
|
|
|
use verification::{VerifierType, QueueConfig};
|
2017-10-17 06:20:24 +02:00
|
|
|
use journaldb;
|
2017-10-12 15:36:27 +02:00
|
|
|
use kvdb_rocksdb::CompactionProfile;
|
2017-07-12 13:09:17 +02:00
|
|
|
|
2016-07-05 17:50:46 +02:00
|
|
|
pub use std::time::Duration;
|
2016-05-26 18:24:51 +02:00
|
|
|
pub use blockchain::Config as BlockChainConfig;
|
2016-09-26 19:21:25 +02:00
|
|
|
pub use trace::Config as TraceConfig;
|
2016-05-19 00:44:49 +02:00
|
|
|
pub use evm::VMType;
|
2016-09-27 16:50:24 +02:00
|
|
|
|
2016-06-27 13:58:12 +02:00
|
|
|
/// Client state db compaction profile
|
2017-03-21 20:57:13 +01:00
|
|
|
#[derive(Debug, PartialEq, Clone)]
|
2016-06-27 13:58:12 +02:00
|
|
|
pub enum DatabaseCompactionProfile {
|
2016-10-21 23:21:57 +02:00
|
|
|
/// Try to determine compaction profile automatically
|
|
|
|
Auto,
|
|
|
|
/// SSD compaction profile
|
|
|
|
SSD,
|
2016-06-27 13:58:12 +02:00
|
|
|
/// HDD or other slow storage io compaction profile
|
|
|
|
HDD,
|
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for DatabaseCompactionProfile {
|
2016-07-25 16:09:47 +02:00
|
|
|
fn default() -> Self {
|
2016-10-21 23:21:57 +02:00
|
|
|
DatabaseCompactionProfile::Auto
|
2016-07-25 16:09:47 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-28 20:29:58 +02:00
|
|
|
impl DatabaseCompactionProfile {
|
|
|
|
/// Returns corresponding compaction profile.
|
2016-10-21 23:21:57 +02:00
|
|
|
pub fn compaction_profile(&self, db_path: &Path) -> CompactionProfile {
|
2016-07-28 20:29:58 +02:00
|
|
|
match *self {
|
2016-10-21 23:21:57 +02:00
|
|
|
DatabaseCompactionProfile::Auto => CompactionProfile::auto(db_path),
|
|
|
|
DatabaseCompactionProfile::SSD => CompactionProfile::ssd(),
|
2016-07-28 20:29:58 +02:00
|
|
|
DatabaseCompactionProfile::HDD => CompactionProfile::hdd(),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-07-25 16:09:47 +02:00
|
|
|
impl FromStr for DatabaseCompactionProfile {
|
|
|
|
type Err = String;
|
|
|
|
|
|
|
|
fn from_str(s: &str) -> Result<Self, Self::Err> {
|
|
|
|
match s {
|
2016-10-21 23:21:57 +02:00
|
|
|
"auto" => Ok(DatabaseCompactionProfile::Auto),
|
|
|
|
"ssd" => Ok(DatabaseCompactionProfile::SSD),
|
2016-07-25 16:09:47 +02:00
|
|
|
"hdd" => Ok(DatabaseCompactionProfile::HDD),
|
2016-10-21 23:21:57 +02:00
|
|
|
_ => Err("Invalid compaction profile given. Expected default/hdd/ssd.".into()),
|
2016-07-25 16:09:47 +02:00
|
|
|
}
|
|
|
|
}
|
2016-06-27 13:58:12 +02:00
|
|
|
}
|
|
|
|
|
2016-07-05 17:50:46 +02:00
|
|
|
/// Operating mode for the client.
|
2016-09-06 15:31:13 +02:00
|
|
|
#[derive(Debug, Eq, PartialEq, Clone)]
|
2016-07-05 17:50:46 +02:00
|
|
|
pub enum Mode {
|
|
|
|
/// Always on.
|
|
|
|
Active,
|
|
|
|
/// Goes offline after RLP is inactive for some (given) time, but
|
|
|
|
/// comes back online after a while of inactivity.
|
|
|
|
Passive(Duration, Duration),
|
|
|
|
/// Goes offline after RLP is inactive for some (given) time and
|
|
|
|
/// stays inactive.
|
|
|
|
Dark(Duration),
|
2016-10-31 16:58:35 +01:00
|
|
|
/// Always off.
|
|
|
|
Off,
|
2016-07-05 17:50:46 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
impl Default for Mode {
|
2016-07-25 16:09:47 +02:00
|
|
|
fn default() -> Self {
|
|
|
|
Mode::Active
|
|
|
|
}
|
2016-07-05 17:50:46 +02:00
|
|
|
}
|
|
|
|
|
2016-11-05 10:38:00 +01:00
|
|
|
impl Display for Mode {
|
|
|
|
fn fmt(&self, f: &mut Formatter) -> Result<(), FmtError> {
|
|
|
|
match *self {
|
|
|
|
Mode::Active => write!(f, "active"),
|
|
|
|
Mode::Passive(..) => write!(f, "passive"),
|
|
|
|
Mode::Dark(..) => write!(f, "dark"),
|
|
|
|
Mode::Off => write!(f, "offline"),
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-07-12 13:09:17 +02:00
|
|
|
impl Into<IpcMode> for Mode {
|
|
|
|
fn into(self) -> IpcMode {
|
|
|
|
match self {
|
|
|
|
Mode::Off => IpcMode::Off,
|
|
|
|
Mode::Dark(timeout) => IpcMode::Dark(timeout.as_secs()),
|
|
|
|
Mode::Passive(timeout, alarm) => IpcMode::Passive(timeout.as_secs(), alarm.as_secs()),
|
|
|
|
Mode::Active => IpcMode::Active,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
impl From<IpcMode> for Mode {
|
|
|
|
fn from(mode: IpcMode) -> Self {
|
|
|
|
match mode {
|
|
|
|
IpcMode::Off => Mode::Off,
|
|
|
|
IpcMode::Dark(timeout) => Mode::Dark(Duration::from_secs(timeout)),
|
|
|
|
IpcMode::Passive(timeout, alarm) => Mode::Passive(Duration::from_secs(timeout), Duration::from_secs(alarm)),
|
|
|
|
IpcMode::Active => Mode::Active,
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2016-03-10 11:32:10 +01:00
|
|
|
/// Client configuration. Includes configs for all sub-systems.
|
2016-07-25 16:09:47 +02:00
|
|
|
#[derive(Debug, PartialEq, Default)]
|
2016-03-10 11:32:10 +01:00
|
|
|
pub struct ClientConfig {
|
|
|
|
/// Block queue configuration.
|
2016-09-27 16:50:24 +02:00
|
|
|
pub queue: QueueConfig,
|
2016-03-10 11:32:10 +01:00
|
|
|
/// Blockchain configuration.
|
|
|
|
pub blockchain: BlockChainConfig,
|
2016-04-30 17:41:24 +02:00
|
|
|
/// Trace configuration.
|
|
|
|
pub tracing: TraceConfig,
|
2016-05-19 00:44:49 +02:00
|
|
|
/// VM type.
|
|
|
|
pub vm_type: VMType,
|
2016-10-03 11:13:10 +02:00
|
|
|
/// Fat DB enabled?
|
|
|
|
pub fat_db: bool,
|
2016-03-11 14:45:19 +01:00
|
|
|
/// The JournalDB ("pruning") algorithm to use.
|
|
|
|
pub pruning: journaldb::Algorithm,
|
2016-03-10 11:32:10 +01:00
|
|
|
/// The name of the client instance.
|
|
|
|
pub name: String,
|
2016-10-07 00:28:42 +02:00
|
|
|
/// RocksDB state column cache-size if not default
|
2016-06-20 12:42:04 +02:00
|
|
|
pub db_cache_size: Option<usize>,
|
2016-06-27 13:58:12 +02:00
|
|
|
/// State db compaction profile
|
|
|
|
pub db_compaction: DatabaseCompactionProfile,
|
2016-07-29 15:36:00 +02:00
|
|
|
/// Should db have WAL enabled?
|
2016-09-26 19:21:25 +02:00
|
|
|
pub db_wal: bool,
|
2016-07-05 17:50:46 +02:00
|
|
|
/// Operating mode
|
|
|
|
pub mode: Mode,
|
2017-03-13 12:10:53 +01:00
|
|
|
/// The chain spec name
|
|
|
|
pub spec_name: String,
|
2016-06-28 13:23:15 +02:00
|
|
|
/// Type of block verifier used by client.
|
|
|
|
pub verifier_type: VerifierType,
|
2016-10-07 00:28:42 +02:00
|
|
|
/// State db cache-size.
|
|
|
|
pub state_cache_size: usize,
|
2016-10-07 12:18:42 +02:00
|
|
|
/// EVM jump-tables cache size.
|
|
|
|
pub jump_table_size: usize,
|
2017-01-20 13:25:53 +01:00
|
|
|
/// Minimum state pruning history size.
|
2016-10-14 14:44:56 +02:00
|
|
|
pub history: u64,
|
2017-01-20 13:25:53 +01:00
|
|
|
/// Ideal memory usage for state pruning history.
|
|
|
|
pub history_mem: usize,
|
2016-10-24 15:09:13 +02:00
|
|
|
/// Check seal valididity on block import
|
|
|
|
pub check_seal: bool,
|
2016-03-10 11:32:10 +01:00
|
|
|
}
|
2016-07-25 16:09:47 +02:00
|
|
|
|
|
|
|
#[cfg(test)]
|
|
|
|
mod test {
|
|
|
|
use super::{DatabaseCompactionProfile, Mode};
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_default_compaction_profile() {
|
2016-10-21 23:21:57 +02:00
|
|
|
assert_eq!(DatabaseCompactionProfile::default(), DatabaseCompactionProfile::Auto);
|
2016-07-25 16:09:47 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_parsing_compaction_profile() {
|
2016-10-21 23:21:57 +02:00
|
|
|
assert_eq!(DatabaseCompactionProfile::Auto, "auto".parse().unwrap());
|
|
|
|
assert_eq!(DatabaseCompactionProfile::SSD, "ssd".parse().unwrap());
|
2016-07-25 16:09:47 +02:00
|
|
|
assert_eq!(DatabaseCompactionProfile::HDD, "hdd".parse().unwrap());
|
|
|
|
}
|
|
|
|
|
|
|
|
#[test]
|
|
|
|
fn test_mode_default() {
|
|
|
|
assert_eq!(Mode::default(), Mode::Active);
|
|
|
|
}
|
|
|
|
}
|