From 15cb9c1c1a30ad09fd09f4a3cc7f53100302807a Mon Sep 17 00:00:00 2001 From: Marius Sturm Date: Sun, 10 Apr 2016 22:33:31 +0200 Subject: [PATCH] Use check_result timestamp for GELF log messages fixes #9184 Signed-off-by: Michael Friedrich --- lib/perfdata/gelfwriter.cpp | 13 ++++++++----- lib/perfdata/gelfwriter.hpp | 6 +++--- 2 files changed, 11 insertions(+), 8 deletions(-) diff --git a/lib/perfdata/gelfwriter.cpp b/lib/perfdata/gelfwriter.cpp index 6eddecd79..d77ac2720 100644 --- a/lib/perfdata/gelfwriter.cpp +++ b/lib/perfdata/gelfwriter.cpp @@ -89,6 +89,7 @@ void GelfWriter::CheckResultHandler(const Checkable::Ptr& checkable, const Check Host::Ptr host; Service::Ptr service; tie(host, service) = GetHostService(checkable); + double ts = cr->GetExecutionEnd(); Dictionary::Ptr fields = new Dictionary(); @@ -159,7 +160,7 @@ void GelfWriter::CheckResultHandler(const Checkable::Ptr& checkable, const Check } } - SendLogMessage(ComposeGelfMessage(fields, GetSource())); + SendLogMessage(ComposeGelfMessage(fields, GetSource(), ts)); } void GelfWriter::NotificationToUserHandler(const Notification::Ptr& notification, const Checkable::Ptr& checkable, @@ -174,6 +175,7 @@ void GelfWriter::NotificationToUserHandler(const Notification::Ptr& notification Host::Ptr host; Service::Ptr service; tie(host, service) = GetHostService(checkable); + double ts = cr->GetExecutionEnd(); String notification_type_str = Notification::NotificationTypeToString(notification_type); @@ -206,7 +208,7 @@ void GelfWriter::NotificationToUserHandler(const Notification::Ptr& notification fields->Set("_notification_type", notification_type_str); fields->Set("_comment", author_comment); - SendLogMessage(ComposeGelfMessage(fields, GetSource())); + SendLogMessage(ComposeGelfMessage(fields, GetSource(), ts)); } void GelfWriter::StateChangeHandler(const Checkable::Ptr& checkable, const CheckResult::Ptr& cr, StateType type) @@ -219,6 +221,7 @@ void GelfWriter::StateChangeHandler(const Checkable::Ptr& checkable, const Check Host::Ptr host; Service::Ptr service; tie(host, service) = GetHostService(checkable); + double ts = cr->GetExecutionEnd(); Dictionary::Ptr fields = new Dictionary(); @@ -244,14 +247,14 @@ void GelfWriter::StateChangeHandler(const Checkable::Ptr& checkable, const Check fields->Set("_check_source", cr->GetCheckSource()); } - SendLogMessage(ComposeGelfMessage(fields, GetSource())); + SendLogMessage(ComposeGelfMessage(fields, GetSource(), ts)); } -String GelfWriter::ComposeGelfMessage(const Dictionary::Ptr& fields, const String& source) +String GelfWriter::ComposeGelfMessage(const Dictionary::Ptr& fields, const String& source, double ts) { fields->Set("version", "1.1"); fields->Set("host", source); - fields->Set("timestamp", Utility::GetTime()); + fields->Set("timestamp", ts); return JsonEncode(fields); } diff --git a/lib/perfdata/gelfwriter.hpp b/lib/perfdata/gelfwriter.hpp index 327f0596a..f2b526e4c 100644 --- a/lib/perfdata/gelfwriter.hpp +++ b/lib/perfdata/gelfwriter.hpp @@ -51,9 +51,9 @@ private: void CheckResultHandler(const Checkable::Ptr& checkable, const CheckResult::Ptr& cr); void NotificationToUserHandler(const Notification::Ptr& notification, const Checkable::Ptr& checkable, - const User::Ptr& user, NotificationType notification_type, CheckResult::Ptr const& cr, - const String& author, const String& comment_text, const String& command_name); - String ComposeGelfMessage(const Dictionary::Ptr& fields, const String& source); + const User::Ptr& user, NotificationType notification_type, CheckResult::Ptr const& cr, + const String& author, const String& comment_text, const String& command_name); + String ComposeGelfMessage(const Dictionary::Ptr& fields, const String& source, double ts); void StateChangeHandler(const Checkable::Ptr& checkable, const CheckResult::Ptr& cr, StateType type); void SendLogMessage(const String& gelf);