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 
69 struct FeeSetup
70 {
73 
76 
79 
80  /* (Remember to update the example cfg files when changing any of these
81  * values.) */
82 };
83 
84 // This entire derived class is deprecated.
85 // For new config information use the style implied
86 // in the base class. For existing config information
87 // try to refactor code to use the new style.
88 //
89 class Config : public BasicConfig
90 {
91 public:
92  // Settings related to the configuration file location and directories
93  static char const* const configFileName;
94  static char const* const databaseDirName;
95  static char const* const validatorsFileName;
96 
98  boost::filesystem::path
99  getDebugLogFile() const;
100 
101 private:
102  boost::filesystem::path CONFIG_FILE;
103 
104 public:
105  boost::filesystem::path CONFIG_DIR;
106 
107 private:
108  boost::filesystem::path DEBUG_LOGFILE;
109 
110  void
111  load();
113 
114  bool QUIET = false; // Minimize logging verbosity.
115  bool SILENT = false; // No output to console after startup.
125  bool RUN_STANDALONE = false;
126 
127  bool RUN_REPORTING = false;
128 
129  bool REPORTING_READ_ONLY = false;
130 
131  bool USE_TX_TABLES = true;
132 
139  bool signingEnabled_ = false;
140 
141  // The amount of RAM, in bytes, that we detected on this system.
143 
144 public:
145  bool doImport = false;
146  bool nodeToShard = false;
147  bool ELB_SUPPORT = false;
148 
149  std::vector<std::string> IPS; // Peer IPs from rippled.cfg.
150  std::vector<std::string> IPS_FIXED; // Fixed Peer IPs from rippled.cfg.
151  std::vector<std::string> SNTP_SERVERS; // SNTP servers from rippled.cfg.
152 
155 
156  bool START_VALID = false;
157 
159 
160  // Network parameters
161  uint32_t NETWORK_ID = 0;
162 
163  // DEPRECATED - Fee units for a reference transction.
164  // Only provided for backwards compatibility in a couple of places
165  static constexpr std::uint32_t FEE_UNITS_DEPRECATED = 10;
166 
167  // Note: The following parameters do not relate to the UNL or trust at all
168  // Minimum number of nodes to consider the network present
170 
171  // Peer networking parameters
172  // 1 = relay, 0 = do not relay (but process), -1 = drop completely (do NOT
173  // process)
176 
177  // True to ask peers not to relay current IP.
178  bool PEER_PRIVATE = false;
179  // peers_max is a legacy configuration, which is going to be replaced
180  // with individual inbound peers peers_in_max and outbound peers
181  // peers_out_max configuration. for now we support both the legacy and
182  // the new configuration. if peers_max is configured then peers_in_max and
183  // peers_out_max are ignored.
187 
188  // Path searching: these were reasonable default values at some point but
189  // further research is needed to decide if they still are
190  // and whether all of them are needed.
191  //
192  // The performance and resource consumption of a server can
193  // be dramatically impacted by changing these configuration
194  // options; higher values result in exponentially higher
195  // resource usage.
196  //
197  // Servers operating as validators disable path finding by
198  // default by setting the `PATH_SEARCH_MAX` option to 0
199  // unless it is explicitly set in the configuration file.
201  int PATH_SEARCH = 2;
204 
205  // Validation
207  VALIDATION_QUORUM; // validations to consider ledger authoritative
208 
210 
211  // Node storage configuration
214 
215  // Tunable that adjusts various parameters, typically associated
216  // with hardware parameters (RAM size and CPU cores). The default
217  // is 'tiny'.
219 
220  bool SSL_VERIFY = true;
223 
224  // Compression
225  bool COMPRESSION = false;
226 
227  // Enable the experimental Ledger Replay functionality
228  bool LEDGER_REPLAY = false;
229 
230  // Work queue limits
231  int MAX_TRANSACTIONS = 250;
232  static constexpr int MAX_JOB_QUEUE_TX = 1000;
233  static constexpr int MIN_JOB_QUEUE_TX = 100;
234 
235  // Amendment majority time
237 
238  // Thread pool configuration (0 = choose for me)
239  int WORKERS = 0; // jobqueue thread count. default: upto 6
240  int IO_WORKERS = 0; // io svc thread count. default: 2
241  int PREFETCH_WORKERS = 0; // prefetch thread count. default: 4
242 
243  // Can only be set in code, specifically unit tests
244  bool FORCE_MULTI_THREAD = false;
245 
246  // Normally the sweep timer is automatically deduced based on the node
247  // size, but we allow admins to explicitly set it in the config.
249 
250  // Reduce-relay - these parameters are experimental.
251  // Enable reduce-relay features
252  // Validation/proposal reduce-relay feature
254  // Send squelch message to peers. Generally this config should
255  // have the same value as VP_REDUCE_RELAY_ENABLE. It can be
256  // used for testing the feature's function without
257  // affecting the message relaying. To use it for testing,
258  // set it to false and set VP_REDUCE_RELAY_ENABLE to true.
259  // Squelch messages will not be sent to the peers in this case.
260  // Set log level to debug so that the feature function can be
261  // analyzed.
263  // Transaction reduce-relay feature
265  // If tx reduce-relay feature is disabled
266  // and this flag is enabled then some
267  // tx-related metrics is collected. It
268  // is ignored if tx reduce-relay feature is
269  // enabled. It is used in debugging to compare
270  // metrics with the feature disabled/enabled.
272  // Minimum peers a server should have before
273  // selecting random peers
275  // Percentage of peers with the tx reduce-relay feature enabled
276  // to relay to out of total active peers
278 
279  // These override the command line client settings
281 
283 
285 
286  // How long can a peer remain in the "unknown" state
288 
289  // How long can a peer remain in the "diverged" state
291 
292  // Enable the beta API version
293  bool BETA_RPC_API = false;
294 
295  // First, attempt to load the latest ledger directly from disk.
296  bool FAST_LOAD = false;
297 
298 public:
299  Config();
300 
301  /* Be very careful to make sure these bool params
302  are in the right order. */
303  void
304  setup(
305  std::string const& strConf,
306  bool bQuiet,
307  bool bSilent,
308  bool bStandalone);
309 
310  void
311  setupControl(bool bQuiet, bool bSilent, bool bStandalone);
312 
318  void
319  loadFromString(std::string const& fileContents);
320 
321  bool
322  quiet() const
323  {
324  return QUIET;
325  }
326  bool
327  silent() const
328  {
329  return SILENT;
330  }
331  bool
332  standalone() const
333  {
334  return RUN_STANDALONE;
335  }
336  bool
337  reporting() const
338  {
339  return RUN_REPORTING;
340  }
341 
342  bool
343  useTxTables() const
344  {
345  return USE_TX_TABLES;
346  }
347 
348  bool
350  {
351  return REPORTING_READ_ONLY;
352  }
353 
354  void
356  {
358  }
359 
360  bool
361  canSign() const
362  {
363  return signingEnabled_;
364  }
365 
383  int
384  getValueFor(SizedItem item, std::optional<std::size_t> node = std::nullopt)
385  const;
386 };
387 
388 FeeSetup
389 setup_FeeVote(Section const& section);
390 
391 } // namespace ripple
392 
393 #endif
ripple::SizedItem::openFinalLimit
@ openFinalLimit
ripple::FeeSetup::reference_fee
XRPAmount reference_fee
The cost of a reference transaction in drops.
Definition: Config.h:72
ripple::Config::NORMAL
@ NORMAL
Definition: Config.h:153
ripple::Config::SWEEP_INTERVAL
std::optional< int > SWEEP_INTERVAL
Definition: Config.h:248
std::string
STL class.
ripple::SizedItem
SizedItem
Definition: Config.h:48
ripple::Config::PATH_SEARCH
int PATH_SEARCH
Definition: Config.h:201
ripple::Config::VALIDATION_QUORUM
std::optional< std::size_t > VALIDATION_QUORUM
Definition: Config.h:207
unordered_set
ripple::Config::LEDGER_REPLAY
bool LEDGER_REPLAY
Definition: Config.h:228
ripple::Config::Config
Config()
Definition: Config.cpp:267
ripple::SizedItem::accountIdCacheSize
@ accountIdCacheSize
ripple::Config::validatorsFileName
static char const *const validatorsFileName
Definition: Config.h:95
vector
ripple::Config::SSL_VERIFY_DIR
std::string SSL_VERIFY_DIR
Definition: Config.h:222
ripple::Config::CONFIG_FILE
boost::filesystem::path CONFIG_FILE
Definition: Config.h:102
std::chrono::seconds
ripple::Config::NODE_SIZE
std::size_t NODE_SIZE
Definition: Config.h:218
ripple::Config::PEER_PRIVATE
bool PEER_PRIVATE
Definition: Config.h:178
ripple::Config::DEBUG_LOGFILE
boost::filesystem::path DEBUG_LOGFILE
Definition: Config.h:108
ripple::Config::silent
bool silent() const
Definition: Config.h:327
ripple::Config::setupControl
void setupControl(bool bQuiet, bool bSilent, bool bStandalone)
Definition: Config.cpp:273
ripple::SizedItem::treeCacheAge
@ treeCacheAge
ripple::Config::LOAD
@ LOAD
Definition: Config.h:153
ripple::Config::ramSize_
const std::uint64_t ramSize_
Definition: Config.h:142
ripple::Config::StartUpType
StartUpType
Definition: Config.h:153
ripple::SizedItem::hashNodeDBCache
@ hashNodeDBCache
ripple::Config::MIN_JOB_QUEUE_TX
static constexpr int MIN_JOB_QUEUE_TX
Definition: Config.h:233
ripple::SizedItem::ledgerFetch
@ ledgerFetch
ripple::Config::MAX_TRANSACTIONS
int MAX_TRANSACTIONS
Definition: Config.h:231
ripple::Config::quiet
bool quiet() const
Definition: Config.h:322
ripple::Config::FETCH_DEPTH
std::uint32_t FETCH_DEPTH
Definition: Config.h:213
algorithm
ripple::Config::PATH_SEARCH_MAX
int PATH_SEARCH_MAX
Definition: Config.h:203
ripple::Config::VP_REDUCE_RELAY_SQUELCH
bool VP_REDUCE_RELAY_SQUELCH
Definition: Config.h:262
ripple::Config::IO_WORKERS
int IO_WORKERS
Definition: Config.h:240
ripple::Config::RUN_STANDALONE
bool RUN_STANDALONE
Operate in stand-alone mode.
Definition: Config.h:125
ripple::SizedItem::ramSizeGB
@ ramSizeGB
ripple::Config::load
void load()
Definition: Config.cpp:435
ripple::Config::j_
const beast::Journal j_
Definition: Config.h:112
ripple::Config::RELAY_UNTRUSTED_PROPOSALS
int RELAY_UNTRUSTED_PROPOSALS
Definition: Config.h:175
ripple::Config::reporting
bool reporting() const
Definition: Config.h:337
ripple::Config::SSL_VERIFY_FILE
std::string SSL_VERIFY_FILE
Definition: Config.h:221
ripple::Config::loadFromString
void loadFromString(std::string const &fileContents)
Load the config from the contents of the string.
Definition: Config.cpp:457
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:1022
ripple::Config::FORCE_MULTI_THREAD
bool FORCE_MULTI_THREAD
Definition: Config.h:244
ripple::Config::FAST_LOAD
bool FAST_LOAD
Definition: Config.h:296
ripple::Config
Definition: Config.h:89
chrono
ripple::Config::NETWORK
@ NETWORK
Definition: Config.h:153
ripple::Config::SNTP_SERVERS
std::vector< std::string > SNTP_SERVERS
Definition: Config.h:151
ripple::Config::IPS_FIXED
std::vector< std::string > IPS_FIXED
Definition: Config.h:150
ripple::Config::standalone
bool standalone() const
Definition: Config.h:332
ripple::Config::SSL_VERIFY
bool SSL_VERIFY
Definition: Config.h:220
ripple::Config::USE_TX_TABLES
bool USE_TX_TABLES
Definition: Config.h:131
ripple::Config::useTxTables
bool useTxTables() const
Definition: Config.h:343
ripple::Config::BETA_RPC_API
bool BETA_RPC_API
Definition: Config.h:293
cstdint
ripple::setup_FeeVote
FeeSetup setup_FeeVote(Section const &section)
Definition: Config.cpp:1031
ripple::Config::PEERS_OUT_MAX
std::size_t PEERS_OUT_MAX
Definition: Config.h:185
ripple::Config::START_UP
StartUpType START_UP
Definition: Config.h:154
ripple::Config::AMENDMENT_MAJORITY_TIME
std::chrono::seconds AMENDMENT_MAJORITY_TIME
Definition: Config.h:236
ripple::SizedItem::lgrDBCache
@ lgrDBCache
ripple::Config::MAX_JOB_QUEUE_TX
static constexpr int MAX_JOB_QUEUE_TX
Definition: Config.h:232
beast::Journal
A generic endpoint for log messages.
Definition: Journal.h:58
ripple::FeeSetup::account_reserve
XRPAmount account_reserve
The account reserve requirement in drops.
Definition: Config.h:75
ripple::SizedItem::burstSize
@ burstSize
ripple::Config::nodeToShard
bool nodeToShard
Definition: Config.h:146
std::uint64_t
ripple::Config::WORKERS
int WORKERS
Definition: Config.h:239
ripple::Config::canSign
bool canSign() const
Definition: Config.h:361
ripple::Config::PEERS_IN_MAX
std::size_t PEERS_IN_MAX
Definition: Config.h:186
ripple::Config::databaseDirName
static char const *const databaseDirName
Definition: Config.h:94
ripple::Config::START_VALID
bool START_VALID
Definition: Config.h:156
map
ripple::SizedItem::txnDBCache
@ txnDBCache
ripple::Config::PREFETCH_WORKERS
int PREFETCH_WORKERS
Definition: Config.h:241
ripple::Config::FEE_UNITS_DEPRECATED
static constexpr std::uint32_t FEE_UNITS_DEPRECATED
Definition: Config.h:165
ripple::Config::PATH_SEARCH_OLD
int PATH_SEARCH_OLD
Definition: Config.h:200
ripple::Config::LEDGER_HISTORY
std::uint32_t LEDGER_HISTORY
Definition: Config.h:212
ripple::Config::NETWORK_QUORUM
std::size_t NETWORK_QUORUM
Definition: Config.h:169
ripple::Config::VP_REDUCE_RELAY_ENABLE
bool VP_REDUCE_RELAY_ENABLE
Definition: Config.h:253
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:105
ripple::Config::PEERS_MAX
std::size_t PEERS_MAX
Definition: Config.h:184
ripple::Config::setReportingReadOnly
void setReportingReadOnly(bool b)
Definition: Config.h:355
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:153
ripple::Config::features
std::unordered_set< uint256, beast::uhash<> > features
Definition: Config.h:282
ripple::Config::PATH_SEARCH_FAST
int PATH_SEARCH_FAST
Definition: Config.h:202
ripple::Config::setup
void setup(std::string const &strConf, bool bQuiet, bool bSilent, bool bStandalone)
Definition: Config.cpp:315
ripple::Config::NETWORK_ID
uint32_t NETWORK_ID
Definition: Config.h:161
ripple::SizedItem::treeCacheSize
@ treeCacheSize
ripple::Config::TX_REDUCE_RELAY_MIN_PEERS
std::size_t TX_REDUCE_RELAY_MIN_PEERS
Definition: Config.h:274
ripple::Config::SERVER_DOMAIN
std::string SERVER_DOMAIN
Definition: Config.h:284
ripple::Config::TX_REDUCE_RELAY_METRICS
bool TX_REDUCE_RELAY_METRICS
Definition: Config.h:271
ripple::Config::REPLAY
@ REPLAY
Definition: Config.h:153
ripple::FeeSetup::owner_reserve
XRPAmount owner_reserve
The per-owned item reserve requirement in drops.
Definition: Config.h:78
ripple::Config::RELAY_UNTRUSTED_VALIDATIONS
int RELAY_UNTRUSTED_VALIDATIONS
Definition: Config.h:174
ripple::Config::doImport
bool doImport
Definition: Config.h:145
ripple::SizedItem::sweepInterval
@ sweepInterval
ripple::Config::COMPRESSION
bool COMPRESSION
Definition: Config.h:225
ripple::defaultAmendmentMajorityTime
constexpr const std::chrono::seconds defaultAmendmentMajorityTime
The minimum amount of time an amendment must hold a majority.
Definition: SystemParameters.h:88
ripple::SizedItem::ledgerSize
@ ledgerSize
optional
ripple::Config::IPS
std::vector< std::string > IPS
Definition: Config.h:149
ripple::Config::configFileName
static char const *const configFileName
Definition: Config.h:93
std::size_t
ripple::Config::TX_RELAY_PERCENTAGE
std::size_t TX_RELAY_PERCENTAGE
Definition: Config.h:277
ripple::FeeSetup
Fee schedule for startup / standalone, and to vote for.
Definition: Config.h:69
ripple::Config::QUIET
bool QUIET
Definition: Config.h:114
ripple::Config::TX_REDUCE_RELAY_ENABLE
bool TX_REDUCE_RELAY_ENABLE
Definition: Config.h:264
ripple::Config::reportingReadOnly
bool reportingReadOnly() const
Definition: Config.h:349
ripple::Config::SILENT
bool SILENT
Definition: Config.h:115
ripple::Config::getDebugLogFile
boost::filesystem::path getDebugLogFile() const
Returns the full path and filename of the debug log file.
Definition: Config.cpp:988
ripple::Config::FEES
FeeSetup FEES
Definition: Config.h:209
ripple::Config::signingEnabled_
bool signingEnabled_
Determines if the server will sign a tx, given an account's secret seed.
Definition: Config.h:139
ripple::Config::LOAD_FILE
@ LOAD_FILE
Definition: Config.h:153
ripple::Config::ELB_SUPPORT
bool ELB_SUPPORT
Definition: Config.h:147
type_traits
ripple::BasicConfig
Holds unparsed configuration information.
Definition: BasicConfig.h:215
ripple::Config::START_LEDGER
std::string START_LEDGER
Definition: Config.h:158
ripple::SizedItem::ledgerAge
@ ledgerAge
ripple::Config::MAX_UNKNOWN_TIME
std::chrono::seconds MAX_UNKNOWN_TIME
Definition: Config.h:287
ripple::XRPAmount
Definition: XRPAmount.h:46
ripple::Config::REPORTING_READ_ONLY
bool REPORTING_READ_ONLY
Definition: Config.h:129
ripple::Config::MAX_DIVERGED_TIME
std::chrono::seconds MAX_DIVERGED_TIME
Definition: Config.h:290
ripple::Config::RUN_REPORTING
bool RUN_REPORTING
Definition: Config.h:127
ripple::Config::rpc_ip
std::optional< beast::IP::Endpoint > rpc_ip
Definition: Config.h:280
string