From: Joe Orton Date: Wed, 10 Nov 2004 15:21:44 +0000 (+0000) Subject: Add -t -DDUMP_CERTS option to mod_ssl which dumps the filenames of all X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=92a4eacd1d91407f786cb9f12902857dc03813a9;p=thirdparty%2Fapache%2Fhttpd.git Add -t -DDUMP_CERTS option to mod_ssl which dumps the filenames of all configured SSL certificates to stdout, useful for cron-ing through a "do I need to renew any of my certificates this week" tool: * modules/ssl/ssl_engine_config.c (ssl_hook_ConfigTest): New function. * modules/ssl/mod_ssl.c (ssl_register_hooks): ...register it as a test_config hook. git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/trunk/modules/ssl@105741 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/mod_ssl.c b/mod_ssl.c index 5e21a3bc1b7..f676f06e40e 100644 --- a/mod_ssl.c +++ b/mod_ssl.c @@ -474,6 +474,7 @@ static void ssl_register_hooks(apr_pool_t *p) ssl_io_filter_register(p); ap_hook_pre_connection(ssl_hook_pre_connection,NULL,NULL, APR_HOOK_MIDDLE); + ap_hook_test_config (ssl_hook_ConfigTest, NULL,NULL, APR_HOOK_MIDDLE); ap_hook_post_config (ssl_init_Module, NULL,NULL, APR_HOOK_MIDDLE); ap_hook_http_method (ssl_hook_http_method, NULL,NULL, APR_HOOK_MIDDLE); ap_hook_default_port (ssl_hook_default_port, NULL,NULL, APR_HOOK_MIDDLE); diff --git a/ssl_engine_config.c b/ssl_engine_config.c index bd92b6a2025..d9cc5b8a1eb 100644 --- a/ssl_engine_config.c +++ b/ssl_engine_config.c @@ -1380,3 +1380,28 @@ const char *ssl_cmd_SSLUserName(cmd_parms *cmd, void *dcfg, dc->szUserName = arg; return NULL; } + +void ssl_hook_ConfigTest(apr_pool_t *pconf, server_rec *s) +{ + if (!ap_exists_config_define("DUMP_CERTS")) { + return; + } + + /* Dump the filenames of all configured server certificates to + * stdout. */ + while (s) { + SSLSrvConfigRec *sc = mySrvConfig(s); + + if (sc && sc->server && sc->server->pks) { + modssl_pk_server_t *const pks = sc->server->pks; + int i; + + for (i = 0; (i < SSL_AIDX_MAX) && pks->cert_files[i]; i++) { + printf("%s\n", pks->cert_files[i]); + } + } + + s = s->next; + } + +} diff --git a/ssl_private.h b/ssl_private.h index e044f3a80fa..4f834948ba1 100644 --- a/ssl_private.h +++ b/ssl_private.h @@ -530,6 +530,7 @@ int ssl_hook_Access(request_rec *); int ssl_hook_Fixup(request_rec *); int ssl_hook_ReadReq(request_rec *); int ssl_hook_Upgrade(request_rec *); +void ssl_hook_ConfigTest(apr_pool_t *pconf, server_rec *s); /* OpenSSL callbacks */ RSA *ssl_callback_TmpRSA(SSL *, int, int);