mirror of https://github.com/Icinga/icinga2.git
Fix null ptr dereference in HttpServerConnection::ProcessMessageAsync
This commit is contained in:
parent
6400a300cd
commit
6e7421eab0
|
@ -29,7 +29,7 @@
|
||||||
using namespace icinga;
|
using namespace icinga;
|
||||||
|
|
||||||
HttpResponse::HttpResponse(const Stream::Ptr& stream, const HttpRequest& request)
|
HttpResponse::HttpResponse(const Stream::Ptr& stream, const HttpRequest& request)
|
||||||
: Complete(false), m_State(HttpResponseStart), m_Request(request), m_Stream(stream)
|
: Complete(false), m_State(HttpResponseStart), m_Request(&request), m_Stream(stream)
|
||||||
{ }
|
{ }
|
||||||
|
|
||||||
void HttpResponse::SetStatus(int code, const String& message)
|
void HttpResponse::SetStatus(int code, const String& message)
|
||||||
|
@ -44,7 +44,7 @@ void HttpResponse::SetStatus(int code, const String& message)
|
||||||
|
|
||||||
String status = "HTTP/";
|
String status = "HTTP/";
|
||||||
|
|
||||||
if (m_Request.ProtocolVersion == HttpVersion10)
|
if (m_Request->ProtocolVersion == HttpVersion10)
|
||||||
status += "1.0";
|
status += "1.0";
|
||||||
else
|
else
|
||||||
status += "1.1";
|
status += "1.1";
|
||||||
|
@ -64,7 +64,7 @@ void HttpResponse::AddHeader(const String& key, const String& value)
|
||||||
void HttpResponse::FinishHeaders(void)
|
void HttpResponse::FinishHeaders(void)
|
||||||
{
|
{
|
||||||
if (m_State == HttpResponseHeaders) {
|
if (m_State == HttpResponseHeaders) {
|
||||||
if (m_Request.ProtocolVersion == HttpVersion11)
|
if (m_Request->ProtocolVersion == HttpVersion11)
|
||||||
AddHeader("Transfer-Encoding", "chunked");
|
AddHeader("Transfer-Encoding", "chunked");
|
||||||
|
|
||||||
AddHeader("Server", "Icinga/" + Application::GetAppVersion());
|
AddHeader("Server", "Icinga/" + Application::GetAppVersion());
|
||||||
|
@ -81,7 +81,7 @@ void HttpResponse::WriteBody(const char *data, size_t count)
|
||||||
{
|
{
|
||||||
ASSERT(m_State == HttpResponseHeaders || m_State == HttpResponseBody);
|
ASSERT(m_State == HttpResponseHeaders || m_State == HttpResponseBody);
|
||||||
|
|
||||||
if (m_Request.ProtocolVersion == HttpVersion10) {
|
if (m_Request->ProtocolVersion == HttpVersion10) {
|
||||||
if (!m_Body)
|
if (!m_Body)
|
||||||
m_Body = new FIFO();
|
m_Body = new FIFO();
|
||||||
|
|
||||||
|
@ -97,7 +97,7 @@ void HttpResponse::Finish(void)
|
||||||
{
|
{
|
||||||
ASSERT(m_State != HttpResponseEnd);
|
ASSERT(m_State != HttpResponseEnd);
|
||||||
|
|
||||||
if (m_Request.ProtocolVersion == HttpVersion10) {
|
if (m_Request->ProtocolVersion == HttpVersion10) {
|
||||||
if (m_Body)
|
if (m_Body)
|
||||||
AddHeader("Content-Length", Convert::ToString(m_Body->GetAvailableBytes()));
|
AddHeader("Content-Length", Convert::ToString(m_Body->GetAvailableBytes()));
|
||||||
|
|
||||||
|
@ -115,7 +115,7 @@ void HttpResponse::Finish(void)
|
||||||
|
|
||||||
m_State = HttpResponseEnd;
|
m_State = HttpResponseEnd;
|
||||||
|
|
||||||
if (m_Request.ProtocolVersion == HttpVersion10 || m_Request.Headers->Get("connection") == "close")
|
if (m_Request->ProtocolVersion == HttpVersion10 || m_Request->Headers->Get("connection") == "close")
|
||||||
m_Stream->Shutdown();
|
m_Stream->Shutdown();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,3 +267,8 @@ bool HttpResponse::IsPeerConnected(void) const
|
||||||
{
|
{
|
||||||
return !m_Stream->IsEof();
|
return !m_Stream->IsEof();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HttpResponse::RebindRequest(const HttpRequest& request)
|
||||||
|
{
|
||||||
|
m_Request = &request;
|
||||||
|
}
|
||||||
|
|
|
@ -65,10 +65,12 @@ public:
|
||||||
|
|
||||||
bool IsPeerConnected(void) const;
|
bool IsPeerConnected(void) const;
|
||||||
|
|
||||||
|
void RebindRequest(const HttpRequest& request);
|
||||||
|
|
||||||
private:
|
private:
|
||||||
HttpResponseState m_State;
|
HttpResponseState m_State;
|
||||||
boost::shared_ptr<ChunkReadContext> m_ChunkContext;
|
boost::shared_ptr<ChunkReadContext> m_ChunkContext;
|
||||||
const HttpRequest& m_Request;
|
const HttpRequest *m_Request;
|
||||||
Stream::Ptr m_Stream;
|
Stream::Ptr m_Stream;
|
||||||
FIFO::Ptr m_Body;
|
FIFO::Ptr m_Body;
|
||||||
std::vector<String> m_Headers;
|
std::vector<String> m_Headers;
|
||||||
|
|
|
@ -316,6 +316,8 @@ bool HttpServerConnection::ManageHeaders(HttpResponse& response)
|
||||||
|
|
||||||
void HttpServerConnection::ProcessMessageAsync(HttpRequest& request, HttpResponse& response, const ApiUser::Ptr& user)
|
void HttpServerConnection::ProcessMessageAsync(HttpRequest& request, HttpResponse& response, const ApiUser::Ptr& user)
|
||||||
{
|
{
|
||||||
|
response.RebindRequest(request);
|
||||||
|
|
||||||
try {
|
try {
|
||||||
HttpHandler::ProcessRequest(user, request, response);
|
HttpHandler::ProcessRequest(user, request, response);
|
||||||
} catch (const std::exception& ex) {
|
} catch (const std::exception& ex) {
|
||||||
|
|
Loading…
Reference in New Issue