feature #10912 [Form] Added support for injecting HttpFoundation's Request in ServerParams for the Validator extension (csarrazi)
This PR was merged into the 2.4-dev branch.
Discussion
----------
[Form] Added support for injecting HttpFoundation's Request in ServerParams for the Validator extension
| Q | A
| ------------- | ---
| Bug fix? | yes
| New feature? | yes
| BC breaks? | no
| Deprecations? | no
| Tests pass? | yes
| Fixed tickets | #10009
| License | MIT
| Doc PR | -
The Request object should be injected in the ```ServerParams``` object before using it in the extension, if one wishes to use Symfony2's ```Request``` to fetch the server parameters.
Commits
-------
86f9cb9
Added support for injecting HttpFoundation's RequestStack in ServerParams
This commit is contained in:
commit
5a4bf3e938
|
@ -11,11 +11,20 @@
|
|||
|
||||
namespace Symfony\Component\Form\Extension\Validator\Util;
|
||||
|
||||
use Symfony\Component\HttpFoundation\RequestStack;
|
||||
|
||||
/**
|
||||
* @author Bernhard Schussek <bschussek@gmail.com>
|
||||
*/
|
||||
class ServerParams
|
||||
{
|
||||
private $requestStack;
|
||||
|
||||
public function __construct(RequestStack $requestStack = null)
|
||||
{
|
||||
$this->requestStack = $requestStack;
|
||||
}
|
||||
|
||||
/**
|
||||
* Returns maximum post size in bytes.
|
||||
*
|
||||
|
@ -65,6 +74,10 @@ class ServerParams
|
|||
*/
|
||||
public function getContentLength()
|
||||
{
|
||||
if (null !== $this->requestStack && null !== $request = $this->requestStack->getCurrentRequest()) {
|
||||
return $request->server->get('CONTENT_LENGTH');
|
||||
}
|
||||
|
||||
return isset($_SERVER['CONTENT_LENGTH'])
|
||||
? (int) $_SERVER['CONTENT_LENGTH']
|
||||
: null;
|
||||
|
|
|
@ -11,8 +11,33 @@
|
|||
|
||||
namespace Symfony\Component\Form\Tests\Extension\Validator\Util;
|
||||
|
||||
use Symfony\Component\Form\Extension\Validator\Util\ServerParams;
|
||||
use Symfony\Component\HttpFoundation\Request;
|
||||
|
||||
class ServerParamsTest extends \PHPUnit_Framework_TestCase
|
||||
{
|
||||
public function testGetContentLengthFromSuperglobals()
|
||||
{
|
||||
$serverParams = new ServerParams();
|
||||
$this->assertNull($serverParams->getContentLength());
|
||||
|
||||
$_SERVER['CONTENT_LENGTH'] = 1024;
|
||||
|
||||
$this->assertEquals(1024, $serverParams->getContentLength());
|
||||
|
||||
unset($_SERVER['CONTENT_LENGTH']);
|
||||
}
|
||||
|
||||
public function testGetContentLengthFromRequest()
|
||||
{
|
||||
$request = Request::create('http://foo', 'GET', array(), array(), array(), array('CONTENT_LENGTH' => 1024));
|
||||
$requestStack = $this->getMock('Symfony\Component\HttpFoundation\RequestStack', array('getCurrentRequest'));
|
||||
$requestStack->expects($this->once())->method('getCurrentRequest')->will($this->returnValue($request));
|
||||
$serverParams = new ServerParams($requestStack);
|
||||
|
||||
$this->assertEquals(1024, $serverParams->getContentLength());
|
||||
}
|
||||
|
||||
/** @dataProvider getGetPostMaxSizeTestData */
|
||||
public function testGetPostMaxSize($size, $bytes)
|
||||
{
|
||||
|
|
Reference in New Issue