20#ifndef RIPPLE_NET_HTTPCLIENTSSLCONTEXT_H_INCLUDED
21#define RIPPLE_NET_HTTPCLIENTSSLCONTEXT_H_INCLUDED
23#include <xrpld/core/Config.h>
24#include <xrpld/net/RegisterSSLCerts.h>
25#include <xrpl/basics/Log.h>
26#include <xrpl/basics/contract.h>
27#include <boost/asio.hpp>
28#include <boost/asio/ip/tcp.hpp>
29#include <boost/asio/ssl.hpp>
30#include <boost/format.hpp>
40 boost::asio::ssl::context_base::method method =
41 boost::asio::ssl::context::sslv23)
44 boost::system::error_code ec;
51 Throw<std::runtime_error>(boost::str(
52 boost::format(
"Failed to set_default_verify_paths: %s") %
65 Throw<std::runtime_error>(boost::str(
66 boost::format(
"Failed to add verify path: %s") %
71 boost::asio::ssl::context&
100 boost::asio::ssl::stream<boost::asio::ip::tcp::socket>>::
104 boost::asio::ssl::stream<boost::asio::ip::tcp::socket&>>::
106 boost::system::error_code
109 boost::system::error_code ec;
110 if (!SSL_set_tlsext_host_name(strm.native_handle(), host.
c_str()))
113 static_cast<int>(::ERR_get_error()),
114 boost::asio::error::get_ssl_category());
118 strm.set_verify_mode(boost::asio::ssl::verify_none, ec);
128 boost::asio::ssl::stream<boost::asio::ip::tcp::socket>>::
132 boost::asio::ssl::stream<boost::asio::ip::tcp::socket&>>::
141 boost::system::error_code
144 boost::system::error_code ec;
148 strm.set_verify_mode(boost::asio::ssl::verify_peer, ec);
151 strm.set_verify_callback(
155 std::placeholders::_1,
156 std::placeholders::_2,
178 boost::asio::ssl::verify_context& ctx,
181 if (boost::asio::ssl::rfc2818_verification(domain)(preverified, ctx))
184 JLOG(j.
warn()) <<
"Outbound SSL connection to " << domain
185 <<
" fails certificate verification";
A generic endpoint for log messages.
std::string SSL_VERIFY_FILE
std::string SSL_VERIFY_DIR
static bool rfc2818_verify(std::string const &domain, bool preverified, boost::asio::ssl::verify_context &ctx, beast::Journal j)
callback invoked for name verification - just passes through to the asio rfc2818 implementation.
boost::system::error_code preConnectVerify(T &strm, std::string const &host)
invoked before connect/async_connect on an ssl stream to setup name verification.
boost::asio::ssl::context ssl_context_
boost::system::error_code postConnectVerify(T &strm, std::string const &host)
invoked after connect/async_connect but before sending data on an ssl stream - to setup name verifica...
boost::asio::ssl::context & context()
HTTPClientSSLContext(Config const &config, beast::Journal j, boost::asio::ssl::context_base::method method=boost::asio::ssl::context::sslv23)
Use hash_* containers for keys that do not need a cryptographically secure hashing algorithm.
void registerSSLCerts(boost::asio::ssl::context &ctx, boost::system::error_code &ec, beast::Journal j)
Register default SSL certificates.