Manage products and payment links via API
Create a product
Request
To create a product, send a POST
request to https://aw.horizonpay.kz/products
with the following parameters:
Parameter | Type | Description |
---|---|---|
name * required |
string | Product name. |
description * required |
string | Product description. |
currency * required |
string | A product price currency in the ISO-4217 alpha-3 code format. For example, USD . |
amount * required |
string | Product price amount in minimal units. |
quantity | string | Products quantity available to sell. Don't send the parameter if infinite is true |
infinite | boolean | Set to true if product's quantity is unlimited. For instance, it is a virtual product. |
visible_fields | array | It is an array which may consist of the values first_name , last_name , country , state , city , address , zip , phone , birth_date , email , taxpayer_id . Fields for customer's data indicated in the array will be displayed at the payment page. |
test | boolean | true or false . The product will be a test one if it is true |
immortal | boolean | true or false . Set to true if payment period is unlimited. |
expired_at | string | Date and time till a product can be paid. Format: YYYY-MM-DDThh:mm:ssTZD, where YYYY – year (for example 2019), MM – month (for example 02), DD – day (for example 09), hh – hours (for example 18), mm – minutes (for example 20), ss – seconds (for example 45), TZD – time zone (+hh:mm или –hh:mm) |
return_url | string | URL where to return Customer back to a merchant's shop after a payment completion. If the parameter is not defined, Customer will be redirected to a shop URL registered with Horizonpay. |
shop_id | integer | Shop ID. |
language * required |
string | Change to payment page language. English (en ) is set by default. Possible values of language parameter. |
transaction_type | string | Transaction type. Default - payment . Possible values are: payment - combination of authorization and capture processed at a time; authorization - verify and hold cardholder's funds. |
Request example with an unlimited product quantity and an unlimited payment period
curl https://aw.horizonpay.kz/products \
-X POST -u {Your shop id}:{Your shop secret key} \
-H "Content-Type: application/json" \
-d \
'{
"name": "product",
"description": "description",
"currency": "USD",
"amount": "990",
"infinite": true,
"test": false,
"immortal": true,
"return_url": "http://return-url.com",
"shop_id": "1",
"language": "en",
"transaction_type": "payment"
}'
Request example with limited product's quantity and limited payment period
curl https://aw.horizonpay.kz/products \
-X POST -u shop_id:secret_key \
-H "Content-Type: application/json" \
-H "Accept: application/json" \
-d \
'{
"name": "product",
"description": "description",
"currency": "USD",
"amount": "990",
"quantity": "10",
"infinite": false,
"test": false,
"immortal": false,
"expired_at": "2023-12-31",
"return_url": "http://return-url.com",
"shop_id": "1",
"language": "en",
"transaction_type": "payment"
}`
Response
If credentials and parameters are valid, Horizonpay will return 201
HTTP status code and a new product object with payment links.
In case of invalid parameters in the request Horizonpay will return 422
HTTP status code and an error message.
Response example, HTTP status code 201
{
"id": "prd_ed27b047d3ccd1a6",
"name": "product",
"description": "description of product",
"currency": "USD",
"amount": 990,
"quantity": 10,
"infinite": false,
"language": "en",
"transaction_type": "payment",
"created_at": "2022-12-20T18:54:42.033Z",
"updated_at": "2022-12-20T18:54:42.033Z",
"test": false,
"additional_data": {},
"pay_url": "https://aw.horizonpay.kz/products/prd_ed27b047d3ccd1a6/pay",
"payment_url": "https://aw.horizonpay.kz/products/prd_ed27b047d3ccd1a6/pay",
"confirm_url": "https://checkout.horizonpay.kz/v2/confirm_order/prd_ed27b047d3ccd1a6/1"
}
Response to the request with invalid parameters, HTTP status code 422
{
"message": "Currency is not in ISO 4217 Alpha-3 format. Currency is unknown ISO 4217 Alpha-3 code",
"errors": {
"currency": [
"is not in ISO 4217 Alpha-3 format",
"is unknown ISO 4217 Alpha-3 code"
]
}
}
Get a payment link and details for an existing product
Request
To get details of a product, send a GET
request to https://aw.horizonpay.kz/products/{product_id}
, where {product_id}
is a product identifier, the id
parameter value from the response to the request to create a product.
Example the request to get details of the product with the ID prd_ed27b047d3ccd1a6
curl -u shop_id:secret \
https://aw.horizonpay.kz/products/prd_ed27b047d3ccd1a6
Response
If the product ID exists, Horizonpay returns 200
HTTP status code and the product details.
In case of invalid parameters in the request Horizonpay will return 302
HTTP status code and the response body, where an error description will be shown.
Response with a payment link, HTTP status code 200
{
"id": "prd_ed27b047d3ccd1a6",
"name": "product",
"description": "description of product",
"currency": "USD",
"amount": 990,
"quantity": 10,
"infinite": false,
"language": "en",
"transaction_type": "payment",
"created_at": "2022-12-20T18:54:42.033Z",
"updated_at": "2022-12-20T18:54:42.033Z",
"test": false,
"additional_data": {},
"pay_url": "https://aw.horizonpay.kz/products/prd_ed27b047d3ccd1a6/pay",
"payment_url": "https://aw.horizonpay.kz/products/prd_ed27b047d3ccd1a6/pay",
"confirm_url": "https://checkout.horizonpay.kz/v2/confirm_order/prd_ed27b047d3ccd1a6/1"
}
Retrieve all products
Request
To retrieve all products, send a GET
request to https://aw.horizonpay.kz/products
.
Request example
curl -u {Your shop id}:{Your shop secret key} \
https://aw.horizonpay.kz/products
Response
If credentials are valid, Horizonpay will return 200
HTTP status code and products.
Response example
[
{
"id": "prd_4e3933e63c7490fc",
"name": "product",
"description": "description of product",
"amount": 100,
"currency": "USD",
"language": "en",
"infinite": true,
"quantity": 0,
"transaction_type": "payment",
"created_at": "2023-05-02T17:35:14.950Z",
"updated_at": "2023-05-02T17:35:14.950Z",
"additional_data": {},
"test": false,
"pay_url": "https://aw.horizonpay.kz/products/prd_4e3933e63c7490fc/pay",
"payment_url": "https://aw.horizonpay.kz/products/prd_4e3933e63c7490fc/pay",
"confirm_url": "https://checkout.horizonpay.kz/v2/confirm_order/prd_4e3933e63c7490fc/1"
},
{
"id": "prd_1567bece456ac4aa",
"name": "product 2",
"description": "description of product 2",
"amount": 990,
"currency": "EUR",
"language": "it",
"infinite": false,
"quantity": 7,
"transaction_type": "payment",
"created_at": "2023-02-15T11:54:59.579Z",
"updated_at": "2023-02-15T11:54:59.579Z",
"additional_data": {},
"test": false,
"pay_url": "https://aw.horizonpay.kz/products/prd_1567bece456ac4aa/pay",
"payment_url": "https://aw.horizonpay.kz/products/prd_1567bece456ac4aa/pay",
"confirm_url": "https://checkout.horizonpay.kz/v2/confirm_order/prd_1567bece456ac4aa/1"
},
{
"id": "prd_3c97b6f1bba28db7",
"name": "test product",
"description": "description of test product",
"amount": 100,
"currency": "USD",
"language": "en",
"infinite": true,
"quantity": null,
"transaction_type": "authorization",
"created_at": "2020-01-21T10:46:20.232Z",
"updated_at": "2020-02-17T16:53:43.770Z",
"additional_data": {},
"test": true,
"pay_url": "https://aw.horizonpay.kz/products/prd_3c97b6f1bba28db7/pay",
"payment_url": "https://aw.horizonpay.kz/products/prd_3c97b6f1bba28db7/pay",
"confirm_url": "https://checkout.horizonpay.kz/v2/confirm_order/prd_3c97b6f1bba28db7/1"
}
]
Update a product
Request
To update product details, send a PUT
to https://aw.horizonpay.kz/products/{product_id}
, where {product_id}
is a product identifier, the id
parameter value from the response to the request to create a product.
The request parameters as the same as the parameters of the request to create a product.
Example to update an amount and a quantity of the product with the ID prd_1567bece456ac4aa
curl https://aw.horizonpay.kz/products/prd_1567bece456ac4aa \
-X PUT -u {Your shop id}:{Your shop secret key} \
-H "Content-Type: application/json" \
-d \
'
{
"amount": 950,
"infinite": false,
"quantity": "5"
}
Response
If the product ID exists and credentials are valid, Horizonpay will return 204
HTTP status code and empty body.