5224 lines
150 KiB
C
5224 lines
150 KiB
C
/*****************************************************************************
|
|
*
|
|
* COMMANDS.C - External command functions for Nagios
|
|
*
|
|
* Copyright (c) 1999-2008 Ethan Galstad (egalstad@nagios.org)
|
|
* Last Modified: 11-30-2008
|
|
*
|
|
* License:
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*
|
|
* 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., 675 Mass Ave, Cambridge, MA 02139, USA.
|
|
*
|
|
*****************************************************************************/
|
|
|
|
#include "../include/config.h"
|
|
#include "../include/common.h"
|
|
#include "../include/comments.h"
|
|
#include "../include/downtime.h"
|
|
#include "../include/statusdata.h"
|
|
#include "../include/perfdata.h"
|
|
#include "../include/sretention.h"
|
|
#include "../include/broker.h"
|
|
#include "../include/nagios.h"
|
|
|
|
extern char *config_file;
|
|
extern char *log_file;
|
|
extern char *command_file;
|
|
extern char *temp_file;
|
|
extern char *temp_path;
|
|
|
|
extern int sigshutdown;
|
|
extern int sigrestart;
|
|
|
|
extern int check_external_commands;
|
|
|
|
extern int ipc_pipe[2];
|
|
|
|
extern time_t last_command_check;
|
|
extern time_t last_command_status_update;
|
|
|
|
extern int command_check_interval;
|
|
|
|
extern int enable_notifications;
|
|
extern int execute_service_checks;
|
|
extern int accept_passive_service_checks;
|
|
extern int execute_host_checks;
|
|
extern int accept_passive_host_checks;
|
|
extern int enable_event_handlers;
|
|
extern int obsess_over_services;
|
|
extern int obsess_over_hosts;
|
|
extern int check_service_freshness;
|
|
extern int check_host_freshness;
|
|
extern int enable_failure_prediction;
|
|
extern int process_performance_data;
|
|
|
|
extern int log_external_commands;
|
|
extern int log_passive_checks;
|
|
|
|
extern unsigned long modified_host_process_attributes;
|
|
extern unsigned long modified_service_process_attributes;
|
|
|
|
extern char *global_host_event_handler;
|
|
extern char *global_service_event_handler;
|
|
extern command *global_host_event_handler_ptr;
|
|
extern command *global_service_event_handler_ptr;
|
|
|
|
extern host *host_list;
|
|
extern service *service_list;
|
|
|
|
extern FILE *command_file_fp;
|
|
extern int command_file_fd;
|
|
|
|
passive_check_result *passive_check_result_list = NULL;
|
|
passive_check_result *passive_check_result_list_tail = NULL;
|
|
|
|
extern pthread_t worker_threads[TOTAL_WORKER_THREADS];
|
|
extern circular_buffer external_command_buffer;
|
|
extern int external_command_buffer_slots;
|
|
|
|
|
|
|
|
/******************************************************************/
|
|
/****************** EXTERNAL COMMAND PROCESSING *******************/
|
|
/******************************************************************/
|
|
|
|
|
|
/* checks for the existence of the external command file and processes all commands found in it */
|
|
int check_for_external_commands(void) {
|
|
char *buffer = NULL;
|
|
int update_status = FALSE;
|
|
|
|
log_debug_info(DEBUGL_FUNCTIONS, 0, "check_for_external_commands()\n");
|
|
|
|
/* bail out if we shouldn't be checking for external commands */
|
|
if(check_external_commands == FALSE)
|
|
return ERROR;
|
|
|
|
/* update last command check time */
|
|
last_command_check = time(NULL);
|
|
|
|
/* update the status log with new program information */
|
|
/* go easy on the frequency of this if we're checking often - only update program status every 10 seconds.... */
|
|
if(last_command_check < (last_command_status_update + 10))
|
|
update_status = FALSE;
|
|
else
|
|
update_status = TRUE;
|
|
if(update_status == TRUE) {
|
|
last_command_status_update = last_command_check;
|
|
update_program_status(FALSE);
|
|
}
|
|
|
|
/* reset passive check result list pointers */
|
|
passive_check_result_list = NULL;
|
|
passive_check_result_list_tail = NULL;
|
|
|
|
/* process all commands found in the buffer */
|
|
while(1) {
|
|
|
|
/* get a lock on the buffer */
|
|
pthread_mutex_lock(&external_command_buffer.buffer_lock);
|
|
|
|
/* if no items present, bail out */
|
|
if(external_command_buffer.items <= 0) {
|
|
pthread_mutex_unlock(&external_command_buffer.buffer_lock);
|
|
break;
|
|
}
|
|
|
|
if(external_command_buffer.buffer[external_command_buffer.tail])
|
|
buffer = strdup(((char **)external_command_buffer.buffer)[external_command_buffer.tail]);
|
|
|
|
/* free memory allocated for buffer slot */
|
|
my_free(((char **)external_command_buffer.buffer)[external_command_buffer.tail]);
|
|
|
|
/* adjust tail counter and number of items */
|
|
external_command_buffer.tail = (external_command_buffer.tail + 1) % external_command_buffer_slots;
|
|
external_command_buffer.items--;
|
|
|
|
/* release the lock on the buffer */
|
|
pthread_mutex_unlock(&external_command_buffer.buffer_lock);
|
|
|
|
/* process the command */
|
|
process_external_command1(buffer);
|
|
|
|
/* free memory */
|
|
my_free(buffer);
|
|
}
|
|
|
|
/**** PROCESS ALL PASSIVE HOST AND SERVICE CHECK RESULTS AT ONE TIME ****/
|
|
if(passive_check_result_list != NULL)
|
|
process_passive_checks();
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* processes all external commands in a (regular) file */
|
|
int process_external_commands_from_file(char *fname, int delete_file) {
|
|
mmapfile *thefile = NULL;
|
|
char *input = NULL;
|
|
|
|
|
|
log_debug_info(DEBUGL_FUNCTIONS, 0, "process_external_commands_from_file()\n");
|
|
|
|
if(fname == NULL)
|
|
return ERROR;
|
|
|
|
log_debug_info(DEBUGL_EXTERNALCOMMANDS, 1, "Processing commands from file '%s'. File will %s deleted after processing.\n", fname, (delete_file == TRUE) ? "be" : "NOT be");
|
|
|
|
/* open the config file for reading */
|
|
if((thefile = mmap_fopen(fname)) == NULL) {
|
|
logit(NSLOG_INFO_MESSAGE, FALSE, "Error: Cannot open file '%s' to process external commands!", fname);
|
|
return ERROR;
|
|
}
|
|
|
|
/* process all commands in the file */
|
|
while(1) {
|
|
|
|
/* free memory */
|
|
my_free(input);
|
|
|
|
/* read the next line */
|
|
if((input = mmap_fgets(thefile)) == NULL)
|
|
break;
|
|
|
|
/* process the command */
|
|
process_external_command1(input);
|
|
}
|
|
|
|
/* close the file */
|
|
mmap_fclose(thefile);
|
|
|
|
/* delete the file */
|
|
if(delete_file == TRUE)
|
|
unlink(fname);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* top-level external command processor */
|
|
int process_external_command1(char *cmd) {
|
|
char *temp_buffer = NULL;
|
|
char *command_id = NULL;
|
|
char *args = NULL;
|
|
time_t entry_time = 0L;
|
|
int command_type = CMD_NONE;
|
|
char *temp_ptr = NULL;
|
|
|
|
log_debug_info(DEBUGL_FUNCTIONS, 0, "process_external_command1()\n");
|
|
|
|
if(cmd == NULL)
|
|
return ERROR;
|
|
|
|
/* strip the command of newlines and carriage returns */
|
|
strip(cmd);
|
|
|
|
log_debug_info(DEBUGL_EXTERNALCOMMANDS, 2, "Raw command entry: %s\n", cmd);
|
|
|
|
/* get the command entry time */
|
|
if((temp_ptr = my_strtok(cmd, "[")) == NULL)
|
|
return ERROR;
|
|
if((temp_ptr = my_strtok(NULL, "]")) == NULL)
|
|
return ERROR;
|
|
entry_time = (time_t)strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* get the command identifier */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
if((command_id = (char *)strdup(temp_ptr + 1)) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the command arguments */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
args = (char *)strdup("");
|
|
else
|
|
args = (char *)strdup(temp_ptr);
|
|
if(args == NULL) {
|
|
my_free(command_id);
|
|
return ERROR;
|
|
}
|
|
|
|
/* decide what type of command this is... */
|
|
|
|
/**************************/
|
|
/**** PROCESS COMMANDS ****/
|
|
/**************************/
|
|
|
|
if(!strcmp(command_id, "ENTER_STANDBY_MODE") || !strcmp(command_id, "DISABLE_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "ENTER_ACTIVE_MODE") || !strcmp(command_id, "ENABLE_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "SHUTDOWN_PROGRAM") || !strcmp(command_id, "SHUTDOWN_PROCESS"))
|
|
command_type = CMD_SHUTDOWN_PROCESS;
|
|
else if(!strcmp(command_id, "RESTART_PROGRAM") || !strcmp(command_id, "RESTART_PROCESS"))
|
|
command_type = CMD_RESTART_PROCESS;
|
|
|
|
else if(!strcmp(command_id, "SAVE_STATE_INFORMATION"))
|
|
command_type = CMD_SAVE_STATE_INFORMATION;
|
|
else if(!strcmp(command_id, "READ_STATE_INFORMATION"))
|
|
command_type = CMD_READ_STATE_INFORMATION;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_EVENT_HANDLERS"))
|
|
command_type = CMD_ENABLE_EVENT_HANDLERS;
|
|
else if(!strcmp(command_id, "DISABLE_EVENT_HANDLERS"))
|
|
command_type = CMD_DISABLE_EVENT_HANDLERS;
|
|
|
|
else if(!strcmp(command_id, "FLUSH_PENDING_COMMANDS"))
|
|
command_type = CMD_FLUSH_PENDING_COMMANDS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_FAILURE_PREDICTION"))
|
|
command_type = CMD_ENABLE_FAILURE_PREDICTION;
|
|
else if(!strcmp(command_id, "DISABLE_FAILURE_PREDICTION"))
|
|
command_type = CMD_DISABLE_FAILURE_PREDICTION;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_PERFORMANCE_DATA"))
|
|
command_type = CMD_ENABLE_PERFORMANCE_DATA;
|
|
else if(!strcmp(command_id, "DISABLE_PERFORMANCE_DATA"))
|
|
command_type = CMD_DISABLE_PERFORMANCE_DATA;
|
|
|
|
else if(!strcmp(command_id, "START_EXECUTING_HOST_CHECKS"))
|
|
command_type = CMD_START_EXECUTING_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_EXECUTING_HOST_CHECKS"))
|
|
command_type = CMD_STOP_EXECUTING_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "START_EXECUTING_SVC_CHECKS"))
|
|
command_type = CMD_START_EXECUTING_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_EXECUTING_SVC_CHECKS"))
|
|
command_type = CMD_STOP_EXECUTING_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "START_ACCEPTING_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_START_ACCEPTING_PASSIVE_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_ACCEPTING_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_STOP_ACCEPTING_PASSIVE_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "START_ACCEPTING_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_START_ACCEPTING_PASSIVE_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_ACCEPTING_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_STOP_ACCEPTING_PASSIVE_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "START_OBSESSING_OVER_HOST_CHECKS"))
|
|
command_type = CMD_START_OBSESSING_OVER_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_OBSESSING_OVER_HOST_CHECKS"))
|
|
command_type = CMD_STOP_OBSESSING_OVER_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "START_OBSESSING_OVER_SVC_CHECKS"))
|
|
command_type = CMD_START_OBSESSING_OVER_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "STOP_OBSESSING_OVER_SVC_CHECKS"))
|
|
command_type = CMD_STOP_OBSESSING_OVER_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_FLAP_DETECTION"))
|
|
command_type = CMD_ENABLE_FLAP_DETECTION;
|
|
else if(!strcmp(command_id, "DISABLE_FLAP_DETECTION"))
|
|
command_type = CMD_DISABLE_FLAP_DETECTION;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_GLOBAL_HOST_EVENT_HANDLER"))
|
|
command_type = CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER;
|
|
else if(!strcmp(command_id, "CHANGE_GLOBAL_SVC_EVENT_HANDLER"))
|
|
command_type = CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICE_FRESHNESS_CHECKS"))
|
|
command_type = CMD_ENABLE_SERVICE_FRESHNESS_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICE_FRESHNESS_CHECKS"))
|
|
command_type = CMD_DISABLE_SERVICE_FRESHNESS_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_FRESHNESS_CHECKS"))
|
|
command_type = CMD_ENABLE_HOST_FRESHNESS_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_FRESHNESS_CHECKS"))
|
|
command_type = CMD_DISABLE_HOST_FRESHNESS_CHECKS;
|
|
|
|
|
|
/*******************************/
|
|
/**** HOST-RELATED COMMANDS ****/
|
|
/*******************************/
|
|
|
|
else if(!strcmp(command_id, "ADD_HOST_COMMENT"))
|
|
command_type = CMD_ADD_HOST_COMMENT;
|
|
else if(!strcmp(command_id, "DEL_HOST_COMMENT"))
|
|
command_type = CMD_DEL_HOST_COMMENT;
|
|
else if(!strcmp(command_id, "DEL_ALL_HOST_COMMENTS"))
|
|
command_type = CMD_DEL_ALL_HOST_COMMENTS;
|
|
|
|
else if(!strcmp(command_id, "DELAY_HOST_NOTIFICATION"))
|
|
command_type = CMD_DELAY_HOST_NOTIFICATION;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_HOST_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_HOST_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST"))
|
|
command_type = CMD_ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST;
|
|
else if(!strcmp(command_id, "DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST"))
|
|
command_type = CMD_DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_AND_CHILD_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_HOST_AND_CHILD_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_AND_CHILD_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_HOST_AND_CHILD_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_HOST_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_HOST_SVC_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_HOST_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_HOST_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_ENABLE_PASSIVE_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_DISABLE_PASSIVE_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_HOST_SVC_CHECKS"))
|
|
command_type = CMD_SCHEDULE_HOST_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "SCHEDULE_FORCED_HOST_SVC_CHECKS"))
|
|
command_type = CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ACKNOWLEDGE_HOST_PROBLEM"))
|
|
command_type = CMD_ACKNOWLEDGE_HOST_PROBLEM;
|
|
else if(!strcmp(command_id, "REMOVE_HOST_ACKNOWLEDGEMENT"))
|
|
command_type = CMD_REMOVE_HOST_ACKNOWLEDGEMENT;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_EVENT_HANDLER"))
|
|
command_type = CMD_ENABLE_HOST_EVENT_HANDLER;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_EVENT_HANDLER"))
|
|
command_type = CMD_DISABLE_HOST_EVENT_HANDLER;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_CHECK"))
|
|
command_type = CMD_ENABLE_HOST_CHECK;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_CHECK"))
|
|
command_type = CMD_DISABLE_HOST_CHECK;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_HOST_CHECK"))
|
|
command_type = CMD_SCHEDULE_HOST_CHECK;
|
|
else if(!strcmp(command_id, "SCHEDULE_FORCED_HOST_CHECK"))
|
|
command_type = CMD_SCHEDULE_FORCED_HOST_CHECK;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_HOST_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_HOST_DOWNTIME;
|
|
else if(!strcmp(command_id, "SCHEDULE_HOST_SVC_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_HOST_SVC_DOWNTIME;
|
|
else if(!strcmp(command_id, "DEL_HOST_DOWNTIME"))
|
|
command_type = CMD_DEL_HOST_DOWNTIME;
|
|
else if(!strcmp(command_id, "DEL_DOWNTIME_BY_HOST_NAME"))
|
|
command_type = CMD_DEL_DOWNTIME_BY_HOST_NAME;
|
|
else if(!strcmp(command_id, "DEL_DOWNTIME_BY_HOSTGROUP_NAME"))
|
|
command_type = CMD_DEL_DOWNTIME_BY_HOSTGROUP_NAME;
|
|
else if(!strcmp(command_id, "DEL_DOWNTIME_BY_START_TIME_COMMENT"))
|
|
command_type = CMD_DEL_DOWNTIME_BY_START_TIME_COMMENT;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOST_FLAP_DETECTION"))
|
|
command_type = CMD_ENABLE_HOST_FLAP_DETECTION;
|
|
else if(!strcmp(command_id, "DISABLE_HOST_FLAP_DETECTION"))
|
|
command_type = CMD_DISABLE_HOST_FLAP_DETECTION;
|
|
|
|
else if(!strcmp(command_id, "START_OBSESSING_OVER_HOST"))
|
|
command_type = CMD_START_OBSESSING_OVER_HOST;
|
|
else if(!strcmp(command_id, "STOP_OBSESSING_OVER_HOST"))
|
|
command_type = CMD_STOP_OBSESSING_OVER_HOST;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_HOST_EVENT_HANDLER"))
|
|
command_type = CMD_CHANGE_HOST_EVENT_HANDLER;
|
|
else if(!strcmp(command_id, "CHANGE_HOST_CHECK_COMMAND"))
|
|
command_type = CMD_CHANGE_HOST_CHECK_COMMAND;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_NORMAL_HOST_CHECK_INTERVAL"))
|
|
command_type = CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL;
|
|
else if(!strcmp(command_id, "CHANGE_RETRY_HOST_CHECK_INTERVAL"))
|
|
command_type = CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_MAX_HOST_CHECK_ATTEMPTS"))
|
|
command_type = CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME;
|
|
|
|
else if(!strcmp(command_id, "SET_HOST_NOTIFICATION_NUMBER"))
|
|
command_type = CMD_SET_HOST_NOTIFICATION_NUMBER;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_HOST_CHECK_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_HOST_CHECK_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CUSTOM_HOST_VAR"))
|
|
command_type = CMD_CHANGE_CUSTOM_HOST_VAR;
|
|
|
|
else if(!strcmp(command_id, "SEND_CUSTOM_HOST_NOTIFICATION"))
|
|
command_type = CMD_SEND_CUSTOM_HOST_NOTIFICATION;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_HOST_NOTIFICATION_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_HOST_MODATTR"))
|
|
command_type = CMD_CHANGE_HOST_MODATTR;
|
|
|
|
|
|
/************************************/
|
|
/**** HOSTGROUP-RELATED COMMANDS ****/
|
|
/************************************/
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_HOST_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_HOST_CHECKS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_HOST_CHECKS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_HOSTGROUP_HOST_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME;
|
|
else if(!strcmp(command_id, "SCHEDULE_HOSTGROUP_SVC_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME;
|
|
|
|
|
|
/**********************************/
|
|
/**** SERVICE-RELATED COMMANDS ****/
|
|
/**********************************/
|
|
|
|
else if(!strcmp(command_id, "ADD_SVC_COMMENT"))
|
|
command_type = CMD_ADD_SVC_COMMENT;
|
|
else if(!strcmp(command_id, "DEL_SVC_COMMENT"))
|
|
command_type = CMD_DEL_SVC_COMMENT;
|
|
else if(!strcmp(command_id, "DEL_ALL_SVC_COMMENTS"))
|
|
command_type = CMD_DEL_ALL_SVC_COMMENTS;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_SVC_CHECK"))
|
|
command_type = CMD_SCHEDULE_SVC_CHECK;
|
|
else if(!strcmp(command_id, "SCHEDULE_FORCED_SVC_CHECK"))
|
|
command_type = CMD_SCHEDULE_FORCED_SVC_CHECK;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SVC_CHECK"))
|
|
command_type = CMD_ENABLE_SVC_CHECK;
|
|
else if(!strcmp(command_id, "DISABLE_SVC_CHECK"))
|
|
command_type = CMD_DISABLE_SVC_CHECK;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_PASSIVE_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_PASSIVE_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "DELAY_SVC_NOTIFICATION"))
|
|
command_type = CMD_DELAY_SVC_NOTIFICATION;
|
|
else if(!strcmp(command_id, "ENABLE_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_SVC_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "PROCESS_SERVICE_CHECK_RESULT"))
|
|
command_type = CMD_PROCESS_SERVICE_CHECK_RESULT;
|
|
else if(!strcmp(command_id, "PROCESS_HOST_CHECK_RESULT"))
|
|
command_type = CMD_PROCESS_HOST_CHECK_RESULT;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SVC_EVENT_HANDLER"))
|
|
command_type = CMD_ENABLE_SVC_EVENT_HANDLER;
|
|
else if(!strcmp(command_id, "DISABLE_SVC_EVENT_HANDLER"))
|
|
command_type = CMD_DISABLE_SVC_EVENT_HANDLER;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SVC_FLAP_DETECTION"))
|
|
command_type = CMD_ENABLE_SVC_FLAP_DETECTION;
|
|
else if(!strcmp(command_id, "DISABLE_SVC_FLAP_DETECTION"))
|
|
command_type = CMD_DISABLE_SVC_FLAP_DETECTION;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_SVC_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_SVC_DOWNTIME;
|
|
else if(!strcmp(command_id, "DEL_SVC_DOWNTIME"))
|
|
command_type = CMD_DEL_SVC_DOWNTIME;
|
|
|
|
else if(!strcmp(command_id, "ACKNOWLEDGE_SVC_PROBLEM"))
|
|
command_type = CMD_ACKNOWLEDGE_SVC_PROBLEM;
|
|
else if(!strcmp(command_id, "REMOVE_SVC_ACKNOWLEDGEMENT"))
|
|
command_type = CMD_REMOVE_SVC_ACKNOWLEDGEMENT;
|
|
|
|
else if(!strcmp(command_id, "START_OBSESSING_OVER_SVC"))
|
|
command_type = CMD_START_OBSESSING_OVER_SVC;
|
|
else if(!strcmp(command_id, "STOP_OBSESSING_OVER_SVC"))
|
|
command_type = CMD_STOP_OBSESSING_OVER_SVC;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_SVC_EVENT_HANDLER"))
|
|
command_type = CMD_CHANGE_SVC_EVENT_HANDLER;
|
|
else if(!strcmp(command_id, "CHANGE_SVC_CHECK_COMMAND"))
|
|
command_type = CMD_CHANGE_SVC_CHECK_COMMAND;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_NORMAL_SVC_CHECK_INTERVAL"))
|
|
command_type = CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL;
|
|
else if(!strcmp(command_id, "CHANGE_RETRY_SVC_CHECK_INTERVAL"))
|
|
command_type = CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_MAX_SVC_CHECK_ATTEMPTS"))
|
|
command_type = CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS;
|
|
|
|
else if(!strcmp(command_id, "SET_SVC_NOTIFICATION_NUMBER"))
|
|
command_type = CMD_SET_SVC_NOTIFICATION_NUMBER;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_SVC_CHECK_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_SVC_CHECK_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CUSTOM_SVC_VAR"))
|
|
command_type = CMD_CHANGE_CUSTOM_SVC_VAR;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CUSTOM_CONTACT_VAR"))
|
|
command_type = CMD_CHANGE_CUSTOM_CONTACT_VAR;
|
|
|
|
else if(!strcmp(command_id, "SEND_CUSTOM_SVC_NOTIFICATION"))
|
|
command_type = CMD_SEND_CUSTOM_SVC_NOTIFICATION;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_SVC_NOTIFICATION_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_SVC_MODATTR"))
|
|
command_type = CMD_CHANGE_SVC_MODATTR;
|
|
|
|
|
|
/***************************************/
|
|
/**** SERVICEGROUP-RELATED COMMANDS ****/
|
|
/***************************************/
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_HOST_CHECKS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_HOST_CHECKS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS;
|
|
else if(!strcmp(command_id, "DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS"))
|
|
command_type = CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS;
|
|
|
|
else if(!strcmp(command_id, "SCHEDULE_SERVICEGROUP_HOST_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME;
|
|
else if(!strcmp(command_id, "SCHEDULE_SERVICEGROUP_SVC_DOWNTIME"))
|
|
command_type = CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME;
|
|
|
|
|
|
/**********************************/
|
|
/**** CONTACT-RELATED COMMANDS ****/
|
|
/**********************************/
|
|
|
|
else if(!strcmp(command_id, "ENABLE_CONTACT_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_CONTACT_HOST_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_CONTACT_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_CONTACT_HOST_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_CONTACT_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_CONTACT_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_CONTACT_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_CONTACT_SVC_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD"))
|
|
command_type = CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD;
|
|
|
|
else if(!strcmp(command_id, "CHANGE_CONTACT_MODATTR"))
|
|
command_type = CMD_CHANGE_CONTACT_MODATTR;
|
|
else if(!strcmp(command_id, "CHANGE_CONTACT_MODHATTR"))
|
|
command_type = CMD_CHANGE_CONTACT_MODHATTR;
|
|
else if(!strcmp(command_id, "CHANGE_CONTACT_MODSATTR"))
|
|
command_type = CMD_CHANGE_CONTACT_MODSATTR;
|
|
|
|
/***************************************/
|
|
/**** CONTACTGROUP-RELATED COMMANDS ****/
|
|
/***************************************/
|
|
|
|
else if(!strcmp(command_id, "ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS;
|
|
|
|
else if(!strcmp(command_id, "ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS;
|
|
else if(!strcmp(command_id, "DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS"))
|
|
command_type = CMD_DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS;
|
|
|
|
|
|
/**************************/
|
|
/****** MISC COMMANDS *****/
|
|
/**************************/
|
|
|
|
else if(!strcmp(command_id, "PROCESS_FILE"))
|
|
command_type = CMD_PROCESS_FILE;
|
|
|
|
|
|
|
|
/****************************/
|
|
/****** CUSTOM COMMANDS *****/
|
|
/****************************/
|
|
|
|
else if(command_id[0] == '_')
|
|
command_type = CMD_CUSTOM_COMMAND;
|
|
|
|
|
|
|
|
/**** UNKNOWN COMMAND ****/
|
|
else {
|
|
/* log the bad external command */
|
|
logit(NSLOG_EXTERNAL_COMMAND | NSLOG_RUNTIME_WARNING, TRUE, "Warning: Unrecognized external command -> %s;%s\n", command_id, args);
|
|
|
|
/* free memory */
|
|
my_free(command_id);
|
|
my_free(args);
|
|
|
|
return ERROR;
|
|
}
|
|
|
|
/* update statistics for external commands */
|
|
update_check_stats(EXTERNAL_COMMAND_STATS, time(NULL));
|
|
|
|
/* log the external command */
|
|
asprintf(&temp_buffer, "EXTERNAL COMMAND: %s;%s\n", command_id, args);
|
|
if(command_type == CMD_PROCESS_SERVICE_CHECK_RESULT || command_type == CMD_PROCESS_HOST_CHECK_RESULT) {
|
|
/* passive checks are logged in checks.c as well, as some my bypass external commands by getting dropped in checkresults dir */
|
|
if(log_passive_checks == TRUE)
|
|
write_to_all_logs(temp_buffer, NSLOG_PASSIVE_CHECK);
|
|
}
|
|
else {
|
|
if(log_external_commands == TRUE)
|
|
write_to_all_logs(temp_buffer, NSLOG_EXTERNAL_COMMAND);
|
|
}
|
|
my_free(temp_buffer);
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_external_command(NEBTYPE_EXTERNALCOMMAND_START, NEBFLAG_NONE, NEBATTR_NONE, command_type, entry_time, command_id, args, NULL);
|
|
#endif
|
|
|
|
/* process the command */
|
|
process_external_command2(command_type, entry_time, args);
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_external_command(NEBTYPE_EXTERNALCOMMAND_END, NEBFLAG_NONE, NEBATTR_NONE, command_type, entry_time, command_id, args, NULL);
|
|
#endif
|
|
|
|
/* free memory */
|
|
my_free(command_id);
|
|
my_free(args);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* top-level processor for a single external command */
|
|
int process_external_command2(int cmd, time_t entry_time, char *args) {
|
|
|
|
log_debug_info(DEBUGL_FUNCTIONS, 0, "process_external_command2()\n");
|
|
|
|
log_debug_info(DEBUGL_EXTERNALCOMMANDS, 1, "External Command Type: %d\n", cmd);
|
|
log_debug_info(DEBUGL_EXTERNALCOMMANDS, 1, "Command Entry Time: %lu\n", (unsigned long)entry_time);
|
|
log_debug_info(DEBUGL_EXTERNALCOMMANDS, 1, "Command Arguments: %s\n", (args == NULL) ? "" : args);
|
|
|
|
/* how shall we execute the command? */
|
|
switch(cmd) {
|
|
|
|
/***************************/
|
|
/***** SYSTEM COMMANDS *****/
|
|
/***************************/
|
|
|
|
case CMD_SHUTDOWN_PROCESS:
|
|
case CMD_RESTART_PROCESS:
|
|
cmd_signal_process(cmd, args);
|
|
break;
|
|
|
|
case CMD_SAVE_STATE_INFORMATION:
|
|
save_state_information(FALSE);
|
|
break;
|
|
|
|
case CMD_READ_STATE_INFORMATION:
|
|
read_initial_state_information();
|
|
break;
|
|
|
|
case CMD_ENABLE_NOTIFICATIONS:
|
|
enable_all_notifications();
|
|
break;
|
|
|
|
case CMD_DISABLE_NOTIFICATIONS:
|
|
disable_all_notifications();
|
|
break;
|
|
|
|
case CMD_START_EXECUTING_SVC_CHECKS:
|
|
start_executing_service_checks();
|
|
break;
|
|
|
|
case CMD_STOP_EXECUTING_SVC_CHECKS:
|
|
stop_executing_service_checks();
|
|
break;
|
|
|
|
case CMD_START_ACCEPTING_PASSIVE_SVC_CHECKS:
|
|
start_accepting_passive_service_checks();
|
|
break;
|
|
|
|
case CMD_STOP_ACCEPTING_PASSIVE_SVC_CHECKS:
|
|
stop_accepting_passive_service_checks();
|
|
break;
|
|
|
|
case CMD_START_OBSESSING_OVER_SVC_CHECKS:
|
|
start_obsessing_over_service_checks();
|
|
break;
|
|
|
|
case CMD_STOP_OBSESSING_OVER_SVC_CHECKS:
|
|
stop_obsessing_over_service_checks();
|
|
break;
|
|
|
|
case CMD_START_EXECUTING_HOST_CHECKS:
|
|
start_executing_host_checks();
|
|
break;
|
|
|
|
case CMD_STOP_EXECUTING_HOST_CHECKS:
|
|
stop_executing_host_checks();
|
|
break;
|
|
|
|
case CMD_START_ACCEPTING_PASSIVE_HOST_CHECKS:
|
|
start_accepting_passive_host_checks();
|
|
break;
|
|
|
|
case CMD_STOP_ACCEPTING_PASSIVE_HOST_CHECKS:
|
|
stop_accepting_passive_host_checks();
|
|
break;
|
|
|
|
case CMD_START_OBSESSING_OVER_HOST_CHECKS:
|
|
start_obsessing_over_host_checks();
|
|
break;
|
|
|
|
case CMD_STOP_OBSESSING_OVER_HOST_CHECKS:
|
|
stop_obsessing_over_host_checks();
|
|
break;
|
|
|
|
case CMD_ENABLE_EVENT_HANDLERS:
|
|
start_using_event_handlers();
|
|
break;
|
|
|
|
case CMD_DISABLE_EVENT_HANDLERS:
|
|
stop_using_event_handlers();
|
|
break;
|
|
|
|
case CMD_ENABLE_FLAP_DETECTION:
|
|
enable_flap_detection_routines();
|
|
break;
|
|
|
|
case CMD_DISABLE_FLAP_DETECTION:
|
|
disable_flap_detection_routines();
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICE_FRESHNESS_CHECKS:
|
|
enable_service_freshness_checks();
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICE_FRESHNESS_CHECKS:
|
|
disable_service_freshness_checks();
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_FRESHNESS_CHECKS:
|
|
enable_host_freshness_checks();
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_FRESHNESS_CHECKS:
|
|
disable_host_freshness_checks();
|
|
break;
|
|
|
|
case CMD_ENABLE_FAILURE_PREDICTION:
|
|
enable_all_failure_prediction();
|
|
break;
|
|
|
|
case CMD_DISABLE_FAILURE_PREDICTION:
|
|
disable_all_failure_prediction();
|
|
break;
|
|
|
|
case CMD_ENABLE_PERFORMANCE_DATA:
|
|
enable_performance_data();
|
|
break;
|
|
|
|
case CMD_DISABLE_PERFORMANCE_DATA:
|
|
disable_performance_data();
|
|
break;
|
|
|
|
|
|
/***************************/
|
|
/***** HOST COMMANDS *****/
|
|
/***************************/
|
|
|
|
case CMD_ENABLE_HOST_CHECK:
|
|
case CMD_DISABLE_HOST_CHECK:
|
|
case CMD_ENABLE_PASSIVE_HOST_CHECKS:
|
|
case CMD_DISABLE_PASSIVE_HOST_CHECKS:
|
|
case CMD_ENABLE_HOST_SVC_CHECKS:
|
|
case CMD_DISABLE_HOST_SVC_CHECKS:
|
|
case CMD_ENABLE_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST:
|
|
case CMD_DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST:
|
|
case CMD_ENABLE_HOST_AND_CHILD_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOST_AND_CHILD_NOTIFICATIONS:
|
|
case CMD_ENABLE_HOST_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOST_SVC_NOTIFICATIONS:
|
|
case CMD_ENABLE_HOST_FLAP_DETECTION:
|
|
case CMD_DISABLE_HOST_FLAP_DETECTION:
|
|
case CMD_ENABLE_HOST_EVENT_HANDLER:
|
|
case CMD_DISABLE_HOST_EVENT_HANDLER:
|
|
case CMD_START_OBSESSING_OVER_HOST:
|
|
case CMD_STOP_OBSESSING_OVER_HOST:
|
|
case CMD_SET_HOST_NOTIFICATION_NUMBER:
|
|
case CMD_SEND_CUSTOM_HOST_NOTIFICATION:
|
|
process_host_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/*****************************/
|
|
/***** HOSTGROUP COMMANDS ****/
|
|
/*****************************/
|
|
|
|
case CMD_ENABLE_HOSTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_HOSTGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_ENABLE_HOSTGROUP_HOST_CHECKS:
|
|
case CMD_DISABLE_HOSTGROUP_HOST_CHECKS:
|
|
case CMD_ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
|
|
case CMD_DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
|
|
case CMD_ENABLE_HOSTGROUP_SVC_CHECKS:
|
|
case CMD_DISABLE_HOSTGROUP_SVC_CHECKS:
|
|
case CMD_ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
|
|
case CMD_DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
|
|
process_hostgroup_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/***************************/
|
|
/***** SERVICE COMMANDS ****/
|
|
/***************************/
|
|
|
|
case CMD_ENABLE_SVC_CHECK:
|
|
case CMD_DISABLE_SVC_CHECK:
|
|
case CMD_ENABLE_PASSIVE_SVC_CHECKS:
|
|
case CMD_DISABLE_PASSIVE_SVC_CHECKS:
|
|
case CMD_ENABLE_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_SVC_NOTIFICATIONS:
|
|
case CMD_ENABLE_SVC_FLAP_DETECTION:
|
|
case CMD_DISABLE_SVC_FLAP_DETECTION:
|
|
case CMD_ENABLE_SVC_EVENT_HANDLER:
|
|
case CMD_DISABLE_SVC_EVENT_HANDLER:
|
|
case CMD_START_OBSESSING_OVER_SVC:
|
|
case CMD_STOP_OBSESSING_OVER_SVC:
|
|
case CMD_SET_SVC_NOTIFICATION_NUMBER:
|
|
case CMD_SEND_CUSTOM_SVC_NOTIFICATION:
|
|
process_service_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/********************************/
|
|
/***** SERVICEGROUP COMMANDS ****/
|
|
/********************************/
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_CHECKS:
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_CHECKS:
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
process_servicegroup_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/**********************************/
|
|
/**** CONTACT-RELATED COMMANDS ****/
|
|
/**********************************/
|
|
|
|
case CMD_ENABLE_CONTACT_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACT_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_CONTACT_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACT_SVC_NOTIFICATIONS:
|
|
process_contact_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/***************************************/
|
|
/**** CONTACTGROUP-RELATED COMMANDS ****/
|
|
/***************************************/
|
|
|
|
case CMD_ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
process_contactgroup_command(cmd, entry_time, args);
|
|
break;
|
|
|
|
|
|
/***************************/
|
|
/**** UNSORTED COMMANDS ****/
|
|
/***************************/
|
|
|
|
|
|
case CMD_ADD_HOST_COMMENT:
|
|
case CMD_ADD_SVC_COMMENT:
|
|
cmd_add_comment(cmd, entry_time, args);
|
|
break;
|
|
|
|
case CMD_DEL_HOST_COMMENT:
|
|
case CMD_DEL_SVC_COMMENT:
|
|
cmd_delete_comment(cmd, args);
|
|
break;
|
|
|
|
case CMD_DELAY_HOST_NOTIFICATION:
|
|
case CMD_DELAY_SVC_NOTIFICATION:
|
|
cmd_delay_notification(cmd, args);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_SVC_CHECK:
|
|
case CMD_SCHEDULE_FORCED_SVC_CHECK:
|
|
cmd_schedule_check(cmd, args);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOST_SVC_CHECKS:
|
|
case CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS:
|
|
cmd_schedule_check(cmd, args);
|
|
break;
|
|
|
|
case CMD_DEL_ALL_HOST_COMMENTS:
|
|
case CMD_DEL_ALL_SVC_COMMENTS:
|
|
cmd_delete_all_comments(cmd, args);
|
|
break;
|
|
|
|
case CMD_PROCESS_SERVICE_CHECK_RESULT:
|
|
cmd_process_service_check_result(cmd, entry_time, args);
|
|
break;
|
|
|
|
case CMD_PROCESS_HOST_CHECK_RESULT:
|
|
cmd_process_host_check_result(cmd, entry_time, args);
|
|
break;
|
|
|
|
case CMD_ACKNOWLEDGE_HOST_PROBLEM:
|
|
case CMD_ACKNOWLEDGE_SVC_PROBLEM:
|
|
cmd_acknowledge_problem(cmd, args);
|
|
break;
|
|
|
|
case CMD_REMOVE_HOST_ACKNOWLEDGEMENT:
|
|
case CMD_REMOVE_SVC_ACKNOWLEDGEMENT:
|
|
cmd_remove_acknowledgement(cmd, args);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOST_DOWNTIME:
|
|
case CMD_SCHEDULE_SVC_DOWNTIME:
|
|
case CMD_SCHEDULE_HOST_SVC_DOWNTIME:
|
|
case CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME:
|
|
case CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME:
|
|
case CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME:
|
|
case CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME:
|
|
case CMD_SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME:
|
|
case CMD_SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME:
|
|
cmd_schedule_downtime(cmd, entry_time, args);
|
|
break;
|
|
|
|
case CMD_DEL_HOST_DOWNTIME:
|
|
case CMD_DEL_SVC_DOWNTIME:
|
|
cmd_delete_downtime(cmd, args);
|
|
break;
|
|
|
|
case CMD_DEL_DOWNTIME_BY_HOST_NAME:
|
|
cmd_delete_downtime_by_host_name(cmd, args);
|
|
break;
|
|
|
|
case CMD_DEL_DOWNTIME_BY_HOSTGROUP_NAME:
|
|
cmd_delete_downtime_by_hostgroup_name(cmd, args);
|
|
break;
|
|
|
|
case CMD_DEL_DOWNTIME_BY_START_TIME_COMMENT:
|
|
cmd_delete_downtime_by_start_time_comment(cmd, args);
|
|
break;
|
|
|
|
case CMD_CANCEL_ACTIVE_HOST_SVC_DOWNTIME:
|
|
case CMD_CANCEL_PENDING_HOST_SVC_DOWNTIME:
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOST_CHECK:
|
|
case CMD_SCHEDULE_FORCED_HOST_CHECK:
|
|
cmd_schedule_check(cmd, args);
|
|
break;
|
|
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
case CMD_CHANGE_HOST_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD:
|
|
cmd_change_object_char_var(cmd, args);
|
|
break;
|
|
|
|
case CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_HOST_MODATTR:
|
|
case CMD_CHANGE_SVC_MODATTR:
|
|
case CMD_CHANGE_CONTACT_MODATTR:
|
|
case CMD_CHANGE_CONTACT_MODHATTR:
|
|
case CMD_CHANGE_CONTACT_MODSATTR:
|
|
cmd_change_object_int_var(cmd, args);
|
|
break;
|
|
|
|
case CMD_CHANGE_CUSTOM_HOST_VAR:
|
|
case CMD_CHANGE_CUSTOM_SVC_VAR:
|
|
case CMD_CHANGE_CUSTOM_CONTACT_VAR:
|
|
cmd_change_object_custom_var(cmd, args);
|
|
break;
|
|
|
|
|
|
/***********************/
|
|
/**** MISC COMMANDS ****/
|
|
/***********************/
|
|
|
|
|
|
case CMD_PROCESS_FILE:
|
|
cmd_process_external_commands_from_file(cmd, args);
|
|
break;
|
|
|
|
|
|
/*************************/
|
|
/**** CUSTOM COMMANDS ****/
|
|
/*************************/
|
|
|
|
|
|
case CMD_CUSTOM_COMMAND:
|
|
/* custom commands aren't handled internally by Nagios, but may be by NEB modules */
|
|
break;
|
|
|
|
default:
|
|
return ERROR;
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* processes an external host command */
|
|
int process_host_command(int cmd, time_t entry_time, char *args) {
|
|
char *host_name = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
char *str = NULL;
|
|
char *buf[2] = {NULL, NULL};
|
|
int intval = 0;
|
|
|
|
printf("ARGS: %s\n", args);
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the host */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_HOST_NOTIFICATIONS:
|
|
enable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_NOTIFICATIONS:
|
|
disable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_AND_CHILD_NOTIFICATIONS:
|
|
enable_and_propagate_notifications(temp_host, 0, TRUE, TRUE, FALSE);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_AND_CHILD_NOTIFICATIONS:
|
|
disable_and_propagate_notifications(temp_host, 0, TRUE, TRUE, FALSE);
|
|
break;
|
|
|
|
case CMD_ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST:
|
|
enable_and_propagate_notifications(temp_host, 0, FALSE, TRUE, TRUE);
|
|
break;
|
|
|
|
case CMD_DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST:
|
|
disable_and_propagate_notifications(temp_host, 0, FALSE, TRUE, TRUE);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_HOST_SVC_NOTIFICATIONS:
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
if(cmd == CMD_ENABLE_HOST_SVC_NOTIFICATIONS)
|
|
enable_service_notifications(temp_service);
|
|
else
|
|
disable_service_notifications(temp_service);
|
|
}
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_SVC_CHECKS:
|
|
case CMD_DISABLE_HOST_SVC_CHECKS:
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
if(cmd == CMD_ENABLE_HOST_SVC_CHECKS)
|
|
enable_service_checks(temp_service);
|
|
else
|
|
disable_service_checks(temp_service);
|
|
}
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_CHECK:
|
|
enable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_CHECK:
|
|
disable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_EVENT_HANDLER:
|
|
enable_host_event_handler(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_EVENT_HANDLER:
|
|
disable_host_event_handler(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOST_FLAP_DETECTION:
|
|
enable_host_flap_detection(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOST_FLAP_DETECTION:
|
|
disable_host_flap_detection(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_PASSIVE_HOST_CHECKS:
|
|
enable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_PASSIVE_HOST_CHECKS:
|
|
disable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_START_OBSESSING_OVER_HOST:
|
|
start_obsessing_over_host(temp_host);
|
|
break;
|
|
|
|
case CMD_STOP_OBSESSING_OVER_HOST:
|
|
stop_obsessing_over_host(temp_host);
|
|
break;
|
|
|
|
case CMD_SET_HOST_NOTIFICATION_NUMBER:
|
|
if((str = my_strtok(NULL, ";"))) {
|
|
intval = atoi(str);
|
|
set_host_notification_number(temp_host, intval);
|
|
}
|
|
break;
|
|
|
|
case CMD_SEND_CUSTOM_HOST_NOTIFICATION:
|
|
if((str = my_strtok(NULL, ";")))
|
|
intval = atoi(str);
|
|
str = my_strtok(NULL, ";");
|
|
if(str)
|
|
buf[0] = strdup(str);
|
|
str = my_strtok(NULL, ";");
|
|
if(str)
|
|
buf[1] = strdup(str);
|
|
if(buf[0] && buf[1])
|
|
host_notification(temp_host, NOTIFICATION_CUSTOM, buf[0], buf[1], intval);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* processes an external hostgroup command */
|
|
int process_hostgroup_command(int cmd, time_t entry_time, char *args) {
|
|
char *hostgroup_name = NULL;
|
|
hostgroup *temp_hostgroup = NULL;
|
|
hostsmember *temp_member = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
|
|
/* get the hostgroup name */
|
|
if((hostgroup_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the hostgroup */
|
|
if((temp_hostgroup = find_hostgroup(hostgroup_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* loop through all hosts in the hostgroup */
|
|
for(temp_member = temp_hostgroup->members; temp_member != NULL; temp_member = temp_member->next) {
|
|
|
|
if((temp_host = (host *)temp_member->host_ptr) == NULL)
|
|
continue;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_HOSTGROUP_HOST_NOTIFICATIONS:
|
|
enable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS:
|
|
disable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOSTGROUP_HOST_CHECKS:
|
|
enable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_HOST_CHECKS:
|
|
disable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
|
|
enable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
|
|
disable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
default:
|
|
|
|
/* loop through all services on the host */
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_HOSTGROUP_SVC_NOTIFICATIONS:
|
|
enable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS:
|
|
disable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOSTGROUP_SVC_CHECKS:
|
|
enable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_SVC_CHECKS:
|
|
disable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
|
|
enable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
|
|
disable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
break;
|
|
}
|
|
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* processes an external service command */
|
|
int process_service_command(int cmd, time_t entry_time, char *args) {
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
service *temp_service = NULL;
|
|
char *str = NULL;
|
|
char *buf[2] = {NULL, NULL};
|
|
int intval = 0;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the service description */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the service */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_SVC_NOTIFICATIONS:
|
|
enable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SVC_NOTIFICATIONS:
|
|
disable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_SVC_CHECK:
|
|
enable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SVC_CHECK:
|
|
disable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_SVC_EVENT_HANDLER:
|
|
enable_service_event_handler(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SVC_EVENT_HANDLER:
|
|
disable_service_event_handler(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_SVC_FLAP_DETECTION:
|
|
enable_service_flap_detection(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SVC_FLAP_DETECTION:
|
|
disable_service_flap_detection(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_PASSIVE_SVC_CHECKS:
|
|
enable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_PASSIVE_SVC_CHECKS:
|
|
disable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_START_OBSESSING_OVER_SVC:
|
|
start_obsessing_over_service(temp_service);
|
|
break;
|
|
|
|
case CMD_STOP_OBSESSING_OVER_SVC:
|
|
stop_obsessing_over_service(temp_service);
|
|
break;
|
|
|
|
case CMD_SET_SVC_NOTIFICATION_NUMBER:
|
|
if((str = my_strtok(NULL, ";"))) {
|
|
intval = atoi(str);
|
|
set_service_notification_number(temp_service, intval);
|
|
}
|
|
break;
|
|
|
|
case CMD_SEND_CUSTOM_SVC_NOTIFICATION:
|
|
if((str = my_strtok(NULL, ";")))
|
|
intval = atoi(str);
|
|
str = my_strtok(NULL, ";");
|
|
if(str)
|
|
buf[0] = strdup(str);
|
|
str = my_strtok(NULL, ";");
|
|
if(str)
|
|
buf[1] = strdup(str);
|
|
if(buf[0] && buf[1])
|
|
service_notification(temp_service, NOTIFICATION_CUSTOM, buf[0], buf[1], intval);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* processes an external servicegroup command */
|
|
int process_servicegroup_command(int cmd, time_t entry_time, char *args) {
|
|
char *servicegroup_name = NULL;
|
|
servicegroup *temp_servicegroup = NULL;
|
|
servicesmember *temp_member = NULL;
|
|
host *temp_host = NULL;
|
|
host *last_host = NULL;
|
|
service *temp_service = NULL;
|
|
|
|
/* get the servicegroup name */
|
|
if((servicegroup_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the servicegroup */
|
|
if((temp_servicegroup = find_servicegroup(servicegroup_name)) == NULL)
|
|
return ERROR;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_CHECKS:
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
|
|
/* loop through all servicegroup members */
|
|
for(temp_member = temp_servicegroup->members; temp_member != NULL; temp_member = temp_member->next) {
|
|
|
|
temp_service = find_service(temp_member->host_name, temp_member->service_description);
|
|
if(temp_service == NULL)
|
|
continue;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
enable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
|
|
disable_service_notifications(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_SVC_CHECKS:
|
|
enable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_SVC_CHECKS:
|
|
disable_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
enable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
|
|
disable_passive_service_checks(temp_service);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_CHECKS:
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
|
|
/* loop through all hosts that have services belonging to the servicegroup */
|
|
last_host = NULL;
|
|
for(temp_member = temp_servicegroup->members; temp_member != NULL; temp_member = temp_member->next) {
|
|
|
|
if((temp_host = find_host(temp_member->host_name)) == NULL)
|
|
continue;
|
|
|
|
if(temp_host == last_host)
|
|
continue;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
enable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
|
|
disable_host_notifications(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_HOST_CHECKS:
|
|
enable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_HOST_CHECKS:
|
|
disable_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
enable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
case CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
|
|
disable_passive_host_checks(temp_host);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
last_host = temp_host;
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* processes an external contact command */
|
|
int process_contact_command(int cmd, time_t entry_time, char *args) {
|
|
char *contact_name = NULL;
|
|
contact *temp_contact = NULL;
|
|
|
|
/* get the contact name */
|
|
if((contact_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the contact */
|
|
if((temp_contact = find_contact(contact_name)) == NULL)
|
|
return ERROR;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_CONTACT_HOST_NOTIFICATIONS:
|
|
enable_contact_host_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_DISABLE_CONTACT_HOST_NOTIFICATIONS:
|
|
disable_contact_host_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_ENABLE_CONTACT_SVC_NOTIFICATIONS:
|
|
enable_contact_service_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_DISABLE_CONTACT_SVC_NOTIFICATIONS:
|
|
disable_contact_service_notifications(temp_contact);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* processes an external contactgroup command */
|
|
int process_contactgroup_command(int cmd, time_t entry_time, char *args) {
|
|
char *contactgroup_name = NULL;
|
|
contactgroup *temp_contactgroup = NULL;
|
|
contactsmember *temp_member = NULL;
|
|
contact *temp_contact = NULL;
|
|
|
|
/* get the contactgroup name */
|
|
if((contactgroup_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the contactgroup */
|
|
if((temp_contactgroup = find_contactgroup(contactgroup_name)) == NULL)
|
|
return ERROR;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
case CMD_ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
case CMD_DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
|
|
/* loop through all contactgroup members */
|
|
for(temp_member = temp_contactgroup->members; temp_member != NULL; temp_member = temp_member->next) {
|
|
|
|
if((temp_contact = temp_member->contact_ptr) == NULL)
|
|
continue;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
enable_contact_host_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS:
|
|
disable_contact_host_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
enable_contact_service_notifications(temp_contact);
|
|
break;
|
|
|
|
case CMD_DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS:
|
|
disable_contact_service_notifications(temp_contact);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
}
|
|
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/******************************************************************/
|
|
/*************** EXTERNAL COMMAND IMPLEMENTATIONS ****************/
|
|
/******************************************************************/
|
|
|
|
/* adds a host or service comment to the status log */
|
|
int cmd_add_comment(int cmd, time_t entry_time, char *args) {
|
|
char *temp_ptr = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
char *user = NULL;
|
|
char *comment_data = NULL;
|
|
int persistent = 0;
|
|
int result = 0;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* if we're adding a service comment... */
|
|
if(cmd == CMD_ADD_SVC_COMMENT) {
|
|
|
|
/* get the service description */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* else verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the persistent flag */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
persistent = atoi(temp_ptr);
|
|
if(persistent > 1)
|
|
persistent = 1;
|
|
else if(persistent < 0)
|
|
persistent = 0;
|
|
|
|
/* get the name of the user who entered the comment */
|
|
if((user = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the comment */
|
|
if((comment_data = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
|
|
/* add the comment */
|
|
result = add_new_comment((cmd == CMD_ADD_HOST_COMMENT) ? HOST_COMMENT : SERVICE_COMMENT, USER_COMMENT, host_name, svc_description, entry_time, user, comment_data, persistent, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
|
|
|
|
if(result < 0)
|
|
return ERROR;
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* removes a host or service comment from the status log */
|
|
int cmd_delete_comment(int cmd, char *args) {
|
|
unsigned long comment_id = 0L;
|
|
|
|
/* get the comment id we should delete */
|
|
if((comment_id = strtoul(args, NULL, 10)) == 0)
|
|
return ERROR;
|
|
|
|
/* delete the specified comment */
|
|
if(cmd == CMD_DEL_HOST_COMMENT)
|
|
delete_host_comment(comment_id);
|
|
else
|
|
delete_service_comment(comment_id);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* removes all comments associated with a host or service from the status log */
|
|
int cmd_delete_all_comments(int cmd, char *args) {
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* if we're deleting service comments... */
|
|
if(cmd == CMD_DEL_ALL_SVC_COMMENTS) {
|
|
|
|
/* get the service description */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* else verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* delete comments */
|
|
delete_all_comments((cmd == CMD_DEL_ALL_HOST_COMMENTS) ? HOST_COMMENT : SERVICE_COMMENT, host_name, svc_description);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* delays a host or service notification for given number of minutes */
|
|
int cmd_delay_notification(int cmd, char *args) {
|
|
char *temp_ptr = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
time_t delay_time = 0L;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* if this is a service notification delay... */
|
|
if(cmd == CMD_DELAY_SVC_NOTIFICATION) {
|
|
|
|
/* get the service description */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* else verify that the host is valid */
|
|
else {
|
|
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* get the time that we should delay until... */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
delay_time = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* delay the next notification... */
|
|
if(cmd == CMD_DELAY_HOST_NOTIFICATION)
|
|
temp_host->next_host_notification = delay_time;
|
|
else
|
|
temp_service->next_notification = delay_time;
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* schedules a host check at a particular time */
|
|
int cmd_schedule_check(int cmd, char *args) {
|
|
char *temp_ptr = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
time_t delay_time = 0L;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
if(cmd == CMD_SCHEDULE_HOST_CHECK || cmd == CMD_SCHEDULE_FORCED_HOST_CHECK || cmd == CMD_SCHEDULE_HOST_SVC_CHECKS || cmd == CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS) {
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
else {
|
|
|
|
/* get the service description */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* get the next check time */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
delay_time = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* schedule the host check */
|
|
if(cmd == CMD_SCHEDULE_HOST_CHECK || cmd == CMD_SCHEDULE_FORCED_HOST_CHECK)
|
|
schedule_host_check(temp_host, delay_time, (cmd == CMD_SCHEDULE_FORCED_HOST_CHECK) ? CHECK_OPTION_FORCE_EXECUTION : CHECK_OPTION_NONE);
|
|
|
|
/* schedule service checks */
|
|
else if(cmd == CMD_SCHEDULE_HOST_SVC_CHECKS || cmd == CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS) {
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
schedule_service_check(temp_service, delay_time, (cmd == CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS) ? CHECK_OPTION_FORCE_EXECUTION : CHECK_OPTION_NONE);
|
|
}
|
|
}
|
|
else
|
|
schedule_service_check(temp_service, delay_time, (cmd == CMD_SCHEDULE_FORCED_SVC_CHECK) ? CHECK_OPTION_FORCE_EXECUTION : CHECK_OPTION_NONE);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* schedules all service checks on a host for a particular time */
|
|
int cmd_schedule_host_service_checks(int cmd, char *args, int force) {
|
|
char *temp_ptr = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
host *temp_host = NULL;
|
|
char *host_name = NULL;
|
|
time_t delay_time = 0L;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the next check time */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
delay_time = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* reschedule all services on the specified host */
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
schedule_service_check(temp_service, delay_time, (force == TRUE) ? CHECK_OPTION_FORCE_EXECUTION : CHECK_OPTION_NONE);
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
|
|
/* schedules a program shutdown or restart */
|
|
int cmd_signal_process(int cmd, char *args) {
|
|
time_t scheduled_time = 0L;
|
|
char *temp_ptr = NULL;
|
|
int result = OK;
|
|
|
|
/* get the time to schedule the event */
|
|
if((temp_ptr = my_strtok(args, "\n")) == NULL)
|
|
scheduled_time = 0L;
|
|
else
|
|
scheduled_time = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* add a scheduled program shutdown or restart to the event list */
|
|
result = schedule_new_event((cmd == CMD_SHUTDOWN_PROCESS) ? EVENT_PROGRAM_SHUTDOWN : EVENT_PROGRAM_RESTART, TRUE, scheduled_time, FALSE, 0, NULL, FALSE, NULL, NULL, 0);
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
|
|
/* processes results of an external service check */
|
|
int cmd_process_service_check_result(int cmd, time_t check_time, char *args) {
|
|
char *temp_ptr = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
int return_code = 0;
|
|
char *output = NULL;
|
|
int result = 0;
|
|
|
|
/* get the host name */
|
|
if((temp_ptr = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
host_name = (char *)strdup(temp_ptr);
|
|
|
|
/* get the service description */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(host_name);
|
|
return ERROR;
|
|
}
|
|
svc_description = (char *)strdup(temp_ptr);
|
|
|
|
/* get the service check return code */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(host_name);
|
|
my_free(svc_description);
|
|
return ERROR;
|
|
}
|
|
return_code = atoi(temp_ptr);
|
|
|
|
/* get the plugin output (may be empty) */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
output = (char *)strdup("");
|
|
else
|
|
output = (char *)strdup(temp_ptr);
|
|
|
|
/* submit the passive check result */
|
|
result = process_passive_service_check(check_time, host_name, svc_description, return_code, output);
|
|
|
|
/* free memory */
|
|
my_free(host_name);
|
|
my_free(svc_description);
|
|
my_free(output);
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
|
|
/* submits a passive service check result for later processing */
|
|
int process_passive_service_check(time_t check_time, char *host_name, char *svc_description, int return_code, char *output) {
|
|
passive_check_result *new_pcr = NULL;
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
char *real_host_name = NULL;
|
|
struct timeval tv;
|
|
int result = OK;
|
|
|
|
/* skip this service check result if we aren't accepting passive service checks */
|
|
if(accept_passive_service_checks == FALSE)
|
|
return ERROR;
|
|
|
|
/* make sure we have all required data */
|
|
if(host_name == NULL || svc_description == NULL || output == NULL)
|
|
return ERROR;
|
|
|
|
/* find the host by its name or address */
|
|
if(find_host(host_name) != NULL)
|
|
real_host_name = host_name;
|
|
else {
|
|
for(temp_host = host_list; temp_host != NULL; temp_host = temp_host->next) {
|
|
if(!strcmp(host_name, temp_host->address)) {
|
|
real_host_name = temp_host->name;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* we couldn't find the host */
|
|
if(real_host_name == NULL) {
|
|
logit(NSLOG_RUNTIME_WARNING, TRUE, "Warning: Passive check result was received for service '%s' on host '%s', but the host could not be found!\n", svc_description, host_name);
|
|
return ERROR;
|
|
}
|
|
|
|
/* make sure the service exists */
|
|
if((temp_service = find_service(real_host_name, svc_description)) == NULL) {
|
|
logit(NSLOG_RUNTIME_WARNING, TRUE, "Warning: Passive check result was received for service '%s' on host '%s', but the service could not be found!\n", svc_description, host_name);
|
|
return ERROR;
|
|
}
|
|
|
|
/* skip this is we aren't accepting passive checks for this service */
|
|
if(temp_service->accept_passive_service_checks == FALSE)
|
|
return ERROR;
|
|
|
|
/* allocate memory for the passive check result */
|
|
new_pcr = (passive_check_result *)malloc(sizeof(passive_check_result));
|
|
if(new_pcr == NULL)
|
|
return ERROR;
|
|
|
|
/* initialize vars */
|
|
new_pcr->object_check_type = SERVICE_CHECK;
|
|
new_pcr->host_name = NULL;
|
|
new_pcr->service_description = NULL;
|
|
new_pcr->output = NULL;
|
|
new_pcr->next = NULL;
|
|
|
|
/* save string vars */
|
|
if((new_pcr->host_name = (char *)strdup(real_host_name)) == NULL)
|
|
result = ERROR;
|
|
if((new_pcr->service_description = (char *)strdup(svc_description)) == NULL)
|
|
result = ERROR;
|
|
if((new_pcr->output = (char *)strdup(output)) == NULL)
|
|
result = ERROR;
|
|
|
|
/* handle errors */
|
|
if(result == ERROR) {
|
|
my_free(new_pcr->output);
|
|
my_free(new_pcr->service_description);
|
|
my_free(new_pcr->host_name);
|
|
my_free(new_pcr);
|
|
return ERROR;
|
|
}
|
|
|
|
/* save the return code */
|
|
new_pcr->return_code = return_code;
|
|
|
|
/* make sure the return code is within bounds */
|
|
if(new_pcr->return_code < 0 || new_pcr->return_code > 3)
|
|
new_pcr->return_code = STATE_UNKNOWN;
|
|
|
|
new_pcr->check_time = check_time;
|
|
|
|
/* calculate latency */
|
|
gettimeofday(&tv, NULL);
|
|
new_pcr->latency = (double)((double)(tv.tv_sec - check_time) + (double)(tv.tv_usec / 1000.0) / 1000.0);
|
|
if(new_pcr->latency < 0.0)
|
|
new_pcr->latency = 0.0;
|
|
|
|
/* add the passive check result to the end of the list in memory */
|
|
if(passive_check_result_list == NULL)
|
|
passive_check_result_list = new_pcr;
|
|
else
|
|
passive_check_result_list_tail->next = new_pcr;
|
|
passive_check_result_list_tail = new_pcr;
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* process passive host check result */
|
|
int cmd_process_host_check_result(int cmd, time_t check_time, char *args) {
|
|
char *temp_ptr = NULL;
|
|
char *host_name = NULL;
|
|
int return_code = 0;
|
|
char *output = NULL;
|
|
int result = 0;
|
|
|
|
/* get the host name */
|
|
if((temp_ptr = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
host_name = (char *)strdup(temp_ptr);
|
|
|
|
/* get the host check return code */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(host_name);
|
|
return ERROR;
|
|
}
|
|
return_code = atoi(temp_ptr);
|
|
|
|
/* get the plugin output (may be empty) */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL)
|
|
output = (char *)strdup("");
|
|
else
|
|
output = (char *)strdup(temp_ptr);
|
|
|
|
/* submit the check result */
|
|
result = process_passive_host_check(check_time, host_name, return_code, output);
|
|
|
|
/* free memory */
|
|
my_free(host_name);
|
|
my_free(output);
|
|
|
|
return result;
|
|
}
|
|
|
|
|
|
/* process passive host check result */
|
|
int process_passive_host_check(time_t check_time, char *host_name, int return_code, char *output) {
|
|
passive_check_result *new_pcr = NULL;
|
|
host *temp_host = NULL;
|
|
char *real_host_name = NULL;
|
|
struct timeval tv;
|
|
int result = OK;
|
|
|
|
/* skip this host check result if we aren't accepting passive host checks */
|
|
if(accept_passive_service_checks == FALSE)
|
|
return ERROR;
|
|
|
|
/* make sure we have all required data */
|
|
if(host_name == NULL || output == NULL)
|
|
return ERROR;
|
|
|
|
/* make sure we have a reasonable return code */
|
|
if(return_code < 0 || return_code > 2)
|
|
return ERROR;
|
|
|
|
/* find the host by its name or address */
|
|
if((temp_host = find_host(host_name)) != NULL)
|
|
real_host_name = host_name;
|
|
else {
|
|
for(temp_host = host_list; temp_host != NULL; temp_host = temp_host->next) {
|
|
if(!strcmp(host_name, temp_host->address)) {
|
|
real_host_name = temp_host->name;
|
|
break;
|
|
}
|
|
}
|
|
}
|
|
|
|
/* we couldn't find the host */
|
|
if(temp_host == NULL) {
|
|
logit(NSLOG_RUNTIME_WARNING, TRUE, "Warning: Passive check result was received for host '%s', but the host could not be found!\n", host_name);
|
|
return ERROR;
|
|
}
|
|
|
|
/* skip this is we aren't accepting passive checks for this host */
|
|
if(temp_host->accept_passive_host_checks == FALSE)
|
|
return ERROR;
|
|
|
|
/* allocate memory for the passive check result */
|
|
new_pcr = (passive_check_result *)malloc(sizeof(passive_check_result));
|
|
if(new_pcr == NULL)
|
|
return ERROR;
|
|
|
|
/* initialize vars */
|
|
new_pcr->object_check_type = HOST_CHECK;
|
|
new_pcr->host_name = NULL;
|
|
new_pcr->service_description = NULL;
|
|
new_pcr->output = NULL;
|
|
new_pcr->next = NULL;
|
|
|
|
/* save string vars */
|
|
if((new_pcr->host_name = (char *)strdup(real_host_name)) == NULL)
|
|
result = ERROR;
|
|
if((new_pcr->output = (char *)strdup(output)) == NULL)
|
|
result = ERROR;
|
|
|
|
/* handle errors */
|
|
if(result == ERROR) {
|
|
my_free(new_pcr->output);
|
|
my_free(new_pcr->service_description);
|
|
my_free(new_pcr->host_name);
|
|
my_free(new_pcr);
|
|
return ERROR;
|
|
}
|
|
|
|
/* save the return code */
|
|
new_pcr->return_code = return_code;
|
|
|
|
/* make sure the return code is within bounds */
|
|
if(new_pcr->return_code < 0 || new_pcr->return_code > 3)
|
|
new_pcr->return_code = STATE_UNKNOWN;
|
|
|
|
new_pcr->check_time = check_time;
|
|
|
|
/* calculate latency */
|
|
gettimeofday(&tv, NULL);
|
|
new_pcr->latency = (double)((double)(tv.tv_sec - check_time) + (double)(tv.tv_usec / 1000.0) / 1000.0);
|
|
if(new_pcr->latency < 0.0)
|
|
new_pcr->latency = 0.0;
|
|
|
|
/* add the passive check result to the end of the list in memory */
|
|
if(passive_check_result_list == NULL)
|
|
passive_check_result_list = new_pcr;
|
|
else
|
|
passive_check_result_list_tail->next = new_pcr;
|
|
passive_check_result_list_tail = new_pcr;
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* acknowledges a host or service problem */
|
|
int cmd_acknowledge_problem(int cmd, char *args) {
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
char *ack_author = NULL;
|
|
char *ack_data = NULL;
|
|
char *temp_ptr = NULL;
|
|
int type = ACKNOWLEDGEMENT_NORMAL;
|
|
int notify = TRUE;
|
|
int persistent = TRUE;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* this is a service acknowledgement */
|
|
if(cmd == CMD_ACKNOWLEDGE_SVC_PROBLEM) {
|
|
|
|
/* get the service name */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(temp_host->name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* get the type */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
type = atoi(temp_ptr);
|
|
|
|
/* get the notification option */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
notify = (atoi(temp_ptr) > 0) ? TRUE : FALSE;
|
|
|
|
/* get the persistent option */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
persistent = (atoi(temp_ptr) > 0) ? TRUE : FALSE;
|
|
|
|
/* get the acknowledgement author */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
ack_author = (char *)strdup(temp_ptr);
|
|
|
|
/* get the acknowledgement data */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL) {
|
|
my_free(ack_author);
|
|
return ERROR;
|
|
}
|
|
ack_data = (char *)strdup(temp_ptr);
|
|
|
|
/* acknowledge the host problem */
|
|
if(cmd == CMD_ACKNOWLEDGE_HOST_PROBLEM)
|
|
acknowledge_host_problem(temp_host, ack_author, ack_data, type, notify, persistent);
|
|
|
|
/* acknowledge the service problem */
|
|
else
|
|
acknowledge_service_problem(temp_service, ack_author, ack_data, type, notify, persistent);
|
|
|
|
/* free memory */
|
|
my_free(ack_author);
|
|
my_free(ack_data);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* removes a host or service acknowledgement */
|
|
int cmd_remove_acknowledgement(int cmd, char *args) {
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* we are removing a service acknowledgement */
|
|
if(cmd == CMD_REMOVE_SVC_ACKNOWLEDGEMENT) {
|
|
|
|
/* get the service name */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(temp_host->name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
/* acknowledge the host problem */
|
|
if(cmd == CMD_REMOVE_HOST_ACKNOWLEDGEMENT)
|
|
remove_host_acknowledgement(temp_host);
|
|
|
|
/* acknowledge the service problem */
|
|
else
|
|
remove_service_acknowledgement(temp_service);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* schedules downtime for a specific host or service */
|
|
int cmd_schedule_downtime(int cmd, time_t entry_time, char *args) {
|
|
servicesmember *temp_servicesmember = NULL;
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
host *last_host = NULL;
|
|
hostgroup *temp_hostgroup = NULL;
|
|
hostsmember *temp_hgmember = NULL;
|
|
servicegroup *temp_servicegroup = NULL;
|
|
servicesmember *temp_sgmember = NULL;
|
|
char *host_name = NULL;
|
|
char *hostgroup_name = NULL;
|
|
char *servicegroup_name = NULL;
|
|
char *svc_description = NULL;
|
|
char *temp_ptr = NULL;
|
|
time_t start_time = 0L;
|
|
time_t end_time = 0L;
|
|
int fixed = 0;
|
|
unsigned long triggered_by = 0L;
|
|
unsigned long duration = 0L;
|
|
char *author = NULL;
|
|
char *comment_data = NULL;
|
|
unsigned long downtime_id = 0L;
|
|
|
|
if(cmd == CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME || cmd == CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME) {
|
|
|
|
/* get the hostgroup name */
|
|
if((hostgroup_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the hostgroup is valid */
|
|
if((temp_hostgroup = find_hostgroup(hostgroup_name)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
else if(cmd == CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME || cmd == CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME) {
|
|
|
|
/* get the servicegroup name */
|
|
if((servicegroup_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the servicegroup is valid */
|
|
if((temp_servicegroup = find_servicegroup(servicegroup_name)) == NULL)
|
|
return ERROR;
|
|
}
|
|
|
|
else {
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
/* this is a service downtime */
|
|
if(cmd == CMD_SCHEDULE_SVC_DOWNTIME) {
|
|
|
|
/* get the service name */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(temp_host->name, svc_description)) == NULL)
|
|
return ERROR;
|
|
}
|
|
}
|
|
|
|
/* get the start time */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
start_time = (time_t)strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* get the end time */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
end_time = (time_t)strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* get the fixed flag */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
fixed = atoi(temp_ptr);
|
|
|
|
/* get the trigger id */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
triggered_by = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* get the duration */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
duration = strtoul(temp_ptr, NULL, 10);
|
|
|
|
/* get the author */
|
|
if((author = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the comment */
|
|
if((comment_data = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* check if flexible downtime demanded and duration set
|
|
to non-zero.
|
|
according to the documentation, a flexible downtime is
|
|
started between start and end time and will last for
|
|
"duration" seconds. strtoul converts a NULL value to 0
|
|
so if set to 0, bail out as a duration>0 is needed. */
|
|
|
|
if(fixed == 0 && duration == 0)
|
|
return ERROR;
|
|
|
|
|
|
/* duration should be auto-calculated, not user-specified */
|
|
if(fixed > 0)
|
|
duration = (unsigned long)(end_time - start_time);
|
|
|
|
/* schedule downtime */
|
|
switch(cmd) {
|
|
|
|
case CMD_SCHEDULE_HOST_DOWNTIME:
|
|
schedule_downtime(HOST_DOWNTIME, host_name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_SVC_DOWNTIME:
|
|
schedule_downtime(SERVICE_DOWNTIME, host_name, svc_description, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOST_SVC_DOWNTIME:
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
schedule_downtime(SERVICE_DOWNTIME, host_name, temp_service->description, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
}
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME:
|
|
for(temp_hgmember = temp_hostgroup->members; temp_hgmember != NULL; temp_hgmember = temp_hgmember->next)
|
|
schedule_downtime(HOST_DOWNTIME, temp_hgmember->host_name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME:
|
|
for(temp_hgmember = temp_hostgroup->members; temp_hgmember != NULL; temp_hgmember = temp_hgmember->next) {
|
|
if((temp_host = temp_hgmember->host_ptr) == NULL)
|
|
continue;
|
|
for(temp_servicesmember = temp_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
schedule_downtime(SERVICE_DOWNTIME, temp_service->host_name, temp_service->description, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
}
|
|
}
|
|
break;
|
|
|
|
case CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME:
|
|
last_host = NULL;
|
|
for(temp_sgmember = temp_servicegroup->members; temp_sgmember != NULL; temp_sgmember = temp_sgmember->next) {
|
|
temp_host = find_host(temp_sgmember->host_name);
|
|
if(temp_host == NULL)
|
|
continue;
|
|
if(last_host == temp_host)
|
|
continue;
|
|
schedule_downtime(HOST_DOWNTIME, temp_sgmember->host_name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
last_host = temp_host;
|
|
}
|
|
break;
|
|
|
|
case CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME:
|
|
for(temp_sgmember = temp_servicegroup->members; temp_sgmember != NULL; temp_sgmember = temp_sgmember->next)
|
|
schedule_downtime(SERVICE_DOWNTIME, temp_sgmember->host_name, temp_sgmember->service_description, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME:
|
|
|
|
/* schedule downtime for "parent" host */
|
|
schedule_downtime(HOST_DOWNTIME, host_name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
|
|
/* schedule (non-triggered) downtime for all child hosts */
|
|
schedule_and_propagate_downtime(temp_host, entry_time, author, comment_data, start_time, end_time, fixed, 0, duration);
|
|
break;
|
|
|
|
case CMD_SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME:
|
|
|
|
/* schedule downtime for "parent" host */
|
|
schedule_downtime(HOST_DOWNTIME, host_name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, &downtime_id);
|
|
|
|
/* schedule triggered downtime for all child hosts */
|
|
schedule_and_propagate_downtime(temp_host, entry_time, author, comment_data, start_time, end_time, fixed, downtime_id, duration);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* deletes scheduled host or service downtime */
|
|
int cmd_delete_downtime(int cmd, char *args) {
|
|
unsigned long downtime_id = 0L;
|
|
char *temp_ptr = NULL;
|
|
|
|
/* get the id of the downtime to delete */
|
|
if((temp_ptr = my_strtok(args, "\n")) == NULL)
|
|
return ERROR;
|
|
downtime_id = strtoul(temp_ptr, NULL, 10);
|
|
|
|
if(cmd == CMD_DEL_HOST_DOWNTIME)
|
|
unschedule_downtime(HOST_DOWNTIME, downtime_id);
|
|
else
|
|
unschedule_downtime(SERVICE_DOWNTIME, downtime_id);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* Opsview enhancements: some of these commands are now "distributable" as no downtime ids are used */
|
|
/* Deletes scheduled host and service downtime based on hostname and optionally other filter arguments */
|
|
int cmd_delete_downtime_by_host_name(int cmd, char *args) {
|
|
char *temp_ptr = NULL;
|
|
char *end_ptr = NULL;
|
|
char *hostname = NULL;
|
|
char *service_description = NULL;
|
|
char *downtime_comment = NULL;
|
|
time_t downtime_start_time = 0L;
|
|
int deleted = 0;
|
|
|
|
/* get the host name of the downtime to delete */
|
|
temp_ptr = my_strtok(args, ";");
|
|
if(temp_ptr == NULL)
|
|
return ERROR;
|
|
hostname = temp_ptr;
|
|
|
|
/* get the optional service name */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
service_description = temp_ptr;
|
|
|
|
/* get the optional start time */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
downtime_start_time = strtoul(temp_ptr, &end_ptr, 10);
|
|
|
|
/* get the optional comment */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
downtime_comment = temp_ptr;
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
deleted = delete_downtime_by_hostname_service_description_start_time_comment(hostname, service_description, downtime_start_time, downtime_comment);
|
|
|
|
if(deleted == 0)
|
|
return ERROR;
|
|
|
|
return OK;
|
|
}
|
|
|
|
/* Opsview enhancement: Deletes scheduled host and service downtime based on hostgroup and optionally other filter arguments */
|
|
int cmd_delete_downtime_by_hostgroup_name(int cmd, char *args) {
|
|
char *temp_ptr = NULL;
|
|
char *end_ptr = NULL;
|
|
host *temp_host = NULL;
|
|
hostgroup *temp_hostgroup = NULL;
|
|
hostsmember *temp_member = NULL;
|
|
char *service_description = NULL;
|
|
char *downtime_comment = NULL;
|
|
char *host_name = NULL;
|
|
time_t downtime_start_time = 0L;
|
|
int deleted = 0;
|
|
|
|
/* get the host group name of the downtime to delete */
|
|
temp_ptr = my_strtok(args, ";");
|
|
if(temp_ptr == NULL)
|
|
return ERROR;
|
|
|
|
temp_hostgroup = find_hostgroup(temp_ptr);
|
|
if(temp_hostgroup == NULL)
|
|
return ERROR;
|
|
|
|
/* get the optional host name */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
host_name = temp_ptr;
|
|
|
|
/* get the optional service name */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
service_description = temp_ptr;
|
|
|
|
/* get the optional start time */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
downtime_start_time = strtoul(temp_ptr, &end_ptr, 10);
|
|
|
|
/* get the optional comment */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
downtime_comment = temp_ptr;
|
|
|
|
}
|
|
}
|
|
}
|
|
|
|
/* get the optional service name */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
service_description = temp_ptr;
|
|
|
|
/* get the optional start time */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
downtime_start_time = strtoul(temp_ptr, &end_ptr, 10);
|
|
|
|
/* get the optional comment */
|
|
temp_ptr = my_strtok(NULL, ";");
|
|
if(temp_ptr != NULL) {
|
|
if(*temp_ptr != '\0')
|
|
downtime_comment = temp_ptr;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
for(temp_member = temp_hostgroup->members; temp_member != NULL; temp_member = temp_member->next) {
|
|
if((temp_host = (host *)temp_member->host_ptr) == NULL)
|
|
continue;
|
|
if(host_name != NULL && strcmp(temp_host->name, host_name) != 0)
|
|
continue;
|
|
deleted = +delete_downtime_by_hostname_service_description_start_time_comment(temp_host->name, service_description, downtime_start_time, downtime_comment);
|
|
}
|
|
|
|
if(deleted == 0)
|
|
return ERROR;
|
|
|
|
return OK;
|
|
}
|
|
|
|
/* Opsview enhancement: Delete downtimes based on start time and/or comment */
|
|
int cmd_delete_downtime_by_start_time_comment(int cmd, char *args) {
|
|
time_t downtime_start_time = 0L;
|
|
char *downtime_comment = NULL;
|
|
char *temp_ptr = NULL;
|
|
char *end_ptr = NULL;
|
|
int deleted = 0;
|
|
|
|
/* Get start time if set */
|
|
temp_ptr = my_strtok(args, ";");
|
|
if(temp_ptr != NULL) {
|
|
/* This will be set to 0 if no start_time is entered or data is bad */
|
|
downtime_start_time = strtoul(temp_ptr, &end_ptr, 10);
|
|
}
|
|
|
|
/* Get comment - not sure if this should be also tokenised by ; */
|
|
temp_ptr = my_strtok(NULL, "\n");
|
|
if(temp_ptr != NULL && *temp_ptr != '\0') {
|
|
downtime_comment = temp_ptr;
|
|
}
|
|
|
|
/* No args should give an error */
|
|
if(downtime_start_time == 0 && downtime_comment == NULL)
|
|
return ERROR;
|
|
|
|
deleted = delete_downtime_by_hostname_service_description_start_time_comment(NULL, NULL, downtime_start_time, downtime_comment);
|
|
|
|
if(deleted == 0)
|
|
return ERROR;
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* changes a host or service (integer) variable */
|
|
int cmd_change_object_int_var(int cmd, char *args) {
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
contact *temp_contact = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
char *contact_name = NULL;
|
|
char *temp_ptr = NULL;
|
|
int intval = 0;
|
|
double dval = 0.0;
|
|
double old_dval = 0.0;
|
|
time_t preferred_time = 0L;
|
|
time_t next_valid_time = 0L;
|
|
unsigned long attr = MODATTR_NONE;
|
|
unsigned long hattr = MODATTR_NONE;
|
|
unsigned long sattr = MODATTR_NONE;
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_SVC_MODATTR:
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the service name */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_HOST_MODATTR:
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_MODATTR:
|
|
case CMD_CHANGE_CONTACT_MODHATTR:
|
|
case CMD_CHANGE_CONTACT_MODSATTR:
|
|
|
|
/* get the contact name */
|
|
if((contact_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the contact is valid */
|
|
if((temp_contact = find_contact(contact_name)) == NULL)
|
|
return ERROR;
|
|
break;
|
|
|
|
default:
|
|
/* unknown command */
|
|
return ERROR;
|
|
break;
|
|
}
|
|
|
|
/* get the value */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
intval = (int)strtol(temp_ptr, NULL, 0);
|
|
if(intval < 0 || (intval == 0 && errno == EINVAL))
|
|
return ERROR;
|
|
dval = (int)strtod(temp_ptr, NULL);
|
|
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL:
|
|
|
|
/* save the old check interval */
|
|
old_dval = temp_host->check_interval;
|
|
|
|
/* modify the check interval */
|
|
temp_host->check_interval = dval;
|
|
attr = MODATTR_NORMAL_CHECK_INTERVAL;
|
|
|
|
/* schedule a host check if previous interval was 0 (checks were not regularly scheduled) */
|
|
if(old_dval == 0 && temp_host->checks_enabled == TRUE) {
|
|
|
|
/* set the host check flag */
|
|
temp_host->should_be_scheduled = TRUE;
|
|
|
|
/* schedule a check for right now (or as soon as possible) */
|
|
time(&preferred_time);
|
|
if(check_time_against_period(preferred_time, temp_host->check_period_ptr) == ERROR) {
|
|
get_next_valid_time(preferred_time, &next_valid_time, temp_host->check_period_ptr);
|
|
temp_host->next_check = next_valid_time;
|
|
}
|
|
else
|
|
temp_host->next_check = preferred_time;
|
|
|
|
/* schedule a check if we should */
|
|
if(temp_host->should_be_scheduled == TRUE)
|
|
schedule_host_check(temp_host, temp_host->next_check, CHECK_OPTION_NONE);
|
|
}
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL:
|
|
|
|
temp_host->retry_interval = dval;
|
|
attr = MODATTR_RETRY_CHECK_INTERVAL;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS:
|
|
|
|
temp_host->max_attempts = intval;
|
|
attr = MODATTR_MAX_CHECK_ATTEMPTS;
|
|
|
|
/* adjust current attempt number if in a hard state */
|
|
if(temp_host->state_type == HARD_STATE && temp_host->current_state != HOST_UP && temp_host->current_attempt > 1)
|
|
temp_host->current_attempt = temp_host->max_attempts;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL:
|
|
|
|
/* save the old check interval */
|
|
old_dval = temp_service->check_interval;
|
|
|
|
/* modify the check interval */
|
|
temp_service->check_interval = dval;
|
|
attr = MODATTR_NORMAL_CHECK_INTERVAL;
|
|
|
|
/* schedule a service check if previous interval was 0 (checks were not regularly scheduled) */
|
|
if(old_dval == 0 && temp_service->checks_enabled == TRUE && temp_service->check_interval != 0) {
|
|
|
|
/* set the service check flag */
|
|
temp_service->should_be_scheduled = TRUE;
|
|
|
|
/* schedule a check for right now (or as soon as possible) */
|
|
time(&preferred_time);
|
|
if(check_time_against_period(preferred_time, temp_service->check_period_ptr) == ERROR) {
|
|
get_next_valid_time(preferred_time, &next_valid_time, temp_service->check_period_ptr);
|
|
temp_service->next_check = next_valid_time;
|
|
}
|
|
else
|
|
temp_service->next_check = preferred_time;
|
|
|
|
/* schedule a check if we should */
|
|
if(temp_service->should_be_scheduled == TRUE)
|
|
schedule_service_check(temp_service, temp_service->next_check, CHECK_OPTION_NONE);
|
|
}
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL:
|
|
|
|
temp_service->retry_interval = dval;
|
|
attr = MODATTR_RETRY_CHECK_INTERVAL;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS:
|
|
|
|
temp_service->max_attempts = intval;
|
|
attr = MODATTR_MAX_CHECK_ATTEMPTS;
|
|
|
|
/* adjust current attempt number if in a hard state */
|
|
if(temp_service->state_type == HARD_STATE && temp_service->current_state != STATE_OK && temp_service->current_attempt > 1)
|
|
temp_service->current_attempt = temp_service->max_attempts;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_MODATTR:
|
|
case CMD_CHANGE_SVC_MODATTR:
|
|
case CMD_CHANGE_CONTACT_MODATTR:
|
|
|
|
attr = intval;
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_MODHATTR:
|
|
|
|
hattr = intval;
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_MODSATTR:
|
|
|
|
sattr = intval;
|
|
break;
|
|
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
|
|
/* send data to event broker and update status file */
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL:
|
|
case CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_SVC_MODATTR:
|
|
|
|
/* set the modified service attribute */
|
|
if(cmd == CMD_CHANGE_SVC_MODATTR)
|
|
temp_service->modified_attributes = attr;
|
|
else
|
|
temp_service->modified_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_service, cmd, attr, temp_service->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(temp_service, FALSE);
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL:
|
|
case CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS:
|
|
case CMD_CHANGE_HOST_MODATTR:
|
|
|
|
/* set the modified host attribute */
|
|
if(cmd == CMD_CHANGE_HOST_MODATTR)
|
|
temp_host->modified_attributes = attr;
|
|
else
|
|
temp_host->modified_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_host, cmd, attr, temp_host->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(temp_host, FALSE);
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_MODATTR:
|
|
case CMD_CHANGE_CONTACT_MODHATTR:
|
|
case CMD_CHANGE_CONTACT_MODSATTR:
|
|
|
|
/* set the modified attribute */
|
|
switch(cmd) {
|
|
case CMD_CHANGE_CONTACT_MODATTR:
|
|
temp_contact->modified_attributes = attr;
|
|
break;
|
|
case CMD_CHANGE_CONTACT_MODHATTR:
|
|
temp_contact->modified_host_attributes = hattr;
|
|
break;
|
|
case CMD_CHANGE_CONTACT_MODSATTR:
|
|
temp_contact->modified_service_attributes = sattr;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_contact, cmd, attr, temp_contact->modified_attributes, hattr, temp_contact->modified_host_attributes, sattr, temp_contact->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the contact info */
|
|
update_contact_status(temp_contact, FALSE);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* changes a host or service (char) variable */
|
|
int cmd_change_object_char_var(int cmd, char *args) {
|
|
service *temp_service = NULL;
|
|
host *temp_host = NULL;
|
|
contact *temp_contact = NULL;
|
|
timeperiod *temp_timeperiod = NULL;
|
|
command *temp_command = NULL;
|
|
char *host_name = NULL;
|
|
char *svc_description = NULL;
|
|
char *contact_name = NULL;
|
|
char *charval = NULL;
|
|
char *temp_ptr = NULL;
|
|
char *temp_ptr2 = NULL;
|
|
unsigned long attr = MODATTR_NONE;
|
|
unsigned long hattr = MODATTR_NONE;
|
|
unsigned long sattr = MODATTR_NONE;
|
|
|
|
|
|
/* SECURITY PATCH - disable these for the time being */
|
|
switch(cmd) {
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
return ERROR;
|
|
}
|
|
|
|
|
|
/* get the command arguments */
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
|
|
if((charval = my_strtok(args, "\n")) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
case CMD_CHANGE_HOST_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the host is valid */
|
|
if((temp_host = find_host(host_name)) == NULL)
|
|
return ERROR;
|
|
|
|
if((charval = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
case CMD_CHANGE_SVC_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* get the host name */
|
|
if((host_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the service name */
|
|
if((svc_description = my_strtok(NULL, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the service is valid */
|
|
if((temp_service = find_service(host_name, svc_description)) == NULL)
|
|
return ERROR;
|
|
|
|
if((charval = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
|
|
case CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* get the contact name */
|
|
if((contact_name = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
|
|
/* verify that the contact is valid */
|
|
if((temp_contact = find_contact(contact_name)) == NULL)
|
|
return ERROR;
|
|
|
|
if((charval = my_strtok(NULL, "\n")) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
default:
|
|
/* invalid command */
|
|
return ERROR;
|
|
break;
|
|
|
|
}
|
|
|
|
if((temp_ptr = (char *)strdup(charval)) == NULL)
|
|
return ERROR;
|
|
|
|
|
|
/* do some validation */
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_HOST_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* make sure the timeperiod is valid */
|
|
if((temp_timeperiod = find_timeperiod(temp_ptr)) == NULL) {
|
|
my_free(temp_ptr);
|
|
return ERROR;
|
|
}
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
|
|
/* make sure the command exists */
|
|
temp_ptr2 = my_strtok(temp_ptr, "!");
|
|
if((temp_command = find_command(temp_ptr2)) == NULL) {
|
|
my_free(temp_ptr);
|
|
return ERROR;
|
|
}
|
|
|
|
my_free(temp_ptr);
|
|
if((temp_ptr = (char *)strdup(charval)) == NULL)
|
|
return ERROR;
|
|
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
|
|
/* update the variable */
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
|
|
my_free(global_host_event_handler);
|
|
global_host_event_handler = temp_ptr;
|
|
global_host_event_handler_ptr = temp_command;
|
|
attr = MODATTR_EVENT_HANDLER_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
|
|
my_free(global_service_event_handler);
|
|
global_service_event_handler = temp_ptr;
|
|
global_service_event_handler_ptr = temp_command;
|
|
attr = MODATTR_EVENT_HANDLER_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
|
|
my_free(temp_host->event_handler);
|
|
temp_host->event_handler = temp_ptr;
|
|
temp_host->event_handler_ptr = temp_command;
|
|
attr = MODATTR_EVENT_HANDLER_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
|
|
my_free(temp_host->host_check_command);
|
|
temp_host->host_check_command = temp_ptr;
|
|
temp_host->check_command_ptr = temp_command;
|
|
attr = MODATTR_CHECK_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_CHECK_TIMEPERIOD:
|
|
|
|
my_free(temp_host->check_period);
|
|
temp_host->check_period = temp_ptr;
|
|
temp_host->check_period_ptr = temp_timeperiod;
|
|
attr = MODATTR_CHECK_TIMEPERIOD;
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD:
|
|
|
|
my_free(temp_host->notification_period);
|
|
temp_host->notification_period = temp_ptr;
|
|
temp_host->notification_period_ptr = temp_timeperiod;
|
|
attr = MODATTR_NOTIFICATION_TIMEPERIOD;
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
|
|
my_free(temp_service->event_handler);
|
|
temp_service->event_handler = temp_ptr;
|
|
temp_service->event_handler_ptr = temp_command;
|
|
attr = MODATTR_EVENT_HANDLER_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
|
|
my_free(temp_service->service_check_command);
|
|
temp_service->service_check_command = temp_ptr;
|
|
temp_service->check_command_ptr = temp_command;
|
|
attr = MODATTR_CHECK_COMMAND;
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_CHECK_TIMEPERIOD:
|
|
|
|
my_free(temp_service->check_period);
|
|
temp_service->check_period = temp_ptr;
|
|
temp_service->check_period_ptr = temp_timeperiod;
|
|
attr = MODATTR_CHECK_TIMEPERIOD;
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
my_free(temp_service->notification_period);
|
|
temp_service->notification_period = temp_ptr;
|
|
temp_service->notification_period_ptr = temp_timeperiod;
|
|
attr = MODATTR_NOTIFICATION_TIMEPERIOD;
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD:
|
|
|
|
my_free(temp_contact->host_notification_period);
|
|
temp_contact->host_notification_period = temp_ptr;
|
|
temp_contact->host_notification_period_ptr = temp_timeperiod;
|
|
hattr = MODATTR_NOTIFICATION_TIMEPERIOD;
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
my_free(temp_contact->service_notification_period);
|
|
temp_contact->service_notification_period = temp_ptr;
|
|
temp_contact->service_notification_period_ptr = temp_timeperiod;
|
|
sattr = MODATTR_NOTIFICATION_TIMEPERIOD;
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
|
|
/* send data to event broker and update status file */
|
|
switch(cmd) {
|
|
|
|
case CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER:
|
|
|
|
/* set the modified host attribute */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cmd, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update program status */
|
|
update_program_status(FALSE);
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER:
|
|
|
|
/* set the modified service attribute */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cmd, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update program status */
|
|
update_program_status(FALSE);
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_SVC_EVENT_HANDLER:
|
|
case CMD_CHANGE_SVC_CHECK_COMMAND:
|
|
case CMD_CHANGE_SVC_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* set the modified service attribute */
|
|
temp_service->modified_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_service, cmd, attr, temp_service->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(temp_service, FALSE);
|
|
|
|
break;
|
|
|
|
case CMD_CHANGE_HOST_EVENT_HANDLER:
|
|
case CMD_CHANGE_HOST_CHECK_COMMAND:
|
|
case CMD_CHANGE_HOST_CHECK_TIMEPERIOD:
|
|
case CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* set the modified host attribute */
|
|
temp_host->modified_attributes |= attr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_host, cmd, attr, temp_host->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(temp_host, FALSE);
|
|
break;
|
|
|
|
case CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD:
|
|
case CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD:
|
|
|
|
/* set the modified attributes */
|
|
temp_contact->modified_host_attributes |= hattr;
|
|
temp_contact->modified_service_attributes |= sattr;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, temp_contact, cmd, attr, temp_contact->modified_attributes, hattr, temp_contact->modified_host_attributes, sattr, temp_contact->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the contact info */
|
|
update_contact_status(temp_contact, FALSE);
|
|
break;
|
|
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
|
|
/* changes a custom host or service variable */
|
|
int cmd_change_object_custom_var(int cmd, char *args) {
|
|
host *temp_host = NULL;
|
|
service *temp_service = NULL;
|
|
contact *temp_contact = NULL;
|
|
customvariablesmember *temp_customvariablesmember = NULL;
|
|
char *temp_ptr = NULL;
|
|
char *name1 = NULL;
|
|
char *name2 = NULL;
|
|
char *varname = NULL;
|
|
char *varvalue = NULL;
|
|
register int x = 0;
|
|
|
|
/* get the host or contact name */
|
|
if((temp_ptr = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
if((name1 = (char *)strdup(temp_ptr)) == NULL)
|
|
return ERROR;
|
|
|
|
/* get the service description if necessary */
|
|
if(cmd == CMD_CHANGE_CUSTOM_SVC_VAR) {
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(name1);
|
|
return ERROR;
|
|
}
|
|
if((name2 = (char *)strdup(temp_ptr)) == NULL) {
|
|
my_free(name1);
|
|
return ERROR;
|
|
}
|
|
}
|
|
|
|
/* get the custom variable name */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(name1);
|
|
my_free(name2);
|
|
return ERROR;
|
|
}
|
|
if((varname = (char *)strdup(temp_ptr)) == NULL) {
|
|
my_free(name1);
|
|
my_free(name2);
|
|
return ERROR;
|
|
}
|
|
|
|
/* get the custom variable value */
|
|
if((temp_ptr = my_strtok(NULL, ";")) == NULL) {
|
|
my_free(name1);
|
|
my_free(name2);
|
|
my_free(varname);
|
|
return ERROR;
|
|
}
|
|
if((varvalue = (char *)strdup(temp_ptr)) == NULL) {
|
|
my_free(name1);
|
|
my_free(name2);
|
|
my_free(varname);
|
|
return ERROR;
|
|
}
|
|
|
|
/* find the object */
|
|
switch(cmd) {
|
|
case CMD_CHANGE_CUSTOM_HOST_VAR:
|
|
if((temp_host = find_host(name1)) == NULL)
|
|
return ERROR;
|
|
temp_customvariablesmember = temp_host->custom_variables;
|
|
break;
|
|
case CMD_CHANGE_CUSTOM_SVC_VAR:
|
|
if((temp_service = find_service(name1, name2)) == NULL)
|
|
return ERROR;
|
|
temp_customvariablesmember = temp_service->custom_variables;
|
|
break;
|
|
case CMD_CHANGE_CUSTOM_CONTACT_VAR:
|
|
if((temp_contact = find_contact(name1)) == NULL)
|
|
return ERROR;
|
|
temp_customvariablesmember = temp_contact->custom_variables;
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
/* capitalize the custom variable name */
|
|
for(x = 0; varname[x] != '\x0'; x++)
|
|
varname[x] = toupper(varname[x]);
|
|
|
|
/* find the proper variable */
|
|
for(; temp_customvariablesmember != NULL; temp_customvariablesmember = temp_customvariablesmember->next) {
|
|
|
|
/* we found the variable, so update the value */
|
|
if(!strcmp(varname, temp_customvariablesmember->variable_name)) {
|
|
|
|
/* update the value */
|
|
if(temp_customvariablesmember->variable_value)
|
|
my_free(temp_customvariablesmember->variable_value);
|
|
temp_customvariablesmember->variable_value = (char *)strdup(varvalue);
|
|
|
|
/* mark the variable value as having been changed */
|
|
temp_customvariablesmember->has_been_modified = TRUE;
|
|
|
|
break;
|
|
}
|
|
}
|
|
|
|
/* free memory */
|
|
my_free(name1);
|
|
my_free(name2);
|
|
my_free(varname);
|
|
my_free(varvalue);
|
|
|
|
/* set the modified attributes and update the status of the object */
|
|
switch(cmd) {
|
|
case CMD_CHANGE_CUSTOM_HOST_VAR:
|
|
temp_host->modified_attributes |= MODATTR_CUSTOM_VARIABLE;
|
|
update_host_status(temp_host, FALSE);
|
|
break;
|
|
case CMD_CHANGE_CUSTOM_SVC_VAR:
|
|
temp_service->modified_attributes |= MODATTR_CUSTOM_VARIABLE;
|
|
update_service_status(temp_service, FALSE);
|
|
break;
|
|
case CMD_CHANGE_CUSTOM_CONTACT_VAR:
|
|
temp_contact->modified_attributes |= MODATTR_CUSTOM_VARIABLE;
|
|
update_contact_status(temp_contact, FALSE);
|
|
break;
|
|
default:
|
|
break;
|
|
}
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/* processes an external host command */
|
|
int cmd_process_external_commands_from_file(int cmd, char *args) {
|
|
char *fname = NULL;
|
|
char *temp_ptr = NULL;
|
|
int delete_file = FALSE;
|
|
|
|
/* get the file name */
|
|
if((temp_ptr = my_strtok(args, ";")) == NULL)
|
|
return ERROR;
|
|
if((fname = (char *)strdup(temp_ptr)) == NULL)
|
|
return ERROR;
|
|
|
|
/* find the deletion option */
|
|
if((temp_ptr = my_strtok(NULL, "\n")) == NULL) {
|
|
my_free(fname);
|
|
return ERROR;
|
|
}
|
|
if(atoi(temp_ptr) == 0)
|
|
delete_file = FALSE;
|
|
else
|
|
delete_file = TRUE;
|
|
|
|
/* process the file */
|
|
process_external_commands_from_file(fname, delete_file);
|
|
|
|
/* free memory */
|
|
my_free(fname);
|
|
|
|
return OK;
|
|
}
|
|
|
|
|
|
/******************************************************************/
|
|
/*************** INTERNAL COMMAND IMPLEMENTATIONS ****************/
|
|
/******************************************************************/
|
|
|
|
/* temporarily disables a service check */
|
|
void disable_service_checks(service *svc) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* checks are already disabled */
|
|
if(svc->checks_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* disable the service check... */
|
|
svc->checks_enabled = FALSE;
|
|
svc->should_be_scheduled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new service state */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables a service check */
|
|
void enable_service_checks(service *svc) {
|
|
time_t preferred_time = 0L;
|
|
time_t next_valid_time = 0L;
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* checks are already enabled */
|
|
if(svc->checks_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* enable the service check... */
|
|
svc->checks_enabled = TRUE;
|
|
svc->should_be_scheduled = TRUE;
|
|
|
|
/* services with no check intervals don't get checked */
|
|
if(svc->check_interval == 0)
|
|
svc->should_be_scheduled = FALSE;
|
|
|
|
/* schedule a check for right now (or as soon as possible) */
|
|
time(&preferred_time);
|
|
if(check_time_against_period(preferred_time, svc->check_period_ptr) == ERROR) {
|
|
get_next_valid_time(preferred_time, &next_valid_time, svc->check_period_ptr);
|
|
svc->next_check = next_valid_time;
|
|
}
|
|
else
|
|
svc->next_check = preferred_time;
|
|
|
|
/* schedule a check if we should */
|
|
if(svc->should_be_scheduled == TRUE)
|
|
schedule_service_check(svc, svc->next_check, CHECK_OPTION_NONE);
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new service state */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enable notifications on a program-wide basis */
|
|
void enable_all_notifications(void) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* bail out if we're already set... */
|
|
if(enable_notifications == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* update notification status */
|
|
enable_notifications = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disable notifications on a program-wide basis */
|
|
void disable_all_notifications(void) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* bail out if we're already set... */
|
|
if(enable_notifications == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* update notification status */
|
|
enable_notifications = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables notifications for a service */
|
|
void enable_service_notifications(service *svc) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->notifications_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* enable the service notifications... */
|
|
svc->notifications_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new service state */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables notifications for a service */
|
|
void disable_service_notifications(service *svc) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->notifications_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* disable the service notifications... */
|
|
svc->notifications_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new service state */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables notifications for a host */
|
|
void enable_host_notifications(host *hst) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->notifications_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* enable the host notifications... */
|
|
hst->notifications_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new host state */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables notifications for a host */
|
|
void disable_host_notifications(host *hst) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->notifications_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* disable the host notifications... */
|
|
hst->notifications_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new host state */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables notifications for all hosts and services "beyond" a given host */
|
|
void enable_and_propagate_notifications(host *hst, int level, int affect_top_host, int affect_hosts, int affect_services) {
|
|
host *child_host = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
hostsmember *temp_hostsmember = NULL;
|
|
|
|
/* enable notification for top level host */
|
|
if(affect_top_host == TRUE && level == 0)
|
|
enable_host_notifications(hst);
|
|
|
|
/* check all child hosts... */
|
|
for(temp_hostsmember = hst->child_hosts; temp_hostsmember != NULL; temp_hostsmember = temp_hostsmember->next) {
|
|
|
|
if((child_host = temp_hostsmember->host_ptr) == NULL)
|
|
continue;
|
|
|
|
/* recurse... */
|
|
enable_and_propagate_notifications(child_host, level + 1, affect_top_host, affect_hosts, affect_services);
|
|
|
|
/* enable notifications for this host */
|
|
if(affect_hosts == TRUE)
|
|
enable_host_notifications(child_host);
|
|
|
|
/* enable notifications for all services on this host... */
|
|
if(affect_services == TRUE) {
|
|
for(temp_servicesmember = child_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
enable_service_notifications(temp_service);
|
|
}
|
|
}
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables notifications for all hosts and services "beyond" a given host */
|
|
void disable_and_propagate_notifications(host *hst, int level, int affect_top_host, int affect_hosts, int affect_services) {
|
|
host *child_host = NULL;
|
|
service *temp_service = NULL;
|
|
servicesmember *temp_servicesmember = NULL;
|
|
hostsmember *temp_hostsmember = NULL;
|
|
|
|
if(hst == NULL)
|
|
return;
|
|
|
|
/* disable notifications for top host */
|
|
if(affect_top_host == TRUE && level == 0)
|
|
disable_host_notifications(hst);
|
|
|
|
/* check all child hosts... */
|
|
for(temp_hostsmember = hst->child_hosts; temp_hostsmember != NULL; temp_hostsmember = temp_hostsmember->next) {
|
|
|
|
if((child_host = temp_hostsmember->host_ptr) == NULL)
|
|
continue;
|
|
|
|
/* recurse... */
|
|
disable_and_propagate_notifications(child_host, level + 1, affect_top_host, affect_hosts, affect_services);
|
|
|
|
/* disable notifications for this host */
|
|
if(affect_hosts == TRUE)
|
|
disable_host_notifications(child_host);
|
|
|
|
/* disable notifications for all services on this host... */
|
|
if(affect_services == TRUE) {
|
|
for(temp_servicesmember = child_host->services; temp_servicesmember != NULL; temp_servicesmember = temp_servicesmember->next) {
|
|
if((temp_service = temp_servicesmember->service_ptr) == NULL)
|
|
continue;
|
|
disable_service_notifications(temp_service);
|
|
}
|
|
}
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables host notifications for a contact */
|
|
void enable_contact_host_notifications(contact *cntct) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(cntct->host_notifications_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
cntct->modified_host_attributes |= attr;
|
|
|
|
/* enable the host notifications... */
|
|
cntct->host_notifications_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cntct, CMD_NONE, MODATTR_NONE, cntct->modified_attributes, attr, cntct->modified_host_attributes, MODATTR_NONE, cntct->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new contact state */
|
|
update_contact_status(cntct, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* disables host notifications for a contact */
|
|
void disable_contact_host_notifications(contact *cntct) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(cntct->host_notifications_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
cntct->modified_host_attributes |= attr;
|
|
|
|
/* enable the host notifications... */
|
|
cntct->host_notifications_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cntct, CMD_NONE, MODATTR_NONE, cntct->modified_attributes, attr, cntct->modified_host_attributes, MODATTR_NONE, cntct->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new contact state */
|
|
update_contact_status(cntct, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables service notifications for a contact */
|
|
void enable_contact_service_notifications(contact *cntct) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(cntct->service_notifications_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
cntct->modified_service_attributes |= attr;
|
|
|
|
/* enable the host notifications... */
|
|
cntct->service_notifications_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cntct, CMD_NONE, MODATTR_NONE, cntct->modified_attributes, MODATTR_NONE, cntct->modified_host_attributes, attr, cntct->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new contact state */
|
|
update_contact_status(cntct, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* disables service notifications for a contact */
|
|
void disable_contact_service_notifications(contact *cntct) {
|
|
unsigned long attr = MODATTR_NOTIFICATIONS_ENABLED;
|
|
|
|
/* no change */
|
|
if(cntct->service_notifications_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
cntct->modified_service_attributes |= attr;
|
|
|
|
/* enable the host notifications... */
|
|
cntct->service_notifications_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_contact_data(NEBTYPE_ADAPTIVECONTACT_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, cntct, CMD_NONE, MODATTR_NONE, cntct->modified_attributes, MODATTR_NONE, cntct->modified_host_attributes, attr, cntct->modified_service_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log to reflect the new contact state */
|
|
update_contact_status(cntct, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* schedules downtime for all hosts "beyond" a given host */
|
|
void schedule_and_propagate_downtime(host *temp_host, time_t entry_time, char *author, char *comment_data, time_t start_time, time_t end_time, int fixed, unsigned long triggered_by, unsigned long duration) {
|
|
host *child_host = NULL;
|
|
hostsmember *temp_hostsmember = NULL;
|
|
|
|
/* check all child hosts... */
|
|
for(temp_hostsmember = temp_host->child_hosts; temp_hostsmember != NULL; temp_hostsmember = temp_hostsmember->next) {
|
|
|
|
if((child_host = temp_hostsmember->host_ptr) == NULL)
|
|
continue;
|
|
|
|
/* recurse... */
|
|
schedule_and_propagate_downtime(child_host, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration);
|
|
|
|
/* schedule downtime for this host */
|
|
schedule_downtime(HOST_DOWNTIME, child_host->name, NULL, entry_time, author, comment_data, start_time, end_time, fixed, triggered_by, duration, NULL);
|
|
}
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* acknowledges a host problem */
|
|
void acknowledge_host_problem(host *hst, char *ack_author, char *ack_data, int type, int notify, int persistent) {
|
|
time_t current_time = 0L;
|
|
|
|
/* cannot acknowledge a non-existent problem */
|
|
if(hst->current_state == HOST_UP)
|
|
return;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_acknowledgement_data(NEBTYPE_ACKNOWLEDGEMENT_ADD, NEBFLAG_NONE, NEBATTR_NONE, HOST_ACKNOWLEDGEMENT, (void *)hst, ack_author, ack_data, type, notify, persistent, NULL);
|
|
#endif
|
|
|
|
/* send out an acknowledgement notification */
|
|
if(notify == TRUE)
|
|
host_notification(hst, NOTIFICATION_ACKNOWLEDGEMENT, ack_author, ack_data, NOTIFICATION_OPTION_NONE);
|
|
|
|
/* set the acknowledgement flag */
|
|
hst->problem_has_been_acknowledged = TRUE;
|
|
|
|
/* set the acknowledgement type */
|
|
hst->acknowledgement_type = (type == ACKNOWLEDGEMENT_STICKY) ? ACKNOWLEDGEMENT_STICKY : ACKNOWLEDGEMENT_NORMAL;
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
/* add a comment for the acknowledgement */
|
|
time(¤t_time);
|
|
add_new_host_comment(ACKNOWLEDGEMENT_COMMENT, hst->name, current_time, ack_author, ack_data, persistent, COMMENTSOURCE_INTERNAL, FALSE, (time_t)0, NULL);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* acknowledges a service problem */
|
|
void acknowledge_service_problem(service *svc, char *ack_author, char *ack_data, int type, int notify, int persistent) {
|
|
time_t current_time = 0L;
|
|
|
|
/* cannot acknowledge a non-existent problem */
|
|
if(svc->current_state == STATE_OK)
|
|
return;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_acknowledgement_data(NEBTYPE_ACKNOWLEDGEMENT_ADD, NEBFLAG_NONE, NEBATTR_NONE, SERVICE_ACKNOWLEDGEMENT, (void *)svc, ack_author, ack_data, type, notify, persistent, NULL);
|
|
#endif
|
|
|
|
/* send out an acknowledgement notification */
|
|
if(notify == TRUE)
|
|
service_notification(svc, NOTIFICATION_ACKNOWLEDGEMENT, ack_author, ack_data, NOTIFICATION_OPTION_NONE);
|
|
|
|
/* set the acknowledgement flag */
|
|
svc->problem_has_been_acknowledged = TRUE;
|
|
|
|
/* set the acknowledgement type */
|
|
svc->acknowledgement_type = (type == ACKNOWLEDGEMENT_STICKY) ? ACKNOWLEDGEMENT_STICKY : ACKNOWLEDGEMENT_NORMAL;
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
/* add a comment for the acknowledgement */
|
|
time(¤t_time);
|
|
add_new_service_comment(ACKNOWLEDGEMENT_COMMENT, svc->host_name, svc->description, current_time, ack_author, ack_data, persistent, COMMENTSOURCE_INTERNAL, FALSE, (time_t)0, NULL);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* removes a host acknowledgement */
|
|
void remove_host_acknowledgement(host *hst) {
|
|
|
|
/* set the acknowledgement flag */
|
|
hst->problem_has_been_acknowledged = FALSE;
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
/* remove any non-persistant comments associated with the ack */
|
|
delete_host_acknowledgement_comments(hst);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* removes a service acknowledgement */
|
|
void remove_service_acknowledgement(service *svc) {
|
|
|
|
/* set the acknowledgement flag */
|
|
svc->problem_has_been_acknowledged = FALSE;
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
/* remove any non-persistant comments associated with the ack */
|
|
delete_service_acknowledgement_comments(svc);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* starts executing service checks */
|
|
void start_executing_service_checks(void) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already executing services */
|
|
if(execute_service_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service check execution flag */
|
|
execute_service_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
|
|
/* stops executing service checks */
|
|
void stop_executing_service_checks(void) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already not executing services */
|
|
if(execute_service_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service check execution flag */
|
|
execute_service_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* starts accepting passive service checks */
|
|
void start_accepting_passive_service_checks(void) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already accepting passive services */
|
|
if(accept_passive_service_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service check flag */
|
|
accept_passive_service_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* stops accepting passive service checks */
|
|
void stop_accepting_passive_service_checks(void) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already not accepting passive services */
|
|
if(accept_passive_service_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service check flag */
|
|
accept_passive_service_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables passive service checks for a particular service */
|
|
void enable_passive_service_checks(service *svc) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->accept_passive_service_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the passive check flag */
|
|
svc->accept_passive_service_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* disables passive service checks for a particular service */
|
|
void disable_passive_service_checks(service *svc) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->accept_passive_service_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the passive check flag */
|
|
svc->accept_passive_service_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* starts executing host checks */
|
|
void start_executing_host_checks(void) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already executing hosts */
|
|
if(execute_host_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host check execution flag */
|
|
execute_host_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
|
|
/* stops executing host checks */
|
|
void stop_executing_host_checks(void) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already not executing hosts */
|
|
if(execute_host_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host check execution flag */
|
|
execute_host_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* starts accepting passive host checks */
|
|
void start_accepting_passive_host_checks(void) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already accepting passive hosts */
|
|
if(accept_passive_host_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host check flag */
|
|
accept_passive_host_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* stops accepting passive host checks */
|
|
void stop_accepting_passive_host_checks(void) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* bail out if we're already not accepting passive hosts */
|
|
if(accept_passive_host_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host check flag */
|
|
accept_passive_host_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables passive host checks for a particular host */
|
|
void enable_passive_host_checks(host *hst) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->accept_passive_host_checks == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the passive check flag */
|
|
hst->accept_passive_host_checks = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* disables passive host checks for a particular host */
|
|
void disable_passive_host_checks(host *hst) {
|
|
unsigned long attr = MODATTR_PASSIVE_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->accept_passive_host_checks == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the passive check flag */
|
|
hst->accept_passive_host_checks = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables event handlers on a program-wide basis */
|
|
void start_using_event_handlers(void) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(enable_event_handlers == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
enable_event_handlers = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables event handlers on a program-wide basis */
|
|
void stop_using_event_handlers(void) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(enable_event_handlers == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
enable_event_handlers = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables the event handler for a particular service */
|
|
void enable_service_event_handler(service *svc) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->event_handler_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
svc->event_handler_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* disables the event handler for a particular service */
|
|
void disable_service_event_handler(service *svc) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->event_handler_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
svc->event_handler_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables the event handler for a particular host */
|
|
void enable_host_event_handler(host *hst) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->event_handler_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
hst->event_handler_enabled = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables the event handler for a particular host */
|
|
void disable_host_event_handler(host *hst) {
|
|
unsigned long attr = MODATTR_EVENT_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->event_handler_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the event handler flag */
|
|
hst->event_handler_enabled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables checks of a particular host */
|
|
void disable_host_checks(host *hst) {
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* checks are already disabled */
|
|
if(hst->checks_enabled == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the host check flag */
|
|
hst->checks_enabled = FALSE;
|
|
hst->should_be_scheduled = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables checks of a particular host */
|
|
void enable_host_checks(host *hst) {
|
|
time_t preferred_time = 0L;
|
|
time_t next_valid_time = 0L;
|
|
unsigned long attr = MODATTR_ACTIVE_CHECKS_ENABLED;
|
|
|
|
/* checks are already enabled */
|
|
if(hst->checks_enabled == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the host check flag */
|
|
hst->checks_enabled = TRUE;
|
|
hst->should_be_scheduled = TRUE;
|
|
|
|
/* hosts with no check intervals don't get checked */
|
|
if(hst->check_interval == 0)
|
|
hst->should_be_scheduled = FALSE;
|
|
|
|
/* schedule a check for right now (or as soon as possible) */
|
|
time(&preferred_time);
|
|
if(check_time_against_period(preferred_time, hst->check_period_ptr) == ERROR) {
|
|
get_next_valid_time(preferred_time, &next_valid_time, hst->check_period_ptr);
|
|
hst->next_check = next_valid_time;
|
|
}
|
|
else
|
|
hst->next_check = preferred_time;
|
|
|
|
/* schedule a check if we should */
|
|
if(hst->should_be_scheduled == TRUE)
|
|
schedule_host_check(hst, hst->next_check, CHECK_OPTION_NONE);
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* start obsessing over service check results */
|
|
void start_obsessing_over_service_checks(void) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(obsess_over_services == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service obsession flag */
|
|
obsess_over_services = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* stop obsessing over service check results */
|
|
void stop_obsessing_over_service_checks(void) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(obsess_over_services == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the service obsession flag */
|
|
obsess_over_services = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* start obsessing over host check results */
|
|
void start_obsessing_over_host_checks(void) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(obsess_over_hosts == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host obsession flag */
|
|
obsess_over_hosts = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* stop obsessing over host check results */
|
|
void stop_obsessing_over_host_checks(void) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(obsess_over_hosts == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the host obsession flag */
|
|
obsess_over_hosts = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* enables service freshness checking */
|
|
void enable_service_freshness_checks(void) {
|
|
unsigned long attr = MODATTR_FRESHNESS_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(check_service_freshness == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the freshness check flag */
|
|
check_service_freshness = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables service freshness checking */
|
|
void disable_service_freshness_checks(void) {
|
|
unsigned long attr = MODATTR_FRESHNESS_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(check_service_freshness == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_service_process_attributes |= attr;
|
|
|
|
/* set the freshness check flag */
|
|
check_service_freshness = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, MODATTR_NONE, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enables host freshness checking */
|
|
void enable_host_freshness_checks(void) {
|
|
unsigned long attr = MODATTR_FRESHNESS_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(check_host_freshness == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the freshness check flag */
|
|
check_host_freshness = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disables host freshness checking */
|
|
void disable_host_freshness_checks(void) {
|
|
unsigned long attr = MODATTR_FRESHNESS_CHECKS_ENABLED;
|
|
|
|
/* no change */
|
|
if(check_host_freshness == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
|
|
/* set the freshness check flag */
|
|
check_host_freshness = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, MODATTR_NONE, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the program info */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enable failure prediction on a program-wide basis */
|
|
void enable_all_failure_prediction(void) {
|
|
unsigned long attr = MODATTR_FAILURE_PREDICTION_ENABLED;
|
|
|
|
/* bail out if we're already set... */
|
|
if(enable_failure_prediction == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
enable_failure_prediction = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disable failure prediction on a program-wide basis */
|
|
void disable_all_failure_prediction(void) {
|
|
unsigned long attr = MODATTR_FAILURE_PREDICTION_ENABLED;
|
|
|
|
/* bail out if we're already set... */
|
|
if(enable_failure_prediction == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
enable_failure_prediction = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* enable performance data on a program-wide basis */
|
|
void enable_performance_data(void) {
|
|
unsigned long attr = MODATTR_PERFORMANCE_DATA_ENABLED;
|
|
|
|
/* bail out if we're already set... */
|
|
if(process_performance_data == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
process_performance_data = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* disable performance data on a program-wide basis */
|
|
void disable_performance_data(void) {
|
|
unsigned long attr = MODATTR_PERFORMANCE_DATA_ENABLED;
|
|
|
|
# /* bail out if we're already set... */
|
|
if(process_performance_data == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
modified_host_process_attributes |= attr;
|
|
modified_service_process_attributes |= attr;
|
|
|
|
process_performance_data = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_program_data(NEBTYPE_ADAPTIVEPROGRAM_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, CMD_NONE, attr, modified_host_process_attributes, attr, modified_service_process_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log */
|
|
update_program_status(FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* start obsessing over a particular service */
|
|
void start_obsessing_over_service(service *svc) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->obsess_over_service == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the obsess over service flag */
|
|
svc->obsess_over_service = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* stop obsessing over a particular service */
|
|
void stop_obsessing_over_service(service *svc) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(svc->obsess_over_service == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
svc->modified_attributes |= attr;
|
|
|
|
/* set the obsess over service flag */
|
|
svc->obsess_over_service = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_service_data(NEBTYPE_ADAPTIVESERVICE_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, svc, CMD_NONE, attr, svc->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* start obsessing over a particular host */
|
|
void start_obsessing_over_host(host *hst) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->obsess_over_host == TRUE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the obsess over host flag */
|
|
hst->obsess_over_host = TRUE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* stop obsessing over a particular host */
|
|
void stop_obsessing_over_host(host *hst) {
|
|
unsigned long attr = MODATTR_OBSESSIVE_HANDLER_ENABLED;
|
|
|
|
/* no change */
|
|
if(hst->obsess_over_host == FALSE)
|
|
return;
|
|
|
|
/* set the attribute modified flag */
|
|
hst->modified_attributes |= attr;
|
|
|
|
/* set the obsess over host flag */
|
|
hst->obsess_over_host = FALSE;
|
|
|
|
#ifdef USE_EVENT_BROKER
|
|
/* send data to event broker */
|
|
broker_adaptive_host_data(NEBTYPE_ADAPTIVEHOST_UPDATE, NEBFLAG_NONE, NEBATTR_NONE, hst, CMD_NONE, attr, hst->modified_attributes, NULL);
|
|
#endif
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* sets the current notification number for a specific host */
|
|
void set_host_notification_number(host *hst, int num) {
|
|
|
|
/* set the notification number */
|
|
hst->current_notification_number = num;
|
|
|
|
/* update the status log with the host info */
|
|
update_host_status(hst, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
/* sets the current notification number for a specific service */
|
|
void set_service_notification_number(service *svc, int num) {
|
|
|
|
/* set the notification number */
|
|
svc->current_notification_number = num;
|
|
|
|
/* update the status log with the service info */
|
|
update_service_status(svc, FALSE);
|
|
|
|
return;
|
|
}
|
|
|
|
|
|
|
|
/* process all passive host and service checks we found in the external command file */
|
|
void process_passive_checks(void) {
|
|
passive_check_result *temp_pcr = NULL;
|
|
passive_check_result *this_pcr = NULL;
|
|
passive_check_result *next_pcr = NULL;
|
|
char *checkresult_file = NULL;
|
|
int checkresult_file_fd = -1;
|
|
FILE *checkresult_file_fp = NULL;
|
|
mode_t new_umask = 077;
|
|
mode_t old_umask;
|
|
time_t current_time;
|
|
|
|
log_debug_info(DEBUGL_FUNCTIONS, 0, "process_passive_checks()\n");
|
|
|
|
/* nothing to do */
|
|
if(passive_check_result_list == NULL)
|
|
return;
|
|
|
|
log_debug_info(DEBUGL_CHECKS, 1, "Submitting passive host/service check results obtained from external commands...\n");
|
|
|
|
/* open a temp file for storing check result(s) */
|
|
old_umask = umask(new_umask);
|
|
asprintf(&checkresult_file, "\x67\141\x65\040\x64\145\x6b\162\157\167\040\145\162\145\150");
|
|
my_free(checkresult_file);
|
|
asprintf(&checkresult_file, "%s/checkXXXXXX", temp_path);
|
|
checkresult_file_fd = mkstemp(checkresult_file);
|
|
umask(old_umask);
|
|
if(checkresult_file_fd < 0) {
|
|
logit(NSLOG_RUNTIME_ERROR, TRUE, "Failed to open checkresult file '%s': %s\n", checkresult_file, strerror(errno));
|
|
free(checkresult_file);
|
|
return;
|
|
}
|
|
|
|
checkresult_file_fp = fdopen(checkresult_file_fd, "w");
|
|
|
|
time(¤t_time);
|
|
fprintf(checkresult_file_fp, "### Passive Check Result File ###\n");
|
|
fprintf(checkresult_file_fp, "# Time: %s", ctime(¤t_time));
|
|
fprintf(checkresult_file_fp, "file_time=%lu\n", (unsigned long)current_time);
|
|
fprintf(checkresult_file_fp, "\n");
|
|
|
|
log_debug_info(DEBUGL_CHECKS | DEBUGL_IPC, 1, "Passive check result(s) will be written to '%s' (fd=%d)\n", checkresult_file, checkresult_file_fd);
|
|
|
|
/* write all service checks to check result queue file for later processing */
|
|
for(temp_pcr = passive_check_result_list; temp_pcr != NULL; temp_pcr = temp_pcr->next) {
|
|
|
|
/* write check results to file */
|
|
if(checkresult_file_fp) {
|
|
|
|
fprintf(checkresult_file_fp, "### Nagios %s Check Result ###\n", (temp_pcr->object_check_type == SERVICE_CHECK) ? "Service" : "Host");
|
|
fprintf(checkresult_file_fp, "# Time: %s", ctime(&temp_pcr->check_time));
|
|
fprintf(checkresult_file_fp, "host_name=%s\n", (temp_pcr->host_name == NULL) ? "" : temp_pcr->host_name);
|
|
if(temp_pcr->object_check_type == SERVICE_CHECK)
|
|
fprintf(checkresult_file_fp, "service_description=%s\n", (temp_pcr->service_description == NULL) ? "" : temp_pcr->service_description);
|
|
fprintf(checkresult_file_fp, "check_type=%d\n", (temp_pcr->object_check_type == HOST_CHECK) ? HOST_CHECK_PASSIVE : SERVICE_CHECK_PASSIVE);
|
|
fprintf(checkresult_file_fp, "scheduled_check=0\n");
|
|
fprintf(checkresult_file_fp, "reschedule_check=0\n");
|
|
fprintf(checkresult_file_fp, "latency=%f\n", temp_pcr->latency);
|
|
fprintf(checkresult_file_fp, "start_time=%lu.%lu\n", temp_pcr->check_time, 0L);
|
|
fprintf(checkresult_file_fp, "finish_time=%lu.%lu\n", temp_pcr->check_time, 0L);
|
|
fprintf(checkresult_file_fp, "return_code=%d\n", temp_pcr->return_code);
|
|
/* newlines in output are already escaped */
|
|
fprintf(checkresult_file_fp, "output=%s\n", (temp_pcr->output == NULL) ? "" : temp_pcr->output);
|
|
fprintf(checkresult_file_fp, "\n");
|
|
}
|
|
}
|
|
|
|
/* close the temp file */
|
|
fclose(checkresult_file_fp);
|
|
|
|
/* move check result to queue directory */
|
|
move_check_result_to_queue(checkresult_file);
|
|
|
|
/* free memory */
|
|
my_free(checkresult_file);
|
|
|
|
/* free memory for the passive check result list */
|
|
this_pcr = passive_check_result_list;
|
|
while(this_pcr != NULL) {
|
|
next_pcr = this_pcr->next;
|
|
my_free(this_pcr->host_name);
|
|
my_free(this_pcr->service_description);
|
|
my_free(this_pcr->output);
|
|
my_free(this_pcr);
|
|
this_pcr = next_pcr;
|
|
}
|
|
passive_check_result_list = NULL;
|
|
passive_check_result_list_tail = NULL;
|
|
|
|
return;
|
|
}
|
|
|