From: Stefan Eissing Date: Wed, 25 May 2022 11:49:56 +0000 (+0000) Subject: Merge of r1901088 from trunk: X-Git-Tag: 2.4.54-rc1-candidate~40 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=2b7df61cdcf8dc8efcd2f873bafe6e41a9655bad;p=thirdparty%2Fapache%2Fhttpd.git Merge of r1901088 from trunk: *) mod_proxy_connect: Ensure that the configured timeout is set on the backend socket. Trunk version of patch: https://svn.apache.org/r1901088 Backport version for 2.4.x of patch: Trunk version of patch works svn merge -c 1901088 ^/httpd/httpd/trunk . git-svn-id: https://svn.apache.org/repos/asf/httpd/httpd/branches/2.4.x@1901233 13f79535-47bb-0310-9956-ffa450edef68 --- diff --git a/STATUS b/STATUS index 5d2b2cec90b..33280a4d405 100644 --- a/STATUS +++ b/STATUS @@ -148,15 +148,6 @@ RELEASE SHOWSTOPPERS: PATCHES ACCEPTED TO BACKPORT FROM TRUNK: [ start all new proposals below, under PATCHES PROPOSED. ] - *) mod_proxy_connect: Ensure that the configured timeout is set on the - backend socket. - Trunk version of patch: - https://svn.apache.org/r1901088 - Backport version for 2.4.x of patch: - Trunk version of patch works - svn merge -c 1901088 ^/httpd/httpd/trunk . - +1: rpluem, jorton, icing - PATCHES PROPOSED TO BACKPORT FROM TRUNK: [ New proposals should be added at the end of the list ] diff --git a/modules/proxy/mod_proxy_connect.c b/modules/proxy/mod_proxy_connect.c index 2d05d116735..5a681350f09 100644 --- a/modules/proxy/mod_proxy_connect.c +++ b/modules/proxy/mod_proxy_connect.c @@ -170,6 +170,8 @@ static int proxy_connect_handler(request_rec *r, proxy_worker *worker, apr_port_t connectport = 0; apr_sockaddr_t *nexthop; + apr_interval_time_t current_timeout; + /* is this for us? */ if (r->method_number != M_CONNECT) { ap_log_rerror(APLOG_MARK, APLOG_TRACE1, 0, r, "declining URL %s", url); @@ -272,6 +274,13 @@ static int proxy_connect_handler(request_rec *r, proxy_worker *worker, return HTTP_INTERNAL_SERVER_ERROR; } ap_proxy_ssl_engine(backconn, r->per_dir_config, 0); + + /* + * save the timeout of the socket because core_pre_connection + * will set it to base_server->timeout + * (core TimeOut directive). + */ + apr_socket_timeout_get(sock, ¤t_timeout); rc = ap_run_pre_connection(backconn, sock); if (rc != OK && rc != DONE) { backconn->aborted = 1; @@ -280,6 +289,7 @@ static int proxy_connect_handler(request_rec *r, proxy_worker *worker, apr_socket_close(sock); return HTTP_INTERNAL_SERVER_ERROR; } + apr_socket_timeout_set(sock, current_timeout); ap_log_rerror(APLOG_MARK, APLOG_TRACE3, 0, r, "connection complete to %pI (%s)",