131 / php-sdk
Bank131 PHP SDK
Installs: 37 297
Dependents: 0
Suggesters: 0
Security: 0
Stars: 5
Watchers: 2
Forks: 7
Open Issues: 1
Requires
- php: ^7.3 || ^8.0
- ext-curl: *
- ext-json: *
- ext-mbstring: *
- ext-openssl: *
- guzzlehttp/guzzle: ~6.0 || ~7.0
- psr/http-message: ^1.0
- psr/log: ^1.1||^2.0||^3.0
Requires (Dev)
- phpunit/phpunit: >=8.0
- vimeo/psalm: ^3.11
- dev-master
- 2.0.0
- 0.34.0
- 0.33.0
- 0.32.0
- 0.31.0
- 0.30.0
- 0.29.0
- 0.28.3
- 0.28.2
- 0.28.1
- 0.28.0
- 0.27.0
- 0.26.0
- 0.25.0
- 0.24.0
- 0.23.0
- 0.22.0
- 0.21.0
- 0.20.0
- 0.19.0
- 0.18.0
- 0.17.0
- 0.16.2
- 0.16.1
- 0.16.0
- 0.15.5
- 0.15.4
- 0.15.3
- 0.15.2
- 0.15.1
- 0.15.0
- 0.14.1
- 0.14.0
- 0.13.1
- 0.13.0
- 0.12.0
- 0.11.0
- 0.10.0
- 0.9.0
- 0.8.0
- 0.7.0
- 0.6.3
- 0.6.2
- 0.6.1
- 0.6.0
- 0.5.0
- 0.4.1
- 0.4.0
- 0.3.1
- 0.3.0
- 0.2.0
- 0.1.0
- dev-DT-243
- dev-DT-245
- dev-DT-172
- dev-CHACK-2113
- dev-CHACK-476
- dev-DT-70
- dev-CHACK-1754
- dev-PAHOM-4276
- dev-PAHOM-3739
- dev-CHACK-2030
- dev-CHACK-476-v2
- dev-CHACK-1610
- dev-PAHOM-4144
- dev-CHACK-1585
- dev-PAHOM-3944
- dev-CHACK-951
- dev-CHACK-1333
- dev-PAHOM-2434-extra
- dev-CHACK-831
- dev-PAHOM-910
- dev-PAHOM-541+subscriptions
- dev-dev
This package is auto-updated.
Last update: 2024-11-14 19:41:55 UTC
README
Библиотека для работы с API Bank131 в приложениях написанных на языке PHP.
Требования
- PHP 7.3 или выше
Установка
Рекомендуемый способ установки Bank 131 SDK - установка с помощью пакетного менеджера Composer.
Для включения данной библиотеки в ваш проект необходимо выполнить следующие команды в консоли:
cd /path/to/your/project
composer require 131/php-sdk
Документация
Более подробные примеры в документации API Банк 131
Быстрый старт
Инициализация клиента:
use Bank131\SDK\Client; use Bank131\SDK\Config; $config = new Config( 'https://demo.bank131.ru', 'test_project', file_get_contents('/path/to/your/private_key.pem'), file_get_contents('/path/to/bank131/public_key.pem') ); $client = new Client($config);
Выпуск публичного токена для создания виджета:
use Bank131\SDK\API\Request\Builder\RequestBuilderFactory; $request = RequestBuilderFactory::create() ->issuePublicTokenBuilder() ->setTokenizeWidget() // публичный токен с доступом к виджету токенизации ->setSelfEmployedWidget('111111111111') // публичный токен с доступом к виджету для работы с самозанятыми ->setAcquiringWidget('session_id') // публичный токен с доступом к виджету эквайринга ->build(); $response = $this->client->widget()->issuePublicToken($request);
Создание и старт эквайринг сессии:
use Bank131\SDK\API\Request\Builder\RequestBuilderFactory; use Bank131\SDK\Client; use Bank131\SDK\DTO\Customer; use Bank131\SDK\DTO\Card\BankCard; $request = RequestBuilderFactory::create() ->createPaymentSession() ->build(); /** @var Client $client */ $createSessionResponse = $client->session()->create($request); $request = RequestBuilderFactory::create() ->startPaymentSession($createSessionResponse->getSession()->getId()) ->setCard(new BankCard('4242424242424242', '12', '22', '123', 'CARDHOLDER NAME')) ->setAmount(10000, 'rub') ->setCustomer(new Customer('reference')) ->setMetadata('your metadata here') ->build(); $sessionStartResponse = $this->client->session()->startPayment($request);
Создание и старт сессии для осуществления выплаты:
use Bank131\SDK\API\Request\Builder\RequestBuilderFactory; use Bank131\SDK\DTO\Card\EncryptedCard; use Bank131\SDK\DTO\Customer; use Bank131\SDK\DTO\Participant; use Bank131\SDK\Client; $request = RequestBuilderFactory::create() ->createPayoutSession() ->build(); /** @var Client $client */ $createSessionResponse = $client->session()->create($request); $recipient = new Participant(); $recipient->setFullName('John Doe'); $request = RequestBuilderFactory::create() ->startPayoutSession($createSessionResponse->getSession()->getId()) ->setCard(new EncryptedCard('number_hash_here')) ->setRecipient($recipient) ->setAmount(10000, 'rub') ->setCustomer(new Customer('reference')) ->setMetadata('your metadata here') ->build(); $sessionStartResponse = $this->client->session()->startPayout($request);
Создание объекта выплатной сессии СБП
$request = RequestBuilderFactory::create() ->createPayoutSession() ->setBankAccount( new BankAccountFPS( '0070009210197', '100000000197', 'Перевод средств по договору' ) ) ->build();
Создание объекта платежной сессии через СБП
RequestBuilderFactory::create() ->createPaymentSession() ->makeFasterPaymentSystem() ->setAmount('3000', \Bank131\SDK\DTO\Enum\CurrencyEnum::RUB) ->build();
Запрос статуса сессии:
use Bank131\SDK\Client; /** @var Client $client */ $response = $this->client->session()->status('session_id');
Возврат:
use Bank131\SDK\API\Request\Builder\RequestBuilderFactory; $request = RequestBuilderFactory::create() ->refundSession('session_id') ->setAmount(1000, 'rub') ->setMetadata('your metadata here') ->build(); $response = $this->client->session()->refund($request);
Запрос баланса кошелька:
use Bank131\SDK\Client; /** @var Client $client */ $response = $client->wallet()->balance();
Обработка веб-хуков:
use Bank131\SDK\Client; use Bank131\SDK\Services\WebHook\Hook\WebHookTypeEnum; /** @var Client $client */ $hook = $client->handleWebHook('sign from headers', 'request body'); switch ($hook->getType()) { case WebHookTypeEnum::READY_TO_CONFIRM: $client->session()->confirm($hook->getSession()->getId()); break; case WebHookTypeEnum::READY_TO_CAPTURE: $client->session()->capture($hook->getSession()->getId()); break; case WebHookTypeEnum::ACTION_REQUIRED: //do some logic break; case WebHookTypeEnum::PAYMENT_FINISHED: //do some logic break; case WebHookTypeEnum::PAYMENT_REFUNDED: //do some logic break; }