diff options
-rw-r--r-- | plugins/check_mysql.c | 50 |
1 files changed, 48 insertions, 2 deletions
diff --git a/plugins/check_mysql.c b/plugins/check_mysql.c index 51579c2a..18c884ca 100644 --- a/plugins/check_mysql.c +++ b/plugins/check_mysql.c | |||
@@ -49,6 +49,12 @@ char *db_host = NULL; | |||
49 | char *db_socket = NULL; | 49 | char *db_socket = NULL; |
50 | char *db_pass = NULL; | 50 | char *db_pass = NULL; |
51 | char *db = NULL; | 51 | char *db = NULL; |
52 | char *ca_cert = NULL; | ||
53 | char *ca_path = NULL; | ||
54 | char *cert = NULL; | ||
55 | char *key = NULL; | ||
56 | char *cipher = NULL; | ||
57 | bool ssl = false; | ||
52 | unsigned int db_port = MYSQL_PORT; | 58 | unsigned int db_port = MYSQL_PORT; |
53 | int check_slave = 0, warn_sec = 0, crit_sec = 0; | 59 | int check_slave = 0, warn_sec = 0, crit_sec = 0; |
54 | int verbose = 0; | 60 | int verbose = 0; |
@@ -89,6 +95,8 @@ main (int argc, char **argv) | |||
89 | 95 | ||
90 | mysql_options(&mysql,MYSQL_READ_DEFAULT_GROUP,"client"); | 96 | mysql_options(&mysql,MYSQL_READ_DEFAULT_GROUP,"client"); |
91 | 97 | ||
98 | if (ssl) | ||
99 | mysql_ssl_set(&mysql,key,cert,ca_cert,ca_path,cipher); | ||
92 | /* establish a connection to the server and error checking */ | 100 | /* establish a connection to the server and error checking */ |
93 | if (!mysql_real_connect(&mysql,db_host,db_user,db_pass,db,db_port,db_socket,0)) { | 101 | if (!mysql_real_connect(&mysql,db_host,db_user,db_pass,db,db_port,db_socket,0)) { |
94 | if (mysql_errno (&mysql) == CR_UNKNOWN_HOST) | 102 | if (mysql_errno (&mysql) == CR_UNKNOWN_HOST) |
@@ -260,6 +268,12 @@ process_arguments (int argc, char **argv) | |||
260 | {"verbose", no_argument, 0, 'v'}, | 268 | {"verbose", no_argument, 0, 'v'}, |
261 | {"version", no_argument, 0, 'V'}, | 269 | {"version", no_argument, 0, 'V'}, |
262 | {"help", no_argument, 0, 'h'}, | 270 | {"help", no_argument, 0, 'h'}, |
271 | {"ssl", no_argument, 0, 'l'}, | ||
272 | {"ca_cert", optional_argument, 0, 'A'}, | ||
273 | {"key", required_argument,0,'k'}, | ||
274 | {"cert", required_argument,0,'a'}, | ||
275 | {"ca_path", required_argument, 0, 'F'}, | ||
276 | {"cipher", required_argument, 0, 'C'}, | ||
263 | {0, 0, 0, 0} | 277 | {0, 0, 0, 0} |
264 | }; | 278 | }; |
265 | 279 | ||
@@ -267,7 +281,7 @@ process_arguments (int argc, char **argv) | |||
267 | return ERROR; | 281 | return ERROR; |
268 | 282 | ||
269 | while (1) { | 283 | while (1) { |
270 | c = getopt_long (argc, argv, "hvVSP:p:u:d:H:s:c:w:", longopts, &option); | 284 | c = getopt_long (argc, argv, "hlvVSP:p:u:d:H:s:c:w:A:a:k:F:C:", longopts, &option); |
271 | 285 | ||
272 | if (c == -1 || c == EOF) | 286 | if (c == -1 || c == EOF) |
273 | break; | 287 | break; |
@@ -287,6 +301,24 @@ process_arguments (int argc, char **argv) | |||
287 | case 'd': /* database */ | 301 | case 'd': /* database */ |
288 | db = optarg; | 302 | db = optarg; |
289 | break; | 303 | break; |
304 | case 'l': | ||
305 | ssl = true; | ||
306 | break; | ||
307 | case 'A': | ||
308 | ca_cert = optarg; | ||
309 | break; | ||
310 | case 'a': | ||
311 | cert = optarg; | ||
312 | break; | ||
313 | case 'k': | ||
314 | key = optarg; | ||
315 | break; | ||
316 | case 'F': | ||
317 | ca_path = optarg; | ||
318 | break; | ||
319 | case 'C': | ||
320 | cipher = optarg; | ||
321 | break; | ||
290 | case 'u': /* username */ | 322 | case 'u': /* username */ |
291 | db_user = optarg; | 323 | db_user = optarg; |
292 | break; | 324 | break; |
@@ -409,6 +441,19 @@ print_help (void) | |||
409 | printf (" %s\n", "-c, --critical"); | 441 | printf (" %s\n", "-c, --critical"); |
410 | printf (" %s\n", _("Exit with CRITICAL status if slave server is more then INTEGER seconds")); | 442 | printf (" %s\n", _("Exit with CRITICAL status if slave server is more then INTEGER seconds")); |
411 | printf (" %s\n", _("behind master")); | 443 | printf (" %s\n", _("behind master")); |
444 | printf (" %s\n", "-l, --ssl"); | ||
445 | printf (" %s\n", _("Use ssl encryptation")); | ||
446 | printf (" %s\n", "-A, --ca_cert"); | ||
447 | printf (" %s\n", _("Path to CA signing the cert")); | ||
448 | printf (" %s\n", "-a, --cert"); | ||
449 | printf (" %s\n", _("Path to certificate to use for encriptation")); | ||
450 | printf (" %s\n", "-k, --key"); | ||
451 | printf (" %s\n", _("Path to certificate key")); | ||
452 | printf (" %s\n", "-F, --ca_path"); | ||
453 | printf (" %s\n", _("Path to CA dir")); | ||
454 | printf (" %s\n", "-C, --cipher"); | ||
455 | printf (" %s\n", _("List of valid cipher to use for encriptation")); | ||
456 | |||
412 | 457 | ||
413 | printf ("\n"); | 458 | printf ("\n"); |
414 | printf (" %s\n", _("There are no required arguments. By default, the local database is checked")); | 459 | printf (" %s\n", _("There are no required arguments. By default, the local database is checked")); |
@@ -429,5 +474,6 @@ print_usage (void) | |||
429 | { | 474 | { |
430 | printf ("%s\n", _("Usage:")); | 475 | printf ("%s\n", _("Usage:")); |
431 | printf (" %s [-d database] [-H host] [-P port] [-s socket]\n",progname); | 476 | printf (" %s [-d database] [-H host] [-P port] [-s socket]\n",progname); |
432 | printf (" [-u user] [-p password] [-S]\n"); | 477 | printf (" [-u user] [-p password] [-S] [-l] [-A ca] [-a cert]\n"); |
478 | printf (" [-k key] [-F ca_dir] [-C cipher]\n"); | ||
433 | } | 479 | } |