From f7eab23a5c03b4f323e1445e3129b54da56793d3 Mon Sep 17 00:00:00 2001 From: Phally Date: Fri, 26 Jul 2013 12:05:45 +0200 Subject: [PATCH] Strips the base off the generated URL from the AuthComponent. Fixes #3922. --- .../Controller/Component/AuthComponent.php | 2 +- .../Component/AuthComponentTest.php | 35 +++++++++++++++++++ 2 files changed, 36 insertions(+), 1 deletion(-) diff --git a/lib/Cake/Controller/Component/AuthComponent.php b/lib/Cake/Controller/Component/AuthComponent.php index 833b5f40f..621c97fc5 100644 --- a/lib/Cake/Controller/Component/AuthComponent.php +++ b/lib/Cake/Controller/Component/AuthComponent.php @@ -677,7 +677,7 @@ class AuthComponent extends Component { $redir = '/'; } if (is_array($redir)) { - return Router::url($redir); + return Router::url($redir + array('base' => false)); } return $redir; } diff --git a/lib/Cake/Test/Case/Controller/Component/AuthComponentTest.php b/lib/Cake/Test/Case/Controller/Component/AuthComponentTest.php index 4855928f5..73e70704a 100644 --- a/lib/Cake/Test/Case/Controller/Component/AuthComponentTest.php +++ b/lib/Cake/Test/Case/Controller/Component/AuthComponentTest.php @@ -1268,6 +1268,41 @@ class AuthComponentTest extends CakeTestCase { $this->assertFalse($this->Auth->Session->check('Auth.redirect')); } +/** + * test that the returned URL doesn't contain the base URL. + * + * @see https://cakephp.lighthouseapp.com/projects/42648/tickets/3922-authcomponentredirecturl-prepends-appbaseurl + * + * @return void This test method doesn't return anything. + */ + public function testRedirectUrlWithBaseSet() { + $App = Configure::read('App'); + + Configure::write('App', array( + 'dir' => APP_DIR, + 'webroot' => WEBROOT_DIR, + 'base' => false, + 'baseUrl' => '/cake/index.php' + )); + + $url = '/users/login'; + $this->Auth->request = $this->Controller->request = new CakeRequest($url); + $this->Auth->request->addParams(Router::parse($url)); + $this->Auth->request->url = Router::normalize($url); + + Router::setRequestInfo($this->Auth->request); + + $this->Auth->loginAction = array('controller' => 'users', 'action' => 'login'); + $this->Auth->loginRedirect = array('controller' => 'users', 'action' => 'home'); + + $result = $this->Auth->redirectUrl(); + $this->assertEquals('/users/home', $result); + $this->assertFalse($this->Auth->Session->check('Auth.redirect')); + + Configure::write('App', $App); + Router::reload(); + } + /** * test password hashing *