Payment-method icon

PayPal Drop-in integration

Add PayPal to an existing Drop-in integration.

This page explains how to add PayPal to your existing Web Drop-in integration.

The PayPal Smart Payment Buttons are available from Drop-in

v 3.7.0
and later.

Requirements

Requirement Description
Integration type Make sure that you have built your Drop-in integration.
Setup steps Before you begin, complete the PayPal setup steps.

API reference

Select which endpoint you are using:

This is the default with Drop-in v5.0.0 or later.

Parameter name Required Description
lineItems Price and product information about the purchased items. For each item, you only need to send quantity, description, itemCategory, sku, amountExcludingTax, and taxAmount.
The allowed values for itemCategory are:
  • DIGITAL_GOODS: goods that are stored, delivered, and used in electronic format.
  • PHYSICAL_GOODS: tangible goods that can be shipped with proof of delivery.
  • DONATION: a contribution or gift for which no goods or services are exchanged, usually to a not-for-profit organization.
additionalData.paypalPairingId Only for customer-initiated transactions where you use the Fraudnet SDK and pass the same pairing ID to Fraudnet and Adyen.
A unique ID determined by you, to link a transaction to a Fraudnet PayPal risk session.
PayPal refers to this ID as pairing ID, CMID, or tracking ID.
additionalData.paypalRisk Only for marketplaces and for merchants in specific verticals.
A stringified additional_data array with the PayPal risk fields that PayPal told you to send. Each array item consists of:
  • key: the name of the PayPal risk field.
  • value: the value of the PayPal risk field for the current transaction.
Contact your PayPal account manager to learn which paypalRisk fields apply in your case and what happens if you do not populate a specific field. For a list of example fields, refer to the common risk fields for marketplaces.

The following example shows a payment request with the lineItems fields you can use for PayPal, and a few paypalRisk keys and values in additionalData.

Expand view
Copy link to code block
Copy code
Copy code
curl https://checkout-test.adyen.com/v70/sessions \
-H 'x-API-key: ADYEN_API_KEY' \
-H 'content-type: application/json' \
-d '{
"merchantAccount":"ADYEN_MERCHANT_ACCOUNT",
"amount":{
"currency":"USD",
"value":1000
},
"shopperReference":"YOUR_UNIQUE_SHOPPER_ID",
"reference":"YOUR_ORDER_NUMBER",
"returnUrl":"https://your-company.com/checkout?shopperOrder=12xy..",
"lineItems":[
{
"quantity":"1",
"description":"Red Shoes",
"itemCategory":"PHYSICAL_GOODS",
"sku":"ABC123",
"amountExcludingTax":"590",
"taxAmount":"10"
},
{
"quantity":"3",
"description":"Polkadot Socks",
"itemCategory":"PHYSICAL_GOODS",
"sku":"DEF234",
"amountExcludingTax":"90",
"taxAmount":"10"
}
],
"additionalData": {
"paypalRisk": "STATE_DATA"
}
}'

Amounts in Hungarian Forints (HUF)

In case of a transaction in HUF, PayPal expects the transaction amount and the line item amounts to be rounded to the nearest whole amount. For example, an amount of HUF 74499 must be rounded to HUF 74500. PayPal also expects the rounded line item amounts to add up to the rounded transaction amount.

If you do not round the amounts, Adyen will do that. However, a discrepancy can occur between the transaction amount and the total of the line item amounts. When this happens, PayPal doesn't accept the transaction. To avoid that problem, we recommend that you round all HUF amounts yourself and check that they add up.

PayPal risk fields

PayPal requires marketplaces and also merchants in specific verticals to send information about the context of the transaction, for risk mitigation purposes.

Not all businesses need to send risk fields. Contact your PayPal account manager to verify.

Common PayPal risk fields for marketplaces

As an example, the following table shows the most common paypalRisk fields that marketplaces need to send. It is possible that PayPal requires you to send more, less, or other fields.

