2014-04-03 15:36:13 +02:00
/******************************************************************************
* Icinga 2 *
2017-01-10 15:54:22 +01:00
* Copyright ( C ) 2012 - 2017 Icinga Development Team ( https : //www.icinga.com/) *
2014-04-03 15:36:13 +02:00
* *
* This program is free software ; you can redistribute it and / or *
* modify it under the terms of the GNU General Public License *
* as published by the Free Software Foundation ; either version 2 *
* of the License , or ( at your option ) any later version . *
* *
* This program is distributed in the hope that it will be useful , *
* but WITHOUT ANY WARRANTY ; without even the implied warranty of *
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE . See the *
* GNU General Public License for more details . *
* *
* You should have received a copy of the GNU General Public License *
* along with this program ; if not , write to the Free Software Foundation *
* Inc . , 51 Franklin St , Fifth Floor , Boston , MA 02110 - 1301 , USA . *
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */
2014-05-25 16:23:35 +02:00
# include "db_ido/dbevents.hpp"
# include "db_ido/dbtype.hpp"
# include "db_ido/dbvalue.hpp"
# include "base/convert.hpp"
# include "base/objectlock.hpp"
# include "base/initialize.hpp"
2015-08-15 20:28:05 +02:00
# include "base/configtype.hpp"
2014-05-25 16:23:35 +02:00
# include "base/utility.hpp"
2014-10-19 14:21:12 +02:00
# include "base/logger.hpp"
2014-05-25 16:23:35 +02:00
# include "remote/endpoint.hpp"
# include "icinga/notification.hpp"
# include "icinga/checkcommand.hpp"
# include "icinga/eventcommand.hpp"
# include "icinga/externalcommandprocessor.hpp"
# include "icinga/compatutility.hpp"
# include "icinga/icingaapplication.hpp"
2014-04-03 15:36:13 +02:00
# include <boost/algorithm/string/join.hpp>
using namespace icinga ;
INITIALIZE_ONCE ( & DbEvents : : StaticInitialize ) ;
void DbEvents : : StaticInitialize ( void )
{
/* Status */
2015-08-20 17:18:48 +02:00
Comment : : OnCommentAdded . connect ( boost : : bind ( & DbEvents : : AddComment , _1 ) ) ;
Comment : : OnCommentRemoved . connect ( boost : : bind ( & DbEvents : : RemoveComment , _1 ) ) ;
2015-12-14 11:36:03 +01:00
Downtime : : OnDowntimeAdded . connect ( boost : : bind ( & DbEvents : : AddDowntime , _1 ) ) ;
2015-08-20 17:18:48 +02:00
Downtime : : OnDowntimeRemoved . connect ( boost : : bind ( & DbEvents : : RemoveDowntime , _1 ) ) ;
Downtime : : OnDowntimeTriggered . connect ( boost : : bind ( & DbEvents : : TriggerDowntime , _1 ) ) ;
2014-05-02 23:38:37 +02:00
Checkable : : OnAcknowledgementSet . connect ( boost : : bind ( & DbEvents : : AddAcknowledgement , _1 , _4 ) ) ;
Checkable : : OnAcknowledgementCleared . connect ( boost : : bind ( & DbEvents : : RemoveAcknowledgement , _1 ) ) ;
2016-01-22 18:42:15 +01:00
Checkable : : OnNextCheckUpdated . connect ( boost : : bind ( & DbEvents : : NextCheckUpdatedHandler , _1 ) ) ;
2015-08-04 14:47:44 +02:00
Checkable : : OnFlappingChanged . connect ( boost : : bind ( & DbEvents : : FlappingChangedHandler , _1 ) ) ;
2014-05-10 16:52:48 +02:00
Checkable : : OnNotificationSentToAllUsers . connect ( boost : : bind ( & DbEvents : : LastNotificationChangedHandler , _1 , _2 ) ) ;
2015-08-04 14:47:44 +02:00
Checkable : : OnEnableActiveChecksChanged . connect ( boost : : bind ( & DbEvents : : EnableActiveChecksChangedHandler , _1 ) ) ;
Checkable : : OnEnablePassiveChecksChanged . connect ( boost : : bind ( & DbEvents : : EnablePassiveChecksChangedHandler , _1 ) ) ;
Checkable : : OnEnableNotificationsChanged . connect ( boost : : bind ( & DbEvents : : EnableNotificationsChangedHandler , _1 ) ) ;
Checkable : : OnEnablePerfdataChanged . connect ( boost : : bind ( & DbEvents : : EnablePerfdataChangedHandler , _1 ) ) ;
Checkable : : OnEnableFlappingChanged . connect ( boost : : bind ( & DbEvents : : EnableFlappingChangedHandler , _1 ) ) ;
2014-04-03 15:36:13 +02:00
2014-12-12 15:53:10 +01:00
Checkable : : OnReachabilityChanged . connect ( boost : : bind ( & DbEvents : : ReachabilityChangedHandler , _1 , _2 , _3 ) ) ;
2014-04-03 15:36:13 +02:00
/* History */
2015-08-20 17:18:48 +02:00
Comment : : OnCommentAdded . connect ( boost : : bind ( & DbEvents : : AddCommentHistory , _1 ) ) ;
Downtime : : OnDowntimeAdded . connect ( boost : : bind ( & DbEvents : : AddDowntimeHistory , _1 ) ) ;
2015-02-07 23:24:16 +01:00
Checkable : : OnAcknowledgementSet . connect ( boost : : bind ( & DbEvents : : AddAcknowledgementHistory , _1 , _2 , _3 , _4 , _5 , _6 ) ) ;
2014-04-03 15:36:13 +02:00
2014-05-10 16:52:48 +02:00
Checkable : : OnNotificationSentToAllUsers . connect ( boost : : bind ( & DbEvents : : AddNotificationHistory , _1 , _2 , _3 , _4 , _5 , _6 , _7 ) ) ;
2014-04-03 15:36:13 +02:00
2014-05-02 23:38:37 +02:00
Checkable : : OnStateChange . connect ( boost : : bind ( & DbEvents : : AddStateChangeHistory , _1 , _2 , _3 ) ) ;
2014-04-03 15:36:13 +02:00
2014-05-10 16:52:48 +02:00
Checkable : : OnNewCheckResult . connect ( boost : : bind ( & DbEvents : : AddCheckResultLogHistory , _1 , _2 ) ) ;
Checkable : : OnNotificationSentToUser . connect ( boost : : bind ( & DbEvents : : AddNotificationSentLogHistory , _1 , _2 , _3 , _4 , _5 , _6 , _7 ) ) ;
2015-08-04 14:47:44 +02:00
Checkable : : OnFlappingChanged . connect ( boost : : bind ( & DbEvents : : AddFlappingChangedLogHistory , _1 ) ) ;
Checkable : : OnEnableFlappingChanged . connect ( boost : : bind ( & DbEvents : : AddEnableFlappingChangedLogHistory , _1 ) ) ;
2015-08-20 17:18:48 +02:00
Downtime : : OnDowntimeTriggered . connect ( boost : : bind ( & DbEvents : : AddTriggerDowntimeLogHistory , _1 ) ) ;
Downtime : : OnDowntimeRemoved . connect ( boost : : bind ( & DbEvents : : AddRemoveDowntimeLogHistory , _1 ) ) ;
2014-04-03 15:36:13 +02:00
2015-08-04 14:47:44 +02:00
Checkable : : OnFlappingChanged . connect ( boost : : bind ( & DbEvents : : AddFlappingChangedHistory , _1 ) ) ;
Checkable : : OnEnableFlappingChanged . connect ( boost : : bind ( & DbEvents : : AddEnableFlappingChangedHistory , _1 ) ) ;
2015-04-24 17:41:07 +02:00
Checkable : : OnNewCheckResult . connect ( boost : : bind ( & DbEvents : : AddCheckableCheckHistory , _1 , _2 ) ) ;
2014-04-03 15:36:13 +02:00
2014-05-10 16:52:48 +02:00
Checkable : : OnEventCommandExecuted . connect ( boost : : bind ( & DbEvents : : AddEventHandlerHistory , _1 ) ) ;
2014-04-03 15:36:13 +02:00
ExternalCommandProcessor : : OnNewExternalCommand . connect ( boost : : bind ( & DbEvents : : AddExternalCommandHistory , _1 , _2 , _3 ) ) ;
}
2014-05-02 23:38:37 +02:00
/* check events */
2016-01-22 18:42:15 +01:00
void DbEvents : : NextCheckUpdatedHandler ( const Checkable : : Ptr & checkable )
2014-05-02 23:38:37 +02:00
{
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-10 15:24:28 +01:00
query1 . Type = DbQueryUpdate ;
2014-11-10 13:21:33 +01:00
query1 . Category = DbCatState ;
2014-11-11 16:35:58 +01:00
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-02 23:38:37 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2015-08-04 14:47:44 +02:00
fields1 - > Set ( " next_check " , DbValue : : FromTimestamp ( checkable - > GetNextCheck ( ) ) ) ;
2014-05-02 23:38:37 +02:00
query1 . Fields = fields1 ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-05-02 23:38:37 +02:00
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
2014-05-02 23:49:52 +02:00
DbObject : : OnQuery ( query1 ) ;
}
2015-08-04 14:47:44 +02:00
void DbEvents : : FlappingChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-02 23:49:52 +02:00
{
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-10 15:24:28 +01:00
query1 . Type = DbQueryUpdate ;
2014-11-10 13:21:33 +01:00
query1 . Category = DbCatState ;
2014-11-11 16:35:58 +01:00
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-02 23:49:52 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-05-02 23:49:52 +02:00
fields1 - > Set ( " is_flapping " , CompatUtility : : GetCheckableIsFlapping ( checkable ) ) ;
fields1 - > Set ( " percent_state_change " , CompatUtility : : GetCheckablePercentStateChange ( checkable ) ) ;
query1 . Fields = fields1 ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-05-02 23:49:52 +02:00
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2014-05-03 00:16:53 +02:00
DbObject : : OnQuery ( query1 ) ;
}
void DbEvents : : LastNotificationChangedHandler ( const Notification : : Ptr & notification , const Checkable : : Ptr & checkable )
{
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > now_bag = CompatUtility : : ConvertTimestamp ( now ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( notification - > GetNextNotification ( ) ) ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-10 15:24:28 +01:00
query1 . Type = DbQueryUpdate ;
2014-11-10 13:21:33 +01:00
query1 . Category = DbCatState ;
2014-11-11 16:35:58 +01:00
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-03 00:16:53 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-05-03 00:16:53 +02:00
fields1 - > Set ( " last_notification " , DbValue : : FromTimestamp ( now_bag . first ) ) ;
fields1 - > Set ( " next_notification " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " current_notification_number " , notification - > GetNotificationNumber ( ) ) ;
query1 . Fields = fields1 ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-05-03 00:16:53 +02:00
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2014-05-02 23:38:37 +02:00
DbObject : : OnQuery ( query1 ) ;
}
2014-12-12 15:53:10 +01:00
void DbEvents : : ReachabilityChangedHandler ( const Checkable : : Ptr & checkable , const CheckResult : : Ptr & cr , std : : set < Checkable : : Ptr > children )
{
int is_reachable = 0 ;
if ( cr - > GetState ( ) = = ServiceOK )
is_reachable = 1 ;
Log ( LogDebug , " DbEvents " )
< < " Updating reachability for checkable ' " < < checkable - > GetName ( ) < < " ': " < < ( is_reachable ? " " : " not " ) < < " reachable for " < < children . size ( ) < < " children. " ;
2016-08-25 06:19:44 +02:00
for ( const Checkable : : Ptr & child : children ) {
2014-12-12 15:53:10 +01:00
Log ( LogDebug , " DbEvents " )
< < " Updating reachability for checkable ' " < < child - > GetName ( ) < < " ': " < < ( is_reachable ? " " : " not " ) < < " reachable. " ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( child ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-10 15:24:28 +01:00
query1 . Type = DbQueryUpdate ;
2014-12-12 15:53:10 +01:00
query1 . Category = DbCatState ;
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( child ) ;
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
fields1 - > Set ( " is_reachable " , is_reachable ) ;
query1 . Fields = fields1 ;
query1 . WhereCriteria = new Dictionary ( ) ;
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
DbObject : : OnQuery ( query1 ) ;
}
}
2014-05-10 16:52:48 +02:00
/* enable changed events */
2015-08-04 14:47:44 +02:00
void DbEvents : : EnableActiveChecksChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-10 16:52:48 +02:00
{
2015-08-04 14:47:44 +02:00
EnableChangedHandlerInternal ( checkable , " active_checks_enabled " , checkable - > GetEnableActiveChecks ( ) ) ;
2014-05-10 16:52:48 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : EnablePassiveChecksChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-10 16:52:48 +02:00
{
2015-08-04 14:47:44 +02:00
EnableChangedHandlerInternal ( checkable , " passive_checks_enabled " , checkable - > GetEnablePassiveChecks ( ) ) ;
2014-05-10 16:52:48 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : EnableNotificationsChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-10 16:52:48 +02:00
{
2015-08-04 14:47:44 +02:00
EnableChangedHandlerInternal ( checkable , " notifications_enabled " , checkable - > GetEnableNotifications ( ) ) ;
2014-05-10 16:52:48 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : EnablePerfdataChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-10 16:52:48 +02:00
{
2015-08-04 14:47:44 +02:00
EnableChangedHandlerInternal ( checkable , " process_performance_data " , checkable - > GetEnablePerfdata ( ) ) ;
2014-05-10 16:52:48 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : EnableFlappingChangedHandler ( const Checkable : : Ptr & checkable )
2014-05-10 16:52:48 +02:00
{
2015-08-04 14:47:44 +02:00
EnableChangedHandlerInternal ( checkable , " flap_detection_enabled " , checkable - > GetEnableFlapping ( ) ) ;
2014-05-10 16:52:48 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : EnableChangedHandlerInternal ( const Checkable : : Ptr & checkable , const String & fieldName , bool enabled )
2014-05-10 16:52:48 +02:00
{
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-10 15:24:28 +01:00
query1 . Type = DbQueryUpdate ;
2014-11-10 13:21:33 +01:00
query1 . Category = DbCatState ;
2014-11-11 16:35:58 +01:00
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-10 16:52:48 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2015-08-04 14:47:44 +02:00
fields1 - > Set ( fieldName , enabled ) ;
2014-05-10 16:52:48 +02:00
query1 . Fields = fields1 ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-05-10 16:52:48 +02:00
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
DbObject : : OnQuery ( query1 ) ;
}
2015-08-04 14:47:44 +02:00
2014-04-03 15:36:13 +02:00
/* comments */
void DbEvents : : AddComments ( const Checkable : : Ptr & checkable )
{
2015-10-29 16:12:53 +01:00
std : : set < Comment : : Ptr > comments = checkable - > GetComments ( ) ;
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
2016-08-25 06:19:44 +02:00
for ( const Comment : : Ptr & comment : comments ) {
2015-12-14 11:36:03 +01:00
AddCommentInternal ( queries , comment , false ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-08-20 17:18:48 +02:00
void DbEvents : : AddComment ( const Comment : : Ptr & comment )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
AddCommentInternal ( queries , comment , false ) ;
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-08-20 17:18:48 +02:00
void DbEvents : : AddCommentHistory ( const Comment : : Ptr & comment )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
AddCommentInternal ( queries , comment , true ) ;
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : AddCommentInternal ( std : : vector < DbQuery > & queries , const Comment : : Ptr & comment , bool historical )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = comment - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
unsigned long entry_time = static_cast < long > ( comment - > GetEntryTime ( ) ) ;
unsigned long entry_time_usec = ( comment - > GetEntryTime ( ) - entry_time ) * 1000 * 1000 ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " entry_time " , DbValue : : FromTimestamp ( entry_time ) ) ;
fields1 - > Set ( " entry_time_usec " , entry_time_usec ) ;
fields1 - > Set ( " entry_type " , comment - > GetEntryType ( ) ) ;
2015-08-20 17:18:48 +02:00
fields1 - > Set ( " object_id " , checkable ) ;
2014-04-03 15:36:13 +02:00
2016-08-16 11:02:10 +02:00
if ( checkable - > GetReflectionType ( ) = = Host : : TypeInstance ) {
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " comment_type " , 2 ) ;
/* requires idoutils 1.10 schema fix */
fields1 - > Set ( " internal_comment_id " , comment - > GetLegacyId ( ) ) ;
2016-08-16 11:02:10 +02:00
} else if ( checkable - > GetReflectionType ( ) = = Service : : TypeInstance ) {
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " comment_type " , 1 ) ;
fields1 - > Set ( " internal_comment_id " , comment - > GetLegacyId ( ) ) ;
} else {
2014-05-28 14:34:26 +02:00
Log ( LogDebug , " DbEvents " , " unknown object type for adding comment. " ) ;
2014-04-03 15:36:13 +02:00
return ;
}
2015-11-06 16:45:09 +01:00
fields1 - > Set ( " name " , comment - > GetName ( ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " comment_time " , DbValue : : FromTimestamp ( entry_time ) ) ; /* same as entry_time */
fields1 - > Set ( " author_name " , comment - > GetAuthor ( ) ) ;
fields1 - > Set ( " comment_data " , comment - > GetText ( ) ) ;
2017-01-25 21:21:22 +01:00
fields1 - > Set ( " is_persistent " , comment - > GetPersistent ( ) ? 1 : 0 ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " comment_source " , 1 ) ; /* external */
fields1 - > Set ( " expires " , ( comment - > GetExpireTime ( ) > 0 ) ? 1 : 0 ) ;
fields1 - > Set ( " expiration_time " , DbValue : : FromTimestamp ( comment - > GetExpireTime ( ) ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
DbQuery query1 ;
if ( ! historical ) {
query1 . Table = " comments " ;
2016-08-01 17:54:03 +02:00
query1 . Type = DbQueryInsert | DbQueryUpdate ;
fields1 - > Set ( " session_token " , 0 ) ; /* DbConnection class fills in real ID */
query1 . WhereCriteria = new Dictionary ( ) ;
query1 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2017-11-06 10:59:44 +01:00
query1 . WhereCriteria - > Set ( " name " , comment - > GetName ( ) ) ;
2017-11-07 16:32:50 +01:00
query1 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( entry_time ) ) ;
2014-04-03 15:36:13 +02:00
} else {
query1 . Table = " commenthistory " ;
2016-08-01 17:54:03 +02:00
query1 . Type = DbQueryInsert ;
2014-04-03 15:36:13 +02:00
}
query1 . Category = DbCatComment ;
query1 . Fields = fields1 ;
2015-12-14 11:36:03 +01:00
queries . push_back ( query1 ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : RemoveComment ( const Comment : : Ptr & comment )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
RemoveCommentInternal ( queries , comment ) ;
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : RemoveCommentInternal ( std : : vector < DbQuery > & queries , const Comment : : Ptr & comment )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = comment - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
2016-06-20 17:38:01 +02:00
unsigned long entry_time = static_cast < long > ( comment - > GetEntryTime ( ) ) ;
2014-04-03 15:36:13 +02:00
/* Status */
DbQuery query1 ;
query1 . Table = " comments " ;
query1 . Type = DbQueryDelete ;
query1 . Category = DbCatComment ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2016-06-20 17:38:01 +02:00
query1 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2017-08-10 16:42:02 +02:00
query1 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( entry_time ) ) ;
2017-09-19 13:14:57 +02:00
query1 . WhereCriteria - > Set ( " name " , comment - > GetName ( ) ) ;
2015-12-18 10:52:04 +01:00
queries . push_back ( query1 ) ;
2014-04-03 15:36:13 +02:00
/* History - update deletion time for service/host */
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query2 ;
query2 . Table = " commenthistory " ;
query2 . Type = DbQueryUpdate ;
query2 . Category = DbCatComment ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields2 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields2 - > Set ( " deletion_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields2 - > Set ( " deletion_time_usec " , time_bag . second ) ;
query2 . Fields = fields2 ;
2014-11-08 21:17:16 +01:00
query2 . WhereCriteria = new Dictionary ( ) ;
2015-12-14 11:36:03 +01:00
query2 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2017-08-10 16:42:02 +02:00
query2 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( entry_time ) ) ;
2017-09-19 13:14:57 +02:00
query2 . WhereCriteria - > Set ( " name " , comment - > GetName ( ) ) ;
2015-12-18 10:52:04 +01:00
queries . push_back ( query2 ) ;
2014-04-03 15:36:13 +02:00
}
/* downtimes */
void DbEvents : : AddDowntimes ( const Checkable : : Ptr & checkable )
{
2015-10-29 16:12:53 +01:00
std : : set < Downtime : : Ptr > downtimes = checkable - > GetDowntimes ( ) ;
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
2016-08-25 06:19:44 +02:00
for ( const Downtime : : Ptr & downtime : downtimes ) {
2015-12-14 11:36:03 +01:00
AddDowntimeInternal ( queries , downtime , false ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : AddDowntime ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
AddDowntimeInternal ( queries , downtime , false ) ;
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : AddDowntimeHistory ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
2015-12-16 13:57:29 +01:00
AddDowntimeInternal ( queries , downtime , true ) ;
2015-12-14 11:36:03 +01:00
DbObject : : OnMultipleQueries ( queries ) ;
2015-02-07 19:37:12 +01:00
}
2014-04-03 15:36:13 +02:00
2015-12-14 11:36:03 +01:00
void DbEvents : : AddDowntimeInternal ( std : : vector < DbQuery > & queries , const Downtime : : Ptr & downtime , bool historical )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = downtime - > GetCheckable ( ) ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " entry_time " , DbValue : : FromTimestamp ( downtime - > GetEntryTime ( ) ) ) ;
fields1 - > Set ( " object_id " , checkable ) ;
2016-08-16 11:02:10 +02:00
if ( checkable - > GetReflectionType ( ) = = Host : : TypeInstance ) {
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " downtime_type " , 2 ) ;
/* requires idoutils 1.10 schema fix */
fields1 - > Set ( " internal_downtime_id " , downtime - > GetLegacyId ( ) ) ;
2016-08-16 11:02:10 +02:00
} else if ( checkable - > GetReflectionType ( ) = = Service : : TypeInstance ) {
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " downtime_type " , 1 ) ;
fields1 - > Set ( " internal_downtime_id " , downtime - > GetLegacyId ( ) ) ;
} else {
2014-05-28 14:34:26 +02:00
Log ( LogDebug , " DbEvents " , " unknown object type for adding downtime. " ) ;
2014-04-03 15:36:13 +02:00
return ;
}
fields1 - > Set ( " author_name " , downtime - > GetAuthor ( ) ) ;
fields1 - > Set ( " comment_data " , downtime - > GetComment ( ) ) ;
2015-08-20 17:18:48 +02:00
fields1 - > Set ( " triggered_by_id " , Downtime : : GetByName ( downtime - > GetTriggeredBy ( ) ) ) ;
2015-04-25 15:06:29 +02:00
fields1 - > Set ( " is_fixed " , downtime - > GetFixed ( ) ? 1 : 0 ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " duration " , downtime - > GetDuration ( ) ) ;
fields1 - > Set ( " scheduled_start_time " , DbValue : : FromTimestamp ( downtime - > GetStartTime ( ) ) ) ;
fields1 - > Set ( " scheduled_end_time " , DbValue : : FromTimestamp ( downtime - > GetEndTime ( ) ) ) ;
2017-09-19 13:14:57 +02:00
fields1 - > Set ( " name " , downtime - > GetName ( ) ) ;
2016-08-11 12:10:04 +02:00
/* flexible downtimes are started at trigger time */
if ( downtime - > GetFixed ( ) ) {
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( downtime - > GetStartTime ( ) ) ;
fields1 - > Set ( " actual_start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " actual_start_time_usec " , time_bag . second ) ;
fields1 - > Set ( " was_started " , ( ( downtime - > GetStartTime ( ) < = Utility : : GetTime ( ) ) ? 1 : 0 ) ) ;
}
2016-05-02 15:32:46 +02:00
fields1 - > Set ( " is_in_effect " , ( downtime - > IsInEffect ( ) ? 1 : 0 ) ) ;
2016-03-23 13:42:00 +01:00
fields1 - > Set ( " trigger_time " , DbValue : : FromTimestamp ( downtime - > GetTriggerTime ( ) ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
DbQuery query1 ;
2016-08-01 17:54:03 +02:00
if ( ! historical ) {
2014-04-03 15:36:13 +02:00
query1 . Table = " scheduleddowntime " ;
2016-08-01 17:54:03 +02:00
query1 . Type = DbQueryInsert | DbQueryUpdate ;
fields1 - > Set ( " session_token " , 0 ) ; /* DbConnection class fills in real ID */
query1 . WhereCriteria = new Dictionary ( ) ;
query1 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2017-11-06 10:59:44 +01:00
query1 . WhereCriteria - > Set ( " name " , downtime - > GetName ( ) ) ;
2016-08-01 17:54:03 +02:00
query1 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( downtime - > GetEntryTime ( ) ) ) ;
} else {
2014-04-03 15:36:13 +02:00
query1 . Table = " downtimehistory " ;
2016-08-01 17:54:03 +02:00
query1 . Type = DbQueryInsert ;
}
2014-04-03 15:36:13 +02:00
query1 . Category = DbCatDowntime ;
query1 . Fields = fields1 ;
2015-12-14 11:36:03 +01:00
queries . push_back ( query1 ) ;
2016-03-23 13:42:00 +01:00
/* host/service status */
if ( ! historical ) {
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query2 ;
if ( service )
query2 . Table = " servicestatus " ;
else
query2 . Table = " hoststatus " ;
query2 . Type = DbQueryUpdate ;
query2 . Category = DbCatState ;
query2 . StatusUpdate = true ;
query2 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
Dictionary : : Ptr fields2 = new Dictionary ( ) ;
fields2 - > Set ( " scheduled_downtime_depth " , checkable - > GetDowntimeDepth ( ) ) ;
query2 . Fields = fields2 ;
query2 . WhereCriteria = new Dictionary ( ) ;
if ( service )
query2 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query2 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query2 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
queries . push_back ( query2 ) ;
}
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : RemoveDowntime ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-12-14 11:36:03 +01:00
std : : vector < DbQuery > queries ;
RemoveDowntimeInternal ( queries , downtime ) ;
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
2015-12-14 11:36:03 +01:00
void DbEvents : : RemoveDowntimeInternal ( std : : vector < DbQuery > & queries , const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = downtime - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
/* Status */
DbQuery query1 ;
query1 . Table = " scheduleddowntime " ;
query1 . Type = DbQueryDelete ;
query1 . Category = DbCatDowntime ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2017-08-09 17:41:43 +02:00
2014-04-03 15:36:13 +02:00
query1 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2016-06-20 17:38:01 +02:00
query1 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( downtime - > GetEntryTime ( ) ) ) ;
2015-10-28 17:12:23 +01:00
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2017-09-19 13:14:57 +02:00
query1 . WhereCriteria - > Set ( " scheduled_start_time " , DbValue : : FromTimestamp ( downtime - > GetStartTime ( ) ) ) ;
query1 . WhereCriteria - > Set ( " scheduled_end_time " , DbValue : : FromTimestamp ( downtime - > GetEndTime ( ) ) ) ;
query1 . WhereCriteria - > Set ( " name " , downtime - > GetName ( ) ) ;
2015-12-14 11:36:03 +01:00
queries . push_back ( query1 ) ;
2014-04-03 15:36:13 +02:00
/* History - update actual_end_time, was_cancelled for service (and host in case) */
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query3 ;
query3 . Table = " downtimehistory " ;
query3 . Type = DbQueryUpdate ;
query3 . Category = DbCatDowntime ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields3 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields3 - > Set ( " was_cancelled " , downtime - > GetWasCancelled ( ) ? 1 : 0 ) ;
2017-02-24 15:29:39 +01:00
if ( downtime - > GetFixed ( ) | | ( ! downtime - > GetFixed ( ) & & downtime - > GetTriggerTime ( ) > 0 ) ) {
fields3 - > Set ( " actual_end_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields3 - > Set ( " actual_end_time_usec " , time_bag . second ) ;
}
2016-03-23 13:42:00 +01:00
fields3 - > Set ( " is_in_effect " , 0 ) ;
2014-04-03 15:36:13 +02:00
query3 . Fields = fields3 ;
2014-11-08 21:17:16 +01:00
query3 . WhereCriteria = new Dictionary ( ) ;
2015-10-28 17:12:23 +01:00
query3 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2014-04-03 15:36:13 +02:00
query3 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( downtime - > GetEntryTime ( ) ) ) ;
query3 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2017-09-19 13:14:57 +02:00
query3 . WhereCriteria - > Set ( " scheduled_start_time " , DbValue : : FromTimestamp ( downtime - > GetStartTime ( ) ) ) ;
query3 . WhereCriteria - > Set ( " scheduled_end_time " , DbValue : : FromTimestamp ( downtime - > GetEndTime ( ) ) ) ;
query3 . WhereCriteria - > Set ( " name " , downtime - > GetName ( ) ) ;
2014-04-03 15:36:13 +02:00
2015-12-14 11:36:03 +01:00
queries . push_back ( query3 ) ;
2015-04-11 11:40:14 +02:00
/* host/service status */
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query4 ;
if ( service )
query4 . Table = " servicestatus " ;
else
query4 . Table = " hoststatus " ;
2015-12-14 11:36:03 +01:00
query4 . Type = DbQueryUpdate ;
2015-04-11 11:40:14 +02:00
query4 . Category = DbCatState ;
query4 . StatusUpdate = true ;
query4 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
Dictionary : : Ptr fields4 = new Dictionary ( ) ;
fields4 - > Set ( " scheduled_downtime_depth " , checkable - > GetDowntimeDepth ( ) ) ;
query4 . Fields = fields4 ;
query4 . WhereCriteria = new Dictionary ( ) ;
if ( service )
query4 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query4 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query4 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2015-12-14 11:36:03 +01:00
queries . push_back ( query4 ) ;
2014-04-03 15:36:13 +02:00
}
2015-08-20 17:18:48 +02:00
void DbEvents : : TriggerDowntime ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = downtime - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
/* Status */
DbQuery query1 ;
query1 . Table = " scheduleddowntime " ;
query1 . Type = DbQueryUpdate ;
query1 . Category = DbCatDowntime ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " was_started " , 1 ) ;
fields1 - > Set ( " actual_start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " actual_start_time_usec " , time_bag . second ) ;
2016-05-02 15:32:46 +02:00
fields1 - > Set ( " is_in_effect " , ( downtime - > IsInEffect ( ) ? 1 : 0 ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " trigger_time " , DbValue : : FromTimestamp ( downtime - > GetTriggerTime ( ) ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
query1 . WhereCriteria - > Set ( " object_id " , checkable ) ;
2017-09-19 13:14:57 +02:00
query1 . WhereCriteria - > Set ( " entry_time " , DbValue : : FromTimestamp ( downtime - > GetEntryTime ( ) ) ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
query1 . WhereCriteria - > Set ( " scheduled_start_time " , DbValue : : FromTimestamp ( downtime - > GetStartTime ( ) ) ) ;
query1 . WhereCriteria - > Set ( " scheduled_end_time " , DbValue : : FromTimestamp ( downtime - > GetEndTime ( ) ) ) ;
query1 . WhereCriteria - > Set ( " name " , downtime - > GetName ( ) ) ;
2014-04-03 15:36:13 +02:00
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
/* History - downtime was started for service (and host in case) */
DbQuery query3 ;
query3 . Table = " downtimehistory " ;
query3 . Type = DbQueryUpdate ;
query3 . Category = DbCatDowntime ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields3 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields3 - > Set ( " was_started " , 1 ) ;
fields3 - > Set ( " is_in_effect " , 1 ) ;
fields3 - > Set ( " actual_start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields3 - > Set ( " actual_start_time_usec " , time_bag . second ) ;
fields3 - > Set ( " trigger_time " , DbValue : : FromTimestamp ( downtime - > GetTriggerTime ( ) ) ) ;
query3 . Fields = fields3 ;
2017-09-19 13:14:57 +02:00
query3 . WhereCriteria = query1 . WhereCriteria ;
2014-04-03 15:36:13 +02:00
DbObject : : OnQuery ( query3 ) ;
2014-05-03 00:37:47 +02:00
/* host/service status */
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query4 ;
if ( service )
query4 . Table = " servicestatus " ;
else
query4 . Table = " hoststatus " ;
2015-12-14 11:36:03 +01:00
query4 . Type = DbQueryUpdate ;
2014-11-11 16:35:58 +01:00
query4 . Category = DbCatState ;
query4 . StatusUpdate = true ;
query4 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-03 00:37:47 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields4 = new Dictionary ( ) ;
2014-05-03 00:37:47 +02:00
fields4 - > Set ( " scheduled_downtime_depth " , checkable - > GetDowntimeDepth ( ) ) ;
query4 . Fields = fields4 ;
2014-11-08 21:17:16 +01:00
query4 . WhereCriteria = new Dictionary ( ) ;
2014-05-03 00:37:47 +02:00
if ( service )
query4 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query4 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query4 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
DbObject : : OnQuery ( query4 ) ;
2014-04-03 15:36:13 +02:00
}
/* acknowledgements */
void DbEvents : : AddAcknowledgementHistory ( const Checkable : : Ptr & checkable , const String & author , const String & comment ,
2015-02-07 23:24:16 +01:00
AcknowledgementType type , bool notify , double expiry )
2014-04-03 15:36:13 +02:00
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add acknowledgement history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
unsigned long end_time = static_cast < long > ( expiry ) ;
DbQuery query1 ;
query1 . Table = " acknowledgements " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatAcknowledgement ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " entry_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " entry_time_usec " , time_bag . second ) ;
fields1 - > Set ( " acknowledgement_type " , type ) ;
fields1 - > Set ( " object_id " , checkable ) ;
fields1 - > Set ( " author_name " , author ) ;
fields1 - > Set ( " comment_data " , comment ) ;
2015-02-07 23:24:16 +01:00
fields1 - > Set ( " persistent_comment " , 1 ) ; //always persistent
fields1 - > Set ( " notify_contacts " , notify ? 1 : 0 ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " is_sticky " , type = = AcknowledgementSticky ? 1 : 0 ) ;
fields1 - > Set ( " end_time " , DbValue : : FromTimestamp ( end_time ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
2017-08-07 10:58:52 +02:00
if ( service ) {
fields1 - > Set ( " state " , service - > GetState ( ) ) ;
} else {
fields1 - > Set ( " state " , CompatUtility : : GetHostCurrentState ( host ) ) ;
}
2014-04-03 15:36:13 +02:00
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
2014-05-02 23:17:36 +02:00
void DbEvents : : AddAcknowledgement ( const Checkable : : Ptr & checkable , AcknowledgementType type )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add acknowledgement for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-05-02 23:17:36 +02:00
AddAcknowledgementInternal ( checkable , type , true ) ;
}
void DbEvents : : RemoveAcknowledgement ( const Checkable : : Ptr & checkable )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " remove acknowledgement for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-05-02 23:17:36 +02:00
AddAcknowledgementInternal ( checkable , AcknowledgementNone , false ) ;
}
void DbEvents : : AddAcknowledgementInternal ( const Checkable : : Ptr & checkable , AcknowledgementType type , bool add )
{
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
DbQuery query1 ;
if ( service )
query1 . Table = " servicestatus " ;
else
query1 . Table = " hoststatus " ;
2015-12-14 11:36:03 +01:00
query1 . Type = DbQueryUpdate ;
2014-11-11 16:35:58 +01:00
query1 . Category = DbCatState ;
query1 . StatusUpdate = true ;
query1 . Object = DbObject : : GetOrCreateByObject ( checkable ) ;
2014-05-02 23:17:36 +02:00
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-05-02 23:17:36 +02:00
fields1 - > Set ( " acknowledgement_type " , type ) ;
fields1 - > Set ( " problem_has_been_acknowledged " , add ? 1 : 0 ) ;
query1 . Fields = fields1 ;
2014-11-08 21:17:16 +01:00
query1 . WhereCriteria = new Dictionary ( ) ;
2014-05-02 23:17:36 +02:00
if ( service )
query1 . WhereCriteria - > Set ( " service_object_id " , service ) ;
else
query1 . WhereCriteria - > Set ( " host_object_id " , host ) ;
query1 . WhereCriteria - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
DbObject : : OnQuery ( query1 ) ;
}
2014-04-03 15:36:13 +02:00
/* notifications */
void DbEvents : : AddNotificationHistory ( const Notification : : Ptr & notification , const Checkable : : Ptr & checkable , const std : : set < User : : Ptr > & users , NotificationType type ,
const CheckResult : : Ptr & cr , const String & author , const String & text )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add notification history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
/* start and end happen at the same time */
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query1 ;
query1 . Table = " notifications " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatNotification ;
2016-03-21 13:37:32 +01:00
query1 . NotificationInsertID = new DbValue ( DbValueObjectInsertID , - 1 ) ;
2014-04-03 15:36:13 +02:00
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " notification_type " , 1 ) ; /* service */
fields1 - > Set ( " notification_reason " , CompatUtility : : MapNotificationReasonType ( type ) ) ;
fields1 - > Set ( " object_id " , checkable ) ;
fields1 - > Set ( " start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " start_time_usec " , time_bag . second ) ;
fields1 - > Set ( " end_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " end_time_usec " , time_bag . second ) ;
2017-08-07 10:58:52 +02:00
if ( service ) {
fields1 - > Set ( " state " , service - > GetState ( ) ) ;
} else {
fields1 - > Set ( " state " , CompatUtility : : GetHostCurrentState ( host ) ) ;
}
2014-04-03 15:36:13 +02:00
if ( cr ) {
fields1 - > Set ( " output " , CompatUtility : : GetCheckResultOutput ( cr ) ) ;
fields1 - > Set ( " long_output " , CompatUtility : : GetCheckResultLongOutput ( cr ) ) ;
}
fields1 - > Set ( " escalated " , 0 ) ;
fields1 - > Set ( " contacts_notified " , static_cast < long > ( users . size ( ) ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
2016-03-21 13:37:32 +01:00
std : : vector < DbQuery > queries ;
2014-04-03 15:36:13 +02:00
2016-08-25 06:19:44 +02:00
for ( const User : : Ptr & user : users ) {
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add contact notification history for service ' " < < checkable - > GetName ( ) < < " ' and user ' " < < user - > GetName ( ) < < " '. " ;
2014-04-03 15:36:13 +02:00
2016-03-21 13:37:32 +01:00
DbQuery query2 ;
query2 . Table = " contactnotifications " ;
query2 . Type = DbQueryInsert ;
query2 . Category = DbCatNotification ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields2 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields2 - > Set ( " contact_object_id " , user ) ;
fields2 - > Set ( " start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields2 - > Set ( " start_time_usec " , time_bag . second ) ;
fields2 - > Set ( " end_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields2 - > Set ( " end_time_usec " , time_bag . second ) ;
2016-03-21 13:37:32 +01:00
fields2 - > Set ( " notification_id " , query1 . NotificationInsertID ) ;
2014-04-03 15:36:13 +02:00
fields2 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
query2 . Fields = fields2 ;
2016-03-21 13:37:32 +01:00
queries . push_back ( query2 ) ;
2014-04-03 15:36:13 +02:00
}
2016-03-21 13:37:32 +01:00
DbObject : : OnMultipleQueries ( queries ) ;
2014-04-03 15:36:13 +02:00
}
/* statehistory */
void DbEvents : : AddStateChangeHistory ( const Checkable : : Ptr & checkable , const CheckResult : : Ptr & cr , StateType type )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add state change history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
2015-04-24 17:41:07 +02:00
double ts = cr - > GetExecutionEnd ( ) ;
std : : pair < unsigned long , unsigned long > state_time_bag = CompatUtility : : ConvertTimestamp ( ts ) ;
2014-04-03 15:36:13 +02:00
DbQuery query1 ;
query1 . Table = " statehistory " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatStateHistory ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2015-04-24 17:41:07 +02:00
fields1 - > Set ( " state_time " , DbValue : : FromTimestamp ( state_time_bag . first ) ) ;
fields1 - > Set ( " state_time_usec " , state_time_bag . second ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " object_id " , checkable ) ;
fields1 - > Set ( " state_change " , 1 ) ; /* service */
fields1 - > Set ( " state_type " , checkable - > GetStateType ( ) ) ;
fields1 - > Set ( " current_check_attempt " , checkable - > GetCheckAttempt ( ) ) ;
fields1 - > Set ( " max_check_attempts " , checkable - > GetMaxCheckAttempts ( ) ) ;
if ( service ) {
2017-08-07 10:58:52 +02:00
fields1 - > Set ( " state " , service - > GetState ( ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " last_state " , service - > GetLastState ( ) ) ;
fields1 - > Set ( " last_hard_state " , service - > GetLastHardState ( ) ) ;
} else {
2017-08-07 10:58:52 +02:00
fields1 - > Set ( " state " , CompatUtility : : GetHostCurrentState ( host ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " last_state " , host - > GetLastState ( ) ) ;
fields1 - > Set ( " last_hard_state " , host - > GetLastHardState ( ) ) ;
}
if ( cr ) {
fields1 - > Set ( " output " , CompatUtility : : GetCheckResultOutput ( cr ) ) ;
fields1 - > Set ( " long_output " , CompatUtility : : GetCheckResultLongOutput ( cr ) ) ;
fields1 - > Set ( " check_source " , cr - > GetCheckSource ( ) ) ;
}
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
/* logentries */
void DbEvents : : AddCheckResultLogHistory ( const Checkable : : Ptr & checkable , const CheckResult : : Ptr & cr )
{
Dictionary : : Ptr vars_after = cr - > GetVarsAfter ( ) ;
long state_after = vars_after - > Get ( " state " ) ;
long stateType_after = vars_after - > Get ( " state_type " ) ;
long attempt_after = vars_after - > Get ( " attempt " ) ;
bool reachable_after = vars_after - > Get ( " reachable " ) ;
Dictionary : : Ptr vars_before = cr - > GetVarsBefore ( ) ;
if ( vars_before ) {
long state_before = vars_before - > Get ( " state " ) ;
long stateType_before = vars_before - > Get ( " state_type " ) ;
long attempt_before = vars_before - > Get ( " attempt " ) ;
bool reachable_before = vars_before - > Get ( " reachable " ) ;
if ( state_before = = state_after & & stateType_before = = stateType_after & &
attempt_before = = attempt_after & & reachable_before = = reachable_after )
return ; /* Nothing changed, ignore this checkresult. */
}
LogEntryType type ;
String output ;
if ( cr )
output = CompatUtility : : GetCheckResultOutput ( cr ) ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
if ( service ) {
msgbuf < < " SERVICE ALERT: "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
2015-09-04 13:24:41 +02:00
< < Service : : StateToString ( service - > GetState ( ) ) < < " ; "
< < Service : : StateTypeToString ( service - > GetStateType ( ) ) < < " ; "
2014-04-03 15:36:13 +02:00
< < attempt_after < < " ; "
< < output < < " "
< < " " ;
switch ( service - > GetState ( ) ) {
2014-04-08 09:11:54 +02:00
case ServiceOK :
2014-04-03 15:36:13 +02:00
type = LogEntryTypeServiceOk ;
break ;
2014-04-08 09:11:54 +02:00
case ServiceUnknown :
2014-04-03 15:36:13 +02:00
type = LogEntryTypeServiceUnknown ;
break ;
2014-04-08 09:11:54 +02:00
case ServiceWarning :
2014-04-03 15:36:13 +02:00
type = LogEntryTypeServiceWarning ;
break ;
2014-04-08 09:11:54 +02:00
case ServiceCritical :
2014-04-03 15:36:13 +02:00
type = LogEntryTypeServiceCritical ;
break ;
default :
2014-10-19 17:52:17 +02:00
Log ( LogCritical , " DbEvents " )
< < " Unknown service state: " < < state_after ;
2014-04-03 15:36:13 +02:00
return ;
}
} else {
msgbuf < < " HOST ALERT: "
< < host - > GetName ( ) < < " ; "
2015-09-04 13:24:41 +02:00
< < CompatUtility : : GetHostStateString ( host ) < < " ; "
< < Host : : StateTypeToString ( host - > GetStateType ( ) ) < < " ; "
2014-04-03 15:36:13 +02:00
< < attempt_after < < " ; "
< < output < < " "
< < " " ;
switch ( host - > GetState ( ) ) {
case HostUp :
type = LogEntryTypeHostUp ;
break ;
case HostDown :
type = LogEntryTypeHostDown ;
break ;
default :
2014-10-19 17:52:17 +02:00
Log ( LogCritical , " DbEvents " )
< < " Unknown host state: " < < state_after ;
2014-04-03 15:36:13 +02:00
return ;
}
2014-04-08 08:54:49 +02:00
if ( ! reachable_after )
type = LogEntryTypeHostUnreachable ;
2014-04-03 15:36:13 +02:00
}
AddLogHistory ( checkable , msgbuf . str ( ) , type ) ;
}
2015-08-20 17:18:48 +02:00
void DbEvents : : AddTriggerDowntimeLogHistory ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = downtime - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
if ( service ) {
msgbuf < < " SERVICE DOWNTIME ALERT: "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
< < " STARTED " < < " ; "
< < " Service has entered a period of scheduled downtime. "
< < " " ;
} else {
msgbuf < < " HOST DOWNTIME ALERT: "
< < host - > GetName ( ) < < " ; "
< < " STARTED " < < " ; "
< < " Service has entered a period of scheduled downtime. "
< < " " ;
}
AddLogHistory ( checkable , msgbuf . str ( ) , LogEntryTypeInfoMessage ) ;
}
2015-08-20 17:18:48 +02:00
void DbEvents : : AddRemoveDowntimeLogHistory ( const Downtime : : Ptr & downtime )
2014-04-03 15:36:13 +02:00
{
2015-08-20 17:18:48 +02:00
Checkable : : Ptr checkable = downtime - > GetCheckable ( ) ;
2014-04-03 15:36:13 +02:00
String downtime_output ;
String downtime_state_str ;
if ( downtime - > GetWasCancelled ( ) ) {
downtime_output = " Scheduled downtime for service has been cancelled. " ;
downtime_state_str = " CANCELLED " ;
} else {
downtime_output = " Service has exited from a period of scheduled downtime. " ;
downtime_state_str = " STOPPED " ;
}
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
if ( service ) {
msgbuf < < " SERVICE DOWNTIME ALERT: "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
< < downtime_state_str < < " ; "
< < downtime_output
< < " " ;
} else {
msgbuf < < " HOST DOWNTIME ALERT: "
< < host - > GetName ( ) < < " ; "
< < downtime_state_str < < " ; "
< < downtime_output
< < " " ;
}
2014-04-06 18:17:52 +02:00
AddLogHistory ( checkable , msgbuf . str ( ) , LogEntryTypeInfoMessage ) ;
2014-04-03 15:36:13 +02:00
}
void DbEvents : : AddNotificationSentLogHistory ( const Notification : : Ptr & notification , const Checkable : : Ptr & checkable , const User : : Ptr & user ,
NotificationType notification_type , const CheckResult : : Ptr & cr ,
const String & author , const String & comment_text )
{
CheckCommand : : Ptr commandObj = checkable - > GetCheckCommand ( ) ;
String check_command = " " ;
if ( commandObj )
check_command = commandObj - > GetName ( ) ;
String notification_type_str = Notification : : NotificationTypeToString ( notification_type ) ;
String author_comment = " " ;
if ( notification_type = = NotificationCustom | | notification_type = = NotificationAcknowledgement ) {
author_comment = " ; " + author + " ; " + comment_text ;
}
if ( ! cr )
return ;
String output ;
if ( cr )
output = CompatUtility : : GetCheckResultOutput ( cr ) ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
if ( service ) {
msgbuf < < " SERVICE NOTIFICATION: "
< < user - > GetName ( ) < < " ; "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
< < notification_type_str < < " "
< < " ( " < < Service : : StateToString ( service - > GetState ( ) ) < < " ); "
< < check_command < < " ; "
< < output < < author_comment
< < " " ;
} else {
msgbuf < < " HOST NOTIFICATION: "
< < user - > GetName ( ) < < " ; "
< < host - > GetName ( ) < < " ; "
< < notification_type_str < < " "
< < " ( " < < Host : : StateToString ( host - > GetState ( ) ) < < " ); "
< < check_command < < " ; "
< < output < < author_comment
< < " " ;
}
2014-04-06 18:17:52 +02:00
AddLogHistory ( checkable , msgbuf . str ( ) , LogEntryTypeHostNotification ) ;
2014-04-03 15:36:13 +02:00
}
2015-08-04 14:47:44 +02:00
void DbEvents : : AddFlappingChangedLogHistory ( const Checkable : : Ptr & checkable )
2014-04-03 15:36:13 +02:00
{
String flapping_state_str ;
String flapping_output ;
2015-08-04 14:47:44 +02:00
if ( checkable - > IsFlapping ( ) ) {
2017-10-19 17:32:52 +02:00
flapping_output = " Service appears to have started flapping ( " + Convert : : ToString ( checkable - > GetFlappingCurrent ( ) ) + " % change >= " + Convert : : ToString ( checkable - > GetFlappingThresholdHigh ( ) ) + " % threshold) " ;
2015-08-04 14:47:44 +02:00
flapping_state_str = " STARTED " ;
} else {
2017-10-19 17:32:52 +02:00
flapping_output = " Service appears to have stopped flapping ( " + Convert : : ToString ( checkable - > GetFlappingCurrent ( ) ) + " % change < " + Convert : : ToString ( checkable - > GetFlappingThresholdLow ( ) ) + " % threshold) " ;
2015-08-04 14:47:44 +02:00
flapping_state_str = " STOPPED " ;
}
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
2014-04-03 15:36:13 +02:00
2015-08-04 14:47:44 +02:00
if ( service ) {
msgbuf < < " SERVICE FLAPPING ALERT: "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
< < flapping_state_str < < " ; "
< < flapping_output
< < " " ;
} else {
msgbuf < < " HOST FLAPPING ALERT: "
< < host - > GetName ( ) < < " ; "
< < flapping_state_str < < " ; "
< < flapping_output
< < " " ;
2014-04-03 15:36:13 +02:00
}
2015-08-04 14:47:44 +02:00
AddLogHistory ( checkable , msgbuf . str ( ) , LogEntryTypeInfoMessage ) ;
}
void DbEvents : : AddEnableFlappingChangedLogHistory ( const Checkable : : Ptr & checkable )
{
if ( ! checkable - > GetEnableFlapping ( ) )
return ;
String flapping_output = " Flap detection has been disabled " ;
String flapping_state_str = " DISABLED " ;
2014-04-03 15:36:13 +02:00
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
if ( service ) {
2014-08-17 17:57:20 +02:00
msgbuf < < " SERVICE FLAPPING ALERT: "
< < host - > GetName ( ) < < " ; "
< < service - > GetShortName ( ) < < " ; "
< < flapping_state_str < < " ; "
< < flapping_output
< < " " ;
2014-04-03 15:36:13 +02:00
} else {
2014-08-17 17:57:20 +02:00
msgbuf < < " HOST FLAPPING ALERT: "
< < host - > GetName ( ) < < " ; "
< < flapping_state_str < < " ; "
< < flapping_output
< < " " ;
2014-04-03 15:36:13 +02:00
}
2014-04-06 18:17:52 +02:00
AddLogHistory ( checkable , msgbuf . str ( ) , LogEntryTypeInfoMessage ) ;
2014-04-03 15:36:13 +02:00
}
void DbEvents : : AddLogHistory ( const Checkable : : Ptr & checkable , String buffer , LogEntryType type )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add log entry history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query1 ;
query1 . Table = " logentries " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatLog ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " logentry_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " entry_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " entry_time_usec " , time_bag . second ) ;
fields1 - > Set ( " object_id " , checkable ) ; // added in 1.10 see #4754
fields1 - > Set ( " logentry_type " , type ) ;
fields1 - > Set ( " logentry_data " , buffer ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
/* flappinghistory */
2015-08-04 14:47:44 +02:00
void DbEvents : : AddFlappingChangedHistory ( const Checkable : : Ptr & checkable )
2014-04-03 15:36:13 +02:00
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add flapping history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query1 ;
query1 . Table = " flappinghistory " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatFlapping ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " event_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " event_time_usec " , time_bag . second ) ;
2015-08-04 14:47:44 +02:00
if ( checkable - > IsFlapping ( ) )
fields1 - > Set ( " event_type " , 1000 ) ;
else {
fields1 - > Set ( " event_type " , 1001 ) ;
fields1 - > Set ( " reason_type " , 1 ) ;
2014-04-03 15:36:13 +02:00
}
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
fields1 - > Set ( " flapping_type " , service ? 1 : 0 ) ;
fields1 - > Set ( " object_id " , checkable ) ;
fields1 - > Set ( " percent_state_change " , checkable - > GetFlappingCurrent ( ) ) ;
2017-10-19 17:32:52 +02:00
fields1 - > Set ( " low_threshold " , checkable - > GetFlappingThresholdLow ( ) ) ;
fields1 - > Set ( " high_threshold " , checkable - > GetFlappingThresholdHigh ( ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
2015-08-04 14:47:44 +02:00
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
void DbEvents : : AddEnableFlappingChangedHistory ( const Checkable : : Ptr & checkable )
{
Log ( LogDebug , " DbEvents " )
< < " add flapping history for ' " < < checkable - > GetName ( ) < < " ' " ;
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query1 ;
query1 . Table = " flappinghistory " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatFlapping ;
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
fields1 - > Set ( " event_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " event_time_usec " , time_bag . second ) ;
if ( ! checkable - > GetEnableFlapping ( ) )
return ;
fields1 - > Set ( " event_type " , 1001 ) ;
fields1 - > Set ( " reason_type " , 2 ) ;
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
fields1 - > Set ( " flapping_type " , service ? 1 : 0 ) ;
fields1 - > Set ( " object_id " , checkable ) ;
fields1 - > Set ( " percent_state_change " , checkable - > GetFlappingCurrent ( ) ) ;
2017-10-19 17:32:52 +02:00
fields1 - > Set ( " low_threshold " , checkable - > GetFlappingThresholdLow ( ) ) ;
fields1 - > Set ( " high_threshold " , checkable - > GetFlappingThresholdHigh ( ) ) ;
2015-08-04 14:47:44 +02:00
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
2014-04-03 15:36:13 +02:00
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
/* servicechecks */
2015-04-27 15:06:14 +02:00
void DbEvents : : AddCheckableCheckHistory ( const Checkable : : Ptr & checkable , const CheckResult : : Ptr & cr )
2014-04-03 15:36:13 +02:00
{
if ( ! cr )
return ;
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
2015-10-15 18:43:30 +02:00
< < " add checkable check history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
std : : ostringstream msgbuf ;
DbQuery query1 ;
query1 . Table = service ? " servicechecks " : " hostchecks " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatCheck ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " check_type " , CompatUtility : : GetCheckableCheckType ( checkable ) ) ;
fields1 - > Set ( " current_check_attempt " , checkable - > GetCheckAttempt ( ) ) ;
fields1 - > Set ( " max_check_attempts " , checkable - > GetMaxCheckAttempts ( ) ) ;
fields1 - > Set ( " state_type " , checkable - > GetStateType ( ) ) ;
2015-04-24 17:41:07 +02:00
double start = cr - > GetExecutionStart ( ) ;
std : : pair < unsigned long , unsigned long > time_bag_start = CompatUtility : : ConvertTimestamp ( start ) ;
2014-04-03 15:36:13 +02:00
2015-04-24 17:41:07 +02:00
double end = cr - > GetExecutionEnd ( ) ;
2014-04-03 15:36:13 +02:00
std : : pair < unsigned long , unsigned long > time_bag_end = CompatUtility : : ConvertTimestamp ( end ) ;
2016-05-10 11:44:14 +02:00
double execution_time = cr - > CalculateExecutionTime ( ) ;
2015-04-24 17:41:07 +02:00
fields1 - > Set ( " start_time " , DbValue : : FromTimestamp ( time_bag_start . first ) ) ;
fields1 - > Set ( " start_time_usec " , time_bag_start . second ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " end_time " , DbValue : : FromTimestamp ( time_bag_end . first ) ) ;
fields1 - > Set ( " end_time_usec " , time_bag_end . second ) ;
fields1 - > Set ( " command_object_id " , checkable - > GetCheckCommand ( ) ) ;
fields1 - > Set ( " command_args " , Empty ) ;
2015-02-14 23:46:55 +01:00
fields1 - > Set ( " command_line " , CompatUtility : : GetCommandLine ( checkable - > GetCheckCommand ( ) ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " execution_time " , Convert : : ToString ( execution_time ) ) ;
2016-05-10 11:44:14 +02:00
fields1 - > Set ( " latency " , Convert : : ToString ( cr - > CalculateLatency ( ) ) ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " return_code " , cr - > GetExitStatus ( ) ) ;
fields1 - > Set ( " output " , CompatUtility : : GetCheckResultOutput ( cr ) ) ;
fields1 - > Set ( " long_output " , CompatUtility : : GetCheckResultLongOutput ( cr ) ) ;
fields1 - > Set ( " perfdata " , CompatUtility : : GetCheckResultPerfdata ( cr ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
if ( service ) {
fields1 - > Set ( " service_object_id " , service ) ;
fields1 - > Set ( " state " , service - > GetState ( ) ) ;
} else {
fields1 - > Set ( " host_object_id " , host ) ;
2017-08-07 10:58:52 +02:00
fields1 - > Set ( " state " , CompatUtility : : GetHostCurrentState ( host ) ) ;
2014-04-03 15:36:13 +02:00
}
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
/* eventhandlers */
void DbEvents : : AddEventHandlerHistory ( const Checkable : : Ptr & checkable )
{
2014-10-19 17:52:17 +02:00
Log ( LogDebug , " DbEvents " )
< < " add eventhandler history for ' " < < checkable - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
double now = Utility : : GetTime ( ) ;
std : : pair < unsigned long , unsigned long > time_bag = CompatUtility : : ConvertTimestamp ( now ) ;
DbQuery query1 ;
query1 . Table = " eventhandlers " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatEventHandler ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
Host : : Ptr host ;
Service : : Ptr service ;
tie ( host , service ) = GetHostService ( checkable ) ;
fields1 - > Set ( " object_id " , checkable ) ;
2017-08-07 10:58:52 +02:00
if ( service ) {
fields1 - > Set ( " state " , service - > GetState ( ) ) ;
fields1 - > Set ( " eventhandler_type " , 1 ) ;
} else {
fields1 - > Set ( " state " , CompatUtility : : GetHostCurrentState ( host ) ) ;
fields1 - > Set ( " eventhandler_type " , 0 ) ;
}
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " state_type " , checkable - > GetStateType ( ) ) ;
fields1 - > Set ( " start_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " start_time_usec " , time_bag . second ) ;
fields1 - > Set ( " end_time " , DbValue : : FromTimestamp ( time_bag . first ) ) ;
fields1 - > Set ( " end_time_usec " , time_bag . second ) ;
fields1 - > Set ( " command_object_id " , checkable - > GetEventCommand ( ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}
/* externalcommands */
void DbEvents : : AddExternalCommandHistory ( double time , const String & command , const std : : vector < String > & arguments )
{
2014-05-28 14:34:26 +02:00
Log ( LogDebug , " DbEvents " , " add external command history " ) ;
2014-04-03 15:36:13 +02:00
DbQuery query1 ;
query1 . Table = " externalcommands " ;
query1 . Type = DbQueryInsert ;
query1 . Category = DbCatExternalCommand ;
2014-11-08 21:17:16 +01:00
Dictionary : : Ptr fields1 = new Dictionary ( ) ;
2014-04-03 15:36:13 +02:00
fields1 - > Set ( " entry_time " , DbValue : : FromTimestamp ( static_cast < long > ( time ) ) ) ;
fields1 - > Set ( " command_type " , CompatUtility : : MapExternalCommandType ( command ) ) ;
fields1 - > Set ( " command_name " , command ) ;
fields1 - > Set ( " command_args " , boost : : algorithm : : join ( arguments , " ; " ) ) ;
fields1 - > Set ( " instance_id " , 0 ) ; /* DbConnection class fills in real ID */
String node = IcingaApplication : : GetInstance ( ) - > GetNodeName ( ) ;
Endpoint : : Ptr endpoint = Endpoint : : GetByName ( node ) ;
if ( endpoint )
fields1 - > Set ( " endpoint_object_id " , endpoint ) ;
query1 . Fields = fields1 ;
DbObject : : OnQuery ( query1 ) ;
}