point-tools/src/Skobkin/Bundle/PointToolsBundle/Service/AbstractApi.php

120 lines
3.4 KiB
PHP
Raw Normal View History

<?php
namespace Skobkin\Bundle\PointToolsBundle\Service;
use GuzzleHttp\ClientInterface;
use Psr\Http\Message\ResponseInterface;
/**
* @todo Refactor DTO deserialization
*/
class AbstractApi
{
/**
* @var ClientInterface HTTP-client from Guzzle
*/
protected $client;
2015-06-02 11:48:39 +00:00
/**
* @var string Authentication token for API
*/
protected $authToken;
/**
* @var string CSRF-token for API
*/
protected $csRfToken;
public function __construct(ClientInterface $httpClient)
{
$this->client = $httpClient;
}
/**
* @param string $path Request path
* @param array $parameters Key => Value array of query parameters
*
* @return ResponseInterface
*/
public function sendGetRequest(string $path, array $parameters = []): ResponseInterface
{
return $this->client->request('GET', $path, ['query' => $parameters]);
}
2015-06-02 11:48:39 +00:00
/**
* @param string $path Request path
* @param array $parameters Key => Value array of request data
*
* @return ResponseInterface
2015-06-02 11:48:39 +00:00
*/
public function sendPostRequest(string $path, array $parameters = []): ResponseInterface
2015-06-02 11:48:39 +00:00
{
return $request = $this->client->request('POST', $path, ['form_params' => $parameters]);
2015-06-02 11:48:39 +00:00
}
/**
* Make GET request and return data from response
*
* @param string $path Path template
* @param array $parameters Parameters array used to fill path template
* @param bool $decodeJsonResponse Decode JSON or return plaintext
* @param bool $decodeJsonToObjects Decode JSON objects to PHP objects instead of arrays
*
2015-06-02 11:48:39 +00:00
* @return mixed
*/
public function getGetRequestData($path, array $parameters = [], bool $decodeJsonResponse = false, bool $decodeJsonToObjects = false)
{
$response = $this->sendGetRequest($path, $parameters);
return $this->processResponse($response, $decodeJsonResponse, $decodeJsonToObjects);
}
/**
* Make POST request and return data from response
2015-06-02 11:48:39 +00:00
*
* @param string $path Path template
* @param array $parameters Parameters array used to fill path template
* @param bool $decodeJson Decode JSON or return plaintext
* @param bool $decodeToObjects Decode JSON objects to PHP objects instead of arrays
*
2015-06-02 11:48:39 +00:00
* @return mixed
*/
public function getPostRequestData($path, array $parameters = [], bool $decodeJson = false, bool $decodeToObjects = false)
{
2015-06-02 11:48:39 +00:00
$response = $this->sendPostRequest($path, $parameters);
return $this->processResponse($response, $decodeJson, $decodeToObjects);
}
/**
* Get HTTP client base URL
*
* @return string Base URL of client
*/
2017-01-05 21:57:32 +00:00
public function getBaseUrl(): string
{
return (string) $this->client->getConfig('base_uri');
}
/**
* @param ResponseInterface $response
* @param bool $decodeJson
* @param bool $decodeToObjects
*
* @return string|array|object
*/
private function processResponse(ResponseInterface $response, bool $decodeJson = false, bool $decodeToObjects = false)
{
if ($decodeJson) {
if ($decodeToObjects) {
return json_decode($response->getBody());
} else {
return json_decode($response->getBody(), true);
}
} else {
return $response->getBody();
}
}
}