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
61 };
62 
63 // This entire derived class is deprecated.
64 // For new config information use the style implied
65 // in the base class. For existing config information
66 // try to refactor code to use the new style.
67 //
68 class Config : public BasicConfig
69 {
70 public:
71  // Settings related to the configuration file location and directories
72  static char const* const configFileName;
73  static char const* const databaseDirName;
74  static char const* const validatorsFileName;
75 
77  boost::filesystem::path
78  getDebugLogFile() const;
79 
80 private:
81  boost::filesystem::path CONFIG_FILE;
82 
83 public:
84  boost::filesystem::path CONFIG_DIR;
85 
86 private:
87  boost::filesystem::path DEBUG_LOGFILE;
88 
89  void
90  load();
92 
93  bool QUIET = false; // Minimize logging verbosity.
94  bool SILENT = false; // No output to console after startup.
104  bool RUN_STANDALONE = false;
105 
106  bool RUN_REPORTING = false;
107 
108  bool REPORTING_READ_ONLY = false;
109 
110  bool USE_TX_TABLES = true;
111 
118  bool signingEnabled_ = false;
119 
120  // The amount of RAM, in bytes, that we detected on this system.
122 
123 public:
124  bool doImport = false;
125  bool nodeToShard = false;
126  bool ELB_SUPPORT = false;
127 
128  std::vector<std::string> IPS; // Peer IPs from rippled.cfg.
129  std::vector<std::string> IPS_FIXED; // Fixed Peer IPs from rippled.cfg.
130  std::vector<std::string> SNTP_SERVERS; // SNTP servers from rippled.cfg.
131 
134 
135  bool START_VALID = false;
136 
138 
139  // Network parameters
140 
141  // The number of fee units a reference transaction costs
142  static constexpr FeeUnit32 TRANSACTION_FEE_BASE{10};
143 
144  // Note: The following parameters do not relate to the UNL or trust at all
145  // Minimum number of nodes to consider the network present
147 
148  // Peer networking parameters
151 
152  // True to ask peers not to relay current IP.
153  bool PEER_PRIVATE = false;
154  // peers_max is a legacy configuration, which is going to be replaced
155  // with individual inbound peers peers_in_max and outbound peers
156  // peers_out_max configuration. for now we support both the legacy and
157  // the new configuration. if peers_max is configured then peers_in_max and
158  // peers_out_max are ignored.
162 
163  // Path searching
165  int PATH_SEARCH = 7;
167  int PATH_SEARCH_MAX = 10;
168 
169  // Validation
171  VALIDATION_QUORUM; // validations to consider ledger authoritative
172 
176 
177  // Node storage configuration
180 
181  // Tunable that adjusts various parameters, typically associated
182  // with hardware parameters (RAM size and CPU cores). The default
183  // is 'tiny'.
185 
186  bool SSL_VERIFY = true;
189 
190  // Compression
191  bool COMPRESSION = false;
192 
193  // Enable the experimental Ledger Replay functionality
194  bool LEDGER_REPLAY = false;
195 
196  // Work queue limits
197  int MAX_TRANSACTIONS = 250;
198  static constexpr int MAX_JOB_QUEUE_TX = 1000;
199  static constexpr int MIN_JOB_QUEUE_TX = 100;
200 
201  // Amendment majority time
203 
204  // Thread pool configuration
206 
207  // Reduce-relay - these parameters are experimental.
208  // Enable reduce-relay features
209  // Validation/proposal reduce-relay feature
211  // Send squelch message to peers. Generally this config should
212  // have the same value as VP_REDUCE_RELAY_ENABLE. It can be
213  // used for testing the feature's function without
214  // affecting the message relaying. To use it for testing,
215  // set it to false and set VP_REDUCE_RELAY_ENABLE to true.
216  // Squelch messages will not be sent to the peers in this case.
217  // Set log level to debug so that the feature function can be
218  // analyzed.
220  // Transaction reduce-relay feature
222  // If tx reduce-relay feature is disabled
223  // and this flag is enabled then some
224  // tx-related metrics is collected. It
225  // is ignored if tx reduce-relay feature is
226  // enabled. It is used in debugging to compare
227  // metrics with the feature disabled/enabled.
229  // Minimum peers a server should have before
230  // selecting random peers
232  // Percentage of peers with the tx reduce-relay feature enabled
233  // to relay to out of total active peers
235 
236  // These override the command line client settings
238 
240 
242 
243  // How long can a peer remain in the "unknown" state
245 
246  // How long can a peer remain in the "diverged" state
248 
249  // Enable the beta API version
250  bool BETA_RPC_API = false;
251 
252 public:
253  Config();
254 
255  /* Be very careful to make sure these bool params
256  are in the right order. */
257  void
258  setup(
259  std::string const& strConf,
260  bool bQuiet,
261  bool bSilent,
262  bool bStandalone);
263 
264  void
265  setupControl(bool bQuiet, bool bSilent, bool bStandalone);
266 
272  void
273  loadFromString(std::string const& fileContents);
274 
275  bool
276  quiet() const
277  {
278  return QUIET;
279  }
280  bool
281  silent() const
282  {
283  return SILENT;
284  }
285  bool
286  standalone() const
287  {
288  return RUN_STANDALONE;
289  }
290  bool
291  reporting() const
292  {
293  return RUN_REPORTING;
294  }
295 
296  bool
297  useTxTables() const
298  {
299  return USE_TX_TABLES;
300  }
301 
302  bool
304  {
305  return REPORTING_READ_ONLY;
306  }
307 
308  void
310  {
312  }
313 
314  bool
315  canSign() const
316  {
317  return signingEnabled_;
318  }
319 
337  int
338  getValueFor(SizedItem item, std::optional<std::size_t> node = std::nullopt)
339  const;
340 };
341 
342 } // namespace ripple
343 
344 #endif
ripple::SizedItem::openFinalLimit
@ openFinalLimit
ripple::Config::NORMAL
@ NORMAL
Definition: Config.h:132
std::string
STL class.
ripple::SizedItem
SizedItem
Definition: Config.h:48
ripple::Config::PATH_SEARCH
int PATH_SEARCH
Definition: Config.h:165
ripple::Config::VALIDATION_QUORUM
std::optional< std::size_t > VALIDATION_QUORUM
Definition: Config.h:171
unordered_set
ripple::Config::LEDGER_REPLAY
bool LEDGER_REPLAY
Definition: Config.h:194
ripple::Config::Config
Config()
Definition: Config.cpp:267
ripple::Config::validatorsFileName
static char const *const validatorsFileName
Definition: Config.h:74
vector
ripple::Config::SSL_VERIFY_DIR
std::string SSL_VERIFY_DIR
Definition: Config.h:188
ripple::Config::CONFIG_FILE
boost::filesystem::path CONFIG_FILE
Definition: Config.h:81
std::chrono::seconds
ripple::Config::NODE_SIZE
std::size_t NODE_SIZE
Definition: Config.h:184
ripple::Config::PEER_PRIVATE
bool PEER_PRIVATE
Definition: Config.h:153
ripple::Config::DEBUG_LOGFILE
boost::filesystem::path DEBUG_LOGFILE
Definition: Config.h:87
ripple::Config::silent
bool silent() const
Definition: Config.h:281
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:132
ripple::Config::ramSize_
const std::uint64_t ramSize_
Definition: Config.h:121
ripple::Config::StartUpType
StartUpType
Definition: Config.h:132
ripple::SizedItem::hashNodeDBCache
@ hashNodeDBCache
ripple::Config::MIN_JOB_QUEUE_TX
static constexpr int MIN_JOB_QUEUE_TX
Definition: Config.h:199
ripple::SizedItem::ledgerFetch
@ ledgerFetch
ripple::Config::MAX_TRANSACTIONS
int MAX_TRANSACTIONS
Definition: Config.h:197
ripple::Config::quiet
bool quiet() const
Definition: Config.h:276
ripple::Config::FETCH_DEPTH
std::uint32_t FETCH_DEPTH
Definition: Config.h:179
algorithm
ripple::Config::PATH_SEARCH_MAX
int PATH_SEARCH_MAX
Definition: Config.h:167
ripple::Config::VP_REDUCE_RELAY_SQUELCH
bool VP_REDUCE_RELAY_SQUELCH
Definition: Config.h:219
ripple::Config::RUN_STANDALONE
bool RUN_STANDALONE
Operate in stand-alone mode.
Definition: Config.h:104
ripple::SizedItem::ramSizeGB
@ ramSizeGB
ripple::Config::load
void load()
Definition: Config.cpp:432
ripple::Config::j_
const beast::Journal j_
Definition: Config.h:91
ripple::Config::reporting
bool reporting() const
Definition: Config.h:291
ripple::Config::SSL_VERIFY_FILE
std::string SSL_VERIFY_FILE
Definition: Config.h:187
ripple::Config::loadFromString
void loadFromString(std::string const &fileContents)
Load the config from the contents of the string.
Definition: Config.cpp:454
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:942
ripple::Config
Definition: Config.h:68
ripple::Config::TRANSACTION_FEE_BASE
static constexpr FeeUnit32 TRANSACTION_FEE_BASE
Definition: Config.h:142
chrono
ripple::Config::NETWORK
@ NETWORK
Definition: Config.h:132
ripple::Config::SNTP_SERVERS
std::vector< std::string > SNTP_SERVERS
Definition: Config.h:130
ripple::Config::IPS_FIXED
std::vector< std::string > IPS_FIXED
Definition: Config.h:129
ripple::Config::FEE_OWNER_RESERVE
XRPAmount FEE_OWNER_RESERVE
Definition: Config.h:175
ripple::Config::standalone
bool standalone() const
Definition: Config.h:286
ripple::Config::SSL_VERIFY
bool SSL_VERIFY
Definition: Config.h:186
ripple::Config::USE_TX_TABLES
bool USE_TX_TABLES
Definition: Config.h:110
ripple::Config::RELAY_UNTRUSTED_PROPOSALS
bool RELAY_UNTRUSTED_PROPOSALS
Definition: Config.h:150
ripple::Config::useTxTables
bool useTxTables() const
Definition: Config.h:297
ripple::Config::FEE_ACCOUNT_RESERVE
XRPAmount FEE_ACCOUNT_RESERVE
Definition: Config.h:174
ripple::Config::BETA_RPC_API
bool BETA_RPC_API
Definition: Config.h:250
cstdint
ripple::Config::PEERS_OUT_MAX
std::size_t PEERS_OUT_MAX
Definition: Config.h:160
ripple::Config::START_UP
StartUpType START_UP
Definition: Config.h:133
ripple::Config::AMENDMENT_MAJORITY_TIME
std::chrono::seconds AMENDMENT_MAJORITY_TIME
Definition: Config.h:202
ripple::SizedItem::lgrDBCache
@ lgrDBCache
ripple::Config::MAX_JOB_QUEUE_TX
static constexpr int MAX_JOB_QUEUE_TX
Definition: Config.h:198
beast::Journal
A generic endpoint for log messages.
Definition: Journal.h:58
ripple::SizedItem::burstSize
@ burstSize
ripple::Config::nodeToShard
bool nodeToShard
Definition: Config.h:125
std::uint64_t
ripple::Config::canSign
bool canSign() const
Definition: Config.h:315
ripple::Config::PEERS_IN_MAX
std::size_t PEERS_IN_MAX
Definition: Config.h:161
ripple::Config::databaseDirName
static char const *const databaseDirName
Definition: Config.h:73
ripple::feeunit::TaggedFee
Definition: FeeUnits.h:70
ripple::Config::START_VALID
bool START_VALID
Definition: Config.h:135
map
ripple::SizedItem::txnDBCache
@ txnDBCache
ripple::Config::WORKERS
std::size_t WORKERS
Definition: Config.h:205
ripple::Config::PATH_SEARCH_OLD
int PATH_SEARCH_OLD
Definition: Config.h:164
ripple::Config::LEDGER_HISTORY
std::uint32_t LEDGER_HISTORY
Definition: Config.h:178
ripple::Config::NETWORK_QUORUM
std::size_t NETWORK_QUORUM
Definition: Config.h:146
ripple::Config::VP_REDUCE_RELAY_ENABLE
bool VP_REDUCE_RELAY_ENABLE
Definition: Config.h:210
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:84
ripple::Config::PEERS_MAX
std::size_t PEERS_MAX
Definition: Config.h:159
ripple::Config::setReportingReadOnly
void setReportingReadOnly(bool b)
Definition: Config.h:309
ripple::Config::FEE_DEFAULT
XRPAmount FEE_DEFAULT
Definition: Config.h:173
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:132
ripple::Config::features
std::unordered_set< uint256, beast::uhash<> > features
Definition: Config.h:239
ripple::Config::PATH_SEARCH_FAST
int PATH_SEARCH_FAST
Definition: Config.h:166
ripple::Config::setup
void setup(std::string const &strConf, bool bQuiet, bool bSilent, bool bStandalone)
Definition: Config.cpp:315
ripple::SizedItem::treeCacheSize
@ treeCacheSize
ripple::Config::TX_REDUCE_RELAY_MIN_PEERS
std::size_t TX_REDUCE_RELAY_MIN_PEERS
Definition: Config.h:231
ripple::Config::SERVER_DOMAIN
std::string SERVER_DOMAIN
Definition: Config.h:241
ripple::Config::TX_REDUCE_RELAY_METRICS
bool TX_REDUCE_RELAY_METRICS
Definition: Config.h:228
ripple::Config::REPLAY
@ REPLAY
Definition: Config.h:132
ripple::Config::doImport
bool doImport
Definition: Config.h:124
ripple::SizedItem::sweepInterval
@ sweepInterval
ripple::Config::COMPRESSION
bool COMPRESSION
Definition: Config.h:191
ripple::defaultAmendmentMajorityTime
constexpr const std::chrono::seconds defaultAmendmentMajorityTime
The minimum amount of time an amendment must hold a majority.
Definition: SystemParameters.h:76
ripple::Config::RELAY_UNTRUSTED_VALIDATIONS
bool RELAY_UNTRUSTED_VALIDATIONS
Definition: Config.h:149
ripple::SizedItem::ledgerSize
@ ledgerSize
optional
ripple::Config::IPS
std::vector< std::string > IPS
Definition: Config.h:128
ripple::Config::configFileName
static char const *const configFileName
Definition: Config.h:72
std::size_t
ripple::Config::TX_RELAY_PERCENTAGE
std::size_t TX_RELAY_PERCENTAGE
Definition: Config.h:234
ripple::Config::QUIET
bool QUIET
Definition: Config.h:93
ripple::Config::TX_REDUCE_RELAY_ENABLE
bool TX_REDUCE_RELAY_ENABLE
Definition: Config.h:221
ripple::Config::reportingReadOnly
bool reportingReadOnly() const
Definition: Config.h:303
ripple::Config::SILENT
bool SILENT
Definition: Config.h:94
ripple::Config::getDebugLogFile
boost::filesystem::path getDebugLogFile() const
Returns the full path and filename of the debug log file.
Definition: Config.cpp:908
ripple::Config::signingEnabled_
bool signingEnabled_
Determines if the server will sign a tx, given an account's secret seed.
Definition: Config.h:118
ripple::Config::LOAD_FILE
@ LOAD_FILE
Definition: Config.h:132
ripple::Config::ELB_SUPPORT
bool ELB_SUPPORT
Definition: Config.h:126
type_traits
ripple::BasicConfig
Holds unparsed configuration information.
Definition: BasicConfig.h:215
ripple::Config::START_LEDGER
std::string START_LEDGER
Definition: Config.h:137
ripple::SizedItem::ledgerAge
@ ledgerAge
ripple::Config::MAX_UNKNOWN_TIME
std::chrono::seconds MAX_UNKNOWN_TIME
Definition: Config.h:244
ripple::XRPAmount
Definition: XRPAmount.h:46
ripple::Config::REPORTING_READ_ONLY
bool REPORTING_READ_ONLY
Definition: Config.h:108
ripple::Config::MAX_DIVERGED_TIME
std::chrono::seconds MAX_DIVERGED_TIME
Definition: Config.h:247
ripple::Config::RUN_REPORTING
bool RUN_REPORTING
Definition: Config.h:106
ripple::Config::rpc_ip
std::optional< beast::IP::Endpoint > rpc_ip
Definition: Config.h:237
string