1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
// This file is part of Substrate. // Copyright (C) 2018-2021 Parity Technologies (UK) Ltd. // SPDX-License-Identifier: GPL-3.0-or-later WITH Classpath-exception-2.0 // This program 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. // This program 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 this program. If not, see <https://www.gnu.org/licenses/>. use crate::arg_enums::TracingReceiver; use sc_service::config::BasePath; use std::path::PathBuf; use structopt::StructOpt; /// Shared parameters used by all `CoreParams`. #[derive(Debug, StructOpt, Clone)] pub struct SharedParams { /// Specify the chain specification. /// /// It can be one of the predefined ones (dev, local, or staging) or it can be a path to a file with /// the chainspec (such as one exported by the `build-spec` subcommand). #[structopt(long, value_name = "CHAIN_SPEC")] pub chain: Option<String>, /// Specify the development chain. #[structopt(long, conflicts_with_all = &["chain"])] pub dev: bool, /// Specify custom base path. #[structopt(long, short = "d", value_name = "PATH", parse(from_os_str))] pub base_path: Option<PathBuf>, /// Sets a custom logging filter. Syntax is <target>=<level>, e.g. -lsync=debug. /// /// Log levels (least to most verbose) are error, warn, info, debug, and trace. /// By default, all targets log `info`. The global log level can be set with -l<level>. #[structopt(short = "l", long, value_name = "LOG_PATTERN")] pub log: Vec<String>, /// Disable log color output. #[structopt(long)] pub disable_log_color: bool, /// Disable feature to dynamically update and reload the log filter. /// /// By default this feature is enabled, however it leads to a small performance decrease. /// The `system_addLogFilter` and `system_resetLogFilter` RPCs will have no effect with this /// option set. #[structopt(long = "disable-log-reloading")] pub disable_log_reloading: bool, /// Sets a custom profiling filter. Syntax is the same as for logging: <target>=<level> #[structopt(long = "tracing-targets", value_name = "TARGETS")] pub tracing_targets: Option<String>, /// Receiver to process tracing messages. #[structopt( long = "tracing-receiver", value_name = "RECEIVER", possible_values = &TracingReceiver::variants(), case_insensitive = true, default_value = "Log" )] pub tracing_receiver: TracingReceiver, } impl SharedParams { /// Specify custom base path. pub fn base_path(&self) -> Option<BasePath> { self.base_path.clone().map(Into::into) } /// Specify the development chain. pub fn is_dev(&self) -> bool { self.dev } /// Get the chain spec for the parameters provided pub fn chain_id(&self, is_dev: bool) -> String { match self.chain { Some(ref chain) => chain.clone(), None => if is_dev { "dev".into() } else { "".into() }, } } /// Get the filters for the logging pub fn log_filters(&self) -> &[String] { &self.log } /// Should the log color output be disabled? pub fn disable_log_color(&self) -> bool { self.disable_log_color } /// Is log reloading disabled pub fn is_log_filter_reloading_disabled(&self) -> bool { self.disable_log_reloading } /// Receiver to process tracing messages. pub fn tracing_receiver(&self) -> sc_service::TracingReceiver { self.tracing_receiver.clone().into() } /// Comma separated list of targets for tracing. pub fn tracing_targets(&self) -> Option<String> { self.tracing_targets.clone() } }