rarus/bonus-server-php-sdk
Composer 安装命令:
composer require rarus/bonus-server-php-sdk
包简介
Bonus server PHP SDK
README 文档
README
Установка
composer require rarus/bonus-server-php-sdk^2.0
Зависимости
- PHP >= 8.2+
- ext-bcmath
- ext-curl
- ext-json
Быстрый старт
$client = RarusLMS::client('API_URL','API_TOKEN'); $card = $client->cards()->getById(1); // Возвращает Cards\DTO\CardDto $user = $client->users()->getById(1); // Возвращает Users\DTO\UserDto // Сериализация в массив $payload = $card->toArray();
Расширенный пример использования
use GuzzleHttp\HandlerStack; use GuzzleHttp\MessageFormatter; use GuzzleHttp\Middleware; use Money\Currency; use Monolog\Handler\StreamHandler; use Monolog\Logger; use Rarus\LMS\SDK\RarusLMS; use Rarus\LMS\SDK\Users\DTO\Fabric; use Rarus\LMS\SDK\Users\DTO\Factory; use Symfony\Component\Cache\Adapter\FilesystemAdapter; use Symfony\Component\Cache\Psr16Cache; $logger = new Logger('rarus-bonus-service'); $logger->pushHandler( new StreamHandler( getenv('LOG_FILE'), getenv('LOG_LEVEL'), ) ); $guzzleHandlerStack = HandlerStack::create(); $guzzleHandlerStack->push( Middleware::log( $logger, new MessageFormatter(MessageFormatter::DEBUG) ) ); $httpClient = new GuzzleHttp\Client([ 'base_uri' => getenv('API_URL'), 'connect_timeout' => 10, 'headers' => [ 'Accept' => 'application/json', ], 'handler' => $guzzleHandlerStack, ]); $psr6Cache = new FilesystemAdapter(); $psr16Cache = new Psr16Cache($psr6Cache); $client = RarusLMS::factory() ->setApiKey(getenv('API_TOKEN')) ->setHttpClient($httpClient) ->setLogger($logger) ->setCurrency(new Currency('RUB')) ->setDateTimeZone(new DateTimeZone('Europe/Moscow')) ->setCache($psr16Cache) ->build(); $userDto = Factory::create() ->withName('Иванов Иван') ->withPhone('+7(900)000-00-00') ->withShopId(1) ->withEmail('test@example.com') ->build(); $newUser = $client->users()->createUser($userDto); // Возвращает Users\DTO\UserDto $user = $client->users(300)->getUserById(1); // кеширует ответ на 5 мин $card = $client->cards()->getCardById(1); $card = $client->cards()->getById(1); // Возвращает Cards\DTO\CardDto $user = $client->users()->getById(1); // Возвращает Users\DTO\UserDto // Сериализация в массив $payload = $card->toArray();
Денежные суммы (moneyphp/money)
Все денежные поля представлены типом Money (minor units). Пример в CardDto:
use Money\Money; use Money\Currency; // В fromArray: $balance = MoneyParser::parse($data['balance'] ?? 0.0, $currency); // В toArray (для JSON): 'balance' => MoneyParser::toString($this->balance),
Примеры
Получить карту и вывести баланс
use Money\Currency; $card = $client->cards()->getById(1); $balanceMoney = $card->balance->getAmount(); echo MoneyParser::convertMoneyToString($balanceMoney, new Currency('RUB')); // 509,7050
Сериализация в массив (например, для кэша)
$cached = $card->toArray(); $again = Cards\DTO\CardDto::fromArray($cached);
Ошибки
Все HTTP/протокольные ошибки приводятся к исключениям пространства имён RarusBonus\Exceptions:
BaseException— базовое исключение SDK, от которого наследуются все остальные типы ошибок.ApiException— ошибка, возвращённая сервером API (статус 4xx/5xx).NetworkException— ошибка сетевого уровня (таймаут, DNS, SSL и т. п.).InvalidArgumentException— ошибка, возникающая при передаче некорректных аргументов в методы SDK.RuntimeException— ошибка, возникающая во время выполнения программы (например, ошибки парсинга или логики).UnknownException— непредусмотренная ошибка, не попавшая в другие категории.
try { $user = $this->client->users()->getUserById($userId); } catch (NetworkException $e) { // ошибка сетевого уровня } catch (ApiClientException $e) { // ошибка, возвращённая сервером API } catch (UnknownException $e) { // непредусмотренная ошибка }
统计信息
- 总下载量: 323
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 3
- 点击次数: 0
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2017-03-13