summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorDaniel Lowrey <rdlowrey@php.net>2014-07-12 10:49:42 -0400
committerDaniel Lowrey <rdlowrey@php.net>2014-07-12 10:51:44 -0400
commitf3bf887e6d84619fd03efc244756f68fa857b346 (patch)
tree6b9c4bf4c71903fcb9a77dab41ca9498a7339c49
parentb3948b1d057a099b49cec95685e13fb0f56028c1 (diff)
downloadphp-git-f3bf887e6d84619fd03efc244756f68fa857b346.tar.gz
Bug #67609: TLS connections fail behind HTTP proxy
-rw-r--r--NEWS3
-rw-r--r--ext/standard/http_fopen_wrapper.c11
2 files changed, 12 insertions, 2 deletions
diff --git a/NEWS b/NEWS
index 8b1f520c81..52aed3f13a 100644
--- a/NEWS
+++ b/NEWS
@@ -28,6 +28,9 @@ PHP NEWS
- pgsql:
. Fixed bug #67555 (Cannot build against libpq 7.3). (Adam)
+- OpenSSL:
+ . Fixed bug #67609 (TLS connections fail behind HTTP proxy). (Daniel Lowrey)
+
- Phar:
. Fixed bug #67587 (Redirection loop on nginx with FPM). (Christian Weiske)
diff --git a/ext/standard/http_fopen_wrapper.c b/ext/standard/http_fopen_wrapper.c
index 1b8d505a4b..87d0bd64e3 100644
--- a/ext/standard/http_fopen_wrapper.c
+++ b/ext/standard/http_fopen_wrapper.c
@@ -120,7 +120,7 @@ php_stream *php_stream_url_wrap_http_ex(php_stream_wrapper *wrapper,
char *scratch = NULL;
char *tmp = NULL;
char *ua_str = NULL;
- zval **ua_zval = NULL, **tmpzval = NULL;
+ zval **ua_zval = NULL, **tmpzval = NULL, *ssl_proxy_peer_name = NULL;
int scratch_len = 0;
int body = 0;
char location[HTTP_HEADER_BLOCK_SIZE];
@@ -224,6 +224,13 @@ php_stream *php_stream_url_wrap_http_ex(php_stream_wrapper *wrapper,
efree(transport_string);
if (stream && use_proxy && use_ssl) {
+ /* Set peer_name or name verification will try to use the proxy server name */
+ if (!context || php_stream_context_get_option(context, "ssl", "peer_name", &tmpzval) == FAILURE) {
+ MAKE_STD_ZVAL(ssl_proxy_peer_name);
+ ZVAL_STRING(ssl_proxy_peer_name, resource->host, 1);
+ php_stream_context_set_option(stream->context, "ssl", "peer_name", ssl_proxy_peer_name);
+ }
+
smart_str header = {0};
smart_str_appendl(&header, "CONNECT ", sizeof("CONNECT ")-1);
@@ -316,7 +323,7 @@ finish:
/* enable SSL transport layer */
if (stream) {
- if (php_stream_xport_crypto_setup(stream, STREAM_CRYPTO_METHOD_SSLv23_CLIENT, NULL TSRMLS_CC) < 0 ||
+ if (php_stream_xport_crypto_setup(stream, STREAM_CRYPTO_METHOD_ANY_CLIENT, NULL TSRMLS_CC) < 0 ||
php_stream_xport_crypto_enable(stream, 1 TSRMLS_CC) < 0) {
php_stream_wrapper_log_error(wrapper, options TSRMLS_CC, "Cannot connect to HTTPS server through proxy");
php_stream_close(stream);