Thanks to visit codestin.com
Credit goes to github.com

Skip to content

Commit 6a9c510

Browse files
committed
fixed the IP address in HttpCache when calling the backend
1 parent e0637fa commit 6a9c510

File tree

4 files changed

+27
-0
lines changed

4 files changed

+27
-0
lines changed

src/Symfony/Component/HttpKernel/HttpCache/HttpCache.php

Lines changed: 4 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -413,6 +413,10 @@ protected function fetch(Request $request, $catch = false)
413413
$subRequest->headers->remove('if_modified_since');
414414
$subRequest->headers->remove('if_none_match');
415415

416+
// fix the client IP address by setting it to 127.0.0.1 as HttpCache
417+
// is always called from the same process as the backend.
418+
$subRequest->server->set('REMOTE_ADDR', '127.0.0.1');
419+
416420
$response = $this->forward($subRequest, $catch);
417421

418422
if ($this->isPrivateRequest($request) && !$response->headers->hasCacheControlDirective('public')) {

src/Symfony/Component/HttpKernel/Tests/HttpCache/HttpCacheTest.php

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -1034,4 +1034,12 @@ public function testEsiRecalculateContentLengthHeader()
10341034
$this->assertEquals('Hello World!', $this->response->getContent());
10351035
$this->assertEquals(12, $this->response->headers->get('Content-Length'));
10361036
}
1037+
1038+
public function testClientIpIsAlwaysLocalhostForForwardedRequests()
1039+
{
1040+
$this->setNextResponse();
1041+
$this->request('GET', '/', array('REMOTE_ADDR' => '10.0.0.1'));
1042+
1043+
$this->assertEquals('127.0.0.1', $this->kernel->getBackendRequest()->server->get('REMOTE_ADDR'));
1044+
}
10371045
}

src/Symfony/Component/HttpKernel/Tests/HttpCache/TestHttpKernel.php

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -26,6 +26,7 @@ class TestHttpKernel extends HttpKernel implements ControllerResolverInterface
2626
protected $called;
2727
protected $customizer;
2828
protected $catch;
29+
protected $backendRequest;
2930

3031
public function __construct($body, $status, $headers, \Closure $customizer = null)
3132
{
@@ -39,9 +40,15 @@ public function __construct($body, $status, $headers, \Closure $customizer = nul
3940
parent::__construct(new EventDispatcher(), $this);
4041
}
4142

43+
public function getBackendRequest()
44+
{
45+
return $this->backendRequest;
46+
}
47+
4248
public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = false)
4349
{
4450
$this->catch = $catch;
51+
$this->backendRequest = $request;
4552

4653
return parent::handle($request, $type, $catch);
4754
}

src/Symfony/Component/HttpKernel/Tests/HttpCache/TestMultipleHttpKernel.php

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -25,6 +25,7 @@ class TestMultipleHttpKernel extends HttpKernel implements ControllerResolverInt
2525
protected $headers;
2626
protected $catch;
2727
protected $call;
28+
protected $backendRequest;
2829

2930
public function __construct($responses)
3031
{
@@ -42,8 +43,15 @@ public function __construct($responses)
4243
parent::__construct(new EventDispatcher(), $this);
4344
}
4445

46+
public function getBackendRequest()
47+
{
48+
return $this->backendRequest;
49+
}
50+
4551
public function handle(Request $request, $type = HttpKernelInterface::MASTER_REQUEST, $catch = false)
4652
{
53+
$this->backendRequest = $request;
54+
4755
return parent::handle($request, $type, $catch);
4856
}
4957

0 commit comments

Comments
 (0)