diff options
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/check_disk.c | 27 | ||||
| -rw-r--r-- | plugins/check_mysql.c | 5 | ||||
| -rw-r--r-- | plugins/check_smtp.c | 38 | 
3 files changed, 59 insertions, 11 deletions
| diff --git a/plugins/check_disk.c b/plugins/check_disk.c index a99f35e3..39dc6cd2 100644 --- a/plugins/check_disk.c +++ b/plugins/check_disk.c | |||
| @@ -626,21 +626,36 @@ process_arguments (int argc, char **argv) | |||
| 626 | if (! strcasecmp (optarg, "bytes")) { | 626 | if (! strcasecmp (optarg, "bytes")) { | 
| 627 | mult = (uintmax_t)1; | 627 | mult = (uintmax_t)1; | 
| 628 | units = strdup ("B"); | 628 | units = strdup ("B"); | 
| 629 | } else if ( (! strcmp (optarg, "kB")) || (!strcmp(optarg, "KiB")) ) { | 629 | } else if (!strcmp(optarg, "KiB")) { | 
| 630 | mult = (uintmax_t)1024; | 630 | mult = (uintmax_t)1024; | 
| 631 | units = strdup ("kiB"); | 631 | units = strdup ("KiB"); | 
| 632 | } else if ( (! strcmp (optarg, "MB")) || (!strcmp(optarg, "MiB")) ) { | 632 | } else if (! strcmp (optarg, "kB")) { | 
| 633 | mult = (uintmax_t)1000; | ||
| 634 | units = strdup ("kB"); | ||
| 635 | } else if (!strcmp(optarg, "MiB")) { | ||
| 633 | mult = (uintmax_t)1024 * 1024; | 636 | mult = (uintmax_t)1024 * 1024; | 
| 634 | units = strdup ("MiB"); | 637 | units = strdup ("MiB"); | 
| 635 | } else if ( (! strcmp (optarg, "GB")) || (!strcmp(optarg, "GiB")) ) { | 638 | } else if (! strcmp (optarg, "MB")) { | 
| 639 | mult = (uintmax_t)1000 * 1000; | ||
| 640 | units = strdup ("MB"); | ||
| 641 | } else if (!strcmp(optarg, "GiB")) { | ||
| 636 | mult = (uintmax_t)1024 * 1024 * 1024; | 642 | mult = (uintmax_t)1024 * 1024 * 1024; | 
| 637 | units = strdup ("GiB"); | 643 | units = strdup ("GiB"); | 
| 638 | } else if ( (! strcmp (optarg, "TB")) || (!strcmp(optarg, "TiB")) ) { | 644 | } else if (! strcmp (optarg, "GB")){ | 
| 645 | mult = (uintmax_t)1000 * 1000 * 1000; | ||
| 646 | units = strdup ("GB"); | ||
| 647 | } else if (!strcmp(optarg, "TiB")) { | ||
| 639 | mult = (uintmax_t)1024 * 1024 * 1024 * 1024; | 648 | mult = (uintmax_t)1024 * 1024 * 1024 * 1024; | 
| 640 | units = strdup ("TiB"); | 649 | units = strdup ("TiB"); | 
| 641 | } else if ( (! strcmp (optarg, "PB")) || (!strcmp(optarg, "PiB")) ) { | 650 | } else if (! strcmp (optarg, "TB")) { | 
| 651 | mult = (uintmax_t)1000 * 1000 * 1000 * 1000; | ||
| 652 | units = strdup ("TB"); | ||
| 653 | } else if (!strcmp(optarg, "PiB")) { | ||
| 642 | mult = (uintmax_t)1024 * 1024 * 1024 * 1024 * 1024; | 654 | mult = (uintmax_t)1024 * 1024 * 1024 * 1024 * 1024; | 
| 643 | units = strdup ("PiB"); | 655 | units = strdup ("PiB"); | 
| 656 | } else if (! strcmp (optarg, "PB")){ | ||
| 657 | mult = (uintmax_t)1000 * 1000 * 1000 * 1000 * 1000; | ||
| 658 | units = strdup ("PB"); | ||
| 644 | } else { | 659 | } else { | 
| 645 | die (STATE_UNKNOWN, _("unit type %s not known\n"), optarg); | 660 | die (STATE_UNKNOWN, _("unit type %s not known\n"), optarg); | 
| 646 | } | 661 | } | 
| diff --git a/plugins/check_mysql.c b/plugins/check_mysql.c index 6cfa70ed..91e150fb 100644 --- a/plugins/check_mysql.c +++ b/plugins/check_mysql.c | |||
| @@ -138,7 +138,10 @@ main (int argc, char **argv) | |||
| 138 | mysql_ssl_set(&mysql,key,cert,ca_cert,ca_dir,ciphers); | 138 | mysql_ssl_set(&mysql,key,cert,ca_cert,ca_dir,ciphers); | 
| 139 | /* establish a connection to the server and error checking */ | 139 | /* establish a connection to the server and error checking */ | 
| 140 | if (!mysql_real_connect(&mysql,db_host,db_user,db_pass,db,db_port,db_socket,0)) { | 140 | if (!mysql_real_connect(&mysql,db_host,db_user,db_pass,db,db_port,db_socket,0)) { | 
| 141 | if (ignore_auth && mysql_errno (&mysql) == ER_ACCESS_DENIED_ERROR) | 141 | /* Depending on internally-selected auth plugin MySQL might return */ | 
| 142 | /* ER_ACCESS_DENIED_NO_PASSWORD_ERROR or ER_ACCESS_DENIED_ERROR. */ | ||
| 143 | /* Semantically these errors are the same. */ | ||
| 144 | if (ignore_auth && (mysql_errno (&mysql) == ER_ACCESS_DENIED_ERROR || mysql_errno (&mysql) == ER_ACCESS_DENIED_NO_PASSWORD_ERROR)) | ||
| 142 | { | 145 | { | 
| 143 | printf("MySQL OK - Version: %s (protocol %d)\n", | 146 | printf("MySQL OK - Version: %s (protocol %d)\n", | 
| 144 | mysql_get_server_info(&mysql), | 147 | mysql_get_server_info(&mysql), | 
| diff --git a/plugins/check_smtp.c b/plugins/check_smtp.c index eaa7eeba..c0ab838a 100644 --- a/plugins/check_smtp.c +++ b/plugins/check_smtp.c | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | * Monitoring check_smtp plugin | 3 | * Monitoring check_smtp plugin | 
| 4 | * | 4 | * | 
| 5 | * License: GPL | 5 | * License: GPL | 
| 6 | * Copyright (c) 2000-2007 Monitoring Plugins Development Team | 6 | * Copyright (c) 2000-2023 Monitoring Plugins Development Team | 
| 7 | * | 7 | * | 
| 8 | * Description: | 8 | * Description: | 
| 9 | * | 9 | * | 
| @@ -52,6 +52,7 @@ int days_till_exp_warn, days_till_exp_crit; | |||
| 52 | enum { | 52 | enum { | 
| 53 | SMTP_PORT = 25 | 53 | SMTP_PORT = 25 | 
| 54 | }; | 54 | }; | 
| 55 | #define PROXY_PREFIX "PROXY TCP4 0.0.0.0 0.0.0.0 25 25\r\n" | ||
| 55 | #define SMTP_EXPECT "220" | 56 | #define SMTP_EXPECT "220" | 
| 56 | #define SMTP_HELO "HELO " | 57 | #define SMTP_HELO "HELO " | 
| 57 | #define SMTP_EHLO "EHLO " | 58 | #define SMTP_EHLO "EHLO " | 
| @@ -102,6 +103,8 @@ double critical_time = 0; | |||
| 102 | int check_critical_time = FALSE; | 103 | int check_critical_time = FALSE; | 
| 103 | int verbose = 0; | 104 | int verbose = 0; | 
| 104 | int use_ssl = FALSE; | 105 | int use_ssl = FALSE; | 
| 106 | int use_sni = FALSE; | ||
| 107 | short use_proxy_prefix = FALSE; | ||
| 105 | short use_ehlo = FALSE; | 108 | short use_ehlo = FALSE; | 
| 106 | short use_lhlo = FALSE; | 109 | short use_lhlo = FALSE; | 
| 107 | short ssl_established = 0; | 110 | short ssl_established = 0; | 
| @@ -184,6 +187,13 @@ main (int argc, char **argv) | |||
| 184 | 187 | ||
| 185 | if (result == STATE_OK) { /* we connected */ | 188 | if (result == STATE_OK) { /* we connected */ | 
| 186 | 189 | ||
| 190 | /* If requested, send PROXY header */ | ||
| 191 | if (use_proxy_prefix) { | ||
| 192 | if (verbose) | ||
| 193 | printf ("Sending header %s\n", PROXY_PREFIX); | ||
| 194 | send(sd, PROXY_PREFIX, strlen(PROXY_PREFIX), 0); | ||
| 195 | } | ||
| 196 | |||
| 187 | /* watch for the SMTP connection string and */ | 197 | /* watch for the SMTP connection string and */ | 
| 188 | /* return a WARNING status if we couldn't read any data */ | 198 | /* return a WARNING status if we couldn't read any data */ | 
| 189 | if (recvlines(buffer, MAX_INPUT_BUFFER) <= 0) { | 199 | if (recvlines(buffer, MAX_INPUT_BUFFER) <= 0) { | 
| @@ -225,7 +235,7 @@ main (int argc, char **argv) | |||
| 225 | smtp_quit(); | 235 | smtp_quit(); | 
| 226 | return STATE_UNKNOWN; | 236 | return STATE_UNKNOWN; | 
| 227 | } | 237 | } | 
| 228 | result = np_net_ssl_init(sd); | 238 | result = np_net_ssl_init_with_hostname(sd, (use_sni ? server_address : NULL)); | 
| 229 | if(result != STATE_OK) { | 239 | if(result != STATE_OK) { | 
| 230 | printf (_("CRITICAL - Cannot create SSL context.\n")); | 240 | printf (_("CRITICAL - Cannot create SSL context.\n")); | 
| 231 | close(sd); | 241 | close(sd); | 
| @@ -454,6 +464,10 @@ process_arguments (int argc, char **argv) | |||
| 454 | int c; | 464 | int c; | 
| 455 | char* temp; | 465 | char* temp; | 
| 456 | 466 | ||
| 467 | enum { | ||
| 468 | SNI_OPTION | ||
| 469 | }; | ||
| 470 | |||
| 457 | int option = 0; | 471 | int option = 0; | 
| 458 | static struct option longopts[] = { | 472 | static struct option longopts[] = { | 
| 459 | {"hostname", required_argument, 0, 'H'}, | 473 | {"hostname", required_argument, 0, 'H'}, | 
| @@ -476,8 +490,10 @@ process_arguments (int argc, char **argv) | |||
| 476 | {"help", no_argument, 0, 'h'}, | 490 | {"help", no_argument, 0, 'h'}, | 
| 477 | {"lmtp", no_argument, 0, 'L'}, | 491 | {"lmtp", no_argument, 0, 'L'}, | 
| 478 | {"starttls",no_argument,0,'S'}, | 492 | {"starttls",no_argument,0,'S'}, | 
| 493 | {"sni", no_argument, 0, SNI_OPTION}, | ||
| 479 | {"certificate",required_argument,0,'D'}, | 494 | {"certificate",required_argument,0,'D'}, | 
| 480 | {"ignore-quit-failure",no_argument,0,'q'}, | 495 | {"ignore-quit-failure",no_argument,0,'q'}, | 
| 496 | {"proxy",no_argument,0,'r'}, | ||
| 481 | {0, 0, 0, 0} | 497 | {0, 0, 0, 0} | 
| 482 | }; | 498 | }; | 
| 483 | 499 | ||
| @@ -494,7 +510,7 @@ process_arguments (int argc, char **argv) | |||
| 494 | } | 510 | } | 
| 495 | 511 | ||
| 496 | while (1) { | 512 | while (1) { | 
| 497 | c = getopt_long (argc, argv, "+hVv46Lt:p:f:e:c:w:H:C:R:SD:F:A:U:P:q", | 513 | c = getopt_long (argc, argv, "+hVv46Lrt:p:f:e:c:w:H:C:R:SD:F:A:U:P:q", | 
| 498 | longopts, &option); | 514 | longopts, &option); | 
| 499 | 515 | ||
| 500 | if (c == -1 || c == EOF) | 516 | if (c == -1 || c == EOF) | 
| @@ -621,6 +637,16 @@ process_arguments (int argc, char **argv) | |||
| 621 | use_ssl = TRUE; | 637 | use_ssl = TRUE; | 
| 622 | use_ehlo = TRUE; | 638 | use_ehlo = TRUE; | 
| 623 | break; | 639 | break; | 
| 640 | case SNI_OPTION: | ||
| 641 | #ifdef HAVE_SSL | ||
| 642 | use_sni = TRUE; | ||
| 643 | #else | ||
| 644 | usage (_("SSL support not available - install OpenSSL and recompile")); | ||
| 645 | #endif | ||
| 646 | break; | ||
| 647 | case 'r': | ||
| 648 | use_proxy_prefix = TRUE; | ||
| 649 | break; | ||
| 624 | case 'L': | 650 | case 'L': | 
| 625 | use_lhlo = TRUE; | 651 | use_lhlo = TRUE; | 
| 626 | break; | 652 | break; | 
| @@ -819,11 +845,15 @@ print_help (void) | |||
| 819 | printf (" %s\n", _("FROM-address to include in MAIL command, required by Exchange 2000")), | 845 | printf (" %s\n", _("FROM-address to include in MAIL command, required by Exchange 2000")), | 
| 820 | printf (" %s\n", "-F, --fqdn=STRING"); | 846 | printf (" %s\n", "-F, --fqdn=STRING"); | 
| 821 | printf (" %s\n", _("FQDN used for HELO")); | 847 | printf (" %s\n", _("FQDN used for HELO")); | 
| 848 | printf (" %s\n", "-r, --proxy"); | ||
| 849 | printf (" %s\n", _("Use PROXY protocol prefix for the connection.")); | ||
| 822 | #ifdef HAVE_SSL | 850 | #ifdef HAVE_SSL | 
| 823 | printf (" %s\n", "-D, --certificate=INTEGER[,INTEGER]"); | 851 | printf (" %s\n", "-D, --certificate=INTEGER[,INTEGER]"); | 
| 824 | printf (" %s\n", _("Minimum number of days a certificate has to be valid.")); | 852 | printf (" %s\n", _("Minimum number of days a certificate has to be valid.")); | 
| 825 | printf (" %s\n", "-S, --starttls"); | 853 | printf (" %s\n", "-S, --starttls"); | 
| 826 | printf (" %s\n", _("Use STARTTLS for the connection.")); | 854 | printf (" %s\n", _("Use STARTTLS for the connection.")); | 
| 855 | printf (" %s\n", "--sni"); | ||
| 856 | printf (" %s\n", _("Enable SSL/TLS hostname extension support (SNI)")); | ||
| 827 | #endif | 857 | #endif | 
| 828 | 858 | ||
| 829 | printf (" %s\n", "-A, --authtype=STRING"); | 859 | printf (" %s\n", "-A, --authtype=STRING"); | 
| @@ -860,6 +890,6 @@ print_usage (void) | |||
| 860 | printf ("%s\n", _("Usage:")); | 890 | printf ("%s\n", _("Usage:")); | 
| 861 | printf ("%s -H host [-p port] [-4|-6] [-e expect] [-C command] [-R response] [-f from addr]\n", progname); | 891 | printf ("%s -H host [-p port] [-4|-6] [-e expect] [-C command] [-R response] [-f from addr]\n", progname); | 
| 862 | printf ("[-A authtype -U authuser -P authpass] [-w warn] [-c crit] [-t timeout] [-q]\n"); | 892 | printf ("[-A authtype -U authuser -P authpass] [-w warn] [-c crit] [-t timeout] [-q]\n"); | 
| 863 | printf ("[-F fqdn] [-S] [-L] [-D warn days cert expire[,crit days cert expire]] [-v] \n"); | 893 | printf ("[-F fqdn] [-S] [-L] [-D warn days cert expire[,crit days cert expire]] [-r] [--sni] [-v] \n"); | 
| 864 | } | 894 | } | 
| 865 | 895 | ||
