rippled
Config.h
1 //------------------------------------------------------------------------------
2 /*
3  This file is part of rippled: https://github.com/ripple/rippled
4  Copyright (c) 2012, 2013 Ripple Labs Inc.
5 
6  Permission to use, copy, modify, and/or distribute this software for any
7  purpose with or without fee is hereby granted, provided that the above
8  copyright notice and this permission notice appear in all copies.
9 
10  THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES
11  WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF
12  MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR
13  ANY SPECIAL , DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES
14  WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN
15  ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF
16  OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.
17 */
18 //==============================================================================
19 
20 #ifndef RIPPLE_CORE_CONFIG_H_INCLUDED
21 #define RIPPLE_CORE_CONFIG_H_INCLUDED
22 
23 #include <ripple/basics/BasicConfig.h>
24 #include <ripple/basics/FeeUnits.h>
25 #include <ripple/basics/base_uint.h>
26 #include <ripple/beast/net/IPEndpoint.h>
27 #include <ripple/beast/utility/Journal.h>
28 #include <ripple/protocol/SystemParameters.h> // VFALCO Breaks levelization
29 #include <boost/beast/core/string.hpp>
30 #include <boost/filesystem.hpp> // VFALCO FIX: This include should not be here
31 #include <boost/lexical_cast.hpp>
32 #include <algorithm>
33 #include <chrono>
34 #include <cstdint>
35 #include <map>
36 #include <optional>
37 #include <string>
38 #include <type_traits>
39 #include <unordered_set>
40 #include <vector>
41 
42 namespace ripple {
43 
44 class Rules;
45 
46 //------------------------------------------------------------------------------
47 
48 enum class SizedItem : std::size_t {
49  sweepInterval = 0,
52  ledgerSize,
53  ledgerAge,
56  txnDBCache,
57  lgrDBCache,
59  burstSize,
60  ramSizeGB,
62 };
63 
64 // This entire derived class is deprecated.
65 // For new config information use the style implied
66 // in the base class. For existing config information
67 // try to refactor code to use the new style.
68 //
69 class Config : public BasicConfig
70 {
71 public:
72  // Settings related to the configuration file location and directories
73  static char const* const configFileName;
74  static char const* const databaseDirName;
75  static char const* const validatorsFileName;
76 
78  boost::filesystem::path
79  getDebugLogFile() const;
80 
81 private:
82  boost::filesystem::path CONFIG_FILE;
83 
84 public:
85  boost::filesystem::path CONFIG_DIR;
86 
87 private:
88  boost::filesystem::path DEBUG_LOGFILE;
89 
90  void
91  load();
93 
94  bool QUIET = false; // Minimize logging verbosity.
95  bool SILENT = false; // No output to console after startup.
105  bool RUN_STANDALONE = false;
106 
107  bool RUN_REPORTING = false;
108 
109  bool REPORTING_READ_ONLY = false;
110 
111  bool USE_TX_TABLES = true;
112 
119  bool signingEnabled_ = false;
120 
121  // The amount of RAM, in bytes, that we detected on this system.
123 
124 public:
125  bool doImport = false;
126  bool nodeToShard = false;
127  bool ELB_SUPPORT = false;
128 
129  std::vector<std::string> IPS; // Peer IPs from rippled.cfg.
130  std::vector<std::string> IPS_FIXED; // Fixed Peer IPs from rippled.cfg.
131  std::vector<std::string> SNTP_SERVERS; // SNTP servers from rippled.cfg.
132 
135 
136  bool START_VALID = false;
137 
139 
140  // Network parameters
141 
142  // DEPRECATED - Fee units for a reference transction.
143  // Only provided for backwards compatibility in a couple of places
144  static constexpr std::uint32_t FEE_UNITS_DEPRECATED = 10;
145 
146  // Note: The following parameters do not relate to the UNL or trust at all
147  // Minimum number of nodes to consider the network present
149 
150  // Peer networking parameters
151  // 1 = relay, 0 = do not relay (but process), -1 = drop completely (do NOT
152  // process)
155 
156  // True to ask peers not to relay current IP.
157  bool PEER_PRIVATE = false;
158  // peers_max is a legacy configuration, which is going to be replaced
159  // with individual inbound peers peers_in_max and outbound peers
160  // peers_out_max configuration. for now we support both the legacy and
161  // the new configuration. if peers_max is configured then peers_in_max and
162  // peers_out_max are ignored.
166 
167  // Path searching: these were reasonable default values at some point but
168  // further research is needed to decide if they still are
169  // and whether all of them are needed.
170  //
171  // The performance and resource consumption of a server can
172  // be dramatically impacted by changing these configuration
173  // options; higher values result in exponentially higher
174  // resource usage.
175  //
176  // Servers operating as validators disable path finding by
177  // default by setting the `PATH_SEARCH_MAX` option to 0
178  // unless it is explicitly set in the configuration file.
180  int PATH_SEARCH = 2;
183 
184  // Validation
186  VALIDATION_QUORUM; // validations to consider ledger authoritative
187 
191 
192  // Node storage configuration
195 
196  // Tunable that adjusts various parameters, typically associated
197  // with hardware parameters (RAM size and CPU cores). The default
198  // is 'tiny'.
200 
201  bool SSL_VERIFY = true;
204 
205  // Compression
206  bool COMPRESSION = false;
207 
208  // Enable the experimental Ledger Replay functionality
209  bool LEDGER_REPLAY = false;
210 
211  // Work queue limits
212  int MAX_TRANSACTIONS = 250;
213  static constexpr int MAX_JOB_QUEUE_TX = 1000;
214  static constexpr int MIN_JOB_QUEUE_TX = 100;
215 
216  // Amendment majority time
218 
219  // Thread pool configuration (0 = choose for me)
220  int WORKERS = 0; // jobqueue thread count. default: upto 6
221  int IO_WORKERS = 0; // io svc thread count. default: 2
222  int PREFETCH_WORKERS = 0; // prefetch thread count. default: 4
223 
224  // Can only be set in code, specifically unit tests
225  bool FORCE_MULTI_THREAD = false;
226 
227  // Normally the sweep timer is automatically deduced based on the node
228  // size, but we allow admins to explicitly set it in the config.
230 
231  // Reduce-relay - these parameters are experimental.
232  // Enable reduce-relay features
233  // Validation/proposal reduce-relay feature
235  // Send squelch message to peers. Generally this config should
236  // have the same value as VP_REDUCE_RELAY_ENABLE. It can be
237  // used for testing the feature's function without
238  // affecting the message relaying. To use it for testing,
239  // set it to false and set VP_REDUCE_RELAY_ENABLE to true.
240  // Squelch messages will not be sent to the peers in this case.
241  // Set log level to debug so that the feature function can be
242  // analyzed.
244  // Transaction reduce-relay feature
246  // If tx reduce-relay feature is disabled
247  // and this flag is enabled then some
248  // tx-related metrics is collected. It
249  // is ignored if tx reduce-relay feature is
250  // enabled. It is used in debugging to compare
251  // metrics with the feature disabled/enabled.
253  // Minimum peers a server should have before
254  // selecting random peers
256  // Percentage of peers with the tx reduce-relay feature enabled
257  // to relay to out of total active peers
259 
260  // These override the command line client settings
262 
264 
266 
267  // How long can a peer remain in the "unknown" state
269 
270  // How long can a peer remain in the "diverged" state
272 
273  // Enable the beta API version
274  bool BETA_RPC_API = false;
275 
276  // First, attempt to load the latest ledger directly from disk.
277  bool FAST_LOAD = false;
278 
279 public:
280  Config();
281 
282  /* Be very careful to make sure these bool params
283  are in the right order. */
284  void
285  setup(
286  std::string const& strConf,
287  bool bQuiet,
288  bool bSilent,
289  bool bStandalone);
290 
291  void
292  setupControl(bool bQuiet, bool bSilent, bool bStandalone);
293 
299  void
300  loadFromString(std::string const& fileContents);
301 
302  bool
303  quiet() const
304  {
305  return QUIET;
306  }
307  bool
308  silent() const
309  {
310  return SILENT;
311  }
312  bool
313  standalone() const
314  {
315  return RUN_STANDALONE;
316  }
317  bool
318  reporting() const
319  {
320  return RUN_REPORTING;
321  }
322 
323  bool
324  useTxTables() const
325  {
326  return USE_TX_TABLES;
327  }
328 
329  bool
331  {
332  return REPORTING_READ_ONLY;
333  }
334 
335  void
337  {
339  }
340 
341  bool
342  canSign() const
343  {
344  return signingEnabled_;
345  }
346 
364  int
365  getValueFor(SizedItem item, std::optional<std::size_t> node = std::nullopt)
366  const;
367 };
368 
369 } // namespace ripple
370 
371 #endif
ripple::SizedItem::openFinalLimit
@ openFinalLimit
ripple::Config::NORMAL
@ NORMAL
Definition: Config.h:133
ripple::Config::SWEEP_INTERVAL
std::optional< int > SWEEP_INTERVAL
Definition: Config.h:229
std::string
STL class.
ripple::SizedItem
SizedItem
Definition: Config.h:48
ripple::Config::PATH_SEARCH
int PATH_SEARCH
Definition: Config.h:180
ripple::Config::VALIDATION_QUORUM
std::optional< std::size_t > VALIDATION_QUORUM
Definition: Config.h:186
unordered_set
ripple::Config::LEDGER_REPLAY
bool LEDGER_REPLAY
Definition: Config.h:209
ripple::Config::Config
Config()
Definition: Config.cpp:266
ripple::SizedItem::accountIdCacheSize
@ accountIdCacheSize
ripple::Config::validatorsFileName
static char const *const validatorsFileName
Definition: Config.h:75
vector
ripple::Config::SSL_VERIFY_DIR
std::string SSL_VERIFY_DIR
Definition: Config.h:203
ripple::Config::CONFIG_FILE
boost::filesystem::path CONFIG_FILE
Definition: Config.h:82
std::chrono::seconds
ripple::Config::NODE_SIZE
std::size_t NODE_SIZE
Definition: Config.h:199
ripple::Config::PEER_PRIVATE
bool PEER_PRIVATE
Definition: Config.h:157
ripple::Config::DEBUG_LOGFILE
boost::filesystem::path DEBUG_LOGFILE
Definition: Config.h:88
ripple::Config::silent
bool silent() const
Definition: Config.h:308
ripple::Config::setupControl
void setupControl(bool bQuiet, bool bSilent, bool bStandalone)
Definition: Config.cpp:272
ripple::SizedItem::treeCacheAge
@ treeCacheAge
ripple::Config::LOAD
@ LOAD
Definition: Config.h:133
ripple::Config::ramSize_
const std::uint64_t ramSize_
Definition: Config.h:122
ripple::Config::StartUpType
StartUpType
Definition: Config.h:133
ripple::SizedItem::hashNodeDBCache
@ hashNodeDBCache
ripple::Config::MIN_JOB_QUEUE_TX
static constexpr int MIN_JOB_QUEUE_TX
Definition: Config.h:214
ripple::SizedItem::ledgerFetch
@ ledgerFetch
ripple::Config::MAX_TRANSACTIONS
int MAX_TRANSACTIONS
Definition: Config.h:212
ripple::Config::quiet
bool quiet() const
Definition: Config.h:303
ripple::Config::FETCH_DEPTH
std::uint32_t FETCH_DEPTH
Definition: Config.h:194
algorithm
ripple::Config::PATH_SEARCH_MAX
int PATH_SEARCH_MAX
Definition: Config.h:182
ripple::Config::VP_REDUCE_RELAY_SQUELCH
bool VP_REDUCE_RELAY_SQUELCH
Definition: Config.h:243
ripple::Config::IO_WORKERS
int IO_WORKERS
Definition: Config.h:221
ripple::Config::RUN_STANDALONE
bool RUN_STANDALONE
Operate in stand-alone mode.
Definition: Config.h:105
ripple::SizedItem::ramSizeGB
@ ramSizeGB
ripple::Config::load
void load()
Definition: Config.cpp:434
ripple::Config::j_
const beast::Journal j_
Definition: Config.h:92
ripple::Config::RELAY_UNTRUSTED_PROPOSALS
int RELAY_UNTRUSTED_PROPOSALS
Definition: Config.h:154
ripple::Config::reporting
bool reporting() const
Definition: Config.h:318
ripple::Config::SSL_VERIFY_FILE
std::string SSL_VERIFY_FILE
Definition: Config.h:202
ripple::Config::loadFromString
void loadFromString(std::string const &fileContents)
Load the config from the contents of the string.
Definition: Config.cpp:456
ripple::Config::getValueFor
int getValueFor(SizedItem item, std::optional< std::size_t > node=std::nullopt) const
Retrieve the default value for the item at the specified node size.
Definition: Config.cpp:989
ripple::Config::FORCE_MULTI_THREAD
bool FORCE_MULTI_THREAD
Definition: Config.h:225
ripple::Config::FAST_LOAD
bool FAST_LOAD
Definition: Config.h:277
ripple::Config
Definition: Config.h:69
chrono
ripple::Config::NETWORK
@ NETWORK
Definition: Config.h:133
ripple::Config::SNTP_SERVERS
std::vector< std::string > SNTP_SERVERS
Definition: Config.h:131
ripple::Config::IPS_FIXED
std::vector< std::string > IPS_FIXED
Definition: Config.h:130
ripple::Config::FEE_OWNER_RESERVE
XRPAmount FEE_OWNER_RESERVE
Definition: Config.h:190
ripple::Config::standalone
bool standalone() const
Definition: Config.h:313
ripple::Config::SSL_VERIFY
bool SSL_VERIFY
Definition: Config.h:201
ripple::Config::USE_TX_TABLES
bool USE_TX_TABLES
Definition: Config.h:111
ripple::Config::useTxTables
bool useTxTables() const
Definition: Config.h:324
ripple::Config::FEE_ACCOUNT_RESERVE
XRPAmount FEE_ACCOUNT_RESERVE
Definition: Config.h:189
ripple::Config::BETA_RPC_API
bool BETA_RPC_API
Definition: Config.h:274
cstdint
ripple::Config::PEERS_OUT_MAX
std::size_t PEERS_OUT_MAX
Definition: Config.h:164
ripple::Config::START_UP
StartUpType START_UP
Definition: Config.h:134
ripple::Config::AMENDMENT_MAJORITY_TIME
std::chrono::seconds AMENDMENT_MAJORITY_TIME
Definition: Config.h:217
ripple::SizedItem::lgrDBCache
@ lgrDBCache
ripple::Config::MAX_JOB_QUEUE_TX
static constexpr int MAX_JOB_QUEUE_TX
Definition: Config.h:213
beast::Journal
A generic endpoint for log messages.
Definition: Journal.h:58
ripple::SizedItem::burstSize
@ burstSize
ripple::Config::nodeToShard
bool nodeToShard
Definition: Config.h:126
std::uint64_t
ripple::Config::WORKERS
int WORKERS
Definition: Config.h:220
ripple::Config::canSign
bool canSign() const
Definition: Config.h:342
ripple::Config::PEERS_IN_MAX
std::size_t PEERS_IN_MAX
Definition: Config.h:165
ripple::Config::databaseDirName
static char const *const databaseDirName
Definition: Config.h:74
ripple::Config::START_VALID
bool START_VALID
Definition: Config.h:136
map
ripple::SizedItem::txnDBCache
@ txnDBCache
ripple::Config::PREFETCH_WORKERS
int PREFETCH_WORKERS
Definition: Config.h:222
ripple::Config::FEE_UNITS_DEPRECATED
static constexpr std::uint32_t FEE_UNITS_DEPRECATED
Definition: Config.h:144
ripple::Config::PATH_SEARCH_OLD
int PATH_SEARCH_OLD
Definition: Config.h:179
ripple::Config::LEDGER_HISTORY
std::uint32_t LEDGER_HISTORY
Definition: Config.h:193
ripple::Config::NETWORK_QUORUM
std::size_t NETWORK_QUORUM
Definition: Config.h:148
ripple::Config::VP_REDUCE_RELAY_ENABLE
bool VP_REDUCE_RELAY_ENABLE
Definition: Config.h:234
ripple::DROPS_PER_XRP
constexpr XRPAmount DROPS_PER_XRP
Number of drops per 1 XRP.
Definition: XRPAmount.h:250
ripple::Config::CONFIG_DIR
boost::filesystem::path CONFIG_DIR
Definition: Config.h:85
ripple::Config::PEERS_MAX
std::size_t PEERS_MAX
Definition: Config.h:163
ripple::Config::setReportingReadOnly
void setReportingReadOnly(bool b)
Definition: Config.h:336
ripple::Config::FEE_DEFAULT
XRPAmount FEE_DEFAULT
Definition: Config.h:188
ripple
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
Definition: RCLCensorshipDetector.h:29
ripple::Config::FRESH
@ FRESH
Definition: Config.h:133
ripple::Config::features
std::unordered_set< uint256, beast::uhash<> > features
Definition: Config.h:263
ripple::Config::PATH_SEARCH_FAST
int PATH_SEARCH_FAST
Definition: Config.h:181
ripple::Config::setup
void setup(std::string const &strConf, bool bQuiet, bool bSilent, bool bStandalone)
Definition: Config.cpp:314
ripple::SizedItem::treeCacheSize
@ treeCacheSize
ripple::Config::TX_REDUCE_RELAY_MIN_PEERS
std::size_t TX_REDUCE_RELAY_MIN_PEERS
Definition: Config.h:255
ripple::Config::SERVER_DOMAIN
std::string SERVER_DOMAIN
Definition: Config.h:265
ripple::Config::TX_REDUCE_RELAY_METRICS
bool TX_REDUCE_RELAY_METRICS
Definition: Config.h:252
ripple::Config::REPLAY
@ REPLAY
Definition: Config.h:133
ripple::Config::RELAY_UNTRUSTED_VALIDATIONS
int RELAY_UNTRUSTED_VALIDATIONS
Definition: Config.h:153
ripple::Config::doImport
bool doImport
Definition: Config.h:125
ripple::SizedItem::sweepInterval
@ sweepInterval
ripple::Config::COMPRESSION
bool COMPRESSION
Definition: Config.h:206
ripple::defaultAmendmentMajorityTime
constexpr const std::chrono::seconds defaultAmendmentMajorityTime
The minimum amount of time an amendment must hold a majority.
Definition: SystemParameters.h:84
ripple::SizedItem::ledgerSize
@ ledgerSize
optional
ripple::Config::IPS
std::vector< std::string > IPS
Definition: Config.h:129
ripple::Config::configFileName
static char const *const configFileName
Definition: Config.h:73
std::size_t
ripple::Config::TX_RELAY_PERCENTAGE
std::size_t TX_RELAY_PERCENTAGE
Definition: Config.h:258
ripple::Config::QUIET
bool QUIET
Definition: Config.h:94
ripple::Config::TX_REDUCE_RELAY_ENABLE
bool TX_REDUCE_RELAY_ENABLE
Definition: Config.h:245
ripple::Config::reportingReadOnly
bool reportingReadOnly() const
Definition: Config.h:330
ripple::Config::SILENT
bool SILENT
Definition: Config.h:95
ripple::Config::getDebugLogFile
boost::filesystem::path getDebugLogFile() const
Returns the full path and filename of the debug log file.
Definition: Config.cpp:955
ripple::Config::signingEnabled_
bool signingEnabled_
Determines if the server will sign a tx, given an account's secret seed.
Definition: Config.h:119
ripple::Config::LOAD_FILE
@ LOAD_FILE
Definition: Config.h:133
ripple::Config::ELB_SUPPORT
bool ELB_SUPPORT
Definition: Config.h:127
type_traits
ripple::BasicConfig
Holds unparsed configuration information.
Definition: BasicConfig.h:215
ripple::Config::START_LEDGER
std::string START_LEDGER
Definition: Config.h:138
ripple::SizedItem::ledgerAge
@ ledgerAge
ripple::Config::MAX_UNKNOWN_TIME
std::chrono::seconds MAX_UNKNOWN_TIME
Definition: Config.h:268
ripple::XRPAmount
Definition: XRPAmount.h:46
ripple::Config::REPORTING_READ_ONLY
bool REPORTING_READ_ONLY
Definition: Config.h:109
ripple::Config::MAX_DIVERGED_TIME
std::chrono::seconds MAX_DIVERGED_TIME
Definition: Config.h:271
ripple::Config::RUN_REPORTING
bool RUN_REPORTING
Definition: Config.h:107
ripple::Config::rpc_ip
std::optional< beast::IP::Endpoint > rpc_ip
Definition: Config.h:261
string