mirror of
https://github.com/Xahau/xahaud.git
synced 2025-12-06 17:27:52 +00:00
Correctly handle connections that fail security checks (RIPD-1114):
* Return error code 400 to the peer along with a descriptive message * Release the slot and decrement IP connection counters.
This commit is contained in:
@@ -26,6 +26,7 @@
|
||||
#include <ripple/basics/make_SSLContext.h>
|
||||
#include <ripple/protocol/JsonFields.h>
|
||||
#include <ripple/server/JsonWriter.h>
|
||||
#include <ripple/server/SimpleWriter.h>
|
||||
#include <ripple/overlay/Cluster.h>
|
||||
#include <ripple/overlay/impl/ConnectAttempt.h>
|
||||
#include <ripple/overlay/impl/OverlayImpl.h>
|
||||
@@ -231,16 +232,30 @@ OverlayImpl::onHandoff (std::unique_ptr <beast::asio::ssl_bundle>&& ssl_bundle,
|
||||
}
|
||||
}
|
||||
|
||||
handoff.moved = true;
|
||||
|
||||
auto hello = parseHello (true, request.headers, journal);
|
||||
if(! hello)
|
||||
{
|
||||
m_peerFinder->on_closed(slot);
|
||||
handoff.moved = false;
|
||||
handoff.response = makeErrorResponse (slot, request,
|
||||
remote_endpoint.address(),
|
||||
"Unable to parse HELLO message");
|
||||
handoff.keep_alive = false;
|
||||
return handoff;
|
||||
}
|
||||
|
||||
auto sharedValue = makeSharedValue(
|
||||
ssl_bundle->stream.native_handle(), journal);
|
||||
if(! sharedValue)
|
||||
{
|
||||
m_peerFinder->on_closed(slot);
|
||||
handoff.moved = false;
|
||||
handoff.response = makeErrorResponse (slot, request,
|
||||
remote_endpoint.address(),
|
||||
"Incorrect security cookie (possible MITM detected)");
|
||||
handoff.keep_alive = false;
|
||||
return handoff;
|
||||
}
|
||||
|
||||
auto publicKey = verifyHello (*hello,
|
||||
*sharedValue,
|
||||
@@ -248,7 +263,15 @@ OverlayImpl::onHandoff (std::unique_ptr <beast::asio::ssl_bundle>&& ssl_bundle,
|
||||
beast::IPAddressConversion::from_asio(
|
||||
remote_endpoint), journal, app_);
|
||||
if(! publicKey)
|
||||
{
|
||||
m_peerFinder->on_closed(slot);
|
||||
handoff.moved = false;
|
||||
handoff.response = makeErrorResponse (slot, request,
|
||||
remote_endpoint.address(),
|
||||
"Unable to verify HELLO message");
|
||||
handoff.keep_alive = false;
|
||||
return handoff;
|
||||
}
|
||||
|
||||
auto const result = m_peerFinder->activate (slot, *publicKey,
|
||||
static_cast<bool>(app_.cluster().member(*publicKey)));
|
||||
@@ -348,6 +371,27 @@ OverlayImpl::makeRedirectResponse (PeerFinder::Slot::ptr const& slot,
|
||||
return response;
|
||||
}
|
||||
|
||||
std::shared_ptr<Writer>
|
||||
OverlayImpl::makeErrorResponse (PeerFinder::Slot::ptr const& slot,
|
||||
http_request_type const& request,
|
||||
address_type remote_address,
|
||||
std::string msg)
|
||||
{
|
||||
beast::deprecated_http::message m;
|
||||
m.version(std::make_pair(request.version / 10, request.version % 10));
|
||||
m.request(false);
|
||||
m.status(400);
|
||||
m.reason("Bad Request");
|
||||
m.headers.insert("Remote-Address", remote_address.to_string());
|
||||
|
||||
auto response = std::make_shared<SimpleWriter> (std::move(m));
|
||||
|
||||
if (!msg.empty())
|
||||
response->body (msg);
|
||||
|
||||
return response;
|
||||
}
|
||||
|
||||
//------------------------------------------------------------------------------
|
||||
|
||||
void
|
||||
|
||||
@@ -276,6 +276,11 @@ private:
|
||||
makeRedirectResponse (PeerFinder::Slot::ptr const& slot,
|
||||
http_request_type const& request, address_type remote_address);
|
||||
|
||||
std::shared_ptr<Writer>
|
||||
makeErrorResponse (PeerFinder::Slot::ptr const& slot,
|
||||
http_request_type const& request, address_type remote_address,
|
||||
std::string msg);
|
||||
|
||||
bool
|
||||
processRequest (http_request_type const& req,
|
||||
Handoff& handoff);
|
||||
|
||||
@@ -21,30 +21,29 @@
|
||||
#define RIPPLE_SERVER_SIMPLEWRITER_H_INCLUDED
|
||||
|
||||
#include <ripple/server/Writer.h>
|
||||
#include <beast/asio/streambuf.h>
|
||||
#include <beast/http/message.h>
|
||||
#include <ripple/beast/deprecated_http.h>
|
||||
#include <beast/streambuf.hpp>
|
||||
#include <utility>
|
||||
|
||||
namespace ripple {
|
||||
namespace HTTP {
|
||||
|
||||
/** Writer that sends a simple HTTP response with a message body. */
|
||||
class SimpleWriter : public Writer
|
||||
{
|
||||
private:
|
||||
beast::http::message message_;
|
||||
beast::asio::streambuf streambuf_;
|
||||
beast::deprecated_http::message message_;
|
||||
beast::streambuf streambuf_;
|
||||
std::string body_;
|
||||
bool prepared_ = false;
|
||||
|
||||
public:
|
||||
explicit
|
||||
SimpleWriter(beast::http::message&& message)
|
||||
: message_(std::forward<beast::http::message>(message))
|
||||
SimpleWriter(beast::deprecated_http::message&& message)
|
||||
: message_(std::forward<beast::deprecated_http::message>(message))
|
||||
{
|
||||
}
|
||||
|
||||
beast::http::message&
|
||||
beast::deprecated_http::message&
|
||||
message()
|
||||
{
|
||||
return message_;
|
||||
@@ -95,14 +94,13 @@ private:
|
||||
{
|
||||
prepared_ = true;
|
||||
message_.headers.erase("Content-Length");
|
||||
message_.headers.append("Content-Length",
|
||||
message_.headers.insert("Content-Length",
|
||||
std::to_string(body_.size()));
|
||||
write(streambuf_, message_);
|
||||
write(streambuf_, body_;
|
||||
beast::http::detail::write(streambuf_, body_);
|
||||
}
|
||||
};
|
||||
|
||||
}
|
||||
}
|
||||
|
||||
#endif
|
||||
|
||||
Reference in New Issue
Block a user