mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-04-29 14:59:39 -04:00
refactor: split http_request_cb into libevent callback and dispatch
The original function is passed to libevent as a callback when HTTP requests are received and processed. It wrapped the libevent request object in a http_libevent::HTTPRequest and then handed that off to bitcoin for basic checks and finally dispatch to worker threads. In this commit we split the function after the http_libevent::HTTPRequest is created, and pass that object to a new function that maintains the logic of checking and dispatching. This will be the merge point for http_libevent and http_bitcoin, where HTTPRequest objects from either namespace have the same downstream lifecycle.
This commit is contained in:
parent
b828fa1e29
commit
3adcd9617e
1 changed files with 31 additions and 27 deletions
|
@ -261,34 +261,8 @@ std::string RequestMethodString(HTTPRequestMethod m)
|
|||
assert(false);
|
||||
}
|
||||
|
||||
/** HTTP request callback */
|
||||
static void http_request_cb(struct evhttp_request* req, void* arg)
|
||||
static void MaybeDispatchRequestToWorker(std::unique_ptr<HTTPRequest> hreq)
|
||||
{
|
||||
evhttp_connection* conn{evhttp_request_get_connection(req)};
|
||||
// Track active requests
|
||||
{
|
||||
g_requests.AddRequest(req);
|
||||
evhttp_request_set_on_complete_cb(req, [](struct evhttp_request* req, void*) {
|
||||
g_requests.RemoveRequest(req);
|
||||
}, nullptr);
|
||||
evhttp_connection_set_closecb(conn, [](evhttp_connection* conn, void* arg) {
|
||||
g_requests.RemoveConnection(conn);
|
||||
}, nullptr);
|
||||
}
|
||||
|
||||
// Disable reading to work around a libevent bug, fixed in 2.1.9
|
||||
// See https://github.com/libevent/libevent/commit/5ff8eb26371c4dc56f384b2de35bea2d87814779
|
||||
// and https://github.com/bitcoin/bitcoin/pull/11593.
|
||||
if (event_get_version_number() >= 0x02010600 && event_get_version_number() < 0x02010900) {
|
||||
if (conn) {
|
||||
bufferevent* bev = evhttp_connection_get_bufferevent(conn);
|
||||
if (bev) {
|
||||
bufferevent_disable(bev, EV_READ);
|
||||
}
|
||||
}
|
||||
}
|
||||
auto hreq{std::make_unique<HTTPRequest>(req, *static_cast<const util::SignalInterrupt*>(arg))};
|
||||
|
||||
// Early address-based allow check
|
||||
if (!ClientAllowed(hreq->GetPeer())) {
|
||||
LogDebug(BCLog::HTTP, "HTTP request from %s rejected: Client network is not allowed RPC access\n",
|
||||
|
@ -341,6 +315,36 @@ static void http_request_cb(struct evhttp_request* req, void* arg)
|
|||
}
|
||||
}
|
||||
|
||||
/** HTTP request callback */
|
||||
static void http_request_cb(struct evhttp_request* req, void* arg)
|
||||
{
|
||||
evhttp_connection* conn{evhttp_request_get_connection(req)};
|
||||
// Track active requests
|
||||
{
|
||||
g_requests.AddRequest(req);
|
||||
evhttp_request_set_on_complete_cb(req, [](struct evhttp_request* req, void*) {
|
||||
g_requests.RemoveRequest(req);
|
||||
}, nullptr);
|
||||
evhttp_connection_set_closecb(conn, [](evhttp_connection* conn, void* arg) {
|
||||
g_requests.RemoveConnection(conn);
|
||||
}, nullptr);
|
||||
}
|
||||
|
||||
// Disable reading to work around a libevent bug, fixed in 2.1.9
|
||||
// See https://github.com/libevent/libevent/commit/5ff8eb26371c4dc56f384b2de35bea2d87814779
|
||||
// and https://github.com/bitcoin/bitcoin/pull/11593.
|
||||
if (event_get_version_number() >= 0x02010600 && event_get_version_number() < 0x02010900) {
|
||||
if (conn) {
|
||||
bufferevent* bev = evhttp_connection_get_bufferevent(conn);
|
||||
if (bev) {
|
||||
bufferevent_disable(bev, EV_READ);
|
||||
}
|
||||
}
|
||||
}
|
||||
auto hreq{std::make_unique<http_libevent::HTTPRequest>(req, *static_cast<const util::SignalInterrupt*>(arg))};
|
||||
MaybeDispatchRequestToWorker(std::move(hreq));
|
||||
}
|
||||
|
||||
/** Callback to reject HTTP requests after shutdown. */
|
||||
static void http_reject_request_cb(struct evhttp_request* req, void*)
|
||||
{
|
||||
|
|
Loading…
Add table
Reference in a new issue