Внимание! Перед началом работы с API на ввод, необходимо передать ТП Paykassma IP-адрес с которого будут отправляться запросы. |
Запрос для передачи в Paykassma вашего ID транзакции (custom_transaction_id). В дальнейшем этот ID присваивается транзакции совершаемой пользователем и передается в постбеке.
https://api.{URL_сервера_Paykassma}/api/v1/payment/save-transaction-custom-id |
Request method: POST
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
label | string (190) | ДА | Уникальный идентификатор (ID) пользователя, осуществляющего платеж |
transaction_custom_id | string (190) | ДА | Идентификатор транзакции в системе Клиента |
{ "label": "55", "transaction_custom_id": "123465477897" } |
{ "status": "ok" } |
{ "status": "fail" "message": "MESSAGE" } |
https://api.{URL_сервера_Paykassma}/api/v1/payment-systems/available |
Request method: GET
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
currency_code | string[] (3) | ДА | Массив состоящий из кодов валют. Отобразятся ПС работающие по указанным валютам |
label | string (190) | ДА | Уникальный идентификатор (ID) пользователя, осуществляющего платеж |
{ "currency_code": [ "USD", "INR" ], "label": "55" } |
{ "status": "ok", "params": { "gif_guide": { "upi": "http:\/\/api.pay.test\/storage\/guide-image\/upi.mp4?cache=1587635151", "phonePe": "http:\/\/api.pay.test\/storage\/guide-image\/phonePe.gif?cache=1589958899", "bkash": "http:\/\/api.pay.test\/storage\/guide-image\/bkash.mpg?cache=1611553163" }, "currency_data": [ { "code": "INR", "symbol": "₹" } ], "wallets": [ { "type": "paytm", "currency_code": "INR", "order": 5, "logo": "http:\/\/api.pay.test\/storage\/payment_system\/logos\/paytm_default.svg", "name": "PayTM" }, { "type": "paytm", "currency_code": "INR", "order": 5, "logo": "http:\/\/api.pay.test\/storage\/payment_system\/logos\/paytm_34.svg", "name": "paytm", "hints": [ { "type": "requisites_hint", "text": null }, { "type": "payment_hint", "text": null }, true ], "show_limits": true } ], "imps": { "INR": { "min": "8000", "max": "560000" } }, "bkash": { "BDT": { "min": "100", "max": "1000000" } }, "upi": { "INR": { "min": "20000", "max": "50000" } }, "paytm": { "INR": { "min": "100000", "max": "20000000" } }, "phone_pe": { "INR": { "min": "100", "max": "800000" } } } } } |
{ "status": "fail" "message": "MESSAGE" } |
В данный момент существуют два вида запроса для создания платежа в зависимости от ПС.
Внимание! Для получения полного списка доступных Вам ПС, необходимо обратиться в ТП Paykassma. ТП предоставят полные примеры запросов для доступных в данный момент ПС. Они же определят правильный запрос, зависящий от выбранной ПС. |
https://api.{URL_сервера_Paykassma}/api/v1/transaction/create/{wallet_type} |
https://api.{URL_сервера_Paykassma}/api/v1/transaction/create/paytm |
В данном случае сначала мы принимаем запрос на ввод по PayTM, далее в ответе мы предоставим реквизиты кошелька, на который пользователь должен перевести платеж, а после оплаты Вам необходимо отправить запрос на активацию транзакции
Request method: POST
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
currency | string (3) | ДА | Код валюты |
label | string (190) | ДА | Уникальный идентификатор пользователя, осуществляющего платеж |
{ "currency": "INR", "label": "eligendi" } |
{ "status": "ok", "params": { "identifier": "6234234234" } } |
{ "status": "fail" "message": "MESSAGE" } |
https://api.{URL_сервера_Paykassma}/api/v1/transaction/activate |
Request method: POST
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
currency_code | string (3) | ДА | Код валюты |
wallet_type | string (190) | ДА | Значение из списка доступных ПС. |
label | string (190) | ДА | Уникальный идентификатор пользователя, осуществляющего платеж |
key1 | string (190) | ДА | Код, по которому происходит активация (Transiction_ID), полученный от пользователя |
{ "currency_code": "USD", "wallet_type": "paytm", "label": "55", "key1": "123-ABC-456-DEF" } |
{ "status": "ok" } |
{ "status": "fail" "message": "MESSAGE" } |
https://api.{URL_сервера_Paykassma}/api/v1/payment/create/{payment_system} |
Request method: POST
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
language | string (2) | ДА | Язык интерфейса |
currency | string (3) | ДА | Код валюты |
bank | string (3) | ДА | Банк, через который осуществляется платеж |
amount | numeric (ограничена max. | ДА | Сумма платежа |
label | string (190) | ДА | Уникальный идентификатор пользователя, осуществляющего платеж |
redirect_url | url | ДА | URL страницы для редиректа после платежа |
{ "language": "en", "currency": "USD", "bank": "MBB", "amount": "1000", "label": "55", "redirect_url": "https:\/\/google.com" } |
{ "status": "ok" } |
{ "status": "fail" "message": "MESSAGE" } |
Запрос на предоставление информации о накоплениях определенного пользователя
Для сохранения информации о транзакциях, сумма которых не превышает размер минимального депозита для конкретной платёжной системы, был реализован функционал накоплений. Транзакции пользователя (выборка по параметру label) копятся в системе и не зачисляются на счёт пользователя до тех пор, пока их сумма не достигнет минимального депозита этой платёжной системы. Постбек на сервер клиента отправится только после достижения суммы минимального депозита. До момента отправки postback транзакция не считается зачисленной на счёт.
https://api.{URL_сервера_Paykassma}/api/v1/deposit-info |
Request method: GET
Format: JSON
Parameters:
Параметр | Тип | Обязательность | Описание |
label | string (190) | ДА | Уникальный идентификатор пользователя, осуществляющего платеж |
wallet_type | url | ДА | Значение из списка доступных ПС. |
currency | string (3) | ДА | Код валюты |
code | string (190) | НЕТ | Название ручной платёжной системы. |
{ "label": "55", "wallet_type": "paytm", "currency": "UDS" } |
{ "status": "ok" "stockpiling_sum": 0, "lacks_sum": 0, "minimum_deposit": 148 } |
{ "status": "fail" "message": "MESSAGE" } |
Для вывода денежных средств пользователем через доступные для Клиента платежные системы, необходимо:
https://api.{URL_сервера_Paykassma}/withdrawal/manual/create |
Внимание: При передаче данных не должно быть пробелов в начале и конце параметров в JSON файле |
Необходимые параметры для передачи в POST запросе
Параметр | Тип данных | Описание | |
wallet_type | text(191) Выбор из доступного списка | Тип платежной системы | |
wallet_recipient | string(191) | Кошелек получателя, на чей счет будет совершенна выплата Внимание! wallet_recipient (Для метода Paytm) должен содержать номер кошелька Paytm без международного кода +91 | |
wallet_sender | string(191) | Кошелек отправителя, с чьего счета будет снятие денежных средств. Конечный выбор отправителя остается за Paykassma. Внимание: в текущей реализации необходимо заполнить поле произвольными четырьмя цифрами | |
account_name | string(191) | Имя держателя банковского аккаунта | |
account_number | string(191) | Номер банковского аккаунта | |
string(191) | Электронная почта того, кому выплачивают | ||
amount | double
| Сумма вывода, в случае с PayTm, принимается сумма кратная 10! | |
withdrawal_id | integer | ID вывода на стороне клиента (возвращается в постбеке). |
$data = [ 'wallet_type' => 'paytm', 'wallet_recipient' => 1234567890, 'wallet_sender' => 'empty', 'email' => '[email protected]', 'amount' => 300, 'withdrawal_id' => '1234567', ]; $data['signature'] = generateSignature($data); // return fa0ee1e2acf7f898635ec417491381c0a4f9d35c //send $data like json ... function generateSignature(array $data) { $privateKey = 'yourprivatekey'; ksort($data); $implode = implode(':', $data); return sha1($privateKey . md5($implode)); } |
{ "wallet_type":"paytm", "wallet_recipient":"123123232", "wallet_sender":1111, "email":"[email protected]", "amount":1000, "withdrawal_id":"13", "signature":"fae51673a8a9c85f724317214bd0bcc665ebc799" } |
При отправки к Paykassma запроса на вывод, в первом ответе получаете сформированные данные по заявке, без сигнатуры следующего вида:
{ "id":1, "wallet_type":"paytm", "wallet_recipient":"123123232", "wallet_sender":"1111", "email":"[email protected]", "amount":1000, "status":1, "created_at":"2020-07-08 07:06:06", "updated_at":"2020-07-08 09:40:39" } |
Статусы выводов:
Статус | Причина |
NOT_APPROVE (0) | в обработке |
APPROVE (1) | успешно |
FAILED (2) | неуспешно |
Внимание! Данный раздел находится в доработке. При интеграции конкретных платежных систем необходимо уточнять актуальные статусы у ТП Paykassma.com. |