/** * {@inheritDoc} */ public function postSend(RequestInterface $request, MessageInterface $response) { $content = $response->getArrayContent(); if (is_array($content) && isset($content['state']) && $content['state'] !== '200') { throw new RuntimeException($content['statemsg'], (int) $content['state']); } /** @var $response \Nic\HttpClient\Message\Response */ if ($response->isClientError() || $response->isServerError()) { $content = $response->getContent(); if (is_array($content) && isset($content['message'])) { if (400 == $response->getStatusCode()) { throw new ErrorException($content['message'], 400); } } $errorMessage = null; if (isset($content['error'])) { $errorMessage = implode("\n", $content['error']); } elseif (isset($content['message'])) { $errorMessage = $content['message']; } else { $errorMessage = $content; } throw new RuntimeException($errorMessage, $response->getStatusCode()); } }
/** * @param \Buzz\Message\RequestInterface $oRequest * @param \Buzz\Message\MessageInterface $oResponse * @throws \GitlabCI\Exception\ErrorException * @throws \GitlabCI\Exception\RuntimeException */ public function postSend(\Buzz\Message\RequestInterface $oRequest, \Buzz\Message\MessageInterface $oResponse) { if ($oResponse->isClientError() || $oResponse->isServerError()) { $aContent = $oResponse->getContent(); if (is_array($aContent) && isset($aContent['message'])) { if (400 == $oResponse->getStatusCode()) { throw new \GitlabCI\Exception\ErrorException($aContent['message'], 400); } } $sErrorMessage = null; if (is_array($aContent)) { if (isset($aContent['error'])) { if (is_array($aContent['error'])) { $sErrorMessage = implode(PHP_EOL, $aContent['error']); } else { $sErrorMessage = $aContent['error']; } } elseif (isset($aContent['message'])) { $sErrorMessage = $aContent['message']; } else { $sErrorMessage = $aContent; } } else { $sErrorMessage = 'Unkown error'; } throw new \GitlabCI\Exception\RuntimeException($sErrorMessage, $oResponse->getStatusCode()); } }
public function postSend(RequestInterface $request, MessageInterface $response) { $raw = $response->getContent(); $content = json_decode($raw, true); if ($response->getStatusCode() === 404) { throw new NotFoundHttpException(sprintf('%s %s: %s', $response->getStatusCode(), $response->getReasonPhrase(), $content['message'])); } if (!($response->isInformational() || $response->isSuccessful())) { throw new \Exception(sprintf('%s %s: %s', $response->getStatusCode(), $response->getReasonPhrase(), $content['message'])); } $response->setContent($content); }
/** * {@inheritDoc} */ public function postSend(RequestInterface $request, MessageInterface $response) { /** @var $response \Dynect\HttpClient\Message\Response */ if ($response->isClientError() || $response->isServerError()) { $content = $response->getContent(); $message = array_shift($content['msgs']); throw new RuntimeException($message['INFO'], $response->getStatusCode()); } }
/** * {@inheritDoc} */ public function postSend(RequestInterface $request, MessageInterface $response) { /** @var $response \GoSquared\HttpClient\Adapter\Buzz\Message\Response */ if ($response->isClientError() || $response->isServerError()) { $content = $response->getContent(); if (is_array($content) && isset($content['code'], $content['message'])) { switch ($content['code']) { case 4001: throw new AuthorizationException($content['message'], 403); break; case 4002: throw new ApiLimitException($content['message'], 403); break; default: throw new ErrorException(sprintf('%d: %s', $content['code'], $content['message']), $response->getStatusCode()); break; } } throw new ErrorException(isset($content['message']) ? $content['message'] : $content, $response->getStatusCode()); } }
/** * @param RequestInterface $request * @param MessageInterface $response * @throws ErrorException */ public function postSend(RequestInterface $request, MessageInterface $response) { if ($response->isClientError() || $response->isServerError()) { $content = $response->getContent(); if (is_array($content) && isset($content['message'])) { if (400 == $response->getStatusCode()) { $message = $this->parseMessage($content['message']); throw new ErrorException($message, 400); } } $errorMessage = null; if (isset($content['error'])) { $errorMessage = implode("\n", $content['error']); } elseif (isset($content['message'])) { $errorMessage = $this->parseMessage($content['message']); } else { $errorMessage = $content; } throw new RuntimeException($errorMessage, $response->getStatusCode()); } }
/** * {@inheritDoc} */ public function postSend(RequestInterface $request, MessageInterface $response) { /** @var $response \Github\HttpClient\Message\Response */ if ($response->isClientError() || $response->isServerError()) { $remaining = $response->getHeader('X-RateLimit-Remaining'); if (null !== $remaining && 1 > $remaining) { throw new ApiLimitExceedException($this->options['api_limit']); } $content = $response->getContent(); if (is_array($content) && isset($content['message'])) { if (400 == $response->getStatusCode()) { throw new ErrorException($content['message'], 400); } elseif (422 == $response->getStatusCode() && isset($content['errors'])) { $errors = array(); foreach ($content['errors'] as $error) { switch ($error['code']) { case 'missing': $errors[] = sprintf('Resource "%s" not exists anymore', $error['resource']); break; case 'missing_field': $errors[] = sprintf('Field "%s" is missing, for resource "%s"', $error['field'], $error['resource']); break; case 'invalid': $errors[] = sprintf('Field "%s" is invalid, for resource "%s"', $error['field'], $error['resource']); break; case 'already_exists': $errors[] = sprintf('Field "%s" already exists, for resource "%s"', $error['field'], $error['resource']); break; default: $errors[] = $error['message']; break; } } throw new ValidationFailedException('Validation Failed: ' . implode(', ', $errors), 422); } } throw new RuntimeException(isset($content['message']) ? $content['message'] : $content, $response->getStatusCode()); } }
/** * Process response received from API * * @access protected * @param MessageInterface $response * @return mixed * * @throws Authentication\Exception * @throws Exceptions\ForbiddenAccessException * * @deprecated Method deprecated in 0.2.0 */ protected function processResponse(MessageInterface $response) { switch ($response->getStatusCode()) { case self::HTTP_RESPONSE_OK: case self::HTTP_RESPONSE_CREATED: return $response->getContent(); break; case self::HTTP_RESPONSE_NO_CONTENT: return true; break; case self::HTTP_RESPONSE_BAD_REQUEST: return $response; case self::HTTP_RESPONSE_UNAUTHORIZED: throw new Authentication\Exception("Unauthorized: Authentication required"); break; case self::HTTP_RESPONSE_FORBIDDEN: throw new Exceptions\ForbiddenAccessException("Not enough permissions."); break; case self::HTTP_RESPONSE_NOT_FOUND: return false; break; default: return $response; break; } }
/** * Passes the returned server headers to parseServerHeaders() to check if any authentication variables need to be set. * Inteprets the returned status code and attempts authentication if status is 401 (Authentication Required) by resending * the last request with an Authentication header. * * @param RequestInterface $request A request object * @param MessageInterface $response A response object */ public function postSend(RequestInterface $request, MessageInterface $response) { $statusCode = $response->getStatusCode(); $this->parseServerHeaders($response->getHeaders(), $statusCode); }
public function postSend(RequestInterface $request, MessageInterface $response) { $this->data[] = array('request' => array('method' => $request->getMethod(), 'url' => sprintf('%s%s', $request->getHost(), $request->getResource()), 'headers' => $request->getHeaders(), 'content' => $request->getContent()), 'response' => array('statusCode' => $response->getStatusCode(), 'reasonPhrase' => $response->getReasonPhrase(), 'headers' => $response->getHeaders(), 'content' => $response->getContent())); }