| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192 | <?phpnamespace GuzzleHttp\Exception;use GuzzleHttp\Promise\PromiseInterface;use Psr\Http\Message\RequestInterface;use Psr\Http\Message\ResponseInterface;use Psr\Http\Message\UriInterface;/** * HTTP Request exception */class RequestException extends TransferException{    /** @var RequestInterface */    private $request;    /** @var ResponseInterface|null */    private $response;    /** @var array */    private $handlerContext;    public function __construct(        $message,        RequestInterface $request,        ResponseInterface $response = null,        \Exception $previous = null,        array $handlerContext = []    ) {        // Set the code of the exception if the response is set and not future.        $code = $response && !($response instanceof PromiseInterface)            ? $response->getStatusCode()            : 0;        parent::__construct($message, $code, $previous);        $this->request = $request;        $this->response = $response;        $this->handlerContext = $handlerContext;    }    /**     * Wrap non-RequestExceptions with a RequestException     *     * @param RequestInterface $request     * @param \Exception       $e     *     * @return RequestException     */    public static function wrapException(RequestInterface $request, \Exception $e)    {        return $e instanceof RequestException            ? $e            : new RequestException($e->getMessage(), $request, null, $e);    }    /**     * Factory method to create a new exception with a normalized error message     *     * @param RequestInterface  $request  Request     * @param ResponseInterface $response Response received     * @param \Exception        $previous Previous exception     * @param array             $ctx      Optional handler context.     *     * @return self     */    public static function create(        RequestInterface $request,        ResponseInterface $response = null,        \Exception $previous = null,        array $ctx = []    ) {        if (!$response) {            return new self(                'Error completing request',                $request,                null,                $previous,                $ctx            );        }        $level = (int) floor($response->getStatusCode() / 100);        if ($level === 4) {            $label = 'Client error';            $className = ClientException::class;        } elseif ($level === 5) {            $label = 'Server error';            $className = ServerException::class;        } else {            $label = 'Unsuccessful request';            $className = __CLASS__;        }        $uri = $request->getUri();        $uri = static::obfuscateUri($uri);        // Client Error: `GET /` resulted in a `404 Not Found` response:        // <html> ... (truncated)        $message = sprintf(            '%s: `%s %s` resulted in a `%s %s` response',            $label,            $request->getMethod(),            $uri,            $response->getStatusCode(),            $response->getReasonPhrase()        );        $summary = static::getResponseBodySummary($response);        if ($summary !== null) {            $message .= ":\n{$summary}\n";        }        return new $className($message, $request, $response, $previous, $ctx);    }    /**     * Get a short summary of the response     *     * Will return `null` if the response is not printable.     *     * @param ResponseInterface $response     *     * @return string|null     */    public static function getResponseBodySummary(ResponseInterface $response)    {        return \GuzzleHttp\Psr7\get_message_body_summary($response);    }    /**     * Obfuscates URI if there is a username and a password present     *     * @param UriInterface $uri     *     * @return UriInterface     */    private static function obfuscateUri(UriInterface $uri)    {        $userInfo = $uri->getUserInfo();        if (false !== ($pos = strpos($userInfo, ':'))) {            return $uri->withUserInfo(substr($userInfo, 0, $pos), '***');        }        return $uri;    }    /**     * Get the request that caused the exception     *     * @return RequestInterface     */    public function getRequest()    {        return $this->request;    }    /**     * Get the associated response     *     * @return ResponseInterface|null     */    public function getResponse()    {        return $this->response;    }    /**     * Check if a response was received     *     * @return bool     */    public function hasResponse()    {        return $this->response !== null;    }    /**     * Get contextual information about the error from the underlying handler.     *     * The contents of this array will vary depending on which handler you are     * using. It may also be just an empty array. Relying on this data will     * couple you to a specific handler, but can give more debug information     * when needed.     *     * @return array     */    public function getHandlerContext()    {        return $this->handlerContext;    }}
 |