From 2be9ac8888aa3a0dd2a4b40353dc6e158a7112c8 Mon Sep 17 00:00:00 2001 From: Frank de Graaf Date: Fri, 4 May 2012 16:58:51 +0200 Subject: [PATCH] Fixed HTTP status codes for non-redirects which were breaking AuthComponent. --- lib/Cake/Controller/Controller.php | 17 ++++++++--------- .../Test/Case/Controller/ControllerTest.php | 5 +++-- 2 files changed, 11 insertions(+), 11 deletions(-) diff --git a/lib/Cake/Controller/Controller.php b/lib/Cake/Controller/Controller.php index 25427a544..ec862aec5 100644 --- a/lib/Cake/Controller/Controller.php +++ b/lib/Cake/Controller/Controller.php @@ -531,7 +531,7 @@ class Controller extends Object implements CakeEventListener { } /** - * Merge components, helpers, and uses vars from + * Merge components, helpers, and uses vars from * Controller::$_mergeParent and PluginAppController. * * @return void @@ -770,18 +770,17 @@ class Controller extends Object implements CakeEventListener { session_write_close(); } - if (!empty($status) && is_string($status)) { - $codes = array_flip($this->response->httpCodes()); - if (isset($codes[$status])) { - $status = $codes[$status]; - } - } - if ($url !== null) { $this->response->header('Location', Router::url($url, true)); } - if (!empty($status) && ($status >= 300 && $status < 400)) { + if (!empty($status)) { + if (is_string($status)) { + $codes = array_flip($this->response->httpCodes()); + if (isset($codes[$status])) { + $status = $codes[$status]; + } + } $this->response->statusCode($status); } diff --git a/lib/Cake/Test/Case/Controller/ControllerTest.php b/lib/Cake/Test/Case/Controller/ControllerTest.php index b77a35bf3..33bc9678b 100644 --- a/lib/Cake/Test/Case/Controller/ControllerTest.php +++ b/lib/Cake/Test/Case/Controller/ControllerTest.php @@ -387,7 +387,7 @@ class AnotherTestController extends ControllerTestAppController { /** * merge parent - * + * * @var string */ protected $_mergeParent = 'ControllerTestAppController'; @@ -728,7 +728,8 @@ class ControllerTest extends CakeTestCase { array(303, "See Other"), array(304, "Not Modified"), array(305, "Use Proxy"), - array(307, "Temporary Redirect") + array(307, "Temporary Redirect"), + array(403, "Forbidden"), ); }