Alternative Payment Methods
Info
The purchase status for Alternative Payment methods will remain Pending until the customer completes payment either in their wallet or at a physical payment office.
Pago Fácil
Pago Fácil provides a network of physical payment centers where your customers can pay their purchases in cash. Your customers must provide their payment information and the amount they wish to pay, and the system takes care of the rest.
Request parameters
You need to include specific fields for this payment method to work correctly. Check the Purchase operation article for details on authentication, languages of the response, and basic purchase parameters such as amount and currency.
Property | Type | Mandatory? | Description |
---|---|---|---|
PaymentMediaId |
numeric |
Yes | The PaymentMediaId for this payment method is 61. |
TargetCountryISO |
string |
Yes | Indicate the destination country. |
Customer → Email |
string |
Yes | Customer’s email. |
Customer → FirstName |
string |
Yes | Customer’s first name. |
Customer → LastName |
string |
Yes | Customer’s last name. |
Customer → DocumentTypeId |
numeric |
No | Customer’s document type. Refer to the Document types table to see the possible values. |
Customer → DocNumber |
string |
No | Customer’s Document Number. |
Customer → PhoneNumber |
string |
No | Customer’s phone number. |
Customer → BillingAddress → Country |
string |
No | Customer’s Country. |
Customer → BillingAddress → State |
string |
No | Customer’s State. |
Customer → BillingAddress → City |
string |
No | Customer’s City. |
Customer → BillingAddress → AddressDetail |
string |
No | Customer’s Address Detail. |
Customer → BillingAddress → PostalCode |
string |
No | Customer’s Postal Code. |
MetaDataIn → PaymentExpirationInMinutes |
numeric |
No | Configure the expiration time for the payment using this field, specifying the duration in minutes. The API applies a default value if you don’t provide this information. |
Request example
{
"PaymentMediaId":61,
"Amount": 10000,
"Currency": "ARS",
"Capture": true,
"Order":"123456789",
"TargetCountryISO": "AR",
"Customer": {
"Email": "eluna@mail.com",
"BillingAddress": {
"AddressType": 1,
"Country": "AR",
"State": "C",
"City": "BsAs",
"AddressDetail": "Joaquin Requena 1580",
"PostalCode": "C1054AAU"
},
"FirstName" : "Erik",
"LastName": "Luna",
"DocNumber" : "12345672",
"DocumentTypeId": 17,
"PhoneNumber" : "24022330"
},
"MetaDataIn" : {
"PaymentExpirationInMinutes" :"7200"
},
"Description": "Prueba Argentina Pago Facil"
}
Response parameters
In the response, you will find the following parameters:
Property | Type | Description |
---|---|---|
Response → MetadataOut → PaymentUrl |
string |
URL to where you need to redirect the customer to get the payment information. |
Response → MetadataOut → PaymentCode |
string |
Payment reference generated by Pago Fácil. |
Response → MetadataOut → PaymentExpirationDate |
date |
Date when the payment will expire. Format DD/MM/YYYY. |
You must redirect your customer to the URL displayed in the parameter Response.MetadataOut.PaymentUrl
, where they can print the voucher and complete the payment in a Pago Fácil office.
Response example
{
"Response": {
"PurchaseId": 1130909,
"Created": "2023-08-15T14:37:16.410",
"Transaction": {
"TransactionID": 1148775,
"Created": "2023-08-15T14:37:16.410",
"AuthorizationDate": "",
"TransactionStatusId": 2,
"Status": "Pending",
"Description": " ",
"Steps": [
{
"Step": "Generic External",
"Created": "",
"ResponseCode": "200",
"ResponseMessage": "OK",
"AcquirerResponseDetail": "{\"trnId\":\"190444\"}"
}
]
},
"Capture": true,
"Amount": 12000,
"OriginalAmount": 12000,
"TaxableAmount": 0,
"Tip": 0,
"Installments": 1,
"Currency": "ARS",
"Description": "Prueba Argentina Pago Facil",
"Customer": {
"CustomerId": 88230,
"Created": "2022-12-08T11:30:35.933",
"Owner": "Commerce",
"Email": "John@mail.com",
"Enabled": true,
"BillingAddress": {
"AddressId": 88894,
"AddressType": 2,
"Country": "COL",
"State": "Antioquia",
"AddressDetail": "Carrera 80 #30 - 20",
"City": "Medellin"
},
"PaymentProfiles": [
{
"PaymentProfileId": 101557,
"PaymentMediaId": 2,
"Created": "2023-05-24T21:35:14.387",
"LastUpdate": "2023-05-24T21:40:30.700",
"Brand": "MasterCard",
"CardOwner": "John Doe",
"Bin": "529991",
"Type": "CreditCard",
"IdCommerceToken": 40604,
"Token": "CT__uYBBUihIydvI--7Pyl8U665OfY_kbX2GGUsAV93Sj0k_",
"Expiration": "203008",
"Last4": "0015",
"Enabled": true,
"DocumentNumber": "74857601",
"DocumentTypeId": 2,
"ExternalValue": "0224d9a155f229d17a966c8f331978dd06df92dcc305fddb9535befe8d7bf999"
},
{
"PaymentProfileId": 252287,
"PaymentMediaId": 1,
"Created": "2023-07-31T18:23:43.257",
"LastUpdate": "2023-07-31T18:23:43.257",
"Brand": "VISA",
"CardOwner": "Jhon Doe",
"Bin": "405188",
"IssuerBank": "Visa",
"Installments": "1;2;3;4;5;6;7;8;9;10;11;12;13;14;15;16;17;18;19;20;21;22;23;24",
"Type": "CreditCard",
"IdCommerceToken": 41630,
"Token": "CT__01dPtulDMY-yaNLK0D4isQhI2h7Angq5R5aAyNExBiM_",
"Expiration": "202912",
"Last4": "6623",
"Enabled": true
}
],
"CaptureURL": "https://api.stage.bamboopayment.com/v1/Capture/",
"URL": "https://api.stage.bamboopayment.com/Customer/88230",
"FirstName": "John",
"LastName": "Doe",
"DocNumber": "139899768",
"DocumentTypeId": 4,
"PhoneNumber": "12345672"
},
"URL": "https://api.stage.bamboopayment.com/Purchase/1130909",
"DataUY": {
"IsFinalConsumer": false,
"TaxableAmount": 0
},
"DataDO": {
"Tax": 0
},
"Acquirer": {
"AcquirerID": 69,
"Name": "Pago Facil"
},
"PurchasePaymentProfileId": 97029,
"MetadataIn": {
"PaymentExpirationInMinutes": "7200"
},
"MetadataOut": {
"PaymentUrl": "https://s3.amazonaws.com/gateway.stage.bamboopayment.com/purchase-coupons/1130909_71afa71e-bb69-4f75-9ce7-666014f6c919_20231115.html",
"PaymentCode": "1130909",
"PaymentExpirationDate": "20/08/2023"
},
"CrossBorderDataResponse": {
"TargetCountryISO": "AR",
"TargetCurrencyISO": "ARS",
"TargetAmount": 100
},
"IsFirstRecurrentPurchase": false,
"AntifraudData": {},
"PurchaseType": 1
},
"Errors": []
}
Transferencias 3.0
With Transferencias 3.0, you can show a QR code generated by Bamboo that your customer can read using their wallet.
Request parameters
You need to include specific fields for this payment method to work correctly. Check the Purchase operation article for details on authentication, languages of the response, and basic purchase parameters such as amount and currency.
Property | Type | Mandatory? | Description |
---|---|---|---|
PaymentMediaId |
numeric |
Yes | The PaymentMediaId for this payment method is 72. |
TargetCountryISO |
string |
Yes | Indicate the destination country. |
Customer → Email |
string |
Yes | Customer’s email. |
Customer → FirstName |
string |
No | Customer’s first name. |
Customer → LastName |
string |
No | Customer’s last name. |
Customer → DocumentTypeId |
numeric |
No | Customer’s document type. Refer to the Document types table to see the possible values. |
Customer → DocNumber |
string |
No | Customer’s Document Number. |
Customer → PhoneNumber |
string |
No | Customer’s phone number. |
Customer → BillingAddress → Country |
string |
No | Customer’s Country. |
Customer → BillingAddress → State |
string |
No | Customer’s State. |
Customer → BillingAddress → City |
string |
No | Customer’s City. |
Customer → BillingAddress → AddressDetail |
string |
No | Customer’s Address Detail. |
Customer → BillingAddress → PostalCode |
string |
No | Customer’s Postal Code. |
MetaDataIn → PaymentExpirationInMinutes |
numeric |
No | Configure the expiration time for the payment using this field, specifying the duration in minutes. The API applies a default value if you don’t provide this information. |
Request example
{
"PaymentMediaId":"72",
"Order":"QA908",
"Capture":"true",
"Amount": 55734,
"TargetCountryISO": "AR",
"Currency":"ARS",
"Customer": {
"Email": "eluna@mail.com",
"BillingAddress": {
"AddressType": 1,
"Country": "AR",
"State": "C",
"City": "BsAs",
"AddressDetail": "Joaquin Requena 1580",
"PostalCode": "C1054AAU"
},
"FirstName" : "Erik",
"LastName": "Luna",
"DocNumber" : "12345672",
"DocumentTypeId": 17,
"PhoneNumber" : "24022330"
},
"Description" : "Test purchase"
}
Response parameters
The following example shows the response to the request.
{
"Response": {
"PurchaseId": 1167185,
"Created": "2023-09-04T20:08:58.295",
"TrxToken": null,
"Order": "QA908",
"Transaction": {
"TransactionID": 1186082,
"Created": "2023-09-04T20:08:58.295",
"AuthorizationDate": "",
"TransactionStatusId": 2,
"Status": "Pending",
"ErrorCode": null,
"Description": " ",
"ApprovalCode": null,
"Steps": [
{
"Step": "Generic External",
"Created": "",
"Status": null,
"ResponseCode": "",
"ResponseMessage": "",
"Error": null,
"AuthorizationCode": "",
"UniqueID": null,
"AcquirerResponseDetail": ""
}
]
},
"Capture": true,
"Amount": 55734,
"OriginalAmount": 55734,
"TaxableAmount": null,
"Tip": 0,
"Installments": 1,
"Currency": "ARS",
"Description": "Test purchase",
"Customer": {
"CustomerId": 251238,
"Created": "2023-09-04T20:08:57.450",
"CommerceCustomerId": null,
"Owner": "Anonymous",
"Email": "eluna@mail.com",
"Enabled": true,
"ShippingAddress": null,
"BillingAddress": {
"AddressId": 374730,
"AddressType": 2,
"Country": "AR",
"State": "C",
"AddressDetail": "Joaquin Requena 1580",
"PostalCode": "C1054AAU",
"City": "BsAs"
},
"Plans": null,
"AdditionalData": null,
"PaymentProfiles": [
{
"PaymentProfileId": 256000,
"PaymentMediaId": 72,
"Created": "2023-09-04T20:08:57.550",
"LastUpdate": "2023-09-04T20:08:57.893",
"Brand": "Transferencias30",
"CardOwner": null,
"Bin": null,
"IssuerBank": null,
"Installments": null,
"Type": "BankTransfer",
"IdCommerceToken": 0,
"Token": null,
"Expiration": null,
"Last4": "",
"Enabled": null,
"DocumentNumber": null,
"DocumentTypeId": null,
"ExternalValue": null,
"AffinityGroup": null
}
],
"CaptureURL": null,
"UniqueID": null,
"URL": "https://api.stage.bamboopayment.com/Customer/251238",
"FirstName": "Erik",
"LastName": "Luna",
"DocNumber": "12345672",
"DocumentTypeId": 17,
"PhoneNumber": "24022330",
"ExternalValue": null
},
"RefundList": null,
"PlanID": null,
"UniqueID": null,
"AdditionalData": null,
"CustomerUserAgent": null,
"CustomerIP": null,
"URL": "https://api.stage.bamboopayment.com/Purchase/1167185",
"DataUY": {
"IsFinalConsumer": false,
"Invoice": null,
"TaxableAmount": null
},
"DataDO": {
"Invoice": null,
"Tax": null
},
"Acquirer": {
"AcquirerID": 83,
"Name": "Transferencias 3.0",
"CommerceNumber": null
},
"CommerceAction": null,
"PurchasePaymentProfileId": 256000,
"LoyaltyPlan": null,
"DeviceFingerprintId": null,
"MetadataIn": null,
"MetadataOut": {
"CodeQr": "630414D2",
"Base64Qr": ""
},
"CrossBorderData": null,
"CrossBorderDataResponse": {
"TargetCountryISO": "AR",
"TargetCurrencyISO": "ARS",
"TargetAmount": 557.34
},
"Redirection": null,
"IsFirstRecurrentPurchase": false,
"AntifraudData": {
"AntifraudFingerprintId": null,
"AntifraudMetadataIn": null
},
"PaymentMediaId": null,
"PurchaseType": 1,
"HasCvv": null,
"TargetCountryISO": null
},
"Errors": []
}
In the field MetadataOut
inside the purchase Response
object, the QR code is returned as a base64 image (Parameter Base64Qr
); add this image inside an image HTML tag. For example:
<img src="" id="qr-code-display" style="max-width: 400px;">
Result:
Offline Bank transfers
With Offline Bank transfers, you can let your customer pay using bank transfers using any Bank account and wallet with CVU (Clave Virtual Uniforme) or CBU (Clave Bancaria Uniforme). To complete the payment, your customer must transfer the purchase amount to the account details in the response.
Request parameters
You need to include specific fields for this payment method to work correctly. Check the Purchase operation article for details on authentication, languages of the response, and basic purchase parameters such as amount and currency.
Property | Type | Mandatory? | Description |
---|---|---|---|
PaymentMediaId |
numeric |
Yes | The PaymentMediaId for this payment method is 532. |
TargetCountryISO |
string |
Yes | Indicate the destination country. |
Customer → Email |
string |
Yes | Customer’s email. |
Customer → FirstName |
string |
No | Customer’s first name. |
Customer → LastName |
string |
No | Customer’s last name. |
Customer → DocumentTypeId |
numeric |
No | Customer’s document type. Refer to the Document types table to see the possible values. |
Customer → DocNumber |
string |
Yes | Customer’s Document Number. |
Customer → PhoneNumber |
string |
No | Customer’s phone number. |
Customer → BillingAddress → Country |
string |
No | Customer’s Country. |
Customer → BillingAddress → State |
string |
No | Customer’s State. |
Customer → BillingAddress → City |
string |
No | Customer’s City. |
Customer → BillingAddress → AddressDetail |
string |
No | Customer’s Address Detail. |
Customer → BillingAddress → PostalCode |
string |
No | Customer’s Postal Code. |
MetaDataIn → PaymentExpirationInMinutes |
numeric |
No | Configure the expiration time for the payment using this field, specifying the duration in minutes. The API applies a default value if you don’t provide this information. |
Request example
{
"PaymentMediaId": 532,
"Order": "QA541",
"Capture": "true",
"Amount": 100000,
"Installments": 1,
"Currency": "USD",
"CrossBorderData": {
"TargetCountryISO": "AR"
},
"Description": "Compra de prueba",
"Customer": {
"Email": "eluna@mail.com",
"BillingAddress": {
"AddressType": 1,
"Country": "AR",
"State": "C",
"City": "BsAs",
"AddressDetail": "Joaquin Requena 1580",
"PostalCode": "C1054AAU"
},
"FirstName": "Erik",
"LastName": "Luna",
"DocNumber": "12345672",
"DocumentTypeId": 17,
"PhoneNumber": "24022330"
},
"MetaDataIn": {
"PaymentExpirationInMinutes": 60
},
"Redirection": {
"Url_Approved": "https://dummystore.com/checkout/response",
"Url_Rejected": "https://dummystore.com/checkout/response",
"Url_Canceled": "https://dummystore.com/checkout/response",
"Url_Pending": "https://dummystore.com/checkout/response"
}
}
Response parameters
We return the Purchase
with the status Pending for Redirection and a CommerceAction
object with ActionReason
as REDIRECTION_NEEDED_EXTERNAL_SERVICE
and the ActionURL
parameter with the URL of the coupon. In this URL, the payer must log in to their home banking app and complete the payment. Refer to the Payment Experience section to see the payment flow.
For more information on the response parameters, please refer to the Response parameters section of the Purchase creation.
Response example
{
"Response": {
"PurchaseId": 1260547,
"Created": "2023-12-13T13:12:28.025",
"TrxToken": null,
"Order": "QA623",
"Transaction": {
"TransactionID": 1280439,
"Created": "2023-12-13T13:12:28.025",
"AuthorizationDate": "",
"TransactionStatusId": 2,
"Status": "Pending",
"ErrorCode": null,
"Description": " ",
"ApprovalCode": null,
"Steps": [
{
"Step": "Generic External",
"Created": "2023-12-13T16:12:28.025",
"Status": "Pending for Redirection",
"ResponseCode": null,
"ResponseMessage": null,
"Error": null,
"AuthorizationCode": null,
"UniqueID": null,
"AcquirerResponseDetail": null
}
]
},
"Capture": true,
"Amount": 84860000,
"OriginalAmount": 84860000,
"TaxableAmount": null,
"Tip": 0,
"Installments": 1,
"Currency": "ARS",
"Description": "Compra de prueba",
"Customer": {
"CustomerId": 263479,
"Created": "2023-12-13T13:12:27.663",
"CommerceCustomerId": null,
"Owner": "Anonymous",
"Email": "eluna@mail.com",
"Enabled": true,
"ShippingAddress": null,
"BillingAddress": {
"AddressId": 0,
"AddressType": 1,
"Country": "AR",
"State": "C",
"AddressDetail": "Joaquin Requena 1580",
"PostalCode": "C1054AAU",
"City": "BsAs"
},
"Plans": null,
"AdditionalData": null,
"PaymentProfiles": [
{
"PaymentProfileId": 268514,
"PaymentMediaId": 532,
"Created": "2023-12-13T16:12:27.810",
"LastUpdate": "2023-12-13T16:12:27.863",
"Brand": "Infinia",
"CardOwner": null,
"Bin": null,
"IssuerBank": null,
"Installments": null,
"Type": "BankTransfer",
"IdCommerceToken": 0,
"Token": null,
"Expiration": null,
"Last4": "",
"Enabled": null,
"DocumentNumber": null,
"DocumentTypeId": null,
"ExternalValue": null,
"AffinityGroup": null
}
],
"CaptureURL": null,
"UniqueID": null,
"URL": "https://api.stage.bamboopayment.com/Customer/263479",
"FirstName": "Erik",
"LastName": "Luna",
"DocNumber": "12345672",
"DocumentTypeId": 17,
"PhoneNumber": "24022330",
"ExternalValue": null
},
"RefundList": null,
"PlanID": null,
"UniqueID": null,
"AdditionalData": null,
"CustomerUserAgent": null,
"CustomerIP": null,
"URL": "https://api.stage.bamboopayment.com/Purchase/1260547",
"DataUY": {
"IsFinalConsumer": false,
"Invoice": null,
"TaxableAmount": null
},
"DataDO": {
"Invoice": null,
"Tax": null
},
"Acquirer": {
"AcquirerID": 147,
"Name": "Infinia Redirect AR",
"CommerceNumber": null
},
"CommerceAction": {
"ActionType": 1,
"ActionReason": "REDIRECTION_NEEDED_EXTERNAL_SERVICE",
"ActionURL": "https://redirect.stage.bamboopayment.com/CA_25001335-2c28-46b8-82f7-29d59963e663",
"ActionBody": null,
"ActionSessionId": "CA_25001335-2c28-46b8-82f7-29d59963e663"
},
"PurchasePaymentProfileId": 268514,
"LoyaltyPlan": null,
"DeviceFingerprintId": null,
"MetadataIn": {},
"MetadataOut": null,
"CrossBorderData": null,
"CrossBorderDataResponse": {
"TargetCountryISO": "AR",
"TargetCurrencyISO": "USD",
"TargetAmount": 1000
},
"Redirection": null,
"IsFirstRecurrentPurchase": false,
"AntifraudData": {
"AntifraudFingerprintId": null,
"AntifraudMetadataIn": null
},
"PaymentMediaId": null,
"PurchaseType": 1,
"HasCvv": null,
"TargetCountryISO": null
},
"Errors": []
}
Payment experience
As mentioned, you must redirect your customer to the URL returned in the response (parameter CommerceAction.ActionURL
).
The first step your customer must take is to provide their DNI/CUIT number.
Then, we show your customer the coupon with the bank information to where they need to create the transfer.
Info
You can customize this coupon to display your logo at the top. Contact Bamboo support to include it.
Once your customer completes the transfer, they can use the confirmation button at the bottom of this screen.