From b34906e9ec3e9d75666921ccf2062701e66b8fea Mon Sep 17 00:00:00 2001 From: dd32 Date: Sun, 17 Jan 2010 08:15:52 +0000 Subject: [PATCH] Allow cURL to follow redirects when running under safe_mode or open_basedir. See #11305 git-svn-id: http://svn.automattic.com/wordpress/trunk@12747 1a063a9b-81f0-0310-95a4-ce76da25c4cd --- wp-includes/http.php | 9 +++++++++ 1 file changed, 9 insertions(+) diff --git a/wp-includes/http.php b/wp-includes/http.php index d14c498f9..60c2da135 100644 --- a/wp-includes/http.php +++ b/wp-includes/http.php @@ -1397,6 +1397,15 @@ class WP_Http_Curl { if ( true === $r['decompress'] && true === WP_Http_Encoding::should_decode($theHeaders['headers']) ) $theBody = WP_Http_Encoding::decompress( $theBody ); + // See #11605 - When running under safe mode, redirection is disabled above. Handle it manually. + if ( !empty($theHeaders['headers']['location']) && (ini_get('safe_mode') || ini_get('open_basedir')) ) { + if ( $r['redirection']-- > 0 ) { + return $this->request($theHeaders['headers']['location'], $r); + } else { + return new WP_Error('http_request_failed', __('Too many redirects.')); + } + } + return array('headers' => $theHeaders['headers'], 'body' => $theBody, 'response' => $response, 'cookies' => $theHeaders['cookies']); }