PayPal risk field Description Data type/format Example
Sender profile fields:
sender_account_id The unique identifier of the buyer's account on the marketplace platform. String, alphanumeric A12345N343
sender_first_name The buyer's first name registered with their marketplace account. String, alphanumeric John
sender_last_name The buyer's last name registered with their marketplace account. String, alphanumeric Smith
sender_email The buyer's email address registered with their marketplace account. String in E.123 email address format john.smith@email.com
sender_phone The buyer's phone number registered with their marketplace account. String in E.123 telephone number format, national notation 0687164125
sender_address_zip US only. The buyer's postal code registered with their marketplace account. String, alphanumeric 60661
sender_country_code The buyer's country registered with their marketplace account. String in two-character ISO-3166-1 alpha-2 country code format. Exception: QZ (Kosovo). US
sender_create_date The date that the buyer's marketplace account was created. String in ISO 8601 date format 2012-12-09T19:14:55.277-0:00
sender_signup_ip The IP address that the buyer used when signing up on the marketplace platform. String in IPv4 or IPv6 format 213.52.172.120
sender_popularity_score If you need to provide this field, ask your PayPal account manager for instructions. String, possible values: high, medium, low high
Receiver profile fields:
receiver_account_id The unique identifier of the seller's account on the marketplace platform. String, alphanumeric AH00000000000000000000001
receiver_create_date The date that the seller's marketplace account was created. String in ISO 8601 date format 2012-12-09T19:14:55.277-0:00
receiver_email The seller's email address registered with their marketplace account. String in E.123 email address format john.smith@email.com
receiver_address_country_code The seller's country registered with their marketplace account. String in two-character ISO-3166-1 alpha-2 country code format. Exception: QZ (Kosovo). US
business_name The seller's business name registered with their marketplace account. String, alphanumeric
recipient_popularity_score If you need to provide this field, ask your PayPal account manager for instructions. String, possible values: high, medium, low high
Sender-Receiver interaction:
first_interaction_date The date of the first interaction between the buyer and the seller. The marketplace defines what an interaction is. For example, a payment transaction, a buyer choosing to follow a seller, and so on. String in ISO 8601 date format 2012-12-09T19:14:55.277-0:00
Transaction information:
txn_count_total The total number of transactions that the buyer has made on the platform. These can be PayPal payments, or payments using a different payment method. Number
Payment Flow/Model/Type:
vertical If the seller is active in more than one business vertical, this field indicates the vertical that applies to the transaction. String, alphanumeric Household goods
transaction_is_tangible Indicates if the transaction is for tangible goods. Boolean in string format. Possible values: 0 (false), or 1 (true) 0

Drop-in configuration

Required configuration

Select which endpoint you are using:

This is the default with Drop-in v5.0.0 or later.

There is no additional configuration you need to include for PayPal.

Optional configuration

When creating an instance of Drop-in, you can also:

Content Security Policy (CSP) nonce

You can include a cspNonce to add a CSP nonce if you use this on your site. This was added in v5.2.0.

Layout

You can configure the layout of the PayPal Smart Payment Buttons. To do that, configure the style element in the PayPal payment method configuration. Use the available style options.

Shipping changes

You can use PayPal's callback method onShippingChange to listen to shipping address changes and validate that you support the shipping address.

Validate user input

You can validate user input with the following parameters:

  • onInit: Called when the button renders.
  • onClick: Called when one of the PayPal buttons is clicked.

Disable PayPal Credit

You can use blockPayPalCreditButton to control rendering the PayPal Credit button. Set this parameter to true if you do not want the PayPal Credit button to be rendered. The default value is false.

Add PayPal Pay Later messages and buttons

PayPal Pay Later is supported in the following countries/regions: AU, FR, DE, IT, ES, UK, US, with local currencies. Certain limitations apply to cross-border payments, when a shopper pays in a country/region other than where you are registered.

To present this option:

  1. Set enableMessages to true, to enable Pay Later messaging on your website.
  2. Render Pay Later messages and buttons by adding code to your page as described in PayPal's instructions.

Disable PayPal Pay Later

You can use blockPayPalPayLaterButton to control rendering the PayPal PayLater button. Set this parameter to true if you do not want the PayPal PayLater button to be rendered. The default value is false.

Example

Copy code
const paypalConfiguration = {
style: { // Optional configuration for PayPal payment buttons.
layout: "vertical",
color: "blue"
},
cspNonce: "MY_CSP_NONCE",
onShippingChange: function(data, actions) {
// Listen to shipping changes.
},
onInit: (data, actions) => {
// onInit is called when the button first renders.
// Call actions.enable() to enable the button.
actions.enable();
// Or actions.disable() to disable it.
},
onClick: () => {
// onClick is called when the button is clicked.
},
blockPayPalCreditButton: true,
blockPayPalPayLaterButton: true
};

Set the intent for individual payments

From v5.34.0 onwards, you can use intent to determine when the funds are captured and whether the payment details are tokenized:

  • capture: authorizes and capture immediately.
  • authorize: authorizes immediately and captures later.
  • subscription: specifies this is a subscription payment.
  • tokenize: specifies this is a billing payment.

Example

Copy code
const paypalConfiguration = {
intent: "authorize"
};

Hide Venmo

If you and your shopper are both located in the US, Venmo is shown in the PayPal Component by default. To hide Venmo in the PayPal Component, set blockPayPalVenmoButton to true.

Get the payment outcome

You can use the resultCode from the API response to show the shopper the current payment status. The resultCode values you can receive for PayPal are:

