diff options
| author | Lionel Cons <lionel.cons@cern.ch> | 2013-05-17 15:00:09 +0200 |
|---|---|---|
| committer | Lionel Cons <lionel.cons@cern.ch> | 2013-05-17 15:00:09 +0200 |
| commit | 2f92d0dab77a3f3b1005dae3401ea1316d6789b2 (patch) | |
| tree | 09dc9a8967680b8d2b27cea698f629b40bc1aab7 /plugins/sslutils.c | |
| parent | 1fd504b6117af25d3baa0c1afc5dbf7fc3c66f2c (diff) | |
| download | monitoring-plugins-2f92d0dab77a3f3b1005dae3401ea1316d6789b2.tar.gz | |
added support for client authentication via SSL
Diffstat (limited to 'plugins/sslutils.c')
| -rw-r--r-- | plugins/sslutils.c | 12 |
1 files changed, 12 insertions, 0 deletions
diff --git a/plugins/sslutils.c b/plugins/sslutils.c index a1ce560d..4927e361 100644 --- a/plugins/sslutils.c +++ b/plugins/sslutils.c | |||
| @@ -45,6 +45,10 @@ int np_net_ssl_init_with_hostname(int sd, char *host_name) { | |||
| 45 | } | 45 | } |
| 46 | 46 | ||
| 47 | int np_net_ssl_init_with_hostname_and_version(int sd, char *host_name, int version) { | 47 | int np_net_ssl_init_with_hostname_and_version(int sd, char *host_name, int version) { |
| 48 | return np_net_ssl_init_with_hostname_version_and_certificate(sd, host_name, version, NULL, NULL); | ||
| 49 | } | ||
| 50 | |||
| 51 | int np_net_ssl_init_with_hostname_version_and_certificate(int sd, char *host_name, int version, char *cert, char *privkey) { | ||
| 48 | const SSL_METHOD *method = NULL; | 52 | const SSL_METHOD *method = NULL; |
| 49 | 53 | ||
| 50 | switch (version) { | 54 | switch (version) { |
| @@ -80,6 +84,14 @@ int np_net_ssl_init_with_hostname_and_version(int sd, char *host_name, int versi | |||
| 80 | printf("%s\n", _("CRITICAL - Cannot create SSL context.")); | 84 | printf("%s\n", _("CRITICAL - Cannot create SSL context.")); |
| 81 | return STATE_CRITICAL; | 85 | return STATE_CRITICAL; |
| 82 | } | 86 | } |
| 87 | if (cert && privkey) { | ||
| 88 | SSL_CTX_use_certificate_file(c, cert, SSL_FILETYPE_PEM); | ||
| 89 | SSL_CTX_use_PrivateKey_file(c, privkey, SSL_FILETYPE_PEM); | ||
| 90 | if (!SSL_CTX_check_private_key(c)) { | ||
| 91 | printf ("%s\n", _("CRITICAL - Private key does not seem to match certificate!\n")); | ||
| 92 | return STATE_CRITICAL; | ||
| 93 | } | ||
| 94 | } | ||
| 83 | #ifdef SSL_OP_NO_TICKET | 95 | #ifdef SSL_OP_NO_TICKET |
| 84 | SSL_CTX_set_options(c, SSL_OP_NO_TICKET); | 96 | SSL_CTX_set_options(c, SSL_OP_NO_TICKET); |
| 85 | #endif | 97 | #endif |
