diff options
| -rw-r--r-- | httpd-2.4.2-r1332643.patch | 240 | ||||
| -rw-r--r-- | httpd.spec | 10 | 
2 files changed, 249 insertions, 1 deletions
diff --git a/httpd-2.4.2-r1332643.patch b/httpd-2.4.2-r1332643.patch new file mode 100644 index 0000000..c408d29 --- /dev/null +++ b/httpd-2.4.2-r1332643.patch @@ -0,0 +1,240 @@ + +https://bugzilla.redhat.com//show_bug.cgi?id=809599 + +http://svn.apache.org/viewvc?view=revision&revision=1332643 + +--- httpd-2.4.2/modules/ssl/ssl_private.h ++++ httpd-2.4.2/modules/ssl/ssl_private.h +@@ -139,6 +139,11 @@ + #define HAVE_FIPS + #endif +  ++#if OPENSSL_VERSION_NUMBER >= 0x10001000L && !defined(OPENSSL_NO_NEXTPROTONEG) \ ++    && !defined(OPENSSL_NO_TLSEXT) ++#define HAVE_TLS_NPN ++#endif ++ + #if (OPENSSL_VERSION_NUMBER >= 0x10000000) + #define MODSSL_SSL_CIPHER_CONST const + #define MODSSL_SSL_METHOD_CONST const +@@ -811,6 +816,7 @@ + int         ssl_callback_SessionTicket(SSL *, unsigned char *, unsigned char *, +                                        EVP_CIPHER_CTX *, HMAC_CTX *, int); + #endif ++int ssl_callback_AdvertiseNextProtos(SSL *ssl, const unsigned char **data, unsigned int *len, void *arg); +  + /**  Session Cache Support  */ + void         ssl_scache_init(server_rec *, apr_pool_t *); +--- httpd-2.4.2/modules/ssl/mod_ssl.c ++++ httpd-2.4.2/modules/ssl/mod_ssl.c +@@ -260,6 +260,18 @@ +     AP_END_CMD + }; +  ++/* Implement 'modssl_run_npn_advertise_protos_hook'. */ ++APR_IMPLEMENT_OPTIONAL_HOOK_RUN_ALL( ++    modssl, AP, int, npn_advertise_protos_hook, ++    (conn_rec *connection, apr_array_header_t *protos), ++    (connection, protos), OK, DECLINED); ++ ++/* Implement 'modssl_run_npn_proto_negotiated_hook'. */ ++APR_IMPLEMENT_OPTIONAL_HOOK_RUN_ALL( ++    modssl, AP, int, npn_proto_negotiated_hook, ++    (conn_rec *connection, const char *proto_name, apr_size_t proto_name_len), ++    (connection, proto_name, proto_name_len), OK, DECLINED); ++ + /* +  *  the various processing hooks +  */ +--- httpd-2.4.2/modules/ssl/mod_ssl.h ++++ httpd-2.4.2/modules/ssl/mod_ssl.h +@@ -63,5 +63,26 @@ +  + APR_DECLARE_OPTIONAL_FN(int, ssl_engine_disable, (conn_rec *)); +  ++/** The npn_advertise_protos optional hook allows other modules to add entries ++ * to the list of protocol names advertised by the server during the Next ++ * Protocol Negotiation (NPN) portion of the SSL handshake.  The hook callee is ++ * given the connection and an APR array; it should push one or more char*'s ++ * pointing to null-terminated strings (such as "http/1.1" or "spdy/2") onto ++ * the array and return OK, or do nothing and return DECLINED. */ ++APR_DECLARE_EXTERNAL_HOOK(modssl, AP, int, npn_advertise_protos_hook, ++                          (conn_rec *connection, apr_array_header_t *protos)); ++ ++/** The npn_proto_negotiated optional hook allows other modules to discover the ++ * name of the protocol that was chosen during the Next Protocol Negotiation ++ * (NPN) portion of the SSL handshake.  Note that this may be the empty string ++ * (in which case modules should probably assume HTTP), or it may be a protocol ++ * that was never even advertised by the server.  The hook callee is given the ++ * connection, a non-null-terminated string containing the protocol name, and ++ * the length of the string; it should do something appropriate (i.e. insert or ++ * remove filters) and return OK, or do nothing and return DECLINED. */ ++APR_DECLARE_EXTERNAL_HOOK(modssl, AP, int, npn_proto_negotiated_hook, ++                          (conn_rec *connection, const char *proto_name, ++                           apr_size_t proto_name_len)); ++ + #endif /* __MOD_SSL_H__ */ + /** @} */ +--- httpd-2.4.2/modules/ssl/ssl_engine_init.c ++++ httpd-2.4.2/modules/ssl/ssl_engine_init.c +@@ -681,6 +681,11 @@ + #endif +  +     SSL_CTX_set_info_callback(ctx, ssl_callback_Info); ++ ++#ifdef HAVE_TLS_NPN ++    SSL_CTX_set_next_protos_advertised_cb( ++        ctx, ssl_callback_AdvertiseNextProtos, NULL); ++#endif + } +  + static void ssl_init_ctx_verify(server_rec *s, +--- httpd-2.4.2/modules/ssl/ssl_engine_io.c ++++ httpd-2.4.2/modules/ssl/ssl_engine_io.c +@@ -28,6 +28,7 @@ +                                   core keeps dumping.'' +                                             -- Unknown    */ + #include "ssl_private.h" ++#include "mod_ssl.h" + #include "apr_date.h" +  + /*  _________________________________________________________________ +@@ -297,6 +298,7 @@ +     apr_pool_t *pool; +     char buffer[AP_IOBUFSIZE]; +     ssl_filter_ctx_t *filter_ctx; ++    int npn_finished;  /* 1 if NPN has finished, 0 otherwise */ + } bio_filter_in_ctx_t; +  + /* +@@ -1374,6 +1376,27 @@ +         APR_BRIGADE_INSERT_TAIL(bb, bucket); +     } +  ++#ifdef HAVE_TLS_NPN ++    /* By this point, Next Protocol Negotiation (NPN) should be completed (if ++     * our version of OpenSSL supports it).  If we haven't already, find out ++     * which protocol was decided upon and inform other modules by calling ++     * npn_proto_negotiated_hook. */ ++    if (!inctx->npn_finished) { ++        const unsigned char *next_proto = NULL; ++        unsigned next_proto_len = 0; ++ ++        SSL_get0_next_proto_negotiated( ++            inctx->ssl, &next_proto, &next_proto_len); ++        ap_log_cerror(APLOG_MARK, APLOG_DEBUG, APR_SUCCESS, f->c, ++                      "SSL NPN negotiated protocol: '%s'", ++                      apr_pstrmemdup(f->c->pool, (const char*)next_proto, ++                                     next_proto_len)); ++        modssl_run_npn_proto_negotiated_hook( ++            f->c, (const char*)next_proto, next_proto_len); ++        inctx->npn_finished = 1; ++    } ++#endif ++ +     return APR_SUCCESS; + } +  +@@ -1855,6 +1878,7 @@ +     inctx->block = APR_BLOCK_READ; +     inctx->pool = c->pool; +     inctx->filter_ctx = filter_ctx; ++    inctx->npn_finished = 0; + } +  + /* The request_rec pointer is passed in here only to ensure that the +--- httpd-2.4.2/modules/ssl/ssl_engine_kernel.c ++++ httpd-2.4.2/modules/ssl/ssl_engine_kernel.c +@@ -29,6 +29,7 @@ +                                   time I was too famous.'' +                                             -- Unknown                */ + #include "ssl_private.h" ++#include "mod_ssl.h" + #include "util_md5.h" +  + static void ssl_configure_env(request_rec *r, SSLConnRec *sslconn); +@@ -2143,3 +2144,84 @@ +     return -1; + } + #endif ++ ++#ifdef HAVE_TLS_NPN ++/* ++ * This callback function is executed when SSL needs to decide what protocols ++ * to advertise during Next Protocol Negotiation (NPN).  It must produce a ++ * string in wire format -- a sequence of length-prefixed strings -- indicating ++ * the advertised protocols.  Refer to SSL_CTX_set_next_protos_advertised_cb ++ * in OpenSSL for reference. ++ */ ++int ssl_callback_AdvertiseNextProtos(SSL *ssl, const unsigned char **data_out, ++                                     unsigned int *size_out, void *arg) ++{ ++    conn_rec *c = (conn_rec*)SSL_get_app_data(ssl); ++    apr_array_header_t *protos; ++    int num_protos; ++    unsigned int size; ++    int i; ++    unsigned char *data; ++    unsigned char *start; ++ ++    *data_out = NULL; ++    *size_out = 0; ++ ++    /* If the connection object is not available, then there's nothing for us ++     * to do. */ ++    if (c == NULL) { ++        return SSL_TLSEXT_ERR_OK; ++    } ++ ++    /* Invoke our npn_advertise_protos hook, giving other modules a chance to ++     * add alternate protocol names to advertise. */ ++    protos = apr_array_make(c->pool, 0, sizeof(char*)); ++    modssl_run_npn_advertise_protos_hook(c, protos); ++    num_protos = protos->nelts; ++ ++    /* We now have a list of null-terminated strings; we need to concatenate ++     * them together into a single string, where each protocol name is prefixed ++     * by its length.  First, calculate how long that string will be. */ ++    size = 0; ++    for (i = 0; i < num_protos; ++i) { ++        const char *string = APR_ARRAY_IDX(protos, i, const char*); ++        unsigned int length = strlen(string); ++        /* If the protocol name is too long (the length must fit in one byte), ++         * then log an error and skip it. */ ++        if (length > 255) { ++            ap_log_cerror(APLOG_MARK, APLOG_ERR, 0, c, ++                          "SSL NPN protocol name too long (length=%u): %s", ++                          length, string); ++            continue; ++        } ++        /* Leave room for the length prefix (one byte) plus the protocol name ++         * itself. */ ++        size += 1 + length; ++    } ++ ++    /* If there is nothing to advertise (either because no modules added ++     * anything to the protos array, or because all strings added to the array ++     * were skipped), then we're done. */ ++    if (size == 0) { ++        return SSL_TLSEXT_ERR_OK; ++    } ++ ++    /* Now we can build the string.  Copy each protocol name string into the ++     * larger string, prefixed by its length. */ ++    data = apr_palloc(c->pool, size * sizeof(unsigned char)); ++    start = data; ++    for (i = 0; i < num_protos; ++i) { ++        const char *string = APR_ARRAY_IDX(protos, i, const char*); ++        apr_size_t length = strlen(string); ++        *start = (unsigned char)length; ++        ++start; ++        memcpy(start, string, length * sizeof(unsigned char)); ++        start += length; ++    } ++ ++    /* Success. */ ++    *data_out = data; ++    *size_out = size; ++    return SSL_TLSEXT_ERR_OK; ++} ++#endif @@ -8,7 +8,7 @@  Summary: Apache HTTP Server  Name: httpd  Version: 2.4.2 -Release: 6%{?dist} +Release: 7%{?dist}  URL: http://httpd.apache.org/  Source0: http://www.apache.org/dist/httpd/httpd-%{version}.tar.bz2  Source1: index.html @@ -48,6 +48,7 @@ Patch26: httpd-2.4.1-suenable.patch  Patch40: httpd-2.4.2-restart.patch  Patch41: httpd-2.4.2-r1327036+.patch  Patch42: httpd-2.4.2-r1326980+.patch +Patch43: httpd-2.4.2-r1332643.patch  License: ASL 2.0  Group: System Environment/Daemons  BuildRoot: %{_tmppath}/%{name}-%{version}-%{release}-root @@ -157,6 +158,7 @@ authentication to the Apache HTTP Server.  %patch40 -p1 -b .restart  %patch41 -p1 -b .r1327036+  %patch42 -p1 -b .r1326980+ +%patch43 -p1 -b .r1332643  # Patch in vendor/release string  sed "s/@RELEASE@/%{vstring}/" < %{PATCH20} | patch -p1 @@ -560,6 +562,12 @@ rm -rf $RPM_BUILD_ROOT  %{_sysconfdir}/rpm/macros.httpd  %changelog +* Tue May  1 2012 Remi Collet <RPMS@FamilleCollet.com> - 2.4.2-7 +- sync with rawhide, rebuild for remi repo + +* Tue May  1 2012 Joe Orton <jorton@redhat.com> - 2.4.2-7 +- mod_ssl: add TLS NPN support (r1332643, #809599) +  * Tue May  1 2012 Joe Orton <jorton@redhat.com> - 2.4.2-6  - add BR on APR >= 1.4.0  | 
