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