mirror of
https://github.com/XRPLF/rippled.git
synced 2025-11-24 13:05:53 +00:00
Format first-party source according to .clang-format
This commit is contained in:
committed by
manojsdoshi
parent
65dfc5d19e
commit
50760c6935
@@ -17,18 +17,18 @@
|
||||
*/
|
||||
//==============================================================================
|
||||
|
||||
#include <ripple/core/Config.h>
|
||||
#include <ripple/core/ConfigSections.h>
|
||||
#include <ripple/basics/contract.h>
|
||||
#include <ripple/basics/FileUtilities.h>
|
||||
#include <ripple/basics/Log.h>
|
||||
#include <ripple/basics/contract.h>
|
||||
#include <ripple/beast/core/LexicalCast.h>
|
||||
#include <ripple/core/Config.h>
|
||||
#include <ripple/core/ConfigSections.h>
|
||||
#include <ripple/json/json_reader.h>
|
||||
#include <ripple/net/HTTPClient.h>
|
||||
#include <ripple/protocol/Feature.h>
|
||||
#include <ripple/protocol/SystemParameters.h>
|
||||
#include <ripple/net/HTTPClient.h>
|
||||
#include <ripple/beast/core/LexicalCast.h>
|
||||
#include <boost/beast/core/string.hpp>
|
||||
#include <boost/algorithm/string.hpp>
|
||||
#include <boost/beast/core/string.hpp>
|
||||
#include <boost/format.hpp>
|
||||
#include <boost/regex.hpp>
|
||||
#include <boost/system/error_code.hpp>
|
||||
@@ -39,103 +39,91 @@
|
||||
|
||||
namespace ripple {
|
||||
|
||||
inline constexpr
|
||||
std::array<std::pair<SizedItem, std::array<int, 5>>, 11>
|
||||
sizedItems
|
||||
{{
|
||||
// FIXME: We should document each of these items, explaining exactly what
|
||||
// they control and whether there exists an explicit config option
|
||||
// that can be used to override the default.
|
||||
{ SizedItem::sweepInterval,
|
||||
{{ 10, 30, 60, 90, 120 }} },
|
||||
{ SizedItem::treeCacheSize,
|
||||
{{ 128000, 256000, 512000, 768000, 2048000 }} },
|
||||
{ SizedItem::treeCacheAge,
|
||||
{{ 30, 60, 90, 120, 900 }} },
|
||||
{ SizedItem::ledgerSize,
|
||||
{{ 32, 128, 256, 384, 768 }} },
|
||||
{ SizedItem::ledgerAge,
|
||||
{{ 30, 90, 180, 240, 900 }} },
|
||||
{ SizedItem::ledgerFetch,
|
||||
{{ 2, 3, 4, 5, 8 }} },
|
||||
{ SizedItem::nodeCacheSize,
|
||||
{{ 16384, 32768, 131072, 262144, 524288 }} },
|
||||
{ SizedItem::nodeCacheAge,
|
||||
{{ 60, 90, 120, 900, 1800 }} },
|
||||
{ SizedItem::hashNodeDBCache,
|
||||
{{ 4, 12, 24, 64, 128 }} },
|
||||
{ SizedItem::txnDBCache,
|
||||
{{ 4, 12, 24, 64, 128 }} },
|
||||
{ SizedItem::lgrDBCache,
|
||||
{{ 4, 8, 16, 32, 128 }} },
|
||||
}};
|
||||
inline constexpr std::array<std::pair<SizedItem, std::array<int, 5>>, 11>
|
||||
sizedItems{{
|
||||
// FIXME: We should document each of these items, explaining exactly
|
||||
// what
|
||||
// they control and whether there exists an explicit config
|
||||
// option that can be used to override the default.
|
||||
{SizedItem::sweepInterval, {{10, 30, 60, 90, 120}}},
|
||||
{SizedItem::treeCacheSize, {{128000, 256000, 512000, 768000, 2048000}}},
|
||||
{SizedItem::treeCacheAge, {{30, 60, 90, 120, 900}}},
|
||||
{SizedItem::ledgerSize, {{32, 128, 256, 384, 768}}},
|
||||
{SizedItem::ledgerAge, {{30, 90, 180, 240, 900}}},
|
||||
{SizedItem::ledgerFetch, {{2, 3, 4, 5, 8}}},
|
||||
{SizedItem::nodeCacheSize, {{16384, 32768, 131072, 262144, 524288}}},
|
||||
{SizedItem::nodeCacheAge, {{60, 90, 120, 900, 1800}}},
|
||||
{SizedItem::hashNodeDBCache, {{4, 12, 24, 64, 128}}},
|
||||
{SizedItem::txnDBCache, {{4, 12, 24, 64, 128}}},
|
||||
{SizedItem::lgrDBCache, {{4, 8, 16, 32, 128}}},
|
||||
}};
|
||||
|
||||
// Ensure that the order of entries in the table corresponds to the
|
||||
// order of entries in the enum:
|
||||
static_assert([]() constexpr -> bool
|
||||
{
|
||||
std::underlying_type_t<SizedItem> idx = 0;
|
||||
static_assert(
|
||||
[]() constexpr->bool {
|
||||
std::underlying_type_t<SizedItem> idx = 0;
|
||||
|
||||
for (auto const& i : sizedItems)
|
||||
{
|
||||
if (static_cast<std::underlying_type_t<SizedItem>>(i.first) != idx)
|
||||
return false;
|
||||
for (auto const& i : sizedItems)
|
||||
{
|
||||
if (static_cast<std::underlying_type_t<SizedItem>>(i.first) != idx)
|
||||
return false;
|
||||
|
||||
++idx;
|
||||
}
|
||||
++idx;
|
||||
}
|
||||
|
||||
return true;
|
||||
}(), "Mismatch between sized item enum & array indices");
|
||||
return true;
|
||||
}(),
|
||||
"Mismatch between sized item enum & array indices");
|
||||
|
||||
//
|
||||
// TODO: Check permissions on config file before using it.
|
||||
//
|
||||
|
||||
#define SECTION_DEFAULT_NAME ""
|
||||
#define SECTION_DEFAULT_NAME ""
|
||||
|
||||
IniFileSections
|
||||
parseIniFile (std::string const& strInput, const bool bTrim)
|
||||
parseIniFile(std::string const& strInput, const bool bTrim)
|
||||
{
|
||||
std::string strData (strInput);
|
||||
std::string strData(strInput);
|
||||
std::vector<std::string> vLines;
|
||||
IniFileSections secResult;
|
||||
|
||||
// Convert DOS format to unix.
|
||||
boost::algorithm::replace_all (strData, "\r\n", "\n");
|
||||
boost::algorithm::replace_all(strData, "\r\n", "\n");
|
||||
|
||||
// Convert MacOS format to unix.
|
||||
boost::algorithm::replace_all (strData, "\r", "\n");
|
||||
boost::algorithm::replace_all(strData, "\r", "\n");
|
||||
|
||||
boost::algorithm::split (vLines, strData,
|
||||
boost::algorithm::is_any_of ("\n"));
|
||||
boost::algorithm::split(vLines, strData, boost::algorithm::is_any_of("\n"));
|
||||
|
||||
// Set the default Section name.
|
||||
std::string strSection = SECTION_DEFAULT_NAME;
|
||||
std::string strSection = SECTION_DEFAULT_NAME;
|
||||
|
||||
// Initialize the default Section.
|
||||
secResult[strSection] = IniFileSections::mapped_type ();
|
||||
secResult[strSection] = IniFileSections::mapped_type();
|
||||
|
||||
// Parse each line.
|
||||
for (auto& strValue : vLines)
|
||||
{
|
||||
if (bTrim)
|
||||
boost::algorithm::trim (strValue);
|
||||
boost::algorithm::trim(strValue);
|
||||
|
||||
if (strValue.empty () || strValue[0] == '#')
|
||||
if (strValue.empty() || strValue[0] == '#')
|
||||
{
|
||||
// Blank line or comment, do nothing.
|
||||
}
|
||||
else if (strValue[0] == '[' && strValue[strValue.length () - 1] == ']')
|
||||
else if (strValue[0] == '[' && strValue[strValue.length() - 1] == ']')
|
||||
{
|
||||
// New Section.
|
||||
strSection = strValue.substr (1, strValue.length () - 2);
|
||||
strSection = strValue.substr(1, strValue.length() - 2);
|
||||
secResult.emplace(strSection, IniFileSections::mapped_type{});
|
||||
}
|
||||
else
|
||||
{
|
||||
// Another line for Section.
|
||||
if (!strValue.empty ())
|
||||
secResult[strSection].push_back (strValue);
|
||||
if (!strValue.empty())
|
||||
secResult[strSection].push_back(strValue);
|
||||
}
|
||||
}
|
||||
|
||||
@@ -143,34 +131,38 @@ parseIniFile (std::string const& strInput, const bool bTrim)
|
||||
}
|
||||
|
||||
IniFileSections::mapped_type*
|
||||
getIniFileSection (IniFileSections& secSource, std::string const& strSection)
|
||||
getIniFileSection(IniFileSections& secSource, std::string const& strSection)
|
||||
{
|
||||
IniFileSections::iterator it;
|
||||
IniFileSections::mapped_type* smtResult;
|
||||
it = secSource.find (strSection);
|
||||
if (it == secSource.end ())
|
||||
smtResult = nullptr;
|
||||
it = secSource.find(strSection);
|
||||
if (it == secSource.end())
|
||||
smtResult = nullptr;
|
||||
else
|
||||
smtResult = & (it->second);
|
||||
smtResult = &(it->second);
|
||||
return smtResult;
|
||||
}
|
||||
|
||||
bool getSingleSection (IniFileSections& secSource,
|
||||
std::string const& strSection, std::string& strValue, beast::Journal j)
|
||||
bool
|
||||
getSingleSection(
|
||||
IniFileSections& secSource,
|
||||
std::string const& strSection,
|
||||
std::string& strValue,
|
||||
beast::Journal j)
|
||||
{
|
||||
IniFileSections::mapped_type* pmtEntries =
|
||||
getIniFileSection (secSource, strSection);
|
||||
bool bSingle = pmtEntries && 1 == pmtEntries->size ();
|
||||
getIniFileSection(secSource, strSection);
|
||||
bool bSingle = pmtEntries && 1 == pmtEntries->size();
|
||||
|
||||
if (bSingle)
|
||||
{
|
||||
strValue = (*pmtEntries)[0];
|
||||
strValue = (*pmtEntries)[0];
|
||||
}
|
||||
else if (pmtEntries)
|
||||
{
|
||||
JLOG (j.warn()) << boost::str (
|
||||
boost::format ("Section [%s]: requires 1 line not %d lines.") %
|
||||
strSection % pmtEntries->size ());
|
||||
JLOG(j.warn()) << boost::str(
|
||||
boost::format("Section [%s]: requires 1 line not %d lines.") %
|
||||
strSection % pmtEntries->size());
|
||||
}
|
||||
|
||||
return bSingle;
|
||||
@@ -186,13 +178,12 @@ char const* const Config::configFileName = "rippled.cfg";
|
||||
char const* const Config::databaseDirName = "db";
|
||||
char const* const Config::validatorsFileName = "validators.txt";
|
||||
|
||||
static
|
||||
std::string
|
||||
getEnvVar (char const* name)
|
||||
static std::string
|
||||
getEnvVar(char const* name)
|
||||
{
|
||||
std::string value;
|
||||
|
||||
auto const v = getenv (name);
|
||||
auto const v = getenv(name);
|
||||
|
||||
if (v != nullptr)
|
||||
value = v;
|
||||
@@ -202,16 +193,20 @@ getEnvVar (char const* name)
|
||||
|
||||
constexpr FeeUnit32 Config::TRANSACTION_FEE_BASE;
|
||||
|
||||
void Config::setupControl(bool bQuiet,
|
||||
bool bSilent, bool bStandalone)
|
||||
void
|
||||
Config::setupControl(bool bQuiet, bool bSilent, bool bStandalone)
|
||||
{
|
||||
QUIET = bQuiet || bSilent;
|
||||
SILENT = bSilent;
|
||||
RUN_STANDALONE = bStandalone;
|
||||
}
|
||||
|
||||
void Config::setup (std::string const& strConf, bool bQuiet,
|
||||
bool bSilent, bool bStandalone)
|
||||
void
|
||||
Config::setup(
|
||||
std::string const& strConf,
|
||||
bool bQuiet,
|
||||
bool bSilent,
|
||||
bool bStandalone)
|
||||
{
|
||||
boost::filesystem::path dataDir;
|
||||
std::string strDbPath, strConfFile;
|
||||
@@ -231,53 +226,54 @@ void Config::setup (std::string const& strConf, bool bQuiet,
|
||||
else
|
||||
strConfFile = configFileName;
|
||||
|
||||
if (!strConf.empty ())
|
||||
if (!strConf.empty())
|
||||
{
|
||||
// --conf=<path> : everything is relative that file.
|
||||
CONFIG_FILE = strConfFile;
|
||||
CONFIG_DIR = boost::filesystem::absolute (CONFIG_FILE);
|
||||
CONFIG_DIR.remove_filename ();
|
||||
dataDir = CONFIG_DIR / strDbPath;
|
||||
CONFIG_FILE = strConfFile;
|
||||
CONFIG_DIR = boost::filesystem::absolute(CONFIG_FILE);
|
||||
CONFIG_DIR.remove_filename();
|
||||
dataDir = CONFIG_DIR / strDbPath;
|
||||
}
|
||||
else
|
||||
{
|
||||
CONFIG_DIR = boost::filesystem::current_path ();
|
||||
CONFIG_FILE = CONFIG_DIR / strConfFile;
|
||||
dataDir = CONFIG_DIR / strDbPath;
|
||||
CONFIG_DIR = boost::filesystem::current_path();
|
||||
CONFIG_FILE = CONFIG_DIR / strConfFile;
|
||||
dataDir = CONFIG_DIR / strDbPath;
|
||||
|
||||
// Construct XDG config and data home.
|
||||
// http://standards.freedesktop.org/basedir-spec/basedir-spec-latest.html
|
||||
std::string strHome = getEnvVar ("HOME");
|
||||
std::string strXdgConfigHome = getEnvVar ("XDG_CONFIG_HOME");
|
||||
std::string strXdgDataHome = getEnvVar ("XDG_DATA_HOME");
|
||||
std::string strHome = getEnvVar("HOME");
|
||||
std::string strXdgConfigHome = getEnvVar("XDG_CONFIG_HOME");
|
||||
std::string strXdgDataHome = getEnvVar("XDG_DATA_HOME");
|
||||
|
||||
if (boost::filesystem::exists (CONFIG_FILE)
|
||||
// Can we figure out XDG dirs?
|
||||
|| (strHome.empty () && (strXdgConfigHome.empty () || strXdgDataHome.empty ())))
|
||||
if (boost::filesystem::exists(CONFIG_FILE)
|
||||
// Can we figure out XDG dirs?
|
||||
|| (strHome.empty() &&
|
||||
(strXdgConfigHome.empty() || strXdgDataHome.empty())))
|
||||
{
|
||||
// Current working directory is fine, put dbs in a subdir.
|
||||
}
|
||||
else
|
||||
{
|
||||
if (strXdgConfigHome.empty ())
|
||||
if (strXdgConfigHome.empty())
|
||||
{
|
||||
// $XDG_CONFIG_HOME was not set, use default based on $HOME.
|
||||
strXdgConfigHome = strHome + "/.config";
|
||||
strXdgConfigHome = strHome + "/.config";
|
||||
}
|
||||
|
||||
if (strXdgDataHome.empty ())
|
||||
if (strXdgDataHome.empty())
|
||||
{
|
||||
// $XDG_DATA_HOME was not set, use default based on $HOME.
|
||||
strXdgDataHome = strHome + "/.local/share";
|
||||
strXdgDataHome = strHome + "/.local/share";
|
||||
}
|
||||
|
||||
CONFIG_DIR = strXdgConfigHome + "/" + systemName ();
|
||||
CONFIG_DIR = strXdgConfigHome + "/" + systemName();
|
||||
CONFIG_FILE = CONFIG_DIR / strConfFile;
|
||||
dataDir = strXdgDataHome + "/" + systemName ();
|
||||
dataDir = strXdgDataHome + "/" + systemName();
|
||||
|
||||
if (!boost::filesystem::exists (CONFIG_FILE))
|
||||
if (!boost::filesystem::exists(CONFIG_FILE))
|
||||
{
|
||||
CONFIG_DIR = "/etc/opt/" + systemName ();
|
||||
CONFIG_DIR = "/etc/opt/" + systemName();
|
||||
CONFIG_FILE = CONFIG_DIR / strConfFile;
|
||||
dataDir = "/var/opt/" + systemName();
|
||||
}
|
||||
@@ -285,12 +281,12 @@ void Config::setup (std::string const& strConf, bool bQuiet,
|
||||
}
|
||||
|
||||
// Update default values
|
||||
load ();
|
||||
load();
|
||||
{
|
||||
// load() may have set a new value for the dataDir
|
||||
std::string const dbPath (legacy ("database_path"));
|
||||
if (!dbPath.empty ())
|
||||
dataDir = boost::filesystem::path (dbPath);
|
||||
std::string const dbPath(legacy("database_path"));
|
||||
if (!dbPath.empty())
|
||||
dataDir = boost::filesystem::path(dbPath);
|
||||
else if (RUN_STANDALONE)
|
||||
dataDir.clear();
|
||||
}
|
||||
@@ -313,7 +309,8 @@ void Config::setup (std::string const& strConf, bool bQuiet,
|
||||
LEDGER_HISTORY = 0;
|
||||
}
|
||||
|
||||
void Config::load ()
|
||||
void
|
||||
Config::load()
|
||||
{
|
||||
// NOTE: this writes to cerr because we want cout to be reserved
|
||||
// for the writing of the json response (so that stdout can be part of a
|
||||
@@ -326,48 +323,48 @@ void Config::load ()
|
||||
|
||||
if (ec)
|
||||
{
|
||||
std::cerr << "Failed to read '" << CONFIG_FILE << "'." <<
|
||||
ec.value() << ": " << ec.message() << std::endl;
|
||||
std::cerr << "Failed to read '" << CONFIG_FILE << "'." << ec.value()
|
||||
<< ": " << ec.message() << std::endl;
|
||||
return;
|
||||
}
|
||||
|
||||
loadFromString (fileContents);
|
||||
loadFromString(fileContents);
|
||||
}
|
||||
|
||||
void Config::loadFromString (std::string const& fileContents)
|
||||
void
|
||||
Config::loadFromString(std::string const& fileContents)
|
||||
{
|
||||
IniFileSections secConfig = parseIniFile (fileContents, true);
|
||||
IniFileSections secConfig = parseIniFile(fileContents, true);
|
||||
|
||||
build (secConfig);
|
||||
build(secConfig);
|
||||
|
||||
if (auto s = getIniFileSection (secConfig, SECTION_IPS))
|
||||
if (auto s = getIniFileSection(secConfig, SECTION_IPS))
|
||||
IPS = *s;
|
||||
|
||||
if (auto s = getIniFileSection (secConfig, SECTION_IPS_FIXED))
|
||||
if (auto s = getIniFileSection(secConfig, SECTION_IPS_FIXED))
|
||||
IPS_FIXED = *s;
|
||||
|
||||
if (auto s = getIniFileSection (secConfig, SECTION_SNTP))
|
||||
if (auto s = getIniFileSection(secConfig, SECTION_SNTP))
|
||||
SNTP_SERVERS = *s;
|
||||
|
||||
{
|
||||
std::string dbPath;
|
||||
if (getSingleSection (secConfig, "database_path", dbPath, j_))
|
||||
if (getSingleSection(secConfig, "database_path", dbPath, j_))
|
||||
{
|
||||
boost::filesystem::path p(dbPath);
|
||||
legacy("database_path",
|
||||
boost::filesystem::absolute (p).string ());
|
||||
legacy("database_path", boost::filesystem::absolute(p).string());
|
||||
}
|
||||
}
|
||||
|
||||
std::string strTemp;
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_PEER_PRIVATE, strTemp, j_))
|
||||
PEER_PRIVATE = beast::lexicalCastThrow <bool> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PEER_PRIVATE, strTemp, j_))
|
||||
PEER_PRIVATE = beast::lexicalCastThrow<bool>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_PEERS_MAX, strTemp, j_))
|
||||
PEERS_MAX = beast::lexicalCastThrow <std::size_t> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PEERS_MAX, strTemp, j_))
|
||||
PEERS_MAX = beast::lexicalCastThrow<std::size_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_NODE_SIZE, strTemp, j_))
|
||||
if (getSingleSection(secConfig, SECTION_NODE_SIZE, strTemp, j_))
|
||||
{
|
||||
if (boost::iequals(strTemp, "tiny"))
|
||||
NODE_SIZE = 0;
|
||||
@@ -380,85 +377,87 @@ void Config::loadFromString (std::string const& fileContents)
|
||||
else if (boost::iequals(strTemp, "huge"))
|
||||
NODE_SIZE = 4;
|
||||
else
|
||||
NODE_SIZE = std::min<std::size_t>(4,
|
||||
beast::lexicalCastThrow<std::size_t>(strTemp));
|
||||
NODE_SIZE = std::min<std::size_t>(
|
||||
4, beast::lexicalCastThrow<std::size_t>(strTemp));
|
||||
}
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_SIGNING_SUPPORT, strTemp, j_))
|
||||
signingEnabled_ = beast::lexicalCastThrow <bool> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_SIGNING_SUPPORT, strTemp, j_))
|
||||
signingEnabled_ = beast::lexicalCastThrow<bool>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_ELB_SUPPORT, strTemp, j_))
|
||||
ELB_SUPPORT = beast::lexicalCastThrow <bool> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_ELB_SUPPORT, strTemp, j_))
|
||||
ELB_SUPPORT = beast::lexicalCastThrow<bool>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_WEBSOCKET_PING_FREQ, strTemp, j_))
|
||||
WEBSOCKET_PING_FREQ = std::chrono::seconds{beast::lexicalCastThrow <int>(strTemp)};
|
||||
if (getSingleSection(secConfig, SECTION_WEBSOCKET_PING_FREQ, strTemp, j_))
|
||||
WEBSOCKET_PING_FREQ =
|
||||
std::chrono::seconds{beast::lexicalCastThrow<int>(strTemp)};
|
||||
|
||||
getSingleSection (secConfig, SECTION_SSL_VERIFY_FILE, SSL_VERIFY_FILE, j_);
|
||||
getSingleSection (secConfig, SECTION_SSL_VERIFY_DIR, SSL_VERIFY_DIR, j_);
|
||||
getSingleSection(secConfig, SECTION_SSL_VERIFY_FILE, SSL_VERIFY_FILE, j_);
|
||||
getSingleSection(secConfig, SECTION_SSL_VERIFY_DIR, SSL_VERIFY_DIR, j_);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_SSL_VERIFY, strTemp, j_))
|
||||
SSL_VERIFY = beast::lexicalCastThrow <bool> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_SSL_VERIFY, strTemp, j_))
|
||||
SSL_VERIFY = beast::lexicalCastThrow<bool>(strTemp);
|
||||
|
||||
if (exists(SECTION_VALIDATION_SEED) && exists(SECTION_VALIDATOR_TOKEN))
|
||||
Throw<std::runtime_error> (
|
||||
"Cannot have both [" SECTION_VALIDATION_SEED "] "
|
||||
"and [" SECTION_VALIDATOR_TOKEN "] config sections");
|
||||
Throw<std::runtime_error>("Cannot have both [" SECTION_VALIDATION_SEED
|
||||
"] "
|
||||
"and [" SECTION_VALIDATOR_TOKEN
|
||||
"] config sections");
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_NETWORK_QUORUM, strTemp, j_))
|
||||
NETWORK_QUORUM = beast::lexicalCastThrow<std::size_t>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_NETWORK_QUORUM, strTemp, j_))
|
||||
NETWORK_QUORUM = beast::lexicalCastThrow<std::size_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_FEE_ACCOUNT_RESERVE, strTemp, j_))
|
||||
FEE_ACCOUNT_RESERVE = beast::lexicalCastThrow <std::uint64_t>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_FEE_ACCOUNT_RESERVE, strTemp, j_))
|
||||
FEE_ACCOUNT_RESERVE = beast::lexicalCastThrow<std::uint64_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_FEE_OWNER_RESERVE, strTemp, j_))
|
||||
FEE_OWNER_RESERVE = beast::lexicalCastThrow <std::uint64_t>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_FEE_OWNER_RESERVE, strTemp, j_))
|
||||
FEE_OWNER_RESERVE = beast::lexicalCastThrow<std::uint64_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_FEE_DEFAULT, strTemp, j_))
|
||||
FEE_DEFAULT = beast::lexicalCastThrow <std::uint64_t>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_FEE_DEFAULT, strTemp, j_))
|
||||
FEE_DEFAULT = beast::lexicalCastThrow<std::uint64_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_LEDGER_HISTORY, strTemp, j_))
|
||||
if (getSingleSection(secConfig, SECTION_LEDGER_HISTORY, strTemp, j_))
|
||||
{
|
||||
if (boost::iequals(strTemp, "full"))
|
||||
LEDGER_HISTORY = 1000000000u;
|
||||
else if (boost::iequals(strTemp, "none"))
|
||||
LEDGER_HISTORY = 0;
|
||||
else
|
||||
LEDGER_HISTORY = beast::lexicalCastThrow <std::uint32_t> (strTemp);
|
||||
LEDGER_HISTORY = beast::lexicalCastThrow<std::uint32_t>(strTemp);
|
||||
}
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_FETCH_DEPTH, strTemp, j_))
|
||||
if (getSingleSection(secConfig, SECTION_FETCH_DEPTH, strTemp, j_))
|
||||
{
|
||||
if (boost::iequals(strTemp, "none"))
|
||||
FETCH_DEPTH = 0;
|
||||
else if (boost::iequals(strTemp, "full"))
|
||||
FETCH_DEPTH = 1000000000u;
|
||||
else
|
||||
FETCH_DEPTH = beast::lexicalCastThrow <std::uint32_t> (strTemp);
|
||||
FETCH_DEPTH = beast::lexicalCastThrow<std::uint32_t>(strTemp);
|
||||
|
||||
if (FETCH_DEPTH < 10)
|
||||
FETCH_DEPTH = 10;
|
||||
}
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_PATH_SEARCH_OLD, strTemp, j_))
|
||||
PATH_SEARCH_OLD = beast::lexicalCastThrow <int> (strTemp);
|
||||
if (getSingleSection (secConfig, SECTION_PATH_SEARCH, strTemp, j_))
|
||||
PATH_SEARCH = beast::lexicalCastThrow <int> (strTemp);
|
||||
if (getSingleSection (secConfig, SECTION_PATH_SEARCH_FAST, strTemp, j_))
|
||||
PATH_SEARCH_FAST = beast::lexicalCastThrow <int> (strTemp);
|
||||
if (getSingleSection (secConfig, SECTION_PATH_SEARCH_MAX, strTemp, j_))
|
||||
PATH_SEARCH_MAX = beast::lexicalCastThrow <int> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PATH_SEARCH_OLD, strTemp, j_))
|
||||
PATH_SEARCH_OLD = beast::lexicalCastThrow<int>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PATH_SEARCH, strTemp, j_))
|
||||
PATH_SEARCH = beast::lexicalCastThrow<int>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PATH_SEARCH_FAST, strTemp, j_))
|
||||
PATH_SEARCH_FAST = beast::lexicalCastThrow<int>(strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_PATH_SEARCH_MAX, strTemp, j_))
|
||||
PATH_SEARCH_MAX = beast::lexicalCastThrow<int>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_DEBUG_LOGFILE, strTemp, j_))
|
||||
DEBUG_LOGFILE = strTemp;
|
||||
if (getSingleSection(secConfig, SECTION_DEBUG_LOGFILE, strTemp, j_))
|
||||
DEBUG_LOGFILE = strTemp;
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_WORKERS, strTemp, j_))
|
||||
WORKERS = beast::lexicalCastThrow <std::size_t> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_WORKERS, strTemp, j_))
|
||||
WORKERS = beast::lexicalCastThrow<std::size_t>(strTemp);
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_COMPRESSION, strTemp, j_))
|
||||
COMPRESSION = beast::lexicalCastThrow <bool> (strTemp);
|
||||
if (getSingleSection(secConfig, SECTION_COMPRESSION, strTemp, j_))
|
||||
COMPRESSION = beast::lexicalCastThrow<bool>(strTemp);
|
||||
|
||||
// Do not load trusted validator configuration for standalone mode
|
||||
if (! RUN_STANDALONE)
|
||||
if (!RUN_STANDALONE)
|
||||
{
|
||||
// If a file was explicitly specified, then throw if the
|
||||
// path is malformed or if the file does not exist or is
|
||||
@@ -470,104 +469,108 @@ void Config::loadFromString (std::string const& fileContents)
|
||||
// if we can't find it.
|
||||
boost::filesystem::path validatorsFile;
|
||||
|
||||
if (getSingleSection (secConfig, SECTION_VALIDATORS_FILE, strTemp, j_))
|
||||
if (getSingleSection(secConfig, SECTION_VALIDATORS_FILE, strTemp, j_))
|
||||
{
|
||||
validatorsFile = strTemp;
|
||||
|
||||
if (validatorsFile.empty ())
|
||||
Throw<std::runtime_error> (
|
||||
if (validatorsFile.empty())
|
||||
Throw<std::runtime_error>(
|
||||
"Invalid path specified in [" SECTION_VALIDATORS_FILE "]");
|
||||
|
||||
if (!validatorsFile.is_absolute() && !CONFIG_DIR.empty())
|
||||
validatorsFile = CONFIG_DIR / validatorsFile;
|
||||
|
||||
if (!boost::filesystem::exists (validatorsFile))
|
||||
Throw<std::runtime_error> (
|
||||
"The file specified in [" SECTION_VALIDATORS_FILE "] "
|
||||
"does not exist: " + validatorsFile.string());
|
||||
if (!boost::filesystem::exists(validatorsFile))
|
||||
Throw<std::runtime_error>(
|
||||
"The file specified in [" SECTION_VALIDATORS_FILE
|
||||
"] "
|
||||
"does not exist: " +
|
||||
validatorsFile.string());
|
||||
|
||||
else if (!boost::filesystem::is_regular_file (validatorsFile) &&
|
||||
!boost::filesystem::is_symlink (validatorsFile))
|
||||
Throw<std::runtime_error> (
|
||||
"Invalid file specified in [" SECTION_VALIDATORS_FILE "]: " +
|
||||
else if (
|
||||
!boost::filesystem::is_regular_file(validatorsFile) &&
|
||||
!boost::filesystem::is_symlink(validatorsFile))
|
||||
Throw<std::runtime_error>(
|
||||
"Invalid file specified in [" SECTION_VALIDATORS_FILE
|
||||
"]: " +
|
||||
validatorsFile.string());
|
||||
}
|
||||
else if (!CONFIG_DIR.empty())
|
||||
{
|
||||
validatorsFile = CONFIG_DIR / validatorsFileName;
|
||||
|
||||
if (!validatorsFile.empty ())
|
||||
if (!validatorsFile.empty())
|
||||
{
|
||||
if(!boost::filesystem::exists (validatorsFile))
|
||||
if (!boost::filesystem::exists(validatorsFile))
|
||||
validatorsFile.clear();
|
||||
else if (!boost::filesystem::is_regular_file (validatorsFile) &&
|
||||
!boost::filesystem::is_symlink (validatorsFile))
|
||||
else if (
|
||||
!boost::filesystem::is_regular_file(validatorsFile) &&
|
||||
!boost::filesystem::is_symlink(validatorsFile))
|
||||
validatorsFile.clear();
|
||||
}
|
||||
}
|
||||
|
||||
if (!validatorsFile.empty () &&
|
||||
boost::filesystem::exists (validatorsFile) &&
|
||||
(boost::filesystem::is_regular_file (validatorsFile) ||
|
||||
boost::filesystem::is_symlink (validatorsFile)))
|
||||
if (!validatorsFile.empty() &&
|
||||
boost::filesystem::exists(validatorsFile) &&
|
||||
(boost::filesystem::is_regular_file(validatorsFile) ||
|
||||
boost::filesystem::is_symlink(validatorsFile)))
|
||||
{
|
||||
boost::system::error_code ec;
|
||||
auto const data = getFileContents(ec, validatorsFile);
|
||||
if (ec)
|
||||
{
|
||||
Throw<std::runtime_error>("Failed to read '" +
|
||||
validatorsFile.string() + "'." +
|
||||
Throw<std::runtime_error>(
|
||||
"Failed to read '" + validatorsFile.string() + "'." +
|
||||
std::to_string(ec.value()) + ": " + ec.message());
|
||||
}
|
||||
|
||||
auto iniFile = parseIniFile (data, true);
|
||||
auto iniFile = parseIniFile(data, true);
|
||||
|
||||
auto entries = getIniFileSection (
|
||||
iniFile,
|
||||
SECTION_VALIDATORS);
|
||||
auto entries = getIniFileSection(iniFile, SECTION_VALIDATORS);
|
||||
|
||||
if (entries)
|
||||
section (SECTION_VALIDATORS).append (*entries);
|
||||
section(SECTION_VALIDATORS).append(*entries);
|
||||
|
||||
auto valKeyEntries = getIniFileSection(
|
||||
iniFile,
|
||||
SECTION_VALIDATOR_KEYS);
|
||||
auto valKeyEntries =
|
||||
getIniFileSection(iniFile, SECTION_VALIDATOR_KEYS);
|
||||
|
||||
if (valKeyEntries)
|
||||
section (SECTION_VALIDATOR_KEYS).append (*valKeyEntries);
|
||||
section(SECTION_VALIDATOR_KEYS).append(*valKeyEntries);
|
||||
|
||||
auto valSiteEntries = getIniFileSection(
|
||||
iniFile,
|
||||
SECTION_VALIDATOR_LIST_SITES);
|
||||
auto valSiteEntries =
|
||||
getIniFileSection(iniFile, SECTION_VALIDATOR_LIST_SITES);
|
||||
|
||||
if (valSiteEntries)
|
||||
section (SECTION_VALIDATOR_LIST_SITES).append (*valSiteEntries);
|
||||
section(SECTION_VALIDATOR_LIST_SITES).append(*valSiteEntries);
|
||||
|
||||
auto valListKeys = getIniFileSection(
|
||||
iniFile,
|
||||
SECTION_VALIDATOR_LIST_KEYS);
|
||||
auto valListKeys =
|
||||
getIniFileSection(iniFile, SECTION_VALIDATOR_LIST_KEYS);
|
||||
|
||||
if (valListKeys)
|
||||
section (SECTION_VALIDATOR_LIST_KEYS).append (*valListKeys);
|
||||
section(SECTION_VALIDATOR_LIST_KEYS).append(*valListKeys);
|
||||
|
||||
if (!entries && !valKeyEntries && !valListKeys)
|
||||
Throw<std::runtime_error> (
|
||||
"The file specified in [" SECTION_VALIDATORS_FILE "] "
|
||||
"does not contain a [" SECTION_VALIDATORS "], "
|
||||
"[" SECTION_VALIDATOR_KEYS "] or "
|
||||
"[" SECTION_VALIDATOR_LIST_KEYS "]"
|
||||
Throw<std::runtime_error>(
|
||||
"The file specified in [" SECTION_VALIDATORS_FILE
|
||||
"] "
|
||||
"does not contain a [" SECTION_VALIDATORS
|
||||
"], "
|
||||
"[" SECTION_VALIDATOR_KEYS
|
||||
"] or "
|
||||
"[" SECTION_VALIDATOR_LIST_KEYS
|
||||
"]"
|
||||
" section: " +
|
||||
validatorsFile.string());
|
||||
}
|
||||
|
||||
// Consolidate [validator_keys] and [validators]
|
||||
section (SECTION_VALIDATORS).append (
|
||||
section (SECTION_VALIDATOR_KEYS).lines ());
|
||||
section(SECTION_VALIDATORS)
|
||||
.append(section(SECTION_VALIDATOR_KEYS).lines());
|
||||
|
||||
if (! section (SECTION_VALIDATOR_LIST_SITES).lines().empty() &&
|
||||
section (SECTION_VALIDATOR_LIST_KEYS).lines().empty())
|
||||
if (!section(SECTION_VALIDATOR_LIST_SITES).lines().empty() &&
|
||||
section(SECTION_VALIDATOR_LIST_KEYS).lines().empty())
|
||||
{
|
||||
Throw<std::runtime_error> (
|
||||
Throw<std::runtime_error>(
|
||||
"[" + std::string(SECTION_VALIDATOR_LIST_KEYS) +
|
||||
"] config section is missing");
|
||||
}
|
||||
@@ -575,7 +578,7 @@ void Config::loadFromString (std::string const& fileContents)
|
||||
|
||||
{
|
||||
auto const part = section("features");
|
||||
for(auto const& s : part.values())
|
||||
for (auto const& s : part.values())
|
||||
{
|
||||
if (auto const f = getRegisteredFeature(s))
|
||||
features.insert(*f);
|
||||
@@ -604,34 +607,33 @@ void Config::loadFromString (std::string const& fileContents)
|
||||
}
|
||||
}
|
||||
|
||||
boost::filesystem::path Config::getDebugLogFile () const
|
||||
boost::filesystem::path
|
||||
Config::getDebugLogFile() const
|
||||
{
|
||||
auto log_file = DEBUG_LOGFILE;
|
||||
|
||||
if (!log_file.empty () && !log_file.is_absolute ())
|
||||
if (!log_file.empty() && !log_file.is_absolute())
|
||||
{
|
||||
// Unless an absolute path for the log file is specified, the
|
||||
// path is relative to the config file directory.
|
||||
log_file = boost::filesystem::absolute (
|
||||
log_file, CONFIG_DIR);
|
||||
log_file = boost::filesystem::absolute(log_file, CONFIG_DIR);
|
||||
}
|
||||
|
||||
if (!log_file.empty ())
|
||||
if (!log_file.empty())
|
||||
{
|
||||
auto log_dir = log_file.parent_path ();
|
||||
auto log_dir = log_file.parent_path();
|
||||
|
||||
if (!boost::filesystem::is_directory (log_dir))
|
||||
if (!boost::filesystem::is_directory(log_dir))
|
||||
{
|
||||
boost::system::error_code ec;
|
||||
boost::filesystem::create_directories (log_dir, ec);
|
||||
boost::filesystem::create_directories(log_dir, ec);
|
||||
|
||||
// If we fail, we warn but continue so that the calling code can
|
||||
// decide how to handle this situation.
|
||||
if (ec)
|
||||
{
|
||||
std::cerr <<
|
||||
"Unable to create log file path " << log_dir <<
|
||||
": " << ec.message() << '\n';
|
||||
std::cerr << "Unable to create log file path " << log_dir
|
||||
<< ": " << ec.message() << '\n';
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -648,4 +650,4 @@ Config::getValueFor(SizedItem item, boost::optional<std::size_t> node) const
|
||||
return sizedItems.at(index).second.at(node.value_or(NODE_SIZE));
|
||||
}
|
||||
|
||||
} // ripple
|
||||
} // namespace ripple
|
||||
|
||||
Reference in New Issue
Block a user