resultCode Description Action to take
Authorised The payment was successful. Inform the shopper that the payment was successful.
Note that the transaction may still fail, for example due to risk rules that are applied after authorisation. Wait for the AUTHORISATION webhook to learn the final outcome.
Pending or
Received
The shopper has completed the payment but the final result is not yet known. Inform the shopper that you received their order, and are waiting for the payment to be completed.
Wait for the AUTHORISATION webhook to learn the final outcome.
Error There was an error when the payment was being processed. Inform the shopper that there was an error processing their payment.
Wait for the AUTHORISATION webhook. This will contain a refusalReason that indicates the cause of the error.
Refused The payment was refused by the shopper's bank. Ask the shopper to try the payment again using a different payment method.
Cancelled The shopper canceled the PayPal payment. Ask the shopper to select a different payment method.

However, the synchronous API response doesn't give you the final outcome. To learn the final status of a payment and determine how to proceed with the order, you should wait for webhooks. This is especially important if you use any standard risk rules or custom risk rules that trigger after authorisation.

The webhooks you can receive for PayPal are:

eventCode success field Description Action to take
AUTHORISATION false The transaction failed. Cancel the order and inform the shopper that the payment failed.
AUTHORISATION true The shopper successfully completed the payment. Inform the shopper that the payment has been successful and proceed with the order.
OFFER_CLOSED true The shopper did not complete the payment. Cancel the order and inform the shopper that the payment timed out.
Note that you only receive this information if you enable the OFFER_CLOSED event code.

Include more information in webhooks

For PayPal, we recommend adding the following information to your standard webhooks:

  • OFFER_CLOSED event code: informs you if the shopper failed to complete the payment. To enable receiving this event code, follow the instructions for non-default event codes.

  • PayPal specific details. When enabled, your standard webhooks return the following details as additionalData:

    • paypalEmail: the email address of the shopper's PayPal account.
    • paypalPayerId: the shopper's PayPal Payer ID.
    • paypalPayerStatus: indicates if the shopper's account has been verified by PayPal.
    • paypalAddressStatus: indicates if the shopper's address has been confirmed by PayPal.
    • paypalProtectionEligibility: indicates if the payment is eligible for PayPal Seller Protection.
    • paypalPayerResidenceCountry: the shopper's country or region of residence.

    To enable receiving these details, follow the instructions for additional settings, making sure to select Include PayPal Details.

Recurring payments

PayPal supports tokenization for recurring payments.

We strongly recommend that you ask explicit permission from the shopper if you intend to make future recurring payments. Being transparent about the payment schedule and the charged amount reduces the risk of chargebacks.

Prepare for tokenization

  1. Note the PayPal setup requirements:

    • If you are not a marketplace and do not have a so-called indirect settlement arrangement, Vault (recurring) permissions must be enabled in your PayPal setup. If you completed the setup without enabling recurring transactions, restart the setup flow and this time select the relevant option.
    • If you are a marketplace or have an indirect settlement arrangement, inform our Support Team that you want to make recurring PayPal payments. They will then take care of the correct setup.
  2. To be able to create tokens through initial zero-value authorization requests:

    • If you use the /sessions endpoint, make sure you are on v5.3.0 or later.
    • If you use the /payments endpoint, update your configuration as described in the next step.
  3. If you want to use the /payments endpoint for creating a token through an initial zero-value authorization request, update your Drop-in configuration in one of the following ways:

    • Add intent: "tokenize" to the PayPal configuration object. This requires v5.34.0 or later.
    • Add the amount object to the global Drop-in configuration. This requires v5.3.0 or later.

    Skip this step if you are not going to create tokens through zero-value authorization requests to the /payments endpoint.

    PayPal configuration object with the tokenize intent
    Expand view
    Copy link to code block
    Copy code
    Copy code
    const paypalConfiguration = {
    // ... other optional configuration
    intent: "tokenize"
    };

    No token is created if you send a zero-value authorization request to the /payments endpoint without having updated the configuration as described above.

Create and use tokens

When the preparation is completed, creating and using tokens for PayPal payments is the same as described for tokenization in general, except for the following:

  1. To create a token through a zero-value authorization request, in your initial /sessions or /payments payment request include:

    Parameter Description
    shopperEmail The shopper's email address. Required when making a zero-value authorization request. Do not include this parameter if the request is not for a zero-value authorization.
    amount.value Set to 0 when making a zero-value authorization request.
  2. Proceed as described for tokenization in general: get the shopper reference and the token from the RECURRING_CONTRACT webhook, and use this data in future payments for the shopper.

For instructions, see:

Refunds

If you have not captured a PayPal payment, you can cancel it. If you have captured the payment and you want to return the funds to the shopper, you need to refund it.

For partial refunds, the instructions differ depending on your capture settings:

Partial refund when payments are captured immediately

