From 059ecdadce53da7fd94d6a5616937342d8e2624a Mon Sep 17 00:00:00 2001 From: Mark Story Date: Fri, 24 Jan 2020 21:58:04 -0500 Subject: [PATCH] Remove base dir from redirect urls Align the redirect parameter with the implementation in authentication. Having the base path present results in a double base path. See https://github.com/cakephp/authentication/pull/343 --- src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php | 4 ---- src/Middleware/UnauthorizedHandler/RedirectHandler.php | 4 ---- .../UnauthorizedHandler/CakeRedirectHandlerTest.php | 2 +- .../Middleware/UnauthorizedHandler/RedirectHandlerTest.php | 2 +- 4 files changed, 2 insertions(+), 10 deletions(-) diff --git a/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php b/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php index 72c121a4..e40580f1 100644 --- a/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php +++ b/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php @@ -65,10 +65,6 @@ protected function getUrl(ServerRequestInterface $request, array $options) $url = $options['url']; if ($options['queryParam'] !== null) { $uri = $request->getUri(); - /** @psalm-suppress NoInterfaceProperties */ - if (property_exists($uri, 'base')) { - $uri = $uri->withPath($uri->base . $uri->getPath()); - } $redirect = $uri->getPath(); if ($uri->getQuery()) { $redirect .= '?' . $uri->getQuery(); diff --git a/src/Middleware/UnauthorizedHandler/RedirectHandler.php b/src/Middleware/UnauthorizedHandler/RedirectHandler.php index 4d49c0da..705ea76e 100644 --- a/src/Middleware/UnauthorizedHandler/RedirectHandler.php +++ b/src/Middleware/UnauthorizedHandler/RedirectHandler.php @@ -94,10 +94,6 @@ protected function getUrl(ServerRequestInterface $request, array $options) $url = $options['url']; if ($options['queryParam'] !== null && $request->getMethod() === 'GET') { $uri = $request->getUri(); - /** @psalm-suppress NoInterfaceProperties */ - if (property_exists($uri, 'base')) { - $uri = $uri->withPath($uri->base . $uri->getPath()); - } $redirect = $uri->getPath(); if ($uri->getQuery()) { $redirect .= '?' . $uri->getQuery(); diff --git a/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php b/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php index 6eb41a93..8d25cc38 100644 --- a/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php +++ b/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php @@ -149,7 +149,7 @@ public function testHandleRedirectWithBasePath() $this->assertEquals(302, $response->getStatusCode()); $this->assertEquals( - '/basedir/login?redirect=%2Fbasedir%2Fadmin%2Fdashboard', + '/basedir/login?redirect=%2Fadmin%2Fdashboard', $response->getHeaderLine('Location') ); } diff --git a/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php b/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php index e8a3d8aa..c0ca1a83 100644 --- a/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php +++ b/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php @@ -150,7 +150,7 @@ public function testHandleRedirectWithBasePath() $this->assertEquals(302, $response->getStatusCode()); $this->assertEquals( - '/basedir/login?redirect=%2Fbasedir%2Fpath', + '/basedir/login?redirect=%2Fpath', $response->getHeaderLine('Location') ); }