mirror of
https://github.com/XRPLF/rippled.git
synced 2025-12-06 17:27:55 +00:00
Support ipv6 for peer and RPC comms:
Fixes: RIPD-1574 Alias beast address classes to the asio equivalents. Adjust users of address classes accordingly. Fix resolver class so that it can support ipv6 addresses. Make unit tests use ipv6 localhost network. Extend endpoint peer message to support string endpoint representations while also supporting the existing fields (both are optional/repeated types). Expand test for Livecache and Endpoint. Workaround some false positive ipaddr tests on windows (asio bug?) Replaced usage of address::from_string(deprecated) with free function make_address. Identified a remaining use of v4 address type and replaced with the more appropriate IPEndpoint type (rpc_ip cmdline option). Add CLI flag for using ipv4 with unit tests. Release Notes ------------- The optional rpc_port command line flag is deprecated. The rpc_ip parameter now works as documented and accepts ip and port combined.
This commit is contained in:
@@ -216,12 +216,15 @@ public:
|
||||
}
|
||||
};
|
||||
|
||||
namespace test{ extern std::atomic<bool> envUseIPv4; }
|
||||
|
||||
static int runUnitTests(
|
||||
std::string const& pattern,
|
||||
std::string const& argument,
|
||||
bool quiet,
|
||||
bool log,
|
||||
bool child,
|
||||
bool ipv4,
|
||||
std::size_t num_jobs,
|
||||
int argc,
|
||||
char** argv)
|
||||
@@ -229,6 +232,9 @@ static int runUnitTests(
|
||||
using namespace beast::unit_test;
|
||||
using namespace ripple::test;
|
||||
|
||||
if (ipv4)
|
||||
ripple::test::envUseIPv4 = true;
|
||||
|
||||
#if HAS_BOOST_PROCESS
|
||||
if (!child && num_jobs == 1)
|
||||
#endif
|
||||
@@ -365,6 +371,7 @@ int run (int argc, char** argv)
|
||||
"Specify the IP address for RPC command. "
|
||||
"Format: <ip-address>[':'<port-number>]")
|
||||
("rpc_port", po::value <std::uint16_t> (),
|
||||
"DEPRECATED: include with rpc_ip instead. "
|
||||
"Specify the port number for RPC command.")
|
||||
;
|
||||
|
||||
@@ -384,6 +391,7 @@ int run (int argc, char** argv)
|
||||
"argument is handled individually by any suite that accesses it -- "
|
||||
"as such, it typically only make sense to provide this when running "
|
||||
"a single suite.")
|
||||
("unittest-ipv4", "Use IPv4 localhost when running unittests (default is IPv6).")
|
||||
("unittest-log",
|
||||
"Force unit test log message output. Only useful in combination with "
|
||||
"--quiet, in which case log messages will print but suite/case names "
|
||||
@@ -468,6 +476,7 @@ int run (int argc, char** argv)
|
||||
bool (vm.count ("quiet")),
|
||||
bool (vm.count ("unittest-log")),
|
||||
unittestChild,
|
||||
bool (vm.count ("unittest-ipv4")),
|
||||
numJobs,
|
||||
argc,
|
||||
argv);
|
||||
@@ -553,37 +562,38 @@ int run (int argc, char** argv)
|
||||
// happen after the config file is loaded.
|
||||
if (vm.count ("rpc_ip"))
|
||||
{
|
||||
try
|
||||
{
|
||||
config->rpc_ip.emplace (
|
||||
boost::asio::ip::address_v4::from_string(
|
||||
vm["rpc_ip"].as<std::string>()));
|
||||
}
|
||||
catch(std::exception const&)
|
||||
auto res = beast::IP::Endpoint::from_string_checked(
|
||||
vm["rpc_ip"].as<std::string>());
|
||||
if (! res.second)
|
||||
{
|
||||
std::cerr << "Invalid rpc_ip = " <<
|
||||
vm["rpc_ip"].as<std::string>() << std::endl;
|
||||
vm["rpc_ip"].as<std::string>() << "\n";
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
|
||||
// Override the RPC destination port number
|
||||
//
|
||||
if (vm.count ("rpc_port"))
|
||||
{
|
||||
try
|
||||
if (res.first.port() == 0)
|
||||
{
|
||||
config->rpc_port.emplace (
|
||||
vm["rpc_port"].as<std::uint16_t>());
|
||||
std::cerr << "No port specified in rpc_ip.\n";
|
||||
if (vm.count ("rpc_port"))
|
||||
{
|
||||
std::cerr << "WARNING: using deprecated rpc_port param.\n";
|
||||
try
|
||||
{
|
||||
res.first.at_port(vm["rpc_port"].as<std::uint16_t>());
|
||||
if (res.first.port() == 0)
|
||||
throw std::domain_error("0");
|
||||
}
|
||||
catch(std::exception const& e)
|
||||
{
|
||||
std::cerr << "Invalid rpc_port = " << e.what() << "\n";
|
||||
return -1;
|
||||
}
|
||||
}
|
||||
else
|
||||
return -1;
|
||||
}
|
||||
|
||||
if (*config->rpc_port == 0)
|
||||
throw std::domain_error("0");
|
||||
}
|
||||
catch(std::exception const& e)
|
||||
{
|
||||
std::cerr << "Invalid rpc_port = " << e.what() << "\n";
|
||||
return -1;
|
||||
}
|
||||
config->rpc_ip = std::move(res.first);
|
||||
}
|
||||
|
||||
if (vm.count ("quorum"))
|
||||
|
||||
Reference in New Issue
Block a user