Version 1
[yaffs-website] / vendor / zendframework / zend-feed / src / Reader / Http / ZendHttpClientDecorator.php
diff --git a/vendor/zendframework/zend-feed/src/Reader/Http/ZendHttpClientDecorator.php b/vendor/zendframework/zend-feed/src/Reader/Http/ZendHttpClientDecorator.php
new file mode 100644 (file)
index 0000000..dbff993
--- /dev/null
@@ -0,0 +1,118 @@
+<?php
+/**
+ * Zend Framework (http://framework.zend.com/)
+ *
+ * @link      http://github.com/zendframework/zf2 for the canonical source repository
+ * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
+ * @license   http://framework.zend.com/license/new-bsd New BSD License
+ */
+
+namespace Zend\Feed\Reader\Http;
+
+use Zend\Http\Client as ZendHttpClient;
+use Zend\Http\Headers;
+use Zend\Feed\Reader\Exception;
+
+class ZendHttpClientDecorator implements HeaderAwareClientInterface
+{
+    /**
+     * @var ZendHttpClient
+     */
+    private $client;
+
+    /**
+     * @param ZendHttpClient $client
+     */
+    public function __construct(ZendHttpClient $client)
+    {
+        $this->client = $client;
+    }
+
+    /**
+     * @return ZendHttpClient
+     */
+    public function getDecoratedClient()
+    {
+        return $this->client;
+    }
+
+    /**
+     * {@inheritDoc}
+     */
+    public function get($uri, array $headers = [])
+    {
+        $this->client->resetParameters();
+        $this->client->setMethod('GET');
+        $this->client->setHeaders(new Headers());
+        $this->client->setUri($uri);
+        if (! empty($headers)) {
+            $this->injectHeaders($headers);
+        }
+        $response = $this->client->send();
+
+        return new Response(
+            $response->getStatusCode(),
+            $response->getBody(),
+            $this->prepareResponseHeaders($response->getHeaders())
+        );
+    }
+
+    /**
+     * Inject header values into the client.
+     *
+     * @param array $headerValues
+     */
+    private function injectHeaders(array $headerValues)
+    {
+        $headers = $this->client->getRequest()->getHeaders();
+        foreach ($headerValues as $name => $values) {
+            if (! is_string($name) || is_numeric($name) || empty($name)) {
+                throw new Exception\InvalidArgumentException(sprintf(
+                    'Header names provided to %s::get must be non-empty, non-numeric strings; received %s',
+                    __CLASS__,
+                    $name
+                ));
+            }
+
+            if (! is_array($values)) {
+                throw new Exception\InvalidArgumentException(sprintf(
+                    'Header values provided to %s::get must be arrays of values; received %s',
+                    __CLASS__,
+                    (is_object($values) ? get_class($values) : gettype($values))
+                ));
+            }
+
+            foreach ($values as $value) {
+                if (! is_string($value) && ! is_numeric($value)) {
+                    throw new Exception\InvalidArgumentException(sprintf(
+                        'Individual header values provided to %s::get must be strings or numbers; '
+                        . 'received %s for header %s',
+                        __CLASS__,
+                        (is_object($value) ? get_class($value) : gettype($value)),
+                        $name
+                    ));
+                }
+
+                $headers->addHeaderLine($name, $value);
+            }
+        }
+    }
+
+    /**
+     * Normalize headers to use with HeaderAwareResponseInterface.
+     *
+     * Ensures multi-value headers are represented as a single string, via
+     * comma concatenation.
+     *
+     * @param Headers $headers
+     * @return array
+     */
+    private function prepareResponseHeaders(Headers $headers)
+    {
+        $normalized = [];
+        foreach ($headers->toArray() as $name => $value) {
+            $normalized[$name] = is_array($value) ? implode(', ', $value) : $value;
+        }
+        return $normalized;
+    }
+}