nagios4/cgi/extinfo.c

3167 lines
156 KiB
C
Raw Normal View History

2017-05-19 22:22:40 +02:00
/**************************************************************************
*
* EXTINFO.C - Nagios Extended Information CGI
*
*
* 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/objects.h"
#include "../include/macros.h"
#include "../include/comments.h"
#include "../include/downtime.h"
#include "../include/statusdata.h"
#include "../include/cgiutils.h"
#include "../include/getcgi.h"
#include "../include/cgiauth.h"
static nagios_macros *mac;
extern char nagios_process_info[MAX_INPUT_BUFFER];
extern int nagios_process_state;
extern int refresh_rate;
extern int buffer_stats[1][3];
extern int program_stats[MAX_CHECK_STATS_TYPES][3];
extern char main_config_file[MAX_FILENAME_LENGTH];
extern char url_html_path[MAX_FILENAME_LENGTH];
extern char url_stylesheets_path[MAX_FILENAME_LENGTH];
extern char url_docs_path[MAX_FILENAME_LENGTH];
extern char url_images_path[MAX_FILENAME_LENGTH];
extern char url_logo_images_path[MAX_FILENAME_LENGTH];
2017-05-19 23:37:19 +02:00
extern char url_js_path[MAX_FILENAME_LENGTH];
2017-05-19 22:22:40 +02:00
extern int enable_splunk_integration;
extern char *notes_url_target;
extern char *action_url_target;
extern hoststatus *hoststatus_list;
extern servicestatus *servicestatus_list;
#define MAX_MESSAGE_BUFFER 4096
#define HEALTH_WARNING_PERCENTAGE 85
#define HEALTH_CRITICAL_PERCENTAGE 75
/* SORTDATA structure */
typedef struct sortdata_struct {
int is_service;
servicestatus *svcstatus;
hoststatus *hststatus;
struct sortdata_struct *next;
} sortdata;
void document_header(int);
void document_footer(void);
int process_cgivars(void);
void show_process_info(void);
void show_host_info(void);
void show_service_info(void);
void show_all_comments(void);
void show_performance_data(void);
void show_hostgroup_info(void);
void show_servicegroup_info(void);
void show_all_downtime(void);
void show_scheduling_queue(void);
void display_comments(int);
int sort_data(int, int);
int compare_sortdata_entries(int, int, sortdata *, sortdata *);
void free_sortdata_list(void);
authdata current_authdata;
sortdata *sortdata_list = NULL;
char *host_name = "";
char *hostgroup_name = "";
char *servicegroup_name = "";
char *service_desc = "";
int display_type = DISPLAY_PROCESS_INFO;
int sort_type = SORT_ASCENDING;
int sort_option = SORT_NEXTCHECKTIME;
int embedded = FALSE;
int display_header = TRUE;
int main(void) {
int found = FALSE;
char temp_buffer[MAX_INPUT_BUFFER] = "";
char *processed_string = NULL;
host *temp_host = NULL;
hostsmember *temp_parenthost = NULL;
hostgroup *temp_hostgroup = NULL;
service *temp_service = NULL;
servicegroup *temp_servicegroup = NULL;
mac = get_global_macros();
/* get the arguments passed in the URL */
process_cgivars();
/* reset internal variables */
reset_cgi_vars();
2017-05-19 23:37:19 +02:00
cgi_init(document_header, document_footer, READ_ALL_OBJECT_DATA, READ_ALL_STATUS_DATA);
2017-05-19 22:22:40 +02:00
/* initialize macros */
init_macros();
/* get authentication information */
get_authentication_information(&current_authdata);
2017-05-19 23:37:19 +02:00
document_header(TRUE);
2017-05-19 22:22:40 +02:00
if(display_header == TRUE) {
/* begin top table */
printf("<table border=0 width=100%%>\n");
printf("<tr>\n");
/* left column of the first row */
printf("<td align=left valign=top width=33%%>\n");
if(display_type == DISPLAY_HOST_INFO)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Host Information");
else if(display_type == DISPLAY_SERVICE_INFO)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Service Information");
else if(display_type == DISPLAY_COMMENTS)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "All Host and Service Comments");
else if(display_type == DISPLAY_PERFORMANCE)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Performance Information");
else if(display_type == DISPLAY_HOSTGROUP_INFO)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Hostgroup Information");
else if(display_type == DISPLAY_SERVICEGROUP_INFO)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Servicegroup Information");
else if(display_type == DISPLAY_DOWNTIME)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "All Host and Service Scheduled Downtime");
else if(display_type == DISPLAY_SCHEDULING_QUEUE)
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Check Scheduling Queue");
else
snprintf(temp_buffer, sizeof(temp_buffer) - 1, "Nagios Process Information");
temp_buffer[sizeof(temp_buffer) - 1] = '\x0';
display_info_table(temp_buffer, TRUE, &current_authdata);
/* find the host */
if(display_type == DISPLAY_HOST_INFO || display_type == DISPLAY_SERVICE_INFO) {
temp_host = find_host(host_name);
grab_host_macros_r(mac, temp_host);
if(display_type == DISPLAY_SERVICE_INFO) {
temp_service = find_service(host_name, service_desc);
grab_service_macros_r(mac, temp_service);
}
/* write some Javascript helper functions */
if(temp_host != NULL) {
printf("<SCRIPT LANGUAGE=\"JavaScript\">\n<!--\n");
printf("function nagios_get_host_name()\n{\n");
printf("return \"%s\";\n", temp_host->name);
printf("}\n");
printf("function nagios_get_host_address()\n{\n");
printf("return \"%s\";\n", temp_host->address);
printf("}\n");
if(temp_service != NULL) {
printf("function nagios_get_service_description()\n{\n");
printf("return \"%s\";\n", temp_service->description);
printf("}\n");
}
printf("//-->\n</SCRIPT>\n");
}
}
/* find the hostgroup */
else if(display_type == DISPLAY_HOSTGROUP_INFO) {
temp_hostgroup = find_hostgroup(hostgroup_name);
grab_hostgroup_macros_r(mac, temp_hostgroup);
}
/* find the servicegroup */
else if(display_type == DISPLAY_SERVICEGROUP_INFO) {
temp_servicegroup = find_servicegroup(servicegroup_name);
grab_servicegroup_macros_r(mac, temp_servicegroup);
}
if((display_type == DISPLAY_HOST_INFO && temp_host != NULL) || (display_type == DISPLAY_SERVICE_INFO && temp_host != NULL && temp_service != NULL) || (display_type == DISPLAY_HOSTGROUP_INFO && temp_hostgroup != NULL) || (display_type == DISPLAY_SERVICEGROUP_INFO && temp_servicegroup != NULL)) {
printf("<TABLE BORDER=1 CELLPADDING=0 CELLSPACING=0 CLASS='linkBox'>\n");
printf("<TR><TD CLASS='linkBox'>\n");
if(display_type == DISPLAY_SERVICE_INFO)
printf("<A HREF='%s?type=%d&host=%s'>View Information For This Host</A><br>\n", EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(host_name));
if(display_type == DISPLAY_SERVICE_INFO || display_type == DISPLAY_HOST_INFO)
printf("<A HREF='%s?host=%s'>View Status Detail For This Host</A><BR>\n", STATUS_CGI, url_encode(host_name));
if(display_type == DISPLAY_HOST_INFO) {
printf("<A HREF='%s?host=%s'>View Alert History For This Host</A><BR>\n", HISTORY_CGI, url_encode(host_name));
#ifdef USE_TRENDS
printf("<A HREF='%s?host=%s'>View Trends For This Host</A><BR>\n", TRENDS_CGI, url_encode(host_name));
#endif
#ifdef USE_HISTOGRAM
printf("<A HREF='%s?host=%s'>View Alert Histogram For This Host</A><BR>\n", HISTOGRAM_CGI, url_encode(host_name));
#endif
printf("<A HREF='%s?host=%s&show_log_entries'>View Availability Report For This Host</A><BR>\n", AVAIL_CGI, url_encode(host_name));
printf("<A HREF='%s?host=%s'>View Notifications For This Host</A>\n", NOTIFICATIONS_CGI, url_encode(host_name));
}
else if(display_type == DISPLAY_SERVICE_INFO) {
printf("<A HREF='%s?host=%s&", HISTORY_CGI, url_encode(host_name));
printf("service=%s'>View Alert History For This Service</A><BR>\n", url_encode(service_desc));
#ifdef USE_TRENDS
printf("<A HREF='%s?host=%s&", TRENDS_CGI, url_encode(host_name));
printf("service=%s'>View Trends For This Service</A><BR>\n", url_encode(service_desc));
#endif
#ifdef USE_HISTOGRAM
printf("<A HREF='%s?host=%s&", HISTOGRAM_CGI, url_encode(host_name));
printf("service=%s'>View Alert Histogram For This Service</A><BR>\n", url_encode(service_desc));
#endif
printf("<A HREF='%s?host=%s&", AVAIL_CGI, url_encode(host_name));
printf("service=%s&show_log_entries'>View Availability Report For This Service</A><BR>\n", url_encode(service_desc));
printf("<A HREF='%s?host=%s&", NOTIFICATIONS_CGI, url_encode(host_name));
printf("service=%s'>View Notifications For This Service</A>\n", url_encode(service_desc));
}
else if(display_type == DISPLAY_HOSTGROUP_INFO) {
printf("<A HREF='%s?hostgroup=%s&style=detail'>View Status Detail For This Hostgroup</A><BR>\n", STATUS_CGI, url_encode(hostgroup_name));
printf("<A HREF='%s?hostgroup=%s&style=overview'>View Status Overview For This Hostgroup</A><BR>\n", STATUS_CGI, url_encode(hostgroup_name));
printf("<A HREF='%s?hostgroup=%s&style=grid'>View Status Grid For This Hostgroup</A><BR>\n", STATUS_CGI, url_encode(hostgroup_name));
printf("<A HREF='%s?hostgroup=%s'>View Availability For This Hostgroup</A><BR>\n", AVAIL_CGI, url_encode(hostgroup_name));
}
else if(display_type == DISPLAY_SERVICEGROUP_INFO) {
printf("<A HREF='%s?servicegroup=%s&style=detail'>View Status Detail For This Servicegroup</A><BR>\n", STATUS_CGI, url_encode(servicegroup_name));
printf("<A HREF='%s?servicegroup=%s&style=overview'>View Status Overview For This Servicegroup</A><BR>\n", STATUS_CGI, url_encode(servicegroup_name));
printf("<A HREF='%s?servicegroup=%s&style=grid'>View Status Grid For This Servicegroup</A><BR>\n", STATUS_CGI, url_encode(servicegroup_name));
printf("<A HREF='%s?servicegroup=%s'>View Availability For This Servicegroup</A><BR>\n", AVAIL_CGI, url_encode(servicegroup_name));
}
printf("</TD></TR>\n");
printf("</TABLE>\n");
}
printf("</td>\n");
/* middle column of top row */
printf("<td align=center valign=middle width=33%%>\n");
if((display_type == DISPLAY_HOST_INFO && temp_host != NULL) || (display_type == DISPLAY_SERVICE_INFO && temp_host != NULL && temp_service != NULL) || (display_type == DISPLAY_HOSTGROUP_INFO && temp_hostgroup != NULL) || (display_type == DISPLAY_SERVICEGROUP_INFO && temp_servicegroup != NULL)) {
if(display_type == DISPLAY_HOST_INFO) {
printf("<DIV CLASS='data'>Host</DIV>\n");
printf("<DIV CLASS='dataTitle'>%s</DIV>\n", temp_host->alias);
printf("<DIV CLASS='dataTitle'>(%s)</DIV><BR>\n", temp_host->name);
if(temp_host->parent_hosts != NULL) {
/* print all parent hosts */
printf("<DIV CLASS='data'>Parents:</DIV>\n");
for(temp_parenthost = temp_host->parent_hosts; temp_parenthost != NULL; temp_parenthost = temp_parenthost->next)
printf("<DIV CLASS='dataTitle'><A HREF='%s?host=%s'>%s</A></DIV>\n", STATUS_CGI, url_encode(temp_parenthost->host_name), temp_parenthost->host_name);
printf("<BR>");
}
printf("<DIV CLASS='data'>Member of</DIV><DIV CLASS='dataTitle'>");
for(temp_hostgroup = hostgroup_list; temp_hostgroup != NULL; temp_hostgroup = temp_hostgroup->next) {
if(is_host_member_of_hostgroup(temp_hostgroup, temp_host) == TRUE) {
if(found == TRUE)
printf(", ");
printf("<A HREF='%s?hostgroup=%s&style=overview'>%s</A>", STATUS_CGI, url_encode(temp_hostgroup->group_name), temp_hostgroup->group_name);
found = TRUE;
}
}
if(found == FALSE)
printf("No hostgroups");
printf("</DIV><BR>\n");
printf("<DIV CLASS='data'>%s</DIV>\n", temp_host->address);
}
if(display_type == DISPLAY_SERVICE_INFO) {
printf("<DIV CLASS='data'>Service</DIV><DIV CLASS='dataTitle'>%s</DIV><DIV CLASS='data'>On Host</DIV>\n", service_desc);
printf("<DIV CLASS='dataTitle'>%s</DIV>\n", temp_host->alias);
printf("<DIV CLASS='dataTitle'>(<A HREF='%s?type=%d&host=%s'>%s</a>)</DIV><BR>\n", EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_host->name), temp_host->name);
printf("<DIV CLASS='data'>Member of</DIV><DIV CLASS='dataTitle'>");
for(temp_servicegroup = servicegroup_list; temp_servicegroup != NULL; temp_servicegroup = temp_servicegroup->next) {
if(is_service_member_of_servicegroup(temp_servicegroup, temp_service) == TRUE) {
if(found == TRUE)
printf(", ");
printf("<A HREF='%s?servicegroup=%s&style=overview'>%s</A>", STATUS_CGI, url_encode(temp_servicegroup->group_name), temp_servicegroup->group_name);
found = TRUE;
}
}
if(found == FALSE)
printf("No servicegroups.");
printf("</DIV><BR>\n");
printf("<DIV CLASS='data'>%s</DIV>\n", temp_host->address);
}
if(display_type == DISPLAY_HOSTGROUP_INFO) {
printf("<DIV CLASS='data'>Hostgroup</DIV>\n");
printf("<DIV CLASS='dataTitle'>%s</DIV>\n", temp_hostgroup->alias);
printf("<DIV CLASS='dataTitle'>(%s)</DIV>\n", temp_hostgroup->group_name);
if(temp_hostgroup->notes != NULL) {
process_macros_r(mac, temp_hostgroup->notes, &processed_string, 0);
printf("<p>%s</p>", processed_string);
free(processed_string);
}
}
if(display_type == DISPLAY_SERVICEGROUP_INFO) {
printf("<DIV CLASS='data'>Servicegroup</DIV>\n");
printf("<DIV CLASS='dataTitle'>%s</DIV>\n", temp_servicegroup->alias);
printf("<DIV CLASS='dataTitle'>(%s)</DIV>\n", temp_servicegroup->group_name);
if(temp_servicegroup->notes != NULL) {
process_macros_r(mac, temp_servicegroup->notes, &processed_string, 0);
printf("<p>%s</p>", processed_string);
free(processed_string);
}
}
if(display_type == DISPLAY_SERVICE_INFO) {
if(temp_service->icon_image != NULL) {
printf("<img src='%s", url_logo_images_path);
process_macros_r(mac, temp_service->icon_image, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
printf("' border=0 alt='%s' title='%s'><BR CLEAR=ALL>", (temp_service->icon_image_alt == NULL) ? "" : temp_service->icon_image_alt, (temp_service->icon_image_alt == NULL) ? "" : temp_service->icon_image_alt);
}
if(temp_service->icon_image_alt != NULL)
printf("<font size=-1><i>( %s )</i></font>\n", temp_service->icon_image_alt);
if(temp_service->notes != NULL) {
process_macros_r(mac, temp_service->notes, &processed_string, 0);
printf("<p>%s</p>\n", processed_string);
free(processed_string);
}
}
if(display_type == DISPLAY_HOST_INFO) {
if(temp_host->icon_image != NULL) {
printf("<img src='%s", url_logo_images_path);
process_macros_r(mac, temp_host->icon_image, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
printf("' border=0 alt='%s' title='%s'><BR CLEAR=ALL>", (temp_host->icon_image_alt == NULL) ? "" : temp_host->icon_image_alt, (temp_host->icon_image_alt == NULL) ? "" : temp_host->icon_image_alt);
}
if(temp_host->icon_image_alt != NULL)
printf("<font size=-1><i>( %s )</i><font>\n", temp_host->icon_image_alt);
if(temp_host->notes != NULL) {
process_macros_r(mac, temp_host->notes, &processed_string, 0);
printf("<p>%s</p>\n", processed_string);
free(processed_string);
}
}
}
printf("</td>\n");
/* right column of top row */
printf("<td align=right valign=bottom width=33%%>\n");
if(display_type == DISPLAY_HOST_INFO && temp_host != NULL) {
printf("<TABLE BORDER='0'>\n");
if(temp_host->action_url != NULL && strcmp(temp_host->action_url, "")) {
printf("<TR><TD ALIGN='right'>\n");
printf("<A HREF='");
process_macros_r(mac, temp_host->action_url, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='Perform Additional Actions On This Host' title='Perform Additional Actions On This Host'></A>\n", (action_url_target == NULL) ? "_blank" : action_url_target, url_images_path, ACTION_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Actions</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
printf("</TD></TR>\n");
}
if(temp_host->notes_url != NULL && strcmp(temp_host->notes_url, "")) {
printf("<TR><TD ALIGN='right'>\n");
printf("<A HREF='");
process_macros_r(mac, temp_host->notes_url, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
/*print_extra_host_url(temp_host->name,temp_host->notes_url);*/
printf("' TARGET='%s'><img src='%s%s' border=0 alt='View Additional Notes For This Host' title='View Additional Notes For This Host'></A>\n", (notes_url_target == NULL) ? "_blank" : notes_url_target, url_images_path, NOTES_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Notes</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
printf("</TD></TR>\n");
}
printf("</TABLE>\n");
}
else if(display_type == DISPLAY_SERVICE_INFO && temp_service != NULL) {
printf("<TABLE BORDER='0'><TR><TD ALIGN='right'>\n");
if(temp_service->action_url != NULL && strcmp(temp_service->action_url, "")) {
printf("<A HREF='");
process_macros_r(mac, temp_service->action_url, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='Perform Additional Actions On This Service' title='Perform Additional Actions On This Service'></A>\n", (action_url_target == NULL) ? "_blank" : action_url_target, url_images_path, ACTION_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Actions</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
}
if(temp_service->notes_url != NULL && strcmp(temp_service->notes_url, "")) {
printf("<A HREF='");
process_macros_r(mac, temp_service->notes_url, &processed_string, 0);
printf("%s", processed_string);
free(processed_string);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='View Additional Notes For This Service' title='View Additional Notes For This Service'></A>\n", (notes_url_target == NULL) ? "_blank" : notes_url_target, url_images_path, NOTES_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Notes</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
}
printf("</TD></TR></TABLE>\n");
}
if(display_type == DISPLAY_HOSTGROUP_INFO && temp_hostgroup != NULL) {
printf("<TABLE BORDER='0'>\n");
if(temp_hostgroup->action_url != NULL && strcmp(temp_hostgroup->action_url, "")) {
printf("<TR><TD ALIGN='right'>\n");
printf("<A HREF='");
print_extra_hostgroup_url(temp_hostgroup->group_name, temp_hostgroup->action_url);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='Perform Additional Actions On This Hostgroup' title='Perform Additional Actions On This Hostgroup'></A>\n", (action_url_target == NULL) ? "_blank" : action_url_target, url_images_path, ACTION_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Actions</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
printf("</TD></TR>\n");
}
if(temp_hostgroup->notes_url != NULL && strcmp(temp_hostgroup->notes_url, "")) {
printf("<TR><TD ALIGN='right'>\n");
printf("<A HREF='");
print_extra_hostgroup_url(temp_hostgroup->group_name, temp_hostgroup->notes_url);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='View Additional Notes For This Hostgroup' title='View Additional Notes For This Hostgroup'></A>\n", (notes_url_target == NULL) ? "_blank" : notes_url_target, url_images_path, NOTES_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Notes</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
printf("</TD></TR>\n");
}
printf("</TABLE>\n");
}
else if(display_type == DISPLAY_SERVICEGROUP_INFO && temp_servicegroup != NULL) {
printf("<TABLE BORDER='0'>\n");
if(temp_servicegroup->action_url != NULL && strcmp(temp_servicegroup->action_url, "")) {
printf("<A HREF='");
print_extra_servicegroup_url(temp_servicegroup->group_name, temp_servicegroup->action_url);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='Perform Additional Actions On This Servicegroup' title='Perform Additional Actions On This Servicegroup'></A>\n", (action_url_target == NULL) ? "_blank" : action_url_target, url_images_path, ACTION_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Actions</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
}
if(temp_servicegroup->notes_url != NULL && strcmp(temp_servicegroup->notes_url, "")) {
printf("<A HREF='");
print_extra_servicegroup_url(temp_servicegroup->group_name, temp_servicegroup->notes_url);
printf("' TARGET='%s'><img src='%s%s' border=0 alt='View Additional Notes For This Servicegroup' title='View Additional Notes For This Servicegroup'></A>\n", (notes_url_target == NULL) ? "_blank" : notes_url_target, url_images_path, NOTES_ICON);
printf("<BR CLEAR=ALL><FONT SIZE=-1><I>Extra Notes</I></FONT><BR CLEAR=ALL><BR CLEAR=ALL>\n");
}
printf("</TABLE>\n");
}
/* display context-sensitive help */
if(display_type == DISPLAY_HOST_INFO)
display_context_help(CONTEXTHELP_EXT_HOST);
else if(display_type == DISPLAY_SERVICE_INFO)
display_context_help(CONTEXTHELP_EXT_SERVICE);
else if(display_type == DISPLAY_HOSTGROUP_INFO)
display_context_help(CONTEXTHELP_EXT_HOSTGROUP);
else if(display_type == DISPLAY_SERVICEGROUP_INFO)
display_context_help(CONTEXTHELP_EXT_SERVICEGROUP);
else if(display_type == DISPLAY_PROCESS_INFO)
display_context_help(CONTEXTHELP_EXT_PROCESS);
else if(display_type == DISPLAY_PERFORMANCE)
display_context_help(CONTEXTHELP_EXT_PERFORMANCE);
else if(display_type == DISPLAY_COMMENTS)
display_context_help(CONTEXTHELP_EXT_COMMENTS);
else if(display_type == DISPLAY_DOWNTIME)
display_context_help(CONTEXTHELP_EXT_DOWNTIME);
else if(display_type == DISPLAY_SCHEDULING_QUEUE)
display_context_help(CONTEXTHELP_EXT_QUEUE);
printf("</td>\n");
/* end of top table */
printf("</tr>\n");
printf("</table>\n");
}
printf("<BR>\n");
if(display_type == DISPLAY_HOST_INFO)
show_host_info();
else if(display_type == DISPLAY_SERVICE_INFO)
show_service_info();
else if(display_type == DISPLAY_COMMENTS)
show_all_comments();
else if(display_type == DISPLAY_PERFORMANCE)
show_performance_data();
else if(display_type == DISPLAY_HOSTGROUP_INFO)
show_hostgroup_info();
else if(display_type == DISPLAY_SERVICEGROUP_INFO)
show_servicegroup_info();
else if(display_type == DISPLAY_DOWNTIME)
show_all_downtime();
else if(display_type == DISPLAY_SCHEDULING_QUEUE)
show_scheduling_queue();
else
show_process_info();
document_footer();
/* free all allocated memory */
free_memory();
free_comment_data();
free_downtime_data();
return OK;
}
void document_header(int use_stylesheet) {
char date_time[MAX_DATETIME_LENGTH];
2017-05-19 23:37:19 +02:00
char *vidurl = NULL;
2017-05-19 22:22:40 +02:00
time_t current_time;
time_t expire_time;
printf("Cache-Control: no-store\r\n");
printf("Pragma: no-cache\r\n");
printf("Refresh: %d\r\n", refresh_rate);
time(&current_time);
get_time_string(&current_time, date_time, (int)sizeof(date_time), HTTP_DATE_TIME);
printf("Last-Modified: %s\r\n", date_time);
expire_time = (time_t)0L;
get_time_string(&expire_time, date_time, (int)sizeof(date_time), HTTP_DATE_TIME);
printf("Expires: %s\r\n", date_time);
2017-05-19 23:37:19 +02:00
printf("Content-type: text/html; charset=utf-8\r\n\r\n");
2017-05-19 22:22:40 +02:00
if(embedded == TRUE)
return;
printf("<html>\n");
printf("<head>\n");
printf("<link rel=\"shortcut icon\" href=\"%sfavicon.ico\" type=\"image/ico\">\n", url_images_path);
printf("<title>\n");
printf("Extended Information\n");
printf("</title>\n");
if(use_stylesheet == TRUE) {
printf("<LINK REL='stylesheet' TYPE='text/css' HREF='%s%s'>", url_stylesheets_path, COMMON_CSS);
printf("<LINK REL='stylesheet' TYPE='text/css' HREF='%s%s'>", url_stylesheets_path, EXTINFO_CSS);
2017-05-19 23:37:19 +02:00
printf("<LINK REL='stylesheet' TYPE='text/css' HREF='%s%s'>\n", url_stylesheets_path, NAGFUNCS_CSS);
2017-05-19 22:22:40 +02:00
}
2017-05-19 23:37:19 +02:00
if (display_type == DISPLAY_HOST_INFO)
vidurl = "https://www.youtube.com/embed/n3QEAf-MxY4";
else if(display_type == DISPLAY_SERVICE_INFO)
vidurl = "https://www.youtube.com/embed/f_knwQOS6FI";
if (vidurl) {
printf("<script type='text/javascript' src='%s%s'></script>\n", url_js_path, JQUERY_JS);
printf("<script type='text/javascript' src='%s%s'></script>\n", url_js_path, NAGFUNCS_JS);
printf("<script type='text/javascript'>\n");
printf("var vbox, vBoxId='extinfo%d', vboxText = "
"'<a href=https://www.nagios.com/tours target=_blank>"
"Click here to watch the entire Nagios Core 4 Tour!</a>';\n",
display_type);
printf("$(document).ready(function() {\n"
"var user = '%s';\nvBoxId += ';' + user;\n",
current_authdata.username);
printf("vbox = new vidbox({pos:'lr',vidurl:'%s',text:vboxText,"
"vidid:vBoxId});\n", vidurl);
printf("});\n</script>\n");
}
2017-05-19 22:22:40 +02:00
printf("</head>\n");
printf("<body CLASS='extinfo'>\n");
/* include user SSI header */
include_ssi_files(EXTINFO_CGI, SSI_HEADER);
return;
}
void document_footer(void) {
if(embedded == TRUE)
return;
/* include user SSI footer */
include_ssi_files(EXTINFO_CGI, SSI_FOOTER);
printf("</body>\n");
printf("</html>\n");
return;
}
int process_cgivars(void) {
char **variables;
int error = FALSE;
int temp_type;
int x;
variables = getcgivars();
for(x = 0; variables[x] != NULL; x++) {
/* do some basic length checking on the variable identifier to prevent buffer overflows */
if(strlen(variables[x]) >= MAX_INPUT_BUFFER - 1) {
continue;
}
/* we found the display type */
else if(!strcmp(variables[x], "type")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
temp_type = atoi(variables[x]);
if(temp_type == DISPLAY_HOST_INFO)
display_type = DISPLAY_HOST_INFO;
else if(temp_type == DISPLAY_SERVICE_INFO)
display_type = DISPLAY_SERVICE_INFO;
else if(temp_type == DISPLAY_COMMENTS)
display_type = DISPLAY_COMMENTS;
else if(temp_type == DISPLAY_PERFORMANCE)
display_type = DISPLAY_PERFORMANCE;
else if(temp_type == DISPLAY_HOSTGROUP_INFO)
display_type = DISPLAY_HOSTGROUP_INFO;
else if(temp_type == DISPLAY_SERVICEGROUP_INFO)
display_type = DISPLAY_SERVICEGROUP_INFO;
else if(temp_type == DISPLAY_DOWNTIME)
display_type = DISPLAY_DOWNTIME;
else if(temp_type == DISPLAY_SCHEDULING_QUEUE)
display_type = DISPLAY_SCHEDULING_QUEUE;
else
display_type = DISPLAY_PROCESS_INFO;
}
/* we found the host name */
else if(!strcmp(variables[x], "host")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
host_name = strdup(variables[x]);
if(host_name == NULL)
host_name = "";
strip_html_brackets(host_name);
}
/* we found the hostgroup name */
else if(!strcmp(variables[x], "hostgroup")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
hostgroup_name = strdup(variables[x]);
if(hostgroup_name == NULL)
hostgroup_name = "";
strip_html_brackets(hostgroup_name);
}
/* we found the service name */
else if(!strcmp(variables[x], "service")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
service_desc = strdup(variables[x]);
if(service_desc == NULL)
service_desc = "";
strip_html_brackets(service_desc);
}
/* we found the servicegroup name */
else if(!strcmp(variables[x], "servicegroup")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
servicegroup_name = strdup(variables[x]);
if(servicegroup_name == NULL)
servicegroup_name = "";
strip_html_brackets(servicegroup_name);
}
/* we found the sort type argument */
else if(!strcmp(variables[x], "sorttype")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
sort_type = atoi(variables[x]);
}
/* we found the sort option argument */
else if(!strcmp(variables[x], "sortoption")) {
x++;
if(variables[x] == NULL) {
error = TRUE;
break;
}
sort_option = atoi(variables[x]);
}
/* we found the embed option */
else if(!strcmp(variables[x], "embedded"))
embedded = TRUE;
/* we found the noheader option */
else if(!strcmp(variables[x], "noheader"))
display_header = FALSE;
}
/* free memory allocated to the CGI variables */
free_cgivars(variables);
return error;
}
void show_process_info(void) {
char date_time[MAX_DATETIME_LENGTH];
time_t current_time;
unsigned long run_time;
char run_time_string[24];
int days = 0;
int hours = 0;
int minutes = 0;
int seconds = 0;
/* make sure the user has rights to view system information */
if(is_authorized_for_system_information(&current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view process information...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
printf("<BR />\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CELLPADDING=20>\n");
printf("<TR><TD VALIGN=TOP>\n");
printf("<DIV CLASS='dataTitle'>Process Information</DIV>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0 CLASS='data'>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
/* program version */
printf("<TR><TD CLASS='dataVar'>Program Version:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", PROGRAM_VERSION);
/* program start time */
get_time_string(&program_start, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Program Start Time:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", date_time);
/* total running time */
time(&current_time);
run_time = (unsigned long)(current_time - program_start);
get_time_breakdown(run_time, &days, &hours, &minutes, &seconds);
sprintf(run_time_string, "%dd %dh %dm %ds", days, hours, minutes, seconds);
printf("<TR><TD CLASS='dataVar'>Total Running Time:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", run_time_string);
/* last log file rotation */
get_time_string(&last_log_rotation, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Log File Rotation:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (last_log_rotation == (time_t)0) ? "N/A" : date_time);
/* PID */
printf("<TR><TD CLASS='dataVar'>Nagios PID</TD><TD CLASS='dataVal'>%d</TD></TR>\n", nagios_pid);
/* notifications enabled */
printf("<TR><TD CLASS='dataVar'>Notifications Enabled?</TD><TD CLASS='dataVal'><DIV CLASS='notifications%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (enable_notifications == TRUE) ? "ENABLED" : "DISABLED", (enable_notifications == TRUE) ? "YES" : "NO");
/* service check execution enabled */
printf("<TR><TD CLASS='dataVar'>Service Checks Being Executed?</TD><TD CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (execute_service_checks == TRUE) ? "ENABLED" : "DISABLED", (execute_service_checks == TRUE) ? "YES" : "NO");
/* passive service check acceptance */
printf("<TR><TD CLASS='dataVar'>Passive Service Checks Being Accepted?</TD><TD CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (accept_passive_service_checks == TRUE) ? "ENABLED" : "DISABLED", (accept_passive_service_checks == TRUE) ? "YES" : "NO");
/* host check execution enabled */
printf("<TR><TD CLASS='dataVar'>Host Checks Being Executed?</TD><TD CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (execute_host_checks == TRUE) ? "ENABLED" : "DISABLED", (execute_host_checks == TRUE) ? "YES" : "NO");
/* passive host check acceptance */
printf("<TR><TD CLASS='dataVar'>Passive Host Checks Being Accepted?</TD><TD CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (accept_passive_host_checks == TRUE) ? "ENABLED" : "DISABLED", (accept_passive_host_checks == TRUE) ? "YES" : "NO");
/* event handlers enabled */
printf("<TR><TD CLASS='dataVar'>Event Handlers Enabled?</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (enable_event_handlers == TRUE) ? "Yes" : "No");
/* obsessing over services */
printf("<TR><TD CLASS='dataVar'>Obsessing Over Services?</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (obsess_over_services == TRUE) ? "Yes" : "No");
/* obsessing over hosts */
printf("<TR><TD CLASS='dataVar'>Obsessing Over Hosts?</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (obsess_over_hosts == TRUE) ? "Yes" : "No");
/* flap detection enabled */
printf("<TR><TD CLASS='dataVar'>Flap Detection Enabled?</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (enable_flap_detection == TRUE) ? "Yes" : "No");
/* process performance data */
printf("<TR><TD CLASS='dataVar'>Performance Data Being Processed?</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (process_performance_data == TRUE) ? "Yes" : "No");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD><TD VALIGN=TOP>\n");
printf("<DIV CLASS='commandTitle'>Process Commands</DIV>\n");
printf("<TABLE BORDER=1 CELLPADDING=0 CELLSPACING=0 CLASS='command'>\n");
printf("<TR><TD>\n");
if(nagios_process_state == STATE_OK) {
printf("<TABLE BORDER=0 CELLPADDING=0 CELLSPACING=0 CLASS='command'>\n");
#ifndef DUMMY_INSTALL
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Shutdown the Nagios Process' TITLE='Shutdown the Nagios Process'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Shutdown the Nagios process</a></td></tr>\n", url_images_path, STOP_ICON, COMMAND_CGI, CMD_SHUTDOWN_PROCESS);
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Restart the Nagios Process' TITLE='Restart the Nagios Process'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Restart the Nagios process</a></td></tr>\n", url_images_path, RESTART_ICON, COMMAND_CGI, CMD_RESTART_PROCESS);
#endif
if(enable_notifications == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Disable Notifications' TITLE='Disable Notifications'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Disable notifications</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_NOTIFICATIONS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Enable Notifications' TITLE='Enable Notifications'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Enable notifications</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_NOTIFICATIONS);
if(execute_service_checks == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Executing Service Checks' TITLE='Stop Executing Service Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop executing service checks</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_EXECUTING_SVC_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Executing Service Checks' TITLE='Start Executing Service Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start executing service checks</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_EXECUTING_SVC_CHECKS);
if(accept_passive_service_checks == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Accepting Passive Service Checks' TITLE='Stop Accepting Passive Service Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop accepting passive service checks</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_ACCEPTING_PASSIVE_SVC_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Accepting Passive Service Checks' TITLE='Start Accepting Passive Service Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start accepting passive service checks</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_ACCEPTING_PASSIVE_SVC_CHECKS);
if(execute_host_checks == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Executing Host Checks' TITLE='Stop Executing Host Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop executing host checks</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_EXECUTING_HOST_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Executing Host Checks' TITLE='Start Executing Host Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start executing host checks</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_EXECUTING_HOST_CHECKS);
if(accept_passive_host_checks == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Accepting Passive Host Checks' TITLE='Stop Accepting Passive Host Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop accepting passive host checks</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_ACCEPTING_PASSIVE_HOST_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Accepting Passive Host Checks' TITLE='Start Accepting Passive Host Checks'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start accepting passive host checks</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_ACCEPTING_PASSIVE_HOST_CHECKS);
if(enable_event_handlers == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Disable Event Handlers' TITLE='Disable Event Handlers'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Disable event handlers</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_EVENT_HANDLERS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Enable Event Handlers' TITLE='Enable Event Handlers'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Enable event handlers</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_EVENT_HANDLERS);
if(obsess_over_services == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Obsessing Over Services' TITLE='Stop Obsessing Over Services'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop obsessing over services</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_OBSESSING_OVER_SVC_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Obsessing Over Services' TITLE='Start Obsessing Over Services'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start obsessing over services</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_OBSESSING_OVER_SVC_CHECKS);
if(obsess_over_hosts == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Stop Obsessing Over Hosts' TITLE='Stop Obsessing Over Hosts'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Stop obsessing over hosts</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_OBSESSING_OVER_HOST_CHECKS);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Start Obsessing Over Hosts' TITLE='Start Obsessing Over Hosts'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Start obsessing over hosts</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_OBSESSING_OVER_HOST_CHECKS);
if(enable_flap_detection == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Disable Flap Detection' TITLE='Disable Flap Detection'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Disable flap detection</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_FLAP_DETECTION);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Enable Flap Detection' TITLE='Enable Flap Detection'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Enable flap detection</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_FLAP_DETECTION);
if(process_performance_data == TRUE)
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Disable Performance Data' TITLE='Disable Performance Data'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Disable performance data</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_PERFORMANCE_DATA);
else
printf("<TR CLASS='command'><TD><img src='%s%s' border=0 ALT='Enable Performance Data' TITLE='Enable Performance Data'></td><td CLASS='command'><a href='%s?cmd_typ=%d'>Enable performance data</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_PERFORMANCE_DATA);
printf("</TABLE>\n");
}
else {
printf("<DIV ALIGN=CENTER CLASS='infoMessage'>It appears as though Nagios is not running, so commands are temporarily unavailable...\n");
printf("</DIV>\n");
}
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD></TR></TABLE>\n");
printf("</DIV>\n");
}
void show_host_info(void) {
hoststatus *temp_hoststatus;
host *temp_host;
char date_time[MAX_DATETIME_LENGTH];
char state_duration[48];
char status_age[48];
char state_string[MAX_INPUT_BUFFER];
2017-05-19 23:37:19 +02:00
const char *bg_class = "";
2017-05-19 22:22:40 +02:00
char *buf = NULL;
int days;
int hours;
int minutes;
int seconds;
time_t current_time;
time_t t;
int duration_error = FALSE;
/* get host info */
temp_host = find_host(host_name);
/* make sure the user has rights to view host information */
if(is_authorized_for_host(temp_host, &current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view information for this host...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
/* get host status info */
temp_hoststatus = find_hoststatus(host_name);
/* make sure host information exists */
if(temp_host == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Host Not Found!</DIV></P>>");
return;
}
if(temp_hoststatus == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Host Status Information Not Found!</DIV></P");
return;
}
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CELLPADDING=0 WIDTH=100%%>\n");
printf("<TR>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
printf("<DIV CLASS='dataTitle'>Host State Information</DIV>\n");
if(temp_hoststatus->has_been_checked == FALSE)
printf("<P><DIV ALIGN=CENTER>This host has not yet been checked, so status information is not available.</DIV></P>\n");
else {
printf("<TABLE BORDER=0>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
current_time = time(NULL);
t = 0;
duration_error = FALSE;
if(temp_hoststatus->last_state_change == (time_t)0) {
if(program_start > current_time)
duration_error = TRUE;
else
t = current_time - program_start;
}
else {
if(temp_hoststatus->last_state_change > current_time)
duration_error = TRUE;
else
t = current_time - temp_hoststatus->last_state_change;
}
get_time_breakdown((unsigned long)t, &days, &hours, &minutes, &seconds);
if(duration_error == TRUE)
snprintf(state_duration, sizeof(state_duration) - 1, "???");
else
snprintf(state_duration, sizeof(state_duration) - 1, "%2dd %2dh %2dm %2ds%s", days, hours, minutes, seconds, (temp_hoststatus->last_state_change == (time_t)0) ? "+" : "");
state_duration[sizeof(state_duration) - 1] = '\x0';
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->status == SD_HOST_UP) {
2017-05-19 22:22:40 +02:00
strcpy(state_string, "UP");
bg_class = "hostUP";
}
2017-05-19 23:37:19 +02:00
else if(temp_hoststatus->status == SD_HOST_DOWN) {
2017-05-19 22:22:40 +02:00
strcpy(state_string, "DOWN");
bg_class = "hostDOWN";
}
2017-05-19 23:37:19 +02:00
else if(temp_hoststatus->status == SD_HOST_UNREACHABLE) {
2017-05-19 22:22:40 +02:00
strcpy(state_string, "UNREACHABLE");
bg_class = "hostUNREACHABLE";
}
printf("<TR><TD CLASS='dataVar'>Host Status:</td><td CLASS='dataVal'><DIV CLASS='%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV>&nbsp;(for %s)%s</td></tr>\n", bg_class, state_string, state_duration, (temp_hoststatus->problem_has_been_acknowledged == TRUE) ? "&nbsp;&nbsp;(Has been acknowledged)" : "");
printf("<TR><TD CLASS='dataVar' VALIGN='top'>Status Information:</td><td CLASS='dataVal'>%s", (temp_hoststatus->plugin_output == NULL) ? "" : html_encode(temp_hoststatus->plugin_output, TRUE));
if(enable_splunk_integration == TRUE) {
printf("&nbsp;&nbsp;");
asprintf(&buf, "%s %s", temp_host->name, temp_hoststatus->plugin_output);
display_splunk_generic_url(buf, 1);
free(buf);
}
if(temp_hoststatus->long_plugin_output != NULL)
printf("<BR>%s", html_encode(temp_hoststatus->long_plugin_output, TRUE));
printf("</TD></TR>\n");
printf("<TR><TD CLASS='dataVar' VALIGN='top'>Performance Data:</td><td CLASS='dataVal'>%s</td></tr>\n", (temp_hoststatus->perf_data == NULL) ? "" : html_encode(temp_hoststatus->perf_data, TRUE));
printf("<TR><TD CLASS='dataVar'>Current Attempt:</TD><TD CLASS='dataVal'>%d/%d", temp_hoststatus->current_attempt, temp_hoststatus->max_attempts);
printf("&nbsp;&nbsp;(%s state)</TD></TR>\n", (temp_hoststatus->state_type == HARD_STATE) ? "HARD" : "SOFT");
get_time_string(&temp_hoststatus->last_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Check Time:</td><td CLASS='dataVal'>%s</td></tr>\n", date_time);
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Check Type:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (temp_hoststatus->check_type == CHECK_TYPE_ACTIVE) ? "ACTIVE" : "PASSIVE");
2017-05-19 22:22:40 +02:00
printf("<TR><TD CLASS='dataVar' NOWRAP>Check Latency / Duration:</TD><TD CLASS='dataVal'>");
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->check_type == CHECK_TYPE_ACTIVE)
2017-05-19 22:22:40 +02:00
printf("%.3f", temp_hoststatus->latency);
else
printf("N/A");
printf("&nbsp;/&nbsp;%.3f seconds", temp_hoststatus->execution_time);
printf("</TD></TR>\n");
get_time_string(&temp_hoststatus->next_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Next Scheduled Active Check:&nbsp;&nbsp;</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (temp_hoststatus->checks_enabled && temp_hoststatus->next_check != (time_t)0 && temp_hoststatus->should_be_scheduled == TRUE) ? date_time : "N/A");
get_time_string(&temp_hoststatus->last_state_change, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last State Change:</td><td CLASS='dataVal'>%s</td></tr>\n", (temp_hoststatus->last_state_change == (time_t)0) ? "N/A" : date_time);
get_time_string(&temp_hoststatus->last_notification, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Notification:</td><td CLASS='dataVal'>%s&nbsp;(notification %d)</td></tr>\n", (temp_hoststatus->last_notification == (time_t)0) ? "N/A" : date_time, temp_hoststatus->current_notification_number);
printf("<TR><TD CLASS='dataVar'>Is This Host Flapping?</td><td CLASS='dataVal'>");
if(temp_hoststatus->flap_detection_enabled == FALSE || enable_flap_detection == FALSE)
printf("N/A");
else
printf("<DIV CLASS='%sflapping'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV>&nbsp;(%3.2f%% state change)", (temp_hoststatus->is_flapping == TRUE) ? "" : "not", (temp_hoststatus->is_flapping == TRUE) ? "YES" : "NO", temp_hoststatus->percent_state_change);
printf("</td></tr>\n");
printf("<TR><TD CLASS='dataVar'>In Scheduled Downtime?</td><td CLASS='dataVal'><DIV CLASS='downtime%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></td></tr>\n", (temp_hoststatus->scheduled_downtime_depth > 0) ? "ACTIVE" : "INACTIVE", (temp_hoststatus->scheduled_downtime_depth > 0) ? "YES" : "NO");
t = 0;
duration_error = FALSE;
if(temp_hoststatus->last_check > current_time)
duration_error = TRUE;
else
/*t=current_time-temp_hoststatus->last_check;*/
t = current_time - temp_hoststatus->last_update;
get_time_breakdown((unsigned long)t, &days, &hours, &minutes, &seconds);
if(duration_error == TRUE)
snprintf(status_age, sizeof(status_age) - 1, "???");
else if(temp_hoststatus->last_check == (time_t)0)
snprintf(status_age, sizeof(status_age) - 1, "N/A");
else
snprintf(status_age, sizeof(status_age) - 1, "%2dd %2dh %2dm %2ds", days, hours, minutes, seconds);
status_age[sizeof(status_age) - 1] = '\x0';
get_time_string(&temp_hoststatus->last_update, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Update:</td><td CLASS='dataVal'>%s&nbsp;&nbsp;(%s ago)</td></tr>\n", (temp_hoststatus->last_update == (time_t)0) ? "N/A" : date_time, status_age);
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<TR><TD CLASS='dataVar'>Active Checks:</TD><TD CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_hoststatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED", (temp_hoststatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED");
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Passive Checks:</TD><td CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_hoststatus->accept_passive_checks == TRUE) ? "ENABLED" : "DISABLED", (temp_hoststatus->accept_passive_checks) ? "ENABLED" : "DISABLED");
2017-05-19 22:22:40 +02:00
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Obsessing:</TD><td CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_hoststatus->obsess == TRUE) ? "ENABLED" : "DISABLED", (temp_hoststatus->obsess) ? "ENABLED" : "DISABLED");
2017-05-19 22:22:40 +02:00
printf("<TR><TD CLASS='dataVar'>Notifications:</td><td CLASS='dataVal'><DIV CLASS='notifications%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></td></tr>\n", (temp_hoststatus->notifications_enabled) ? "ENABLED" : "DISABLED", (temp_hoststatus->notifications_enabled) ? "ENABLED" : "DISABLED");
printf("<TR><TD CLASS='dataVar'>Event Handler:</td><td CLASS='dataVal'><DIV CLASS='eventhandlers%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></td></tr>\n", (temp_hoststatus->event_handler_enabled) ? "ENABLED" : "DISABLED", (temp_hoststatus->event_handler_enabled) ? "ENABLED" : "DISABLED");
printf("<TR><TD CLASS='dataVar'>Flap Detection:</td><td CLASS='dataVal'><DIV CLASS='flapdetection%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></td></tr>\n", (temp_hoststatus->flap_detection_enabled == TRUE) ? "ENABLED" : "DISABLED", (temp_hoststatus->flap_detection_enabled == TRUE) ? "ENABLED" : "DISABLED");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
}
printf("</TD>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP>\n");
printf("<TABLE BORDER=0 CELLPADDING=0 CELLSPACING=0><TR>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='commandPanel'>\n");
printf("<DIV CLASS='commandTitle'>Host Commands</DIV>\n");
printf("<TABLE BORDER='1' CELLPADDING=0 CELLSPACING=0><TR><TD>\n");
if(nagios_process_state == STATE_OK && is_authorized_for_read_only(&current_authdata) == FALSE) {
printf("<TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
#ifdef USE_STATUSMAP
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Locate Host On Map' TITLE='Locate Host On Map'></td><td CLASS='command'><a href='%s?host=%s'>Locate host on map</a></td></tr>\n", url_images_path, STATUSMAP_ICON, STATUSMAP_CGI, url_encode(host_name));
#endif
if(temp_hoststatus->checks_enabled == TRUE) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Active Checks Of This Host' TITLE='Disable Active Checks Of This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Disable active checks of this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_CHECK, url_encode(host_name));
}
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Active Checks Of This Host' TITLE='Enable Active Checks Of This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable active checks of this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_CHECK, url_encode(host_name));
printf("<tr CLASS='data'><td><img src='%s%s' border=0 ALT='Re-schedule Next Host Check' TITLE='Re-schedule Next Host Check'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s%s'>Re-schedule the next check of this host</a></td></tr>\n", url_images_path, DELAY_ICON, COMMAND_CGI, CMD_SCHEDULE_HOST_CHECK, url_encode(host_name), (temp_hoststatus->checks_enabled == TRUE) ? "&force_check" : "");
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->accept_passive_checks == TRUE) {
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Submit Passive Check Result For This Host' TITLE='Submit Passive Check Result For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Submit passive check result for this host</a></td></tr>\n", url_images_path, PASSIVE_ICON, COMMAND_CGI, CMD_PROCESS_HOST_CHECK_RESULT, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Stop Accepting Passive Checks For This Host' TITLE='Stop Accepting Passive Checks For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Stop accepting passive checks for this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_PASSIVE_HOST_CHECKS, url_encode(host_name));
}
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Start Accepting Passive Checks For This Host' TITLE='Start Accepting Passive Checks For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Start accepting passive checks for this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_PASSIVE_HOST_CHECKS, url_encode(host_name));
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->obsess == TRUE)
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Stop Obsessing Over This Host' TITLE='Stop Obsessing Over This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Stop obsessing over this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_OBSESSING_OVER_HOST, url_encode(host_name));
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Start Obsessing Over This Host' TITLE='Start Obsessing Over This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Start obsessing over this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_OBSESSING_OVER_HOST, url_encode(host_name));
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->status == SD_HOST_DOWN || temp_hoststatus->status == SD_HOST_UNREACHABLE) {
2017-05-19 22:22:40 +02:00
if(temp_hoststatus->problem_has_been_acknowledged == FALSE)
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Acknowledge This Host Problem' TITLE='Acknowledge This Host Problem'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Acknowledge this host problem</a></td></tr>\n", url_images_path, ACKNOWLEDGEMENT_ICON, COMMAND_CGI, CMD_ACKNOWLEDGE_HOST_PROBLEM, url_encode(host_name));
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Remove Problem Acknowledgement' TITLE='Remove Problem Acknowledgement'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Remove problem acknowledgement</a></td></tr>\n", url_images_path, REMOVE_ACKNOWLEDGEMENT_ICON, COMMAND_CGI, CMD_REMOVE_HOST_ACKNOWLEDGEMENT, url_encode(host_name));
}
if(temp_hoststatus->notifications_enabled == TRUE)
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For This Host' TITLE='Disable Notifications For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Disable notifications for this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_NOTIFICATIONS, url_encode(host_name));
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For This Host' TITLE='Enable Notifications For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable notifications for this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_NOTIFICATIONS, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Send Custom Notification' TITLE='Send Custom Notification'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Send custom host notification</a></td></tr>\n", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_SEND_CUSTOM_HOST_NOTIFICATION, url_encode(host_name));
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->status != SD_HOST_UP)
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Delay Next Host Notification' TITLE='Delay Next Host Notification'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Delay next host notification</a></td></tr>\n", url_images_path, DELAY_ICON, COMMAND_CGI, CMD_DELAY_HOST_NOTIFICATION, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For This Host' TITLE='Schedule Downtime For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Schedule downtime for this host</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_HOST_DOWNTIME, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For All Services On This Host' TITLE='Schedule Downtime For All Services On This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Schedule downtime for all services on this host</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_HOST_SVC_DOWNTIME, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For All Services On This Host' TITLE='Disable Notifications For All Services On This Host'></td><td CLASS='command' NOWRAP><a href='%s?cmd_typ=%d&host=%s'>Disable notifications for all services on this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_SVC_NOTIFICATIONS, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For All Services On This Host' TITLE='Enable Notifications For All Services On This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable notifications for all services on this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_SVC_NOTIFICATIONS, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule A Check Of All Services On This Host' TITLE='Schedule A Check Of All Services On This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Schedule a check of all services on this host</a></td></tr>\n", url_images_path, DELAY_ICON, COMMAND_CGI, CMD_SCHEDULE_HOST_SVC_CHECKS, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Checks Of All Services On This Host' TITLE='Disable Checks Of All Services On This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Disable checks of all services on this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_SVC_CHECKS, url_encode(host_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Checks Of All Services On This Host' TITLE='Enable Checks Of All Services On This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable checks of all services on this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_SVC_CHECKS, url_encode(host_name));
if(temp_hoststatus->event_handler_enabled == TRUE)
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Event Handler For This Host' TITLE='Disable Event Handler For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Disable event handler for this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_EVENT_HANDLER, url_encode(host_name));
else
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Event Handler For This Host' TITLE='Enable Event Handler For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable event handler for this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_EVENT_HANDLER, url_encode(host_name));
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->flap_detection_enabled == TRUE) {
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Flap Detection For This Host' TITLE='Disable Flap Detection For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Disable flap detection for this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOST_FLAP_DETECTION, url_encode(host_name));
2017-05-19 23:37:19 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Clear Flapping State For This Host' TITLE='Clear Flapping State For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Clear flapping state for this host</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_CLEAR_HOST_FLAPPING_STATE, url_encode(host_name));
} else
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Flap Detection For This Host' TITLE='Enable Flap Detection For This Host'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s'>Enable flap detection for this host</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOST_FLAP_DETECTION, url_encode(host_name));
printf("</TABLE>\n");
}
else if(is_authorized_for_read_only(&current_authdata) == TRUE) {
printf("<DIV ALIGN=CENTER CLASS='infoMessage'>Your account does not have permissions to execute commands.<br>\n");
}
else {
printf("<DIV ALIGN=CENTER CLASS='infoMessage'>It appears as though Nagios is not running, so commands are temporarily unavailable...<br>\n");
printf("Click <a href='%s?type=%d'>here</a> to view Nagios process information</DIV>\n", EXTINFO_CGI, DISPLAY_PROCESS_INFO);
}
printf("</TD></TR></TABLE>\n");
printf("</TD>\n");
printf("</TR>\n");
printf("</TABLE></TR>\n");
printf("<TR>\n");
printf("<TD COLSPAN=2 ALIGN=CENTER VALIGN=TOP CLASS='commentPanel'>\n");
2017-05-19 23:37:19 +02:00
/* display comments */
display_comments(HOST_COMMENT);
2017-05-19 22:22:40 +02:00
printf("</TD>\n");
printf("</TR>\n");
printf("</TABLE>\n");
printf("</DIV>\n");
return;
}
void show_service_info(void) {
service *temp_service;
char date_time[MAX_DATETIME_LENGTH];
char status_age[48];
char state_duration[48];
servicestatus *temp_svcstatus;
char state_string[MAX_INPUT_BUFFER];
2017-05-19 23:37:19 +02:00
const char *bg_class = "";
2017-05-19 22:22:40 +02:00
char *buf = NULL;
int days;
int hours;
int minutes;
int seconds;
time_t t;
time_t current_time;
int duration_error = FALSE;
/* find the service */
temp_service = find_service(host_name, service_desc);
/* make sure the user has rights to view service information */
if(is_authorized_for_service(temp_service, &current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view information for this service...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
/* get service status info */
temp_svcstatus = find_servicestatus(host_name, service_desc);
/* make sure service information exists */
if(temp_service == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Service Not Found!</DIV></P>");
return;
}
if(temp_svcstatus == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Service Status Not Found!</DIV></P>");
return;
}
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CELLPADDING=0 CELLSPACING=0 WIDTH=100%%>\n");
printf("<TR>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
printf("<DIV CLASS='dataTitle'>Service State Information</DIV>\n");
if(temp_svcstatus->has_been_checked == FALSE)
printf("<P><DIV ALIGN=CENTER>This service has not yet been checked, so status information is not available.</DIV></P>\n");
else {
printf("<TABLE BORDER=0>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
current_time = time(NULL);
t = 0;
duration_error = FALSE;
if(temp_svcstatus->last_state_change == (time_t)0) {
if(program_start > current_time)
duration_error = TRUE;
else
t = current_time - program_start;
}
else {
if(temp_svcstatus->last_state_change > current_time)
duration_error = TRUE;
else
t = current_time - temp_svcstatus->last_state_change;
}
get_time_breakdown((unsigned long)t, &days, &hours, &minutes, &seconds);
if(duration_error == TRUE)
snprintf(state_duration, sizeof(state_duration) - 1, "???");
else
snprintf(state_duration, sizeof(state_duration) - 1, "%2dd %2dh %2dm %2ds%s", days, hours, minutes, seconds, (temp_svcstatus->last_state_change == (time_t)0) ? "+" : "");
state_duration[sizeof(state_duration) - 1] = '\x0';
if(temp_svcstatus->status == SERVICE_OK) {
strcpy(state_string, "OK");
bg_class = "serviceOK";
}
else if(temp_svcstatus->status == SERVICE_WARNING) {
strcpy(state_string, "WARNING");
bg_class = "serviceWARNING";
}
else if(temp_svcstatus->status == SERVICE_CRITICAL) {
strcpy(state_string, "CRITICAL");
bg_class = "serviceCRITICAL";
}
else {
strcpy(state_string, "UNKNOWN");
bg_class = "serviceUNKNOWN";
}
printf("<TR><TD CLASS='dataVar'>Current Status:</TD><TD CLASS='dataVal'><DIV CLASS='%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV>&nbsp;(for %s)%s</TD></TR>\n", bg_class, state_string, state_duration, (temp_svcstatus->problem_has_been_acknowledged == TRUE) ? "&nbsp;&nbsp;(Has been acknowledged)" : "");
printf("<TR><TD CLASS='dataVar' VALIGN='top'>Status Information:</TD><TD CLASS='dataVal'>%s", (temp_svcstatus->plugin_output == NULL) ? "" : html_encode(temp_svcstatus->plugin_output, TRUE));
if(enable_splunk_integration == TRUE) {
printf("&nbsp;&nbsp;");
asprintf(&buf, "%s %s %s", temp_service->host_name, temp_service->description, temp_svcstatus->plugin_output);
display_splunk_generic_url(buf, 1);
free(buf);
}
if(temp_svcstatus->long_plugin_output != NULL)
printf("<BR>%s", html_encode(temp_svcstatus->long_plugin_output, TRUE));
printf("</TD></TR>\n");
printf("<TR><TD CLASS='dataVar' VALIGN='top'>Performance Data:</td><td CLASS='dataVal'>%s</td></tr>\n", (temp_svcstatus->perf_data == NULL) ? "" : html_encode(temp_svcstatus->perf_data, TRUE));
printf("<TR><TD CLASS='dataVar'>Current Attempt:</TD><TD CLASS='dataVal'>%d/%d", temp_svcstatus->current_attempt, temp_svcstatus->max_attempts);
printf("&nbsp;&nbsp;(%s state)</TD></TR>\n", (temp_svcstatus->state_type == HARD_STATE) ? "HARD" : "SOFT");
get_time_string(&temp_svcstatus->last_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Check Time:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", date_time);
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Check Type:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (temp_svcstatus->check_type == CHECK_TYPE_ACTIVE) ? "ACTIVE" : "PASSIVE");
2017-05-19 22:22:40 +02:00
printf("<TR><TD CLASS='dataVar' NOWRAP>Check Latency / Duration:</TD><TD CLASS='dataVal'>");
2017-05-19 23:37:19 +02:00
if(temp_svcstatus->check_type == CHECK_TYPE_ACTIVE)
2017-05-19 22:22:40 +02:00
printf("%.3f", temp_svcstatus->latency);
else
printf("N/A");
printf("&nbsp;/&nbsp;%.3f seconds", temp_svcstatus->execution_time);
printf("</TD></TR>\n");
get_time_string(&temp_svcstatus->next_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Next Scheduled Check:&nbsp;&nbsp;</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (temp_svcstatus->checks_enabled && temp_svcstatus->next_check != (time_t)0 && temp_svcstatus->should_be_scheduled == TRUE) ? date_time : "N/A");
get_time_string(&temp_svcstatus->last_state_change, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last State Change:</TD><TD CLASS='dataVal'>%s</TD></TR>\n", (temp_svcstatus->last_state_change == (time_t)0) ? "N/A" : date_time);
get_time_string(&temp_svcstatus->last_notification, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Notification:</TD><TD CLASS='dataVal'>%s&nbsp;(notification %d)</TD></TR>\n", (temp_svcstatus->last_notification == (time_t)0) ? "N/A" : date_time, temp_svcstatus->current_notification_number);
printf("<TR><TD CLASS='dataVar'>Is This Service Flapping?</TD><TD CLASS='dataVal'>");
if(temp_svcstatus->flap_detection_enabled == FALSE || enable_flap_detection == FALSE)
printf("N/A");
else
printf("<DIV CLASS='%sflapping'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV>&nbsp;(%3.2f%% state change)", (temp_svcstatus->is_flapping == TRUE) ? "" : "not", (temp_svcstatus->is_flapping == TRUE) ? "YES" : "NO", temp_svcstatus->percent_state_change);
printf("</TD></TR>\n");
printf("<TR><TD CLASS='dataVar'>In Scheduled Downtime?</TD><TD CLASS='dataVal'><DIV CLASS='downtime%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->scheduled_downtime_depth > 0) ? "ACTIVE" : "INACTIVE", (temp_svcstatus->scheduled_downtime_depth > 0) ? "YES" : "NO");
t = 0;
duration_error = FALSE;
if(temp_svcstatus->last_check > current_time)
duration_error = TRUE;
else
/*t=current_time-temp_svcstatus->last_check;*/
t = current_time - temp_svcstatus->last_update;
get_time_breakdown((unsigned long)t, &days, &hours, &minutes, &seconds);
if(duration_error == TRUE)
snprintf(status_age, sizeof(status_age) - 1, "???");
else if(temp_svcstatus->last_check == (time_t)0)
snprintf(status_age, sizeof(status_age) - 1, "N/A");
else
snprintf(status_age, sizeof(status_age) - 1, "%2dd %2dh %2dm %2ds", days, hours, minutes, seconds);
status_age[sizeof(status_age) - 1] = '\x0';
get_time_string(&temp_svcstatus->last_update, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TR><TD CLASS='dataVar'>Last Update:</TD><TD CLASS='dataVal'>%s&nbsp;&nbsp;(%s ago)</TD></TR>\n", (temp_svcstatus->last_update == (time_t)0) ? "N/A" : date_time, status_age);
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<TR><TD CLASS='dataVar'>Active Checks:</TD><td CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->checks_enabled) ? "ENABLED" : "DISABLED", (temp_svcstatus->checks_enabled) ? "ENABLED" : "DISABLED");
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Passive Checks:</TD><td CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->accept_passive_checks == TRUE) ? "ENABLED" : "DISABLED", (temp_svcstatus->accept_passive_checks) ? "ENABLED" : "DISABLED");
2017-05-19 22:22:40 +02:00
2017-05-19 23:37:19 +02:00
printf("<TR><TD CLASS='dataVar'>Obsessing:</TD><td CLASS='dataVal'><DIV CLASS='checks%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->obsess == TRUE) ? "ENABLED" : "DISABLED", (temp_svcstatus->obsess) ? "ENABLED" : "DISABLED");
2017-05-19 22:22:40 +02:00
printf("<TR><td CLASS='dataVar'>Notifications:</TD><td CLASS='dataVal'><DIV CLASS='notifications%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->notifications_enabled) ? "ENABLED" : "DISABLED", (temp_svcstatus->notifications_enabled) ? "ENABLED" : "DISABLED");
printf("<TR><TD CLASS='dataVar'>Event Handler:</TD><td CLASS='dataVal'><DIV CLASS='eventhandlers%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->event_handler_enabled) ? "ENABLED" : "DISABLED", (temp_svcstatus->event_handler_enabled) ? "ENABLED" : "DISABLED");
printf("<TR><TD CLASS='dataVar'>Flap Detection:</TD><td CLASS='dataVal'><DIV CLASS='flapdetection%s'>&nbsp;&nbsp;%s&nbsp;&nbsp;</DIV></TD></TR>\n", (temp_svcstatus->flap_detection_enabled == TRUE) ? "ENABLED" : "DISABLED", (temp_svcstatus->flap_detection_enabled == TRUE) ? "ENABLED" : "DISABLED");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
}
printf("</TD>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP>\n");
printf("<TABLE BORDER='0' CELLPADDING=0 CELLSPACING=0><TR>\n");
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='commandPanel'>\n");
printf("<DIV CLASS='dataTitle'>Service Commands</DIV>\n");
printf("<TABLE BORDER='1' CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD>\n");
if(nagios_process_state == STATE_OK && is_authorized_for_read_only(&current_authdata) == FALSE) {
printf("<TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
if(temp_svcstatus->checks_enabled) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Active Checks Of This Service' TITLE='Disable Active Checks Of This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SVC_CHECK, url_encode(host_name));
printf("&service=%s'>Disable active checks of this service</a></td></tr>\n", url_encode(service_desc));
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Active Checks Of This Service' TITLE='Enable Active Checks Of This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_SVC_CHECK, url_encode(host_name));
printf("&service=%s'>Enable active checks of this service</a></td></tr>\n", url_encode(service_desc));
}
printf("<tr CLASS='data'><td><img src='%s%s' border=0 ALT='Re-schedule Next Service Check' TITLE='Re-schedule Next Service Check'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DELAY_ICON, COMMAND_CGI, CMD_SCHEDULE_SVC_CHECK, url_encode(host_name));
printf("&service=%s%s'>Re-schedule the next check of this service</a></td></tr>\n", url_encode(service_desc), (temp_svcstatus->checks_enabled == TRUE) ? "&force_check" : "");
2017-05-19 23:37:19 +02:00
if(temp_svcstatus->accept_passive_checks == TRUE) {
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Submit Passive Check Result For This Service' TITLE='Submit Passive Check Result For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, PASSIVE_ICON, COMMAND_CGI, CMD_PROCESS_SERVICE_CHECK_RESULT, url_encode(host_name));
printf("&service=%s'>Submit passive check result for this service</a></td></tr>\n", url_encode(service_desc));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Stop Accepting Passive Checks For This Service' TITLE='Stop Accepting Passive Checks For This Service'></td><td CLASS='command' NOWRAP><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_PASSIVE_SVC_CHECKS, url_encode(host_name));
printf("&service=%s'>Stop accepting passive checks for this service</a></td></tr>\n", url_encode(service_desc));
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Start Accepting Passive Checks For This Service' TITLE='Start Accepting Passive Checks For This Service'></td><td CLASS='command' NOWRAP><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_PASSIVE_SVC_CHECKS, url_encode(host_name));
printf("&service=%s'>Start accepting passive checks for this service</a></td></tr>\n", url_encode(service_desc));
}
2017-05-19 23:37:19 +02:00
if(temp_svcstatus->obsess == TRUE) {
2017-05-19 22:22:40 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Stop Obsessing Over This Service' TITLE='Stop Obsessing Over This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_STOP_OBSESSING_OVER_SVC, url_encode(host_name));
printf("&service=%s'>Stop obsessing over this service</a></td></tr>\n", url_encode(service_desc));
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Start Obsessing Over This Service' TITLE='Start Obsessing Over This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_START_OBSESSING_OVER_SVC, url_encode(host_name));
printf("&service=%s'>Start obsessing over this service</a></td></tr>\n", url_encode(service_desc));
}
if((temp_svcstatus->status == SERVICE_WARNING || temp_svcstatus->status == SERVICE_UNKNOWN || temp_svcstatus->status == SERVICE_CRITICAL) && temp_svcstatus->state_type == HARD_STATE) {
if(temp_svcstatus->problem_has_been_acknowledged == FALSE) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Acknowledge This Service Problem' TITLE='Acknowledge This Service Problem'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ACKNOWLEDGEMENT_ICON, COMMAND_CGI, CMD_ACKNOWLEDGE_SVC_PROBLEM, url_encode(host_name));
printf("&service=%s'>Acknowledge this service problem</a></td></tr>\n", url_encode(service_desc));
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Remove Problem Acknowledgement' TITLE='Remove Problem Acknowledgement'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, REMOVE_ACKNOWLEDGEMENT_ICON, COMMAND_CGI, CMD_REMOVE_SVC_ACKNOWLEDGEMENT, url_encode(host_name));
printf("&service=%s'>Remove problem acknowledgement</a></td></tr>\n", url_encode(service_desc));
}
}
if(temp_svcstatus->notifications_enabled == TRUE) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For This Service' TITLE='Disable Notifications For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SVC_NOTIFICATIONS, url_encode(host_name));
printf("&service=%s'>Disable notifications for this service</a></td></tr>\n", url_encode(service_desc));
if(temp_svcstatus->status != SERVICE_OK) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Delay Next Service Notification' TITLE='Delay Next Service Notification'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DELAY_ICON, COMMAND_CGI, CMD_DELAY_SVC_NOTIFICATION, url_encode(host_name));
printf("&service=%s'>Delay next service notification</a></td></tr>\n", url_encode(service_desc));
}
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For This Service' TITLE='Enable Notifications For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_SVC_NOTIFICATIONS, url_encode(host_name));
printf("&service=%s'>Enable notifications for this service</a></td></tr>\n", url_encode(service_desc));
}
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Send Custom Notification' TITLE='Send Custom Notification'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_SEND_CUSTOM_SVC_NOTIFICATION, url_encode(host_name));
printf("&service=%s'>Send custom service notification</a></td></tr>\n", url_encode(service_desc));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For This Service' TITLE='Schedule Downtime For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_SVC_DOWNTIME, url_encode(host_name));
printf("&service=%s'>Schedule downtime for this service</a></td></tr>\n", url_encode(service_desc));
/*
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Cancel Scheduled Downtime For This Service' TITLE='Cancel Scheduled Downtime For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s",url_images_path,SCHEDULED_DOWNTIME_ICON,COMMAND_CGI,CMD_CANCEL_SVC_DOWNTIME,url_encode(host_name));
printf("&service=%s'>Cancel scheduled downtime for this service</a></td></tr>\n",url_encode(service_desc));
*/
if(temp_svcstatus->event_handler_enabled == TRUE) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Event Handler For This Service' TITLE='Disable Event Handler For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SVC_EVENT_HANDLER, url_encode(host_name));
printf("&service=%s'>Disable event handler for this service</a></td></tr>\n", url_encode(service_desc));
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Event Handler For This Service' TITLE='Enable Event Handler For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_SVC_EVENT_HANDLER, url_encode(host_name));
printf("&service=%s'>Enable event handler for this service</a></td></tr>\n", url_encode(service_desc));
}
if(temp_svcstatus->flap_detection_enabled == TRUE) {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Flap Detection For This Service' TITLE='Disable Flap Detection For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SVC_FLAP_DETECTION, url_encode(host_name));
printf("&service=%s'>Disable flap detection for this service</a></td></tr>\n", url_encode(service_desc));
2017-05-19 23:37:19 +02:00
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Clear Flapping State For This Service' TITLE='Clear Flapping State For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_CLEAR_SVC_FLAPPING_STATE, url_encode(host_name));
printf("&service=%s'>Clear flapping state for this service</a></td></tr>\n", url_encode(service_desc));
2017-05-19 22:22:40 +02:00
}
else {
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Flap Detection For This Service' TITLE='Enable Flap Detection For This Service'></td><td CLASS='command'><a href='%s?cmd_typ=%d&host=%s", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_SVC_FLAP_DETECTION, url_encode(host_name));
printf("&service=%s'>Enable flap detection for this service</a></td></tr>\n", url_encode(service_desc));
}
printf("</table>\n");
}
else if(is_authorized_for_read_only(&current_authdata) == TRUE) {
printf("<DIV ALIGN=CENTER CLASS='infoMessage'>Your account does not have permissions to execute commands.<br>\n");
}
else {
printf("<DIV CLASS='infoMessage'>It appears as though Nagios is not running, so commands are temporarily unavailable...<br>\n");
printf("Click <a href='%s?type=%d'>here</a> to view Nagios process information</DIV>\n", EXTINFO_CGI, DISPLAY_PROCESS_INFO);
}
printf("</td></tr>\n");
printf("</table>\n");
printf("</TD>\n");
printf("</TR></TABLE></TD>\n");
printf("</TR>\n");
printf("<TR><TD COLSPAN=2><BR></TD></TR>\n");
printf("<TR>\n");
printf("<TD COLSPAN=2 ALIGN=CENTER VALIGN=TOP CLASS='commentPanel'>\n");
2017-05-19 23:37:19 +02:00
/* display comments */
display_comments(SERVICE_COMMENT);
2017-05-19 22:22:40 +02:00
printf("</TD>\n");
printf("</TR>\n");
printf("</TABLE>\n");
printf("</DIV>\n");
return;
}
void show_hostgroup_info(void) {
hostgroup *temp_hostgroup;
/* get hostgroup info */
temp_hostgroup = find_hostgroup(hostgroup_name);
/* make sure the user has rights to view hostgroup information */
if(is_authorized_for_hostgroup(temp_hostgroup, &current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view information for this hostgroup...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
/* make sure hostgroup information exists */
if(temp_hostgroup == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Hostgroup Not Found!</DIV></P>");
return;
}
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 WIDTH=100%%>\n");
printf("<TR>\n");
/* top left panel */
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
/* right top panel */
printf("</TD><TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel' ROWSPAN=2>\n");
printf("<DIV CLASS='dataTitle'>Hostgroup Commands</DIV>\n");
if(nagios_process_state == STATE_OK && is_authorized_for_read_only(&current_authdata) == FALSE) {
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For All Hosts In This Hostgroup' TITLE='Schedule Downtime For All Hosts In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Schedule downtime for all hosts in this hostgroup</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_HOSTGROUP_HOST_DOWNTIME, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For All Services In This Hostgroup' TITLE='Schedule Downtime For All Services In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Schedule downtime for all services in this hostgroup</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_HOSTGROUP_SVC_DOWNTIME, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For All Hosts In This Hostgroup' TITLE='Enable Notifications For All Hosts In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Enable notifications for all hosts in this hostgroup</a></td></tr>\n", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_ENABLE_HOSTGROUP_HOST_NOTIFICATIONS, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For All Hosts In This Hostgroup' TITLE='Disable Notifications For All Hosts In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Disable notifications for all hosts in this hostgroup</a></td></tr>\n", url_images_path, NOTIFICATIONS_DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOSTGROUP_HOST_NOTIFICATIONS, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For All Services In This Hostgroup' TITLE='Enable Notifications For All Services In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Enable notifications for all services in this hostgroup</a></td></tr>\n", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_ENABLE_HOSTGROUP_SVC_NOTIFICATIONS, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For All Services In This Hostgroup' TITLE='Disable Notifications For All Services In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Disable notifications for all services in this hostgroup</a></td></tr>\n", url_images_path, NOTIFICATIONS_DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOSTGROUP_SVC_NOTIFICATIONS, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Active Checks Of All Services In This Hostgroup' TITLE='Enable Active Checks Of All Services In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Enable active checks of all services in this hostgroup</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_HOSTGROUP_SVC_CHECKS, url_encode(hostgroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Active Checks Of All Services In This Hostgroup' TITLE='Disable Active Checks Of All Services In This Hostgroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&hostgroup=%s'>Disable active checks of all services in this hostgroup</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_HOSTGROUP_SVC_CHECKS, url_encode(hostgroup_name));
printf("</table>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
}
else if(is_authorized_for_read_only(&current_authdata) == TRUE) {
printf("<DIV ALIGN=CENTER CLASS='infoMessage'>Your account does not have permissions to execute commands.<br>\n");
}
else {
printf("<DIV CLASS='infoMessage'>It appears as though Nagios is not running, so commands are temporarily unavailable...<br>\n");
printf("Click <a href='%s?type=%d'>here</a> to view Nagios process information</DIV>\n", EXTINFO_CGI, DISPLAY_PROCESS_INFO);
}
printf("</TD></TR>\n");
printf("<TR>\n");
/* left bottom panel */
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</DIV>\n");
printf("</div>\n");
printf("</TD>\n");
return;
}
void show_servicegroup_info() {
servicegroup *temp_servicegroup;
/* get servicegroup info */
temp_servicegroup = find_servicegroup(servicegroup_name);
/* make sure the user has rights to view servicegroup information */
if(is_authorized_for_servicegroup(temp_servicegroup, &current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view information for this servicegroup...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
/* make sure servicegroup information exists */
if(temp_servicegroup == NULL) {
printf("<P><DIV CLASS='errorMessage'>Error: Servicegroup Not Found!</DIV></P>");
return;
}
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 WIDTH=100%%>\n");
printf("<TR>\n");
/* top left panel */
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
/* right top panel */
printf("</TD><TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel' ROWSPAN=2>\n");
printf("<DIV CLASS='dataTitle'>Servicegroup Commands</DIV>\n");
if(nagios_process_state == STATE_OK) {
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
printf("<TR><TD>\n");
printf("<TABLE BORDER=0 CELLSPACING=0 CELLPADDING=0 CLASS='command'>\n");
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For All Hosts In This Servicegroup' TITLE='Schedule Downtime For All Hosts In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Schedule downtime for all hosts in this servicegroup</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_SERVICEGROUP_HOST_DOWNTIME, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Schedule Downtime For All Services In This Servicegroup' TITLE='Schedule Downtime For All Services In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Schedule downtime for all services in this servicegroup</a></td></tr>\n", url_images_path, DOWNTIME_ICON, COMMAND_CGI, CMD_SCHEDULE_SERVICEGROUP_SVC_DOWNTIME, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For All Hosts In This Servicegroup' TITLE='Enable Notifications For All Hosts In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Enable notifications for all hosts in this servicegroup</a></td></tr>\n", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_ENABLE_SERVICEGROUP_HOST_NOTIFICATIONS, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For All Hosts In This Servicegroup' TITLE='Disable Notifications For All Hosts In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Disable notifications for all hosts in this servicegroup</a></td></tr>\n", url_images_path, NOTIFICATIONS_DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SERVICEGROUP_HOST_NOTIFICATIONS, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Notifications For All Services In This Servicegroup' TITLE='Enable Notifications For All Services In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Enable notifications for all services in this servicegroup</a></td></tr>\n", url_images_path, NOTIFICATION_ICON, COMMAND_CGI, CMD_ENABLE_SERVICEGROUP_SVC_NOTIFICATIONS, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Notifications For All Services In This Servicegroup' TITLE='Disable Notifications For All Services In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Disable notifications for all services in this servicegroup</a></td></tr>\n", url_images_path, NOTIFICATIONS_DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SERVICEGROUP_SVC_NOTIFICATIONS, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Enable Active Checks Of All Services In This Servicegroup' TITLE='Enable Active Checks Of All Services In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Enable active checks of all services in this servicegroup</a></td></tr>\n", url_images_path, ENABLED_ICON, COMMAND_CGI, CMD_ENABLE_SERVICEGROUP_SVC_CHECKS, url_encode(servicegroup_name));
printf("<tr CLASS='command'><td><img src='%s%s' border=0 ALT='Disable Active Checks Of All Services In This Servicegroup' TITLE='Disable Active Checks Of All Services In This Servicegroup'></td><td CLASS='command'><a href='%s?cmd_typ=%d&servicegroup=%s'>Disable active checks of all services in this servicegroup</a></td></tr>\n", url_images_path, DISABLED_ICON, COMMAND_CGI, CMD_DISABLE_SERVICEGROUP_SVC_CHECKS, url_encode(servicegroup_name));
printf("</table>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
}
else {
printf("<DIV CLASS='infoMessage'>It appears as though Nagios is not running, so commands are temporarily unavailable...<br>\n");
printf("Click <a href='%s?type=%d'>here</a> to view Nagios process information</DIV>\n", EXTINFO_CGI, DISPLAY_PROCESS_INFO);
}
printf("</TD></TR>\n");
printf("<TR>\n");
/* left bottom panel */
printf("<TD ALIGN=CENTER VALIGN=TOP CLASS='stateInfoPanel'>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</DIV>\n");
printf("</div>\n");
printf("</TD>\n");
return;
}
/* shows all service and host comments */
void show_all_comments(void) {
int total_comments = 0;
2017-05-19 23:37:19 +02:00
const char *bg_class = "";
2017-05-19 22:22:40 +02:00
int odd = 0;
char date_time[MAX_DATETIME_LENGTH];
2017-05-19 23:37:19 +02:00
nagios_comment *temp_comment;
2017-05-19 22:22:40 +02:00
host *temp_host;
service *temp_service;
char *comment_type;
char expire_time[MAX_DATETIME_LENGTH];
printf("<BR />\n");
printf("<DIV CLASS='commentNav'>[&nbsp;<A HREF='#HOSTCOMMENTS' CLASS='commentNav'>Host Comments</A>&nbsp;|&nbsp;<A HREF='#SERVICECOMMENTS' CLASS='commentNav'>Service Comments</A>&nbsp;]</DIV>\n");
printf("<BR />\n");
printf("<A NAME=HOSTCOMMENTS></A>\n");
printf("<DIV CLASS='commentTitle'>Host Comments</DIV>\n");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE) {
printf("<div CLASS='comment'><img src='%s%s' border=0>&nbsp;", url_images_path, COMMENT_ICON);
printf("<a href='%s?cmd_typ=%d'>", COMMAND_CGI, CMD_ADD_HOST_COMMENT);
printf("Add a new host comment</a></div>\n");
}
2017-05-19 22:22:40 +02:00
printf("<BR />\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='comment'>\n");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<TR CLASS='comment'><TH CLASS='comment'>Host Name</TH><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH><TH CLASS='comment'>Actions</TH></TR>\n");
else
printf("<TR CLASS='comment'><TH CLASS='comment'>Host Name</TH><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH></TR>\n");
2017-05-19 22:22:40 +02:00
/* display all the host comments */
for(temp_comment = comment_list, total_comments = 0; temp_comment != NULL; temp_comment = temp_comment->next) {
if(temp_comment->comment_type != HOST_COMMENT)
continue;
temp_host = find_host(temp_comment->host_name);
/* make sure the user has rights to view host information */
if(is_authorized_for_host(temp_host, &current_authdata) == FALSE)
continue;
total_comments++;
if(odd) {
odd = 0;
bg_class = "commentOdd";
}
else {
odd = 1;
bg_class = "commentEven";
}
switch(temp_comment->entry_type) {
case USER_COMMENT:
comment_type = "User";
break;
case DOWNTIME_COMMENT:
comment_type = "Scheduled Downtime";
break;
case FLAPPING_COMMENT:
comment_type = "Flap Detection";
break;
case ACKNOWLEDGEMENT_COMMENT:
comment_type = "Acknowledgement";
break;
default:
comment_type = "?";
}
get_time_string(&temp_comment->entry_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
get_time_string(&temp_comment->expire_time, expire_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<tr CLASS='%s'>", bg_class);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s'>%s</A></td>", bg_class, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_comment->host_name), temp_comment->host_name);
printf("<td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%ld</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td>", bg_class, date_time, bg_class, temp_comment->author, bg_class, temp_comment->comment_data, bg_class, temp_comment->comment_id, bg_class, (temp_comment->persistent) ? "Yes" : "No", bg_class, comment_type, bg_class, (temp_comment->expires == TRUE) ? expire_time : "N/A");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<td><a href='%s?cmd_typ=%d&com_id=%lu'><img src='%s%s' border=0 ALT='Delete This Comment' TITLE='Delete This Comment'></td>", COMMAND_CGI, CMD_DEL_HOST_COMMENT, temp_comment->comment_id, url_images_path, DELETE_ICON);
2017-05-19 22:22:40 +02:00
printf("</tr>\n");
}
if(total_comments == 0)
printf("<TR CLASS='commentOdd'><TD CLASS='commentOdd' COLSPAN=9>There are no host comments</TD></TR>");
printf("</TABLE>\n");
printf("</DIV>\n");
printf("<BR /><BR /><BR />\n");
printf("<A NAME=SERVICECOMMENTS></A>\n");
printf("<DIV CLASS='commentTitle'>Service Comments</DIV>\n");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE){
printf("<div CLASS='comment'><img src='%s%s' border=0>&nbsp;", url_images_path, COMMENT_ICON);
printf("<a href='%s?cmd_typ=%d'>", COMMAND_CGI, CMD_ADD_SVC_COMMENT);
printf("Add a new service comment</a></div>\n");
}
2017-05-19 22:22:40 +02:00
printf("<BR />\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='comment'>\n");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<TR CLASS='comment'><TH CLASS='comment'>Host Name</TH><TH CLASS='comment'>Service</TH><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH><TH CLASS='comment'>Actions</TH></TR>\n");
else
printf("<TR CLASS='comment'><TH CLASS='comment'>Host Name</TH><TH CLASS='comment'>Service</TH><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH></TR>\n");
2017-05-19 22:22:40 +02:00
/* display all the service comments */
for(temp_comment = comment_list, total_comments = 0; temp_comment != NULL; temp_comment = temp_comment->next) {
if(temp_comment->comment_type != SERVICE_COMMENT)
continue;
temp_service = find_service(temp_comment->host_name, temp_comment->service_description);
/* make sure the user has rights to view service information */
if(is_authorized_for_service(temp_service, &current_authdata) == FALSE)
continue;
total_comments++;
if(odd) {
odd = 0;
bg_class = "commentOdd";
}
else {
odd = 1;
bg_class = "commentEven";
}
switch(temp_comment->entry_type) {
case USER_COMMENT:
comment_type = "User";
break;
case DOWNTIME_COMMENT:
comment_type = "Scheduled Downtime";
break;
case FLAPPING_COMMENT:
comment_type = "Flap Detection";
break;
case ACKNOWLEDGEMENT_COMMENT:
comment_type = "Acknowledgement";
break;
default:
comment_type = "?";
}
get_time_string(&temp_comment->entry_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
get_time_string(&temp_comment->expire_time, expire_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<tr CLASS='%s'>", bg_class);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s'>%s</A></td>", bg_class, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_comment->host_name), temp_comment->host_name);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s", bg_class, EXTINFO_CGI, DISPLAY_SERVICE_INFO, url_encode(temp_comment->host_name));
printf("&service=%s'>%s</A></td>", url_encode(temp_comment->service_description), temp_comment->service_description);
printf("<td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%ld</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td>", bg_class, date_time, bg_class, temp_comment->author, bg_class, temp_comment->comment_data, bg_class, temp_comment->comment_id, bg_class, (temp_comment->persistent) ? "Yes" : "No", bg_class, comment_type, bg_class, (temp_comment->expires == TRUE) ? expire_time : "N/A");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<td><a href='%s?cmd_typ=%d&com_id=%ld'><img src='%s%s' border=0 ALT='Delete This Comment' TITLE='Delete This Comment'></td>", COMMAND_CGI, CMD_DEL_SVC_COMMENT, temp_comment->comment_id, url_images_path, DELETE_ICON);
2017-05-19 22:22:40 +02:00
printf("</tr>\n");
}
if(total_comments == 0)
printf("<TR CLASS='commentOdd'><TD CLASS='commentOdd' COLSPAN=10>There are no service comments</TD></TR>");
printf("</TABLE>\n");
printf("</DIV>\n");
return;
}
void show_performance_data(void) {
service *temp_service = NULL;
servicestatus *temp_servicestatus = NULL;
host *temp_host = NULL;
hoststatus *temp_hoststatus = NULL;
int total_active_service_checks = 0;
int total_passive_service_checks = 0;
double min_service_execution_time = 0.0;
double max_service_execution_time = 0.0;
double total_service_execution_time = 0.0;
int have_min_service_execution_time = FALSE;
int have_max_service_execution_time = FALSE;
double min_service_latency = 0.0;
double max_service_latency = 0.0;
double long total_service_latency = 0.0;
int have_min_service_latency = FALSE;
int have_max_service_latency = FALSE;
double min_host_latency = 0.0;
double max_host_latency = 0.0;
double total_host_latency = 0.0;
int have_min_host_latency = FALSE;
int have_max_host_latency = FALSE;
double min_service_percent_change_a = 0.0;
double max_service_percent_change_a = 0.0;
double total_service_percent_change_a = 0.0;
int have_min_service_percent_change_a = FALSE;
int have_max_service_percent_change_a = FALSE;
double min_service_percent_change_b = 0.0;
double max_service_percent_change_b = 0.0;
double total_service_percent_change_b = 0.0;
int have_min_service_percent_change_b = FALSE;
int have_max_service_percent_change_b = FALSE;
int active_service_checks_1min = 0;
int active_service_checks_5min = 0;
int active_service_checks_15min = 0;
int active_service_checks_1hour = 0;
int active_service_checks_start = 0;
int active_service_checks_ever = 0;
int passive_service_checks_1min = 0;
int passive_service_checks_5min = 0;
int passive_service_checks_15min = 0;
int passive_service_checks_1hour = 0;
int passive_service_checks_start = 0;
int passive_service_checks_ever = 0;
int total_active_host_checks = 0;
int total_passive_host_checks = 0;
double min_host_execution_time = 0.0;
double max_host_execution_time = 0.0;
double total_host_execution_time = 0.0;
int have_min_host_execution_time = FALSE;
int have_max_host_execution_time = FALSE;
double min_host_percent_change_a = 0.0;
double max_host_percent_change_a = 0.0;
double total_host_percent_change_a = 0.0;
int have_min_host_percent_change_a = FALSE;
int have_max_host_percent_change_a = FALSE;
double min_host_percent_change_b = 0.0;
double max_host_percent_change_b = 0.0;
double total_host_percent_change_b = 0.0;
int have_min_host_percent_change_b = FALSE;
int have_max_host_percent_change_b = FALSE;
int active_host_checks_1min = 0;
int active_host_checks_5min = 0;
int active_host_checks_15min = 0;
int active_host_checks_1hour = 0;
int active_host_checks_start = 0;
int active_host_checks_ever = 0;
int passive_host_checks_1min = 0;
int passive_host_checks_5min = 0;
int passive_host_checks_15min = 0;
int passive_host_checks_1hour = 0;
int passive_host_checks_start = 0;
int passive_host_checks_ever = 0;
time_t current_time;
time(&current_time);
/* check all services */
for(temp_servicestatus = servicestatus_list; temp_servicestatus != NULL; temp_servicestatus = temp_servicestatus->next) {
/* find the service */
temp_service = find_service(temp_servicestatus->host_name, temp_servicestatus->description);
/* make sure the user has rights to view service information */
if(is_authorized_for_service(temp_service, &current_authdata) == FALSE)
continue;
/* is this an active or passive check? */
2017-05-19 23:37:19 +02:00
if(temp_servicestatus->check_type == CHECK_TYPE_ACTIVE) {
2017-05-19 22:22:40 +02:00
total_active_service_checks++;
total_service_execution_time += temp_servicestatus->execution_time;
if(have_min_service_execution_time == FALSE || temp_servicestatus->execution_time < min_service_execution_time) {
have_min_service_execution_time = TRUE;
min_service_execution_time = temp_servicestatus->execution_time;
}
if(have_max_service_execution_time == FALSE || temp_servicestatus->execution_time > max_service_execution_time) {
have_max_service_execution_time = TRUE;
max_service_execution_time = temp_servicestatus->execution_time;
}
total_service_percent_change_a += temp_servicestatus->percent_state_change;
if(have_min_service_percent_change_a == FALSE || temp_servicestatus->percent_state_change < min_service_percent_change_a) {
have_min_service_percent_change_a = TRUE;
min_service_percent_change_a = temp_servicestatus->percent_state_change;
}
if(have_max_service_percent_change_a == FALSE || temp_servicestatus->percent_state_change > max_service_percent_change_a) {
have_max_service_percent_change_a = TRUE;
max_service_percent_change_a = temp_servicestatus->percent_state_change;
}
total_service_latency += temp_servicestatus->latency;
if(have_min_service_latency == FALSE || temp_servicestatus->latency < min_service_latency) {
have_min_service_latency = TRUE;
min_service_latency = temp_servicestatus->latency;
}
if(have_max_service_latency == FALSE || temp_servicestatus->latency > max_service_latency) {
have_max_service_latency = TRUE;
max_service_latency = temp_servicestatus->latency;
}
if(temp_servicestatus->last_check >= (current_time - 60))
active_service_checks_1min++;
if(temp_servicestatus->last_check >= (current_time - 300))
active_service_checks_5min++;
if(temp_servicestatus->last_check >= (current_time - 900))
active_service_checks_15min++;
if(temp_servicestatus->last_check >= (current_time - 3600))
active_service_checks_1hour++;
if(temp_servicestatus->last_check >= program_start)
active_service_checks_start++;
if(temp_servicestatus->last_check != (time_t)0)
active_service_checks_ever++;
}
else {
total_passive_service_checks++;
total_service_percent_change_b += temp_servicestatus->percent_state_change;
if(have_min_service_percent_change_b == FALSE || temp_servicestatus->percent_state_change < min_service_percent_change_b) {
have_min_service_percent_change_b = TRUE;
min_service_percent_change_b = temp_servicestatus->percent_state_change;
}
if(have_max_service_percent_change_b == FALSE || temp_servicestatus->percent_state_change > max_service_percent_change_b) {
have_max_service_percent_change_b = TRUE;
max_service_percent_change_b = temp_servicestatus->percent_state_change;
}
if(temp_servicestatus->last_check >= (current_time - 60))
passive_service_checks_1min++;
if(temp_servicestatus->last_check >= (current_time - 300))
passive_service_checks_5min++;
if(temp_servicestatus->last_check >= (current_time - 900))
passive_service_checks_15min++;
if(temp_servicestatus->last_check >= (current_time - 3600))
passive_service_checks_1hour++;
if(temp_servicestatus->last_check >= program_start)
passive_service_checks_start++;
if(temp_servicestatus->last_check != (time_t)0)
passive_service_checks_ever++;
}
}
/* check all hosts */
for(temp_hoststatus = hoststatus_list; temp_hoststatus != NULL; temp_hoststatus = temp_hoststatus->next) {
/* find the host */
temp_host = find_host(temp_hoststatus->host_name);
/* make sure the user has rights to view host information */
if(is_authorized_for_host(temp_host, &current_authdata) == FALSE)
continue;
/* is this an active or passive check? */
2017-05-19 23:37:19 +02:00
if(temp_hoststatus->check_type == CHECK_TYPE_ACTIVE) {
2017-05-19 22:22:40 +02:00
total_active_host_checks++;
total_host_execution_time += temp_hoststatus->execution_time;
if(have_min_host_execution_time == FALSE || temp_hoststatus->execution_time < min_host_execution_time) {
have_min_host_execution_time = TRUE;
min_host_execution_time = temp_hoststatus->execution_time;
}
if(have_max_host_execution_time == FALSE || temp_hoststatus->execution_time > max_host_execution_time) {
have_max_host_execution_time = TRUE;
max_host_execution_time = temp_hoststatus->execution_time;
}
total_host_percent_change_a += temp_hoststatus->percent_state_change;
if(have_min_host_percent_change_a == FALSE || temp_hoststatus->percent_state_change < min_host_percent_change_a) {
have_min_host_percent_change_a = TRUE;
min_host_percent_change_a = temp_hoststatus->percent_state_change;
}
if(have_max_host_percent_change_a == FALSE || temp_hoststatus->percent_state_change > max_host_percent_change_a) {
have_max_host_percent_change_a = TRUE;
max_host_percent_change_a = temp_hoststatus->percent_state_change;
}
total_host_latency += temp_hoststatus->latency;
if(have_min_host_latency == FALSE || temp_hoststatus->latency < min_host_latency) {
have_min_host_latency = TRUE;
min_host_latency = temp_hoststatus->latency;
}
if(have_max_host_latency == FALSE || temp_hoststatus->latency > max_host_latency) {
have_max_host_latency = TRUE;
max_host_latency = temp_hoststatus->latency;
}
if(temp_hoststatus->last_check >= (current_time - 60))
active_host_checks_1min++;
if(temp_hoststatus->last_check >= (current_time - 300))
active_host_checks_5min++;
if(temp_hoststatus->last_check >= (current_time - 900))
active_host_checks_15min++;
if(temp_hoststatus->last_check >= (current_time - 3600))
active_host_checks_1hour++;
if(temp_hoststatus->last_check >= program_start)
active_host_checks_start++;
if(temp_hoststatus->last_check != (time_t)0)
active_host_checks_ever++;
}
else {
total_passive_host_checks++;
total_host_percent_change_b += temp_hoststatus->percent_state_change;
if(have_min_host_percent_change_b == FALSE || temp_hoststatus->percent_state_change < min_host_percent_change_b) {
have_min_host_percent_change_b = TRUE;
min_host_percent_change_b = temp_hoststatus->percent_state_change;
}
if(have_max_host_percent_change_b == FALSE || temp_hoststatus->percent_state_change > max_host_percent_change_b) {
have_max_host_percent_change_b = TRUE;
max_host_percent_change_b = temp_hoststatus->percent_state_change;
}
if(temp_hoststatus->last_check >= (current_time - 60))
passive_host_checks_1min++;
if(temp_hoststatus->last_check >= (current_time - 300))
passive_host_checks_5min++;
if(temp_hoststatus->last_check >= (current_time - 900))
passive_host_checks_15min++;
if(temp_hoststatus->last_check >= (current_time - 3600))
passive_host_checks_1hour++;
if(temp_hoststatus->last_check >= program_start)
passive_host_checks_start++;
if(temp_hoststatus->last_check != (time_t)0)
passive_host_checks_ever++;
}
}
printf("<div align=center>\n");
printf("<DIV CLASS='dataTitle'>Program-Wide Performance Information</DIV>\n");
printf("<table border='0' cellpadding='10'>\n");
/***** ACTIVE SERVICE CHECKS *****/
printf("<tr>\n");
printf("<td valign=middle><div class='perfTypeTitle'>Services Actively Checked:</div></td>\n");
printf("<td valign=top>\n");
/* fake this so we don't divide by zero for just showing the table */
if(total_active_service_checks == 0)
total_active_service_checks = 1;
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Time Frame</th><th class='data'>Services Checked</th></tr>\n");
printf("<tr><td class='dataVar'>&lt;= 1 minute:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_service_checks_1min, (double)(((double)active_service_checks_1min * 100.0) / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>&lt;= 5 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_service_checks_5min, (double)(((double)active_service_checks_5min * 100.0) / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>&lt;= 15 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_service_checks_15min, (double)(((double)active_service_checks_15min * 100.0) / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>&lt;= 1 hour:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_service_checks_1hour, (double)(((double)active_service_checks_1hour * 100.0) / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>Since program start:&nbsp;&nbsp;</td><td class='dataVal'>%d (%.1f%%)</td>", active_service_checks_start, (double)(((double)active_service_checks_start * 100.0) / (double)total_active_service_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td><td valign=top>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Metric</th><th class='data'>Min.</th><th class='data'>Max.</th><th class='data'>Average</th></tr>\n");
printf("<tr><td class='dataVar'>Check Execution Time:&nbsp;&nbsp;</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.3f sec</td></tr>\n", min_service_execution_time, max_service_execution_time, (double)((double)total_service_execution_time / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>Check Latency:</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.3f sec</td></tr>\n", min_service_latency, max_service_latency, (double)((double)total_service_latency / (double)total_active_service_checks));
printf("<tr><td class='dataVar'>Percent State Change:</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td></tr>\n", min_service_percent_change_a, max_service_percent_change_a, (double)((double)total_service_percent_change_a / (double)total_active_service_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
/***** PASSIVE SERVICE CHECKS *****/
printf("<tr>\n");
printf("<td valign=middle><div class='perfTypeTitle'>Services Passively Checked:</div></td>\n");
printf("<td valign=top>\n");
/* fake this so we don't divide by zero for just showing the table */
if(total_passive_service_checks == 0)
total_passive_service_checks = 1;
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Time Frame</th><th class='data'>Services Checked</th></tr>\n");
printf("<tr><td class='dataVar'>&lt;= 1 minute:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_service_checks_1min, (double)(((double)passive_service_checks_1min * 100.0) / (double)total_passive_service_checks));
printf("<tr><td class='dataVar'>&lt;= 5 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_service_checks_5min, (double)(((double)passive_service_checks_5min * 100.0) / (double)total_passive_service_checks));
printf("<tr><td class='dataVar'>&lt;= 15 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_service_checks_15min, (double)(((double)passive_service_checks_15min * 100.0) / (double)total_passive_service_checks));
printf("<tr><td class='dataVar'>&lt;= 1 hour:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_service_checks_1hour, (double)(((double)passive_service_checks_1hour * 100.0) / (double)total_passive_service_checks));
printf("<tr><td class='dataVar'>Since program start:&nbsp;&nbsp;</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_service_checks_start, (double)(((double)passive_service_checks_start * 100.0) / (double)total_passive_service_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td><td valign=top>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Metric</th><th class='data'>Min.</th><th class='data'>Max.</th><th class='data'>Average</th></tr>\n");
printf("<tr><td class='dataVar'>Percent State Change:&nbsp;&nbsp;</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td></tr>\n", min_service_percent_change_b, max_service_percent_change_b, (double)((double)total_service_percent_change_b / (double)total_passive_service_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
/***** ACTIVE HOST CHECKS *****/
printf("<tr>\n");
printf("<td valign=middle><div class='perfTypeTitle'>Hosts Actively Checked:</div></td>\n");
printf("<td valign=top>\n");
/* fake this so we don't divide by zero for just showing the table */
if(total_active_host_checks == 0)
total_active_host_checks = 1;
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Time Frame</th><th class='data'>Hosts Checked</th></tr>\n");
printf("<tr><td class='dataVar'>&lt;= 1 minute:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_host_checks_1min, (double)(((double)active_host_checks_1min * 100.0) / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>&lt;= 5 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_host_checks_5min, (double)(((double)active_host_checks_5min * 100.0) / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>&lt;= 15 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_host_checks_15min, (double)(((double)active_host_checks_15min * 100.0) / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>&lt;= 1 hour:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", active_host_checks_1hour, (double)(((double)active_host_checks_1hour * 100.0) / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>Since program start:&nbsp;&nbsp;</td><td class='dataVal'>%d (%.1f%%)</td>", active_host_checks_start, (double)(((double)active_host_checks_start * 100.0) / (double)total_active_host_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td><td valign=top>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Metric</th><th class='data'>Min.</th><th class='data'>Max.</th><th class='data'>Average</th></tr>\n");
printf("<tr><td class='dataVar'>Check Execution Time:&nbsp;&nbsp;</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.3f sec</td></tr>\n", min_host_execution_time, max_host_execution_time, (double)((double)total_host_execution_time / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>Check Latency:</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.2f sec</td><td class='dataVal'>%.3f sec</td></tr>\n", min_host_latency, max_host_latency, (double)((double)total_host_latency / (double)total_active_host_checks));
printf("<tr><td class='dataVar'>Percent State Change:</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td></tr>\n", min_host_percent_change_a, max_host_percent_change_a, (double)((double)total_host_percent_change_a / (double)total_active_host_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
/***** PASSIVE HOST CHECKS *****/
printf("<tr>\n");
printf("<td valign=middle><div class='perfTypeTitle'>Hosts Passively Checked:</div></td>\n");
printf("<td valign=top>\n");
/* fake this so we don't divide by zero for just showing the table */
if(total_passive_host_checks == 0)
total_passive_host_checks = 1;
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Time Frame</th><th class='data'>Hosts Checked</th></tr>\n");
printf("<tr><td class='dataVar'>&lt;= 1 minute:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_host_checks_1min, (double)(((double)passive_host_checks_1min * 100.0) / (double)total_passive_host_checks));
printf("<tr><td class='dataVar'>&lt;= 5 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_host_checks_5min, (double)(((double)passive_host_checks_5min * 100.0) / (double)total_passive_host_checks));
printf("<tr><td class='dataVar'>&lt;= 15 minutes:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_host_checks_15min, (double)(((double)passive_host_checks_15min * 100.0) / (double)total_passive_host_checks));
printf("<tr><td class='dataVar'>&lt;= 1 hour:</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_host_checks_1hour, (double)(((double)passive_host_checks_1hour * 100.0) / (double)total_passive_host_checks));
printf("<tr><td class='dataVar'>Since program start:&nbsp;&nbsp;</td><td class='dataVal'>%d (%.1f%%)</td></tr>", passive_host_checks_start, (double)(((double)passive_host_checks_start * 100.0) / (double)total_passive_host_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td><td valign=top>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable2'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Metric</th><th class='data'>Min.</th><th class='data'>Max.</th><th class='data'>Average</th></tr>\n");
printf("<tr><td class='dataVar'>Percent State Change:&nbsp;&nbsp;</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td><td class='dataVal'>%.2f%%</td></tr>\n", min_host_percent_change_b, max_host_percent_change_b, (double)((double)total_host_percent_change_b / (double)total_passive_host_checks));
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
/***** CHECK STATS *****/
printf("<tr>\n");
printf("<td valign=center><div class='perfTypeTitle'>Check Statistics:</div></td>\n");
printf("<td valign=top colspan='2'>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Type</th><th class='data'>Last 1 Min</th><th class='data'>Last 5 Min</th><th class='data'>Last 15 Min</th></tr>\n");
printf("<tr><td class='dataVar'>Active Scheduled Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_SCHEDULED_HOST_CHECK_STATS][0], program_stats[ACTIVE_SCHEDULED_HOST_CHECK_STATS][1], program_stats[ACTIVE_SCHEDULED_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Active On-Demand Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_ONDEMAND_HOST_CHECK_STATS][0], program_stats[ACTIVE_ONDEMAND_HOST_CHECK_STATS][1], program_stats[ACTIVE_ONDEMAND_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Parallel Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[PARALLEL_HOST_CHECK_STATS][0], program_stats[PARALLEL_HOST_CHECK_STATS][1], program_stats[PARALLEL_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Serial Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[SERIAL_HOST_CHECK_STATS][0], program_stats[SERIAL_HOST_CHECK_STATS][1], program_stats[SERIAL_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Cached Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_CACHED_HOST_CHECK_STATS][0], program_stats[ACTIVE_CACHED_HOST_CHECK_STATS][1], program_stats[ACTIVE_CACHED_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Passive Host Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[PASSIVE_HOST_CHECK_STATS][0], program_stats[PASSIVE_HOST_CHECK_STATS][1], program_stats[PASSIVE_HOST_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Active Scheduled Service Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_SCHEDULED_SERVICE_CHECK_STATS][0], program_stats[ACTIVE_SCHEDULED_SERVICE_CHECK_STATS][1], program_stats[ACTIVE_SCHEDULED_SERVICE_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Active On-Demand Service Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_ONDEMAND_SERVICE_CHECK_STATS][0], program_stats[ACTIVE_ONDEMAND_SERVICE_CHECK_STATS][1], program_stats[ACTIVE_ONDEMAND_SERVICE_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Cached Service Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[ACTIVE_CACHED_SERVICE_CHECK_STATS][0], program_stats[ACTIVE_CACHED_SERVICE_CHECK_STATS][1], program_stats[ACTIVE_CACHED_SERVICE_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>Passive Service Checks</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[PASSIVE_SERVICE_CHECK_STATS][0], program_stats[PASSIVE_SERVICE_CHECK_STATS][1], program_stats[PASSIVE_SERVICE_CHECK_STATS][2]);
printf("<tr><td class='dataVar'>External Commands</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", program_stats[EXTERNAL_COMMAND_STATS][0], program_stats[EXTERNAL_COMMAND_STATS][1], program_stats[EXTERNAL_COMMAND_STATS][2]);
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
/***** BUFFER STATS *****/
printf("<tr>\n");
printf("<td valign=center><div class='perfTypeTitle'>Buffer Usage:</div></td>\n");
printf("<td valign=top colspan='2'>\n");
printf("<TABLE BORDER=1 CELLSPACING=0 CELLPADDING=0>\n");
printf("<TR><TD class='stateInfoTable1'>\n");
printf("<TABLE BORDER=0>\n");
printf("<tr class='data'><th class='data'>Type</th><th class='data'>In Use</th><th class='data'>Max Used</th><th class='data'>Total Available</th></tr>\n");
printf("<tr><td class='dataVar'>External Commands&nbsp;</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td><td class='dataVal'>%d</td></tr>", buffer_stats[0][1], buffer_stats[0][2], buffer_stats[0][0]);
printf("</TABLE>\n");
printf("</TD></TR>\n");
printf("</TABLE>\n");
printf("</td>\n");
printf("</tr>\n");
printf("</table>\n");
printf("</div>\n");
return;
}
void display_comments(int type) {
host *temp_host = NULL;
service *temp_service = NULL;
int total_comments = 0;
int display_comment = FALSE;
2017-05-19 23:37:19 +02:00
const char *bg_class = "";
2017-05-19 22:22:40 +02:00
int odd = 1;
char date_time[MAX_DATETIME_LENGTH];
2017-05-19 23:37:19 +02:00
nagios_comment *temp_comment;
scheduled_downtime *temp_downtime;
2017-05-19 22:22:40 +02:00
char *comment_type;
char expire_time[MAX_DATETIME_LENGTH];
/* find the host or service */
if(type == HOST_COMMENT) {
temp_host = find_host(host_name);
if(temp_host == NULL)
return;
}
else {
temp_service = find_service(host_name, service_desc);
if(temp_service == NULL)
return;
}
printf("<A NAME=comments></A>\n");
printf("<DIV CLASS='commentTitle'>%s Comments</DIV>\n", (type == HOST_COMMENT) ? "Host" : "Service");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE){
printf("<TABLE BORDER=0>\n");
2017-05-19 22:22:40 +02:00
2017-05-19 23:37:19 +02:00
printf("<tr>\n");
printf("<td valign=middle><img src='%s%s' border=0 align=center></td><td CLASS='comment'>", url_images_path, COMMENT_ICON);
if(type == HOST_COMMENT)
printf("<a href='%s?cmd_typ=%d&host=%s' CLASS='comment'>", COMMAND_CGI, CMD_ADD_HOST_COMMENT, url_encode(host_name));
else {
printf("<a href='%s?cmd_typ=%d&host=%s&", COMMAND_CGI, CMD_ADD_SVC_COMMENT, url_encode(host_name));
printf("service=%s' CLASS='comment'>", url_encode(service_desc));
}
printf("Add a new comment</a></td>\n");
2017-05-19 22:22:40 +02:00
2017-05-19 23:37:19 +02:00
printf("<td valign=middle><img src='%s%s' border=0 align=center></td><td CLASS='comment'>", url_images_path, DELETE_ICON);
if(type == HOST_COMMENT)
printf("<a href='%s?cmd_typ=%d&host=%s' CLASS='comment'>", COMMAND_CGI, CMD_DEL_ALL_HOST_COMMENTS, url_encode(host_name));
else {
printf("<a href='%s?cmd_typ=%d&host=%s&", COMMAND_CGI, CMD_DEL_ALL_SVC_COMMENTS, url_encode(host_name));
printf("service=%s' CLASS='comment'>", url_encode(service_desc));
}
printf("Delete all comments</a></td>\n");
printf("</tr>\n");
printf("</TABLE>\n");
}
2017-05-19 22:22:40 +02:00
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='comment'>\n");
2017-05-19 23:37:19 +02:00
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<TR CLASS='comment'><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH><TH CLASS='comment'>Actions</TH></TR>\n");
else
printf("<TR CLASS='comment'><TH CLASS='comment'>Entry Time</TH><TH CLASS='comment'>Author</TH><TH CLASS='comment'>Comment</TH><TH CLASS='comment'>Comment ID</TH><TH CLASS='comment'>Persistent</TH><TH CLASS='comment'>Type</TH><TH CLASS='comment'>Expires</TH></TR>\n");
2017-05-19 22:22:40 +02:00
/* check all the comments to see if they apply to this host or service */
/* Comments are displayed in the order they are read from the status.dat file */
for(temp_comment = get_first_comment_by_host(host_name); temp_comment != NULL; temp_comment = get_next_comment_by_host(host_name, temp_comment)) {
display_comment = FALSE;
if(type == HOST_COMMENT && temp_comment->comment_type == HOST_COMMENT)
display_comment = TRUE;
else if(type == SERVICE_COMMENT && temp_comment->comment_type == SERVICE_COMMENT && !strcmp(temp_comment->service_description, service_desc))
display_comment = TRUE;
if(display_comment == TRUE) {
if(odd) {
odd = 0;
bg_class = "commentOdd";
}
else {
odd = 1;
bg_class = "commentEven";
}
switch(temp_comment->entry_type) {
case USER_COMMENT:
comment_type = "User";
break;
case DOWNTIME_COMMENT:
comment_type = "Scheduled Downtime";
break;
case FLAPPING_COMMENT:
comment_type = "Flap Detection";
break;
case ACKNOWLEDGEMENT_COMMENT:
comment_type = "Acknowledgement";
break;
default:
comment_type = "?";
}
2017-05-19 23:37:19 +02:00
if (temp_comment->entry_type == DOWNTIME_COMMENT) {
for(temp_downtime = scheduled_downtime_list; temp_downtime != NULL; temp_downtime = temp_downtime->next) {
if (temp_downtime->comment_id == temp_comment->comment_id)
break;
}
}
else
temp_downtime = NULL;
2017-05-19 22:22:40 +02:00
get_time_string(&temp_comment->entry_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
get_time_string(&temp_comment->expire_time, expire_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<tr CLASS='%s'>", bg_class);
2017-05-19 23:37:19 +02:00
printf("<td CLASS='%s'>%s</td><td CLASS='%s'>%s</td>", bg_class, date_time, bg_class, temp_comment->author);
printf("<td CLASS='%s'>%s", bg_class, temp_comment->comment_data);
if (temp_downtime)
printf("<hr>%s", temp_downtime->comment);
printf("</td><td CLASS='%s'>%lu</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td><td CLASS='%s'>%s</td>",
bg_class, temp_comment->comment_id, bg_class, (temp_comment->persistent) ? "Yes" : "No",
bg_class, comment_type, bg_class, (temp_comment->expires == TRUE) ? expire_time : "N/A");
if(is_authorized_for_read_only(&current_authdata)==FALSE)
printf("<td><a href='%s?cmd_typ=%d&com_id=%lu'><img src='%s%s' border=0 ALT='Delete This Comment' TITLE='Delete This Comment'></td>", COMMAND_CGI, (type == HOST_COMMENT) ? CMD_DEL_HOST_COMMENT : CMD_DEL_SVC_COMMENT, temp_comment->comment_id, url_images_path, DELETE_ICON);
2017-05-19 22:22:40 +02:00
printf("</tr>\n");
total_comments++;
2017-05-19 23:37:19 +02:00
2017-05-19 22:22:40 +02:00
}
}
/* see if this host or service has any comments associated with it */
if(total_comments == 0)
printf("<TR CLASS='commentOdd'><TD CLASS='commentOdd' COLSPAN='%d'>This %s has no comments associated with it</TD></TR>", (type == HOST_COMMENT) ? 9 : 10, (type == HOST_COMMENT) ? "host" : "service");
printf("</TABLE></DIV>\n");
return;
}
/* shows all service and host scheduled downtime */
void show_all_downtime(void) {
int total_downtime = 0;
2017-05-19 23:37:19 +02:00
const char *bg_class = "";
2017-05-19 22:22:40 +02:00
int odd = 0;
char date_time[MAX_DATETIME_LENGTH];
scheduled_downtime *temp_downtime;
host *temp_host;
service *temp_service;
int days;
int hours;
int minutes;
int seconds;
printf("<BR />\n");
printf("<DIV CLASS='downtimeNav'>[&nbsp;<A HREF='#HOSTDOWNTIME' CLASS='downtimeNav'>Host Downtime</A>&nbsp;|&nbsp;<A HREF='#SERVICEDOWNTIME' CLASS='downtimeNav'>Service Downtime</A>&nbsp;]</DIV>\n");
printf("<BR />\n");
printf("<A NAME=HOSTDOWNTIME></A>\n");
printf("<DIV CLASS='downtimeTitle'>Scheduled Host Downtime</DIV>\n");
printf("<div CLASS='comment'><img src='%s%s' border=0>&nbsp;", url_images_path, DOWNTIME_ICON);
printf("<a href='%s?cmd_typ=%d'>", COMMAND_CGI, CMD_SCHEDULE_HOST_DOWNTIME);
printf("Schedule host downtime</a></div>\n");
printf("<BR />\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='downtime'>\n");
printf("<TR CLASS='downtime'><TH CLASS='downtime'>Host Name</TH><TH CLASS='downtime'>Entry Time</TH><TH CLASS='downtime'>Author</TH><TH CLASS='downtime'>Comment</TH><TH CLASS='downtime'>Start Time</TH><TH CLASS='downtime'>End Time</TH><TH CLASS='downtime'>Type</TH><TH CLASS='downtime'>Duration</TH><TH CLASS='downtime'>Downtime ID</TH><TH CLASS='downtime'>Trigger ID</TH><TH CLASS='downtime'>Actions</TH></TR>\n");
/* display all the host downtime */
for(temp_downtime = scheduled_downtime_list, total_downtime = 0; temp_downtime != NULL; temp_downtime = temp_downtime->next) {
if(temp_downtime->type != HOST_DOWNTIME)
continue;
temp_host = find_host(temp_downtime->host_name);
/* make sure the user has rights to view host information */
if(is_authorized_for_host(temp_host, &current_authdata) == FALSE)
continue;
total_downtime++;
if(odd) {
odd = 0;
bg_class = "downtimeOdd";
}
else {
odd = 1;
bg_class = "downtimeEven";
}
printf("<tr CLASS='%s'>", bg_class);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s'>%s</A></td>", bg_class, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_downtime->host_name), temp_downtime->host_name);
get_time_string(&temp_downtime->entry_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->author == NULL) ? "N/A" : temp_downtime->author);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->comment == NULL) ? "N/A" : temp_downtime->comment);
get_time_string(&temp_downtime->start_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
get_time_string(&temp_downtime->end_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->fixed == TRUE) ? "Fixed" : "Flexible");
get_time_breakdown(temp_downtime->duration, &days, &hours, &minutes, &seconds);
printf("<td CLASS='%s'>%dd %dh %dm %ds</td>", bg_class, days, hours, minutes, seconds);
printf("<td CLASS='%s'>%lu</td>", bg_class, temp_downtime->downtime_id);
printf("<td CLASS='%s'>", bg_class);
if(temp_downtime->triggered_by == 0)
printf("N/A");
else
printf("%lu", temp_downtime->triggered_by);
printf("</td>\n");
printf("<td><a href='%s?cmd_typ=%d&down_id=%lu'><img src='%s%s' border=0 ALT='Delete/Cancel This Scheduled Downtime Entry' TITLE='Delete/Cancel This Scheduled Downtime Entry'></td>", COMMAND_CGI, CMD_DEL_HOST_DOWNTIME, temp_downtime->downtime_id, url_images_path, DELETE_ICON);
printf("</tr>\n");
}
if(total_downtime == 0)
printf("<TR CLASS='downtimeOdd'><TD CLASS='downtimeOdd' COLSPAN=11>There are no hosts with scheduled downtime</TD></TR>");
printf("</TABLE>\n");
printf("</DIV>\n");
printf("<BR /><BR /><BR />\n");
printf("<A NAME=SERVICEDOWNTIME></A>\n");
printf("<DIV CLASS='downtimeTitle'>Scheduled Service Downtime</DIV>\n");
printf("<div CLASS='comment'><img src='%s%s' border=0>&nbsp;", url_images_path, DOWNTIME_ICON);
printf("<a href='%s?cmd_typ=%d'>", COMMAND_CGI, CMD_SCHEDULE_SVC_DOWNTIME);
printf("Schedule service downtime</a></div>\n");
printf("<BR />\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='downtime'>\n");
printf("<TR CLASS='downtime'><TH CLASS='downtime'>Host Name</TH><TH CLASS='downtime'>Service</TH><TH CLASS='downtime'>Entry Time</TH><TH CLASS='downtime'>Author</TH><TH CLASS='downtime'>Comment</TH><TH CLASS='downtime'>Start Time</TH><TH CLASS='downtime'>End Time</TH><TH CLASS='downtime'>Type</TH><TH CLASS='downtime'>Duration</TH><TH CLASS='downtime'>Downtime ID</TH><TH CLASS='downtime'>Trigger ID</TH><TH CLASS='downtime'>Actions</TH></TR>\n");
/* display all the service downtime */
for(temp_downtime = scheduled_downtime_list, total_downtime = 0; temp_downtime != NULL; temp_downtime = temp_downtime->next) {
if(temp_downtime->type != SERVICE_DOWNTIME)
continue;
temp_service = find_service(temp_downtime->host_name, temp_downtime->service_description);
/* make sure the user has rights to view service information */
if(is_authorized_for_service(temp_service, &current_authdata) == FALSE)
continue;
total_downtime++;
if(odd) {
odd = 0;
bg_class = "downtimeOdd";
}
else {
odd = 1;
bg_class = "downtimeEven";
}
printf("<tr CLASS='%s'>", bg_class);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s'>%s</A></td>", bg_class, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_downtime->host_name), temp_downtime->host_name);
printf("<td CLASS='%s'><A HREF='%s?type=%d&host=%s", bg_class, EXTINFO_CGI, DISPLAY_SERVICE_INFO, url_encode(temp_downtime->host_name));
printf("&service=%s'>%s</A></td>", url_encode(temp_downtime->service_description), temp_downtime->service_description);
get_time_string(&temp_downtime->entry_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->author == NULL) ? "N/A" : temp_downtime->author);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->comment == NULL) ? "N/A" : temp_downtime->comment);
get_time_string(&temp_downtime->start_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
get_time_string(&temp_downtime->end_time, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<td CLASS='%s'>%s</td>", bg_class, date_time);
printf("<td CLASS='%s'>%s</td>", bg_class, (temp_downtime->fixed == TRUE) ? "Fixed" : "Flexible");
get_time_breakdown(temp_downtime->duration, &days, &hours, &minutes, &seconds);
printf("<td CLASS='%s'>%dd %dh %dm %ds</td>", bg_class, days, hours, minutes, seconds);
printf("<td CLASS='%s'>%lu</td>", bg_class, temp_downtime->downtime_id);
printf("<td CLASS='%s'>", bg_class);
if(temp_downtime->triggered_by == 0)
printf("N/A");
else
printf("%lu", temp_downtime->triggered_by);
printf("</td>\n");
printf("<td><a href='%s?cmd_typ=%d&down_id=%lu'><img src='%s%s' border=0 ALT='Delete/Cancel This Scheduled Downtime Entry' TITLE='Delete/Cancel This Scheduled Downtime Entry'></td>", COMMAND_CGI, CMD_DEL_SVC_DOWNTIME, temp_downtime->downtime_id, url_images_path, DELETE_ICON);
printf("</tr>\n");
}
if(total_downtime == 0)
printf("<TR CLASS='downtimeOdd'><TD CLASS='downtimeOdd' COLSPAN=12>There are no services with scheduled downtime</TD></TR>");
printf("</TABLE>\n");
printf("</DIV>\n");
return;
}
/* shows check scheduling queue */
void show_scheduling_queue(void) {
sortdata *temp_sortdata;
servicestatus *temp_svcstatus = NULL;
hoststatus *temp_hststatus = NULL;
char date_time[MAX_DATETIME_LENGTH];
char temp_url[MAX_INPUT_BUFFER];
int odd = 0;
2017-05-19 23:37:19 +02:00
const char *bgclass = "";
2017-05-19 22:22:40 +02:00
/* make sure the user has rights to view system information */
if(is_authorized_for_system_information(&current_authdata) == FALSE) {
printf("<P><DIV CLASS='errorMessage'>It appears as though you do not have permission to view process information...</DIV></P>\n");
printf("<P><DIV CLASS='errorDescription'>If you believe this is an error, check the HTTP server authentication requirements for accessing this CGI<br>");
printf("and check the authorization options in your CGI configuration file.</DIV></P>\n");
return;
}
/* sort hosts and services */
sort_data(sort_type, sort_option);
printf("<DIV ALIGN=CENTER CLASS='statusSort'>Entries sorted by <b>");
if(sort_option == SORT_HOSTNAME)
printf("host name");
else if(sort_option == SORT_SERVICENAME)
printf("service name");
else if(sort_option == SORT_SERVICESTATUS)
printf("service status");
else if(sort_option == SORT_LASTCHECKTIME)
printf("last check time");
else if(sort_option == SORT_NEXTCHECKTIME)
printf("next check time");
printf("</b> (%s)\n", (sort_type == SORT_ASCENDING) ? "ascending" : "descending");
printf("</DIV>\n");
printf("<P>\n");
printf("<DIV ALIGN=CENTER>\n");
printf("<TABLE BORDER=0 CLASS='queue'>\n");
printf("<TR CLASS='queue'>");
snprintf(temp_url, sizeof(temp_url) - 1, "%s?type=%d", EXTINFO_CGI, DISPLAY_SCHEDULING_QUEUE);
temp_url[sizeof(temp_url) - 1] = '\x0';
printf("<TH CLASS='queue'>Host&nbsp;<A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by host name (ascending)' TITLE='Sort by host name (ascending)'></A><A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by host name (descending)' TITLE='Sort by host name (descending)'></A></TH>", temp_url, SORT_ASCENDING, SORT_HOSTNAME, url_images_path, UP_ARROW_ICON, temp_url, SORT_DESCENDING, SORT_HOSTNAME, url_images_path, DOWN_ARROW_ICON);
printf("<TH CLASS='queue'>Service&nbsp;<A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by service name (ascending)' TITLE='Sort by service name (ascending)'></A><A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by service name (descending)' TITLE='Sort by service name (descending)'></A></TH>", temp_url, SORT_ASCENDING, SORT_SERVICENAME, url_images_path, UP_ARROW_ICON, temp_url, SORT_DESCENDING, SORT_SERVICENAME, url_images_path, DOWN_ARROW_ICON);
printf("<TH CLASS='queue'>Last Check&nbsp;<A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by last check time (ascending)' TITLE='Sort by last check time (ascending)'></A><A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by last check time (descending)' TITLE='Sort by last check time (descending)'></A></TH>", temp_url, SORT_ASCENDING, SORT_LASTCHECKTIME, url_images_path, UP_ARROW_ICON, temp_url, SORT_DESCENDING, SORT_LASTCHECKTIME, url_images_path, DOWN_ARROW_ICON);
printf("<TH CLASS='queue'>Next Check&nbsp;<A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by next check time (ascending)' TITLE='Sort by next check time (ascending)'></A><A HREF='%s&sorttype=%d&sortoption=%d'><IMG SRC='%s%s' BORDER=0 ALT='Sort by next check time (descending)' TITLE='Sort by next check time (descending)'></A></TH>", temp_url, SORT_ASCENDING, SORT_NEXTCHECKTIME, url_images_path, UP_ARROW_ICON, temp_url, SORT_DESCENDING, SORT_NEXTCHECKTIME, url_images_path, DOWN_ARROW_ICON);
printf("<TH CLASS='queue'>Type</TH><TH CLASS='queue'>Active Checks</TH><TH CLASS='queue'>Actions</TH></TR>\n");
/* display all services and hosts */
for(temp_sortdata = sortdata_list; temp_sortdata != NULL; temp_sortdata = temp_sortdata->next) {
/* skip hosts and services that shouldn't be scheduled */
if(temp_sortdata->is_service == TRUE) {
temp_svcstatus = temp_sortdata->svcstatus;
if(temp_svcstatus->should_be_scheduled == FALSE) {
/* passive-only checks should appear if they're being forced */
if(!(temp_svcstatus->checks_enabled == FALSE && temp_svcstatus->next_check != (time_t)0L && (temp_svcstatus->check_options & CHECK_OPTION_FORCE_EXECUTION)))
continue;
}
}
else {
temp_hststatus = temp_sortdata->hststatus;
if(temp_hststatus->should_be_scheduled == FALSE) {
/* passive-only checks should appear if they're being forced */
if(!(temp_hststatus->checks_enabled == FALSE && temp_hststatus->next_check != (time_t)0L && (temp_hststatus->check_options & CHECK_OPTION_FORCE_EXECUTION)))
continue;
}
}
if(odd) {
odd = 0;
bgclass = "Even";
}
else {
odd = 1;
bgclass = "Odd";
}
printf("<TR CLASS='queue%s'>", bgclass);
/* get the service status */
if(temp_sortdata->is_service == TRUE) {
printf("<TD CLASS='queue%s'><A HREF='%s?type=%d&host=%s'>%s</A></TD>", bgclass, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_svcstatus->host_name), temp_svcstatus->host_name);
printf("<TD CLASS='queue%s'><A HREF='%s?type=%d&host=%s", bgclass, EXTINFO_CGI, DISPLAY_SERVICE_INFO, url_encode(temp_svcstatus->host_name));
printf("&service=%s'>%s</A></TD>", url_encode(temp_svcstatus->description), temp_svcstatus->description);
get_time_string(&temp_svcstatus->last_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TD CLASS='queue%s'>%s</TD>", bgclass, (temp_svcstatus->last_check == (time_t)0) ? "N/A" : date_time);
get_time_string(&temp_svcstatus->next_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TD CLASS='queue%s'>%s</TD>", bgclass, (temp_svcstatus->next_check == (time_t)0) ? "N/A" : date_time);
printf("<TD CLASS='queue%s'>", bgclass);
if(temp_svcstatus->check_options == CHECK_OPTION_NONE)
printf("Normal ");
else {
if(temp_svcstatus->check_options & CHECK_OPTION_FORCE_EXECUTION)
printf("Forced ");
if(temp_svcstatus->check_options & CHECK_OPTION_FRESHNESS_CHECK)
printf("Freshness ");
if(temp_svcstatus->check_options & CHECK_OPTION_ORPHAN_CHECK)
printf("Orphan ");
}
printf("</TD>");
printf("<TD CLASS='queue%s'>%s</TD>", (temp_svcstatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED", (temp_svcstatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED");
printf("<TD CLASS='queue%s'>", bgclass);
if(temp_svcstatus->checks_enabled == TRUE) {
printf("<a href='%s?cmd_typ=%d&host=%s", COMMAND_CGI, CMD_DISABLE_SVC_CHECK, url_encode(temp_svcstatus->host_name));
printf("&service=%s'><img src='%s%s' border=0 ALT='Disable Active Checks Of This Service' TITLE='Disable Active Checks Of This Service'></a>\n", url_encode(temp_svcstatus->description), url_images_path, DISABLED_ICON);
}
else {
printf("<a href='%s?cmd_typ=%d&host=%s", COMMAND_CGI, CMD_ENABLE_SVC_CHECK, url_encode(temp_svcstatus->host_name));
printf("&service=%s'><img src='%s%s' border=0 ALT='Enable Active Checks Of This Service' TITLE='Enable Active Checks Of This Service'></a>\n", url_encode(temp_svcstatus->description), url_images_path, ENABLED_ICON);
}
printf("<a href='%s?cmd_typ=%d&host=%s", COMMAND_CGI, CMD_SCHEDULE_SVC_CHECK, url_encode(temp_svcstatus->host_name));
printf("&service=%s%s'><img src='%s%s' border=0 ALT='Re-schedule This Service Check' TITLE='Re-schedule This Service Check'></a>\n", url_encode(temp_svcstatus->description), (temp_svcstatus->checks_enabled == TRUE) ? "&force_check" : "", url_images_path, DELAY_ICON);
printf("</TD>\n");
}
/* get the host status */
else {
printf("<TD CLASS='queue%s'><A HREF='%s?type=%d&host=%s'>%s</A></TD>", bgclass, EXTINFO_CGI, DISPLAY_HOST_INFO, url_encode(temp_hststatus->host_name), temp_hststatus->host_name);
printf("<TD CLASS='queue%s'>&nbsp;</TD>", bgclass);
get_time_string(&temp_hststatus->last_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TD CLASS='queue%s'>%s</TD>", bgclass, (temp_hststatus->last_check == (time_t)0) ? "N/A" : date_time);
get_time_string(&temp_hststatus->next_check, date_time, (int)sizeof(date_time), SHORT_DATE_TIME);
printf("<TD CLASS='queue%s'>%s</TD>", bgclass, (temp_hststatus->next_check == (time_t)0) ? "N/A" : date_time);
printf("<TD CLASS='queue%s'>", bgclass);
if(temp_hststatus->check_options == CHECK_OPTION_NONE)
printf("Normal ");
else {
if(temp_hststatus->check_options & CHECK_OPTION_FORCE_EXECUTION)
printf("Forced ");
if(temp_hststatus->check_options & CHECK_OPTION_FRESHNESS_CHECK)
printf("Freshness ");
if(temp_hststatus->check_options & CHECK_OPTION_ORPHAN_CHECK)
printf("Orphan ");
}
printf("</TD>");
printf("<TD CLASS='queue%s'>%s</TD>", (temp_hststatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED", (temp_hststatus->checks_enabled == TRUE) ? "ENABLED" : "DISABLED");
printf("<TD CLASS='queue%s'>", bgclass);
if(temp_hststatus->checks_enabled == TRUE) {
printf("<a href='%s?cmd_typ=%d&host=%s", COMMAND_CGI, CMD_DISABLE_HOST_CHECK, url_encode(temp_hststatus->host_name));
printf("'><img src='%s%s' border=0 ALT='Disable Active Checks Of This Host' TITLE='Disable Active Checks Of This Host'></a>\n", url_images_path, DISABLED_ICON);
}
else {
printf("<a href='%s?cmd_typ=%d&host=%s", COMMAND_CGI, CMD_ENABLE_HOST_CHECK, url_encode(temp_hststatus->host_name));
printf("'><img src='%s%s' border=0 ALT='Enable Active Checks Of This Host' TITLE='Enable Active Checks Of This Host'></a>\n", url_images_path, ENABLED_ICON);
}
printf("<a href='%s?cmd_typ=%d&host=%s%s", COMMAND_CGI, CMD_SCHEDULE_HOST_CHECK, url_encode(temp_hststatus->host_name), (temp_hststatus->checks_enabled == TRUE) ? "&force_check" : "");
printf("'><img src='%s%s' border=0 ALT='Re-schedule This Host Check' TITLE='Re-schedule This Host Check'></a>\n", url_images_path, DELAY_ICON);
printf("</TD>\n");
}
printf("</TR>\n");
}
printf("</TABLE>\n");
printf("</DIV>\n");
printf("</P>\n");
/* free memory allocated to sorted data list */
free_sortdata_list();
return;
}
/* sorts host and service data */
int sort_data(int s_type, int s_option) {
sortdata *new_sortdata;
sortdata *last_sortdata;
sortdata *temp_sortdata;
servicestatus *temp_svcstatus;
hoststatus *temp_hststatus;
if(s_type == SORT_NONE)
return ERROR;
/* sort all service status entries */
for(temp_svcstatus = servicestatus_list; temp_svcstatus != NULL; temp_svcstatus = temp_svcstatus->next) {
/* allocate memory for a new sort structure */
new_sortdata = (sortdata *)malloc(sizeof(sortdata));
if(new_sortdata == NULL)
return ERROR;
new_sortdata->is_service = TRUE;
new_sortdata->svcstatus = temp_svcstatus;
new_sortdata->hststatus = NULL;
last_sortdata = sortdata_list;
for(temp_sortdata = sortdata_list; temp_sortdata != NULL; temp_sortdata = temp_sortdata->next) {
if(compare_sortdata_entries(s_type, s_option, new_sortdata, temp_sortdata) == TRUE) {
new_sortdata->next = temp_sortdata;
if(temp_sortdata == sortdata_list)
sortdata_list = new_sortdata;
else
last_sortdata->next = new_sortdata;
break;
}
else
last_sortdata = temp_sortdata;
}
if(sortdata_list == NULL) {
new_sortdata->next = NULL;
sortdata_list = new_sortdata;
}
else if(temp_sortdata == NULL) {
new_sortdata->next = NULL;
last_sortdata->next = new_sortdata;
}
}
/* sort all host status entries */
for(temp_hststatus = hoststatus_list; temp_hststatus != NULL; temp_hststatus = temp_hststatus->next) {
/* allocate memory for a new sort structure */
new_sortdata = (sortdata *)malloc(sizeof(sortdata));
if(new_sortdata == NULL)
return ERROR;
new_sortdata->is_service = FALSE;
new_sortdata->svcstatus = NULL;
new_sortdata->hststatus = temp_hststatus;
last_sortdata = sortdata_list;
for(temp_sortdata = sortdata_list; temp_sortdata != NULL; temp_sortdata = temp_sortdata->next) {
if(compare_sortdata_entries(s_type, s_option, new_sortdata, temp_sortdata) == TRUE) {
new_sortdata->next = temp_sortdata;
if(temp_sortdata == sortdata_list)
sortdata_list = new_sortdata;
else
last_sortdata->next = new_sortdata;
break;
}
else
last_sortdata = temp_sortdata;
}
if(sortdata_list == NULL) {
new_sortdata->next = NULL;
sortdata_list = new_sortdata;
}
else if(temp_sortdata == NULL) {
new_sortdata->next = NULL;
last_sortdata->next = new_sortdata;
}
}
return OK;
}
int compare_sortdata_entries(int s_type, int s_option, sortdata *new_sortdata, sortdata *temp_sortdata) {
hoststatus *temp_hststatus = NULL;
servicestatus *temp_svcstatus = NULL;
time_t last_check[2];
time_t next_check[2];
int current_attempt[2];
int status[2];
2017-05-19 23:37:19 +02:00
char *hname[2];
2017-05-19 22:22:40 +02:00
char *service_description[2];
if(new_sortdata->is_service == TRUE) {
temp_svcstatus = new_sortdata->svcstatus;
last_check[0] = temp_svcstatus->last_check;
next_check[0] = temp_svcstatus->next_check;
status[0] = temp_svcstatus->status;
2017-05-19 23:37:19 +02:00
hname[0] = temp_svcstatus->host_name;
2017-05-19 22:22:40 +02:00
service_description[0] = temp_svcstatus->description;
current_attempt[0] = temp_svcstatus->current_attempt;
}
else {
temp_hststatus = new_sortdata->hststatus;
last_check[0] = temp_hststatus->last_check;
next_check[0] = temp_hststatus->next_check;
status[0] = temp_hststatus->status;
2017-05-19 23:37:19 +02:00
hname[0] = temp_hststatus->host_name;
2017-05-19 22:22:40 +02:00
service_description[0] = "";
current_attempt[0] = temp_hststatus->current_attempt;
}
if(temp_sortdata->is_service == TRUE) {
temp_svcstatus = temp_sortdata->svcstatus;
last_check[1] = temp_svcstatus->last_check;
next_check[1] = temp_svcstatus->next_check;
status[1] = temp_svcstatus->status;
2017-05-19 23:37:19 +02:00
hname[1] = temp_svcstatus->host_name;
2017-05-19 22:22:40 +02:00
service_description[1] = temp_svcstatus->description;
current_attempt[1] = temp_svcstatus->current_attempt;
}
else {
temp_hststatus = temp_sortdata->hststatus;
last_check[1] = temp_hststatus->last_check;
next_check[1] = temp_hststatus->next_check;
status[1] = temp_hststatus->status;
2017-05-19 23:37:19 +02:00
hname[1] = temp_hststatus->host_name;
2017-05-19 22:22:40 +02:00
service_description[1] = "";
current_attempt[1] = temp_hststatus->current_attempt;
}
if(s_type == SORT_ASCENDING) {
if(s_option == SORT_LASTCHECKTIME) {
if(last_check[0] <= last_check[1])
return TRUE;
else
return FALSE;
}
if(s_option == SORT_NEXTCHECKTIME) {
if(next_check[0] <= next_check[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_CURRENTATTEMPT) {
if(current_attempt[0] <= current_attempt[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_SERVICESTATUS) {
if(status[0] <= status[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_HOSTNAME) {
2017-05-19 23:37:19 +02:00
if(strcasecmp(hname[0], hname[1]) < 0)
2017-05-19 22:22:40 +02:00
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_SERVICENAME) {
if(strcasecmp(service_description[0], service_description[1]) < 0)
return TRUE;
else
return FALSE;
}
}
else {
if(s_option == SORT_LASTCHECKTIME) {
if(last_check[0] > last_check[1])
return TRUE;
else
return FALSE;
}
if(s_option == SORT_NEXTCHECKTIME) {
if(next_check[0] > next_check[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_CURRENTATTEMPT) {
if(current_attempt[0] > current_attempt[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_SERVICESTATUS) {
if(status[0] > status[1])
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_HOSTNAME) {
2017-05-19 23:37:19 +02:00
if(strcasecmp(hname[0], hname[1]) > 0)
2017-05-19 22:22:40 +02:00
return TRUE;
else
return FALSE;
}
else if(s_option == SORT_SERVICENAME) {
if(strcasecmp(service_description[0], service_description[1]) > 0)
return TRUE;
else
return FALSE;
}
}
return TRUE;
}
/* free all memory allocated to the sortdata structures */
void free_sortdata_list(void) {
sortdata *this_sortdata;
sortdata *next_sortdata;
/* free memory for the sortdata list */
for(this_sortdata = sortdata_list; this_sortdata != NULL; this_sortdata = next_sortdata) {
next_sortdata = this_sortdata->next;
free(this_sortdata);
}
return;
}