From 6fefa13d79d56b1ca15d0154261837ca8d44db0f 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 620f2a2e..c601755d 100644 --- a/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php +++ b/src/Middleware/UnauthorizedHandler/CakeRedirectHandler.php @@ -69,10 +69,6 @@ protected function getUrl(ServerRequestInterface $request, array $options): stri $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 49ca85f4..33d8aa94 100644 --- a/src/Middleware/UnauthorizedHandler/RedirectHandler.php +++ b/src/Middleware/UnauthorizedHandler/RedirectHandler.php @@ -101,10 +101,6 @@ protected function getUrl(ServerRequestInterface $request, array $options): stri $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 79c77ee6..a03775e6 100644 --- a/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php +++ b/tests/TestCase/Middleware/UnauthorizedHandler/CakeRedirectHandlerTest.php @@ -145,7 +145,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 f5e65422..9e75d125 100644 --- a/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php +++ b/tests/TestCase/Middleware/UnauthorizedHandler/RedirectHandlerTest.php @@ -146,7 +146,7 @@ public function testHandleRedirectWithBasePath() $this->assertEquals(302, $response->getStatusCode()); $this->assertEquals( - '/basedir/login?redirect=%2Fbasedir%2Fpath', + '/basedir/login?redirect=%2Fpath', $response->getHeaderLine('Location') ); }