3 * Zend Framework (http://framework.zend.com/)
5 * @link http://github.com/zendframework/zf2 for the canonical source repository
6 * @copyright Copyright (c) 2005-2015 Zend Technologies USA Inc. (http://www.zend.com)
7 * @license http://framework.zend.com/license/new-bsd New BSD License
10 namespace Zend\Feed\Reader\Http;
12 use Zend\Feed\Reader\Exception;
13 use Zend\Http\Client as ZendHttpClient;
14 use Zend\Http\Headers;
16 class ZendHttpClientDecorator implements HeaderAwareClientInterface
24 * @param ZendHttpClient $client
26 public function __construct(ZendHttpClient $client)
28 $this->client = $client;
32 * @return ZendHttpClient
34 public function getDecoratedClient()
42 public function get($uri, array $headers = [])
44 $this->client->resetParameters();
45 $this->client->setMethod('GET');
46 $this->client->setHeaders(new Headers());
47 $this->client->setUri($uri);
48 if (! empty($headers)) {
49 $this->injectHeaders($headers);
51 $response = $this->client->send();
54 $response->getStatusCode(),
56 $this->prepareResponseHeaders($response->getHeaders())
61 * Inject header values into the client.
63 * @param array $headerValues
65 private function injectHeaders(array $headerValues)
67 $headers = $this->client->getRequest()->getHeaders();
68 foreach ($headerValues as $name => $values) {
69 if (! is_string($name) || is_numeric($name) || empty($name)) {
70 throw new Exception\InvalidArgumentException(sprintf(
71 'Header names provided to %s::get must be non-empty, non-numeric strings; received %s',
77 if (! is_array($values)) {
78 throw new Exception\InvalidArgumentException(sprintf(
79 'Header values provided to %s::get must be arrays of values; received %s',
81 (is_object($values) ? get_class($values) : gettype($values))
85 foreach ($values as $value) {
86 if (! is_string($value) && ! is_numeric($value)) {
87 throw new Exception\InvalidArgumentException(sprintf(
88 'Individual header values provided to %s::get must be strings or numbers; '
89 . 'received %s for header %s',
91 (is_object($value) ? get_class($value) : gettype($value)),
96 $headers->addHeaderLine($name, $value);
102 * Normalize headers to use with HeaderAwareResponseInterface.
104 * Ensures multi-value headers are represented as a single string, via
105 * comma concatenation.
107 * @param Headers $headers
110 private function prepareResponseHeaders(Headers $headers)
113 foreach ($headers->toArray() as $name => $value) {
114 $normalized[$name] = is_array($value) ? implode(', ', $value) : $value;