Virtual store's payment page
The merchant's payment page must contain the Carat Portal's script. Below are the URL's for download:
URL for Production environment:
https://ecomm-bin.fiserv.com.br/js/esitefpayment-1.0.min.js
URL for Homologation environment:
https://sandbox.ecomm-bin.fiserv.com.br/js/esitefpayment-1.0.min.js
#
Fields with card dataThe card fields must contain the classes specified below:
Parameter | Description | Format | Mandatory |
---|---|---|---|
esitef-cardnumber | Customer's card number (PAN). | < 19 N | YES |
esitef-cardexpirydate | Card expiry date in MMYY format. | = 4 N | YES |
esitef-cardexpirymonth & esitef-cardexpiryyear | Card expiry month and year, in MM and YY format, respectively. These fields can be sent instead of esitef-cardexpirydate . If all these fields are sent at the same time, the split date (esitef-cardexpirymonth and esitef-cardexpiryyear ) will have priority. | = 2 N | YES |
esitef-cardsecuritycode | Card security code. | < 5 N | YES |
esitef-cardholder | Card holder name. | < 30 AN | COND. |
#
Calling Carat Portal's scriptWhen the customer fills the card data and clicks "pay", the merchant's page must call the esitefDoPayment
JavaScript function, passing as argument a request with the following fields:
Parameter | Description | Format | Mandatory |
---|---|---|---|
nit | Transaction identification in Carat Portal. The field nit received by the transaction creation service. | = 64 AN | YES |
payToken | The field pay_token received by the transaction creation service. This token can only be used once. | = 66 AN | YES |
merchantId | Merchant code on Carat Portal. The production and certification codes will be different. | < 15 AN | YES |
locale | Language of the messages returned in validation errors (onInvalid callback). It can receive the following values: pt - Portuguese en - English es - Spanish If the locale is not sent, pt will be used. | = 2 A | NO |
isCardSecurityCode Optional | Defines if the card security code will be validated as a mandatory or optional field. Send true if it's an optional field. If this field is not sent, the value false will be used (mandatory security code). | < 5 T/F | NO |
onSuccess | Callback function the will be called after a successful payment on Carat Portal. This function receives as argument the payment response described in Success and failure callbacks response. | F | YES |
onFailure | Callback function the will be called after an unsuccessful payment on Carat Portal. This function receives as argument the payment response described in Success and failure callbacks response. | F | YES |
onInvalid | Callback function that will be called after a JavaScript validation error. This function receives as argument the error list described in Validation error callback response | F | YES |
#
Success and failure callbacks responseThe onSuccess
and onFailure
callback functions receive as argument an object containing information related to the payment. Below are the descriptions of these fields:
Parameter | Description | Format |
---|---|---|
code | Carat Portal response code. Any code different from 0 (zero) means failure. For further information, refer to the Response codes. | < 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. | = 3 AN |
nit | Identifier of the payment transaction on Carat Portal. | = 64 AN |
order_id | Order code sent by the merchant on the creation of the transaction. | < 40 AN |
customer_receipt | Customer's receipt. | < 4000 AN |
authorizer_id | Code of the authorizer used on the transaction. | < 4 N |
#
Validation error callback responseThe onInvalid
callback function receives as argument a list of error objects, containing the fields below:
Parameter | Description | Format |
---|---|---|
field | Name of the field in error. | < 30 AN |
cause | Error message. | < 100 AN |
#
ExampleBelow is an example of a page integrated with Carat Portal's JavaScript payment:
To use this example, don't forget to define the variable {{url}}
to the value
sandbox.ecomm-bin.fiserv.com.br