REST API: Add support for the REDIRECT_HTTP_AUTHORIZATION header.
Previously the REST API did not account for server configurations where the Authorization header must be added using ModRewrite. This caused major DUX issues when trying to use custom authentication mechanisms. Fixes #47077. Props dshanske, cklosows. git-svn-id: https://develop.svn.wordpress.org/trunk@47239 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
2c795289c8
commit
e7399111b4
@ -1380,6 +1380,12 @@ class WP_REST_Server {
|
|||||||
foreach ( $server as $key => $value ) {
|
foreach ( $server as $key => $value ) {
|
||||||
if ( strpos( $key, 'HTTP_' ) === 0 ) {
|
if ( strpos( $key, 'HTTP_' ) === 0 ) {
|
||||||
$headers[ substr( $key, 5 ) ] = $value;
|
$headers[ substr( $key, 5 ) ] = $value;
|
||||||
|
} elseif ( 'REDIRECT_HTTP_AUTHORIZATION' === $key && empty( $server['HTTP_AUTHORIZATION'] ) ) {
|
||||||
|
/*
|
||||||
|
* In some server configurations, the authorization header is passed in this alternate location.
|
||||||
|
* Since it would not be passed in in both places we do not check for both headers and resolve.
|
||||||
|
*/
|
||||||
|
$headers['AUTHORIZATION'] = $value;
|
||||||
} elseif ( isset( $additional[ $key ] ) ) {
|
} elseif ( isset( $additional[ $key ] ) ) {
|
||||||
$headers[ $key ] = $value;
|
$headers[ $key ] = $value;
|
||||||
}
|
}
|
||||||
|
@ -1373,6 +1373,64 @@ class Tests_REST_Server extends WP_Test_REST_TestCase {
|
|||||||
$this->assertEquals( '', rest_get_server()->sent_body );
|
$this->assertEquals( '', rest_get_server()->sent_body );
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 47077
|
||||||
|
*/
|
||||||
|
public function test_http_authorization_header_substitution() {
|
||||||
|
$headers = array( 'HTTP_AUTHORIZATION' => 'foo' );
|
||||||
|
$parsed_headers = rest_get_server()->get_headers( $headers );
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
array( 'AUTHORIZATION' => 'foo' ),
|
||||||
|
$parsed_headers
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 47077
|
||||||
|
*/
|
||||||
|
public function test_redirect_http_authorization_header_substitution() {
|
||||||
|
$headers = array( 'REDIRECT_HTTP_AUTHORIZATION' => 'foo' );
|
||||||
|
$parsed_headers = rest_get_server()->get_headers( $headers );
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
array( 'AUTHORIZATION' => 'foo' ),
|
||||||
|
$parsed_headers
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 47077
|
||||||
|
*/
|
||||||
|
public function test_redirect_http_authorization_with_http_authorization_header_substitution() {
|
||||||
|
$headers = array(
|
||||||
|
'HTTP_AUTHORIZATION' => 'foo',
|
||||||
|
'REDIRECT_HTTP_AUTHORIZATION' => 'bar',
|
||||||
|
);
|
||||||
|
$parsed_headers = rest_get_server()->get_headers( $headers );
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
array( 'AUTHORIZATION' => 'foo' ),
|
||||||
|
$parsed_headers
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @ticket 47077
|
||||||
|
*/
|
||||||
|
public function test_redirect_http_authorization_with_empty_http_authorization_header_substitution() {
|
||||||
|
$headers = array(
|
||||||
|
'HTTP_AUTHORIZATION' => '',
|
||||||
|
'REDIRECT_HTTP_AUTHORIZATION' => 'bar',
|
||||||
|
);
|
||||||
|
$parsed_headers = rest_get_server()->get_headers( $headers );
|
||||||
|
|
||||||
|
$this->assertSame(
|
||||||
|
array( 'AUTHORIZATION' => 'bar' ),
|
||||||
|
$parsed_headers
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
public function _validate_as_integer_123( $value, $request, $key ) {
|
public function _validate_as_integer_123( $value, $request, $key ) {
|
||||||
if ( ! is_int( $value ) ) {
|
if ( ! is_int( $value ) ) {
|
||||||
return new WP_Error( 'some-error', 'This is not valid!' );
|
return new WP_Error( 'some-error', 'This is not valid!' );
|
||||||
|
Loading…
Reference in New Issue
Block a user