Skip to content

API version 3

Introduction

To make API responses more user-friendly and comprehensive for you, Horizonpay starts introducing the API version 3 (API v.3). The main changes relate to the response parameters and transaction status codes. The codes now go along with friendly messages for you to get more information about transaction processing.

As of September 15, 2022, the API v.3 is already configured for all https://gw.horizonpay.kz/ - endpoints. To submit requests, just add the X-API-Version: 3 header to the request. For response parameters and their description, please use the guide below.

For any other questions related to the Horizonpay API v.3, you are welcome to contact our Tech Support Team on [email protected].

Requests

To send POST or GET requests to the API v.3 of the https://gw.horizonpay.kz/- endpoints, add the X-API-Version: 3 header to the request, or use the header instead of X-API-Version: 2, if the latter was required.

As for the request parameters, use the parameters described for the required endpoint. No additional parameters are required.

Responses

The API v.3 responses have the following parameters:

Parameter Type Description
uid string A UID of the processed transaction.
status string A status of the processed transaction.
code string A transaction processing code.
friendly_message string Message for the customer.
message string A message from the bank system.
amount integer An amount of the transaction in minimal currency units. For example, USD 12.00 is transmitted as 1200.
currency string A currency of the transaction in the ISO-4217 format, for example, USD.
description string A transaction description.
type string A transaction type.
tracking_id string Set to the tracking_id value from the request.
test boolean Set to true if a transaction is a test one.
created_at string A time when the transaction was created at in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD.
updated_at string A time when the transaction was last updated at in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD.
paid_at string A time when the transaction was successfully completed at in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD. Set to null if the transaction is incomplete.
expired_at string A time when the transaction expires in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD, i.e. a time till which the customer can complete the transaction. Set to null if the parameter is not applicable to the transaction.
closed_at string A time when a banking day in the acquiring bank ends in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD. Set to null if the parameter is not applicable to the transaction.
settled_at string A time when the acquiring bank settled the transaction amount to the merchant's current account in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD. Set to null if the parameter is not applicable to the transaction.
manually_corrected_at string A time when the transaction was successfully completed at in the ISO 8601 format YYYY-MM-DDThh:mm:ssTZD. Set to null if the parameter is not applicable to the transaction.
redirect_url string A URL of the page to finalize the transaction.

