65 lines
2.3 KiB
Diff
65 lines
2.3 KiB
Diff
|
Index: mod_nss-1.0.8/nss_engine_io.c
|
||
|
===================================================================
|
||
|
--- mod_nss-1.0.8.orig/nss_engine_io.c 2015-09-01 09:04:16.141175064 +0200
|
||
|
+++ mod_nss-1.0.8/nss_engine_io.c 2015-09-01 09:04:17.985198759 +0200
|
||
|
@@ -664,6 +664,37 @@ static apr_status_t nss_io_filter_cleanu
|
||
|
return APR_SUCCESS;
|
||
|
}
|
||
|
|
||
|
+static apr_status_t nss_io_filter_handshake(ap_filter_t *f)
|
||
|
+{
|
||
|
+ conn_rec *c = f->c;
|
||
|
+ SSLConnRec *sslconn = myConnConfig(c);
|
||
|
+
|
||
|
+ /*
|
||
|
+ * Enable SNI for backend requests. Make sure we don't do it for
|
||
|
+ * pure SSLv3 connections
|
||
|
+ */
|
||
|
+ if (sslconn->is_proxy) {
|
||
|
+ const char *hostname_note = apr_table_get(c->notes, "proxy-request-hostname");
|
||
|
+ if (hostname_note) {
|
||
|
+ if (SSL_SetURL(sslconn->ssl, hostname_note) == -1) {
|
||
|
+ ap_log_error(APLOG_MARK, APLOG_INFO, 0, c->base_server,
|
||
|
+ "Error setting SNI extension for SSL Proxy request: %d",
|
||
|
+ PR_GetError());
|
||
|
+ } else {
|
||
|
+ ap_log_error(APLOG_MARK, APLOG_INFO, 0, c,
|
||
|
+ "SNI extension for SSL Proxy request set to '%s'",
|
||
|
+ hostname_note);
|
||
|
+ }
|
||
|
+ }
|
||
|
+ else {
|
||
|
+ ap_log_error(APLOG_MARK, APLOG_INFO, 0, c,
|
||
|
+ "Can't set SNI extension: no hostname available");
|
||
|
+ }
|
||
|
+ }
|
||
|
+
|
||
|
+ return APR_SUCCESS;
|
||
|
+}
|
||
|
+
|
||
|
static apr_status_t nss_io_filter_input(ap_filter_t *f,
|
||
|
apr_bucket_brigade *bb,
|
||
|
ap_input_mode_t mode,
|
||
|
@@ -699,6 +730,10 @@ static apr_status_t nss_io_filter_input(
|
||
|
inctx->mode = mode;
|
||
|
inctx->block = block;
|
||
|
|
||
|
+ if ((status = nss_io_filter_handshake(f)) != APR_SUCCESS) {
|
||
|
+ return nss_io_filter_error(f, bb, status);
|
||
|
+ }
|
||
|
+
|
||
|
if (is_init) {
|
||
|
/* protocol module needs to handshake before sending
|
||
|
* data to client (e.g. NNTP or FTP)
|
||
|
@@ -820,6 +855,10 @@ static apr_status_t nss_io_filter_output
|
||
|
inctx->mode = AP_MODE_READBYTES;
|
||
|
inctx->block = APR_BLOCK_READ;
|
||
|
|
||
|
+ if ((status = nss_io_filter_handshake(f)) != APR_SUCCESS) {
|
||
|
+ return nss_io_filter_error(f, bb, status);
|
||
|
+ }
|
||
|
+
|
||
|
while (!APR_BRIGADE_EMPTY(bb)) {
|
||
|
apr_bucket *bucket = APR_BRIGADE_FIRST(bb);
|
||
|
|