/* * update_info.c - Part of AFD, an automatic file distribution program. * Copyright (c) 1996 - 2015 Deutscher Wetterdienst (DWD), * Holger Kiehl * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. */ #include "afddefs.h" DESCR__S_M3 /* ** NAME ** update_info - updates any information that changes for module ** afd_info ** ** SYNOPSIS ** void update_info(Widget w) ** ** DESCRIPTION ** ** RETURN VALUES ** None. ** ** AUTHOR ** H.Kiehl ** ** HISTORY ** 14.11.1996 H.Kiehl Created ** 06.10.1997 H.Kiehl Take real hostname when displaying the IP number. ** 15.08.2004 H.Kiehl Added HTTP and SSL support. ** */ DESCR__E_M3 #include #include /* strerror() */ #include /* strftime(), localtime() */ #include #include #include #include "mafd_ctrl.h" #include "afd_info.h" /* External global variables. */ extern int host_position; extern char host_name[], host_alias_1[], host_alias_2[], *info_data, label_l[NO_OF_FSA_ROWS][40], label_r[NO_OF_FSA_ROWS][40], protocol_label_str[]; extern Display *display; extern XtIntervalId interval_id_host; extern XtAppContext app; extern Widget info_w, protocol_label, text_wl[], text_wr[], label_l_widget[], label_r_widget[], pll_widget, /* Pixmap label left. */ plr_widget; /* Pixmap label right. */ extern struct filetransfer_status *fsa; extern struct prev_values prev; extern Pixmap active_pixmap, passive_pixmap; /*############################ update_info() ############################*/ void update_info(Widget w) { static int interval = 0; int status; signed char flush = NO; char *ptr, str_line[MAX_INFO_STRING_LENGTH], tmp_str_line[MAX_INFO_STRING_LENGTH]; XmString text; /* Check if FSA changed. */ (void)check_fsa(YES, AFD_INFO); status = fsa[host_position].host_status & HOST_ERROR_OFFLINE_STATIC; if (prev.errors_offline != status) { if (status == HOST_ERROR_OFFLINE_STATIC) { XtSetSensitive(label_l_widget[4], False); XtSetSensitive(text_wl[4], False); } else { XtSetSensitive(label_l_widget[4], True); XtSetSensitive(text_wl[4], True); } prev.errors_offline = status; } if (prev.protocol != fsa[host_position].protocol) { size_t length; prev.protocol = fsa[host_position].protocol; length = sprintf(protocol_label_str, "Protocols : "); if (fsa[host_position].protocol & FTP_FLAG) { length += sprintf(&protocol_label_str[length], "FTP "); } if (fsa[host_position].protocol & SFTP_FLAG) { length += sprintf(&protocol_label_str[length], "SFTP "); } if (fsa[host_position].protocol & LOC_FLAG) { length += sprintf(&protocol_label_str[length], "LOC "); } if (fsa[host_position].protocol & EXEC_FLAG) { length += sprintf(&protocol_label_str[length], "EXEC "); } if (fsa[host_position].protocol & SMTP_FLAG) { length += sprintf(&protocol_label_str[length], "SMTP "); } if (fsa[host_position].protocol & HTTP_FLAG) { length += sprintf(&protocol_label_str[length], "HTTP "); } #ifdef _WITH_SCP_SUPPORT if (fsa[host_position].protocol & SCP_FLAG) { length += sprintf(&protocol_label_str[length], "SCP "); } #endif #ifdef _WITH_WMO_SUPPORT if (fsa[host_position].protocol & WMO_FLAG) { length += sprintf(&protocol_label_str[length], "WMO "); } #endif #ifdef _WITH_MAP_SUPPORT if (fsa[host_position].protocol & MAP_FLAG) { length += sprintf(&protocol_label_str[length], "MAP "); } #endif #ifdef WITH_SSL if (fsa[host_position].protocol & SSL_FLAG) { length += sprintf(&protocol_label_str[length], "SSL "); } #endif text = XmStringCreateLocalized(protocol_label_str); XtVaSetValues(protocol_label, XmNlabelString, text, NULL); XmStringFree(text); } if (strcmp(prev.real_hostname[0], fsa[host_position].real_hostname[0]) != 0) { (void)strcpy(prev.real_hostname[0], fsa[host_position].real_hostname[0]); (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, prev.real_hostname[0]); XmTextSetString(text_wl[1], str_line); flush = YES; } if (strcmp(prev.real_hostname[1], fsa[host_position].real_hostname[1]) != 0) { (void)strcpy(prev.real_hostname[1], fsa[host_position].real_hostname[1]); (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, prev.real_hostname[1]); XmTextSetString(text_wr[1], str_line); flush = YES; } if (prev.retry_interval != fsa[host_position].retry_interval) { prev.retry_interval = fsa[host_position].retry_interval; (void)sprintf(str_line, "%*d", AFD_INFO_STR_LENGTH, prev.retry_interval / 60); XmTextSetString(text_wr[4], str_line); flush = YES; } if (prev.files_send != fsa[host_position].file_counter_done) { prev.files_send = fsa[host_position].file_counter_done; (void)sprintf(str_line, "%*u", AFD_INFO_STR_LENGTH, prev.files_send); XmTextSetString(text_wl[2], str_line); flush = YES; } if (prev.bytes_send != fsa[host_position].bytes_send) { prev.bytes_send = fsa[host_position].bytes_send; #if SIZEOF_OFF_T == 4 (void)sprintf(str_line, "%*lu", AFD_INFO_STR_LENGTH, prev.bytes_send); #else (void)sprintf(str_line, "%*llu", AFD_INFO_STR_LENGTH, prev.bytes_send); #endif XmTextSetString(text_wr[2], str_line); flush = YES; } if (prev.total_errors != fsa[host_position].total_errors) { prev.total_errors = fsa[host_position].total_errors; (void)sprintf(str_line, "%*u", AFD_INFO_STR_LENGTH, prev.total_errors); XmTextSetString(text_wl[4], str_line); flush = YES; } if (prev.no_of_connections != fsa[host_position].connections) { prev.no_of_connections = fsa[host_position].connections; (void)sprintf(str_line, "%*u", AFD_INFO_STR_LENGTH, prev.no_of_connections); XmTextSetString(text_wr[3], str_line); flush = YES; } if (prev.last_connection != fsa[host_position].last_connection) { prev.last_connection = fsa[host_position].last_connection; (void)strftime(tmp_str_line, MAX_INFO_STRING_LENGTH, "%d.%m.%Y %H:%M:%S", localtime(&prev.last_connection)); (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, tmp_str_line); XmTextSetString(text_wl[3], str_line); flush = YES; } if (prev.toggle_pos != fsa[host_position].toggle_pos) { prev.toggle_pos = fsa[host_position].toggle_pos; if (prev.toggle_pos == 0) { /* * There is NO secondary host */ /* Display the first host name. */ (void)strcpy(host_alias_1, host_name); if ((fsa[host_position].host_toggle_str[0] != '\0') && (active_pixmap != XmUNSPECIFIED_PIXMAP) && (passive_pixmap != XmUNSPECIFIED_PIXMAP)) { (void)sprintf(label_l[0], "%*c%-*s :", 3, ' ', (FSA_INFO_TEXT_WIDTH_L - 3), host_alias_1); XtVaSetValues(pll_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, active_pixmap, NULL); } else { (void)sprintf(label_l[0], "%-*s :", FSA_INFO_TEXT_WIDTH_L, host_alias_1); } text = XmStringCreateLocalized(label_l[0]); XtVaSetValues(label_l_widget[0], XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelString, text, NULL); XmStringFree(text); /* Get IP for the first host. */ if ((fsa[host_position].protocol & FTP_FLAG) || (fsa[host_position].protocol & SFTP_FLAG) || #ifdef _WITH_SCP_SUPPORT (fsa[host_position].protocol & SCP_FLAG) || #endif #ifdef _WITH_WMO_SUPPORT (fsa[host_position].protocol & WMO_FLAG) || #endif #ifdef _WITH_MAP_SUPPORT (fsa[host_position].protocol & MAP_FLAG) || #endif (fsa[host_position].protocol & HTTP_FLAG) || (fsa[host_position].protocol & SMTP_FLAG)) { get_ip_no(fsa[host_position].real_hostname[0], tmp_str_line); } else { *tmp_str_line = '\0'; } (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, tmp_str_line); XmTextSetString(text_wl[0], str_line); /* Display the second host name. */ (void)strcpy(host_alias_2, NO_SECODARY_HOST); (void)sprintf(label_r[0], "%-*s :", FSA_INFO_TEXT_WIDTH_R, host_alias_2); XmTextSetString(text_wr[0], NULL); } else { /* * There IS a secondary host */ /* Display the first host name. */ (void)strcpy(host_alias_1, host_name); ptr = host_alias_1 + strlen(host_alias_1); *ptr = fsa[host_position].host_toggle_str[1]; *(ptr + 1) = '\0'; if ((fsa[host_position].host_toggle_str[0] != '\0') && (active_pixmap != XmUNSPECIFIED_PIXMAP) && (passive_pixmap != XmUNSPECIFIED_PIXMAP)) { (void)sprintf(label_l[0], "%*c%-*s :", 3, ' ', (FSA_INFO_TEXT_WIDTH_L - 3), host_alias_1); if (fsa[host_position].host_toggle == HOST_ONE) { XtVaSetValues(pll_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, active_pixmap, NULL); } else { XtVaSetValues(pll_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, passive_pixmap, NULL); } } else { (void)sprintf(label_l[0], "%-*s :", FSA_INFO_TEXT_WIDTH_L, host_alias_1); } text = XmStringCreateLocalized(label_l[0]); XtVaSetValues(label_l_widget[0], XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelString, text, NULL); XmStringFree(text); /* Get IP for the first host. */ if ((fsa[host_position].protocol & FTP_FLAG) || (fsa[host_position].protocol & SFTP_FLAG) || #ifdef _WITH_SCP_SUPPORT (fsa[host_position].protocol & SCP_FLAG) || #endif #ifdef _WITH_WMO_SUPPORT (fsa[host_position].protocol & WMO_FLAG) || #endif #ifdef _WITH_MAP_SUPPORT (fsa[host_position].protocol & MAP_FLAG) || #endif (fsa[host_position].protocol & HTTP_FLAG) || (fsa[host_position].protocol & SMTP_FLAG)) { get_ip_no(fsa[host_position].real_hostname[0], tmp_str_line); } else { *tmp_str_line = '\0'; } (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, tmp_str_line); XmTextSetString(text_wl[0], str_line); /* Display the second host name. */ (void)strcpy(host_alias_2, host_name); ptr = host_alias_2 + strlen(host_alias_2); *ptr = fsa[host_position].host_toggle_str[2]; *(ptr + 1) = '\0'; if ((fsa[host_position].host_toggle_str[0] != '\0') && (active_pixmap != XmUNSPECIFIED_PIXMAP) && (passive_pixmap != XmUNSPECIFIED_PIXMAP)) { (void)sprintf(label_r[0], "%*c%-*s :", 3, ' ', (FSA_INFO_TEXT_WIDTH_R - 1), host_alias_2); if (fsa[host_position].host_toggle == HOST_ONE) { XtVaSetValues(plr_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, passive_pixmap, NULL); } else { XtVaSetValues(plr_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, active_pixmap, NULL); } } else { (void)sprintf(label_r[0], "%-*s :", FSA_INFO_TEXT_WIDTH_R, host_alias_2); } text = XmStringCreateLocalized(label_r[0]); XtVaSetValues(label_r_widget[0], XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelString, text, NULL); XmStringFree(text); /* Get IP for the second host. */ if ((fsa[host_position].protocol & FTP_FLAG) || (fsa[host_position].protocol & SFTP_FLAG) || #ifdef _WITH_SCP_SUPPORT (fsa[host_position].protocol & SCP_FLAG) || #endif #ifdef _WITH_WMO_SUPPORT (fsa[host_position].protocol & WMO_FLAG) || #endif #ifdef _WITH_MAP_SUPPORT (fsa[host_position].protocol & MAP_FLAG) || #endif (fsa[host_position].protocol & HTTP_FLAG) || (fsa[host_position].protocol & SMTP_FLAG)) { get_ip_no(fsa[host_position].real_hostname[1], tmp_str_line); } else { *tmp_str_line = '\0'; } (void)sprintf(str_line, "%*s", AFD_INFO_STR_LENGTH, tmp_str_line); XmTextSetString(text_wr[0], str_line); } flush = YES; } /* Check if the host have been toggled. */ if ((fsa[host_position].host_toggle_str[0] != '\0') && (active_pixmap != XmUNSPECIFIED_PIXMAP) && (passive_pixmap != XmUNSPECIFIED_PIXMAP) && (prev.host_toggle != fsa[host_position].host_toggle)) { prev.host_toggle = fsa[host_position].host_toggle; if (fsa[host_position].host_toggle == HOST_ONE) { XtVaSetValues(pll_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, active_pixmap, NULL); XtVaSetValues(plr_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, passive_pixmap, NULL); } else { XtVaSetValues(pll_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, passive_pixmap, NULL); XtVaSetValues(plr_widget, XmNtopAttachment, XmATTACH_POSITION, XmNtopPosition, 1, XmNbottomAttachment, XmATTACH_POSITION, XmNbottomPosition, 40, XmNleftAttachment, XmATTACH_POSITION, XmNleftPosition, 1, XmNlabelType, XmPIXMAP, XmNlabelPixmap, active_pixmap, NULL); } flush = YES; } if (interval++ == FILE_UPDATE_INTERVAL) { interval = 0; /* Check if the information file for this host has changed. */ if (check_info_file(host_name, HOST_INFO_FILE, YES) == YES) { flush = YES; XmTextSetString(info_w, NULL); /* Clears old entry. */ XmTextSetString(info_w, info_data); } } if (flush == YES) { XFlush(display); } /* Call update_info() after UPDATE_INTERVAL ms. */ interval_id_host = XtAppAddTimeOut(app, UPDATE_INTERVAL, (XtTimerCallbackProc)update_info, NULL); return; }