Laravel version update
Laravel version update
This commit is contained in:
		
							
								
								
									
										38
									
								
								vendor/guzzlehttp/guzzle/src/Client.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										38
									
								
								vendor/guzzlehttp/guzzle/src/Client.php
									
									
									
									
										vendored
									
									
								
							| @@ -63,6 +63,8 @@ class Client implements ClientInterface | ||||
|     { | ||||
|         if (!isset($config['handler'])) { | ||||
|             $config['handler'] = HandlerStack::create(); | ||||
|         } elseif (!is_callable($config['handler'])) { | ||||
|             throw new \InvalidArgumentException('handler must be a callable'); | ||||
|         } | ||||
|  | ||||
|         // Convert the base_uri to a UriInterface | ||||
| @@ -142,7 +144,7 @@ class Client implements ClientInterface | ||||
|         $uri = Psr7\uri_for($uri === null ? '' : $uri); | ||||
|  | ||||
|         if (isset($config['base_uri'])) { | ||||
|             $uri = Psr7\Uri::resolve(Psr7\uri_for($config['base_uri']), $uri); | ||||
|             $uri = Psr7\UriResolver::resolve(Psr7\uri_for($config['base_uri']), $uri); | ||||
|         } | ||||
|  | ||||
|         return $uri->getScheme() === '' && $uri->getHost() !== '' ? $uri->withScheme('http') : $uri; | ||||
| @@ -288,7 +290,14 @@ class Client implements ClientInterface | ||||
|      */ | ||||
|     private function applyOptions(RequestInterface $request, array &$options) | ||||
|     { | ||||
|         $modify = []; | ||||
|         $modify = [ | ||||
|             'set_headers' => [], | ||||
|         ]; | ||||
|  | ||||
|         if (isset($options['headers'])) { | ||||
|             $modify['set_headers'] = $options['headers']; | ||||
|             unset($options['headers']); | ||||
|         } | ||||
|  | ||||
|         if (isset($options['form_params'])) { | ||||
|             if (isset($options['multipart'])) { | ||||
| @@ -300,6 +309,8 @@ class Client implements ClientInterface | ||||
|             } | ||||
|             $options['body'] = http_build_query($options['form_params'], '', '&'); | ||||
|             unset($options['form_params']); | ||||
|             // Ensure that we don't have the header in different case and set the new value. | ||||
|             $options['_conditional'] = Psr7\_caseless_remove(['Content-Type'], $options['_conditional']); | ||||
|             $options['_conditional']['Content-Type'] = 'application/x-www-form-urlencoded'; | ||||
|         } | ||||
|  | ||||
| @@ -311,24 +322,19 @@ class Client implements ClientInterface | ||||
|         if (isset($options['json'])) { | ||||
|             $options['body'] = \GuzzleHttp\json_encode($options['json']); | ||||
|             unset($options['json']); | ||||
|             // Ensure that we don't have the header in different case and set the new value. | ||||
|             $options['_conditional'] = Psr7\_caseless_remove(['Content-Type'], $options['_conditional']); | ||||
|             $options['_conditional']['Content-Type'] = 'application/json'; | ||||
|         } | ||||
|  | ||||
|         if (!empty($options['decode_content']) | ||||
|             && $options['decode_content'] !== true | ||||
|         ) { | ||||
|             // Ensure that we don't have the header in different case and set the new value. | ||||
|             $options['_conditional'] = Psr7\_caseless_remove(['Accept-Encoding'], $options['_conditional']); | ||||
|             $modify['set_headers']['Accept-Encoding'] = $options['decode_content']; | ||||
|         } | ||||
|  | ||||
|         if (isset($options['headers'])) { | ||||
|             if (isset($modify['set_headers'])) { | ||||
|                 $modify['set_headers'] = $options['headers'] + $modify['set_headers']; | ||||
|             } else { | ||||
|                 $modify['set_headers'] = $options['headers']; | ||||
|             } | ||||
|             unset($options['headers']); | ||||
|         } | ||||
|  | ||||
|         if (isset($options['body'])) { | ||||
|             if (is_array($options['body'])) { | ||||
|                 $this->invalidBody(); | ||||
| @@ -342,6 +348,8 @@ class Client implements ClientInterface | ||||
|             $type = isset($value[2]) ? strtolower($value[2]) : 'basic'; | ||||
|             switch ($type) { | ||||
|                 case 'basic': | ||||
|                     // Ensure that we don't have the header in different case and set the new value. | ||||
|                     $modify['set_headers'] = Psr7\_caseless_remove(['Authorization'], $modify['set_headers']); | ||||
|                     $modify['set_headers']['Authorization'] = 'Basic ' | ||||
|                         . base64_encode("$value[0]:$value[1]"); | ||||
|                     break; | ||||
| @@ -350,6 +358,10 @@ class Client implements ClientInterface | ||||
|                     $options['curl'][CURLOPT_HTTPAUTH] = CURLAUTH_DIGEST; | ||||
|                     $options['curl'][CURLOPT_USERPWD] = "$value[0]:$value[1]"; | ||||
|                     break; | ||||
|                 case 'ntlm': | ||||
|                     $options['curl'][CURLOPT_HTTPAUTH] = CURLAUTH_NTLM; | ||||
|                     $options['curl'][CURLOPT_USERPWD] = "$value[0]:$value[1]"; | ||||
|                     break; | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -376,6 +388,8 @@ class Client implements ClientInterface | ||||
|         $request = Psr7\modify_request($request, $modify); | ||||
|         if ($request->getBody() instanceof Psr7\MultipartStream) { | ||||
|             // Use a multipart/form-data POST if a Content-Type is not set. | ||||
|             // Ensure that we don't have the header in different case and set the new value. | ||||
|             $options['_conditional'] = Psr7\_caseless_remove(['Content-Type'], $options['_conditional']); | ||||
|             $options['_conditional']['Content-Type'] = 'multipart/form-data; boundary=' | ||||
|                 . $request->getBody()->getBoundary(); | ||||
|         } | ||||
| @@ -402,7 +416,7 @@ class Client implements ClientInterface | ||||
|         throw new \InvalidArgumentException('Passing in the "body" request ' | ||||
|             . 'option as an array to send a POST request has been deprecated. ' | ||||
|             . 'Please use the "form_params" request option to send a ' | ||||
|             . 'application/x-www-form-urlencoded request, or a the "multipart" ' | ||||
|             . 'application/x-www-form-urlencoded request, or the "multipart" ' | ||||
|             . 'request option to send a multipart/form-data request.'); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -12,7 +12,7 @@ use Psr\Http\Message\UriInterface; | ||||
|  */ | ||||
| interface ClientInterface | ||||
| { | ||||
|     const VERSION = '6.2.1'; | ||||
|     const VERSION = '6.3.3'; | ||||
|  | ||||
|     /** | ||||
|      * Send an HTTP request. | ||||
|   | ||||
| @@ -86,6 +86,25 @@ class CookieJar implements CookieJarInterface | ||||
|         return false; | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Finds and returns the cookie based on the name | ||||
|      * | ||||
|      * @param string $name cookie name to search for | ||||
|      * @return SetCookie|null cookie that was found or null if not found | ||||
|      */ | ||||
|     public function getCookieByName($name) | ||||
|     { | ||||
|         // don't allow a null name | ||||
|         if ($name === null) { | ||||
|             return null; | ||||
|         } | ||||
|         foreach ($this->cookies as $cookie) { | ||||
|             if ($cookie->getName() !== null && strcasecmp($cookie->getName(), $name) === 0) { | ||||
|                 return $cookie; | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     public function toArray() | ||||
|     { | ||||
|         return array_map(function (SetCookie $cookie) { | ||||
| @@ -216,11 +235,41 @@ class CookieJar implements CookieJarInterface | ||||
|                 if (!$sc->getDomain()) { | ||||
|                     $sc->setDomain($request->getUri()->getHost()); | ||||
|                 } | ||||
|                 if (0 !== strpos($sc->getPath(), '/')) { | ||||
|                     $sc->setPath($this->getCookiePathFromRequest($request)); | ||||
|                 } | ||||
|                 $this->setCookie($sc); | ||||
|             } | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     /** | ||||
|      * Computes cookie path following RFC 6265 section 5.1.4 | ||||
|      * | ||||
|      * @link https://tools.ietf.org/html/rfc6265#section-5.1.4 | ||||
|      * | ||||
|      * @param RequestInterface $request | ||||
|      * @return string | ||||
|      */ | ||||
|     private function getCookiePathFromRequest(RequestInterface $request) | ||||
|     { | ||||
|         $uriPath = $request->getUri()->getPath(); | ||||
|         if (''  === $uriPath) { | ||||
|             return '/'; | ||||
|         } | ||||
|         if (0 !== strpos($uriPath, '/')) { | ||||
|             return '/'; | ||||
|         } | ||||
|         if ('/' === $uriPath) { | ||||
|             return '/'; | ||||
|         } | ||||
|         if (0 === $lastSlashPos = strrpos($uriPath, '/')) { | ||||
|             return '/'; | ||||
|         } | ||||
|  | ||||
|         return substr($uriPath, 0, $lastSlashPos); | ||||
|     } | ||||
|  | ||||
|     public function withCookieHeader(RequestInterface $request) | ||||
|     { | ||||
|         $values = []; | ||||
|   | ||||
| @@ -15,7 +15,7 @@ class SessionCookieJar extends CookieJar | ||||
|     /** | ||||
|      * Create a new SessionCookieJar object | ||||
|      * | ||||
|      * @param string $sessionKey        Session key name to store the cookie  | ||||
|      * @param string $sessionKey        Session key name to store the cookie | ||||
|      *                                  data in session | ||||
|      * @param bool $storeSessionCookies Set to true to store session cookies | ||||
|      *                                  in the cookie jar. | ||||
|   | ||||
| @@ -35,14 +35,13 @@ class SetCookie | ||||
|         $data = self::$defaults; | ||||
|         // Explode the cookie string using a series of semicolons | ||||
|         $pieces = array_filter(array_map('trim', explode(';', $cookie))); | ||||
|         // The name of the cookie (first kvp) must include an equal sign. | ||||
|         if (empty($pieces) || !strpos($pieces[0], '=')) { | ||||
|         // The name of the cookie (first kvp) must exist and include an equal sign. | ||||
|         if (empty($pieces[0]) || !strpos($pieces[0], '=')) { | ||||
|             return new self($data); | ||||
|         } | ||||
|  | ||||
|         // Add the cookie pieces into the parsed data array | ||||
|         foreach ($pieces as $part) { | ||||
|  | ||||
|             $cookieParts = explode('=', $part, 2); | ||||
|             $key = trim($cookieParts[0]); | ||||
|             $value = isset($cookieParts[1]) | ||||
| @@ -349,7 +348,7 @@ class SetCookie | ||||
|             return false; | ||||
|         } | ||||
|  | ||||
|         return (bool) preg_match('/\.' . preg_quote($cookieDomain) . '$/', $domain); | ||||
|         return (bool) preg_match('/\.' . preg_quote($cookieDomain, '/') . '$/', $domain); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -359,7 +358,7 @@ class SetCookie | ||||
|      */ | ||||
|     public function isExpired() | ||||
|     { | ||||
|         return $this->getExpires() && time() > $this->getExpires(); | ||||
|         return $this->getExpires() !== null && time() > $this->getExpires(); | ||||
|     } | ||||
|  | ||||
|     /** | ||||
| @@ -378,8 +377,8 @@ class SetCookie | ||||
|         // Check if any of the invalid characters are present in the cookie name | ||||
|         if (preg_match( | ||||
|             '/[\x00-\x20\x22\x28-\x29\x2c\x2f\x3a-\x40\x5c\x7b\x7d\x7f]/', | ||||
|             $name) | ||||
|         ) { | ||||
|             $name | ||||
|         )) { | ||||
|             return 'Cookie name must not contain invalid characters: ASCII ' | ||||
|                 . 'Control characters (0-31;127), space, tab and the ' | ||||
|                 . 'following characters: ()<>@,;:\"/?={}'; | ||||
|   | ||||
| @@ -1,7 +1,27 @@ | ||||
| <?php | ||||
| namespace GuzzleHttp\Exception; | ||||
|  | ||||
| use Psr\Http\Message\RequestInterface; | ||||
| use Psr\Http\Message\ResponseInterface; | ||||
|  | ||||
| /** | ||||
|  * Exception when an HTTP error occurs (4xx or 5xx error) | ||||
|  */ | ||||
| class BadResponseException extends RequestException {} | ||||
| class BadResponseException extends RequestException | ||||
| { | ||||
|     public function __construct( | ||||
|         $message, | ||||
|         RequestInterface $request, | ||||
|         ResponseInterface $response = null, | ||||
|         \Exception $previous = null, | ||||
|         array $handlerContext = [] | ||||
|     ) { | ||||
|         if (null === $response) { | ||||
|             @trigger_error( | ||||
|                 'Instantiating the ' . __CLASS__ . ' class without a Response is deprecated since version 6.3 and will be removed in 7.0.', | ||||
|                 E_USER_DEPRECATED | ||||
|             ); | ||||
|         } | ||||
|         parent::__construct($message, $request, $response, $previous, $handlerContext); | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -1,4 +1,13 @@ | ||||
| <?php | ||||
| namespace GuzzleHttp\Exception; | ||||
|  | ||||
| /** | ||||
|  * @method string getMessage() | ||||
|  * @method \Throwable|null getPrevious() | ||||
|  * @method mixed getCode() | ||||
|  * @method string getFile() | ||||
|  * @method int getLine() | ||||
|  * @method array getTrace() | ||||
|  * @method string getTraceAsString() | ||||
|  */ | ||||
| interface GuzzleException {} | ||||
|   | ||||
| @@ -81,10 +81,10 @@ class RequestException extends TransferException | ||||
|         $level = (int) floor($response->getStatusCode() / 100); | ||||
|         if ($level === 4) { | ||||
|             $label = 'Client error'; | ||||
|             $className = __NAMESPACE__ . '\\ClientException'; | ||||
|             $className = ClientException::class; | ||||
|         } elseif ($level === 5) { | ||||
|             $label = 'Server error'; | ||||
|             $className = __NAMESPACE__ . '\\ServerException'; | ||||
|             $className = ServerException::class; | ||||
|         } else { | ||||
|             $label = 'Unsuccessful request'; | ||||
|             $className = __CLASS__; | ||||
| @@ -93,13 +93,15 @@ class RequestException extends TransferException | ||||
|         $uri = $request->getUri(); | ||||
|         $uri = static::obfuscateUri($uri); | ||||
|  | ||||
|         // Server Error: `GET /` resulted in a `404 Not Found` response: | ||||
|         // Client Error: `GET /` resulted in a `404 Not Found` response: | ||||
|         // <html> ... (truncated) | ||||
|         $message = sprintf( | ||||
|             '%s: `%s` resulted in a `%s` response', | ||||
|             '%s: `%s %s` resulted in a `%s %s` response', | ||||
|             $label, | ||||
|             $request->getMethod() . ' ' . $uri, | ||||
|             $response->getStatusCode() . ' ' . $response->getReasonPhrase() | ||||
|             $request->getMethod(), | ||||
|             $uri, | ||||
|             $response->getStatusCode(), | ||||
|             $response->getReasonPhrase() | ||||
|         ); | ||||
|  | ||||
|         $summary = static::getResponseBodySummary($response); | ||||
| @@ -129,6 +131,11 @@ class RequestException extends TransferException | ||||
|         } | ||||
|  | ||||
|         $size = $body->getSize(); | ||||
|  | ||||
|         if ($size === 0) { | ||||
|             return null; | ||||
|         } | ||||
|  | ||||
|         $summary = $body->read(120); | ||||
|         $body->rewind(); | ||||
|  | ||||
|   | ||||
| @@ -4,7 +4,6 @@ namespace GuzzleHttp\Handler; | ||||
| use GuzzleHttp\Exception\RequestException; | ||||
| use GuzzleHttp\Exception\ConnectException; | ||||
| use GuzzleHttp\Promise\FulfilledPromise; | ||||
| use GuzzleHttp\Promise\RejectedPromise; | ||||
| use GuzzleHttp\Psr7; | ||||
| use GuzzleHttp\Psr7\LazyOpenStream; | ||||
| use GuzzleHttp\TransferStats; | ||||
| @@ -16,7 +15,7 @@ use Psr\Http\Message\RequestInterface; | ||||
| class CurlFactory implements CurlFactoryInterface | ||||
| { | ||||
|     /** @var array */ | ||||
|     private $handles; | ||||
|     private $handles = []; | ||||
|  | ||||
|     /** @var int Total number of idle handles to keep in cache */ | ||||
|     private $maxHandles; | ||||
| @@ -163,7 +162,7 @@ class CurlFactory implements CurlFactoryInterface | ||||
|         // If an exception was encountered during the onHeaders event, then | ||||
|         // return a rejected promise that wraps that exception. | ||||
|         if ($easy->onHeadersException) { | ||||
|             return new RejectedPromise( | ||||
|             return \GuzzleHttp\Promise\rejection_for( | ||||
|                 new RequestException( | ||||
|                     'An error was encountered during the on_headers event', | ||||
|                     $easy->request, | ||||
| @@ -186,7 +185,7 @@ class CurlFactory implements CurlFactoryInterface | ||||
|             ? new ConnectException($message, $easy->request, null, $ctx) | ||||
|             : new RequestException($message, $easy->request, $easy->response, null, $ctx); | ||||
|  | ||||
|         return new RejectedPromise($error); | ||||
|         return \GuzzleHttp\Promise\rejection_for($error); | ||||
|     } | ||||
|  | ||||
|     private function getDefaultConf(EasyHandle $easy) | ||||
| @@ -288,7 +287,14 @@ class CurlFactory implements CurlFactoryInterface | ||||
|     { | ||||
|         foreach ($conf['_headers'] as $name => $values) { | ||||
|             foreach ($values as $value) { | ||||
|                 $conf[CURLOPT_HTTPHEADER][] = "$name: $value"; | ||||
|                 $value = (string) $value; | ||||
|                 if ($value === '') { | ||||
|                     // cURL requires a special format for empty headers. | ||||
|                     // See https://github.com/guzzle/guzzle/issues/1882 for more details. | ||||
|                     $conf[CURLOPT_HTTPHEADER][] = "$name;"; | ||||
|                 } else { | ||||
|                     $conf[CURLOPT_HTTPHEADER][] = "$name: $value"; | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -326,12 +332,20 @@ class CurlFactory implements CurlFactoryInterface | ||||
|                 $conf[CURLOPT_SSL_VERIFYHOST] = 2; | ||||
|                 $conf[CURLOPT_SSL_VERIFYPEER] = true; | ||||
|                 if (is_string($options['verify'])) { | ||||
|                     $conf[CURLOPT_CAINFO] = $options['verify']; | ||||
|                     // Throw an error if the file/folder/link path is not valid or doesn't exist. | ||||
|                     if (!file_exists($options['verify'])) { | ||||
|                         throw new \InvalidArgumentException( | ||||
|                             "SSL CA bundle not found: {$options['verify']}" | ||||
|                         ); | ||||
|                     } | ||||
|                     // If it's a directory or a link to a directory use CURLOPT_CAPATH. | ||||
|                     // If not, it's probably a file, or a link to a file, so use CURLOPT_CAINFO. | ||||
|                     if (is_dir($options['verify']) || | ||||
|                         (is_link($options['verify']) && is_dir(readlink($options['verify'])))) { | ||||
|                         $conf[CURLOPT_CAPATH] = $options['verify']; | ||||
|                     } else { | ||||
|                         $conf[CURLOPT_CAINFO] = $options['verify']; | ||||
|                     } | ||||
|                 } | ||||
|             } | ||||
|         } | ||||
| @@ -370,15 +384,30 @@ class CurlFactory implements CurlFactoryInterface | ||||
|             $conf[CURLOPT_FILE] = fopen('php://temp', 'w+'); | ||||
|             $easy->sink = Psr7\stream_for($conf[CURLOPT_FILE]); | ||||
|         } | ||||
|  | ||||
|         $timeoutRequiresNoSignal = false; | ||||
|         if (isset($options['timeout'])) { | ||||
|             $timeoutRequiresNoSignal |= $options['timeout'] < 1; | ||||
|             $conf[CURLOPT_TIMEOUT_MS] = $options['timeout'] * 1000; | ||||
|         } | ||||
|  | ||||
|         // CURL default value is CURL_IPRESOLVE_WHATEVER | ||||
|         if (isset($options['force_ip_resolve'])) { | ||||
|             if ('v4' === $options['force_ip_resolve']) { | ||||
|                 $conf[CURLOPT_IPRESOLVE] = CURL_IPRESOLVE_V4; | ||||
|             } elseif ('v6' === $options['force_ip_resolve']) { | ||||
|                 $conf[CURLOPT_IPRESOLVE] = CURL_IPRESOLVE_V6; | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (isset($options['connect_timeout'])) { | ||||
|             $timeoutRequiresNoSignal |= $options['connect_timeout'] < 1; | ||||
|             $conf[CURLOPT_CONNECTTIMEOUT_MS] = $options['connect_timeout'] * 1000; | ||||
|         } | ||||
|  | ||||
|         if ($timeoutRequiresNoSignal && strtoupper(substr(PHP_OS, 0, 3)) !== 'WIN') { | ||||
|             $conf[CURLOPT_NOSIGNAL] = true; | ||||
|         } | ||||
|  | ||||
|         if (isset($options['proxy'])) { | ||||
|             if (!is_array($options['proxy'])) { | ||||
|                 $conf[CURLOPT_PROXY] = $options['proxy']; | ||||
|   | ||||
| @@ -65,7 +65,9 @@ class CurlMultiHandler | ||||
|  | ||||
|         $promise = new Promise( | ||||
|             [$this, 'execute'], | ||||
|             function () use ($id) { return $this->cancel($id); } | ||||
|             function () use ($id) { | ||||
|                 return $this->cancel($id); | ||||
|             } | ||||
|         ); | ||||
|  | ||||
|         $this->addRequest(['easy' => $easy, 'deferred' => $promise]); | ||||
|   | ||||
| @@ -1,6 +1,7 @@ | ||||
| <?php | ||||
| namespace GuzzleHttp\Handler; | ||||
|  | ||||
| use GuzzleHttp\Exception\RequestException; | ||||
| use GuzzleHttp\HandlerStack; | ||||
| use GuzzleHttp\Promise\PromiseInterface; | ||||
| use GuzzleHttp\Promise\RejectedPromise; | ||||
| @@ -13,7 +14,7 @@ use Psr\Http\Message\ResponseInterface; | ||||
|  */ | ||||
| class MockHandler implements \Countable | ||||
| { | ||||
|     private $queue; | ||||
|     private $queue = []; | ||||
|     private $lastRequest; | ||||
|     private $lastOptions; | ||||
|     private $onFulfilled; | ||||
| @@ -73,12 +74,24 @@ class MockHandler implements \Countable | ||||
|         $this->lastOptions = $options; | ||||
|         $response = array_shift($this->queue); | ||||
|  | ||||
|         if (isset($options['on_headers'])) { | ||||
|             if (!is_callable($options['on_headers'])) { | ||||
|                 throw new \InvalidArgumentException('on_headers must be callable'); | ||||
|             } | ||||
|             try { | ||||
|                 $options['on_headers']($response); | ||||
|             } catch (\Exception $e) { | ||||
|                 $msg = 'An error was encountered during the on_headers event'; | ||||
|                 $response = new RequestException($msg, $request, $response, $e); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         if (is_callable($response)) { | ||||
|             $response = call_user_func($response, $request, $options); | ||||
|         } | ||||
|  | ||||
|         $response = $response instanceof \Exception | ||||
|             ? new RejectedPromise($response) | ||||
|             ? \GuzzleHttp\Promise\rejection_for($response) | ||||
|             : \GuzzleHttp\Promise\promise_for($response); | ||||
|  | ||||
|         return $response->then( | ||||
| @@ -107,7 +120,7 @@ class MockHandler implements \Countable | ||||
|                 if ($this->onRejected) { | ||||
|                     call_user_func($this->onRejected, $reason); | ||||
|                 } | ||||
|                 return new RejectedPromise($reason); | ||||
|                 return \GuzzleHttp\Promise\rejection_for($reason); | ||||
|             } | ||||
|         ); | ||||
|     } | ||||
| @@ -145,7 +158,7 @@ class MockHandler implements \Countable | ||||
|     /** | ||||
|      * Get the last received request options. | ||||
|      * | ||||
|      * @return RequestInterface | ||||
|      * @return array | ||||
|      */ | ||||
|     public function getLastOptions() | ||||
|     { | ||||
|   | ||||
| @@ -4,7 +4,6 @@ namespace GuzzleHttp\Handler; | ||||
| use GuzzleHttp\Exception\RequestException; | ||||
| use GuzzleHttp\Exception\ConnectException; | ||||
| use GuzzleHttp\Promise\FulfilledPromise; | ||||
| use GuzzleHttp\Promise\RejectedPromise; | ||||
| use GuzzleHttp\Promise\PromiseInterface; | ||||
| use GuzzleHttp\Psr7; | ||||
| use GuzzleHttp\TransferStats; | ||||
| @@ -61,13 +60,14 @@ class StreamHandler | ||||
|             if (strpos($message, 'getaddrinfo') // DNS lookup failed | ||||
|                 || strpos($message, 'Connection refused') | ||||
|                 || strpos($message, "couldn't connect to host") // error on HHVM | ||||
|                 || strpos($message, "connection attempt failed") | ||||
|             ) { | ||||
|                 $e = new ConnectException($e->getMessage(), $request, $e); | ||||
|             } | ||||
|             $e = RequestException::wrapException($request, $e); | ||||
|             $this->invokeStats($options, $request, $startTime, null, $e); | ||||
|  | ||||
|             return new RejectedPromise($e); | ||||
|             return \GuzzleHttp\Promise\rejection_for($e); | ||||
|         } | ||||
|     } | ||||
|  | ||||
| @@ -103,7 +103,7 @@ class StreamHandler | ||||
|         $status = $parts[1]; | ||||
|         $reason = isset($parts[2]) ? $parts[2] : null; | ||||
|         $headers = \GuzzleHttp\headers_from_lines($hdrs); | ||||
|         list ($stream, $headers) = $this->checkDecode($options, $headers, $stream); | ||||
|         list($stream, $headers) = $this->checkDecode($options, $headers, $stream); | ||||
|         $stream = Psr7\stream_for($stream); | ||||
|         $sink = $stream; | ||||
|  | ||||
| @@ -119,7 +119,7 @@ class StreamHandler | ||||
|             } catch (\Exception $e) { | ||||
|                 $msg = 'An error was encountered during the on_headers event'; | ||||
|                 $ex = new RequestException($msg, $request, $response, $e); | ||||
|                 return new RejectedPromise($ex); | ||||
|                 return \GuzzleHttp\Promise\rejection_for($ex); | ||||
|             } | ||||
|         } | ||||
|  | ||||
| @@ -276,7 +276,7 @@ class StreamHandler | ||||
|         } | ||||
|  | ||||
|         $params = []; | ||||
|         $context = $this->getDefaultContext($request, $options); | ||||
|         $context = $this->getDefaultContext($request); | ||||
|  | ||||
|         if (isset($options['on_headers']) && !is_callable($options['on_headers'])) { | ||||
|             throw new \InvalidArgumentException('on_headers must be callable'); | ||||
| @@ -301,6 +301,17 @@ class StreamHandler | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         // Microsoft NTLM authentication only supported with curl handler | ||||
|         if (isset($options['auth']) | ||||
|             && is_array($options['auth']) | ||||
|             && isset($options['auth'][2]) | ||||
|             && 'ntlm' == $options['auth'][2] | ||||
|         ) { | ||||
|             throw new \InvalidArgumentException('Microsoft NTLM authentication only supported with curl handler'); | ||||
|         } | ||||
|  | ||||
|         $uri = $this->resolveHost($request, $options); | ||||
|  | ||||
|         $context = $this->createResource( | ||||
|             function () use ($context, $params) { | ||||
|                 return stream_context_create($context, $params); | ||||
| @@ -308,14 +319,45 @@ class StreamHandler | ||||
|         ); | ||||
|  | ||||
|         return $this->createResource( | ||||
|             function () use ($request, &$http_response_header, $context) { | ||||
|                 $resource = fopen((string) $request->getUri()->withFragment(''), 'r', null, $context); | ||||
|             function () use ($uri, &$http_response_header, $context, $options) { | ||||
|                 $resource = fopen((string) $uri, 'r', null, $context); | ||||
|                 $this->lastHeaders = $http_response_header; | ||||
|  | ||||
|                 if (isset($options['read_timeout'])) { | ||||
|                     $readTimeout = $options['read_timeout']; | ||||
|                     $sec = (int) $readTimeout; | ||||
|                     $usec = ($readTimeout - $sec) * 100000; | ||||
|                     stream_set_timeout($resource, $sec, $usec); | ||||
|                 } | ||||
|  | ||||
|                 return $resource; | ||||
|             } | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     private function resolveHost(RequestInterface $request, array $options) | ||||
|     { | ||||
|         $uri = $request->getUri(); | ||||
|  | ||||
|         if (isset($options['force_ip_resolve']) && !filter_var($uri->getHost(), FILTER_VALIDATE_IP)) { | ||||
|             if ('v4' === $options['force_ip_resolve']) { | ||||
|                 $records = dns_get_record($uri->getHost(), DNS_A); | ||||
|                 if (!isset($records[0]['ip'])) { | ||||
|                     throw new ConnectException(sprintf("Could not resolve IPv4 address for host '%s'", $uri->getHost()), $request); | ||||
|                 } | ||||
|                 $uri = $uri->withHost($records[0]['ip']); | ||||
|             } elseif ('v6' === $options['force_ip_resolve']) { | ||||
|                 $records = dns_get_record($uri->getHost(), DNS_AAAA); | ||||
|                 if (!isset($records[0]['ipv6'])) { | ||||
|                     throw new ConnectException(sprintf("Could not resolve IPv6 address for host '%s'", $uri->getHost()), $request); | ||||
|                 } | ||||
|                 $uri = $uri->withHost('[' . $records[0]['ipv6'] . ']'); | ||||
|             } | ||||
|         } | ||||
|  | ||||
|         return $uri; | ||||
|     } | ||||
|  | ||||
|     private function getDefaultContext(RequestInterface $request) | ||||
|     { | ||||
|         $headers = ''; | ||||
|   | ||||
| @@ -22,7 +22,7 @@ class HandlerStack | ||||
|      * Creates a default handler stack that can be used by clients. | ||||
|      * | ||||
|      * The returned handler will wrap the provided handler or use the most | ||||
|      * appropriate default handler for you system. The returned HandlerStack has | ||||
|      * appropriate default handler for your system. The returned HandlerStack has | ||||
|      * support for cookies, redirects, HTTP error exceptions, and preparing a body | ||||
|      * before sending. | ||||
|      * | ||||
|   | ||||
| @@ -19,7 +19,6 @@ use Psr\Http\Message\ResponseInterface; | ||||
|  * - {host}:           Host of the request | ||||
|  * - {method}:         Method of the request | ||||
|  * - {uri}:            URI of the request | ||||
|  * - {host}:           Host of the request | ||||
|  * - {version}:        Protocol version | ||||
|  * - {target}:         Request target of the request (path + query + fragment) | ||||
|  * - {hostname}:       Hostname of the machine that sent the request | ||||
| @@ -74,7 +73,6 @@ class MessageFormatter | ||||
|         return preg_replace_callback( | ||||
|             '/{\s*([A-Za-z_\-\.0-9]+)\s*}/', | ||||
|             function (array $matches) use ($request, $response, $error, &$cache) { | ||||
|  | ||||
|                 if (isset($cache[$matches[1]])) { | ||||
|                     return $cache[$matches[1]]; | ||||
|                 } | ||||
|   | ||||
							
								
								
									
										13
									
								
								vendor/guzzlehttp/guzzle/src/Middleware.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										13
									
								
								vendor/guzzlehttp/guzzle/src/Middleware.php
									
									
									
									
										vendored
									
									
								
							| @@ -34,10 +34,11 @@ final class Middleware | ||||
|                 $cookieJar = $options['cookies']; | ||||
|                 $request = $cookieJar->withCookieHeader($request); | ||||
|                 return $handler($request, $options) | ||||
|                     ->then(function ($response) use ($cookieJar, $request) { | ||||
|                         $cookieJar->extractCookies($request, $response); | ||||
|                         return $response; | ||||
|                     } | ||||
|                     ->then( | ||||
|                         function ($response) use ($cookieJar, $request) { | ||||
|                             $cookieJar->extractCookies($request, $response); | ||||
|                             return $response; | ||||
|                         } | ||||
|                 ); | ||||
|             }; | ||||
|         }; | ||||
| @@ -72,7 +73,7 @@ final class Middleware | ||||
|     /** | ||||
|      * Middleware that pushes history data to an ArrayAccess container. | ||||
|      * | ||||
|      * @param array $container Container to hold the history (by reference). | ||||
|      * @param array|\ArrayAccess $container Container to hold the history (by reference). | ||||
|      * | ||||
|      * @return callable Returns a function that accepts the next handler. | ||||
|      * @throws \InvalidArgumentException if container is not an array or ArrayAccess. | ||||
| @@ -102,7 +103,7 @@ final class Middleware | ||||
|                             'error'    => $reason, | ||||
|                             'options'  => $options | ||||
|                         ]; | ||||
|                         return new RejectedPromise($reason); | ||||
|                         return \GuzzleHttp\Promise\rejection_for($reason); | ||||
|                     } | ||||
|                 ); | ||||
|             }; | ||||
|   | ||||
| @@ -14,9 +14,6 @@ class PrepareBodyMiddleware | ||||
|     /** @var callable  */ | ||||
|     private $nextHandler; | ||||
|  | ||||
|     /** @var array */ | ||||
|     private static $skipMethods = ['GET' => true, 'HEAD' => true]; | ||||
|  | ||||
|     /** | ||||
|      * @param callable $nextHandler Next handler to invoke. | ||||
|      */ | ||||
| @@ -36,9 +33,7 @@ class PrepareBodyMiddleware | ||||
|         $fn = $this->nextHandler; | ||||
|  | ||||
|         // Don't do anything if the request has no body. | ||||
|         if (isset(self::$skipMethods[$request->getMethod()]) | ||||
|             || $request->getBody()->getSize() === 0 | ||||
|         ) { | ||||
|         if ($request->getBody()->getSize() === 0) { | ||||
|             return $fn($request, $options); | ||||
|         } | ||||
|  | ||||
| @@ -54,8 +49,7 @@ class PrepareBodyMiddleware | ||||
|         } | ||||
|  | ||||
|         // Add a default content-length or transfer-encoding header. | ||||
|         if (!isset(self::$skipMethods[$request->getMethod()]) | ||||
|             && !$request->hasHeader('Content-Length') | ||||
|         if (!$request->hasHeader('Content-Length') | ||||
|             && !$request->hasHeader('Transfer-Encoding') | ||||
|         ) { | ||||
|             $size = $request->getBody()->getSize(); | ||||
|   | ||||
| @@ -19,6 +19,8 @@ class RedirectMiddleware | ||||
| { | ||||
|     const HISTORY_HEADER = 'X-Guzzle-Redirect-History'; | ||||
|  | ||||
|     const STATUS_HISTORY_HEADER = 'X-Guzzle-Redirect-Status-History'; | ||||
|  | ||||
|     public static $defaultSettings = [ | ||||
|         'max'             => 5, | ||||
|         'protocols'       => ['http', 'https'], | ||||
| @@ -108,23 +110,27 @@ class RedirectMiddleware | ||||
|         if (!empty($options['allow_redirects']['track_redirects'])) { | ||||
|             return $this->withTracking( | ||||
|                 $promise, | ||||
|                 (string) $nextRequest->getUri() | ||||
|                 (string) $nextRequest->getUri(), | ||||
|                 $response->getStatusCode() | ||||
|             ); | ||||
|         } | ||||
|  | ||||
|         return $promise; | ||||
|     } | ||||
|  | ||||
|     private function withTracking(PromiseInterface $promise, $uri) | ||||
|     private function withTracking(PromiseInterface $promise, $uri, $statusCode) | ||||
|     { | ||||
|         return $promise->then( | ||||
|             function (ResponseInterface $response) use ($uri) { | ||||
|             function (ResponseInterface $response) use ($uri, $statusCode) { | ||||
|                 // Note that we are pushing to the front of the list as this | ||||
|                 // would be an earlier response than what is currently present | ||||
|                 // in the history header. | ||||
|                 $header = $response->getHeader(self::HISTORY_HEADER); | ||||
|                 array_unshift($header, $uri); | ||||
|                 return $response->withHeader(self::HISTORY_HEADER, $header); | ||||
|                 $historyHeader = $response->getHeader(self::HISTORY_HEADER); | ||||
|                 $statusHeader = $response->getHeader(self::STATUS_HISTORY_HEADER); | ||||
|                 array_unshift($historyHeader, $uri); | ||||
|                 array_unshift($statusHeader, $statusCode); | ||||
|                 return $response->withHeader(self::HISTORY_HEADER, $historyHeader) | ||||
|                                 ->withHeader(self::STATUS_HISTORY_HEADER, $statusHeader); | ||||
|             } | ||||
|         ); | ||||
|     } | ||||
| @@ -208,9 +214,9 @@ class RedirectMiddleware | ||||
|         ResponseInterface $response, | ||||
|         array $protocols | ||||
|     ) { | ||||
|         $location = Psr7\Uri::resolve( | ||||
|         $location = Psr7\UriResolver::resolve( | ||||
|             $request->getUri(), | ||||
|             $response->getHeaderLine('Location') | ||||
|             new Psr7\Uri($response->getHeaderLine('Location')) | ||||
|         ); | ||||
|  | ||||
|         // Ensure that the redirect URI is allowed based on the protocols. | ||||
|   | ||||
							
								
								
									
										15
									
								
								vendor/guzzlehttp/guzzle/src/RequestOptions.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										15
									
								
								vendor/guzzlehttp/guzzle/src/RequestOptions.php
									
									
									
									
										vendored
									
									
								
							| @@ -43,8 +43,8 @@ final class RequestOptions | ||||
|     const AUTH = 'auth'; | ||||
|  | ||||
|     /** | ||||
|      * body: (string|null|callable|iterator|object) Body to send in the | ||||
|      * request. | ||||
|      * body: (resource|string|null|int|float|StreamInterface|callable|\Iterator) | ||||
|      * Body to send in the request. | ||||
|      */ | ||||
|     const BODY = 'body'; | ||||
|  | ||||
| @@ -237,8 +237,19 @@ final class RequestOptions | ||||
|      */ | ||||
|     const TIMEOUT = 'timeout'; | ||||
|  | ||||
|     /** | ||||
|      * read_timeout: (float, default=default_socket_timeout ini setting) Float describing | ||||
|      * the body read timeout, for stream requests. | ||||
|      */ | ||||
|     const READ_TIMEOUT = 'read_timeout'; | ||||
|  | ||||
|     /** | ||||
|      * version: (float) Specifies the HTTP protocol version to attempt to use. | ||||
|      */ | ||||
|     const VERSION = 'version'; | ||||
|  | ||||
|     /** | ||||
|      * force_ip_resolve: (bool) Force client to use only ipv4 or ipv6 protocol | ||||
|      */ | ||||
|     const FORCE_IP_RESOLVE = 'force_ip_resolve'; | ||||
| } | ||||
|   | ||||
| @@ -97,7 +97,7 @@ class RetryMiddleware | ||||
|                 null, | ||||
|                 $reason | ||||
|             )) { | ||||
|                 return new RejectedPromise($reason); | ||||
|                 return \GuzzleHttp\Promise\rejection_for($reason); | ||||
|             } | ||||
|             return $this->doRetry($req, $options); | ||||
|         }; | ||||
|   | ||||
							
								
								
									
										4
									
								
								vendor/guzzlehttp/guzzle/src/UriTemplate.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								vendor/guzzlehttp/guzzle/src/UriTemplate.php
									
									
									
									
										vendored
									
									
								
							| @@ -107,7 +107,6 @@ class UriTemplate | ||||
|         $useQuery = self::$operatorHash[$parsed['operator']]['query']; | ||||
|  | ||||
|         foreach ($parsed['values'] as $value) { | ||||
|  | ||||
|             if (!isset($this->variables[$value['value']])) { | ||||
|                 continue; | ||||
|             } | ||||
| @@ -117,11 +116,9 @@ class UriTemplate | ||||
|             $expanded = ''; | ||||
|  | ||||
|             if (is_array($variable)) { | ||||
|  | ||||
|                 $isAssoc = $this->isAssoc($variable); | ||||
|                 $kvp = []; | ||||
|                 foreach ($variable as $key => $var) { | ||||
|  | ||||
|                     if ($isAssoc) { | ||||
|                         $key = rawurlencode($key); | ||||
|                         $isNestedArray = is_array($var); | ||||
| @@ -179,7 +176,6 @@ class UriTemplate | ||||
|                     } | ||||
|                     $expanded = implode(',', $kvp); | ||||
|                 } | ||||
|  | ||||
|             } else { | ||||
|                 if ($value['modifier'] === ':') { | ||||
|                     $variable = substr($variable, 0, $value['position']); | ||||
|   | ||||
							
								
								
									
										8
									
								
								vendor/guzzlehttp/guzzle/src/functions.php
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										8
									
								
								vendor/guzzlehttp/guzzle/src/functions.php
									
									
									
									
										vendored
									
									
								
							| @@ -167,6 +167,8 @@ function default_ca_bundle() | ||||
|         '/etc/ssl/certs/ca-certificates.crt', | ||||
|         // FreeBSD (provided by the ca_root_nss package) | ||||
|         '/usr/local/share/certs/ca-root-nss.crt', | ||||
|         // SLES 12 (provided by the ca-certificates package) | ||||
|         '/var/lib/ca-certificates/ca-bundle.pem', | ||||
|         // OS X provided by homebrew (using the default path) | ||||
|         '/usr/local/etc/openssl/cert.pem', | ||||
|         // Google app engine | ||||
| @@ -300,7 +302,8 @@ function json_decode($json, $assoc = false, $depth = 512, $options = 0) | ||||
|     $data = \json_decode($json, $assoc, $depth, $options); | ||||
|     if (JSON_ERROR_NONE !== json_last_error()) { | ||||
|         throw new \InvalidArgumentException( | ||||
|             'json_decode error: ' . json_last_error_msg()); | ||||
|             'json_decode error: ' . json_last_error_msg() | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     return $data; | ||||
| @@ -322,7 +325,8 @@ function json_encode($value, $options = 0, $depth = 512) | ||||
|     $json = \json_encode($value, $options, $depth); | ||||
|     if (JSON_ERROR_NONE !== json_last_error()) { | ||||
|         throw new \InvalidArgumentException( | ||||
|             'json_encode error: ' . json_last_error_msg()); | ||||
|             'json_encode error: ' . json_last_error_msg() | ||||
|         ); | ||||
|     } | ||||
|  | ||||
|     return $json; | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Manish Verma
					Manish Verma