芝麻web文件管理V1.00
编辑当前文件:/home/qrafawbu/qrafiqxcreativeagency.com/accounts/office/vendor/google/gax/src/ApiException.php
null, 'metadata' => null, 'basicMessage' => $message, ]; parent::__construct($message, $code, $optionalArgs['previous']); $this->status = $status; $this->metadata = $optionalArgs['metadata']; $this->basicMessage = $optionalArgs['basicMessage']; if ($this->metadata) { $this->decodedMetadataErrorInfo = self::decodeMetadataErrorInfo($this->metadata); } } public function getStatus() { return $this->status; } /** * Returns null if metadata does not contain error info, or returns containsErrorInfo() array * if the metadata does contain error info. * @param array $metadata * @return array $details { * @type string|null $reason * @type string|null $domain * @type array|null $errorInfoMetadata * } */ private static function decodeMetadataErrorInfo(array $metadata) { $details = []; // ApiExceptions created from RPC status have metadata that is an array of objects. if (is_object(reset($metadata))) { $metadataRpcStatus = Serializer::decodeAnyMessages($metadata); $details = self::containsErrorInfo($metadataRpcStatus); } elseif (self::containsErrorInfo($metadata)) { $details = self::containsErrorInfo($metadata); } else { // For GRPC-based responses, the $metadata needs to be decoded. $metadataGrpc = Serializer::decodeMetadata($metadata); $details = self::containsErrorInfo($metadataGrpc); } return $details; } /** * Returns the `reason` in ErrorInfo for an exception, or null if there is no ErrorInfo. * @return string|null $reason */ public function getReason() { return ($this->decodedMetadataErrorInfo) ? $this->decodedMetadataErrorInfo['reason'] : null; } /** * Returns the `domain` in ErrorInfo for an exception, or null if there is no ErrorInfo. * @return string|null $domain */ public function getDomain() { return ($this->decodedMetadataErrorInfo) ? $this->decodedMetadataErrorInfo['domain'] : null; } /** * Returns the `metadata` in ErrorInfo for an exception, or null if there is no ErrorInfo. * @return array|null $errorInfoMetadata */ public function getErrorInfoMetadata() { return ($this->decodedMetadataErrorInfo) ? $this->decodedMetadataErrorInfo['errorInfoMetadata'] : null; } /** * @param stdClass $status * @return ApiException */ public static function createFromStdClass(stdClass $status) { $metadata = property_exists($status, 'metadata') ? $status->metadata : null; return self::create( $status->details, $status->code, $metadata, Serializer::decodeMetadata((array) $metadata) ); } /** * @param string $basicMessage * @param int $rpcCode * @param array|null $metadata * @param Exception $previous * @return ApiException */ public static function createFromApiResponse( $basicMessage, $rpcCode, array $metadata = null, Exception $previous = null ) { return self::create( $basicMessage, $rpcCode, $metadata, Serializer::decodeMetadata((array) $metadata), $previous ); } /** * For REST-based responses, the metadata does not need to be decoded. * * @param string $basicMessage * @param int $rpcCode * @param array|null $metadata * @param Exception $previous * @return ApiException */ public static function createFromRestApiResponse( $basicMessage, $rpcCode, array $metadata = null, Exception $previous = null ) { return self::create( $basicMessage, $rpcCode, $metadata, is_null($metadata) ? [] : $metadata, $previous ); } /** * Checks if decoded metadata includes errorInfo message. * If errorInfo is set, it will always contain `reason`, `domain`, and `metadata` keys. * @param array $decodedMetadata * @return array { * @type string $reason * @type string $domain * @type array $errorInfoMetadata * } */ private static function containsErrorInfo(array $decodedMetadata) { if (empty($decodedMetadata)) { return []; } foreach ($decodedMetadata as $value) { $isErrorInfoArray = isset($value['reason']) && isset($value['domain']) && isset($value['metadata']); if ($isErrorInfoArray) { return [ 'reason' => $value['reason'], 'domain' => $value['domain'], 'errorInfoMetadata' => $value['metadata'], ]; } } return []; } /** * Construct an ApiException with a useful message, including decoded metadata. * If the decoded metadata includes an errorInfo message, then the domain, reason, * and metadata fields from that message are hoisted directly into the error. * * @param string $basicMessage * @param int $rpcCode * @param iterable|null $metadata * @param array $decodedMetadata * @param Exception|null $previous * @return ApiException */ private static function create( string $basicMessage, int $rpcCode, $metadata, array $decodedMetadata, Exception $previous = null ) { $containsErrorInfo = self::containsErrorInfo($decodedMetadata); $rpcStatus = ApiStatus::statusFromRpcCode($rpcCode); $messageData = [ 'message' => $basicMessage, 'code' => $rpcCode, 'status' => $rpcStatus, 'details' => $decodedMetadata ]; if ($containsErrorInfo) { $messageData = array_merge($containsErrorInfo, $messageData); } $message = json_encode($messageData, JSON_PRETTY_PRINT); if ($metadata instanceof RepeatedField) { $metadata = iterator_to_array($metadata); } return new ApiException($message, $rpcCode, $rpcStatus, [ 'previous' => $previous, 'metadata' => $metadata, 'basicMessage' => $basicMessage, ]); } /** * @param Status $status * @return ApiException */ public static function createFromRpcStatus(Status $status) { return self::create( $status->getMessage(), $status->getCode(), $status->getDetails(), Serializer::decodeAnyMessages($status->getDetails()) ); } /** * Creates an ApiException from a GuzzleHttp RequestException. * * @param RequestException $ex * @param boolean $isStream * @return ApiException * @throws ValidationException */ public static function createFromRequestException(RequestException $ex, bool $isStream = false) { $res = $ex->getResponse(); $body = (string) $res->getBody(); $decoded = json_decode($body, true); // A streaming response body will return one error in an array. Parse // that first (and only) error message, if provided. if ($isStream && isset($decoded[0])) { $decoded = $decoded[0]; } if (isset($decoded['error']) && $decoded['error']) { $error = $decoded['error']; $basicMessage = $error['message'] ?? ''; $code = isset($error['status']) ? ApiStatus::rpcCodeFromStatus($error['status']) : $ex->getCode(); $metadata = $error['details'] ?? null; return static::createFromRestApiResponse($basicMessage, $code, $metadata); } // Use the RPC code instead of the HTTP Status Code. $code = ApiStatus::rpcCodeFromHttpStatusCode($res->getStatusCode()); return static::createFromApiResponse($body, $code); } /** * @return null|string */ public function getBasicMessage() { return $this->basicMessage; } /** * @return mixed[] */ public function getMetadata() { return $this->metadata; } /** * String representation of ApiException * @return string */ public function __toString() { return __CLASS__ . ": $this->message\n"; } }