First use of the stored card

The example below shows how to use the Card on File feature when the card is being stored for the first time.
This process allows the card to be reused in future transactions, offering greater convenience and security for the user.

ℹ️

Learn more about this feature in the documentation.

EnvironmentMethodEndpoint
Sandboxposthttps://apisandbox.braspag.com.br/v2/sales/
Productionhttps://api.braspag.com.br/v2/sales/

Request

{  
   "MerchantOrderId":"2014111701",
   "Customer":{  
      "Name":"Aline de Souza",
      "Email":"[email protected]",
      "Birthdate":"1990-01-01"
   },
   "Payment":{  
     "Provider":"Simulado",
     "Type":"DebitCard",
     "Amount":15700,
     "Currency":"BRL",
     "Country":"BRA",
     "Installments":1,
     "Capture":true,
     "SoftDescriptor":"123456789ABCD",
     "DebitCard":{  
         "CardNumber":"4091688625337641",
         "Holder":"Teste Holder",
         "ExpirationDate":"12/2035",
         "SecurityCode":"333",
         "SaveCard":"false",
         "Brand":"Visa",
         "CardOnFile":{
            "Usage": "First"
         }
     }
   }
}
PROPERTYTYPESIZEREQUIREDDESCRIPTION
MerchantOrderIdText50YesOrder identification number. Warning: Allowed characters are a-z, A-Z, 0-9. Special characters and blank spaces are not allowed.
Customer.NameText255NoCustomer's name.Size: 255.
Warning: Only a-z, A-Z characters are allowed. Special characters and numbers are not allowed.
Customer.StatusText255NoThe customer’s registration status on the store. (NEW / EXISTING)
Customer.EmailText255NoCustomer's email
Customer.BirthdateDate10NoCustomer's birthdate (AAAA/MM/DD).
Payment.ProviderText15YesName of payment method provider.
Payment.TypeText100YesType of the Payment Method.
Payment.AmountNumber15YesOrder Amount (to be sent in cents).
Payment.CurrencyText3NoCurrency in which the payment will be made (BRL).
Payment.CountryText3NoCountry in which the payment will be made.
Payment.SoftDescriptorText13NoThe store’s name that will be on the shopper’s bank invoice. Does not allow special characters.
Payment.InstallmentsNumber2YesNumber of installments. If the transaction is a recurrence, the number of installments will be 1. For installment transactions, the number of installments will be greater than 1.
Payment.CaptureBooleanNo (Default false)Boolean that identifies if the authorization should be done by authomatic capture (true) or posterior capture (false).
DebitCard.CardNumberText19YesShopper’s card number.
DebitCard.HolderText25YesName of the shopper that’s printed on the card. Does not accept special characters.
DebitCard.ExpirationDateText7YesExpiration date printed on the card. Example: MM/AAAA.
DebitCard.SecurityCodeText4NoSecurity code printed on the back of the card.
DebitCard.SaveCardBooleanNo (Default false)Boolean that identifies if the card will be saved to generate a CardToken. Find out more about Tokenization of Cards
DebitCard.BrandText10YesCard brand. Possible values: Visa / Master / Amex / Elo / Aura / JCB / Diners / Discover.
DebitCard.CardOnFile.UsageText-No"First" if the card was stored and it’s your first use. "Used" if the card was stored and has been used for another transaction before.

Response

{
    "MerchantOrderId": "2014111701",
    "Customer":{  
      "Name":"Aline de Souza",
      "Email":"[email protected]",
      "Birthdate":"1990-01-01"
   },
    "Payment": {
        "ServiceTaxAmount": 0,
        "Installments": 1,
        "Interest": 0,
        "Capture": true,
        "DebitCard": {
            "CardNumber": "4091688625337641",
            "Holder": "Teste Holder",
            "ExpirationDate": "12/2035",
            "SaveCard": false,
            "Brand": "Visa",
            "CardOnFile": {
                "Usage": "First"               
            },
            "PaymentAccountReference": "JZHOZJHNZH87KQXM3G60B9I21GVZN"
        },
        "Tid": "0928084922246",
        "ProofOfSale": "652515",
        "AuthorizationCode": "927181",
        "SoftDescriptor": "123456789ABCD",
        "Provider": "Simulado",
        "IsQrCode": false,
        "DynamicCurrencyConversion": false,
        "Amount": 15700,
        "ReceivedDate": "2022-09-28 08:49:22",
        "CapturedAmount": 15700,
        "CapturedDate": "2022-09-28 08:49:22",
        "Status": 2,
        "IsSplitted": false,
        "ReturnMessage": "Operation Successful",
        "ReturnCode": "6",
        "PaymentId": "91bad53a-9198-4738-a280-f51dddc34988",
        "Type": "DebitCard",
        "Currency": "BRL",
        "Country": "BRA",
        "Links": [
            {
                "Method": "GET",
                "Rel": "self",
                "Href": "https://apiquerysandbox.cieloecommerce.cielo.com.br/1/sales/91bad53a-9198-4738-a280-f51dddc34988"
            },
            {
                "Method": "PUT",
                "Rel": "void",
                "Href": "https://apisandbox.cieloecommerce.cielo.com.br/1/sales/91bad53a-9198-4738-a280-f51dddc34988/void"
            }
        ]
    }
}

PROPERTYDESCRIPTIONTYPESIZEFORMAT
ProofOfSaleAuthorization number, identical to NSU.Text6Alphanumeric text
TidTransaction Id on the acquirer.Text20Alphanumeric text
AuthorizationCodeAuthorization code.Text6Alphanumeric text
SoftDescriptorText that will be printed on the carrier’s bank invoice. Does not allow special characters.Text13Alphanumeric text
PaymentIdPayment ID number, needed for future operations like Consulting, Capture and Cancellation.Guid36xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx
ECIEletronic Commerce Indicator. Indicates how safe a transaction is.Text2Example: 7
StatusTransaction status.Byte2
ReturnCodeAcquiring return code.Text32Alphanumeric text
ReturnMessageAcquiring return message.Text512Alphanumeric text
Payment.MerchantAdviceCodeCard brand’s return code that defines the period for transaction submission retry. Valid only for Mastercard.Text2Numeric
DebitCard.PaymentAccountReferencePAR (payment account reference) is the number that associates different tokens to the same card. It will be returned by the Master and Visa brands and passed on to Cielo e-commerce customers. If the card brand doesn’t send the information the field will not be returned.Alphanumeric29

⚠️

Warning

For Mastercard brands, it is necessary to send the Payment.InitiatedTransactionIndicator node to indicate the transaction initiator..