If the status parameter is set to incomplete, redirect the customer to this URL. It runs the 3-D Secure verification of the cardholder.
parent_uid string A UID of the parent transactions, if applicable.
reason string A description of the chargeback reason.
recurring_type string A type of the recurring transaction. Set to null if the parameter is not applicable to the transaction.
language string A language parameter value from the request, or en, if the parameter is not sent in the request.
status_code integer A status code of the 3-D Secure verification. Set to null if the parameter is not applicable to the transaction.
errors object A section of error details and parameters.
customer object A section of the customer information.
ip string The customer's IP address.
email string The customer's email.
device_id string The customer's device ID.
birth_date string The customer's date of birth.
first_name string The customer's first name.
last_name string The customer's last name.
address string The customer' billing address.
country string The customer's billing country in the ISO 3166-1 alpha-2 format.
city string The customer's billing city.
state string The customer's two-letter billing state, if the billing address country is US or CA.
zip string The customer's billing ZIP or postal code. If country=US, the zip format must be NNNNN or NNNNN-NNNN.
phone string The customer's phone number.
payment_method object A section of details of the payment method used by the customer to make the transaction.
payment_method_type string A payment method type used to make the transaction.
holder string The cardholder name.
stamp string The card stamp.
brand string The card brand.
last_4 string The last 4 digits of the card.
first_1 string The first digit of the card.
bin string The card BIN.
issuer_country string The country of the card issuing bank.
issuer_name string The issuing bank of the card.
product string The card product type.
exp_month integer The card expiration month represented with two digits, for example 01.
exp_year integer The card expiration year represented with four digits, for example 2021.
token_provider string The card token provider, if any.
token string The card token.
recipient object A section of the recipient's details. Applicable for payouts and P2P transactions initiated by the customer to the recipient.
customer object A section of the recipient's personal and address details.
first_name string The recipient's first name.
last_name string The recipient's last name.
address string The recipient's billing address.
country string The recipient's billing country in the ISO 3166-1 alpha-2 format.
city string The recipient's billing city.
state string The recipient's two-letter billing state, if the billing address country is US or CA.
zip string The recipient's billing ZIP or postal code. If country=US, the zip format must be NNNNN or NNNNN-NNNN.
phone string The recipient's phone number.
payment_method object A section of details of the payment method used to receive a payout or P2P transfer.
holder string The recipient cardholder name.
stamp string The recipient card stamp.
brand string The recipient card brand.
last_4 string The last 4 digits of the recipient card.
first_1 string The first digit of the recipient card.
bin string The recipient card BIN.
issuer_country string The recipient card country.
issuer_name string The issuing bank of the recipient card.
product string The recipient card product type.
exp_month integer The recipient card expiration month represented with two digits, for example 01.
exp_year integer The recipient card expiration year represented with four digits, for example 2021.
token string The recipient card token.
token_provider string The source card token provider, if any.
payment_method_type string A payment method type used to receive a payout or P2P transfer.
smart_routing_verification object A section of the Smart Routing service parameters. Applicable if the Smart Routing service is activated.
status string A status of the Smart Routing service processing.
three_d_secure_verification object A section of the 3-D Secure verification parameters.
additional_data object A section of additional details about the transaction.
browser object A section of the customer's browser data.
contract object A section of the parameters related to card tokens issued for payments by saved cards.
avs_cvc_verification object A section of the AVS/ CVC verification check.
avs_verification object A section with the result of the AVS verification check.
result_code string A code of the AVS verification check result.
cvc_verification object A section with the result of the CVC verification check.
result_code string A code of the CVC verification check result.
transaction object A section of the transaction details.
ref_id string A transaction reference ID assigned by the bank.
message string A transaction processing message.
amount integer A transaction amount in minimal currency units.
currency string A currency of the transaction in the ISO-4217 format, for example, USD.
billing_descriptor string A transaction billing descriptor.
gateway_id integer An ID of the payment gateway through which the transaction was processed in the Horizonpay system.
status string A transaction status.
auth_code string A transaction authorization code.
rrn string A Retrieval Reference Number of the transaction assigned by the bank.
bank_code string A transaction processing code assigned by the bank.
links object A section of links.
receipt_url string A URL of the transaction receipt.
bank_info object A section of parameters of the balance request.

If the parameter is not applicable to the transaction, response parameter values are set to null.

Processing codes

An API v.3 response mandatory contains a code parameter value in the {Letter code}.{4 code digits} format, where:

  • {Letter code} stands for a transaction processing status;
  • {4 error code digits} relate to an error code of a system service that can not process a transaction.

Letter codes

API v.3 letter code API v2 status Status description
S successful The transaction is successfully processed.
F failed The transaction is failed due to some reason in the system of the bank / integration provider.
P pending
incomplete
The transaction is still being processed, or the system waits for the customer's action to complete the transaction.
E error There was an error while processing the transaction by Horizonpay internal services.

4 error code digits

API v.3 4 digit range Description
0000 The operation is successful.
0001 - 0499 Error codes of the system validation and processing service for card transactions.
0501 - 0999 Error codes of the system validation and processing service for transactions that are initiated with alternative payment methods.
1000 - 1999 Error codes of the payment gateway service.
2000 - 3999 Error codes of the Smart Routing service.
4000 - 4999 Error codes of the 3-D Secure verification service.
6000 - 6999 Error codes of the AVS/ CVC verification check.
7000 - 7999 Error codes of the Verify service.
8001 Error code of the P2P verification service.
8010 Error code of the payment gateway service for requests in asynchronous mode.
8005 - 9999 Bank error codes.

You can find detailed description of all the codes in the API v.3 processing error codes appendix.

Example of the API v.3 response to the payment transaction request

The sample transaction has the incomplete status and the P.9998 code. Provided that the three_d_secure_verification is the only section with the incomplete status, the transaction could not be processed as the Horizonpay system waits for the customer to take the 3-D Secure verification check.

