mirror of
https://github.com/anthonyaxenov/atol-online.git
synced 2024-11-16 20:03:44 +00:00
AnthonyAxenov
03591600dd
- абстрактный класс AtolClient: - больше не наследуется от клиента guzzle, но содержит его объект - из Kkt вынесены методы, отвечающие за формирование запроса, отправку и получение ответа, в т.ч. авторизацию - переименованы исключения TooLongKktLoginException, TooLongKktPasswordException, EmptyKktLoginException и EmptyKktPasswordException - мелочи по AuthFailedException - заготовки тестов AtolClient и KktMonitor
127 lines
2.9 KiB
PHP
127 lines
2.9 KiB
PHP
<?php
|
||
/*
|
||
* Copyright (c) 2020-2021 Антон Аксенов (Anthony Axenov)
|
||
*
|
||
* This code is licensed under MIT.
|
||
* Этот код распространяется по лицензии MIT.
|
||
* https://github.com/anthonyaxenov/atol-online/blob/master/LICENSE
|
||
*/
|
||
|
||
declare(strict_types = 1);
|
||
|
||
namespace AtolOnline\Api;
|
||
|
||
use JsonSerializable;
|
||
use Psr\Http\Message\ResponseInterface;
|
||
use stdClass;
|
||
use Stringable;
|
||
|
||
/**
|
||
* Класс AtolResponse, описывающий ответ от ККТ
|
||
*
|
||
* @property mixed $error
|
||
* @package AtolOnline\Api
|
||
*/
|
||
class KktResponse implements JsonSerializable, Stringable
|
||
{
|
||
/**
|
||
* @var int Код ответа сервера
|
||
*/
|
||
protected int $code;
|
||
|
||
/**
|
||
* @var stdClass|array|null Содержимое ответа сервера
|
||
*/
|
||
protected stdClass|array|null $content;
|
||
|
||
/**
|
||
* @var array Заголовки ответа
|
||
*/
|
||
protected array $headers;
|
||
|
||
/**
|
||
* AtolResponse constructor.
|
||
*
|
||
* @param ResponseInterface $response
|
||
*/
|
||
public function __construct(ResponseInterface $response)
|
||
{
|
||
$this->code = $response->getStatusCode();
|
||
$this->headers = $response->getHeaders();
|
||
$this->content = json_decode((string)$response->getBody());
|
||
}
|
||
|
||
/**
|
||
* Возвращает заголовки ответа
|
||
*
|
||
* @return array
|
||
*/
|
||
public function getHeaders(): array
|
||
{
|
||
return $this->headers;
|
||
}
|
||
|
||
/**
|
||
* Возвращает запрошенный параметр из декодированного объекта результата
|
||
*
|
||
* @param $name
|
||
* @return mixed
|
||
*/
|
||
public function __get($name): mixed
|
||
{
|
||
return $this->getContent()?->$name;
|
||
}
|
||
|
||
/**
|
||
* Возвращает код ответа
|
||
*
|
||
* @return int
|
||
*/
|
||
public function getCode(): int
|
||
{
|
||
return $this->code;
|
||
}
|
||
|
||
/**
|
||
* Возвращает объект результата запроса
|
||
*
|
||
* @return mixed
|
||
*/
|
||
public function getContent(): mixed
|
||
{
|
||
return $this->content;
|
||
}
|
||
|
||
/**
|
||
* Проверяет успешность запроса по соержимому результата
|
||
*
|
||
* @return bool
|
||
*/
|
||
public function isValid(): bool
|
||
{
|
||
return !empty($this->getCode())
|
||
&& !empty($this->getContent())
|
||
&& empty($this->getContent()->error)
|
||
&& $this->getCode() < 400;
|
||
}
|
||
|
||
/**
|
||
* Возвращает текстовое представление
|
||
*/
|
||
public function __toString(): string
|
||
{
|
||
return json_encode($this->jsonSerialize(), JSON_UNESCAPED_UNICODE);
|
||
}
|
||
|
||
/**
|
||
* @inheritDoc
|
||
*/
|
||
public function jsonSerialize(): array
|
||
{
|
||
return [
|
||
'code' => $this->code,
|
||
'headers' => $this->headers,
|
||
'body' => $this->content,
|
||
];
|
||
}
|
||
} |