From 948333225d86f02810ced4d734212f58a28c7212 Mon Sep 17 00:00:00 2001 From: Noah Hilverling Date: Wed, 31 Jan 2018 10:17:49 +0100 Subject: [PATCH] Fix nullptr deref in cluster events --- lib/icinga/clusterevents.cpp | 30 ---------------------------- lib/remote/jsonrpcconnection-pki.cpp | 3 --- lib/remote/jsonrpcconnection.cpp | 9 +++++---- 3 files changed, 5 insertions(+), 37 deletions(-) diff --git a/lib/icinga/clusterevents.cpp b/lib/icinga/clusterevents.cpp index 9ae894db1..e892caabf 100644 --- a/lib/icinga/clusterevents.cpp +++ b/lib/icinga/clusterevents.cpp @@ -114,9 +114,6 @@ Value ClusterEvents::CheckResultAPIHandler(const MessageOrigin::Ptr& origin, con return Empty; } - if (!params) - return Empty; - CheckResult::Ptr cr; Array::Ptr vperf; @@ -220,9 +217,6 @@ Value ClusterEvents::NextCheckChangedAPIHandler(const MessageOrigin::Ptr& origin return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -284,9 +278,6 @@ Value ClusterEvents::NextNotificationChangedAPIHandler(const MessageOrigin::Ptr& return Empty; } - if (!params) - return Empty; - Notification::Ptr notification = Notification::GetByName(params->Get("notification")); if (!notification) @@ -344,9 +335,6 @@ Value ClusterEvents::ForceNextCheckChangedAPIHandler(const MessageOrigin::Ptr& o return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -409,9 +397,6 @@ Value ClusterEvents::ForceNextNotificationChangedAPIHandler(const MessageOrigin: return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -480,9 +465,6 @@ Value ClusterEvents::AcknowledgementSetAPIHandler(const MessageOrigin::Ptr& orig return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -546,9 +528,6 @@ Value ClusterEvents::AcknowledgementClearedAPIHandler(const MessageOrigin::Ptr& return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -612,9 +591,6 @@ Value ClusterEvents::SendNotificationsAPIHandler(const MessageOrigin::Ptr& origi return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -706,9 +682,6 @@ Value ClusterEvents::NotificationSentUserAPIHandler(const MessageOrigin::Ptr& or return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) @@ -822,9 +795,6 @@ Value ClusterEvents::NotificationSentToAllUsersAPIHandler(const MessageOrigin::P return Empty; } - if (!params) - return Empty; - Host::Ptr host = Host::GetByName(params->Get("host")); if (!host) diff --git a/lib/remote/jsonrpcconnection-pki.cpp b/lib/remote/jsonrpcconnection-pki.cpp index 31fa9078a..80740ac31 100644 --- a/lib/remote/jsonrpcconnection-pki.cpp +++ b/lib/remote/jsonrpcconnection-pki.cpp @@ -40,9 +40,6 @@ REGISTER_APIFUNCTION(UpdateCertificate, pki, &UpdateCertificateHandler); Value RequestCertificateHandler(const MessageOrigin::Ptr& origin, const Dictionary::Ptr& params) { - if (!params) - return Empty; - String certText = params->Get("cert_request"); std::shared_ptr cert; diff --git a/lib/remote/jsonrpcconnection.cpp b/lib/remote/jsonrpcconnection.cpp index 574cb007f..c1895934c 100644 --- a/lib/remote/jsonrpcconnection.cpp +++ b/lib/remote/jsonrpcconnection.cpp @@ -225,7 +225,11 @@ void JsonRpcConnection::MessageHandler(const String& jsonString) Log(LogNotice, "JsonRpcConnection") << "Call to non-existent function '" << method << "' from endpoint '" << m_Identity << "'."; } else { - resultMessage->Set("result", afunc->Invoke(origin, message->Get("params"))); + Dictionary::Ptr params = message->Get("params"); + if (params) + resultMessage->Set("result", afunc->Invoke(origin, params)); + else + resultMessage->Set("result", Empty); } } catch (const std::exception& ex) { /* TODO: Add a user readable error message for the remote caller */ @@ -287,9 +291,6 @@ void JsonRpcConnection::DataAvailableHandler() Value SetLogPositionHandler(const MessageOrigin::Ptr& origin, const Dictionary::Ptr& params) { - if (!params) - return Empty; - double log_position = params->Get("log_position"); Endpoint::Ptr endpoint = origin->FromClient->GetEndpoint(); -- 2.40.0