If you are using the default setup where PayPal payments are captured immediately after authorization, partially refund a PayPal payment as follows:

  1. In your /payments/{paymentPspReference}/refunds request, specify:

    Parameter Required Description
    amount -white_check_mark- The amount that is refunded to the shopper.
    lineItems Price and product information for the items that the shopper should pay for. The sum of the lineItems must match the amount. If they do not match, Adyen will add a dummy lineItem entry to account for the difference.

    Only specify the items that you are refunding the money for.

    The following example shows how to make a partial refund for item #1 of the above order.

    Example /refunds request for partial refund
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://checkout-test.adyen.com/v65/payments/TCG5XS42X8NKGK82/refunds \
    -H 'x-api-key: ADYEN_API_KEY' \
    -H 'content-type: application/json' \
    -d '{
    "reference": "YOUR_UNIQUE_REFERENCE",
    "amount": {
    "value": 1200,
    "currency": "EUR"
    },
    "merchantAccount": "YOUR_MERCHANT_ACCOUNT",
    "lineItems": [
    {
    "quantity": "1",
    "taxPercentage": "2000",
    "description": "Polo shirt",
    "id": "Item #1",
    "itemCategory": "Shirts",
    "amountIncludingTax": "1200",
    "taxAmount": "200",
    "amountExcludingTax": "1000",
    "productUrl": "https://www.mystoredemo.io#/product/01",
    "imageUrl": "https://www.mystoredemo.io/1689f3f40b292d1de2c6.png"
    }
    ]
    }
  2. Note that in the response, the pspReference is specifically for the refund transaction, not for the original payment.

    Example /refunds response
    Expand view
    Copy link to code block
    Copy code
    Copy code
    {
    "merchantAccount": "YOUR_MERCHANT_ACCOUNT",
    "pspReference": "IHG5XS4FGKVLGK82",
    "reference": "YOUR_UNIQUE_REFERENCE",
    "status": "received",
    "amount": {
    "currency": "EUR",
    "value": 1200
    },
    "lineItems": [
    {
    "quantity": "1",
    "taxPercentage": "2000",
    "description": "Polo shirt",
    "id": "Item #1",
    "itemCategory": "Shirts",
    "amountIncludingTax": "1200",
    "taxAmount": "200",
    "amountExcludingTax": "1000",
    "productUrl": "https://www.mystoredemo.io#/product/01",
    "imageUrl": "https://www.mystoredemo.io/1689f3f40b292d1de2c6.png"
    }
    ]
    }

Partial refund when payments are captured later

Your request for a partial refund must include a capturePspReference if all of the following is true:

  • You configured capturing payments later, instead of immediately after authorization.
  • Multiple partial captures are enabled for your account.
  • You are going to do more than one partial capture.

PayPal uses this unique capture reference to locate the transaction in their systems. Without it, the refund can fail.

To partially refund a PayPal payment if payments are captured later:

  1. Get the pspReference from the /payments/{paymentPspReference}/captures response for the payment that you want to partially refund. This is the reference to the capture that PayPal needs.

  2. In your /payments/{paymentPspReference}/refunds request, specify:

    Parameter Required Description
    capturePspReference The pspReference from the /payments/{paymentPspReference}/captures response. Do not use the paymentPspReference.
    Example /refunds request for partial refund when payments are captured later
    Expand view
    Copy link to code block
    Copy code
    Copy code
    curl https://checkout-test.adyen.com/v71/payments/TCG5XS42X8NKGK82/refunds \
    -H 'x-api-key: ADYEN_API_KEY' \
    -H 'content-type: application/json' \
    -d '{
    "merchantAccount": "YOUR_MERCHANT_ACCOUNT",
    "reference": "YOUR_UNIQUE_REFERENCE",
    "capturePspReference": "QSKF8GZ2KX998X72",
    "amount": {
    "value": 1200,
    "currency": "EUR"
    }
    }

Set up PayPal Seller Protection

PayPal Seller Protection only applies to physical goods.

If you participate in the PayPal Seller Protection program, make sure that you submit the following fields in your payment requests:

The details provided in these fields will populate the Ship to section of the PayPal checkout.

We recommend that you check that your setup is working correctly with a test payment. Make sure that you submit the correct fields, and that the test payment is marked as eligible for PayPal Seller Protection in the transaction details.

Test and go live

Test your integration

When you are done setting up your integration, use your PayPal sandbox accounts to test the PayPal payment flow. Your business sandbox account lets you simulate your role as a merchant when testing payments. With your personal sandbox account you can simulate the role of a customer.

Refer to the following resources:

  • For instructions to create sandbox accounts, see Set up PayPal.
  • For testing instructions, see the PayPal sandbox testing guide.
  • You can check the status of a PayPal test payment in your Customer Area > Transactions > Payments.

    Before you go live

    For live operations, you need to get a live PayPal business account and configure your live environment. See Set up PayPal.

    Note that in the live environment, PayPal will only be available if:

    • The shopper is logged in to their PayPal account.
    • The shopper has at least one valid payment method on their PayPal account.

    See also