Allow for array('redirection' => 0) to bypass WP_Error on redirects being encountered; Allows HEAD requests WITH 'redirection' > 0 specified at call time to follow redirections; Standardises on return values from all transports to act the same based on the Unit Tests. Fixes #16855
git-svn-id: https://develop.svn.wordpress.org/trunk@17551 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
048fcd1cce
commit
3591957d49
@ -100,9 +100,20 @@ class WP_Http {
|
|||||||
'sslverify' => true
|
'sslverify' => true
|
||||||
);
|
);
|
||||||
|
|
||||||
|
|
||||||
|
// Pre-parse for the HEAD checks.
|
||||||
|
$args = wp_parse_args( $args );
|
||||||
|
|
||||||
|
// By default, Head requests do not cause redirections.
|
||||||
|
if ( isset($args['method']) && 'HEAD' == $args['method'] )
|
||||||
|
$defaults['redirection'] = 0;
|
||||||
|
|
||||||
$r = wp_parse_args( $args, $defaults );
|
$r = wp_parse_args( $args, $defaults );
|
||||||
$r = apply_filters( 'http_request_args', $r, $url );
|
$r = apply_filters( 'http_request_args', $r, $url );
|
||||||
|
|
||||||
|
// Certain classes decrement this, store a copy of the original value for loop purposes.
|
||||||
|
$r['_redirection'] = $r['redirection'];
|
||||||
|
|
||||||
// Allow plugins to short-circuit the request
|
// Allow plugins to short-circuit the request
|
||||||
$pre = apply_filters( 'pre_http_request', false, $r, $url );
|
$pre = apply_filters( 'pre_http_request', false, $r, $url );
|
||||||
if ( false !== $pre )
|
if ( false !== $pre )
|
||||||
@ -664,7 +675,7 @@ class WP_Http_Fsockopen {
|
|||||||
return new WP_Error('http_request_failed', $arrHeaders['response']['code'] . ': ' . $arrHeaders['response']['message']);
|
return new WP_Error('http_request_failed', $arrHeaders['response']['code'] . ': ' . $arrHeaders['response']['message']);
|
||||||
|
|
||||||
// If location is found, then assume redirect and redirect to location.
|
// If location is found, then assume redirect and redirect to location.
|
||||||
if ( 'HEAD' != $r['method'] && isset($arrHeaders['headers']['location']) ) {
|
if ( isset($arrHeaders['headers']['location']) && 0 !== $r['_redirection'] ) {
|
||||||
if ( $r['redirection']-- > 0 ) {
|
if ( $r['redirection']-- > 0 ) {
|
||||||
return $this->request($arrHeaders['headers']['location'], $r);
|
return $this->request($arrHeaders['headers']['location'], $r);
|
||||||
} else {
|
} else {
|
||||||
@ -800,9 +811,6 @@ class WP_Http_Streams {
|
|||||||
$arrContext['http']['header'] .= $proxy->authentication_header() . "\r\n";
|
$arrContext['http']['header'] .= $proxy->authentication_header() . "\r\n";
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( 'HEAD' == $r['method'] ) // Disable redirects for HEAD requests
|
|
||||||
$arrContext['http']['max_redirects'] = 1;
|
|
||||||
|
|
||||||
if ( ! empty($r['body'] ) )
|
if ( ! empty($r['body'] ) )
|
||||||
$arrContext['http']['content'] = $r['body'];
|
$arrContext['http']['content'] = $r['body'];
|
||||||
|
|
||||||
@ -837,6 +845,11 @@ class WP_Http_Streams {
|
|||||||
else
|
else
|
||||||
$processedHeaders = WP_Http::processHeaders($meta['wrapper_data']);
|
$processedHeaders = WP_Http::processHeaders($meta['wrapper_data']);
|
||||||
|
|
||||||
|
// Streams does not provide an error code which we can use to see why the request stream stoped.
|
||||||
|
// We can however test to see if a location header is present and return based on that.
|
||||||
|
if ( isset($processedHeaders['headers']['location']) && 0 !== $args['_redirection'] )
|
||||||
|
return new WP_Error('http_request_failed', __('Too many redirects.'));
|
||||||
|
|
||||||
if ( ! empty( $strResponse ) && isset( $processedHeaders['headers']['transfer-encoding'] ) && 'chunked' == $processedHeaders['headers']['transfer-encoding'] )
|
if ( ! empty( $strResponse ) && isset( $processedHeaders['headers']['transfer-encoding'] ) && 'chunked' == $processedHeaders['headers']['transfer-encoding'] )
|
||||||
$strResponse = WP_Http::chunkTransferDecode($strResponse);
|
$strResponse = WP_Http::chunkTransferDecode($strResponse);
|
||||||
|
|
||||||
@ -949,9 +962,6 @@ class WP_Http_ExtHttp {
|
|||||||
)
|
)
|
||||||
);
|
);
|
||||||
|
|
||||||
if ( HTTP_METH_HEAD == $r['method'] )
|
|
||||||
$options['redirect'] = 0; // Assumption: Docs seem to suggest that this means do not follow. Untested.
|
|
||||||
|
|
||||||
// The HTTP extensions offers really easy proxy support.
|
// The HTTP extensions offers really easy proxy support.
|
||||||
$proxy = new WP_HTTP_Proxy();
|
$proxy = new WP_HTTP_Proxy();
|
||||||
|
|
||||||
@ -1116,8 +1126,7 @@ class WP_Http_Curl {
|
|||||||
curl_setopt( $handle, CURLOPT_HEADER, false );
|
curl_setopt( $handle, CURLOPT_HEADER, false );
|
||||||
|
|
||||||
// The option doesn't work with safe mode or when open_basedir is set.
|
// The option doesn't work with safe mode or when open_basedir is set.
|
||||||
// Disable HEAD when making HEAD requests.
|
if ( !ini_get('safe_mode') && !ini_get('open_basedir') && 0 !== $r['_redirection'] )
|
||||||
if ( !ini_get('safe_mode') && !ini_get('open_basedir') && 'HEAD' != $r['method'] )
|
|
||||||
curl_setopt( $handle, CURLOPT_FOLLOWLOCATION, true );
|
curl_setopt( $handle, CURLOPT_FOLLOWLOCATION, true );
|
||||||
|
|
||||||
if ( !empty( $r['headers'] ) ) {
|
if ( !empty( $r['headers'] ) ) {
|
||||||
@ -1176,7 +1185,7 @@ class WP_Http_Curl {
|
|||||||
curl_close( $handle );
|
curl_close( $handle );
|
||||||
|
|
||||||
// See #11305 - When running under safe mode, redirection is disabled above. Handle it manually.
|
// See #11305 - 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 ( !empty($theHeaders['headers']['location']) && (ini_get('safe_mode') || ini_get('open_basedir')) && 0 !== $r['_redirection'] ) {
|
||||||
if ( $r['redirection']-- > 0 ) {
|
if ( $r['redirection']-- > 0 ) {
|
||||||
return $this->request($theHeaders['headers']['location'], $r);
|
return $this->request($theHeaders['headers']['location'], $r);
|
||||||
} else {
|
} else {
|
||||||
|
Loading…
Reference in New Issue
Block a user