2013-01-22 08:34:29 +01:00
/******************************************************************************
* Icinga 2 *
2016-01-12 08:29:59 +01:00
* Copyright ( C ) 2012 - 2016 Icinga Development Team ( https : //www.icinga.org/) *
2013-01-22 08:34:29 +01: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 "icinga/externalcommandprocessor.hpp"
# include "icinga/host.hpp"
# include "icinga/service.hpp"
# include "icinga/user.hpp"
# include "icinga/hostgroup.hpp"
# include "icinga/servicegroup.hpp"
# include "icinga/pluginutility.hpp"
# include "icinga/icingaapplication.hpp"
# include "icinga/checkcommand.hpp"
# include "icinga/eventcommand.hpp"
# include "icinga/notificationcommand.hpp"
2015-06-15 17:24:55 +02:00
# include "icinga/compatutility.hpp"
2014-05-25 16:23:35 +02:00
# include "remote/apifunction.hpp"
# include "base/convert.hpp"
2014-10-19 14:21:12 +02:00
# include "base/logger.hpp"
2014-05-25 16:23:35 +02:00
# include "base/objectlock.hpp"
# include "base/application.hpp"
# include "base/utility.hpp"
# include "base/exception.hpp"
2013-03-17 20:19:29 +01:00
# include <fstream>
2013-03-15 18:21:29 +01:00
# include <boost/algorithm/string/classification.hpp>
2013-03-16 21:18:53 +01:00
# include <boost/foreach.hpp>
2013-03-18 11:02:18 +01:00
# include <boost/algorithm/string/split.hpp>
2013-01-22 08:34:29 +01:00
using namespace icinga ;
2014-05-03 20:02:22 +02:00
INITIALIZE_ONCE ( & ExternalCommandProcessor : : StaticInitialize ) ;
2014-04-08 15:36:45 +02:00
2014-05-11 06:30:50 +02:00
typedef boost : : function < void ( double , const std : : vector < String > & arguments ) > ExternalCommandCallback ;
2014-04-08 15:36:45 +02:00
struct ExternalCommandInfo
{
ExternalCommandCallback Callback ;
size_t MinArgs ;
size_t MaxArgs ;
} ;
2014-05-03 20:02:22 +02:00
static boost : : mutex & GetMutex ( void )
{
static boost : : mutex mtx ;
return mtx ;
}
static std : : map < String , ExternalCommandInfo > & GetCommands ( void )
{
static std : : map < String , ExternalCommandInfo > commands ;
return commands ;
}
2013-01-22 08:34:29 +01:00
2013-09-30 19:32:32 +02:00
boost : : signals2 : : signal < void ( double , const String & , const std : : vector < String > & ) > ExternalCommandProcessor : : OnNewExternalCommand ;
2014-05-23 11:05:25 +02:00
static void RegisterCommand ( const String & command , const ExternalCommandCallback & callback , size_t minArgs = 0 , size_t maxArgs = UINT_MAX )
2014-04-08 15:36:45 +02:00
{
2014-05-03 20:02:22 +02:00
boost : : mutex : : scoped_lock lock ( GetMutex ( ) ) ;
2014-04-08 15:36:45 +02:00
ExternalCommandInfo eci ;
eci . Callback = callback ;
eci . MinArgs = minArgs ;
2014-05-23 11:05:25 +02:00
eci . MaxArgs = ( maxArgs = = UINT_MAX ) ? minArgs : maxArgs ;
2014-05-03 20:02:22 +02:00
GetCommands ( ) [ command ] = eci ;
2014-04-08 15:36:45 +02:00
}
2013-01-29 15:00:39 +01:00
void ExternalCommandProcessor : : Execute ( const String & line )
2013-01-24 23:42:02 +01:00
{
if ( line . IsEmpty ( ) )
return ;
if ( line [ 0 ] ! = ' [ ' )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing timestamp in command: " + line ) ) ;
2013-01-24 23:42:02 +01:00
size_t pos = line . FindFirstOf ( " ] " ) ;
if ( pos = = String : : NPos )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing timestamp in command: " + line ) ) ;
2013-01-24 23:42:02 +01:00
String timestamp = line . SubStr ( 1 , pos - 1 ) ;
String args = line . SubStr ( pos + 2 , String : : NPos ) ;
2013-01-29 12:05:46 +01:00
double ts = Convert : : ToDouble ( timestamp ) ;
2013-01-24 23:42:02 +01:00
if ( ts = = 0 )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Invalid timestamp in command: " + line ) ) ;
2013-01-24 23:42:02 +01:00
2013-03-18 11:02:18 +01:00
std : : vector < String > argv ;
boost : : algorithm : : split ( argv , args , boost : : is_any_of ( " ; " ) ) ;
2013-01-24 23:42:02 +01:00
2013-03-06 15:41:13 +01:00
if ( argv . empty ( ) )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing arguments in command: " + line ) ) ;
2013-01-24 23:42:02 +01:00
2013-03-16 21:18:53 +01:00
std : : vector < String > argvExtra ( argv . begin ( ) + 1 , argv . end ( ) ) ;
2013-01-24 23:42:02 +01:00
Execute ( ts , argv [ 0 ] , argvExtra ) ;
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : Execute ( double time , const String & command , const std : : vector < String > & arguments )
2013-01-22 08:34:29 +01:00
{
2014-04-08 15:36:45 +02:00
ExternalCommandInfo eci ;
2013-02-17 19:14:34 +01:00
{
2014-05-03 20:02:22 +02:00
boost : : mutex : : scoped_lock lock ( GetMutex ( ) ) ;
2013-02-17 19:14:34 +01:00
2014-04-08 15:36:45 +02:00
std : : map < String , ExternalCommandInfo > : : iterator it ;
2014-05-03 20:02:22 +02:00
it = GetCommands ( ) . find ( command ) ;
2013-02-17 19:14:34 +01:00
2014-05-03 20:02:22 +02:00
if ( it = = GetCommands ( ) . end ( ) )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " The external command ' " + command + " ' does not exist. " ) ) ;
2013-02-17 19:14:34 +01:00
2014-04-08 15:36:45 +02:00
eci = it - > second ;
2013-01-22 08:34:29 +01:00
}
2014-04-08 15:36:45 +02:00
if ( arguments . size ( ) < eci . MinArgs )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Expected " + Convert : : ToString ( eci . MinArgs ) + " arguments " ) ) ;
size_t argnum = std : : min ( arguments . size ( ) , eci . MaxArgs ) ;
std : : vector < String > realArguments ;
realArguments . resize ( argnum ) ;
2014-04-11 15:47:26 +02:00
if ( argnum > 0 ) {
2014-04-08 15:36:45 +02:00
std : : copy ( arguments . begin ( ) , arguments . begin ( ) + argnum - 1 , realArguments . begin ( ) ) ;
2015-02-11 16:45:52 +01:00
2014-04-11 15:47:26 +02:00
String last_argument ;
2014-05-11 06:00:34 +02:00
for ( std : : vector < String > : : size_type i = argnum - 1 ; i < arguments . size ( ) ; i + + ) {
2014-04-11 15:47:26 +02:00
if ( ! last_argument . IsEmpty ( ) )
last_argument + = " ; " ;
2014-04-08 15:36:45 +02:00
2014-04-11 15:47:26 +02:00
last_argument + = arguments [ i ] ;
}
2014-04-08 15:36:45 +02:00
2014-04-11 15:47:26 +02:00
realArguments [ argnum - 1 ] = last_argument ;
}
2014-04-08 15:36:45 +02:00
OnNewExternalCommand ( time , command , realArguments ) ;
2013-09-30 19:32:32 +02:00
2014-04-08 15:36:45 +02:00
eci . Callback ( time , realArguments ) ;
2013-02-17 19:14:34 +01:00
}
2013-01-22 08:34:29 +01:00
2014-05-03 20:02:22 +02:00
void ExternalCommandProcessor : : StaticInitialize ( void )
2013-02-17 19:14:34 +01:00
{
2014-04-08 15:36:45 +02:00
RegisterCommand ( " PROCESS_HOST_CHECK_RESULT " , & ExternalCommandProcessor : : ProcessHostCheckResult , 3 ) ;
RegisterCommand ( " PROCESS_SERVICE_CHECK_RESULT " , & ExternalCommandProcessor : : ProcessServiceCheckResult , 4 ) ;
RegisterCommand ( " SCHEDULE_HOST_CHECK " , & ExternalCommandProcessor : : ScheduleHostCheck , 2 ) ;
RegisterCommand ( " SCHEDULE_FORCED_HOST_CHECK " , & ExternalCommandProcessor : : ScheduleForcedHostCheck , 2 ) ;
RegisterCommand ( " SCHEDULE_SVC_CHECK " , & ExternalCommandProcessor : : ScheduleSvcCheck , 3 ) ;
RegisterCommand ( " SCHEDULE_FORCED_SVC_CHECK " , & ExternalCommandProcessor : : ScheduleForcedSvcCheck , 3 ) ;
RegisterCommand ( " ENABLE_HOST_CHECK " , & ExternalCommandProcessor : : EnableHostCheck , 1 ) ;
RegisterCommand ( " DISABLE_HOST_CHECK " , & ExternalCommandProcessor : : DisableHostCheck , 1 ) ;
RegisterCommand ( " ENABLE_SVC_CHECK " , & ExternalCommandProcessor : : EnableSvcCheck , 2 ) ;
RegisterCommand ( " DISABLE_SVC_CHECK " , & ExternalCommandProcessor : : DisableSvcCheck , 2 ) ;
2013-02-17 19:14:34 +01:00
RegisterCommand ( " SHUTDOWN_PROCESS " , & ExternalCommandProcessor : : ShutdownProcess ) ;
2013-08-30 14:27:24 +02:00
RegisterCommand ( " RESTART_PROCESS " , & ExternalCommandProcessor : : RestartProcess ) ;
2014-04-08 15:36:45 +02:00
RegisterCommand ( " SCHEDULE_FORCED_HOST_SVC_CHECKS " , & ExternalCommandProcessor : : ScheduleForcedHostSvcChecks , 2 ) ;
RegisterCommand ( " SCHEDULE_HOST_SVC_CHECKS " , & ExternalCommandProcessor : : ScheduleHostSvcChecks , 2 ) ;
RegisterCommand ( " ENABLE_HOST_SVC_CHECKS " , & ExternalCommandProcessor : : EnableHostSvcChecks , 1 ) ;
RegisterCommand ( " DISABLE_HOST_SVC_CHECKS " , & ExternalCommandProcessor : : DisableHostSvcChecks , 1 ) ;
RegisterCommand ( " ACKNOWLEDGE_SVC_PROBLEM " , & ExternalCommandProcessor : : AcknowledgeSvcProblem , 7 ) ;
RegisterCommand ( " ACKNOWLEDGE_SVC_PROBLEM_EXPIRE " , & ExternalCommandProcessor : : AcknowledgeSvcProblemExpire , 8 ) ;
RegisterCommand ( " REMOVE_SVC_ACKNOWLEDGEMENT " , & ExternalCommandProcessor : : RemoveSvcAcknowledgement , 2 ) ;
RegisterCommand ( " ACKNOWLEDGE_HOST_PROBLEM " , & ExternalCommandProcessor : : AcknowledgeHostProblem , 6 ) ;
RegisterCommand ( " ACKNOWLEDGE_HOST_PROBLEM_EXPIRE " , & ExternalCommandProcessor : : AcknowledgeHostProblemExpire , 7 ) ;
RegisterCommand ( " REMOVE_HOST_ACKNOWLEDGEMENT " , & ExternalCommandProcessor : : RemoveHostAcknowledgement , 1 ) ;
RegisterCommand ( " DISABLE_HOST_FLAP_DETECTION " , & ExternalCommandProcessor : : DisableHostFlapping , 1 ) ;
RegisterCommand ( " ENABLE_HOST_FLAP_DETECTION " , & ExternalCommandProcessor : : EnableHostFlapping , 1 ) ;
RegisterCommand ( " DISABLE_SVC_FLAP_DETECTION " , & ExternalCommandProcessor : : DisableSvcFlapping , 2 ) ;
RegisterCommand ( " ENABLE_SVC_FLAP_DETECTION " , & ExternalCommandProcessor : : EnableSvcFlapping , 2 ) ;
RegisterCommand ( " ENABLE_HOSTGROUP_SVC_CHECKS " , & ExternalCommandProcessor : : EnableHostgroupSvcChecks , 1 ) ;
RegisterCommand ( " DISABLE_HOSTGROUP_SVC_CHECKS " , & ExternalCommandProcessor : : DisableHostgroupSvcChecks , 1 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_SVC_CHECKS " , & ExternalCommandProcessor : : EnableServicegroupSvcChecks , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_SVC_CHECKS " , & ExternalCommandProcessor : : DisableServicegroupSvcChecks , 1 ) ;
RegisterCommand ( " ENABLE_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : EnablePassiveHostChecks , 1 ) ;
RegisterCommand ( " DISABLE_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : DisablePassiveHostChecks , 1 ) ;
RegisterCommand ( " ENABLE_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : EnablePassiveSvcChecks , 2 ) ;
RegisterCommand ( " DISABLE_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : DisablePassiveSvcChecks , 2 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : EnableServicegroupPassiveSvcChecks , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : DisableServicegroupPassiveSvcChecks , 1 ) ;
RegisterCommand ( " ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : EnableHostgroupPassiveSvcChecks , 1 ) ;
RegisterCommand ( " DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS " , & ExternalCommandProcessor : : DisableHostgroupPassiveSvcChecks , 1 ) ;
RegisterCommand ( " PROCESS_FILE " , & ExternalCommandProcessor : : ProcessFile , 2 ) ;
RegisterCommand ( " SCHEDULE_SVC_DOWNTIME " , & ExternalCommandProcessor : : ScheduleSvcDowntime , 9 ) ;
RegisterCommand ( " DEL_SVC_DOWNTIME " , & ExternalCommandProcessor : : DelSvcDowntime , 1 ) ;
RegisterCommand ( " SCHEDULE_HOST_DOWNTIME " , & ExternalCommandProcessor : : ScheduleHostDowntime , 8 ) ;
RegisterCommand ( " DEL_HOST_DOWNTIME " , & ExternalCommandProcessor : : DelHostDowntime , 1 ) ;
2016-02-26 14:31:32 +01:00
RegisterCommand ( " DEL_DOWNTIME_BY_HOST_NAME " , & ExternalCommandProcessor : : DelDowntimeByHostName , 1 , 4 ) ;
2014-04-08 15:36:45 +02:00
RegisterCommand ( " SCHEDULE_HOST_SVC_DOWNTIME " , & ExternalCommandProcessor : : ScheduleHostSvcDowntime , 8 ) ;
RegisterCommand ( " SCHEDULE_HOSTGROUP_HOST_DOWNTIME " , & ExternalCommandProcessor : : ScheduleHostgroupHostDowntime , 8 ) ;
RegisterCommand ( " SCHEDULE_HOSTGROUP_SVC_DOWNTIME " , & ExternalCommandProcessor : : ScheduleHostgroupSvcDowntime , 8 ) ;
RegisterCommand ( " SCHEDULE_SERVICEGROUP_HOST_DOWNTIME " , & ExternalCommandProcessor : : ScheduleServicegroupHostDowntime , 8 ) ;
RegisterCommand ( " SCHEDULE_SERVICEGROUP_SVC_DOWNTIME " , & ExternalCommandProcessor : : ScheduleServicegroupSvcDowntime , 8 ) ;
RegisterCommand ( " ADD_HOST_COMMENT " , & ExternalCommandProcessor : : AddHostComment , 4 ) ;
RegisterCommand ( " DEL_HOST_COMMENT " , & ExternalCommandProcessor : : DelHostComment , 1 ) ;
RegisterCommand ( " ADD_SVC_COMMENT " , & ExternalCommandProcessor : : AddSvcComment , 5 ) ;
RegisterCommand ( " DEL_SVC_COMMENT " , & ExternalCommandProcessor : : DelSvcComment , 1 ) ;
RegisterCommand ( " DEL_ALL_HOST_COMMENTS " , & ExternalCommandProcessor : : DelAllHostComments , 1 ) ;
RegisterCommand ( " DEL_ALL_SVC_COMMENTS " , & ExternalCommandProcessor : : DelAllSvcComments , 2 ) ;
RegisterCommand ( " SEND_CUSTOM_HOST_NOTIFICATION " , & ExternalCommandProcessor : : SendCustomHostNotification , 4 ) ;
RegisterCommand ( " SEND_CUSTOM_SVC_NOTIFICATION " , & ExternalCommandProcessor : : SendCustomSvcNotification , 5 ) ;
RegisterCommand ( " DELAY_HOST_NOTIFICATION " , & ExternalCommandProcessor : : DelayHostNotification , 2 ) ;
RegisterCommand ( " DELAY_SVC_NOTIFICATION " , & ExternalCommandProcessor : : DelaySvcNotification , 3 ) ;
RegisterCommand ( " ENABLE_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableHostNotifications , 1 ) ;
RegisterCommand ( " DISABLE_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableHostNotifications , 1 ) ;
RegisterCommand ( " ENABLE_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableSvcNotifications , 2 ) ;
RegisterCommand ( " DISABLE_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableSvcNotifications , 2 ) ;
2015-02-11 16:45:52 +01:00
RegisterCommand ( " ENABLE_HOST_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableHostSvcNotifications , 1 ) ;
RegisterCommand ( " DISABLE_HOST_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableHostSvcNotifications , 1 ) ;
2014-04-08 15:36:45 +02:00
RegisterCommand ( " DISABLE_HOSTGROUP_HOST_CHECKS " , & ExternalCommandProcessor : : DisableHostgroupHostChecks , 1 ) ;
RegisterCommand ( " DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : DisableHostgroupPassiveHostChecks , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_HOST_CHECKS " , & ExternalCommandProcessor : : DisableServicegroupHostChecks , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : DisableServicegroupPassiveHostChecks , 1 ) ;
RegisterCommand ( " ENABLE_HOSTGROUP_HOST_CHECKS " , & ExternalCommandProcessor : : EnableHostgroupHostChecks , 1 ) ;
RegisterCommand ( " ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : EnableHostgroupPassiveHostChecks , 1 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_HOST_CHECKS " , & ExternalCommandProcessor : : EnableServicegroupHostChecks , 1 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS " , & ExternalCommandProcessor : : EnableServicegroupPassiveHostChecks , 1 ) ;
2013-10-08 11:57:35 +02:00
RegisterCommand ( " ENABLE_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableNotifications ) ;
RegisterCommand ( " DISABLE_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableNotifications ) ;
RegisterCommand ( " ENABLE_FLAP_DETECTION " , & ExternalCommandProcessor : : EnableFlapDetection ) ;
RegisterCommand ( " DISABLE_FLAP_DETECTION " , & ExternalCommandProcessor : : DisableFlapDetection ) ;
RegisterCommand ( " ENABLE_EVENT_HANDLERS " , & ExternalCommandProcessor : : EnableEventHandlers ) ;
RegisterCommand ( " DISABLE_EVENT_HANDLERS " , & ExternalCommandProcessor : : DisableEventHandlers ) ;
RegisterCommand ( " ENABLE_PERFORMANCE_DATA " , & ExternalCommandProcessor : : EnablePerformanceData ) ;
RegisterCommand ( " DISABLE_PERFORMANCE_DATA " , & ExternalCommandProcessor : : DisablePerformanceData ) ;
RegisterCommand ( " START_EXECUTING_SVC_CHECKS " , & ExternalCommandProcessor : : StartExecutingSvcChecks ) ;
RegisterCommand ( " STOP_EXECUTING_SVC_CHECKS " , & ExternalCommandProcessor : : StopExecutingSvcChecks ) ;
2014-04-17 11:29:47 +02:00
RegisterCommand ( " START_EXECUTING_HOST_CHECKS " , & ExternalCommandProcessor : : StartExecutingHostChecks ) ;
RegisterCommand ( " STOP_EXECUTING_HOST_CHECKS " , & ExternalCommandProcessor : : StopExecutingHostChecks ) ;
2014-04-08 15:36:45 +02:00
RegisterCommand ( " CHANGE_NORMAL_SVC_CHECK_INTERVAL " , & ExternalCommandProcessor : : ChangeNormalSvcCheckInterval , 3 ) ;
RegisterCommand ( " CHANGE_NORMAL_HOST_CHECK_INTERVAL " , & ExternalCommandProcessor : : ChangeNormalHostCheckInterval , 2 ) ;
RegisterCommand ( " CHANGE_RETRY_SVC_CHECK_INTERVAL " , & ExternalCommandProcessor : : ChangeRetrySvcCheckInterval , 3 ) ;
RegisterCommand ( " CHANGE_RETRY_HOST_CHECK_INTERVAL " , & ExternalCommandProcessor : : ChangeRetryHostCheckInterval , 2 ) ;
RegisterCommand ( " ENABLE_HOST_EVENT_HANDLER " , & ExternalCommandProcessor : : EnableHostEventHandler , 1 ) ;
RegisterCommand ( " DISABLE_HOST_EVENT_HANDLER " , & ExternalCommandProcessor : : DisableHostEventHandler , 1 ) ;
RegisterCommand ( " ENABLE_SVC_EVENT_HANDLER " , & ExternalCommandProcessor : : EnableSvcEventHandler , 2 ) ;
RegisterCommand ( " DISABLE_SVC_EVENT_HANDLER " , & ExternalCommandProcessor : : DisableSvcEventHandler , 2 ) ;
RegisterCommand ( " CHANGE_HOST_EVENT_HANDLER " , & ExternalCommandProcessor : : ChangeHostEventHandler , 2 ) ;
RegisterCommand ( " CHANGE_SVC_EVENT_HANDLER " , & ExternalCommandProcessor : : ChangeSvcEventHandler , 3 ) ;
RegisterCommand ( " CHANGE_HOST_CHECK_COMMAND " , & ExternalCommandProcessor : : ChangeHostCheckCommand , 2 ) ;
RegisterCommand ( " CHANGE_SVC_CHECK_COMMAND " , & ExternalCommandProcessor : : ChangeSvcCheckCommand , 3 ) ;
RegisterCommand ( " CHANGE_MAX_HOST_CHECK_ATTEMPTS " , & ExternalCommandProcessor : : ChangeMaxHostCheckAttempts , 2 ) ;
RegisterCommand ( " CHANGE_MAX_SVC_CHECK_ATTEMPTS " , & ExternalCommandProcessor : : ChangeMaxSvcCheckAttempts , 3 ) ;
RegisterCommand ( " CHANGE_HOST_CHECK_TIMEPERIOD " , & ExternalCommandProcessor : : ChangeHostCheckTimeperiod , 2 ) ;
RegisterCommand ( " CHANGE_SVC_CHECK_TIMEPERIOD " , & ExternalCommandProcessor : : ChangeSvcCheckTimeperiod , 3 ) ;
2014-04-15 17:33:56 +02:00
RegisterCommand ( " CHANGE_CUSTOM_HOST_VAR " , & ExternalCommandProcessor : : ChangeCustomHostVar , 3 ) ;
RegisterCommand ( " CHANGE_CUSTOM_SVC_VAR " , & ExternalCommandProcessor : : ChangeCustomSvcVar , 4 ) ;
RegisterCommand ( " CHANGE_CUSTOM_USER_VAR " , & ExternalCommandProcessor : : ChangeCustomUserVar , 3 ) ;
RegisterCommand ( " CHANGE_CUSTOM_CHECKCOMMAND_VAR " , & ExternalCommandProcessor : : ChangeCustomCheckcommandVar , 3 ) ;
RegisterCommand ( " CHANGE_CUSTOM_EVENTCOMMAND_VAR " , & ExternalCommandProcessor : : ChangeCustomEventcommandVar , 3 ) ;
RegisterCommand ( " CHANGE_CUSTOM_NOTIFICATIONCOMMAND_VAR " , & ExternalCommandProcessor : : ChangeCustomNotificationcommandVar , 3 ) ;
2014-04-08 15:36:45 +02:00
RegisterCommand ( " ENABLE_HOSTGROUP_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableHostgroupHostNotifications , 1 ) ;
RegisterCommand ( " ENABLE_HOSTGROUP_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableHostgroupSvcNotifications , 1 ) ;
RegisterCommand ( " DISABLE_HOSTGROUP_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableHostgroupHostNotifications , 1 ) ;
RegisterCommand ( " DISABLE_HOSTGROUP_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableHostgroupSvcNotifications , 1 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableServicegroupHostNotifications , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableServicegroupHostNotifications , 1 ) ;
RegisterCommand ( " ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : EnableServicegroupSvcNotifications , 1 ) ;
RegisterCommand ( " DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS " , & ExternalCommandProcessor : : DisableServicegroupSvcNotifications , 1 ) ;
2013-01-22 08:34:29 +01:00
}
2015-10-27 18:00:55 +01:00
void ExternalCommandProcessor : : ExecuteFromFile ( const String & line , std : : deque < std : : vector < String > > & file_queue )
{
if ( line . IsEmpty ( ) )
return ;
if ( line [ 0 ] ! = ' [ ' )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing timestamp in command: " + line ) ) ;
size_t pos = line . FindFirstOf ( " ] " ) ;
if ( pos = = String : : NPos )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing timestamp in command: " + line ) ) ;
String timestamp = line . SubStr ( 1 , pos - 1 ) ;
String args = line . SubStr ( pos + 2 , String : : NPos ) ;
double ts = Convert : : ToDouble ( timestamp ) ;
if ( ts = = 0 )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Invalid timestamp in command: " + line ) ) ;
std : : vector < String > argv ;
boost : : algorithm : : split ( argv , args , boost : : is_any_of ( " ; " ) ) ;
if ( argv . empty ( ) )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Missing arguments in command: " + line ) ) ;
std : : vector < String > argvExtra ( argv . begin ( ) + 1 , argv . end ( ) ) ;
if ( argv [ 0 ] = = " PROCESS_FILE " ) {
Log ( LogDebug , " ExternalCommandProcessor " )
< < " Enqueing external command file " < < argvExtra [ 0 ] ;
file_queue . push_back ( argvExtra ) ;
} else {
Execute ( ts , argv [ 0 ] , argvExtra ) ;
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ProcessHostCheckResult ( double time , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
2013-09-27 23:13:25 +02:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot process passive host check result for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-09-27 12:24:30 +02:00
2014-04-03 15:36:13 +02:00
if ( ! host - > GetEnablePassiveChecks ( ) )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Got passive check result for host ' " + arguments [ 0 ] + " ' which has passive checks disabled. " ) ) ;
2013-02-26 11:18:03 +01:00
2013-03-06 11:03:50 +01:00
int exitStatus = Convert : : ToDouble ( arguments [ 1 ] ) ;
2014-11-08 21:17:16 +01:00
CheckResult : : Ptr result = new CheckResult ( ) ;
2014-09-07 12:27:06 +02:00
std : : pair < String , String > co = PluginUtility : : ParseCheckOutput ( arguments [ 2 ] ) ;
2014-03-12 10:05:36 +01:00
result - > SetOutput ( co . first ) ;
2014-09-17 15:38:39 +02:00
result - > SetPerformanceData ( PluginUtility : : SplitPerfdata ( co . second ) ) ;
2014-01-28 14:44:06 +01:00
ServiceState state ;
if ( exitStatus = = 0 )
2014-04-08 09:11:54 +02:00
state = ServiceOK ;
2014-01-28 14:44:06 +01:00
else if ( exitStatus = = 1 )
2014-04-08 09:11:54 +02:00
state = ServiceCritical ;
2014-01-28 14:44:06 +01:00
else
2014-02-04 15:59:08 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Invalid status code: " + arguments [ 1 ] ) ) ;
2014-01-28 14:44:06 +01:00
result - > SetState ( state ) ;
2013-02-26 11:18:03 +01:00
2013-11-09 14:22:38 +01:00
result - > SetScheduleStart ( time ) ;
result - > SetScheduleEnd ( time ) ;
result - > SetExecutionStart ( time ) ;
result - > SetExecutionEnd ( time ) ;
2016-03-11 10:30:50 +01:00
/* Mark this check result as passive. */
2013-11-09 14:22:38 +01:00
result - > SetActive ( false ) ;
2013-02-26 11:18:03 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Processing passive check result for host ' " < < arguments [ 0 ] < < " ' " ;
2014-04-03 15:36:13 +02:00
host - > ProcessCheckResult ( result ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ProcessServiceCheckResult ( double time , const std : : vector < String > & arguments )
2013-01-22 12:05:36 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-22 12:05:36 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot process passive service check result for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-24 23:10:07 +01:00
if ( ! service - > GetEnablePassiveChecks ( ) )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Got passive check result for service ' " + arguments [ 1 ] + " ' which has passive checks disabled. " ) ) ;
2013-01-24 23:10:07 +01:00
2013-01-29 12:05:46 +01:00
int exitStatus = Convert : : ToDouble ( arguments [ 2 ] ) ;
2014-11-08 21:17:16 +01:00
CheckResult : : Ptr result = new CheckResult ( ) ;
2015-05-27 16:05:10 +02:00
String output = CompatUtility : : UnEscapeString ( arguments [ 3 ] ) ;
std : : pair < String , String > co = PluginUtility : : ParseCheckOutput ( output ) ;
2014-03-12 10:05:36 +01:00
result - > SetOutput ( co . first ) ;
2014-09-17 15:38:39 +02:00
result - > SetPerformanceData ( PluginUtility : : SplitPerfdata ( co . second ) ) ;
2013-11-09 14:22:38 +01:00
result - > SetState ( PluginUtility : : ExitStatusToState ( exitStatus ) ) ;
result - > SetScheduleStart ( time ) ;
result - > SetScheduleEnd ( time ) ;
result - > SetExecutionStart ( time ) ;
result - > SetExecutionEnd ( time ) ;
2016-03-11 10:30:50 +01:00
/* Mark this check result as passive. */
2013-11-09 14:22:38 +01:00
result - > SetActive ( false ) ;
2013-01-22 12:05:36 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Processing passive check result for service ' " < < arguments [ 1 ] < < " ' " ;
2013-01-22 12:05:36 +01:00
service - > ProcessCheckResult ( result ) ;
}
2013-01-22 12:56:29 +01:00
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostCheck ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule host check for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-02-26 11:18:03 +01:00
double planned_check = Convert : : ToDouble ( arguments [ 1 ] ) ;
2014-04-03 15:36:13 +02:00
if ( planned_check > host - > GetNextCheck ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Ignoring reschedule request for host ' "
< < arguments [ 0 ] < < " ' (next check is already sooner than requested check time) " ;
2013-02-26 11:18:03 +01:00
return ;
}
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2013-09-12 15:47:45 +02:00
if ( planned_check < Utility : : GetTime ( ) )
planned_check = Utility : : GetTime ( ) ;
2015-08-04 14:47:44 +02:00
host - > SetNextCheck ( planned_check ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( host ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleForcedHostCheck ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule forced host check for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > SetForceNextCheck ( true ) ;
host - > SetNextCheck ( Convert : : ToDouble ( arguments [ 1 ] ) ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( host ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleSvcCheck ( double , const std : : vector < String > & arguments )
2013-01-22 12:56:29 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-22 12:56:29 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule service check for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-29 12:05:46 +01:00
double planned_check = Convert : : ToDouble ( arguments [ 2 ] ) ;
2013-01-22 12:56:29 +01:00
2013-01-22 15:13:51 +01:00
if ( planned_check > service - > GetNextCheck ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Ignoring reschedule request for service ' "
< < arguments [ 1 ] < < " ' (next check is already sooner than requested check time) " ;
2013-01-22 15:13:51 +01:00
return ;
}
2013-01-22 12:56:29 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2013-09-12 15:47:45 +02:00
if ( planned_check < Utility : : GetTime ( ) )
planned_check = Utility : : GetTime ( ) ;
2015-08-04 14:47:44 +02:00
service - > SetNextCheck ( planned_check ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( service ) ;
2013-01-22 12:56:29 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleForcedSvcCheck ( double , const std : : vector < String > & arguments )
2013-01-22 12:56:29 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-22 12:56:29 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule forced service check for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > SetForceNextCheck ( true ) ;
service - > SetNextCheck ( Convert : : ToDouble ( arguments [ 2 ] ) ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( service ) ;
2013-01-22 12:56:29 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableHostCheck ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
2013-12-11 11:46:12 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-09-27 12:24:30 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableHostCheck ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host check non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableSvcCheck ( double , const std : : vector < String > & arguments )
2013-01-22 16:01:08 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-22 16:01:08 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service check for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-01-22 16:01:08 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableSvcCheck ( double , const std : : vector < String > & arguments )
2013-01-22 16:01:08 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-22 16:01:08 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service check for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-01-22 16:01:08 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ShutdownProcess ( double , const std : : vector < String > & )
2013-01-22 16:23:25 +01:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Shutting down Icinga via external command. " ) ;
2013-01-22 16:23:25 +01:00
Application : : RequestShutdown ( ) ;
}
2013-08-30 14:27:24 +02:00
void ExternalCommandProcessor : : RestartProcess ( double , const std : : vector < String > & )
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Restarting Icinga via external command. " ) ;
2013-08-30 14:27:24 +02:00
Application : : RequestRestart ( ) ;
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleForcedHostSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-23 10:42:16 +01:00
{
2013-01-29 12:05:46 +01:00
double planned_check = Convert : : ToDouble ( arguments [ 1 ] ) ;
2013-01-23 10:42:16 +01:00
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule forced host service checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-29 14:19:54 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > SetNextCheck ( planned_check ) ;
service - > SetForceNextCheck ( true ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( service ) ;
2013-01-23 10:42:16 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-23 10:42:16 +01:00
{
2013-01-29 12:05:46 +01:00
double planned_check = Convert : : ToDouble ( arguments [ 1 ] ) ;
2013-01-23 10:42:16 +01:00
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot reschedule host service checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-09-12 15:47:45 +02:00
if ( planned_check < Utility : : GetTime ( ) )
planned_check = Utility : : GetTime ( ) ;
2013-01-29 14:19:54 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2013-01-23 10:42:16 +01:00
if ( planned_check > service - > GetNextCheck ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Ignoring reschedule request for service ' "
< < service - > GetName ( ) < < " ' (next check is already sooner than requested check time) " ;
2013-01-23 16:07:55 +01:00
continue ;
2013-01-23 10:42:16 +01:00
}
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Rescheduling next check for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > SetNextCheck ( planned_check ) ;
2016-01-22 18:42:15 +01:00
/* trigger update event for DB IDO */
Checkable : : OnNextCheckUpdated ( service ) ;
2013-01-23 10:42:16 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableHostSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-23 10:51:54 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host service checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-29 14:19:54 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-01-23 10:51:54 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableHostSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-23 10:51:54 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host service checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-29 14:19:54 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-01-23 10:51:54 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AcknowledgeSvcProblem ( double , const std : : vector < String > & arguments )
2013-01-23 13:21:07 +01:00
{
2014-03-19 23:08:01 +01:00
bool sticky = ( Convert : : ToLong ( arguments [ 2 ] ) = = 2 ? true : false ) ;
2015-02-07 21:39:19 +01:00
bool notify = ( Convert : : ToLong ( arguments [ 3 ] ) > 0 ? true : false ) ;
2013-01-23 13:21:07 +01:00
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-23 13:21:07 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot acknowledge service problem for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-04-08 09:11:54 +02:00
if ( service - > GetState ( ) = = ServiceOK )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " The service ' " + arguments [ 1 ] + " ' is OK. " ) ) ;
2013-01-23 16:18:58 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
2015-02-07 21:39:19 +01:00
< < " Setting acknowledgement for service ' " < < service - > GetName ( ) < < " ' " < < ( notify ? " " : " . Disabled notification " ) ;
2013-03-06 11:03:50 +01:00
2015-08-20 17:18:48 +02:00
Comment : : AddComment ( service , CommentAcknowledgement , arguments [ 5 ] , arguments [ 6 ] , 0 ) ;
2015-02-07 21:39:19 +01:00
service - > AcknowledgeProblem ( arguments [ 5 ] , arguments [ 6 ] , sticky ? AcknowledgementSticky : AcknowledgementNormal , notify ) ;
2013-01-23 13:21:07 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AcknowledgeSvcProblemExpire ( double , const std : : vector < String > & arguments )
2013-01-23 13:21:07 +01:00
{
2014-03-19 23:08:01 +01:00
bool sticky = ( Convert : : ToLong ( arguments [ 2 ] ) = = 2 ? true : false ) ;
2015-02-07 21:39:19 +01:00
bool notify = ( Convert : : ToLong ( arguments [ 3 ] ) > 0 ? true : false ) ;
2013-01-29 12:05:46 +01:00
double timestamp = Convert : : ToDouble ( arguments [ 5 ] ) ;
2013-01-23 13:21:07 +01:00
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-23 13:21:07 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot acknowledge service problem with expire time for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-04-08 09:11:54 +02:00
if ( service - > GetState ( ) = = ServiceOK )
2013-03-16 21:18:53 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " The service ' " + arguments [ 1 ] + " ' is OK. " ) ) ;
2013-01-23 16:18:58 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
2015-02-07 21:39:19 +01:00
< < " Setting timed acknowledgement for service ' " < < service - > GetName ( ) < < " ' " < < ( notify ? " " : " . Disabled notification " ) ;
2013-03-06 11:03:50 +01:00
2015-08-20 17:18:48 +02:00
Comment : : AddComment ( service , CommentAcknowledgement , arguments [ 6 ] , arguments [ 7 ] , timestamp ) ;
2015-02-07 21:39:19 +01:00
service - > AcknowledgeProblem ( arguments [ 6 ] , arguments [ 7 ] , sticky ? AcknowledgementSticky : AcknowledgementNormal , notify , timestamp ) ;
2013-01-23 13:21:07 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : RemoveSvcAcknowledgement ( double , const std : : vector < String > & arguments )
2013-01-23 13:21:07 +01:00
{
2013-02-09 02:16:02 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-23 13:21:07 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot remove service acknowledgement for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing acknowledgement for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2014-03-13 16:43:32 +01:00
{
ObjectLock olock ( service ) ;
service - > ClearAcknowledgement ( ) ;
}
service - > RemoveCommentsByType ( CommentAcknowledgement ) ;
2013-01-23 13:21:07 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AcknowledgeHostProblem ( double , const std : : vector < String > & arguments )
2013-01-27 11:35:47 +01:00
{
2014-03-19 23:08:01 +01:00
bool sticky = ( Convert : : ToLong ( arguments [ 1 ] ) = = 2 ? true : false ) ;
2015-02-07 21:39:19 +01:00
bool notify = ( Convert : : ToLong ( arguments [ 2 ] ) > 0 ? true : false ) ;
2013-01-27 11:35:47 +01:00
2013-01-27 12:02:22 +01:00
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-01-27 11:35:47 +01:00
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot acknowledge host problem for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
2015-02-07 21:39:19 +01:00
< < " Setting acknowledgement for host ' " < < host - > GetName ( ) < < " ' " < < ( notify ? " " : " . Disabled notification " ) ;
2013-02-19 23:02:08 +01:00
2014-04-03 15:36:13 +02:00
if ( host - > GetState ( ) = = HostUp )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " The host ' " + arguments [ 0 ] + " ' is OK. " ) ) ;
2015-08-20 17:18:48 +02:00
Comment : : AddComment ( host , CommentAcknowledgement , arguments [ 4 ] , arguments [ 5 ] , 0 ) ;
2015-02-07 21:39:19 +01:00
host - > AcknowledgeProblem ( arguments [ 4 ] , arguments [ 5 ] , sticky ? AcknowledgementSticky : AcknowledgementNormal , notify ) ;
2013-01-27 11:35:47 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AcknowledgeHostProblemExpire ( double , const std : : vector < String > & arguments )
2013-01-27 11:35:47 +01:00
{
2014-03-19 23:08:01 +01:00
bool sticky = ( Convert : : ToLong ( arguments [ 1 ] ) = = 2 ? true : false ) ;
2015-02-07 21:39:19 +01:00
bool notify = ( Convert : : ToLong ( arguments [ 2 ] ) > 0 ? true : false ) ;
2013-01-29 12:05:46 +01:00
double timestamp = Convert : : ToDouble ( arguments [ 4 ] ) ;
2013-01-27 11:35:47 +01:00
2013-01-27 12:02:22 +01:00
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-01-27 11:35:47 +01:00
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot acknowledge host problem with expire time for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
2015-02-07 21:39:19 +01:00
< < " Setting timed acknowledgement for host ' " < < host - > GetName ( ) < < " ' " < < ( notify ? " " : " . Disabled notification " ) ;
2013-02-19 23:02:08 +01:00
2014-04-03 15:36:13 +02:00
if ( host - > GetState ( ) = = HostUp )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " The host ' " + arguments [ 0 ] + " ' is OK. " ) ) ;
2015-08-20 17:18:48 +02:00
Comment : : AddComment ( host , CommentAcknowledgement , arguments [ 5 ] , arguments [ 6 ] , timestamp ) ;
2015-02-07 21:39:19 +01:00
host - > AcknowledgeProblem ( arguments [ 5 ] , arguments [ 6 ] , sticky ? AcknowledgementSticky : AcknowledgementNormal , notify , timestamp ) ;
2013-01-27 11:35:47 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : RemoveHostAcknowledgement ( double , const std : : vector < String > & arguments )
2013-01-27 11:35:47 +01:00
{
2013-01-27 12:02:22 +01:00
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-01-27 11:35:47 +01:00
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot remove acknowledgement for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing acknowledgement for host ' " < < host - > GetName ( ) < < " ' " ;
2014-04-03 15:36:13 +02:00
{
ObjectLock olock ( host ) ;
host - > ClearAcknowledgement ( ) ;
2014-03-19 22:08:28 +01:00
}
2014-04-03 15:36:13 +02:00
host - > RemoveCommentsByType ( CommentAcknowledgement ) ;
2013-01-27 11:35:47 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableHostgroupSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 13:39:42 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable hostgroup service checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2013-01-24 15:12:32 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-01-24 15:12:32 +01:00
}
2013-01-24 13:39:42 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableHostgroupSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 13:39:42 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable hostgroup service checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2013-01-24 15:12:32 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-01-24 15:12:32 +01:00
}
2013-01-24 13:39:42 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableServicegroupSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 13:39:42 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable servicegroup service checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-01-24 13:39:42 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableServicegroupSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 13:39:42 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable servicegroup service checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-01-24 23:10:07 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnablePassiveHostChecks ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable passive host checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisablePassiveHostChecks ( double , const std : : vector < String > & arguments )
2013-02-26 11:18:03 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable passive host checks for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-02-26 11:18:03 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnablePassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-24 23:10:07 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service checks for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2013-01-24 23:10:07 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisablePassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-24 23:10:07 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service checks for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-01-24 23:10:07 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableServicegroupPassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable servicegroup passive service checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2013-01-24 23:10:07 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableServicegroupPassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable servicegroup passive service checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-01-24 13:39:42 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableHostgroupPassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable hostgroup passive service checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2013-01-24 23:10:07 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2013-01-24 23:10:07 +01:00
}
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableHostgroupPassiveSvcChecks ( double , const std : : vector < String > & arguments )
2013-01-24 23:10:07 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable hostgroup passive service checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2013-01-24 23:10:07 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for service ' " < < service - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-01-24 23:10:07 +01:00
}
}
}
2013-01-24 23:42:02 +01:00
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ProcessFile ( double , const std : : vector < String > & arguments )
2013-01-24 23:42:02 +01:00
{
2015-10-27 18:00:55 +01:00
std : : deque < std : : vector < String > > file_queue ;
file_queue . push_back ( arguments ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
while ( ! file_queue . empty ( ) ) {
std : : vector < String > argument = file_queue . front ( ) ;
file_queue . pop_front ( ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
String file = argument [ 0 ] ;
int to_delete = Convert : : ToLong ( argument [ 1 ] ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
std : : ifstream ifp ;
ifp . exceptions ( std : : ifstream : : badbit ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
ifp . open ( file . CStr ( ) , std : : ifstream : : in ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
while ( ifp . good ( ) ) {
std : : string line ;
std : : getline ( ifp , line ) ;
try {
Log ( LogNotice , " compat " )
< < " Executing external command: " < < line ;
ExecuteFromFile ( line , file_queue ) ;
} catch ( const std : : exception & ex ) {
Log ( LogWarning , " ExternalCommandProcessor " )
< < " External command failed: " < < DiagnosticInformation ( ex ) ;
}
2013-01-24 23:42:02 +01:00
}
2015-10-27 18:00:55 +01:00
ifp . close ( ) ;
2013-01-24 23:42:02 +01:00
2015-10-27 18:00:55 +01:00
if ( to_delete > 0 )
( void ) unlink ( file . CStr ( ) ) ;
}
2013-01-24 23:42:02 +01:00
}
2013-01-29 14:19:54 +01:00
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleSvcDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-29 14:19:54 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule service downtime for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 09:59:22 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 5 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 4 ] ) ;
2013-01-30 09:59:22 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-29 14:19:54 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for service " < < service - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( service , arguments [ 7 ] , arguments [ 8 ] ,
2013-01-29 14:19:54 +01:00
Convert : : ToDouble ( arguments [ 2 ] ) , Convert : : ToDouble ( arguments [ 3 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 6 ] ) ) ;
2013-01-29 14:19:54 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelSvcDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
2013-01-30 09:59:22 +01:00
int id = Convert : : ToLong ( arguments [ 0 ] ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing downtime ID " < < arguments [ 0 ] ;
2015-08-20 17:18:48 +02:00
String rid = Downtime : : GetDowntimeIDFromLegacyID ( id ) ;
Downtime : : RemoveDowntime ( rid , true ) ;
2013-01-29 14:19:54 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule host downtime for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 09:59:22 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 09:59:22 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-29 14:19:54 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for host " < < host - > GetName ( ) ;
2014-04-03 15:36:13 +02:00
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( host , arguments [ 6 ] , arguments [ 7 ] ,
2014-04-03 15:36:13 +02:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-29 14:19:54 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelHostDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
2013-01-30 09:59:22 +01:00
int id = Convert : : ToLong ( arguments [ 0 ] ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing downtime ID " < < arguments [ 0 ] ;
2015-08-20 17:18:48 +02:00
String rid = Downtime : : GetDowntimeIDFromLegacyID ( id ) ;
Downtime : : RemoveDowntime ( rid , true ) ;
2013-01-29 14:19:54 +01:00
}
2015-07-31 14:46:38 +02:00
void ExternalCommandProcessor : : DelDowntimeByHostName ( double , const std : : vector < String > & arguments )
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule host services downtime for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
String serviceName ;
if ( arguments . size ( ) > = 2 )
serviceName = arguments [ 1 ] ;
String startTime ;
if ( arguments . size ( ) > = 3 )
startTime = arguments [ 2 ] ;
String commentString ;
if ( arguments . size ( ) > = 4 )
commentString = arguments [ 3 ] ;
if ( arguments . size ( ) > 5 )
Log ( LogWarning , " ExternalCommandProcessor " )
< < ( " Ignoring additional parameters for host ' " + arguments [ 0 ] + " ' downtime deletion. " ) ;
2015-08-20 17:18:48 +02:00
BOOST_FOREACH ( const Downtime : : Ptr & downtime , host - > GetDowntimes ( ) ) {
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing downtime ' " < < downtime - > GetName ( ) < < " '. " ;
2015-07-31 14:46:38 +02:00
2015-08-20 17:18:48 +02:00
Downtime : : RemoveDowntime ( downtime - > GetName ( ) , true ) ;
2015-07-31 14:46:38 +02:00
}
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
if ( ! serviceName . IsEmpty ( ) & & serviceName ! = service - > GetName ( ) )
continue ;
2015-08-20 17:18:48 +02:00
BOOST_FOREACH ( const Downtime : : Ptr & downtime , service - > GetDowntimes ( ) ) {
if ( ! startTime . IsEmpty ( ) & & downtime - > GetStartTime ( ) ! = Convert : : ToDouble ( startTime ) )
continue ;
2015-07-31 14:46:38 +02:00
2015-08-20 17:18:48 +02:00
if ( ! commentString . IsEmpty ( ) & & downtime - > GetComment ( ) ! = commentString )
continue ;
2015-07-31 14:46:38 +02:00
2015-08-20 17:18:48 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing downtime ' " < < downtime - > GetName ( ) < < " '. " ;
2015-07-31 14:46:38 +02:00
2015-08-20 17:18:48 +02:00
Downtime : : RemoveDowntime ( downtime - > GetName ( ) , true ) ;
}
2015-07-31 14:46:38 +02:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostSvcDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule host services downtime for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 09:59:22 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 09:59:22 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-29 14:19:54 +01:00
2015-02-04 21:19:47 +01:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for host " < < host - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( host , arguments [ 6 ] , arguments [ 7 ] ,
2015-02-04 21:19:47 +01:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2015-02-04 21:19:47 +01:00
2013-01-29 14:19:54 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for service " < < service - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( service , arguments [ 6 ] , arguments [ 7 ] ,
2013-01-29 14:19:54 +01:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-29 14:19:54 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostgroupHostDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule hostgroup host downtime for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 09:59:22 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 09:59:22 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-30 09:59:22 +01:00
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for host " < < host - > GetName ( ) ;
2014-04-03 15:36:13 +02:00
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( host , arguments [ 6 ] , arguments [ 7 ] ,
2014-04-03 15:36:13 +02:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-29 14:19:54 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleHostgroupSvcDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
2013-01-30 13:23:00 +01:00
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule hostgroup service downtime for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 13:23:00 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 13:23:00 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-30 13:23:00 +01:00
/* Note: we can't just directly create downtimes for all the services by iterating
* over all hosts in the host group - otherwise we might end up creating multiple
* downtimes for some services . */
2013-03-16 21:18:53 +01:00
std : : set < Service : : Ptr > services ;
2013-01-30 13:23:00 +01:00
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2013-01-30 13:23:00 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
services . insert ( service ) ;
}
}
BOOST_FOREACH ( const Service : : Ptr & service , services ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for service " < < service - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( service , arguments [ 6 ] , arguments [ 7 ] ,
2013-01-30 13:23:00 +01:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-30 13:23:00 +01:00
}
2013-01-29 14:19:54 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleServicegroupHostDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
2013-01-30 13:23:00 +01:00
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule servicegroup host downtime for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 13:23:00 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 13:23:00 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-30 13:23:00 +01:00
/* Note: we can't just directly create downtimes for all the hosts by iterating
* over all services in the service group - otherwise we might end up creating multiple
* downtimes for some hosts . */
2014-04-03 15:36:13 +02:00
std : : set < Host : : Ptr > hosts ;
2013-01-30 13:23:00 +01:00
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2013-02-18 14:40:24 +01:00
Host : : Ptr host = service - > GetHost ( ) ;
2014-04-03 15:36:13 +02:00
hosts . insert ( host ) ;
2013-01-30 13:23:00 +01:00
}
2014-04-03 15:36:13 +02:00
BOOST_FOREACH ( const Host : : Ptr & host , hosts ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for host " < < host - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( host , arguments [ 6 ] , arguments [ 7 ] ,
2013-01-30 13:23:00 +01:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-30 13:23:00 +01:00
}
2013-01-29 14:19:54 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : ScheduleServicegroupSvcDowntime ( double , const std : : vector < String > & arguments )
2013-01-29 14:19:54 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot schedule servicegroup service downtime for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-01-30 09:59:22 +01:00
String triggeredBy ;
int triggeredByLegacy = Convert : : ToLong ( arguments [ 4 ] ) ;
2015-04-25 15:06:29 +02:00
int is_fixed = Convert : : ToLong ( arguments [ 3 ] ) ;
2013-01-30 09:59:22 +01:00
if ( triggeredByLegacy ! = 0 )
2015-08-20 17:18:48 +02:00
triggeredBy = Downtime : : GetDowntimeIDFromLegacyID ( triggeredByLegacy ) ;
2013-01-30 09:59:22 +01:00
2013-03-02 09:07:47 +01:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating downtime for service " < < service - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Downtime : : AddDowntime ( service , arguments [ 6 ] , arguments [ 7 ] ,
2013-01-29 14:19:54 +01:00
Convert : : ToDouble ( arguments [ 1 ] ) , Convert : : ToDouble ( arguments [ 2 ] ) ,
2015-04-25 15:06:29 +02:00
Convert : : ToBool ( is_fixed ) , triggeredBy , Convert : : ToDouble ( arguments [ 5 ] ) ) ;
2013-01-29 14:19:54 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AddHostComment ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot add host comment for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2016-04-25 16:52:09 +02:00
if ( arguments [ 2 ] . IsEmpty ( ) | | arguments [ 3 ] . IsEmpty ( ) )
2016-05-11 16:12:09 +02:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Author and comment must not be empty " ) ) ;
2016-04-25 16:52:09 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating comment for host " < < host - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Comment : : AddComment ( host , CommentUser , arguments [ 2 ] , arguments [ 3 ] , 0 ) ;
2013-01-29 16:29:09 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelHostComment ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
2013-01-30 09:59:22 +01:00
int id = Convert : : ToLong ( arguments [ 0 ] ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing comment ID " < < arguments [ 0 ] ;
2015-08-20 17:18:48 +02:00
String rid = Comment : : GetCommentIDFromLegacyID ( id ) ;
Comment : : RemoveComment ( rid ) ;
2013-01-29 16:29:09 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : AddSvcComment ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-29 16:29:09 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot add service comment for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2016-04-25 16:52:09 +02:00
if ( arguments [ 3 ] . IsEmpty ( ) | | arguments [ 4 ] . IsEmpty ( ) )
2016-05-11 16:12:09 +02:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Author and comment must not be empty " ) ) ;
2016-04-25 16:52:09 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Creating comment for service " < < service - > GetName ( ) ;
2015-08-20 17:18:48 +02:00
( void ) Comment : : AddComment ( service , CommentUser , arguments [ 3 ] , arguments [ 4 ] , 0 ) ;
2013-01-29 16:29:09 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelSvcComment ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
2013-01-30 09:59:22 +01:00
int id = Convert : : ToLong ( arguments [ 0 ] ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing comment ID " < < arguments [ 0 ] ;
2013-01-30 09:59:22 +01:00
2015-08-20 17:18:48 +02:00
String rid = Comment : : GetCommentIDFromLegacyID ( id ) ;
Comment : : RemoveComment ( rid ) ;
2013-01-29 16:29:09 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelAllHostComments ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot delete all host comments for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing all comments for host " < < host - > GetName ( ) ;
2014-04-03 15:36:13 +02:00
host - > RemoveAllComments ( ) ;
2013-01-29 16:29:09 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelAllSvcComments ( double , const std : : vector < String > & arguments )
2013-01-29 16:29:09 +01:00
{
2013-02-08 15:38:22 +01:00
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-01-29 16:29:09 +01:00
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot delete all service comments for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Removing all comments for service " < < service - > GetName ( ) ;
2013-02-09 01:16:43 +01:00
service - > RemoveAllComments ( ) ;
2013-01-29 16:29:09 +01:00
}
2013-02-09 15:20:10 +01:00
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : SendCustomHostNotification ( double , const std : : vector < String > & arguments )
2013-02-09 15:20:10 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot send custom host notification for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-21 13:22:26 +01:00
int options = Convert : : ToLong ( arguments [ 1 ] ) ;
2013-02-09 15:20:10 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Sending custom notification for host " < < host - > GetName ( ) ;
2014-04-03 15:36:13 +02:00
if ( options & 2 ) {
host - > SetForceNextNotification ( true ) ;
2013-03-21 13:22:26 +01:00
}
2014-04-03 15:36:13 +02:00
2016-06-07 12:44:12 +02:00
Checkable : : OnNotificationsRequested ( host , NotificationCustom ,
host - > GetLastCheckResult ( ) , arguments [ 2 ] , arguments [ 3 ] , MessageOrigin : : Ptr ( ) ) ;
2013-02-09 15:20:10 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : SendCustomSvcNotification ( double , const std : : vector < String > & arguments )
2013-02-09 15:20:10 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot send custom service notification for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-03-21 13:22:26 +01:00
int options = Convert : : ToLong ( arguments [ 2 ] ) ;
2013-02-09 15:20:10 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Sending custom notification for service " < < service - > GetName ( ) ;
2013-03-21 13:22:26 +01:00
if ( options & 2 ) {
service - > SetForceNextNotification ( true ) ;
}
2016-06-07 12:44:12 +02:00
Service : : OnNotificationsRequested ( service , NotificationCustom ,
service - > GetLastCheckResult ( ) , arguments [ 3 ] , arguments [ 4 ] , MessageOrigin : : Ptr ( ) ) ;
2013-02-09 15:20:10 +01:00
}
2013-02-26 12:37:25 +01:00
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelayHostNotification ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot delay host notification for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Delaying notifications for host ' " < < host - > GetName ( ) < < " ' " ;
2013-03-06 11:03:50 +01:00
2014-04-03 15:36:13 +02:00
BOOST_FOREACH ( const Notification : : Ptr & notification , host - > GetNotifications ( ) ) {
2013-03-20 10:08:27 +01:00
notification - > SetNextNotification ( Convert : : ToDouble ( arguments [ 1 ] ) ) ;
2013-02-26 12:37:25 +01:00
}
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DelaySvcNotification ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot delay service notification for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Delaying notifications for service " < < service - > GetName ( ) ;
2013-03-06 11:03:50 +01:00
2013-03-20 10:08:27 +01:00
BOOST_FOREACH ( const Notification : : Ptr & notification , service - > GetNotifications ( ) ) {
notification - > SetNextNotification ( Convert : : ToDouble ( arguments [ 2 ] ) ) ;
2013-03-06 11:03:50 +01:00
}
2013-02-26 12:37:25 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableHostNotifications ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host notifications for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , true ) ;
2013-02-26 12:37:25 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableHostNotifications ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host notifications for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for host ' " < < arguments [ 0 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , false ) ;
2013-02-26 12:37:25 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : EnableSvcNotifications ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service notifications for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , true ) ;
2013-02-26 12:37:25 +01:00
}
2013-03-16 21:18:53 +01:00
void ExternalCommandProcessor : : DisableSvcNotifications ( double , const std : : vector < String > & arguments )
2013-02-26 12:37:25 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service notifications for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for service ' " < < arguments [ 1 ] < < " ' " ;
2013-03-06 11:03:50 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , false ) ;
2013-02-26 12:37:25 +01:00
}
2013-04-15 10:23:06 +02:00
2015-02-11 16:45:52 +01:00
void ExternalCommandProcessor : : EnableHostSvcNotifications ( double , const std : : vector < String > & arguments )
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable notifications for all services for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for all services on host ' " < < arguments [ 0 ] < < " ' " ;
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , true ) ;
2015-02-11 16:45:52 +01:00
}
}
void ExternalCommandProcessor : : DisableHostSvcNotifications ( double , const std : : vector < String > & arguments )
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable notifications for all services for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for all services on host ' " < < arguments [ 0 ] < < " ' " ;
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , false ) ;
2015-02-11 16:45:52 +01:00
}
}
2013-04-15 10:23:06 +02:00
void ExternalCommandProcessor : : DisableHostgroupHostChecks ( double , const std : : vector < String > & arguments )
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable hostgroup host checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : DisableHostgroupPassiveHostChecks ( double , const std : : vector < String > & arguments )
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable hostgroup passive host checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : DisableServicegroupHostChecks ( double , const std : : vector < String > & arguments )
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable servicegroup host checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling active checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , false ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : DisableServicegroupPassiveHostChecks ( double , const std : : vector < String > & arguments )
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable servicegroup passive host checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling passive checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , false ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : EnableHostgroupHostChecks ( double , const std : : vector < String > & arguments )
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable hostgroup host checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : EnableHostgroupPassiveHostChecks ( double , const std : : vector < String > & arguments )
{
2014-01-20 16:04:02 +01:00
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable hostgroup passive host checks for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for host ' " < < host - > GetName ( ) < < " ' " ;
2014-01-20 16:04:02 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2014-01-20 16:04:02 +01:00
}
2013-04-15 10:23:06 +02:00
}
void ExternalCommandProcessor : : EnableServicegroupHostChecks ( double , const std : : vector < String > & arguments )
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable servicegroup host checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling active checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_active_checks " , true ) ;
2013-04-15 10:23:06 +02:00
}
}
void ExternalCommandProcessor : : EnableServicegroupPassiveHostChecks ( double , const std : : vector < String > & arguments )
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable servicegroup passive host checks for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
2013-04-15 10:23:06 +02:00
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling passive checks for host ' " < < host - > GetName ( ) < < " ' " ;
2013-04-15 10:23:06 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_passive_checks " , true ) ;
2013-04-15 10:23:06 +02:00
}
}
2013-06-21 10:28:21 +02:00
void ExternalCommandProcessor : : EnableHostFlapping ( double , const std : : vector < String > & arguments )
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host flapping for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling flapping detection for host ' " < < arguments [ 0 ] < < " ' " ;
2013-06-21 10:28:21 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_flapping " , true ) ;
2013-06-21 10:28:21 +02:00
}
void ExternalCommandProcessor : : DisableHostFlapping ( double , const std : : vector < String > & arguments )
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host flapping for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling flapping detection for host ' " < < arguments [ 0 ] < < " ' " ;
2013-06-21 10:28:21 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_flapping " , false ) ;
2013-06-21 10:28:21 +02:00
}
void ExternalCommandProcessor : : EnableSvcFlapping ( double , const std : : vector < String > & arguments )
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service flapping for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling flapping detection for service ' " < < arguments [ 1 ] < < " ' " ;
2013-06-21 10:28:21 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_flapping " , true ) ;
2013-06-21 10:28:21 +02:00
}
void ExternalCommandProcessor : : DisableSvcFlapping ( double , const std : : vector < String > & arguments )
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
2013-09-27 12:24:30 +02:00
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service flapping for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling flapping detection for service ' " < < arguments [ 1 ] < < " ' " ;
2013-06-21 10:28:21 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_flapping " , false ) ;
2013-07-01 11:17:58 +02:00
}
2013-10-08 11:57:35 +02:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableNotifications ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling notifications. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_notifications " , true ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableNotifications ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling notifications. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_notifications " , false ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableFlapDetection ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling flap detection. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_flapping " , true ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableFlapDetection ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling flap detection. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_flapping " , false ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableEventHandlers ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling event handlers. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_event_handlers " , true ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableEventHandlers ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling event handlers. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_event_handlers " , false ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnablePerformanceData ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling performance data processing. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_perfdata " , true ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisablePerformanceData ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling performance data processing. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_perfdata " , false ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : StartExecutingSvcChecks ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling service checks. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_service_checks " , true ) ;
2013-10-08 11:57:35 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : StopExecutingSvcChecks ( double , const std : : vector < String > & )
2013-10-08 11:57:35 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling service checks. " ) ;
2013-10-08 11:57:35 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_service_checks " , false ) ;
2014-04-17 11:29:47 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : StartExecutingHostChecks ( double , const std : : vector < String > & )
2014-04-17 11:29:47 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally enabling host checks. " ) ;
2014-04-17 11:29:47 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_host_checks " , true ) ;
2014-04-17 11:29:47 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : StopExecutingHostChecks ( double , const std : : vector < String > & )
2014-04-17 11:29:47 +02:00
{
2014-05-28 13:45:45 +02:00
Log ( LogNotice , " ExternalCommandProcessor " , " Globally disabling host checks. " ) ;
2014-04-17 11:29:47 +02:00
2016-01-21 19:07:54 +01:00
IcingaApplication : : GetInstance ( ) - > ModifyAttribute ( " enable_host_checks " , false ) ;
2013-10-08 11:57:35 +02:00
}
2013-10-16 11:46:54 +02:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeNormalSvcCheckInterval ( double , const std : : vector < String > & arguments )
2013-10-16 13:02:21 +02:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot update check interval for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-10-16 13:07:59 +02:00
double interval = Convert : : ToDouble ( arguments [ 2 ] ) ;
2013-10-16 13:02:21 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Updating check interval for service ' " < < arguments [ 1 ] < < " ' " ;
2013-10-16 13:02:21 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " check_interval " , interval * 60 ) ;
2013-10-16 13:02:21 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeNormalHostCheckInterval ( double , const std : : vector < String > & arguments )
2013-10-16 13:02:21 +02:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot update check interval for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Updating check interval for host ' " < < arguments [ 0 ] < < " ' " ;
2013-12-11 11:46:12 +01:00
2013-10-16 13:07:59 +02:00
double interval = Convert : : ToDouble ( arguments [ 1 ] ) ;
2013-10-16 13:02:21 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " check_interval " , interval * 60 ) ;
2013-10-16 13:02:21 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeRetrySvcCheckInterval ( double , const std : : vector < String > & arguments )
2013-10-16 13:02:21 +02:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot update retry interval for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-10-16 13:07:59 +02:00
double interval = Convert : : ToDouble ( arguments [ 2 ] ) ;
2013-10-16 13:02:21 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Updating retry interval for service ' " < < arguments [ 1 ] < < " ' " ;
2013-10-16 13:02:21 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " retry_interval " , interval * 60 ) ;
2013-10-16 13:02:21 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeRetryHostCheckInterval ( double , const std : : vector < String > & arguments )
2013-10-16 13:02:21 +02:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot update retry interval for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Updating retry interval for host ' " < < arguments [ 0 ] < < " ' " ;
2013-12-11 11:46:12 +01:00
2013-10-16 13:07:59 +02:00
double interval = Convert : : ToDouble ( arguments [ 1 ] ) ;
2013-10-16 13:02:21 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " retry_interval " , interval * 60 ) ;
2013-10-16 15:20:14 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableHostEventHandler ( double , const std : : vector < String > & arguments )
2013-10-16 15:20:14 +02:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable event handler for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling event handler for host ' " < < arguments [ 0 ] < < " ' " ;
2013-10-16 15:20:14 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_event_handler " , true ) ;
2013-10-16 15:20:14 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableHostEventHandler ( double , const std : : vector < String > & arguments )
2013-10-16 15:20:14 +02:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable event handler for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling event handler for host ' " < < arguments [ 0 ] < < " ' " ;
2013-10-16 15:20:14 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_event_handler " , false ) ;
2013-10-16 15:20:14 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableSvcEventHandler ( double , const std : : vector < String > & arguments )
2013-10-16 15:20:14 +02:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
2013-11-26 12:31:17 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable event handler for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-10-16 15:20:14 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling event handler for service ' " < < arguments [ 1 ] < < " ' " ;
2013-10-16 15:20:14 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_event_handler " , true ) ;
2013-10-16 15:20:14 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableSvcEventHandler ( double , const std : : vector < String > & arguments )
2013-10-16 15:20:14 +02:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
2013-11-26 12:31:17 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable event handler for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-10-16 15:20:14 +02:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling event handler for service ' " < < arguments [ 1 ] + " ' " ;
2013-10-16 15:20:14 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_event_handler " , false ) ;
2013-10-16 15:20:14 +02:00
}
2013-11-26 12:31:17 +01:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeHostEventHandler ( double , const std : : vector < String > & arguments )
2013-11-26 12:31:17 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change event handler for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-03-17 18:52:23 +01:00
if ( arguments [ 1 ] . IsEmpty ( ) ) {
2015-08-04 14:47:44 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Unsetting event handler for host ' " < < arguments [ 0 ] < < " ' " ;
host - > ModifyAttribute ( " event_command " , " " ) ;
2014-03-17 18:52:23 +01:00
} else {
EventCommand : : Ptr command = EventCommand : : GetByName ( arguments [ 1 ] ) ;
2013-11-26 12:31:17 +01:00
2014-03-17 18:52:23 +01:00
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Event command ' " + arguments [ 1 ] + " ' does not exist. " ) ) ;
2013-11-26 12:31:17 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing event handler for host ' " < < arguments [ 0 ] < < " ' to ' " < < arguments [ 1 ] < < " ' " ;
2013-11-26 12:31:17 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " event_command " , command - > GetName ( ) ) ;
2013-11-26 12:31:17 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeSvcEventHandler ( double , const std : : vector < String > & arguments )
2013-11-26 12:31:17 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
2013-11-26 12:56:42 +01:00
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change event handler for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-11-26 12:31:17 +01:00
2014-03-17 18:52:23 +01:00
if ( arguments [ 2 ] . IsEmpty ( ) ) {
2015-08-04 14:47:44 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Unsetting event handler for service ' " < < arguments [ 1 ] < < " ' " ;
service - > ModifyAttribute ( " event_command " , " " ) ;
2014-03-17 18:52:23 +01:00
} else {
EventCommand : : Ptr command = EventCommand : : GetByName ( arguments [ 2 ] ) ;
2013-11-26 12:31:17 +01:00
2014-03-17 18:52:23 +01:00
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Event command ' " + arguments [ 2 ] + " ' does not exist. " ) ) ;
2013-11-26 12:31:17 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing event handler for service ' " < < arguments [ 1 ] < < " ' to ' " < < arguments [ 2 ] < < " ' " ;
2013-11-26 12:31:17 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " event_command " , command - > GetName ( ) ) ;
2013-11-26 12:31:17 +01:00
}
}
2013-11-26 12:56:42 +01:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeHostCheckCommand ( double , const std : : vector < String > & arguments )
2013-11-26 12:56:42 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change check command for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-12-18 14:41:19 +01:00
CheckCommand : : Ptr command = CheckCommand : : GetByName ( arguments [ 1 ] ) ;
2013-11-26 12:56:42 +01:00
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Check command ' " + arguments [ 1 ] + " ' does not exist. " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing check command for host ' " < < arguments [ 0 ] < < " ' to ' " < < arguments [ 1 ] < < " ' " ;
2013-11-26 12:56:42 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " check_command " , command - > GetName ( ) ) ;
2013-11-26 12:56:42 +01:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeSvcCheckCommand ( double , const std : : vector < String > & arguments )
2013-11-26 12:56:42 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change check command for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
CheckCommand : : Ptr command = CheckCommand : : GetByName ( arguments [ 2 ] ) ;
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Check command ' " + arguments [ 2 ] + " ' does not exist. " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing check command for service ' " < < arguments [ 1 ] < < " ' to ' " < < arguments [ 2 ] < < " ' " ;
2013-11-26 12:56:42 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " check_command " , command - > GetName ( ) ) ;
2013-11-26 12:56:42 +01:00
}
2013-11-26 13:27:41 +01:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeMaxHostCheckAttempts ( double , const std : : vector < String > & arguments )
2013-11-26 13:27:41 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change max check attempts for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-12-18 14:41:19 +01:00
int attempts = Convert : : ToLong ( arguments [ 1 ] ) ;
2013-11-26 13:27:41 +01:00
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing max check attempts for host ' " < < arguments [ 0 ] < < " ' to ' " < < arguments [ 1 ] < < " ' " ;
2013-11-26 13:27:41 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " max_check_attempts " , attempts ) ;
2013-11-26 13:27:41 +01:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeMaxSvcCheckAttempts ( double , const std : : vector < String > & arguments )
2013-11-26 13:27:41 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change max check attempts for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
int attempts = Convert : : ToLong ( arguments [ 2 ] ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing max check attempts for service ' " < < arguments [ 1 ] < < " ' to ' " < < arguments [ 2 ] < < " ' " ;
2013-11-26 13:27:41 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " max_check_attempts " , attempts ) ;
2013-11-26 13:27:41 +01:00
}
2013-11-26 13:43:56 +01:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeHostCheckTimeperiod ( double , const std : : vector < String > & arguments )
2013-11-26 13:43:56 +01:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change check period for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2013-12-18 14:41:19 +01:00
TimePeriod : : Ptr tp = TimePeriod : : GetByName ( arguments [ 1 ] ) ;
2013-11-26 13:43:56 +01:00
if ( ! tp )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Time period ' " + arguments [ 1 ] + " ' does not exist. " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing check period for host ' " < < arguments [ 0 ] < < " ' to ' " < < arguments [ 1 ] < < " ' " ;
2013-11-26 13:43:56 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " check_period " , tp - > GetName ( ) ) ;
2013-11-26 13:43:56 +01:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeSvcCheckTimeperiod ( double , const std : : vector < String > & arguments )
2013-11-26 13:43:56 +01:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change check period for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
TimePeriod : : Ptr tp = TimePeriod : : GetByName ( arguments [ 2 ] ) ;
if ( ! tp )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Time period ' " + arguments [ 2 ] + " ' does not exist. " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing check period for service ' " < < arguments [ 1 ] < < " ' to ' " < < arguments [ 2 ] < < " ' " ;
2013-11-26 13:43:56 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " check_period " , tp - > GetName ( ) ) ;
2013-12-11 11:46:12 +01:00
}
2014-01-20 16:58:18 +01:00
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomHostVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
Host : : Ptr host = Host : : GetByName ( arguments [ 0 ] ) ;
if ( ! host )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing custom var ' " < < arguments [ 1 ] < < " ' for host ' " < < arguments [ 0 ] < < " ' to value ' " < < arguments [ 2 ] < < " ' " ;
2014-04-15 17:33:56 +02:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " vars. " + arguments [ 1 ] , arguments [ 2 ] ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomSvcVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
Service : : Ptr service = Service : : GetByNamePair ( arguments [ 0 ] , arguments [ 1 ] ) ;
if ( ! service )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent service ' " + arguments [ 1 ] + " ' on host ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing custom var ' " < < arguments [ 2 ] < < " ' for service ' " < < arguments [ 1 ] < < " ' on host ' "
< < arguments [ 0 ] < < " ' to value ' " < < arguments [ 3 ] < < " ' " ;
2014-04-15 17:33:56 +02:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " vars. " + arguments [ 2 ] , arguments [ 3 ] ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomUserVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
User : : Ptr user = User : : GetByName ( arguments [ 0 ] ) ;
if ( ! user )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent user ' " + arguments [ 0 ] + " ' " ) ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing custom var ' " < < arguments [ 1 ] < < " ' for user ' " < < arguments [ 0 ] < < " ' to value ' " < < arguments [ 2 ] < < " ' " ;
2014-04-15 17:33:56 +02:00
2015-08-04 14:47:44 +02:00
user - > ModifyAttribute ( " vars. " + arguments [ 1 ] , arguments [ 2 ] ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomCheckcommandVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
CheckCommand : : Ptr command = CheckCommand : : GetByName ( arguments [ 0 ] ) ;
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent command ' " + arguments [ 0 ] + " ' " ) ) ;
2014-04-17 15:20:28 +02:00
ChangeCustomCommandVarInternal ( command , arguments [ 1 ] , arguments [ 2 ] ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomEventcommandVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
EventCommand : : Ptr command = EventCommand : : GetByName ( arguments [ 0 ] ) ;
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent command ' " + arguments [ 0 ] + " ' " ) ) ;
2014-04-17 15:20:28 +02:00
ChangeCustomCommandVarInternal ( command , arguments [ 1 ] , arguments [ 2 ] ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : ChangeCustomNotificationcommandVar ( double , const std : : vector < String > & arguments )
2014-04-15 17:33:56 +02:00
{
NotificationCommand : : Ptr command = NotificationCommand : : GetByName ( arguments [ 0 ] ) ;
if ( ! command )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot change custom var for non-existent command ' " + arguments [ 0 ] + " ' " ) ) ;
2014-04-17 15:20:28 +02:00
ChangeCustomCommandVarInternal ( command , arguments [ 1 ] , arguments [ 2 ] ) ;
}
void ExternalCommandProcessor : : ChangeCustomCommandVarInternal ( const Command : : Ptr & command , const String & name , const Value & value )
{
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Changing custom var ' " < < name < < " ' for command ' " < < command - > GetName ( ) < < " ' to value ' " < < value < < " ' " ;
2014-04-15 17:33:56 +02:00
2015-08-04 14:47:44 +02:00
command - > ModifyAttribute ( " vars. " + name , value ) ;
2014-04-15 17:33:56 +02:00
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableHostgroupHostNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host notifications for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for host ' " < < host - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , true ) ;
2014-01-20 16:58:18 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableHostgroupSvcNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service notifications for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , true ) ;
2014-01-20 16:58:18 +01:00
}
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableHostgroupHostNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host notifications for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for host ' " < < host - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , false ) ;
2014-01-20 16:58:18 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableHostgroupSvcNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
HostGroup : : Ptr hg = HostGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! hg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service notifications for non-existent hostgroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Host : : Ptr & host , hg - > GetMembers ( ) ) {
BOOST_FOREACH ( const Service : : Ptr & service , host - > GetServices ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , false ) ;
2014-01-20 16:58:18 +01:00
}
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableServicegroupHostNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable host notifications for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for host ' " < < host - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , true ) ;
2014-01-20 16:58:18 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : EnableServicegroupSvcNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot enable service notifications for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Enabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , true ) ;
2014-01-20 16:58:18 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableServicegroupHostNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable host notifications for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
Host : : Ptr host = service - > GetHost ( ) ;
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for host ' " < < host - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
host - > ModifyAttribute ( " enable_notifications " , false ) ;
2014-01-20 16:58:18 +01:00
}
}
2014-05-11 06:30:50 +02:00
void ExternalCommandProcessor : : DisableServicegroupSvcNotifications ( double , const std : : vector < String > & arguments )
2014-01-20 16:58:18 +01:00
{
ServiceGroup : : Ptr sg = ServiceGroup : : GetByName ( arguments [ 0 ] ) ;
if ( ! sg )
BOOST_THROW_EXCEPTION ( std : : invalid_argument ( " Cannot disable service notifications for non-existent servicegroup ' " + arguments [ 0 ] + " ' " ) ) ;
BOOST_FOREACH ( const Service : : Ptr & service , sg - > GetMembers ( ) ) {
2014-10-20 10:09:57 +02:00
Log ( LogNotice , " ExternalCommandProcessor " )
< < " Disabling notifications for service ' " < < service - > GetName ( ) < < " ' " ;
2014-01-20 16:58:18 +01:00
2015-08-04 14:47:44 +02:00
service - > ModifyAttribute ( " enable_notifications " , false ) ;
2014-01-20 16:58:18 +01:00
}
}