Allow the cURL transport to handle '0' response bodies. Fixes #17223

git-svn-id: http://svn.automattic.com/wordpress/trunk@17692 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
dd32 2011-04-23 13:49:52 +00:00
parent 26cc29597b
commit ad5f5db861
1 changed files with 2 additions and 2 deletions

View File

@ -1091,11 +1091,11 @@ class WP_Http_Curl {
$theBody = ''; $theBody = '';
$theHeaders = WP_Http::processHeaders( $this->headers ); $theHeaders = WP_Http::processHeaders( $this->headers );
if ( ! empty($theResponse) && ! is_bool( $theResponse ) ) // is_bool: when using $args['stream'], curl_exec will return (bool)true if ( strlen($theResponse) > 0 && ! is_bool( $theResponse ) ) // is_bool: when using $args['stream'], curl_exec will return (bool)true
$theBody = $theResponse; $theBody = $theResponse;
// If no response, and It's not a HEAD request with valid headers returned // If no response, and It's not a HEAD request with valid headers returned
if ( empty($theResponse) && ('HEAD' != $args['method'] || empty($this->headers)) ) { if ( 0 == strlen($theResponse) && ('HEAD' != $args['method'] || empty($this->headers)) ) {
if ( $curl_error = curl_error($handle) ) if ( $curl_error = curl_error($handle) )
return new WP_Error('http_request_failed', $curl_error); return new WP_Error('http_request_failed', $curl_error);
if ( in_array( curl_getinfo( $handle, CURLINFO_HTTP_CODE ), array(301, 302) ) ) if ( in_array( curl_getinfo( $handle, CURLINFO_HTTP_CODE ), array(301, 302) ) )