Card tokenization service by provider
The Horizonpay system is fully PCI DSS certified, thus it can provide merchants with the tokenization services. Instead of storing sensitive card data on their back end, merchants can get the card number tokenized, save and use the received token for subsequent payments.
When you submit a card token in payment or authorization transaction requests, the credit card details are not required. The Horizonpay system detects the card data by the card token and pass them to the processing network. The cardholder will be asked to confirm the transaction with the CVC/CVV only.
If the merchant uses the subscription service, the card token is enough to initiate a recurring payment.
Info
You should meet the PCI DSS requirements to deal with sensitive card data.
Create a card token
To get a card tokenized, send a POST
request to https://gw.horizonpay.kz/credit_cards
with the following parameters:
Parameter | Type | Description |
---|---|---|
request | object | |
number * required |
string (19) | A card number. |
holder * required |
string (32) | A cardholder name as it appears on the card. |
exp_month * required |
integer (2) | A card expiration month expressed with two digits (for example, 01). |
exp_year * required |
integer (4) | A card expiration year expressed with four digits (for example, 2027). |
contract * required |
array | An array consisting of elements:recurring - Horizonpay returns a card token to use it in subsequent charges without to enter a card data again. Customer agrees to be charged regularly, but initially the customer must make a payment with full card data including CVC/CVV code and pass 3-D Secure verification. |
Example of the request to tokenize a card number
{
"request":{
"number":"4200000000000000",
"holder":"John Smith",
"exp_month":"05",
"exp_year":"2027",
"contract":["recurring"]
}
}
Update card token data
The request to update card token attributes should be sent via HTTP POST
on https://gw.horizonpay.kz/credit_cards/{token}
, where {token}
stands for the token value, with the following parameters:
Parameter | Type | Description |
---|---|---|
request | object | |
holder * required |
string (32) | A cardholder name as it appears on the card. |
exp_month * required |
integer | A card expiration month expressed with two digits (for example, 01). Submit it along with exp_year . |
exp_year * required |
integer | A card expiration year expressed with four digits (for example, 2027). Submit it along with exp_month . |
Example of the request to update tokenized card attributes
To change holder
, exp_month
and exp_year
of the card token 23b48236ea85378ff899e33819ee31b1631ed8197dc254f9eb28c0011307cf32
, send a POST
request to https://gw.horizonpay.kz/credit_cards/23b48236ea85378ff899e33819ee31b1631ed8197dc254f9eb28c0011307cf32
.
{
"request":{
"holder":"John Doe",
"exp_month":"01",
"exp_year":"2027"
}
}
Response
The response to the card tokenization or update requests specifies the following parameters:
Parameter | Type | Description |
---|---|---|
holder * required |
string | The cardholder name as it was sent in a request. |
brand * required |
string | The detected card brand: visa , master , jcb , discover , dinersclub , amex , belkart and unionpay . |
first_1 * required |
string (1) | The first digit of the card. |
last_4 * required |
string (4) | The last 4 digits of the card. |
stamp * required |
string | The card hash. It is constant even if either the card expiration date, or the cardholder is changed. |
token * required |
string | The card token. In case of the update request, a new token is returned. |
exp_month * required |
integer | The card expiration month expressed with two digits (for example, 01). |
exp_year * required |
integer | The card expiration year expressed with four digits (for example, 2027). |
Example of the response
{
"holder":"John Doe",
"stamp":"a825df7faba8804619aef7a6d5a5821ec292fce04e3e43933ca33d0692df90b4",
"brand":"visa",
"last_4":"0000",
"first_1":"4",
"token":"7ba647e7013b5cb9df39f17c375783aef81bc8c20f221b962becbd0686cc33af",
"exp_month":1,
"exp_year":2027
}