{
  "uid": "46154-aba1cf5e57",
  "code": "P.9998",
  "friendly_message": "Incomplete transaction",
  "status": "incomplete",
  "amount": 100,
  "currency": "USD",
  "description": "Test transaction ütf",
  "type": "payment",
  "payment_method": {
    "payment_method_type": "credit_card",
    "holder": "John Doe",
    "stamp": "5f854c844e3007f2ecff2aa614f6a4cc6b8a2c241aab3e5776fe7912dc7b9d92",
    "brand": "visa",
    "last_4": "0013",
    "first_1": "4",
    "bin": "420000",
    "issuer_country": "LT",
    "issuer_name": "VISA",
    "product": "VISA",
    "exp_month": 10,
    "exp_year": 1,
    "exp_year": 2027,
    "token_provider": null,
    "token": "2efef4c9-d4de-4603-bc84-7a9bc5456939"
  },
  "tracking_id": "tracking_id_000",
  "message": null,
  "test": true,
  "created_at": "2022-09-15T08:43:56.521Z",
  "updated_at": "2022-09-15T08:43:57.943Z",
  "paid_at": null,
  "expired_at": null,
  "recurring_type": "initial",
  "closed_at": null,
  "settled_at": null,
  "manually_corrected_at": null,
  "language": "en",
  "redirect_url": "https://gw.horizonpay.kz/process/46154-aba1cf5e57",
  "status_code": 21,
  "links": {
    "receipt_url": "https://bo.horizonpay.kz/customer/transactions/46154-aba1cf5e57/bbe9f4090e43351ca1ee724a202376cb24da3ffbfa86df30c80e95fb4fdee386?language=en"
  },
  "additional_data": {
    "browser": {
      "screen_width": 1920,
      "screen_height": 1080,
      "screen_color_depth": 24,
      "language": "en",
      "java_enabled": false,
      "user_agent": "Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.36",
      "time_zone": -180,
      "time_zone_name": "Europe/Vilnius",
      "accept_header": "*/*",
      "window_height": 667,
      "window_width": 600
    },
    "contract": [
      "recurring"
    ]
  },
  "customer": {
    "ip": "127.0.0.1",
    "email": "[email protected]",
    "device_id": "12312312321fff67",
    "birth_date": "1980-01-31",
    "first_name": "John",
    "last_name": "Doe",
    "address": "1st Street",
    "country": "US",
    "city": "Denver",
    "zip": "96002",
    "state": "CO",
    "phone": null
  },
  "smart_routing_verification": {
    "status": "successful"
  },
  "max_mind_verification": {
    "score": 45,
    "status": "successful",
    "distance": null,
    "countryMatch": "No",
    "countryCode": null,
    "freeMail": "No",
    "anonymousProxy": "No",
    "binMatch": "No",
    "binCountry": "LT",
    "err": "IP_NOT_FOUND",
    "proxyScore": "0.00",
    "ip_region": null,
    "ip_city": null,
    "ip_latitude": null,
    "ip_longitude": null,
    "binName": null,
    "ip_isp": null,
    "ip_org": null,
    "binNameMatch": "NA",
    "binPhoneMatch": "NA",
    "binPhone": null,
    "custPhoneInBillingLoc": "NotFound",
    "highRiskCountry": "No",
    "queriesRemaining": "14286",
    "cityPostalMatch": "No",
    "shipCityPostalMatch": null,
    "carderEmail": "No"
  },
  "three_d_secure_verification": {
    "status": "incomplete",
    "message": "Authentication Available",
    "ve_status": "Y",
    "acs_url": null,
    "pa_req": null,
    "md": null,
    "pa_res_url": "https://gw.horizonpay.kz/process/46154-aba1cf5e57",
    "eci": null,
    "pa_status": null,
    "xid": null,
    "cavv": null,
    "cavv_algorithm": null,
    "fail_reason": null,
    "method_process_url": "https://gw.horizonpay.kz/api/v1/transactions/bd79f747-a42f-4ee3-b993-069310ca8238/method-process",
    "creq": null
  },
  "transaction": {
    "auth_code": null,
    "bank_code": null,
    "rrn": null,
    "ref_id": null,
    "message": null,
    "amount": 100,
    "currency": "USD",
    "billing_descriptor": null,
    "gateway_id": 645,
    "status": "incomplete"
  },
  "avs_cvc_verification": {
    "avs_verification": {
      "result_code": null
    },
    "cvc_verification": {
      "result_code": null
    }
  }
}