diff options
Diffstat (limited to 'php-symfony-pr15249.patch')
-rw-r--r-- | php-symfony-pr15249.patch | 173 |
1 files changed, 0 insertions, 173 deletions
diff --git a/php-symfony-pr15249.patch b/php-symfony-pr15249.patch deleted file mode 100644 index fc41718..0000000 --- a/php-symfony-pr15249.patch +++ /dev/null @@ -1,173 +0,0 @@ -From eb80fbb48ce47070507918fd692f8c20f65816dd Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?K=C3=A9vin=20Dunglas?= <dunglas@gmail.com> -Date: Thu, 9 Jul 2015 11:23:44 +0200 -Subject: [PATCH 1/3] [HttpFoundation] Allow to use resources as content body - and to return resources from string content. - ---- - src/Symfony/Component/HttpFoundation/Request.php | 52 +++++++++++++++------- - .../Component/HttpFoundation/Tests/RequestTest.php | 20 +++++++++ - 2 files changed, 57 insertions(+), 15 deletions(-) - -diff --git a/src/Symfony/Component/HttpFoundation/Request.php b/src/Symfony/Component/HttpFoundation/Request.php -index 84b3a69..6fa20ac 100644 ---- a/src/Symfony/Component/HttpFoundation/Request.php -+++ b/src/Symfony/Component/HttpFoundation/Request.php -@@ -199,13 +199,13 @@ class Request - /** - * Constructor. - * -- * @param array $query The GET parameters -- * @param array $request The POST parameters -- * @param array $attributes The request attributes (parameters parsed from the PATH_INFO, ...) -- * @param array $cookies The COOKIE parameters -- * @param array $files The FILES parameters -- * @param array $server The SERVER parameters -- * @param string $content The raw body data -+ * @param array $query The GET parameters -+ * @param array $request The POST parameters -+ * @param array $attributes The request attributes (parameters parsed from the PATH_INFO, ...) -+ * @param array $cookies The COOKIE parameters -+ * @param array $files The FILES parameters -+ * @param array $server The SERVER parameters -+ * @param string|resource $content The raw body data - * - * @api - */ -@@ -219,13 +219,13 @@ public function __construct(array $query = array(), array $request = array(), ar - * - * This method also re-initializes all properties. - * -- * @param array $query The GET parameters -- * @param array $request The POST parameters -- * @param array $attributes The request attributes (parameters parsed from the PATH_INFO, ...) -- * @param array $cookies The COOKIE parameters -- * @param array $files The FILES parameters -- * @param array $server The SERVER parameters -- * @param string $content The raw body data -+ * @param array $query The GET parameters -+ * @param array $request The POST parameters -+ * @param array $attributes The request attributes (parameters parsed from the PATH_INFO, ...) -+ * @param array $cookies The COOKIE parameters -+ * @param array $files The FILES parameters -+ * @param array $server The SERVER parameters -+ * @param string|resource $content The raw body data - * - * @api - */ -@@ -1465,16 +1465,38 @@ public function isMethodSafe() - */ - public function getContent($asResource = false) - { -- if (PHP_VERSION_ID < 50600 && (false === $this->content || (true === $asResource && null !== $this->content))) { -+ $currentContentIsResource = is_resource($this->content); -+ if (PHP_VERSION_ID < 50600 && !$currentContentIsResource && (false === $this->content || (true === $asResource && null !== $this->content))) { - throw new \LogicException('getContent() can only be called once when using the resource return type and PHP below 5.6.'); - } - - if (true === $asResource) { -+ if ($currentContentIsResource) { -+ rewind($this->content); -+ -+ return $this->content; -+ } -+ -+ // Content passed in parameter (test) -+ if (is_string($this->content)) { -+ $resource = fopen('php://temp','r+'); -+ fwrite($resource, $this->content); -+ rewind($resource); -+ -+ return $resource; -+ } -+ - $this->content = false; - - return fopen('php://input', 'rb'); - } - -+ if ($currentContentIsResource) { -+ rewind($this->content); -+ -+ return stream_get_contents($this->content); -+ } -+ - if (null === $this->content) { - $this->content = file_get_contents('php://input'); - } -diff --git a/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php b/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -index 366b555..fcc73f5 100644 ---- a/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -+++ b/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -@@ -923,6 +923,26 @@ public function testGetContentReturnsResource() - $this->assertTrue(feof($retval)); - } - -+ public function testGetContentReturnsResourceWhenContentSetInConstructor() -+ { -+ $req = new Request(array(), array(), array(), array(), array(), array(), 'MyContent'); -+ $resource = $req->getContent(true); -+ -+ $this->assertTrue(is_resource($resource)); -+ $this->assertEquals('MyContent', stream_get_contents($resource)); -+ } -+ -+ public function testContentAsResource() -+ { -+ $resource = fopen('php://memory','r+'); -+ fwrite($resource, 'My other content'); -+ rewind($resource); -+ -+ $req = new Request(array(), array(), array(), array(), array(), array(), $resource); -+ $this->assertEquals('My other content', stream_get_contents($req->getContent(true))); -+ $this->assertEquals('My other content', $req->getContent()); -+ } -+ - /** - * @expectedException \LogicException - * @dataProvider getContentCantBeCalledTwiceWithResourcesProvider - -From bb6db5768b5bb7e3b1f5e71656d3ddf779151006 Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?K=C3=A9vin=20Dunglas?= <dunglas@gmail.com> -Date: Thu, 16 Jul 2015 08:17:59 +0200 -Subject: [PATCH 2/3] Simplify condition - ---- - src/Symfony/Component/HttpFoundation/Request.php | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - -diff --git a/src/Symfony/Component/HttpFoundation/Request.php b/src/Symfony/Component/HttpFoundation/Request.php -index 6fa20ac..2d28251 100644 ---- a/src/Symfony/Component/HttpFoundation/Request.php -+++ b/src/Symfony/Component/HttpFoundation/Request.php -@@ -1466,7 +1466,7 @@ public function isMethodSafe() - public function getContent($asResource = false) - { - $currentContentIsResource = is_resource($this->content); -- if (PHP_VERSION_ID < 50600 && !$currentContentIsResource && (false === $this->content || (true === $asResource && null !== $this->content))) { -+ if (PHP_VERSION_ID < 50600 && false === $this->content) { - throw new \LogicException('getContent() can only be called once when using the resource return type and PHP below 5.6.'); - } - - -From fc90cfa0c70677b5b119cbbd882059552468d84b Mon Sep 17 00:00:00 2001 -From: =?UTF-8?q?K=C3=A9vin=20Dunglas?= <dunglas@gmail.com> -Date: Thu, 16 Jul 2015 08:34:36 +0200 -Subject: [PATCH 3/3] Fix test - ---- - src/Symfony/Component/HttpFoundation/Tests/RequestTest.php | 1 - - 1 file changed, 1 deletion(-) - -diff --git a/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php b/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -index fcc73f5..797a00a 100644 ---- a/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -+++ b/src/Symfony/Component/HttpFoundation/Tests/RequestTest.php -@@ -987,7 +987,6 @@ public function getContentCantBeCalledTwiceWithResourcesProvider() - return array( - 'Resource then fetch' => array(true, false), - 'Resource then resource' => array(true, true), -- 'Fetch then resource' => array(false, true), - ); - } - |