mirror of
https://github.com/kamilwylegala/cakephp2-php8.git
synced 2025-01-19 11:06:15 +00:00
Making RequestHandler component carry along a passed status code. This fixes issues where RequestHandler hijacks an redirect(). Fixes #658
This commit is contained in:
parent
c48f6d6536
commit
95dbae8acf
2 changed files with 25 additions and 5 deletions
|
@ -262,7 +262,7 @@ class RequestHandlerComponent extends Object {
|
||||||
* @param mixed $url A string or array containing the redirect location
|
* @param mixed $url A string or array containing the redirect location
|
||||||
* @access public
|
* @access public
|
||||||
*/
|
*/
|
||||||
function beforeRedirect(&$controller, $url) {
|
function beforeRedirect(&$controller, $url, $status = null) {
|
||||||
if (!$this->isAjax()) {
|
if (!$this->isAjax()) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -272,6 +272,12 @@ class RequestHandlerComponent extends Object {
|
||||||
if (is_array($url)) {
|
if (is_array($url)) {
|
||||||
$url = Router::url($url + array('base' => false));
|
$url = Router::url($url + array('base' => false));
|
||||||
}
|
}
|
||||||
|
if (!empty($status)) {
|
||||||
|
$statusCode = $controller->httpCodes($status);
|
||||||
|
$code = key($statusCode);
|
||||||
|
$msg = $statusCode[$code];
|
||||||
|
$controller->header("HTTP/1.1 {$code} {$msg}");
|
||||||
|
}
|
||||||
echo $this->requestAction($url, array('return'));
|
echo $this->requestAction($url, array('return'));
|
||||||
$this->_stop();
|
$this->_stop();
|
||||||
}
|
}
|
||||||
|
|
|
@ -21,6 +21,7 @@ App::import('Controller', 'Controller', false);
|
||||||
App::import('Component', array('RequestHandler'));
|
App::import('Component', array('RequestHandler'));
|
||||||
|
|
||||||
Mock::generatePartial('RequestHandlerComponent', 'NoStopRequestHandler', array('_stop'));
|
Mock::generatePartial('RequestHandlerComponent', 'NoStopRequestHandler', array('_stop'));
|
||||||
|
Mock::generatePartial('Controller', 'RequestHandlerMockController', array('header'));
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* RequestHandlerTestController class
|
* RequestHandlerTestController class
|
||||||
|
@ -602,9 +603,7 @@ class RequestHandlerComponentTest extends CakeTestCase {
|
||||||
*/
|
*/
|
||||||
function testBeforeRedirectCallbackWithArrayUrl() {
|
function testBeforeRedirectCallbackWithArrayUrl() {
|
||||||
$_SERVER['HTTP_X_REQUESTED_WITH'] = 'XMLHttpRequest';
|
$_SERVER['HTTP_X_REQUESTED_WITH'] = 'XMLHttpRequest';
|
||||||
App::build(array(
|
|
||||||
'views' => array(TEST_CAKE_CORE_INCLUDE_PATH . 'tests' . DS . 'test_app' . DS . 'views'. DS)
|
|
||||||
), true);
|
|
||||||
Router::setRequestInfo(array(
|
Router::setRequestInfo(array(
|
||||||
array('plugin' => null, 'controller' => 'accounts', 'action' => 'index', 'pass' => array(), 'named' => array(), 'form' => array(), 'url' => array('url' => 'accounts/'), 'bare' => 0),
|
array('plugin' => null, 'controller' => 'accounts', 'action' => 'index', 'pass' => array(), 'named' => array(), 'form' => array(), 'url' => array('url' => 'accounts/'), 'bare' => 0),
|
||||||
array('base' => '/officespace', 'here' => '/officespace/accounts/', 'webroot' => '/officespace/')
|
array('base' => '/officespace', 'here' => '/officespace/accounts/', 'webroot' => '/officespace/')
|
||||||
|
@ -619,7 +618,22 @@ class RequestHandlerComponentTest extends CakeTestCase {
|
||||||
);
|
);
|
||||||
$result = ob_get_clean();
|
$result = ob_get_clean();
|
||||||
$this->assertEqual($result, 'one: first two: second');
|
$this->assertEqual($result, 'one: first two: second');
|
||||||
App::build();
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* assure that beforeRedirect with a status code will correctly set the status header
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
function testBeforeRedirectCallingHeader() {
|
||||||
|
$controller =& new RequestHandlerMockController();
|
||||||
|
$RequestHandler =& new NoStopRequestHandler();
|
||||||
|
|
||||||
|
$controller->expectOnce('header', array('HTTP/1.1 403 Forbidden'));
|
||||||
|
|
||||||
|
ob_start();
|
||||||
|
$RequestHandler->beforeRedirect($controller, 'request_handler_test/param_method/first/second', 403);
|
||||||
|
$result = ob_get_clean();
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Reference in a new issue