nagios4/base/commands.c

5442 lines
160 KiB
C

/*****************************************************************************
*
* COMMANDS.C - External command functions for Nagios
*
*
* 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"
#include "../include/workers.h"
extern int sigrestart;
static int command_file_fd;
static FILE *command_file_fp;
static int command_file_created = FALSE;
/* The command file worker process */
static struct {
/* these must come first for check source detection */
const char *type;
const char *source_name;
int pid;
int sd;
iocache *ioc;
} command_worker = { "command file", "command file worker", 0, 0, NULL };
/******************************************************************/
/************* EXTERNAL COMMAND WORKER CONTROLLERS ****************/
/******************************************************************/
/* creates external command file as a named pipe (FIFO) and opens it for reading (non-blocked mode) */
int open_command_file(void)
{
struct stat st;
int result = 0;
/* if the command file was created or
we're not checking external commands, don't do anything */
if (command_file_created == TRUE || check_external_commands == FALSE) {
return OK;
}
/* reset umask (group needs write permissions) */
umask(S_IWOTH);
/* use existing FIFO if possible */
result = stat(command_file, &st);
if(!(result != -1 && (st.st_mode & S_IFIFO))) {
/* create the external command file as a named pipe (FIFO) */
result = mkfifo(command_file, S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP);
if (result != 0) {
logit(NSLOG_RUNTIME_ERROR, TRUE,
"Error: Could not create external command file '%s' as named pipe: (%d) -> %s. "
"If this file already exists and you are sure that another copy of Nagios is not running, you should delete this file.\n",
command_file, errno, strerror(errno));
return ERROR;
}
}
/* open the command file for reading (non-blocked) - O_TRUNC flag cannot be used due to errors on some systems */
/* NOTE: file must be opened read-write for poll() to work */
command_file_fd = open(command_file, O_RDWR | O_NONBLOCK);
if (command_file_fd < 0) {
logit(NSLOG_RUNTIME_ERROR, TRUE,
"Error: Could not open external command file for reading via open(): (%d) -> %s\n", errno, strerror(errno));
return ERROR;
}
/* set a flag to remember we already created the file */
command_file_created = TRUE;
return OK;
}
/* closes the external command file FIFO and deletes it */
int close_command_file(void)
{
/* if the command file wasn't created or was already cleaned up
or we're not checking external commands, don't do anything */
if (command_file_created == FALSE || check_external_commands == FALSE) {
return OK;
}
/* reset our flag */
command_file_created = FALSE;
/* close the command file */
fclose(command_file_fp);
/* unlink the pipe */
unlink(command_file);
return OK;
}
/* shutdown command file worker thread */
int shutdown_command_file_worker(void) {
if (!command_worker.pid)
return 0;
iocache_destroy(command_worker.ioc);
command_worker.ioc = NULL;
iobroker_close(nagios_iobs, command_worker.sd);
command_worker.sd = -1;
kill(command_worker.pid, SIGKILL);
command_worker.pid = 0;
return 0;
}
static int command_input_handler(int sd, int events, void *discard) {
int ret, cmd_ret;
char *buf;
unsigned long size;
if (sigrestart)
return 0;
ret = iocache_read(command_worker.ioc, sd);
log_debug_info(DEBUGL_COMMANDS, 2, "Read %d bytes from command worker\n", ret);
if (ret == 0) {
logit(NSLOG_RUNTIME_WARNING, TRUE, "Command file worker seems to have died. Respawning\n");
shutdown_command_file_worker();
launch_command_file_worker();
return 0;
}
while ((buf = iocache_use_delim(command_worker.ioc, "\n", 1, &size))) {
if (buf[0] == '[') {
/* raw external command */
buf[size] = 0;
log_debug_info(DEBUGL_COMMANDS, 1, "Read raw external command '%s'\n", buf);
}
if ((cmd_ret = process_external_command1(buf)) != CMD_ERROR_OK) {
logit(NSLOG_EXTERNAL_COMMAND | NSLOG_RUNTIME_WARNING, TRUE, "External command %s returned error %s\n", buf, cmd_error_strerror(cmd_ret));
}
}
return 0;
}
/* main controller of command file helper process */
static int command_file_worker(int sd) {
iocache *ioc;
if (open_command_file() == ERROR)
return (EXIT_FAILURE);
ioc = iocache_create(65536);
if (!ioc)
exit(EXIT_FAILURE);
while(1) {
struct pollfd pfd;
int pollval, ret;
char *buf;
unsigned long size;
/* if our master has gone away, we need to die */
if (kill(nagios_pid, 0) < 0 && errno == ESRCH) {
return EXIT_SUCCESS;
}
errno = 0;
/* wait for data to arrive */
/* select seems to not work, so we have to use poll instead */
/* 10-15-08 EG check into implementing William's patch @ http://blog.netways.de/2008/08/15/nagios-unter-mac-os-x-installieren/ */
/* 10-15-08 EG poll() seems broken on OSX - see Jonathan's patch a few lines down */
pfd.fd = command_file_fd;
pfd.events = POLLIN;
pollval = poll(&pfd, 1, 500);
/* loop if no data */
if(pollval == 0)
continue;
/* check for errors */
if(pollval == -1) {
/* @todo printf("Failed to poll() command file pipe: %m\n"); */
if (errno == EINTR)
continue;
return EXIT_FAILURE;
}
errno = 0;
ret = iocache_read(ioc, command_file_fd);
if (ret < 1) {
if (errno == EINTR)
continue;
return EXIT_FAILURE;
}
size = iocache_available(ioc);
buf = iocache_use_size(ioc, size);
ret = write(sd, buf, size);
/*
* @todo Add libio to get io_write_all(), which handles
* EINTR and EAGAIN properly instead of just exiting.
*/
if (ret < 0 && errno != EINTR)
return EXIT_FAILURE;
} /* while(1) */
}
int launch_command_file_worker(void) {
int ret, sv[2];
char *str;
#ifdef HAVE_SIGACTION
struct sigaction sig_action;
#endif
/*
* if we're restarting, we may well already have a command
* file worker process attached. Keep it if that's so.
*/
if (command_worker.pid && kill(command_worker.pid, 0) == 0 &&
iobroker_is_registered(nagios_iobs, command_worker.sd))
{
return 0;
}
if (socketpair(AF_UNIX, SOCK_STREAM, 0, sv) < 0) {
logit(NSLOG_RUNTIME_ERROR, TRUE, "Failed to create socketpair for command file worker: %m\n");
return ERROR;
}
command_worker.pid = fork();
if (command_worker.pid < 0) {
logit(NSLOG_RUNTIME_ERROR, TRUE, "Failed to fork() command file worker: %m\n");
goto err_close;
}
if (command_worker.pid) {
command_worker.ioc = iocache_create(512 * 1024);
if (!command_worker.ioc) {
logit(NSLOG_RUNTIME_ERROR, TRUE, "Failed to create I/O cache for command file worker: %m\n");
goto err_close;
}
command_worker.sd = sv[0];
ret = iobroker_register(nagios_iobs, command_worker.sd, NULL, command_input_handler);
if (ret < 0) {
logit(NSLOG_RUNTIME_ERROR, TRUE, "Failed to register command file worker socket %d with io broker %p: %s; errno=%d: %s\n",
command_worker.sd, nagios_iobs, iobroker_strerror(ret), errno, strerror(errno));
iocache_destroy(command_worker.ioc);
goto err_close;
}
logit(NSLOG_INFO_MESSAGE, TRUE, "Successfully launched command file worker with pid %d\n",
command_worker.pid);
return OK;
}
/* child goes here */
close(sv[0]);
/* make our own process-group so we can be traced into and stuff */
setpgid(0, 0);
/* we must preserve command_file before nuking memory */
(void)chdir("/tmp");
(void)chdir("nagios-cfw");
str = strdup(command_file);
free_memory(get_global_macros());
command_file = str;
#ifdef HAVE_SIGACTION
sig_action.sa_sigaction = NULL;
sig_action.sa_handler = SIG_IGN;
sigemptyset(&sig_action.sa_mask);
sig_action.sa_flags = 0;
sigaction(SIGPIPE, &sig_action, NULL);
#else
signal(SIGPIPE, SIG_IGN);
#endif
exit(command_file_worker(sv[1]));
/* error conditions for parent */
err_close:
close(sv[0]);
close(sv[1]);
command_worker.pid = 0;
command_worker.sd = -1;
return ERROR;
}
/******************************************************************/
/****************** EXTERNAL COMMAND PROCESSING *******************/
/******************************************************************/
/*** stupid helpers ****/
static host *find_host_by_name_or_address(const char *name)
{
host *h;
if ((h = find_host(name)) || !name)
return h;
for (h = host_list; h; h = h->next)
if (!strcmp(h->address, name))
return h;
return NULL;
}
/* 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;
int external_command_ret = OK;
log_debug_info(DEBUGL_FUNCTIONS, 0, "process_external_command1()\n");
if(cmd == NULL)
return CMD_ERROR_MALFORMED_COMMAND;
/* 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_with_free(cmd, "[", FALSE)) == NULL)
return CMD_ERROR_MALFORMED_COMMAND;
if((temp_ptr = my_strtok_with_free(NULL, "]", FALSE)) == NULL) {
temp_ptr = my_strtok_with_free(NULL, NULL, TRUE);
return CMD_ERROR_MALFORMED_COMMAND;
}
entry_time = (time_t)strtoul(temp_ptr, NULL, 10);
/* get the command identifier */
if((temp_ptr = my_strtok_with_free(NULL, ";", FALSE)) == NULL) {
temp_ptr = my_strtok_with_free(NULL, NULL, TRUE);
return CMD_ERROR_MALFORMED_COMMAND;
}
else if((command_id = (char *)strdup(temp_ptr + 1)) == NULL) {
temp_ptr = my_strtok_with_free(NULL, NULL, TRUE);
return CMD_ERROR_INTERNAL_ERROR;
}
/* get the command arguments */
if((temp_ptr = my_strtok_with_free(NULL, "\n", FALSE)) == NULL)
args = (char *)strdup("");
else
args = (char *)strdup(temp_ptr);
temp_ptr = my_strtok_with_free(NULL, NULL, TRUE);
if(args == NULL) {
my_free(command_id);
return CMD_ERROR_INTERNAL_ERROR;
}
/* decide what type of command this is... */
/**************************/
/**** PROCESS COMMANDS ****/
/**************************/
if(!strcasecmp(command_id, "ENTER_STANDBY_MODE") || !strcasecmp(command_id, "DISABLE_NOTIFICATIONS"))
command_type = CMD_DISABLE_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENTER_ACTIVE_MODE") || !strcasecmp(command_id, "ENABLE_NOTIFICATIONS"))
command_type = CMD_ENABLE_NOTIFICATIONS;
else if(!strcasecmp(command_id, "SHUTDOWN_PROGRAM") || !strcasecmp(command_id, "SHUTDOWN_PROCESS"))
command_type = CMD_SHUTDOWN_PROCESS;
else if(!strcasecmp(command_id, "RESTART_PROGRAM") || !strcasecmp(command_id, "RESTART_PROCESS"))
command_type = CMD_RESTART_PROCESS;
else if(!strcasecmp(command_id, "SAVE_STATE_INFORMATION"))
command_type = CMD_SAVE_STATE_INFORMATION;
else if(!strcasecmp(command_id, "READ_STATE_INFORMATION"))
command_type = CMD_READ_STATE_INFORMATION;
else if(!strcasecmp(command_id, "ENABLE_EVENT_HANDLERS"))
command_type = CMD_ENABLE_EVENT_HANDLERS;
else if(!strcasecmp(command_id, "DISABLE_EVENT_HANDLERS"))
command_type = CMD_DISABLE_EVENT_HANDLERS;
else if(!strcasecmp(command_id, "ENABLE_PERFORMANCE_DATA"))
command_type = CMD_ENABLE_PERFORMANCE_DATA;
else if(!strcasecmp(command_id, "DISABLE_PERFORMANCE_DATA"))
command_type = CMD_DISABLE_PERFORMANCE_DATA;
else if(!strcasecmp(command_id, "START_EXECUTING_HOST_CHECKS"))
command_type = CMD_START_EXECUTING_HOST_CHECKS;
else if(!strcasecmp(command_id, "STOP_EXECUTING_HOST_CHECKS"))
command_type = CMD_STOP_EXECUTING_HOST_CHECKS;
else if(!strcasecmp(command_id, "START_EXECUTING_SVC_CHECKS"))
command_type = CMD_START_EXECUTING_SVC_CHECKS;
else if(!strcasecmp(command_id, "STOP_EXECUTING_SVC_CHECKS"))
command_type = CMD_STOP_EXECUTING_SVC_CHECKS;
else if(!strcasecmp(command_id, "START_ACCEPTING_PASSIVE_HOST_CHECKS"))
command_type = CMD_START_ACCEPTING_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "STOP_ACCEPTING_PASSIVE_HOST_CHECKS"))
command_type = CMD_STOP_ACCEPTING_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "START_ACCEPTING_PASSIVE_SVC_CHECKS"))
command_type = CMD_START_ACCEPTING_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "STOP_ACCEPTING_PASSIVE_SVC_CHECKS"))
command_type = CMD_STOP_ACCEPTING_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "START_OBSESSING_OVER_HOST_CHECKS"))
command_type = CMD_START_OBSESSING_OVER_HOST_CHECKS;
else if(!strcasecmp(command_id, "STOP_OBSESSING_OVER_HOST_CHECKS"))
command_type = CMD_STOP_OBSESSING_OVER_HOST_CHECKS;
else if(!strcasecmp(command_id, "START_OBSESSING_OVER_SVC_CHECKS"))
command_type = CMD_START_OBSESSING_OVER_SVC_CHECKS;
else if(!strcasecmp(command_id, "STOP_OBSESSING_OVER_SVC_CHECKS"))
command_type = CMD_STOP_OBSESSING_OVER_SVC_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_FLAP_DETECTION"))
command_type = CMD_ENABLE_FLAP_DETECTION;
else if(!strcasecmp(command_id, "DISABLE_FLAP_DETECTION"))
command_type = CMD_DISABLE_FLAP_DETECTION;
else if(!strcasecmp(command_id, "CHANGE_GLOBAL_HOST_EVENT_HANDLER"))
command_type = CMD_CHANGE_GLOBAL_HOST_EVENT_HANDLER;
else if(!strcasecmp(command_id, "CHANGE_GLOBAL_SVC_EVENT_HANDLER"))
command_type = CMD_CHANGE_GLOBAL_SVC_EVENT_HANDLER;
else if(!strcasecmp(command_id, "ENABLE_SERVICE_FRESHNESS_CHECKS"))
command_type = CMD_ENABLE_SERVICE_FRESHNESS_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_SERVICE_FRESHNESS_CHECKS"))
command_type = CMD_DISABLE_SERVICE_FRESHNESS_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_HOST_FRESHNESS_CHECKS"))
command_type = CMD_ENABLE_HOST_FRESHNESS_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOST_FRESHNESS_CHECKS"))
command_type = CMD_DISABLE_HOST_FRESHNESS_CHECKS;
/*******************************/
/**** HOST-RELATED COMMANDS ****/
/*******************************/
else if(!strcasecmp(command_id, "ADD_HOST_COMMENT"))
command_type = CMD_ADD_HOST_COMMENT;
else if(!strcasecmp(command_id, "DEL_HOST_COMMENT"))
command_type = CMD_DEL_HOST_COMMENT;
else if(!strcasecmp(command_id, "DEL_ALL_HOST_COMMENTS"))
command_type = CMD_DEL_ALL_HOST_COMMENTS;
else if(!strcasecmp(command_id, "DELAY_HOST_NOTIFICATION"))
command_type = CMD_DELAY_HOST_NOTIFICATION;
else if(!strcasecmp(command_id, "ENABLE_HOST_NOTIFICATIONS"))
command_type = CMD_ENABLE_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_HOST_NOTIFICATIONS"))
command_type = CMD_DISABLE_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST"))
command_type = CMD_ENABLE_ALL_NOTIFICATIONS_BEYOND_HOST;
else if(!strcasecmp(command_id, "DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST"))
command_type = CMD_DISABLE_ALL_NOTIFICATIONS_BEYOND_HOST;
else if(!strcasecmp(command_id, "ENABLE_HOST_AND_CHILD_NOTIFICATIONS"))
command_type = CMD_ENABLE_HOST_AND_CHILD_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_HOST_AND_CHILD_NOTIFICATIONS"))
command_type = CMD_DISABLE_HOST_AND_CHILD_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_HOST_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_HOST_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_HOST_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_HOST_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_HOST_SVC_CHECKS"))
command_type = CMD_ENABLE_HOST_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOST_SVC_CHECKS"))
command_type = CMD_DISABLE_HOST_SVC_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_PASSIVE_HOST_CHECKS"))
command_type = CMD_ENABLE_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_PASSIVE_HOST_CHECKS"))
command_type = CMD_DISABLE_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "SCHEDULE_HOST_SVC_CHECKS"))
command_type = CMD_SCHEDULE_HOST_SVC_CHECKS;
else if(!strcasecmp(command_id, "SCHEDULE_FORCED_HOST_SVC_CHECKS"))
command_type = CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS;
else if(!strcasecmp(command_id, "ACKNOWLEDGE_HOST_PROBLEM"))
command_type = CMD_ACKNOWLEDGE_HOST_PROBLEM;
else if(!strcasecmp(command_id, "REMOVE_HOST_ACKNOWLEDGEMENT"))
command_type = CMD_REMOVE_HOST_ACKNOWLEDGEMENT;
else if(!strcasecmp(command_id, "ENABLE_HOST_EVENT_HANDLER"))
command_type = CMD_ENABLE_HOST_EVENT_HANDLER;
else if(!strcasecmp(command_id, "DISABLE_HOST_EVENT_HANDLER"))
command_type = CMD_DISABLE_HOST_EVENT_HANDLER;
else if(!strcasecmp(command_id, "ENABLE_HOST_CHECK"))
command_type = CMD_ENABLE_HOST_CHECK;
else if(!strcasecmp(command_id, "DISABLE_HOST_CHECK"))
command_type = CMD_DISABLE_HOST_CHECK;
else if(!strcasecmp(command_id, "SCHEDULE_HOST_CHECK"))
command_type = CMD_SCHEDULE_HOST_CHECK;
else if(!strcasecmp(command_id, "SCHEDULE_FORCED_HOST_CHECK"))
command_type = CMD_SCHEDULE_FORCED_HOST_CHECK;
else if(!strcasecmp(command_id, "SCHEDULE_HOST_DOWNTIME"))
command_type = CMD_SCHEDULE_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "SCHEDULE_HOST_SVC_DOWNTIME"))
command_type = CMD_SCHEDULE_HOST_SVC_DOWNTIME;
else if(!strcasecmp(command_id, "DEL_HOST_DOWNTIME"))
command_type = CMD_DEL_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "DEL_DOWNTIME_BY_HOST_NAME"))
command_type = CMD_DEL_DOWNTIME_BY_HOST_NAME;
else if(!strcasecmp(command_id, "DEL_DOWNTIME_BY_HOSTGROUP_NAME"))
command_type = CMD_DEL_DOWNTIME_BY_HOSTGROUP_NAME;
else if(!strcasecmp(command_id, "DEL_DOWNTIME_BY_START_TIME_COMMENT"))
command_type = CMD_DEL_DOWNTIME_BY_START_TIME_COMMENT;
else if(!strcasecmp(command_id, "ENABLE_HOST_FLAP_DETECTION"))
command_type = CMD_ENABLE_HOST_FLAP_DETECTION;
else if(!strcasecmp(command_id, "DISABLE_HOST_FLAP_DETECTION"))
command_type = CMD_DISABLE_HOST_FLAP_DETECTION;
else if(!strcasecmp(command_id, "START_OBSESSING_OVER_HOST"))
command_type = CMD_START_OBSESSING_OVER_HOST;
else if(!strcasecmp(command_id, "STOP_OBSESSING_OVER_HOST"))
command_type = CMD_STOP_OBSESSING_OVER_HOST;
else if(!strcasecmp(command_id, "CHANGE_HOST_EVENT_HANDLER"))
command_type = CMD_CHANGE_HOST_EVENT_HANDLER;
else if(!strcasecmp(command_id, "CHANGE_HOST_CHECK_COMMAND"))
command_type = CMD_CHANGE_HOST_CHECK_COMMAND;
else if(!strcasecmp(command_id, "CHANGE_NORMAL_HOST_CHECK_INTERVAL"))
command_type = CMD_CHANGE_NORMAL_HOST_CHECK_INTERVAL;
else if(!strcasecmp(command_id, "CHANGE_RETRY_HOST_CHECK_INTERVAL"))
command_type = CMD_CHANGE_RETRY_HOST_CHECK_INTERVAL;
else if(!strcasecmp(command_id, "CHANGE_MAX_HOST_CHECK_ATTEMPTS"))
command_type = CMD_CHANGE_MAX_HOST_CHECK_ATTEMPTS;
else if(!strcasecmp(command_id, "SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME"))
command_type = CMD_SCHEDULE_AND_PROPAGATE_TRIGGERED_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME"))
command_type = CMD_SCHEDULE_AND_PROPAGATE_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "SET_HOST_NOTIFICATION_NUMBER"))
command_type = CMD_SET_HOST_NOTIFICATION_NUMBER;
else if(!strcasecmp(command_id, "CHANGE_HOST_CHECK_TIMEPERIOD"))
command_type = CMD_CHANGE_HOST_CHECK_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_CUSTOM_HOST_VAR"))
command_type = CMD_CHANGE_CUSTOM_HOST_VAR;
else if(!strcasecmp(command_id, "SEND_CUSTOM_HOST_NOTIFICATION"))
command_type = CMD_SEND_CUSTOM_HOST_NOTIFICATION;
else if(!strcasecmp(command_id, "CHANGE_HOST_NOTIFICATION_TIMEPERIOD"))
command_type = CMD_CHANGE_HOST_NOTIFICATION_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_HOST_MODATTR"))
command_type = CMD_CHANGE_HOST_MODATTR;
else if (!strcasecmp(command_id,"CLEAR_HOST_FLAPPING_STATE"))
command_type = CMD_CLEAR_HOST_FLAPPING_STATE;
/************************************/
/**** HOSTGROUP-RELATED COMMANDS ****/
/************************************/
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_ENABLE_HOSTGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_HOSTGROUP_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_HOST_CHECKS"))
command_type = CMD_ENABLE_HOSTGROUP_HOST_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_HOST_CHECKS"))
command_type = CMD_DISABLE_HOSTGROUP_HOST_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS"))
command_type = CMD_ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS"))
command_type = CMD_DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_SVC_CHECKS"))
command_type = CMD_ENABLE_HOSTGROUP_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_SVC_CHECKS"))
command_type = CMD_DISABLE_HOSTGROUP_SVC_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS"))
command_type = CMD_ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS"))
command_type = CMD_DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "SCHEDULE_HOSTGROUP_HOST_DOWNTIME"))
command_type = CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "SCHEDULE_HOSTGROUP_SVC_DOWNTIME"))
command_type = CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME;
/**********************************/
/**** SERVICE-RELATED COMMANDS ****/
/**********************************/
else if(!strcasecmp(command_id, "ADD_SVC_COMMENT"))
command_type = CMD_ADD_SVC_COMMENT;
else if(!strcasecmp(command_id, "DEL_SVC_COMMENT"))
command_type = CMD_DEL_SVC_COMMENT;
else if(!strcasecmp(command_id, "DEL_ALL_SVC_COMMENTS"))
command_type = CMD_DEL_ALL_SVC_COMMENTS;
else if(!strcasecmp(command_id, "SCHEDULE_SVC_CHECK"))
command_type = CMD_SCHEDULE_SVC_CHECK;
else if(!strcasecmp(command_id, "SCHEDULE_FORCED_SVC_CHECK"))
command_type = CMD_SCHEDULE_FORCED_SVC_CHECK;
else if(!strcasecmp(command_id, "ENABLE_SVC_CHECK"))
command_type = CMD_ENABLE_SVC_CHECK;
else if(!strcasecmp(command_id, "DISABLE_SVC_CHECK"))
command_type = CMD_DISABLE_SVC_CHECK;
else if(!strcasecmp(command_id, "ENABLE_PASSIVE_SVC_CHECKS"))
command_type = CMD_ENABLE_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_PASSIVE_SVC_CHECKS"))
command_type = CMD_DISABLE_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "DELAY_SVC_NOTIFICATION"))
command_type = CMD_DELAY_SVC_NOTIFICATION;
else if(!strcasecmp(command_id, "ENABLE_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "PROCESS_SERVICE_CHECK_RESULT"))
command_type = CMD_PROCESS_SERVICE_CHECK_RESULT;
else if(!strcasecmp(command_id, "PROCESS_HOST_CHECK_RESULT"))
command_type = CMD_PROCESS_HOST_CHECK_RESULT;
else if(!strcasecmp(command_id, "ENABLE_SVC_EVENT_HANDLER"))
command_type = CMD_ENABLE_SVC_EVENT_HANDLER;
else if(!strcasecmp(command_id, "DISABLE_SVC_EVENT_HANDLER"))
command_type = CMD_DISABLE_SVC_EVENT_HANDLER;
else if(!strcasecmp(command_id, "ENABLE_SVC_FLAP_DETECTION"))
command_type = CMD_ENABLE_SVC_FLAP_DETECTION;
else if(!strcasecmp(command_id, "DISABLE_SVC_FLAP_DETECTION"))
command_type = CMD_DISABLE_SVC_FLAP_DETECTION;
else if(!strcasecmp(command_id, "SCHEDULE_SVC_DOWNTIME"))
command_type = CMD_SCHEDULE_SVC_DOWNTIME;
else if(!strcasecmp(command_id, "DEL_SVC_DOWNTIME"))
command_type = CMD_DEL_SVC_DOWNTIME;
else if(!strcasecmp(command_id, "ACKNOWLEDGE_SVC_PROBLEM"))
command_type = CMD_ACKNOWLEDGE_SVC_PROBLEM;
else if(!strcasecmp(command_id, "REMOVE_SVC_ACKNOWLEDGEMENT"))
command_type = CMD_REMOVE_SVC_ACKNOWLEDGEMENT;
else if(!strcasecmp(command_id, "START_OBSESSING_OVER_SVC"))
command_type = CMD_START_OBSESSING_OVER_SVC;
else if(!strcasecmp(command_id, "STOP_OBSESSING_OVER_SVC"))
command_type = CMD_STOP_OBSESSING_OVER_SVC;
else if(!strcasecmp(command_id, "CHANGE_SVC_EVENT_HANDLER"))
command_type = CMD_CHANGE_SVC_EVENT_HANDLER;
else if(!strcasecmp(command_id, "CHANGE_SVC_CHECK_COMMAND"))
command_type = CMD_CHANGE_SVC_CHECK_COMMAND;
else if(!strcasecmp(command_id, "CHANGE_NORMAL_SVC_CHECK_INTERVAL"))
command_type = CMD_CHANGE_NORMAL_SVC_CHECK_INTERVAL;
else if(!strcasecmp(command_id, "CHANGE_RETRY_SVC_CHECK_INTERVAL"))
command_type = CMD_CHANGE_RETRY_SVC_CHECK_INTERVAL;
else if(!strcasecmp(command_id, "CHANGE_MAX_SVC_CHECK_ATTEMPTS"))
command_type = CMD_CHANGE_MAX_SVC_CHECK_ATTEMPTS;
else if(!strcasecmp(command_id, "SET_SVC_NOTIFICATION_NUMBER"))
command_type = CMD_SET_SVC_NOTIFICATION_NUMBER;
else if(!strcasecmp(command_id, "CHANGE_SVC_CHECK_TIMEPERIOD"))
command_type = CMD_CHANGE_SVC_CHECK_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_CUSTOM_SVC_VAR"))
command_type = CMD_CHANGE_CUSTOM_SVC_VAR;
else if(!strcasecmp(command_id, "CHANGE_CUSTOM_CONTACT_VAR"))
command_type = CMD_CHANGE_CUSTOM_CONTACT_VAR;
else if(!strcasecmp(command_id, "SEND_CUSTOM_SVC_NOTIFICATION"))
command_type = CMD_SEND_CUSTOM_SVC_NOTIFICATION;
else if(!strcasecmp(command_id, "CHANGE_SVC_NOTIFICATION_TIMEPERIOD"))
command_type = CMD_CHANGE_SVC_NOTIFICATION_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_SVC_MODATTR"))
command_type = CMD_CHANGE_SVC_MODATTR;
else if (!strcasecmp(command_id,"CLEAR_SVC_FLAPPING_STATE"))
command_type = CMD_CLEAR_SVC_FLAPPING_STATE;
/***************************************/
/**** SERVICEGROUP-RELATED COMMANDS ****/
/***************************************/
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_HOST_CHECKS"))
command_type = CMD_ENABLE_SERVICEGROUP_HOST_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_HOST_CHECKS"))
command_type = CMD_DISABLE_SERVICEGROUP_HOST_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS"))
command_type = CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS"))
command_type = CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_SVC_CHECKS"))
command_type = CMD_ENABLE_SERVICEGROUP_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_SVC_CHECKS"))
command_type = CMD_DISABLE_SERVICEGROUP_SVC_CHECKS;
else if(!strcasecmp(command_id, "ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS"))
command_type = CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS"))
command_type = CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS;
else if(!strcasecmp(command_id, "SCHEDULE_SERVICEGROUP_HOST_DOWNTIME"))
command_type = CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME;
else if(!strcasecmp(command_id, "SCHEDULE_SERVICEGROUP_SVC_DOWNTIME"))
command_type = CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME;
/**********************************/
/**** CONTACT-RELATED COMMANDS ****/
/**********************************/
else if(!strcasecmp(command_id, "ENABLE_CONTACT_HOST_NOTIFICATIONS"))
command_type = CMD_ENABLE_CONTACT_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_CONTACT_HOST_NOTIFICATIONS"))
command_type = CMD_DISABLE_CONTACT_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_CONTACT_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_CONTACT_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_CONTACT_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_CONTACT_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD"))
command_type = CMD_CHANGE_CONTACT_HOST_NOTIFICATION_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD"))
command_type = CMD_CHANGE_CONTACT_SVC_NOTIFICATION_TIMEPERIOD;
else if(!strcasecmp(command_id, "CHANGE_CONTACT_MODATTR"))
command_type = CMD_CHANGE_CONTACT_MODATTR;
else if(!strcasecmp(command_id, "CHANGE_CONTACT_MODHATTR"))
command_type = CMD_CHANGE_CONTACT_MODHATTR;
else if(!strcasecmp(command_id, "CHANGE_CONTACT_MODSATTR"))
command_type = CMD_CHANGE_CONTACT_MODSATTR;
/***************************************/
/**** CONTACTGROUP-RELATED COMMANDS ****/
/***************************************/
else if(!strcasecmp(command_id, "ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_ENABLE_CONTACTGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS"))
command_type = CMD_DISABLE_CONTACTGROUP_HOST_NOTIFICATIONS;
else if(!strcasecmp(command_id, "ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_ENABLE_CONTACTGROUP_SVC_NOTIFICATIONS;
else if(!strcasecmp(command_id, "DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS"))
command_type = CMD_DISABLE_CONTACTGROUP_SVC_NOTIFICATIONS;
/**************************/
/****** MISC COMMANDS *****/
/**************************/
else if(!strcasecmp(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 CMD_ERROR_UNKNOWN_COMMAND;
}
/* 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 */
external_command_ret = (process_external_command2(command_type, entry_time, args) == OK) ? CMD_ERROR_OK : CMD_ERROR_FAILURE;
if (external_command_ret != CMD_ERROR_OK) {
logit(NSLOG_EXTERNAL_COMMAND | NSLOG_RUNTIME_WARNING, TRUE, "Error: External command failed -> %s;%s\n", command_id, 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 external_command_ret;
}
const char *cmd_error_strerror(int code) {
switch(code) {
case CMD_ERROR_OK:
return "No error";
case CMD_ERROR_FAILURE:
return "Command failed";
case CMD_ERROR_INTERNAL_ERROR:
return "Internal error";
case CMD_ERROR_UNKNOWN_COMMAND:
return "Unknown or unsupported command";
case CMD_ERROR_MALFORMED_COMMAND:
return "Malformed command";
}
return "Unknown error";
}
/* top-level processor for a single external command */
int process_external_command2(int cmd, time_t entry_time, char *args) {
int ret = OK;
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:
ret = cmd_signal_process(cmd, args);
break;
case CMD_SAVE_STATE_INFORMATION:
ret = save_state_information(FALSE);
break;
case CMD_READ_STATE_INFORMATION:
ret = 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_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:
case CMD_CLEAR_HOST_FLAPPING_STATE:
ret = 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:
ret = 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:
case CMD_CLEAR_SVC_FLAPPING_STATE:
ret = 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:
ret = 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:
ret = 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:
ret = process_contactgroup_command(cmd, entry_time, args);
break;
/***************************/
/**** UNSORTED COMMANDS ****/
/***************************/
case CMD_ADD_HOST_COMMENT:
case CMD_ADD_SVC_COMMENT:
ret= cmd_add_comment(cmd, entry_time, args);
break;
case CMD_DEL_HOST_COMMENT:
case CMD_DEL_SVC_COMMENT:
ret = cmd_delete_comment(cmd, args);
break;
case CMD_DELAY_HOST_NOTIFICATION:
case CMD_DELAY_SVC_NOTIFICATION:
ret = cmd_delay_notification(cmd, args);
break;
case CMD_SCHEDULE_SVC_CHECK:
case CMD_SCHEDULE_FORCED_SVC_CHECK:
ret =cmd_schedule_check(cmd, args);
break;
case CMD_SCHEDULE_HOST_SVC_CHECKS:
case CMD_SCHEDULE_FORCED_HOST_SVC_CHECKS:
ret = cmd_schedule_check(cmd, args);
break;
case CMD_DEL_ALL_HOST_COMMENTS:
case CMD_DEL_ALL_SVC_COMMENTS:
ret = cmd_delete_all_comments(cmd, args);
break;
case CMD_PROCESS_SERVICE_CHECK_RESULT:
ret = cmd_process_service_check_result(cmd, entry_time, args);
break;
case CMD_PROCESS_HOST_CHECK_RESULT:
ret = cmd_process_host_check_result(cmd, entry_time, args);
break;
case CMD_ACKNOWLEDGE_HOST_PROBLEM:
case CMD_ACKNOWLEDGE_SVC_PROBLEM:
ret = cmd_acknowledge_problem(cmd, args);
break;
case CMD_REMOVE_HOST_ACKNOWLEDGEMENT:
case CMD_REMOVE_SVC_ACKNOWLEDGEMENT:
ret = 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:
ret = cmd_schedule_downtime(cmd, entry_time, args);
break;
case CMD_DEL_HOST_DOWNTIME:
case CMD_DEL_SVC_DOWNTIME:
ret = cmd_delete_downtime(cmd, args);
break;
case CMD_DEL_DOWNTIME_BY_HOST_NAME:
ret = cmd_delete_downtime_by_host_name(cmd, args);
break;
case CMD_DEL_DOWNTIME_BY_HOSTGROUP_NAME:
ret = cmd_delete_downtime_by_hostgroup_name(cmd, args);
break;
case CMD_DEL_DOWNTIME_BY_START_TIME_COMMENT:
ret = cmd_delete_downtime_by_start_time_comment(cmd, args);
break;
case CMD_SCHEDULE_HOST_CHECK:
case CMD_SCHEDULE_FORCED_HOST_CHECK:
ret = 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:
ret = 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:
ret = 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:
ret = cmd_change_object_custom_var(cmd, args);
break;
/***********************/
/**** MISC COMMANDS ****/
/***********************/
case CMD_PROCESS_FILE:
ret = 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 CMD_ERROR_UNKNOWN_COMMAND;
break;
}
return ret;
}
/* 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};
char *author, *comment;
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_CLEAR_HOST_FLAPPING_STATE:
clear_host_flapping_state(temp_host);
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;
}
if ((author = my_strtok(NULL, ";")) != NULL) {
if ((comment = my_strtok(NULL, ";")) != NULL) {
time_t current_time = time(NULL);
add_new_host_comment(USER_COMMENT, host_name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
}
}
return OK;
}
/* processes an external hostgroup command */
int process_hostgroup_command(int cmd, time_t entry_time, char *args) {
char *hostgroup_name = NULL;
char *author = NULL, *comment = NULL;
hostgroup *temp_hostgroup = NULL;
hostsmember *temp_member = NULL;
host *temp_host = NULL;
service *temp_service = NULL;
servicesmember *temp_servicesmember = NULL;
time_t current_time = time(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;
if ((author = my_strtok(NULL, ";")) != NULL)
comment = my_strtok(NULL, ";");
/* 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);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS:
disable_host_notifications(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_HOSTGROUP_HOST_CHECKS:
enable_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_HOST_CHECKS:
disable_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
enable_passive_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_PASSIVE_HOST_CHECKS:
disable_passive_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
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);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS:
disable_service_notifications(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_HOSTGROUP_SVC_CHECKS:
enable_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_SVC_CHECKS:
disable_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
enable_passive_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_HOSTGROUP_PASSIVE_SVC_CHECKS:
disable_passive_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_host->name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
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};
char *author, *comment;
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_CLEAR_SVC_FLAPPING_STATE:
clear_service_flapping_state(temp_service);
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;
}
if ((author = my_strtok(NULL, ";")) != NULL) {
if ((comment = my_strtok(NULL, ";")) != NULL) {
time_t current_time = time(NULL);
add_new_service_comment(USER_COMMENT, host_name, svc_description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
}
}
return OK;
}
/* processes an external servicegroup command */
int process_servicegroup_command(int cmd, time_t entry_time, char *args) {
char *servicegroup_name = NULL;
char *author = NULL, *comment = NULL;
servicegroup *temp_servicegroup = NULL;
servicesmember *temp_member = NULL;
host *temp_host = NULL;
host *last_host = NULL;
service *temp_service = NULL;
time_t current_time = time(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;
if ((author = my_strtok(NULL, ";")) != NULL)
comment = my_strtok(NULL, ";");
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);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS:
disable_service_notifications(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_SERVICEGROUP_SVC_CHECKS:
enable_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_SVC_CHECKS:
disable_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
enable_passive_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_PASSIVE_SVC_CHECKS:
disable_passive_service_checks(temp_service);
if (comment)
add_new_service_comment(USER_COMMENT, temp_member->host_name, temp_service->description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
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);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS:
disable_host_notifications(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_SERVICEGROUP_HOST_CHECKS:
enable_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_HOST_CHECKS:
disable_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_ENABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
enable_passive_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
break;
case CMD_DISABLE_SERVICEGROUP_PASSIVE_HOST_CHECKS:
disable_passive_host_checks(temp_host);
if (comment)
add_new_host_comment(USER_COMMENT, temp_host->name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
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;
char *author, *comment;
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, ";")) == NULL)
return ERROR;
delay_time = strtoul(temp_ptr, NULL, 10);
/* delay the next notification... */
if(cmd == CMD_DELAY_SVC_NOTIFICATION)
temp_service->next_notification = delay_time;
else
temp_host->next_notification = delay_time;
if ((author = my_strtok(NULL, ";")) != NULL) {
if ((comment = my_strtok(NULL, ";")) != NULL) {
time_t current_time = time(NULL);
if(cmd == CMD_DELAY_SVC_NOTIFICATION)
add_new_service_comment(USER_COMMENT, host_name, svc_description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
else
add_new_host_comment(USER_COMMENT, host_name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
}
}
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;
char *author, *comment;
time_t delay_time = 0L;
/* get the host name */
if((host_name = my_strtok_with_free(args, ";", FALSE)) == 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_with_free(NULL, ";", FALSE)) == NULL)
return ERROR;
/* verify that the service is valid */
if((temp_service = find_service(host_name, svc_description)) == NULL) {
temp_ptr = my_strtok_with_free(NULL, ";", TRUE);
return ERROR;
}
}
/* get the next check time */
if((temp_ptr = my_strtok_with_free(NULL, ";", FALSE)) == NULL) {
temp_ptr = my_strtok_with_free(NULL, ";", TRUE);
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);
if ((author = my_strtok_with_free(NULL, ";", FALSE)) != NULL) {
if ((comment = my_strtok_with_free(NULL, ";", FALSE)) != NULL) {
time_t current_time = time(NULL);
if (svc_description)
add_new_service_comment(USER_COMMENT, host_name, svc_description, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
else
add_new_host_comment(USER_COMMENT, host_name, current_time, author, comment, FALSE, COMMENTSOURCE_EXTERNAL, FALSE, (time_t)0, NULL);
}
}
temp_ptr = my_strtok_with_free(NULL, ";", TRUE);
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 event_signal = 0;
/* 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);
/* what signal are we sending? */
event_signal = EVENT_PROGRAM_RESTART;
if (cmd == CMD_SHUTDOWN_PROCESS)
event_signal = EVENT_PROGRAM_SHUTDOWN;
/* add a scheduled program shutdown or restart to the event list */
if (!schedule_new_event(event_signal, TRUE, scheduled_time, FALSE, 0, NULL, FALSE, NULL, NULL, 0))
return ERROR;
return OK;
}
/* 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) */
temp_ptr = my_strtok(NULL, "\n");
/* Interpolate backslash and newline escape sequences to the literal
* characters they represent. This converts to the format we use internally
* so we don't have to worry about different representations later. */
output = (temp_ptr) ? unescape_check_result_output(temp_ptr) : strdup("");
/* 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) {
check_result cr;
host *temp_host = NULL;
service *temp_service = NULL;
struct timeval tv;
/* 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 */
temp_host = find_host_by_name_or_address(host_name);
/* we couldn't find the host */
if(temp_host == NULL) {
log_debug_info(DEBUGL_CHECKS, 0,
"Passive check result was received for service '%s' on host '%s', but the host could not be found!\n",
svc_description, host_name);
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;
}
/* now the service */
temp_service = find_service(temp_host->name, svc_description);
/* we couldn't find the service */
if(temp_service == NULL) {
log_debug_info(DEBUGL_CHECKS, 0,
"Passive check result was received for service '%s' on host '%s', but the service could not be found!\n",
svc_description, host_name);
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_checks == FALSE) {
log_debug_info(DEBUGL_CHECKS, 0, "Service '%s' on host '%s' is not accepting passive checks, bailing\n", host_name, svc_description);
return ERROR;
}
memset(&cr, 0, sizeof(cr));
cr.exited_ok = 1;
cr.check_type = CHECK_TYPE_PASSIVE;
cr.host_name = temp_host->name;
cr.service_description = temp_service->description;
cr.output = output;
cr.start_time.tv_sec = cr.finish_time.tv_sec = check_time;
cr.source = command_worker.source_name;
/* save the return code and make sure it's sane */
cr.return_code = return_code;
if (cr.return_code < 0 || cr.return_code > 3)
cr.return_code = STATE_UNKNOWN;
/* calculate latency */
gettimeofday(&tv, NULL);
cr.latency = (double)((double)(tv.tv_sec - check_time) + (double)(tv.tv_usec / 1000.0) / 1000.0);
if(cr.latency < 0.0)
cr.latency = 0.0;
return handle_async_service_check_result(temp_service, &cr);
}
/* 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) */
temp_ptr = my_strtok(NULL, "\n");
/* Interpolate backslash and newline escape sequences to the literal
* characters they represent. This converts to the format we use internally
* so we don't have to worry about different representations later. */
output = (temp_ptr) ? unescape_check_result_output(temp_ptr) : strdup("");
/* 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) {
check_result cr;
host *temp_host = NULL;
struct timeval tv;
/* 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 */
temp_host = find_host_by_name_or_address(host_name);
/* 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);
log_debug_info(DEBUGL_CHECKS, 0, "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_checks == FALSE) {
log_debug_info(DEBUGL_CHECKS, 0, "Host '%s' is not accepting passive checks, bailing\n", host_name);
return ERROR;
}
memset(&cr, 0, sizeof(cr));
cr.exited_ok = 1;
cr.check_type = CHECK_TYPE_PASSIVE;
cr.host_name = temp_host->name;
cr.output = output;
cr.start_time.tv_sec = cr.finish_time.tv_sec = check_time;
cr.source = command_worker.source_name;
cr.return_code = return_code;
/* calculate latency */
gettimeofday(&tv, NULL);
cr.latency = (double)((double)(tv.tv_sec - check_time) + (double)(tv.tv_usec / 1000.0) / 1000.0);
if(cr.latency < 0.0)
cr.latency = 0.0;
handle_async_host_check_result(temp_host, &cr);
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;
}
/* 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;
if (args == NULL) {
return ERROR;
}
/* 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 && *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;
}
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;
}
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->check_command);
temp_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->check_command);
temp_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;
}
}
/* find the object */
switch(cmd) {
case CMD_CHANGE_CUSTOM_HOST_VAR:
if((temp_host = find_host(name1)) == NULL) {
my_free(name1);
my_free(name2);
return ERROR;
}
temp_customvariablesmember = temp_host->custom_variables;
break;
case CMD_CHANGE_CUSTOM_SVC_VAR:
if((temp_service = find_service(name1, name2)) == NULL) {
my_free(name1);
my_free(name2);
return ERROR;
}
temp_customvariablesmember = temp_service->custom_variables;
break;
case CMD_CHANGE_CUSTOM_CONTACT_VAR:
if((temp_contact = find_contact(name1)) == NULL) {
my_free(name1);
my_free(name2);
return ERROR;
}
temp_customvariablesmember = temp_contact->custom_variables;
break;
default:
break;
}
/* 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;
}
/* 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(&current_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(&current_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_checks == TRUE)
return;
/* set the attribute modified flag */
svc->modified_attributes |= attr;
/* set the passive check flag */
svc->accept_passive_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_checks == FALSE)
return;
/* set the attribute modified flag */
svc->modified_attributes |= attr;
/* set the passive check flag */
svc->accept_passive_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_checks == TRUE)
return;
/* set the attribute modified flag */
hst->modified_attributes |= attr;
/* set the passive check flag */
hst->accept_passive_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_checks == FALSE)
return;
/* set the attribute modified flag */
hst->modified_attributes |= attr;
/* set the passive check flag */
hst->accept_passive_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 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 == TRUE)
return;
/* set the attribute modified flag */
svc->modified_attributes |= attr;
/* set the obsess over service flag */
svc->obsess = 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 == FALSE)
return;
/* set the attribute modified flag */
svc->modified_attributes |= attr;
/* set the obsess over service flag */
svc->obsess = 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 == TRUE)
return;
/* set the attribute modified flag */
hst->modified_attributes |= attr;
/* set the obsess flag */
hst->obsess = 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 == FALSE)
return;
/* set the attribute modified flag */
hst->modified_attributes |= attr;
/* set the obsess over host flag */
hst->obsess = 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;
}
/* clears the flapping state for a specific host */
void clear_host_flapping_state(host *hst) {
int i = 0;
double low_threshold = 0.0;
double high_threshold = 0.0;
if (enable_flap_detection == FALSE || hst->flap_detection_enabled == FALSE) {
return;
}
low_threshold = (hst->low_flap_threshold <= 0.0) ? low_host_flap_threshold : hst->low_flap_threshold;
high_threshold = (hst->high_flap_threshold <= 0.0) ? high_host_flap_threshold : hst->high_flap_threshold;
if (hst->is_flapping) {
log_debug_info(DEBUGL_FLAPPING, 1, "Host '%s' flapping state cleared.\n", hst->name);
/* log a notice - this one is parsed by the history CGI */
logit(NSLOG_INFO_MESSAGE, FALSE,
"HOST FLAPPING ALERT: %s;STOPPED; Flapping state cleared for host. (%2.1f%% change < %2.1f%% threshold)\n",
hst->name, hst->percent_state_change, low_threshold);
#ifdef USE_EVENT_BROKER
/* send data to event broker */
broker_flapping_data(NEBTYPE_FLAPPING_STOP, NEBFLAG_NONE, NEBATTR_FLAPPING_STOP_NORMAL, HOST_FLAPPING, hst, hst->percent_state_change, high_threshold, low_threshold, NULL);
#endif
/* send a notification */
host_notification(hst, NOTIFICATION_FLAPPINGSTOP, NULL, NULL, NOTIFICATION_OPTION_NONE);
/* should we send a recovery notification? */
if (hst->current_state == HOST_UP && hst->check_flapping_recovery_notification == TRUE) {
host_notification(hst, NOTIFICATION_NORMAL, NULL, NULL, NOTIFICATION_OPTION_NONE);
}
}
/* clear the history and state change percent */
for (i = 0; i < MAX_STATE_HISTORY_ENTRIES; ++i) {
hst->state_history[i] = 0;
}
hst->state_history_index = 0;
hst->percent_state_change = 0.0;
/* delete the comment we added earlier */
if (hst->flapping_comment_id != 0) {
delete_host_comment(hst->flapping_comment_id);
}
hst->flapping_comment_id = 0;
/* clear the flapping indicator */
hst->is_flapping = FALSE;
/* clear the recovery notification flag */
hst->check_flapping_recovery_notification = FALSE;
}
/* clears the flapping state for a specific service */
void clear_service_flapping_state(service *svc) {
int i = 0;
double low_threshold = 0.0;
double high_threshold = 0.0;
if (enable_flap_detection == FALSE || svc->flap_detection_enabled == FALSE) {
return;
}
low_threshold = (svc->low_flap_threshold <= 0.0) ? low_service_flap_threshold : svc->low_flap_threshold;
high_threshold = (svc->high_flap_threshold <= 0.0) ? high_service_flap_threshold : svc->high_flap_threshold;
if (svc->is_flapping) {
log_debug_info(DEBUGL_FLAPPING, 1, "Service '%s' on host '%s' flapping state cleared.\n", svc->description, svc->host_name);
/* log a notice - this one is parsed by the history CGI */
logit(NSLOG_INFO_MESSAGE, FALSE,
"SERVICE FLAPPING ALERT: %s;%s;STOPPED; Flapping state cleared for service. (%2.1f%% change < %2.1f%% threshold)\n",
svc->host_name, svc->description, svc->percent_state_change, low_threshold);
#ifdef USE_EVENT_BROKER
/* send data to event broker */
broker_flapping_data(NEBTYPE_FLAPPING_STOP, NEBFLAG_NONE, NEBATTR_FLAPPING_STOP_NORMAL, SERVICE_FLAPPING, svc, svc->percent_state_change, high_threshold, low_threshold, NULL);
#endif
/* send a notification */
service_notification(svc, NOTIFICATION_FLAPPINGSTOP, NULL, NULL, NOTIFICATION_OPTION_NONE);
/* should we send a recovery notification? */
if (svc->current_state == STATE_OK && svc->check_flapping_recovery_notification == TRUE) {
service_notification(svc, NOTIFICATION_NORMAL, NULL, NULL, NOTIFICATION_OPTION_NONE);
}
}
/* clear the history and state change percent */
for (i = 0; i < MAX_STATE_HISTORY_ENTRIES; ++i) {
svc->state_history[i] = 0;
}
svc->state_history_index = 0;
svc->percent_state_change = 0.0;
/* delete the comment we added earlier */
if (svc->flapping_comment_id != 0) {
delete_service_comment(svc->flapping_comment_id);
}
svc->flapping_comment_id = 0;
/* clear the flapping indicator */
svc->is_flapping = FALSE;
/* clear the recovery notification flag */
svc->check_flapping_recovery_notification = FALSE;
}