Bitcoin Core 28.99.0
P2P Digital Currency
|
#include <functional>
#include <optional>
#include <span>
#include <string>
Go to the source code of this file.
Classes | |
class | HTTPRequest |
In-flight HTTP request. More... | |
class | HTTPClosure |
Event handler closure. More... | |
class | HTTPEvent |
Event class. More... | |
Namespaces | |
namespace | util |
Typedefs | |
typedef std::function< bool(HTTPRequest *req, const std::string &)> | HTTPRequestHandler |
Handler for requests to a certain HTTP path. More... | |
Functions | |
bool | InitHTTPServer (const util::SignalInterrupt &interrupt) |
Initialize HTTP server. More... | |
void | StartHTTPServer () |
Start HTTP server. More... | |
void | InterruptHTTPServer () |
Interrupt HTTP server threads. More... | |
void | StopHTTPServer () |
Stop HTTP server. More... | |
void | UpdateHTTPServerLogging (bool enable) |
Change logging level for libevent. More... | |
void | RegisterHTTPHandler (const std::string &prefix, bool exactMatch, const HTTPRequestHandler &handler) |
Register handler for prefix. More... | |
void | UnregisterHTTPHandler (const std::string &prefix, bool exactMatch) |
Unregister handler for prefix. More... | |
struct event_base * | EventBase () |
Return evhttp event base. More... | |
std::optional< std::string > | GetQueryParameterFromUri (const char *uri, const std::string &key) |
Get the query parameter value from request uri for a specified key, or std::nullopt if the key is not found. More... | |
Variables | |
static const int | DEFAULT_HTTP_THREADS =16 |
The default value for -rpcthreads . More... | |
static const int | DEFAULT_HTTP_WORKQUEUE =64 |
The default value for -rpcworkqueue . More... | |
static const int | DEFAULT_HTTP_SERVER_TIMEOUT =30 |
typedef std::function<bool(HTTPRequest* req, const std::string &)> HTTPRequestHandler |
Handler for requests to a certain HTTP path.
Definition at line 53 of file httpserver.h.
struct event_base * EventBase | ( | ) |
Return evhttp event base.
This can be used by submodules to queue timers or custom events.
Definition at line 559 of file httpserver.cpp.
std::optional< std::string > GetQueryParameterFromUri | ( | const char * | uri, |
const std::string & | key | ||
) |
Get the query parameter value from request uri for a specified key, or std::nullopt if the key is not found.
If the query string contains duplicate keys, the first value is returned. Many web frameworks would instead parse this as an array of values, but this is not (yet) implemented as it is currently not needed in any of the endpoints.
Helper function for HTTPRequest::GetQueryParameter.
[in] | uri | is the entire request uri |
[in] | key | represents the query parameter of which the value is returned |
Definition at line 726 of file httpserver.cpp.
bool InitHTTPServer | ( | const util::SignalInterrupt & | interrupt | ) |
Initialize HTTP server.
Call this before RegisterHTTPHandler or EventBase().
Definition at line 437 of file httpserver.cpp.
void InterruptHTTPServer | ( | ) |
Interrupt HTTP server threads.
Definition at line 506 of file httpserver.cpp.
void RegisterHTTPHandler | ( | const std::string & | prefix, |
bool | exactMatch, | ||
const HTTPRequestHandler & | handler | ||
) |
Register handler for prefix.
If multiple handlers match a prefix, the first-registered one will be invoked.
Definition at line 753 of file httpserver.cpp.
void StartHTTPServer | ( | ) |
Start HTTP server.
This is separate from InitHTTPServer to give users race-condition-free time to register their handlers between InitHTTPServer and StartHTTPServer.
Definition at line 495 of file httpserver.cpp.
void StopHTTPServer | ( | ) |
Stop HTTP server.
Definition at line 518 of file httpserver.cpp.
void UnregisterHTTPHandler | ( | const std::string & | prefix, |
bool | exactMatch | ||
) |
Unregister handler for prefix.
Definition at line 760 of file httpserver.cpp.
void UpdateHTTPServerLogging | ( | bool | enable | ) |
Change logging level for libevent.
Definition at line 484 of file httpserver.cpp.
|
static |
Definition at line 28 of file httpserver.h.
|
static |
The default value for -rpcthreads
.
This number of threads will be created at startup.
Definition at line 20 of file httpserver.h.
|
static |
The default value for -rpcworkqueue
.
This is the maximum depth of the work queue, we don't allocate this number of work queue items upfront.
Definition at line 26 of file httpserver.h.