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