/**
  * Internal logged wrapper for HTTP GET request
  *
  * @param string $url URL for GET request
  *
  * @return type
  */
 protected function _get($url)
 {
     $start = microtime(true);
     try {
         $result = $this->client()->get($url);
     } catch (Exception $e) {
         $result = new Response(['HTTP/1.1 ' . $e->getCode()], $e->getMessage());
     }
     $timeTook = microtime(true) - $start;
     if (!$result->isOk()) {
         $this->_httpErrors[] = $result->statusCode() . ' - ' . $result->body();
     }
     if ($this->_connection->logQueries() && $this->_connection->logger()) {
         $log = new LoggedQuery();
         $log->query = $url;
         $log->took = round($timeTook * 1000);
         if ($result->isOk()) {
             $log->numRows = strlen($result->body());
         } else {
             $log->error = new Exception('HTTP Error ' . $result->statusCode() . "\n" . $result->body());
         }
         $this->_connection->logger()->log($log);
     }
     return $result;
 }
Example #2
0
 /**
  * Test body()
  *
  * @return void
  */
 public function testBody()
 {
     $data = ['property' => 'value'];
     $encoded = json_encode($data);
     $response = new Response([], $encoded);
     $result = $response->body('json_decode');
     $this->assertEquals($data['property'], $result->property);
     $this->assertEquals($encoded, $response->body());
     $this->assertEquals($encoded, $response->body);
     $this->assertTrue(isset($response->body));
 }
 /**
  * Verifica si la respuesta del servidor tenĂ­a errores
  * @param \Cake\Network\Http\Response $response
  * @return bool
  */
 public function responseHasError($response)
 {
     return $response->statusCode() != 200 || $response->body() == null || strpos(strtolower($response->body()), 'error') !== false;
 }