Perform Payment
import CardOnFile from './parametros-do-card-on-file.md';
import Recorrencia from './parametros-da-recorrencia.md';
API interface that allows the online store to process sales requisitions.
Call details
- Resource:
/v2/payments
- HTTP Method:
POST
- Request format:
JSON
- Response format:
JSON
- Header parameters:
Parameter | Description | Format | Mandatory |
---|---|---|---|
merchant_id | Merchant code on Carat Portal. The production and certification codes will be different. | < 15 AN | YES |
merchant_key | Merchant authentication key on Carat Portal. The production and certification keys will be different. | < 80 AN | YES |
Content-Type | It must be sent with the value application/json . | = 15 AN | YES |
Examples
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: ************' \
--header 'merchant_key: ************' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "121314",
"installments": "10",
"installment_type": "4",
"authorizer_id": "2",
"amount": "10000",
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
}
}'
--verbose
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "Transacao Aprov.",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1657810477538",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin",
"authorizer_date": "14/07/2022T11:54",
"authorization_number": "145778",
"merchant_usn": "12050620649",
"esitef_usn": "220714103502410",
"sitef_usn": "145778",
"host_usn": "999145778 ",
"amount": "10000",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000005",
"terminal_id": "ES000032",
"payment_date": "14/07/2022T11:54"
}
}
Sitef Payment - Token
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "1657833175201",
"installments": "10",
"installment_type": "4",
"authorizer_id": "2",
"amount": "10000",
"card": {
"token": "qJgaDApmM1APmglEpPUq7PomYpCXVqPWLW0MuEws1ZeOk95tDhqkKp-3n4KUNXAzsYxIazMSxNNSUXJ0zgwcuA=="
},
"acquirer": {},
"additional_data": {}
}'
--verbose
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "APROVADA",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1657833175201",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin",
"authorizer_date": "14/07/2022T18:12",
"authorization_number": "500335",
"merchant_usn": "12050620649",
"esitef_usn": "220714103502980",
"sitef_usn": "500335",
"host_usn": "007500335 ",
"amount": "10000",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000000",
"terminal_id": "ES000001",
"payment_date": "14/07/2022T18:12",
"recurrency_tid": "999988887777666"
}
}
Sitef Payment - Konduto antifraud
For further information, please refer to our specific Konduto section.
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "2423423434",
"order_id": "1657904793420",
"installments": "1",
"installment_type": "4",
"authorizer_id": "2",
"amount": "1300",
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
},
"additional_data": {
"anti_fraud": "enabled_before_auth",
"visitor_id": "XKhas09jcks",
"items": [
{
"title": "title1",
"quantity": "1",
"unit_price": "1111",
"description": "description1",
"id": "id1",
"discount_amount": "111",
"sku": "sku1",
"creation_date": "11/01/2011"
}
],
"payer": {
"name": "Marcos",
"surname": "da Silva",
"email": "[email protected]",
"born_date": "1990-01-01T11:11:11",
"creation_date": "02/03/2004",
"is_new_client": "true",
"is_vip_client": "true",
"phones": [
{
"number": "333333333",
"ddd": "22",
"ddi": "11"
},
{
"number": "666666666",
"ddd": "55",
"ddi": "44"
}
],
"identification_number": "47764543004"
},
"shipment": {
"name": "Fernando",
"surname": "Bezerra",
"address": {
"zip_code": "98764312",
"street_number": "987",
"street_name": "Rua Shipment",
"complement": "ap. 587",
"city": "São Shipment",
"state": "MA",
"country": "BRA"
}
},
"passengers": [
{
"name": "Miguel",
"last_name": "Herrera",
"frequent_flyer_card": "frequentFlyerCard",
"legal_document_type": "1",
"legal_document": "12312312312",
"birth_date": "1980-07-28T10:40:00",
"customer_class": "customerClass",
"nationality": "BRA",
"is_frequent_traveler": "true",
"is_with_special_needs": "true"
}
],
"connections": [
{
"company": "Verde",
"class": "first",
"from": "GRU",
"to": "CGH",
"departure_date": "2023-09-07T07:09:00",
"journey_type": "OUTWARD",
"origin_city": "San Juan",
"destination_city": "Homero Lopez",
"class_code": "VIP"
},
{
"company": "Rosa",
"class": "economy",
"from": "BSB",
"to": "VCP",
"departure_date": "2022-10-21T16:39:00",
"journey_type": "RETURN",
"origin_city": "San Pablo",
"destination_city": "Juanito Cruz",
"class_code": "ECONOMY"
}
],
"hotel_reservations": [
{
"hotel": "Hotel Green Tree",
"address": {
"zip_code": "83392019",
"street_number": "529",
"street_name": "Rua Hoteleira",
"complement": "ap. 019",
"city": "San Hotel",
"state": "AC",
"country": "EN"
},
"rooms": [
{
"number": "902",
"code": "ROOM902",
"type": "King Size",
"check_in_date": "2020-01-09T12:30:00",
"check_out_date": "2020-01-19T13:00:00",
"number_of_guests": "1",
"board_basis": "Vegan",
"guests": [
{
"name": "José Aníbal",
"document": "98798798712",
"document_type": "cpf",
"birth_date": "12/03/1970",
"nationality": "BRA"
}
]
}
],
"category": "categoryhotel"
}
],
"billing_data": {
"address": {
"zip_code": "12341234",
"street_number": "666",
"street_name": "Rua Billing",
"complement": "ap. 2369",
"city": "São Billing",
"state": "AM",
"country": "BRA"
}
},
"travel": {
"transport_type": "flight",
"expiration_date": "2022-02-14T01:30:00"
},
"discount_info": "Informações de desconto",
"events": [
{
"name": "Evento de Rock",
"date": "2021-11-22T09:28:00",
"type": "show",
"subtype": "music",
"venue": {
"name": "Debicard Hall",
"street_name": "Rua do Evento",
"street_number": "928",
"city": "Jardinópolis",
"state": "MS",
"country": "DO",
"capacity": "300"
},
"tickets": [
{
"id": "12h374612h4h",
"category": "social",
"section": "Seção 1",
"premium": "true",
"attendee": {
"name": "Daniel Almeida",
"document": "71728293945",
"document_type": "other",
"birth_date": "03/10/1990"
}
}
]
}
]
}
}'
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "Transacao Aprov.",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1657904793420",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin",
"authorizer_date": "15/07/2022T14:06",
"authorization_number": "155321",
"merchant_usn": "2423423434",
"esitef_usn": "220715103604930",
"sitef_usn": "155321",
"host_usn": "999155321 ",
"amount": "1300",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000005",
"terminal_id": "ES000015",
"payment_date": "15/07/2022T14:06",
"analysis": {
"status": "ACC",
"code": "0",
"message": "Recommendation: [APPROVE] Score: [0,00]"
}
}
}
Payment with later capture
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "1657810601498",
"installments": "10",
"installment_type": "4",
"authorizer_id": "2",
"amount": "10000",
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
},
"additional_data": {
"postpone_confirmation": "true"
}
}'
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "Transacao Aprov.",
"status": "PPC",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1657810601498",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin",
"authorizer_date": "14/07/2022T11:56",
"authorization_number": "145779",
"merchant_usn": "12050620649",
"esitef_usn": "220714103502420",
"sitef_usn": "145779",
"host_usn": "999145779 ",
"amount": "10000",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000005",
"terminal_id": "ES000032",
"payment_date": "14/07/2022T11:56"
}
}
Confirmation Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request PUT 'https://{{url}}/e-sitef/api/v2/payments/1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr?confirm=true' \
--header 'Content-Type: application/json' \
--header 'merchant_id: ********' \
--header 'merchant_key: ********'
Confirmation Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "130",
"status": "CON",
"acquirer_id": "5",
"host_usn": "999145779 ",
"payment_date": "14/07/2022T11:58"
}
}
Payment without order_id
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"installments": "10",
"installment_type": "4",
"authorizer_id": "2",
"amount": "10000",
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
}
}'
Response:
{
"code": "187",
"message": "Empty order_id value"
}
Account validation payment - Zero Auth Dollar
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "1661350282230",
"installments": "1",
"installment_type": "4",
"authorizer_id": "2",
"amount": "0",
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
}
}'
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "200",
"authorizer_message": "Success. [Cód.: 00]",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1661350282230",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "202",
"acquirer_name": "e.Rede REST",
"authorizer_date": "24/08/2022T11:11",
"authorization_number": "866551",
"merchant_usn": "12050620649",
"esitef_usn": "220824105973790",
"host_usn": "513089380",
"tid": "220824105973790",
"amount": "0",
"payment_type": "C",
"payment_date": "24/08/2022T11:11"
}
}
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "200",
"authorizer_message": "Success. [Cód.: 00]",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1661350282230",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "202",
"acquirer_name": "Bin",
"authorizer_date": "24/08/2022T11:11",
"authorization_number": "866551",
"merchant_usn": "12050620649",
"esitef_usn": "220824105973790",
"host_usn": "513089380",
"tid": "220824105973790",
"amount": "0",
"payment_type": "C",
"payment_date": "24/08/2022T11:11",
"standin_details": "000001",
"cvv_result_code": "M"
}
}
Payment - 3DS
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "1660136901859",
"installments": "1",
"installment_type": "4",
"authorizer_id": "1",
"amount": "9900",
"card": {
"expiry_date": "1023",
"number": "5555555555555555",
"security_code": "123",
"holder": "Joao Silva"
},
"external_authentication": {
"xid": "MTIzNDU2Nzg5MDEyMzQ1Njc4OTA=",
"eci": "05",
"cavv": "jMoRyYgNSt0ZAREBBu8LHI+3oZo="
}
}'
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "00",
"authorizer_message": "TRANSACAO EXECUTADA COM SUCESSO",
"status": "CON",
"nit": "1dac764c4e38f6bea19a30656bc6ecb40b4cd58f139e56870a638a6bf0bfa2c0",
"order_id": "1660136901859",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "1",
"acquirer_id": "407",
"acquirer_name": "GetNetWS",
"authorizer_date": "03/10/2022T14:25",
"authorization_number": "267692",
"merchant_usn": "12050620649",
"esitef_usn": "221003109032570",
"host_usn": "072483954509",
"tid": "-1",
"amount": "9900",
"payment_type": "C",
"authorizer_merchant_id": "142365",
"payment_date": "03/10/2022T14:25"
}
}
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "00",
"authorizer_message": "TRANSACAO EXECUTADA COM SUCESSO",
"status": "CON",
"nit": "1dac764c4e38f6bea19a30656bc6ecb40b4cd58f139e56870a638a6bf0bfa2c0",
"order_id": "1660136901859",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "1",
"acquirer_id": "407",
"acquirer_name": "Bin",
"authorizer_date": "03/10/2022T14:25",
"authorization_number": "267692",
"merchant_usn": "12050620649",
"esitef_usn": "221003109032570",
"host_usn": "072483954509",
"tid": "-1",
"amount": "9900",
"payment_type": "C",
"authorizer_merchant_id": "142365",
"payment_date": "03/10/2022T14:25",
"standin_details": "000001",
"cvv_result_code": "M"
}
}
Payment - Network Token
Some card brands have a tokenization solution that offers the storage of cards in safes at the brand itself, in an encrypted form. This brand tokenization is intended to improve the security and quality of the transmitted card information, which leads to possible increases in the conversion of approval by issuing banks.
Parameter | Description | Format | Required |
---|---|---|---|
card | |||
number | Token generated by the brand (DPAN) | ≤ 19 N | Yes |
cryptogram | Cryptogram generated by the brand | = 28 A | Yes for network token payments |
wallet_type | Field that specifies whether the transaction is processed with PAN or DPAN. You must send the value “network_token” for tokenized transactions. | AN | Yes for network token payments |
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl --location --request POST 'https://{{url}}/e-sitef/api/v2/payments/' \
--header 'Content-Type: application/json' \
--header 'merchant_id: **********' \
--header 'merchant_key: **********' \
--data-raw '{
"merchant_usn": "12050620649",
"order_id": "1665002632429",
"installments": "1",
"installment_type": "4",
"authorizer_id": "2",
"amount": "10000",
"card": {
"number": "5555555555555555",
"expiry_date": "1223",
"cryptogram": "ALRzlt6NKQtPAAZAkOuIAAADFA==",
"wallet_type": "network_token"
}
}'
Parameter | Description | Format |
---|---|---|
card | ||
par | EMVCo introduced PAR (Payment Account Reference) to provide an industry-aligned approach designed to help link all token-based transactions associated with a specific account. | < 32 |
suffix | Last four digits of the PAN, returned by Visa and Mastercard in transactions carried out with DPAN (Network Token). | = 4 |
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "TRANSACAO APROVADA",
"status": "CON",
"nit": "1854a5dac2033afc012c4ed807183bf77f6179a75c79ec81c770a0bde8aef583",
"order_id": "0001709151774770",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin (Via Servicos TEF)",
"authorizer_date": "28/02/2024T17:22",
"authorization_number": "226596",
"merchant_usn": "1709151775",
"esitef_usn": "240228062687260",
"sitef_usn": "816339",
"host_usn": "43734572890",
"amount": "100",
"payment_type": "C",
"terminal_id": "ES000001",
"card_par": "hI3C1LmpTY46qNx4YlsyOvbRQBg3o",
"payment_date": "28/02/2024T17:22",
"recurrency_tid": "055950827503911",
"standin_details": "000001",
"cvv_result_code": "M"
},
"card": {
"par": "hI3C1LmpTY46qNx4YlsyOvbRQBg3o",
"suffix": "0042"
}
}
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "Transacao Aprov.",
"status": "CON",
"nit": "41252cb6d538652cd8293541c8740cbe9bbd1dc380ecd65ab340d9dc0abf1d4a",
"order_id": "1665002632429",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "229",
"acquirer_name": "Bin",
"authorizer_date": "05/10/2022T17:43",
"authorization_number": "050246",
"merchant_usn": "12050620649",
"esitef_usn": "221005109152250",
"sitef_usn": "050246",
"host_usn": "999050246 ",
"amount": "10000",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000007",
"terminal_id": "ES000001",
"payment_date": "05/10/2022T17:43"
}
}
Payment confirmation service
After creating and authorizing a payment pending confirmation, the merchant must call the confirmation service to confirm or undo the payment using the same NIT obtained on the first step of the flow.
Call details
- Resource:
/v1/payments/{nit}
- HTTP Method:
PUT
- Request format:
query string
- Response format:
JSON
- Header parameters:
Parameter | Description | Format | Mandatory |
---|---|---|---|
merchant_id | Merchant code on Carat Portal. The production and certification codes will be different. | < 15 AN | YES |
merchant_key | Merchant authentication key on Carat Portal. The production and certification keys will be different. | < 80 AN | YES |
Examples
Below is an example of the payment confirmation service call using the cURL tool.
Full payment confirmation
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl
--request PUT "https://{{url}}/e-sitef/api/v1/payments/1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr?confirm=true"
--header "merchant_id:xxxxxxxxxxxxxxx"
--header "merchant_key: xxxxxxxxxxx"
--verbose
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"status": "CON"
}
}
Payment confirmation with partial amount
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl
--request PUT "https://{{url}}/e-sitef/api/v1/payments/1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr?confirm=true&amount=1000"
--header "merchant_id:xxxxxxxxxxxxxxx"
--header "merchant_key: xxxxxxxxxxx"
--verbose
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"status": "CON",
"acquirer_id": "5"
}
}
Request parameters
The table below describes the request parameters of the transaction creation service:
Parameter | Description | Format | Mandatory | ||||
---|---|---|---|---|---|---|---|
merchant_usn | Unique sequential number for each order, created by the merchant. The USN will be used during the whole communication with the merchant to help identifying the order. As it is a possible access key on the merchant's side, even though it's optional to Carat Portal, it's strongly recommended that the field is formatted and sent by the merchant's application. | < 12 N | NO | ||||
order_id | Order code defined by the merchant. It's advised that it is different for each order so that it becomes easier to track it. For transactions routed through the acquirer Bin, there's a 20 characters limit. | < 40 AN | YES | ||||
installments | Number of installments. Send 1 for spot sales. | < 2 N | YES | ||||
installment_type | Installment financing type: Value 3 = installments with interest. Value 4 = installments without interest (use this value also on spot sales). Value 6 = installments with interest (IATA). Value 7 = installments without interest (IATA). The IATA financing types are only used by companies that work with air transportation. | < 2 N | YES | ||||
authorizer_id | Code of the authorizer on Carat Portal. Learn more. | < 3 N | NO | ||||
amount | Total price of the purchase (in cents). Example: 1,00 = 100 or 1.100,00 = 110000 – send the value without the comma and the dots. | < 12 N | YES | ||||
soft_descriptor | Additional text that will be presented alongside the name of the establishment in the credit card invoice. Learn more | < 3025 AN | NO | ||||
card | Card data. | ||||||
number | Customer's card number (PAN). Brand generated token (DPAN) for network token payment. Learn more | < 19 N | YES | ||||
expiry_date | Card expiry date in MMYY format. Its requirement depends on the selected acquirer. In most cases, this field is mandatory. | = 4 N | COND. | ||||
security_code | Card security code. This field may not be mandatory if the company has an agreement in the contract established with the acquirers, only for payments of certain areas. However, it is possible to configure the mandatory field in the merchant settings, consult Carat support for more information. Important: a payment with schedule implies on storing the customer's card data on Carat Portal's environment. However, for security reasons, the security code cannot be stored. Therefore, the scheduled payments will always be executed without the security code. | < 5 N | COND. | ||||
holder | Card holder name. Only mandatory for payments with e-Rede, GetNet WS and VR (SmartNet). | < 30 AN | NO | ||||
token | HASH of a card stored on Carat Portal. It's not allowed to send an ‘open' card number (number field) and a stored card (token field) on the same request. | = 88 AN | NO | ||||
cryptogram | Field that specifies whether the transaction is processed with PAN or DPAN. If “type” is empty, the default value is PAN (non-tokenized card number). If there is a tokenized transaction, you must send the value “network_token”. | AN | NO | ||||
wallet_type | Field that specifies whether the transaction is processed with PAN or DPAN. If “type” is empty, the default value is PAN (non-tokenized card number). If there is a tokenized transaction, you must send the value “network_token”. | AN | NO | ||||
external_authentication | This element receives MPI authentication result fields. | ||||||
eci | Eletronic Commerce Indicator – Card holder authentication security level indicator. | < 3 N | NO | ||||
xid | External card holder authentication transaction id. | < 40 N | NO | ||||
cavv | Cardholder Authentication Verification Value - Codes that refers to card holder authentication result data. | < 40 N | NO | ||||
iata | This element contains specific fields for IATA transactions. | ||||||
departure_tax | Departure tax in cents. | < 12 N | YES only for installment_type = 6 or 7 | ||||
first_installment | Amount of the first installment on IATA transactions in cents. This functionality is available only for E-Rede acquirer. | < 12 N | NO | ||||
acquirer | Data required only to specific acquirers / routings. | ||||||
financing_plan | Financing Plan code used for Via Certa Financiadora routed payments, only in case of installments plan with interest. | < 4 N | NO | ||||
special_code | Conductor/Renner SiTef routings general use code. | < 6 N | NO | ||||
mid | Acquirer merchant code - For BIN routings, the MID to be used by the merchant is unique. This field must be used if it is necessary to select a MID other than the default one. | < 15 AN | COND | ||||
recurrency | Flag that defines whether or not the payment is recurring. Accepted all routings via SiTef, Cielo e-Commerce, Global Payments WS, Stone WS, e.Rede REST and GetnetWS routings. In the case of a Stone WS recurrency, it is mandatory to send only one of the fields below, is_first_recurring OR is_subsequent_recurring . | < 5 T/F | NO | ||||
recurrency_tid | First transaction's TID. This field tells the first and the subsequent transactions apart. Use only if it is a recurrent payment.This field is used only for e.Rede REST routings using the brands Visa or Mastercard and for GetnetWS routing. | < 16 AN | NO | ||||
is_first_recurring | Flag used only for StoneWS routing. Indicates that the transaction is the first in a series of recurring transactions. | < 5 T/F | COND. | ||||
is_subsequent_recurring | Flag used only for StoneWS routing. It indicates that the transaction is the second or nth of a series of recurring transactions, where n > 2. | < 5 T/F | COND. | ||||
recurrency_original_amount | Original value of the transaction that started the recurrency. This value must be informed in all subsequent recurrences. Used only for recurrence. Field used only in BIN routing, mandatory when recurrence | < 18 AN | NO | ||||
product_code | Product code. It is mandatory in routing via Marisa. | < 6 N | COND. | ||||
terminal | Sitef terminal code. In absence Carat Portal will generate a random terminal code. | = 14 N | No | ||||
company_code | Sitef company code. In absence Carat Portal will use company code from merchant configuration. | = 8 N | No | ||||
authorization_number | Authorization number. Mandatory for Bradescard Voucher authorizer. | < 6 AN | COND. | ||||
acquirer.vouchers_filter[] | Choice of vouchers that will not be accepted. Options of "Vouchers": 01 - Food, 02 - Meal, 03 - Culture, 04 - Fuel, 05 - Benefit. Example: You do not want to accept Vouchers: Culture, Fuel, Benefit. You must send: "vouchers_filter": ["03", "04", "05"] | ||||||
acquirer.prefixes | Element for sending SiTef prefixes, like CICLOS, CPLANO and VLRADD. If the prefix that was sent is not supported by card, Carat Portal will invalidate the transaction, preventing that a false impression of the use of a functionality is given. Example: { "key" : "value" } -> { "CICLO" : "01" } | ||||||
key | Prefix name. | < 1024 AN | NO | ||||
value | Prefix value. | < 1024 AN | NO | ||||
acquirer.submerchant_split[] | It consists of an array for split payments, unique to BIN and Sipag routing, both via SiTef. It allows the division of parts of the total amount of the payment among other merchants. The maximum number of items allowed in this array is 5 items. | ||||||
submerchant_code | BIN/Sipag merchant code | < 51 AN | NO | ||||
submerchant_amount | Transaction amount related to the merchant | < 12 N | NO | ||||
acquirer.card_on_file | It is intended for sending specific information such as card storage authorization, confirming that the cardholder has authorized the storage of the card. Learn more. | ||||||
usage | Identifies the usage. For instance, in case of storage authorization: authorized | < 11 AN | NO | ||||
reason | Itentifies the reason. For instance, in case of storage authorization: card | < 11 AN | NO | ||||
WARNING: The terminal e company_code parameters must be used only for SiTef routings and must be sent simultaneously.It is also necessary send a request to the Carat Portal Support Team for the permission Allows sending Company and SiTef Terminal via REST. | |||||||
additional_data | Element for sending additional data. | ||||||
postpone_confirmation | This field must be sent with value true if a payment with late confirmation is desired. | < 5 T/F | NO | ||||
visitor_id | Visitor identifier obtained using Konduto's JavaScript | < 40 AN | NO | ||||
description | Product description | < 100 AN | NO | ||||
discount_amount | Discount amount of the product in cents | < 10 N | NO | ||||
discount_info | Discount information. | < 500 AN | NO | ||||
sku | Item product code | < 100 AN | NO | ||||
creation_date | Indicates the date of publication of the product on the merchant's site (Format: DD/MM/YYYY ) | = 10 AN | NO | ||||
additional_data.payer | Element for sending data related to the payer. | ||||||
name | Customer name | < 100 AN | YES | ||||
surname | Customer surname | < 100 AN | YES | ||||
email | Customer e-mail | < 100 AN | YES | ||||
born_date | Customer birth date (format : YYYY-MM-DDTHH:MM:SS ) | = 19 AN | NO | ||||
identification_number | Customer document number | < 100 AN | NO | ||||
creation_date | Account creation date on the site (format: DD/MM/YYYY ) | = 10 AN | NO | ||||
is_new_client | Boolean that indicates if the customer is using a recently created account in this purchase | < 5 T/F | NO | ||||
is_vip_client | Boolean that indicates if the customer is VIP or a frequent buyer | < 5 T/F | NO | ||||
additional_data.merchant | Element for sending data related to the merchant. | ||||||
email | Merchant's e-mail address. | < 1024 AN | NO | ||||
additional_data .passengers[] | Passengers information | ||||||
name | Passenger first name | < 100 AN | YES | ||||
last_name | Passenger last name | < 100 AN | YES | ||||
legal_document | Passenger document | < 100 AN | YES | ||||
legal_document_type | Passenger document type (5 = passport, any other number = id) | < 8 AN | YES | ||||
birth_date | Passenger birth date (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | NO | ||||
nationality | Passenger nationality, following ISO 3166-1 alfa-3 | = 3 AN | NO | ||||
is_frequent_traveler | Frequent traveler boolean | < 5 T/F | NO | ||||
is_with_special_needs | Boolean which indicates if it's a passenger with special needs | < 5 T/F | NO | ||||
frequent_flyer_card | Loyalty program type | < 255 AN | NO | ||||
customer_class | Loyalty program category | < 255 AN | NO | ||||
additional_data .hotel_reservations[] | Hotel reservation information | ||||||
hotel | Hotel name | < 100 AN | YES | ||||
category | Hotel category | < 100 AN | NO | ||||
additional_data .hotel_reservations[] .address | Hotel address information | ||||||
street_name | Hotel street name | < 255 AN | NO | ||||
street_number | Hotel street number | < 255 AN | NO | ||||
complement | Hotel address complement | < 100 AN | NO | ||||
city | Hotel city | < 100 AN | NO | ||||
state | Hotel state | < 100 AN | NO | ||||
zip_code | Hotel zip code | < 100 AN | NO | ||||
country | Hotel country code, following ISO 3166-1 alfa-3 | = 3 AN | NO | ||||
additional_data .hotel_reservations[] .rooms[] | Hotel rooms information | ||||||
number | Room number | < 100 AN | NO | ||||
code | Room code | < 100 AN | NO | ||||
type | Room type | < 100 AN | NO | ||||
check_in_date | Check-in date and time (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | YES | ||||
check_out_date | Check-out date and time (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | NO | ||||
number_of_guests | Number of guests | < 9999 N | NO | ||||
board_basis | Feeding regime | < 100 AN | NO | ||||
additional_data .hotel_reservations[] .rooms[] .guests[] | Hotel room guests information | ||||||
name | Guest name | < 100 AN | YES | ||||
document | Guest document | < 8 AN | NO | ||||
document_type | Guest document type:
| < 8 AN | NO | ||||
birth_date | Guest birth date (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | NO | ||||
nationality | Guest nationality, following ISO 3166-1 alfa-3 | = 3 AN | |||||
additional_data .events[] | Event information | ||||||
name | Event name | < 255 AN | YES | ||||
date | Event date and time (format YYYY-MM-DDTHH:MM:SS ) | < 17 AN | YES | ||||
type | Event type:
| < 9 AN | YES | ||||
subtype | Event type details | < 255 AN | NO | ||||
additional_data .events[] .venue | Event venue information | ||||||
name | Venue name | < 255 AN | NO | ||||
street_name | Venue street name | < 255 AN | NO | ||||
street_number | Venue street number | < 255 AN | NO | ||||
city | Venue city | < 255 AN | NO | ||||
state | Venue state | < 255 AN | NO | ||||
country | Venue country code, following ISO 3166-1 alfa-3 | = 3 AN | NO | ||||
capacity | Venue capacity | < 255 AN | NO | ||||
additional_data .events[] .tickets[] | Event tickets information | ||||||
id | Unique ticket identifier | < 255 AN | NO | ||||
category | Ticket category:
| < 10 AN | YES | ||||
section | Ticket section | < 255 AN | NO | ||||
premium | Premium ticket indicator | < 5 T/F | NO | ||||
additional_data .events[] .tickets[] .attendee | Event attendee information | ||||||
name | Attendee name | < 255 AN | NO | ||||
document | Attendee document | < 100 AN | YES | ||||
document_type | Attendee document type:
| < 100 AN | NO | ||||
birth_date | Attendee birth date (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | NO | ||||
additional_data.shipment.receiver_address | |||||||
street_name | Shipment address street name. | < 255 AN | NO | ||||
street_number | Shipment address street number. | < 15 AN | NO | ||||
complement | Shipment address complement. | < 50 AN | NO | ||||
zip_code | Shipment zip code. E.G.: 21241-140. | < 9 AN | NO | ||||
city | Shipment city. | < 50 AN | NO | ||||
state | Shipment state. | = 2 AN | NO | ||||
country | Shipment country, following ISO 3166-1. E.G.: BRA | = 3 AN | NO | ||||
additional_data.browser | |||||||
email | Email registered in the customer's browser. | < 100 AN | NO | ||||
host_name | Host name where the customer was before entering the store's website. | < 60 AN | NO | ||||
additional_data.items[] | |||||||
title | Product name. | < 255 AN | NO | ||||
quantity | Quantity of the product to be acquired. | < 15 N | NO | ||||
id | Product identifier. | < 255 AN | NO | ||||
unit_price | Unit price of the product. | < 15 N | NO | ||||
additional_data.items[].passenger | |||||||
email | Passenger email. | < 255 AN | NO | ||||
legal_document | Id of the passenger to whom the ticket was issued. | < 32 AN | NO | ||||
name | Passenger name. | < 120 AN | NO | ||||
customer_class | Classification of the Airline. Values such as Gold or Platinum can be used. | < 32 AN | NO | ||||
additional_data.items[].passenger.phone | |||||||
ddi | Passenger phone IDD. | < 3 N | NO | ||||
ddd | Passenger phone DDD. | < 3 N | NO | ||||
number | Passenger phone number. | < 9 N | NO | ||||
additional_data.extra_param.acquirer_params[] | |||||||
key | Id of the additional information to be sent. For further details about this field, see https://developercielo.github.io/Webservice-3.0/english.html#merchant-defined-data. | < 1024 N | NO | ||||
value | Value of additional information to be sent. | < 1024 AN | NO | ||||
additional_data.shipment | |||||||
name | Delivery recipient name. | < 255 AN | NO | ||||
method | Type of product delivery service. Allowed values:SAME_DAY – Delivery on the same day.ONE_DAY – Delivery overnight or on the next day.TWO_DAY – Delivery in two days.THREE_DAY – Delivery in three days.LOW_COST – Low cost delivery service.PICKUP – Product to be picked up in the store.OTHER – Other method.NONE – No delivery service, as it is a service or subscription. | < 9 AN | NO | ||||
additional_data.shipment.phones[] | |||||||
ddi | Addressee phone IDD. | < 3 N | NO | ||||
ddd | Addressee phone DDD. | < 3 N | NO | ||||
number | Addressee phone number. | < 9 N | NO | ||||
additional_data .connections[] | Travel connections information | ||||||
journey_type |
| < 7 AN | YES | ||||
origin_city | Origin city | < 100 AN | YES, if transport_type =bus | ||||
destination_city | Destination city | < 100 AN | YES, se transport_type =bus | ||||
from | IATA airport code of the origin airport | = 3 AN | YES, if transport_type =flight | ||||
to | IATA airport code of the destination airport | = 3 AN | YES, if transport_type =flight | ||||
departure_date | Departure date and time (format: YYYY-MM-DDTHH:MM:SS ) | < 17 AN | YES | ||||
class | Seat class name (Ex: economy , business or first ) | < 8 AN | NO | ||||
class_code | Seat class code | < 20 AN | NO | ||||
company | Airline name | < 20 AN | NO | ||||
additional_data .billing_data .address | Billing address information | ||||||
street_name | Billing street name | < 255 AN | NO | ||||
street_number | Billing street number | < 255 AN | NO | ||||
complement | Billing address complement | < 100 AN | NO | ||||
city | Billing city | < 100 AN | NO | ||||
state | Billing state | < 100 AN | NO | ||||
zip_code | Billing zip code | < 100 AN | NO | ||||
country | Billing country code, following ISO 3166-1 alfa-3 | = 3 AN | NO | ||||
additional_data .travel | Travel information | ||||||
transport_type | Travel transport type (flight or bus ) | < 6 AN | YES | ||||
expiration_date | Expiration date (format: DD/MM/YYYY ) | = 10 AN | NO |
The table below describes the additional parameters that must be sent on a payment with fraud analysis (for the time being only available for Cielo e-Commerce):
Parameter | Description | Format | Mandatory |
---|---|---|---|
additional_data | |||
anti_fraud_institution | Institution that will carry out the fraud analysis to the merchant. It must be send with the value AUTHORIZER . | = 10 AN | YES para análise de fraude |
anti_fraud | Enables the fraud analysis service. Allowed values:enabled_before_auth – fraud analysis will be done BEFORE the payment authorization. If the analysis is rejected, the payment won't be initiated.enabled_after_auth – fraud analysis will be done AFTER the payment authorization. If the analysis is rejected, the payment will be cancelled. | < 19 AN | YES para análise de fraude |
journey_type | Type of the trip. Allowed values:ROUND_TRIP – round trip.OUTWARD – outward.RETURN – return. | < 10 AN | NO |
Response parameters
If successful, the HTTP response code will be 201
. Any other code must be interpreted as an error. The table below describes the response parameters of the payment effectuation service:
Parameter | Description | Format | |
---|---|---|---|
code | Carat Portal response code. Any code different from 0 means failure. Learn more. | < 4 N | |
message | Carat Portal response message. | < 500 AN | |
payment | |||
authorizer_code | Authorizer response code. | < 10 AN | |
authorizer_message | Authorizer response message. | < 500 AN | |
status | Status of the payment transaction on Carat Portal. Learn more. | = 3 AN | |
nit | Identifier of the payment transaction on Carat. | = 64 AN | |
order_id | Order code sent by the merchant on the creation of the transaction. | < 40 AN | |
merchant_usn | Unique sequential number sent by the merchant on the creation of the transaction. | < 12 N | |
amount | Total price of the purchase specified by the merchant (in cents) on the creation of the transaction. | < 12 N | |
sitef_usn | Unique sequential number of the payment transaction on SiTef. | = 6 N | |
esitef_usn | Unique sequential number of the payment transaction on Carat Portal. | = 15 N | |
customer_receipt | Customer's receipt. | < 4000 AN | |
merchant_receipt | Merchant's receipt. | < 4000 AN | |
authorizer_id | Code of the authorizer used on the transaction. | < 4 N | |
acquirer_id | Code of the acquirer used on the transaction. | < 4 N | |
acquirer_name | Name of the acquirer used on the transaction. | < 100 AN | |
authorizer_date | Payment authorization date returned by the authorizer in DD/MM/YYYY'T'HH:mm format. Example: 13/07/2017T16:03 | = 16 D | |
authorization_number | Authorization number. | < 6 AN | |
host_usn | Host USN. | < 15 AN | |
tid | ID of the transaction on the acquirer. This field is only returned on transactions with acquirers that are external to SiTef. | < 40 AN | |
eci | Eletronic Commerce Indicator. | < 3 AN | |
payment_date | Payment authorization date on Carat Portal in DD/MM/YYYY'T'HH:mm format. Example: 13/07/2017T16:03 | = 16 D | |
issuer | Issuer code returned by the authorizer. | < 5 AN | |
authorizer_merchant_id | Affiliation code of the merchant on the authorizer. | < 100 AN | |
xid | XID field returned on 3DS authentications or certain acquirers. | < 40 AN | |
cavv | Cardholder Authentication Verification Value - Codes that refers to card holder authentication result data. | < 40 N | NO |
recurrency_tid | First transaction's id (TID) on the card brand. Returned only if it is a recurrent payment. This field is used only for e.Rede REST routings using the brands Visa or Mastercard. | < 16 AN | |
terminal_id | Terminal code used in the transaction | < 8 AN | |
payment_type | Payment type from the selected authorizer: B = boleto, C = credit, D = debit, P = Private Label credit card, T = bank transfer, G = gift card, O = other payment methods, W = Boleto NR via Web Service | = 1 AN | |
standin_details | This field provides additional information to identify whether a transaction was performed by the Stand-in on behalf of the issuer. Learn more. | < 6 AN | |
cvv_result_code | CVV result code (present only in Mastercard and Visa transactions). Values: M = Valid (match) N = Invalid (not matching) P = Not processed (issuer temporarily unavailable) U = not verified S = CVV2 must be on card | = 1 N | |
payment.analysis | |||
status | Status of the payment transaction on Carat Portal. Learn more. | = 3 AN | |
code | Carat Portal response code. Any code different from 0 means failure. Learn more. | < 4 N | |
message | Carat Portal response message. | < 500 AN |
Dynamic MCC Fields
Can be used for both payment and REST pre-authorization transactions
Request Parameters
Additionally to the fields of the Payment, the fields below are used specifically in dynamic MCC transactions integrated to the bin routing:
Parameter | Description | Format | Mandatory | |||
---|---|---|---|---|---|---|
soft_descriptor | Personalized phrase that will be printed on the bearer's invoice. For information regarding the dynamic MCC, it is equivalent to the name of the submerchant. | < 25 AN | YES | |||
additional_data | Element for sending additional data. | |||||
mcc | Submerchant's MCC. | = 4 N | YES | |||
subacquirer_merchant_id | Submerchant's code. Deprecated field!!! Use additional_data.subacquirer_merchant.id instead. | < 15 N | NO | |||
additional_data.subacquirer_merchant | Element for sending data related to a subacquirer's merchant. | |||||
id | Submerchant's code. | < 15 N | YES | |||
phone_number | Submerchant's phone number. | < 14 AN | NO | |||
address | Submerchant's address. | < 48 AN | NO | |||
city | Submerchant's city. | < 13 AN | NO | |||
state | Submerchant's state, in two-digit acronym format (e.g.: SP). | = 2 A | YES | |||
country | Submerchant's country. Follow the standard ISO 3166-1 alpha-2 (e.g.: BR). | = 2 A | YES | |||
zip_code | Submerchant's zip code. | < 9 AN | YES | |||
identification_number | Submerchant's CNPJ. | < 18 N | YES | |||
payment_facilitator_id | Facilitator's code. | < 11 N | YES |
Example
Request:
To use this example, don't forget to define the variable {{url}}
with the value
curl
--request POST "https://esitef-homologacao.softwareexpress.com.br/e-sitef/api/v1/transactions"
--header "Content-Type: application/json"
--header "merchant_id: xxxxxxxx"
--header "merchant_key: xxxxxxxxxxx"
--data-binary
{
"merchant_usn": "19035815234",
"order_id": "1616438400044",
"installments": "1",
"installment_type": "4",
"authorizer_id": "2",
"amount": "1300",
"soft_descriptor": "L012121",
"additional_data": {
"mcc": "1111",
"subacquirer_merchant": {
"id": "12345",
"address": "Avenida Paulista, 2000",
"city": "São Paulo",
"state": "SP",
"country": "BR",
"zip_code": "01107001",
"identification_number": "53455823000178",
"payment_facilitator_id": "654321",
"phone_number": "+55 11 99999-9999"
}
},
"card": {
"expiry_date": "1222",
"security_code": "123",
"number": "5555555555555555"
}
}
Response:
{
"code": "0",
"message": "OK. Transaction successful.",
"payment": {
"authorizer_code": "000",
"authorizer_message": "Transacao Aprov.",
"status": "CON",
"nit": "1234567890abcdefghijklmnopqrstuvwxyz1234567890abcdefghijklmnopqr",
"order_id": "1657810477538",
"customer_receipt": "====CUPOM COMPRADOR====",
"merchant_receipt": "====CUPOM ESTABELECIMENTO====",
"authorizer_id": "2",
"acquirer_id": "5",
"acquirer_name": "Bin",
"authorizer_date": "14/07/2022T11:54",
"authorization_number": "145778",
"merchant_usn": "12050620649",
"esitef_usn": "220714103502410",
"sitef_usn": "145778",
"host_usn": "999145778 ",
"amount": "10000",
"payment_type": "C",
"issuer": "2",
"authorizer_merchant_id": "000000000000005",
"terminal_id": "ES000032",
"payment_date": "14/07/2022T11:54",
"standin_details": "000001",
"cvv_result_code": "M"
}
}
Updated about 2 months ago