PayPal (with Braintree) integration guide
PayPal (with Braintree) is a payment provider allowing customers to pay using payment methods saved to their PayPal account. This section is intended to help you implement PayPal (with Braintree) based on your preferred integration workflow.
Note
PayPal (with Braintree) is different from PayPal in the following ways:
- PayPal (with Braintree) allows for customer-not-present (also known as "merchant-initiated") transactions via a saved token, whereas standard PayPal only supports customer-present transactions.
- PayPal (with Braintree) only supports the individual iframe integration method and PayPal supports the multi-iframe, individual iframe, and custom redirect integration methods.
- PayPal (with Braintree supports the "Continue button" and "Checkout page" payment flows while PayPal only supports a "Checkout page" flow.
- PayPal (with Braintree) only supports the AUD, CAD, EUR, GBP, and USD currencies; PayPal supports the AUD, BRL, CAD, CHF, CZK, DKK, EUR, GBP, HKD, HUF, ILS, INR, JPY, MXN, MYR, NOK, NZD, PLN, RUB, SEK, SGD, THB, TWD, and USD currencies.
- For a checkout page flow, the required fields for the two payment methods are the same. However, PayPal (with Braintree) requires additional parameters for either the "Continue button" payment flow or the merchant-initiated transactions.
Services and compatibility
Payment method gateway name | PayPal |
Supported transaction types | |
Supported integration methods |
|
Supported payment flows |
|
Supported processing currencies | AUD, CAD, EUR, GBP, USD |
Webhook event types |
|
Configuration
In order to use PayPal (with Braintree) with your merchant account, you must first work with integrations to add it to your account.
In order to configure your account for use with PayPal (with Braintree), you will need the following:
- A login for the PayPal developer site.
- A Braintree account.
- Have PayPal accounts ready for your different markets.
After you have the above and have worked with Integrations Support to get your PayPal ClientID, you are ready to follow the configuration steps.
Prerequisites
In order to configure your account for use with PayPal (with Braintree), you need the following:
- PayPal Developer Account
- Braintree Account
Configuration Steps
To configure PayPal (with Braintree), you must complete the following set of steps:
Link PayPal account to Braintree environment
Integration support helps you complete this step for the Sandbox environment. However, you must do the configuration for your production environment.
Follow these steps to link your PayPal account:
-
Navigate to the Braintree Environment
Go to the Braintree Environment and log in.
-
Get the API keys
Go to Settings > API.
The system displays all the keys.
-
Locate the Merchant ID
The Merchant ID displays at the bottom of the Keys page.
Make note of this ID because you will use this value in Step 7.
-
Navigate to Processing Options
Go back to the home screen.
Go to Settings > Processing > Processing Options.
-
Configure Options
In the PayPal area, click Options.
You are prompted to log in with your PayPal account credentials.
After successfully logging in, the PayPal Accounts page displays. Braintree retrieves the necessary clientID, PayPal email, and Client Secret.
-
Link One or More PayPal Accounts
Merchant account IDs are created and added to the merchant account by PayPal after the merchant has signed all the necessary PayPal documentation. Contact PayPal and the merchant to arrange the creation of merchant account IDs. Follow this same process when you need to add new payment methods to the merchant account.
a. Click the +Link New PayPal Account button.
b. Provide PayPal account details and URLs for Privacy Policy and Terms and Conditions.
c. In the new account row (the one that does not show any merchant accounts), click Edit.
d. Start typing the merchant account name so that the selector displays a list of all potential matches.
e. If you want to enable PayPal Disputes for this account, select Manage PayPal Disputes in the Braintree Control Panel.
Note
If you link a merchant account here, any previous links made to that merchant account are removed.
-
Add Merchant Account IDs for Each Currency to Support
To support multiple currencies, you must have a different merchant account ID for each currency. Work with your PayPal account representative to arrange this.
Token migration
It is possible to migrate your existing APM tokens to Nexio for recurring transactions.
Migration from PayPal
If you do not have an existing Braintree account, and you want to take advantage of recurring transactions with PayPal (with Braintree), you must migrate your PayPal tokens.
- Contact PayPal.
- Request a download of your existing PayPal subscription agreement IDs.
- Contact Braintree and provide the downloaded file for importing the tokens.
- If migrating the tokens to the Nexio vault, continue with the next set of steps.
Migration from PayPal (with Braintree)
If you have migrated your tokens from PayPal (or have Braintree tokens) to Braintree and you want to migrate those tokens to the Nexio vault for recurring transactions, complete the following steps:
- Contact Braintree.
- Request a download of your existing PayPal (with Braintree) Braintree IDs.
The following fields can be included in the file as needed. Nexio recommends that you include as much information as possible:
apmToken
,customerRef
,email
,shopperReference
,currencyCode
,firstName
,lastName
,orderNumber
,shipToAddressOne
,shipToAddressTwo
,shipToCity
,shipToCountry
,shipToPostal
,shipToState
,billToAddressOne
,billToAddressTwo
,billToCity
,billToCountry
,billToPostal
,billToState
,merchantId
,originalRefNumber
- Contact Integrations Support to let them know that you are ready to migrate your tokens from PayPal (with Braintree). They provide you with information about the next steps to take for sending the file.
Integration flow
The general integration flow is the same for all APMs and depends on which APMs you want to integrate with.
First, the decision about which APMs to use affects the possible integration methods and the required parameters for the APM one-time-use token request. Use the information from this integration guide with the information from any other applicable integration guides as you plan your integration. In order to integrate an APM after it has been added to your merchant account, you need to decide which integration method you want to use, which may be dependent on the method you have used with other APMs. Note that you can mix and match those methods for each APM but your page may not look as usable or clear as when using a single method. There are pros and cons to each method. For additional information, see the Supported integration methods for APMs topic.
After deciding on the integration method, you need to make sure that you know which currencies are supported (for an overview of all APMs, see Supported currencies for APMs) and which parameters are required in a request. This is especially important for integrations with multiple APMs. Make sure that all the required parameters are accounted for across all the APMs used. For an overview of common parameters across the APMs, see Common required parameters.
You also need to decide whether you want to specify where you want the APM to return the customer after they pay or just to the page that opened the APM payment page. If you specify a page, you must include the customerRedirectUrl
parameter in the APM one-time-use token request, you need to create that page on your site, and you need to create the code for the page that parses the query string parameters passed along with that redirect URL. Note that you must use this option when using the custom integration method. If you use the referring page, that page needs to listen for event messages.
In addition to either of the previous options, you should also configure webhooks to get event messages. This is especially helpful for instances where the APM process fails or there are problems with a transaction request.
Next, decide on where you are displaying the APM as a payment option (on a product page, shopping cart page, checkout page, or some combination of those. For example, PayPal (with Braintree) has a “Continue button” flow that you can use on a shopping cart page, which may affect how you integrate.
On each page where you are putting the APM option, first you need an APM one-time-use token. This is where you can send most of the required parameters. If necessary, you can also send customization options for the iframe display (whether multi or individual). This returns URLs and an APM token that you use for the integration method you want. Use this URL for the iframe or link. Each APM gets a different URL (except for the multi-iframe method, which gets one for all APMs that are supported).
You will also want to note the asyncTraceId
(it is the same for all APMs returned from the APM one-time-use token) because you can use that to track the status of the transaction and narrow down the problem when troubleshooting.
Many of the APMs open a new webpage when the customer selects to pay using that method. The ideal payment flow returns control to the merchant website after the customer authenticates and pays from the APM website. As mentioned previously, your integration needs to include code that gets the data returned from the APM. This will be in the URL query parameters or as event messages or as webhooks. Use this information for display a payment success or failure message for the customer.
Required fields
The following table shows the required and optional fields for PayPal (with Braintree) transactions in the Create APM one-time-use token request.
Field | Required? | Description |
---|---|---|
data.amount | Yes | The transaction amount. |
data.currency | Yes | The three-character ISO currency code for the transaction. For PayPal (with Braintree), supported currencies are AUD, CAD, EUR, GBP, and USD. |
data.customer.orderNumber | Yes | The order number. |
data.customer.firstName | Conditional | The customer's first name, as it is set for the payment method. This parameter is not required for a 'continue button' payment flow, such as on a shopping cart page before getting to the checkout page. For more information, see the Paypal (with Braintree) payment flow section. |
data.customer.lastName | Conditional | The customer's last name, as it is set for the payment method. This parameter is not required for a 'continue button' payment flow, such as on a shopping cart page before getting to the checkout page. For more information, see the Paypal (with Braintree) payment flow section. |
data.customer.email | Conditional | The customer's email address. This parameter is not required for a 'continue button' payment flow, such as on a shopping cart page before getting to the checkout page, For more information, see the Paypal (with Braintree) payment flow section. |
data.customer.customerRef | Conditional | Customer identifier. You can use this field to pass a customer ID to the APM or to manage user subscriptions. For recurring transactions, you must include a value for this parameter in the request. |
processingOptions.doNotProcessPayment | Conditional | If you want to set up a 'continue button' payment flow, such as on a shopping cart page before getting to the checkout page, include this parameter in the body of your one-time-use token request and set it equal to true .For the 'continue button' flow, you do not have to include the following parameters: data.customer.firstName , data.customer.lastName , and data.customer.email . These fields are returned from PayPal in the response for this flow.For more information, see the Paypal (with Braintree) payment flow section. |
processingOptions.saveRecurringToken | Conditional | If you want to save a recurring token for a future merchant-initiated transaction, include this parameter in the body of your one-time-use token request and set it equal to true . In addition, if the amount to process on the Confirm/Place Order page will be more than the current amount for a 'continue button' payment flow, you must include this parameter so that you can send the payment request (for example, if adding tax and shipping costs to the amount).Note: The standard PayPal integration does not support merchant-initiated recurring transactions, only the PayPal (with Braintree) integration. For more information, see Run a merchant-initiated recurring transaction. |
data.cart.items[n].item | No | Item number or code. |
data.cart.items[n].description | No | A description of the item. |
data.cart.items[n].quantity | No | The quantity sold. |
data.cart.items[n].price | No | The price per item. |
data.customer.billToAddressOne | No | The street address for the customer. |
data.customer.billToAddressTwo | No | Additional street address information, if required. |
data.customer.billToCity | No | The city for the address record. |
data.customer.billToState | No | The state or province on file with the payment provider. (If in the US, this must be the two-character state abbreviation). |
data.customer.billToPostal | No | The postal code on file. |
data.customer.billToCountry | No | The two-character (Alpha-2) ISO country code. |
data.customer.billToPhone | No | The billing phone number. |
data.customer.shipToAddressOne | No | The shipping address, if different from the billing address. |
data.customer.shipToAddressTwo | No | Additional shipping address information, if required. |
data.customer.shipToCity | No | The shipping city. |
data.customer.shipToState | No | The shipping state or province. (If in the US, this must be the two-character state abbreviation). |
data.customer.shipToPostal | No | The shipping postal code. |
data.customer.shipToCountry | No | The two-character (Alpha-2) ISO shipping country code. |
data.customer.shipToPhone | No | The shipping phone number. |
data.description | No | A description of the transaction. |
data.paymentMethod | No | The identifier for the alternative payment method. Use this parameter when you want to only return the PayPal (with Braintree) iframe button URL (rather than data for all payment methods associated with the account). The value to use is braintreePayPal . |
isAuthOnly | No | Set to true to run an auth only transaction. |
processingOptions.merchantId | No | The Nexio merchant ID (MID). |
processingOptions.paymentOptionTag | No | A custom value used to route transactions to a specific gateway or merchant account. |
uiOptions.displaySubmitButton | No | Set to true to include a submit button in the iframe. |
uiOptions.css | No | The URL where your custom CSS file is hosted. |
Example requests
The following are example one-time-use token requests for PayPal (with Braintree).
curl -X POST https://api.nexiopaysandbox.com/apm/v3/token \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Basic [Base64_encoded_login]'
-d '{
"data": {
"amount": 4.00,
"currency": "USD",
"paymentMethod": "braintreePayPal",
"customer": {
"orderNumber": "12345678",
"firstName": "John",
"lastName": "Doe",
"email": "[email protected]"
}
}
}'
curl -X POST https://api.nexiopaysandbox.com/apm/v3/token \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Basic [Base64_encoded_login]'
-d '{
"data": {
"amount": 4.00,
"currency": "USD",
"paymentMethod": "braintreePayPal",
"customer": {
"orderNumber": "12345678"
}
},
"processingOptions": {
"doNotProcessPayment": true
}
}'
curl -X POST https://api.nexiopaysandbox.com/apm/v3/token \
-H 'Content-Type: application/json' \
-H 'Accept: application/json' \
-H 'Authorization: Basic [Base64_encoded_login]'
-d '{
"data": {
"amount": 4.00,
"currency": "USD",
"paymentMethod": "braintreePayPal",
"customer": {
"orderNumber": "12345678",
"customerRef": "RP006",
"firstName": "John",
"lastName": "Doe",
"email": "[email protected]"
}
},
"processingOptions": {
"saveRecurringToken": true
}
}'
{
"expiration": "2018-09-18T15:43:05.664Z",
"token": "830d36f6-a5e3-4455-9600-3a55b63e2fc2",
"asyncTraceId": "830d36f6-a5e3-4455-9600-3a55b63e2fc2",
"expressIFrameUrl": "https://www.api.nexiopaysandbox.com/v3?token=830d36f6-a5e3-4455-9600-3a55b63e2fc2",
"redirectUrls": [],
"buttonIFrameUrls": [
{
"paymentMethod": "braintreePayPal",
"url": "https://api.nexiopaysandbox.com/apm/v3?token=830d36f6-a5e3-4455-9600-3a55b63e2fc2&paymentMethod=braintreePayPal"
},
{
"paymentMethod": "applePayCyberSource",
"url": "https://api.nexiopaysandbox.com/apm/v3?token=830d36f6-a5e3-4455-9600-3a55b63e2fc2&paymentMethod=applePayCyberSource"
},
{
"paymentMethod": "nihaoPayWechatPay",
"url": "https://api.nexiopaysandbox.com/apm/v3?token=830d36f6-a5e3-4455-9600-3a55b63e2fc2&paymentMethod=nihaoPayWechatPay"
}
]
}
For the individual iframe option: You use the buttonIFrameUrls.url
of the braintreePayPal
APM for the transaction.
For the multi iframe integration method: Not supported for this payment method.
For the custom redirect option: Not supported for this payment method.
Transaction types and integration methods
Regardless of the integration method workflow you implement, consumers are redirected to PayPal (with Braintree) to complete their transactions.
Nexio supports the following transaction types for PayPal (with Braintree):
- Auth Only
- Merchant-initiated (recurring)
- Sale
- In an individual iframe that may look like one of the following:
- In an individual iframe that may look like one of the following:
- Void
- Capture
- Refund
PayPal (with Braintree) also supports Pay Later messaging. For details, see the Pay Later messaging topic.
PayPal (with Braintree) payment flow
The following show the general flows for a customer accessing a merchant site through payment using PayPal with Braintree, either from the cart (Continue button flow) or the checkout page (Checkout page flow).
Continue button flow
The "Continue button" flow provides a way for merchants to increase checkout conversion by moving the payment step to the shopping cart instead of just at checkout.
Customer adds item to shopping cart and clicks PayPal button to pay
-
The customer adds one or more items to a shopping cart.
-
The customer goes to that cart and the order amount displays, along with a Pay with PayPal button.
-
If the customer clicks that button, they are asked to log in to PayPal and to select their payment options and address information.
-
After making those selections, the customer clicks an Agree & Continue button.
-
The customer is redirected to a Confirm/Place Order page. Based on the address selected, they see tax and shipping costs for this order and are asked to confirm payment.
-
The customer is redirected to a Receipt page.
Customer adds item to cart and clicks Checkout button
-
The customer adds one or more items to a shopping cart.
-
The customer goes to that cart and the order amount displays, along with a Pay with PayPal button.
-
Customer instead clicks the Checkout button and is redirected to a Checkout page with all available payment options (potentially including PayPal). Customer address information is collected (or retrieved) and is used to generate tax and shipping costs.
-
If the customer clicks the PayPal button here, they are asked to log in to PayPal and to select their payment options.
If the customer clicks a different APM button, the process for that specific APM continues through to confirming the payment options.
If the customer submits payment for card or ACH, the process continues based on the entered payment options.
-
The customer is redirected to a Receipt page.
Checkout page flow
The "Checkout page" flow is the traditional payment flow for payment methods, where the options for payment are all presented on the Checkout page for the customer to choose from.
Customer adds item to cart and clicks Checkout button
-
The customer adds one or more items to a shopping cart.
-
The customer goes to that cart, the order amount displays, along with a Checkout button.
-
Customer clicks the Checkout button and is redirected to a Checkout page with all available payment options (potentially including PayPal (with Braintree)). Customer address information is collected (or retrieved) and is used to generate tax and shipping costs.
-
If the customer clicks the PayPal (with Braintree) button, they are asked to log in to PayPal and to select their payment options.
If the customer clicks a different APM button, the process for that specific APM continues through to confirming the payment options.
If the customer submits payment for card or ACH, the process continues based on the entered payment options.
-
The customer is redirected to a Receipt page.
Merchant-initiated transactions for PayPal (with Braintree)
You may want to support merchant-initiated transactions through PayPal (with Braintree) for your customers, such as for recurring transactions.
For a tutorial about how to implement this, see the Run a merchant-initiated recurring transaction topic.
Testing data
For testing information and data, see Testing in the PayPal Braintree Developer Documentation.
Response handling
In the one-time-use token request, PayPal (with Braintree) gets returned in the paymentMethod
parameter as braintreePayPal
.
When implementing merchant-initiated recurring transactions, you need to save the apm.token
parameter from the response. For more information, see Run a merchant-initiated recurring transaction.
Nexio responds with transaction results in event messages.
For information about how to run each of the integration workflows, see Transaction types and integration methods above.
Webhooks
In addition to one of the above, if your merchant account is configured to receive webhooks, Nexio provides responses to the webhook URLs that have been registered. For additional information about webhooks, see the Webhooks topic.
The response you get depends on the type of webhooks you have configured.
New webhooks
For PayPal (with Braintree), the new webhook eventType
will always be TRANSACTION
with a processMethod
value of 20
(for APMs).
Those TRANSACTION webhooks will also contain a numerical value for transactionStatus
whenever that status changes. For specific information about the status values, see the Transaction status reference tables in the "Constant transaction values" topic. You can also reference the "Status workflows" table below.
For information about what information gets received in a webhook and how to use it, see the Receiving webhooks topic.
Legacy webhooks
For PayPal (with Braintree), these are the possible legacy webhook event types:
- TRANSACTION_AUTHORIZED
- TRANSACTION_CAPTURED
- TRANSACTION_REFUNDED
- TRANSACTION_SETTLED
- TRANSACTION_VOIDED
For further explanation of the webhook event types, see the legacy webhook Event types table.
Status workflows
The status of a successful transaction with PayPal (with Braintree) varies, depending on the options you choose.
Sale | When isAuthOnly is false , successful sale transactions have the following statuses:
|
Auth only | When isAuthOnly is true , successful sale transactions have the following statuses:
|
Capture | Successful capture transactions have the following status:
|
Void | Successful void transactions have the following status:
|
Refund | Successful refund transactions have the following status:
|
* Pending status displays as "authorized" or "AUTHORIZED" in the Nexio Dashboard; it displays as 10
, meaning "authorized", in the response when querying transactions (for more information about transactionStatus
, see the table).
Next steps
Now, you are ready to get started with running transactions:
If you have any additional questions or feedback, see Contact us.
Updated 3 months ago