WP_HTTP: Prevent the 'max_body_length' and 'stream_handle' properties of the curl class from leaking between requests by specifically initializing them in every case. See #23472 & r23605

git-svn-id: http://core.svn.wordpress.org/trunk@23609 1a063a9b-81f0-0310-95a4-ce76da25c4cd
This commit is contained in:
Dion Hulse 2013-03-04 05:40:43 +00:00
parent d4b814df2f
commit 1f7fc4281f
1 changed files with 4 additions and 0 deletions

View File

@ -1175,6 +1175,8 @@ class WP_Http_Curl {
if ( isset( $r['limit-response-size'] ) ) if ( isset( $r['limit-response-size'] ) )
$this->max_body_length = intval( $r['limit-response-size'] ); $this->max_body_length = intval( $r['limit-response-size'] );
else
$this->max_body_length = false;
// If streaming to a file open a file handle, and setup our curl streaming handler // If streaming to a file open a file handle, and setup our curl streaming handler
if ( $r['stream'] ) { if ( $r['stream'] ) {
@ -1184,6 +1186,8 @@ class WP_Http_Curl {
$this->stream_handle = fopen( $r['filename'], 'w+' ); $this->stream_handle = fopen( $r['filename'], 'w+' );
if ( ! $this->stream_handle ) if ( ! $this->stream_handle )
return new WP_Error( 'http_request_failed', sprintf( __( 'Could not open handle for fopen() to %s' ), $r['filename'] ) ); return new WP_Error( 'http_request_failed', sprintf( __( 'Could not open handle for fopen() to %s' ), $r['filename'] ) );
} else {
$this->stream_handle = false;
} }
if ( !empty( $r['headers'] ) ) { if ( !empty( $r['headers'] ) ) {