Charge request
Acquirers might apply various scenarios and transaction flows to process card payments for your billing scheme. It would make you implement different request types if you work with several acquirers or change your acquiring partner.
Horizonpay suggests using a single charge request which unifies the process of handling payments by saved card details.
When the Horizonpay system receives the charge request, it automatically modifies this request either to a payment or to an authorization operation. It depends on what transaction flow is supported by your acquirer which will process a payment. Moreover, if the charge request is modified to the authorization request, Horizonpay automatically sends the capture request.
In the back office the charge request is reported respectively to the type of the processed transaction, i.e. either as a payment or as an authorization and a capture.
Request
Send the POST
request to https://gw.horizonpay.kz/services/credit_cards/charges
with the following parameters:
Parameter | Type | Description |
---|---|---|
request | object | |
amount * required |
integer | An amount in minimal currency units (for example $32.45 must be sent as 3245). |
currency * required |
string | A currency in the ISO-4217 format (for example USD). |
description * required |
string(255) | A short order description. |
tracking_id | string(255) | Your transaction or order ID. Please, use unique values to get the relevant transaction information by query requests. Otherwise, you will get an array of up to 10 recent transactions with the matching tracking_id . |
expired_at | string | Date and time till a transaction should be finalized. Use ISO 8601 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). If a payment is not paid till the indicated date, the transaction status is set to expired . |
duplicate_check | boolean | true or false . Used to avoid payment duplicates. By default, it is set to true , so requests with the same amount and number or token within 30 seconds will be rejected. |
dynamic_billing_descriptor | string | Dynamic billing descriptor. |
language | string | The language of your checkout page. It also specifies the language of email notifications sent out to your customers, if customer notifications are enabled. English (en ) is set by default. Possible values of language parameter. |
notification_url | string | URL where the system should send the notifications about a transaction. The notification request format matches the transaction response format. |
verification_url | string | A URL where the system should send the transaction verification. The verification request format matches the transaction response format. |
return_url * conditionally required |
string | A URL on the merchant side where Horizonpay should redirect the customer after 3-D Secure verification is finished. The parameter is mandatory if your merchant account is 3-D Secure enabled. Contact your account manager for more details. |
test | boolean | true or false . The transaction is processed as a test if the parameter is set to true . |
credit_card | object | A section of card credentials. |
number * required |
string | A card number. The length is from 12 to 19 digits. |
verification_value * required |
string | 3- or 4-digit security code (CVC2, CVV2 or CID depending on the credit card brand). It can be sent along with the token value, Horizonpay will transmit the card details with the given CVC2/CVV2/CID to your acquirer. |
holder * required |
string | A cardholder name as it appears on the card. The maximal length is 32 characters. |
exp_month * required |
integer | A card expiration month indicated with two digits (for example, 01). |
exp_year * required |
integer | A card expiration year indicated with four digits (for example, 2027). |
token * conditionally required |
string | A card token received earlier. The parameter is mandatory if you do not send card credentials. If a card token is used, you should specify the additional_data.contract parameter. |
skip_three_d_secure_verification | boolean | The parameter is used when you want your customer skip the 3-D Secure verification. Contact the Tech Support Team to check if you can apply this parameter. If true , Horizonpay doesn't launch the 3-D Secure verification for charge requests when a card token is submitted. Set to false , by default.The force_three_d_secure_verification parameter overrides the skip_three_d_secure_verification parameter, if both are set to true . |
force_three_d_secure_verification | boolean | The parameter enables the option to make the 3-D Secure verification check mandatory for the customer. Contact the Tech Support Team to check if you can apply this parameter. If true , Horizonpay forces the 3-D Secure verification for charge requests when a card token is submitted. Set to false , by default.The force_three_d_secure_verification parameter overrides the skip_three_d_secure_verification parameter, if both are set to true . |
additional_data | object | A section with additional transaction data. Check with the Support Team if you should send any section parameters. |
p2p | object | A parameter section for AFT transactions. |
service_id * conditionally required |
string | Request the parameter value from your manager. |
service_extension * conditionally required |
string | Request the parameter value from your manager. |
excluded_gateways | array | An array for working with cascading payments |
masterpass | object | A Masterpass service section. |
params | object | A section for Masterpass parameters. |
session | string | A user session ID. |
receipt_text | array | Text added to the customer notification. Submit it as an array of strings, for example ["First line", "Second line"] . |
contract | array | An array of elements:recurring - Horizonpay provides a card token to use for recurrent payments when customers are not required to enter their card data again. Customers indicate their full card details including CVC/CVV codes and pass the 3-D Secure verification only during the initial payment;oneclick - Horizonpay provides a card token for the oneclick payment flow, when the customer is redirected to the checkout page with the prefilled card details and is just required to enter the CVC/CVV code and pass the 3-D Secure verification to complete the payment;credit - Horizonpay provides a card token to use for a payout transaction;card_on_file - Horizonpay returns a card token, so you can link it to the customer account and use it for payments initiated by the customer or by your application. See card_on_file section below for use cases. Note! The card_on_file option might not be supported by your acquirer. If you want to use the card_on_file option, please, contact your account manager. |
avs_cvc_verification | object | AVS/CVC verification. |
card_on_file | object | A section specifying the option parameters which are transmitted on to a payment network. If not specified, the initiator and type parameters are set to default values. |
initiator | string | Applicable values:merchant (default) - the payment is initiated by the merchant, no action by the customer is required (for example a taxi ride cost is charged automatically from the customer's card after the ride is finished);customer - the payment is initiated by the customer, the payment confirmation by the customer is required (for example the customer pays a bill with the saved card). |
type | string | Used only if additional_data.card_on_file.initiator is set to merchant . delayed_charge (default) - delayed charge (for example for the additionally rendered service);increment - you should charge an extra amount (for example in case of the upsale);resubmission - you re-submit a transaction request due to the payment failure (for example no money on the card);reauthorization - you want to renew the authorization (for example to keep money reserved on the card for future charges);no_show - you want to charge the card when the customer didn't use the product or service (for example no visit to a hotel). |
browser | object | A section of client browser details. Section parameters are required for the 3-D Secure 2.0 flow only. |
accept_header | integer | A value of Accept request HTTP header sent by the cardholder browser. |
screen_width | integer | Screen width in pixels. Equals the screen.width parameter of JavaScript. |
screen_height | integer | Screen height in pixels. Equals the screen.height parameter of JavaScript. |
screen_color_depth | integer | Screen color depth in bits per pixel. Equals the screen.colorDepth parameter of JavaScript. Applicable values are:1 - 1 bit4 - 4 bits8 - 8 bits15 - 15 bits16 - 16 bits24 - 24 bits32 - 32 bits48 - 48 bits |
window_width | integer | Browser window width in pixels. Equals the document.body.clientWidth parameter of JavaScript. |
window_height | integer | Browser window height in pixels. Equals the document.body.clientHeight parameter of JavaScript. |
language | string | Language of the navigator. Equals the navigator.language parameter of JavaScript. |
java_enabled | boolean | Indicates if the browser is Java-enabled or not. Equals the navigator.javaEnabled() parameter of JavaScript. |
user_agent | string | User agent string for the browser. Equals the navigator.userAgent parameter of JavaScript. |
time_zone | integer | Time zone difference, in minutes, from the current locale (host system settings) to UTC. Equals the new Date().getTimezoneOffset() parameter of JavaScript. |
time_zone_name | string | A time zone name. Equals the Intl.DateTimeFormat().resolvedOptions().timeZone parameter of JavaScript. |
customer * conditionally required |
object | A section of the customer information. Contact the Tech Support Team to check what section parameters are required. |
ip | string | An IP address of the customer placing an order. |
string | An email of the customer placing an order. | |
device_id | string | A device ID (desktop, smartphone, etc.) of the customer placing an order. |
birth_date | string | The customer's date of birth in the ISO 8601 format YYYY-MM-DD . |
taxpayer_id | string | The customer's taxpayer ID. |
billing_address | object | A section of parameters related to the customer's billing address. Contact the Tech Support Team to check if your acquirer requires any of the section parameters. |
first_name * conditionally required |
string | The customer's first name. The maximal length is 30 characters. |
last_name * conditionally required |
string | The customer's last name. The maximal length is 30 characters. |
country * conditionally required |
string | The customer's billing country in ISO 3166-1 Alpha-2 format. |
city * conditionally required |
string | The customer's billing city. The maximal length is 60 characters. |
state * conditionally required |
string | The customer's two-letter billing state only if the billing address country is US or CA . |
zip | string | The customer's billing ZIP or postal code. If the country is US , the zip format must be NNNNN or NNNNN-NNNN. |
address * conditionally required |
string | The customer's billing address. The maximal length is 255 characters. |
phone * conditionally required |
string | The customer's phone number. The maximal length is 100 characters. |
travel | object | Section with travel related data. |
airline | object | Section for airline ticket addendum data. |
agency_code | string | IATA agency code (for example 03 ). |
agency_name | string | Agency name that sold the ticket (for example Coral travel ). |
ticket_number | string | 14-digit ticket number. Contains 3-digit ticketing code, 4-digit form number, 6-digit serial number, and the check digit (for example 390 5241 025377 1 ). |
booking_number | string | Booking code (for example DKZVUA ). |
restricted_ticked_indicator | string | Information on ticket returns. 0 - when the ticket can be returned. 1 - when the ticket may not be returned. |
legs | array | Array of travel legs. Every leg consists of: |
airline_code | string | 2-letter IATA code (for example B2 ). |
stop_over_code | string | IATA stop-over code. If a traveler stays in the originating city more than 24h, then set the field value to O or leave it empty. If the originating airport is a transit airport, then set the field value to X . |
flight_number | string | Flight number (for example A3 971 ). |
departure_date_time | string | Departure date and time (for example 2014-05-26T05:15:00 ). |
arrival_date_time | string | Arrival date and time (for example, 2014-05-26T07:30:00 ). |
originating_country | string | Country of origin (RU ). |
originating_city | string | City of origin (for example Moscow ) |
originating_airport_code | string | 3-letter IATA code of the airport of origin (for example DME ). |
destination_country | string | Country that the traveler goes to (for example Greece ). |
destination_city | string | City that the traveler goes to (for example Athens ). |
destination_airport_code | string | 3-letter IATA code of the airport that the traveler goes to (for example ATH ). |
coupon | string | Coupon number if applicable. |
class | string | Class flight, 1-letter IATA code (for example C ). |
passengers | array | List of passengers where every list item consists of |
first_name | string | Passenger's first name (for example KONSTANTIN ). |
last_name | string | Passenger's last name (for example IVANOV ). |
Example of the request
{
"request": {
"amount": 100,
"currency": "USD",
"description": "Test transaction",
"tracking_id": "tracking_id_000",
"credit_card": {
"number": "5204240000015003",
"verification_value": "123",
"holder": "John Doe",
"exp_month": "10",
"exp_year": 2027
},
"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/Helskinki",
"accept_header": "*/*",
"window_height": 667,
"window_width": 600
}
},
"three_d_secure": {
"advanced": false
},
"test": true
}
}
Response
The parameters of the response correspond to the parameters of the charge request and additionally specify the following:
Parameter | Type | Description |
---|---|---|
type * required |
string | A transaction type, set to charge . |
parent_uid * required |
string | Transaction ID. Same as uid , if the general request was modified to the payment, or stands for the capture request identifier. |
redirect_url * required |
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. |
Info
At the moment, if you accept payments on the Horizonpay widget and indicate charge
as the transaction_type
parameter value, you might not receive values for the rrn
or bank_code
parameters.
Example of the response to the charge request
{
"uid": "c74e1b00-9b94-4682-82c3-60167ce64841",
"parent_uid": "c74e1b00-9b94-4682-82c3-60167ce64841",
"status": "successful",
"amount": 100,
"currency": "USD",
"description": "Test transaction ütf",
"type": "charge",
"payment_method_type": "credit_card",
"tracking_id": "tracking_id_000",
"message": "Successfully processed",
"test": true,
"created_at": "2024-06-19T08:53:41.211Z",
"updated_at": "2024-06-19T08:53:46.217Z",
"paid_at": "2024-06-19T08:53:46.149Z",
"expired_at": null,
"closed_at": null,
"settled_at": null,
"manually_corrected_at": null,
"language": "en",
"redirect_url": "https://gw.horizonpay.kz/process/c74e1b00-9b94-4682-82c3-60167ce64841",
"credit_card": {
"holder": "John Doe",
"stamp": "a282993adc1299dacc79248e77e04c2995f79fcc9f82f408bec59ba20ff55739",
"brand": "master",
"last_4": "5003",
"first_1": "5",
"bin": "520424",
"bin_8": "52042400",
"issuer_country": null,
"issuer_name": null,
"product": null,
"exp_month": 10,
"exp_year": 2027,
"token_provider": null,
"token": null
},
"status_code": null,
"gateway": {
"iframe": true
},
"mute_notifications": null,
"id": "c74e1b00-9b94-4682-82c3-60167ce64841",
"additional_data": {},
"links": {
"receipt_url": "https://bo.horizonpay.kz/customer/transactions/c74e1b00-9b94-4682-82c3-60167ce64841/33724a6fe94fe937575c6ed18d2ab8abdc34732df17e51be6da88e9b37356101?language=en"
},
"code": "S.0000",
"friendly_message": "The operation is successful.",
"smart_routing_verification": {
"status": "successful"
},
"charge": {
"auth_code": "654321",
"bank_code": "05",
"rrn": "999",
"ref_id": "777888",
"message": "Payment was approved",
"amount": 100,
"currency": "USD",
"billing_descriptor": "test descriptor",
"gateway_id": 3483,
"status": "successful"
},
"avs_cvc_verification": {
"avs_verification": {
"result_code": "1"
},
"cvc_verification": {
"result_code": "1"
}
},
"customer": {
"ip": null,
"email": null,
"device_id": null,
"birth_date": null,
"taxpayer_id": null,
"external_id": null,
"first_name": null,
"last_name": null,
"address": null,
"country": null,
"city": null,
"zip": null,
"state": null,
"phone": null
},
"billing_address": {
"first_name": null,
"last_name": null,
"address": null,
"country": null,
"city": null,
"zip": null,
"state": null,
"phone": null
}
}