Skip to content

Commit d98f783

Browse files
committed
bug symfony#31213 [WebProfilerBundle] Intercept redirections only for HTML format (javiereguiluz)
This PR was merged into the 3.4 branch. Discussion ---------- [WebProfilerBundle] Intercept redirections only for HTML format | Q | A | ------------- | --- | Branch? | 3.4 | Bug fix? | yes | New feature? | no <!-- don't forget to update src/**/CHANGELOG.md files --> | BC breaks? | no <!-- see https://symfony.com/bc --> | Deprecations? | no <!-- don't forget to update UPGRADE-*.md and src/**/CHANGELOG.md files --> | Tests pass? | yes <!-- please add some, will be required by reviewers --> | Fixed tickets | symfony#31168 | License | MIT | Doc PR | - This applies the solution proposed by @bpolaszek in symfony#31168. Commits ------- 4186788 Intercept redirections only for HTML format
2 parents 287da8d + 4186788 commit d98f783

File tree

2 files changed

+15
-2
lines changed

2 files changed

+15
-2
lines changed

src/Symfony/Bundle/WebProfilerBundle/EventListener/WebDebugToolbarListener.php

+1-1
Original file line numberDiff line numberDiff line change
@@ -87,7 +87,7 @@ public function onKernelResponse(FilterResponseEvent $event)
8787
return;
8888
}
8989

90-
if ($response->headers->has('X-Debug-Token') && $response->isRedirect() && $this->interceptRedirects) {
90+
if ($response->headers->has('X-Debug-Token') && $response->isRedirect() && $this->interceptRedirects && 'html' === $request->getRequestFormat()) {
9191
$session = $request->getSession();
9292
if (null !== $session && $session->isStarted() && $session->getFlashBag() instanceof AutoExpireFlashBag) {
9393
// keep current flashes for one more request if using AutoExpireFlashBag

src/Symfony/Bundle/WebProfilerBundle/Tests/EventListener/WebDebugToolbarListenerTest.php

+14-1
Original file line numberDiff line numberDiff line change
@@ -58,7 +58,7 @@ public function getInjectToolbarTests()
5858
/**
5959
* @dataProvider provideRedirects
6060
*/
61-
public function testRedirectionIsIntercepted($statusCode, $hasSession)
61+
public function testHtmlRedirectionIsIntercepted($statusCode, $hasSession)
6262
{
6363
$response = new Response('Some content', $statusCode);
6464
$response->headers->set('X-Debug-Token', 'xxxxxxxx');
@@ -71,6 +71,19 @@ public function testRedirectionIsIntercepted($statusCode, $hasSession)
7171
$this->assertEquals('Redirection', $response->getContent());
7272
}
7373

74+
public function testNonHtmlRedirectionIsNotIntercepted()
75+
{
76+
$response = new Response('Some content', '301');
77+
$response->headers->set('X-Debug-Token', 'xxxxxxxx');
78+
$event = new FilterResponseEvent($this->getKernelMock(), $this->getRequestMock(false, 'json', true), HttpKernelInterface::MASTER_REQUEST, $response);
79+
80+
$listener = new WebDebugToolbarListener($this->getTwigMock('Redirection'), true);
81+
$listener->onKernelResponse($event);
82+
83+
$this->assertEquals(301, $response->getStatusCode());
84+
$this->assertEquals('Some content', $response->getContent());
85+
}
86+
7487
public function testToolbarIsInjected()
7588
{
7689
$response = new Response('<html><head></head><body></body></html>');

0 commit comments

Comments
 (0)