Повернення коштів за регулярними платежами
За необхідності, кошти, що були списані з клієнта за регулярними платежами можуть бути повернуті. Повернення коштів може проводитися як щодо всієї суми платежу, так і щодо його частини.
Формат взаємодії:
Для повернення коштів відправте POST
-запит до ендпоїнту /api/v1/pos/:posId/recurring/:recurringId/payments/:paymentId/refund
, де recurringId
- унікальний ID підписки, paymentId
- унікальний ID платежу.
Параметри запиту:
Parameter | Type | Required | Description |
---|---|---|---|
order_currency | CURRENCY | ✅ | Currency of original order |
refund_amount | Number | Amount to be refunded. If not provided, a full refund of the transaction will be processed. Must be a positive number. The number of decimal digits must be less than or equal to 2 (e.g., 100.00, 250, 50.50) | |
comment | String | Refund comment. Can be used for describing reasons of refund or for passing another data about operation (max length is 2048 characters) | |
server_url | URL | Webhook notification will be sent to this URL |
Приклад запиту:
Body:
{
"order_currency": "USD",
"refund_amount": 100,
"comment": "10101",
"server_url": "https://callback.blackhole.com/callback/capture"
}
інформація
Cума всіх часткових повернень за платежем не може перевищувати загальну суму оригінального платежу.
Параметри відповіді:
Parameter | Type | Description |
---|---|---|
operation_id | UUID | Unique Tranzzo refund identifier |
payment_id | UUID | Tranzzo payment identifier of primary operation |
order_id | String | Merchant's order_id of primary operation (max length is 32 characters) |
transaction_id | UUID | Unique Tranzzo transaction identifier |
pos_id | UUID | Merchant's identifier (POS_ID ) |
mode | MODE | direct |
method | METHOD | refund |
amount | Number | Actual refund amount |
currency | CURRENCY | Transaction currency |
status | STATUS | Transaction status |
status_code | STATUS_CODE | Tranzzo payment status code |
status_description | STATUS_DESCRIPTION | Tranzzo payment status code description |
created_at | TIMESTAMP | Timestamp when transaction was created |
processed_at | TIMESTAMP | Timestamp when transaction was updated last time |
fee | Object | Amount and currency of commission |
comment | String | Refund comment |
receipt_url | URL | URL link to the receipt for the corresponding transaction |
Приклад відповіді:
{
"operation_id": "f7d0c7cb-af32-441f-b2af-4d90d4da70e1",
"payment_id": "fdf1a710-8a34-414c-b023-b7e78104301a",
"order_id": "123",
"transaction_id": "4f98dc46-ffff-4ba7-a267-286fe7669894",
"pos_id": "dc728de1-51ef-4ef1-80f7-3b44b07b5667",
"mode": "direct",
"method": "refund",
"amount": 100,
"currency": "UAH",
"status": "success",
"status_code": "1004",
"status_description": "Refund successful.",
"created_at": "2018-10-10T10:10:10.100",
"processed_at": "2018-10-10T10:10:12.000",
"fee": null,
"comment": "10101",
"receipt_url": "https://cpay.tranzzo.com/public/receipt/12491284012940129402424124124124124ffef3re3rf32f2vf"
}
Наступні кроки:
Тестування платіжного процесу:
- Створіть підписку на регулярні платежі, використовуючи автентифікаційні дані тестового проєкту.
- Ініціюйте проведення вторинної операції повернення.
- Налаштуйте вебхуки.
- Скористайтеся даними для тестування для отримання різних кодів результатів операцій.
- Опрацьовуйте отримані помилки.
Вихід в онлайн:
- Коли наша команда Комплаєнсу активує робочий проєкт, замініть автентифікаційні дані тестового проєкту на дані робочого.