- строгая типизация - переработан класс `TestEnvParams`: - вынесен на уровень выше из под `AtolOnline\Constants` - вместо констант - две функции для получения актуальных параметров подключения по ФФД1.05 и ФФД1.2 - актуализированы `PaymentObjects` согласно #5 - исходники вынесены не уровень выше в `src` - константы теперь enum через `myclabs/php-enum` - новые константы `DocumentTypes` - классы констант финализированы - все исключения переименованы, а многие так или иначе отрефакторены (не полностью) - новые исключения `InvalidSnoException`, `InvalidPaymentAddressException` - `helpers.php` стал полноценным классом `Helpers` - удалены трейты `HasEmail`, `HasInn`, `RublesKopeksConverter` (конвертация перенесена в `Helpers`) - удалён хелпер `valid_strlen()`, вместо него теперь везде `mb_strlen()` - сущности `Client` и `Company` получили свои имплементации для `email` и `inn` - доработки в `BasicTestCase` - полное покрытие тестами: `Client`, `Company`, `Helpers` - поправлен `phpunit.xml` - везде обновлены копирайты - актуализированы и исправлены phpdoc, return types - начато введение `strict_types=1` - минимальный php теперь 8.0 - обновлены все зависимости - подключен пакет коллекций laravel для будущего использования - теперь можно `composer test` и `composer test-cov`
126 lines
2.9 KiB
PHP
126 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;
|
||
|
||
/**
|
||
* Класс AtolResponse, описывающий ответ от ККТ
|
||
*
|
||
* @property mixed $error
|
||
* @package AtolOnline\Api
|
||
*/
|
||
class KktResponse implements JsonSerializable
|
||
{
|
||
/**
|
||
* @var int Код ответа сервера
|
||
*/
|
||
protected int $code;
|
||
|
||
/**
|
||
* @var stdClass Содержимое ответа сервера
|
||
*/
|
||
protected $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)
|
||
{
|
||
return $this->getContent()->$name;
|
||
}
|
||
|
||
/**
|
||
* Возвращает код ответа
|
||
*
|
||
* @return int
|
||
*/
|
||
public function getCode(): int
|
||
{
|
||
return $this->code;
|
||
}
|
||
|
||
/**
|
||
* Возвращает объект результата запроса
|
||
*
|
||
* @return stdClass|null
|
||
*/
|
||
public function getContent(): ?stdClass
|
||
{
|
||
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()
|
||
{
|
||
return json_encode($this->jsonSerialize(), JSON_UNESCAPED_UNICODE);
|
||
}
|
||
|
||
/**
|
||
* @inheritDoc
|
||
*/
|
||
public function jsonSerialize()
|
||
{
|
||
return [
|
||
'code' => $this->code,
|
||
'headers' => $this->headers,
|
||
'body' => $this->content,
|
||
];
|
||
}
|
||
} |