![]() |
Bitcoin Core 22.99.0
P2P Digital Currency
|
In-flight HTTP request. More...
#include <httpserver.h>
Public Types | |
| enum | RequestMethod { UNKNOWN , GET , POST , HEAD , PUT } |
Public Member Functions | |
| HTTPRequest (struct evhttp_request *req, bool replySent=false) | |
| ~HTTPRequest () | |
| std::string | GetURI () const |
| Get requested URI. More... | |
| CService | GetPeer () const |
| Get CService (address:ip) for the origin of the http request. More... | |
| RequestMethod | GetRequestMethod () const |
| Get request method. More... | |
| std::pair< bool, std::string > | GetHeader (const std::string &hdr) const |
| Get the request header specified by hdr, or an empty string. More... | |
| std::string | ReadBody () |
| Read request body. More... | |
| void | WriteHeader (const std::string &hdr, const std::string &value) |
| Write output header. More... | |
| void | WriteReply (int nStatus, const std::string &strReply="") |
| Write HTTP reply. More... | |
Private Attributes | |
| struct evhttp_request * | req |
| bool | replySent |
In-flight HTTP request.
Thin C++ wrapper around evhttp_request.
Definition at line 56 of file httpserver.h.
| Enumerator | |
|---|---|
| UNKNOWN | |
| GET | |
| POST | |
| HEAD | |
| PUT | |
Definition at line 66 of file httpserver.h.
|
explicit |
Definition at line 505 of file httpserver.cpp.
| HTTPRequest::~HTTPRequest | ( | ) |
| std::pair< bool, std::string > HTTPRequest::GetHeader | ( | const std::string & | hdr | ) | const |
Get the request header specified by hdr, or an empty string.
Return a pair (isPresent,string).
Definition at line 519 of file httpserver.cpp.
| CService HTTPRequest::GetPeer | ( | ) | const |
Get CService (address:ip) for the origin of the http request.
Definition at line 592 of file httpserver.cpp.
| HTTPRequest::RequestMethod HTTPRequest::GetRequestMethod | ( | ) | const |
Get request method.
Definition at line 611 of file httpserver.cpp.
| std::string HTTPRequest::GetURI | ( | ) | const |
Get requested URI.
Definition at line 606 of file httpserver.cpp.
| std::string HTTPRequest::ReadBody | ( | ) |
Read request body.
Trivial implementation: if this is ever a performance bottleneck, internal copying can be avoided in multi-segment buffers by using evbuffer_peek and an awkward loop. Though in that case, it'd be even better to not copy into an intermediate string but use a stream abstraction to consume the evbuffer on the fly in the parsing algorithm.
Definition at line 530 of file httpserver.cpp.
| void HTTPRequest::WriteHeader | ( | const std::string & | hdr, |
| const std::string & | value | ||
| ) |
Write output header.
Definition at line 550 of file httpserver.cpp.
| void HTTPRequest::WriteReply | ( | int | nStatus, |
| const std::string & | strReply = "" |
||
| ) |
Write HTTP reply.
Closure sent to main thread to request a reply to be sent to a HTTP request.
nStatus is the HTTP status code to send. strReply is the body of the reply. Keep it empty to send a standard message.
Replies must be sent in the main loop in the main http thread, this cannot be done from worker threads.
Definition at line 562 of file httpserver.cpp.
|
private |
Definition at line 60 of file httpserver.h.
|
private |
Definition at line 59 of file httpserver.h.