190 lines
4.2 KiB
PHP
190 lines
4.2 KiB
PHP
|
<?php
|
||
|
|
||
|
namespace Qcloud\Cos\Exception;
|
||
|
|
||
|
use Psr\Http\Message\RequestInterface;
|
||
|
use Psr\Http\Message\ResponseInterface;
|
||
|
|
||
|
class ServiceResponseException extends \RuntimeException {
|
||
|
|
||
|
/**
|
||
|
* @var Response Response
|
||
|
*/
|
||
|
protected $response;
|
||
|
|
||
|
/**
|
||
|
* @var RequestInterface Request
|
||
|
*/
|
||
|
protected $request;
|
||
|
|
||
|
/**
|
||
|
* @var string Request ID
|
||
|
*/
|
||
|
protected $requestId;
|
||
|
|
||
|
/**
|
||
|
* @var string Exception type (client / server)
|
||
|
*/
|
||
|
protected $exceptionType;
|
||
|
|
||
|
/**
|
||
|
* @var string Exception code
|
||
|
*/
|
||
|
protected $exceptionCode;
|
||
|
|
||
|
/**
|
||
|
* Set the exception code
|
||
|
*
|
||
|
* @param string $code Exception code
|
||
|
*/
|
||
|
public function setExceptionCode($code) {
|
||
|
$this->exceptionCode = $code;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the exception code
|
||
|
*
|
||
|
* @return string|null
|
||
|
*/
|
||
|
public function getExceptionCode() {
|
||
|
return $this->exceptionCode;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the exception type
|
||
|
*
|
||
|
* @param string $type Exception type
|
||
|
*/
|
||
|
public function setExceptionType($type) {
|
||
|
$this->exceptionType = $type;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the exception type (one of client or server)
|
||
|
*
|
||
|
* @return string|null
|
||
|
*/
|
||
|
public function getExceptionType() {
|
||
|
return $this->exceptionType;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the request ID
|
||
|
*
|
||
|
* @param string $id Request ID
|
||
|
*/
|
||
|
public function setRequestId($id) {
|
||
|
$this->requestId = $id;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the Request ID
|
||
|
*
|
||
|
* @return string|null
|
||
|
*/
|
||
|
public function getRequestId() {
|
||
|
return $this->requestId;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the associated response
|
||
|
*
|
||
|
* @param Response $response
|
||
|
*/
|
||
|
public function setResponse(ResponseInterface $response) {
|
||
|
$this->response = $response;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the associated response object
|
||
|
*
|
||
|
* @return Response|null
|
||
|
*/
|
||
|
public function getResponse() {
|
||
|
return $this->response;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Set the associated request
|
||
|
*
|
||
|
* @param RequestInterface $request
|
||
|
*/
|
||
|
public function setRequest(RequestInterface $request) {
|
||
|
$this->request = $request;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the associated request object
|
||
|
*
|
||
|
* @return RequestInterface|null
|
||
|
*/
|
||
|
public function getRequest() {
|
||
|
return $this->request;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the status code of the response
|
||
|
*
|
||
|
* @return int|null
|
||
|
*/
|
||
|
public function getStatusCode() {
|
||
|
return $this->response ? $this->response->getStatusCode() : null;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Cast to a string
|
||
|
*
|
||
|
* @return string
|
||
|
*/
|
||
|
public function __toString() {
|
||
|
$message = get_class($this) . ': '
|
||
|
. 'Cos Error Code: ' . $this->getExceptionCode() . ', '
|
||
|
. 'Status Code: ' . $this->getStatusCode() . ', '
|
||
|
. 'Cos Request ID: ' . $this->getRequestId() . ', '
|
||
|
. 'Cos Error Type: ' . $this->getExceptionType() . ', '
|
||
|
. 'Cos Error Message: ' . $this->getMessage();
|
||
|
|
||
|
// Add the User-Agent if available
|
||
|
if ($this->request) {
|
||
|
$message .= ', ' . 'User-Agent: ' . $this->request->getHeader('User-Agent')[0];
|
||
|
}
|
||
|
|
||
|
return $message;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the request ID of the error. This value is only present if a
|
||
|
* response was received, and is not present in the event of a networking
|
||
|
* error.
|
||
|
*
|
||
|
* Same as `getRequestId()` method, but matches the interface for SDKv3.
|
||
|
*
|
||
|
* @return string|null Returns null if no response was received
|
||
|
*/
|
||
|
public function getCosRequestId() {
|
||
|
return $this->requestId;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the Cos error type.
|
||
|
*
|
||
|
* Same as `getExceptionType()` method, but matches the interface for SDKv3.
|
||
|
*
|
||
|
* @return string|null Returns null if no response was received
|
||
|
*/
|
||
|
public function getCosErrorType() {
|
||
|
return $this->exceptionType;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get the Cos error code.
|
||
|
*
|
||
|
* Same as `getExceptionCode()` method, but matches the interface for SDKv3.
|
||
|
*
|
||
|
* @return string|null Returns null if no response was received
|
||
|
*/
|
||
|
public function getCosErrorCode() {
|
||
|
return $this->exceptionCode;
|
||
|
}
|
||
|
}
|