You have to be an approved partner to integrate the Apple Pay SDK
Apple Pay works on Safari browsers and the following versions of iOS devices:
- macOS 10.14.1 and later.
- iOS 12.1 and later.
- Supported devices and where you can use them
Last updated: May 20th, 8:11am
Apple Pay is a mobile payment and digital wallet service provided by Apple Inc.
Buyers can use Apple Pay on PayPal to make payments on the web using the Safari web browser or an iOS device.
Sellers can use Apple Pay on PayPal to sell:
Visit this site for more information about Apple Pay.
Apple Pay supports payments in 36 countries and 22 currencies:
AUD
, BRL
, CAD
, CHF
, CZK
, DKK
, EUR
, GBP
, HKD
, HUF
, ILS
, JPY
, MXN
, NOK
, NZD
, PHP
, PLN
, SEK
, SGD
, THB
, TWD
, USD
The Apple Pay button shows up on your website when a customer uses the Safari web browser on an eligible device. When your buyer selects the Apple Pay button, they confirm purchase details and authorize the payment on a payment sheet.
Visit this site for more details about Apple Pay's compatibility.
Watch our video tutorial for this integration:
You have to be an approved partner to integrate the Apple Pay SDK
Apple Pay works on Safari browsers and the following versions of iOS devices:
Currently supports Apple Pay one-time payments with the payer present.
Review Apple's terms and conditions for the Apple Pay platform. See Apple's developer terms for more information.
Before you can accept Apple Pay on your website, verify that your sandbox business account supports Apple Pay.
Partners can use the PayPal Developer Dashboard to set up their sandbox accounts to accept Apple Pay. The integration for partner accounts includes creating a sandbox business account through sandbox.paypal.com. If the Apple Pay status for the account shows as disabled, complete the sandbox onboarding steps to enable Apple Pay.
If you created a sandbox business account through sandbox.paypal.com, and the Apple Pay status for the account shows as disabled, complete the sandbox onboarding steps to enable Apple Pay.
Tip: When your integration is ready to go live, read the Go live section for details about the additional steps needed for Apple Pay onboarding.
Before you develop your Apple Pay on the web integration, you need to set up your PayPal account, client ID, and sandbox emails for testing.
Important: You need to verify any domain names that you want to show an Apple Pay button. Apple rejects payments from unverified domains. The Apple Pay payment method won't work if the domain isn't registered.
/.well-known/apple-developer-merchantid-domain-association.
https://api-m.sandbox.paypal.com/v1/oauth2/token
. Note the
access token from the response body.
merchant_payer_id
with the merchant ID for which you
are registering the domain.
https://api-m.sandbox.paypal.com/v1/customer/wallet-domains
.paypal-auth-assertion
header with the
value your_generated_auth_assertion
.
"provider_type": "APPLE_PAY"
to indicate that this is an
`APPLE_PAY` domain registration.
"domain": {"name": "example.com" }
, and replace
"example.com" with the domain you would like to register.
Example JSON request:
1// Register a domain2{3 "provider_type":"APPLE_PAY",4 "domain": {5 "name":"example.com"6 }7}
201 CREATED
response with the merchant and
domain registration details if this is successful.
https://api-m.sandbox.paypal.com/v1/oauth2/token
. Note the
access token from the response body.
merchant_payer_id
with the merchant ID for which you
are deregistering the domain.
https://api-m.sandbox.paypal.com/v1/customer/unregister-wallet-domain
.paypal-auth-assertion
header with the
value your_generated_auth_assertion
.
"provider_type": "APPLE_PAY"
to indicate that this is an
`APPLE_PAY` domain deregistration
"domain": { "name": "example.com" }
, and replace
"example.com" with the domain you would like to deregister.
"reason": "Why you are deregistering this domain"
to
indicate the reason for deregistration.
Example JSON request:
1// Deregister a domain2{3 "provider_type":"APPLE_PAY",4 "domain": {5 "name":"example.com"6 },7 "reason":"Merchant requested to deregister domain",8}
200 OK
response with the merchant and domain
deregistration details if this is successful.
https://api-m.sandbox.paypal.com/v1/oauth2/token
. Note the
access token from the response body.
merchant_payer_id
with the merchant ID that you are
registering the domain for.
https://api-m.sandbox.paypal.com/v1/customer/wallet-domains
.
Bearer: <your_access_token>
.
paypal-auth-assertion
header with the
value your_generated_auth_assertion
to indicate the
merchant for which you are getting the domain.
200 OK
response with the registered domains
under the wallet_domains
field if this is successful.
Create an Apple Pay sandbox account on the Apple Developer website to get a test wallet and test cards to test your Apple Pay integration.
If you already have an Apple sandbox account, you can use that account.
Follow this integration process to add Apple Pay as a checkout option, customize the payment experience, and process payments.
Important: You can find a complete example in the GitHub repo.
To accept Apple Pay directly on your website, create API endpoints on your server that communicate with the PayPal Orders V2 API. These endpoints can create an order, authorize payment, and capture payment for an order.
The following example uses the PayPal Orders V2 API to add routes to an Express server for creating orders and capturing payments. Find the complete sample code in the GitHub repo.
1import * as PayPal from "./paypal-api.js";23// Create order4app.post("/api/orders", async (req, res) => {5 const order = await paypal.createOrder();6 res.json(order);7});89// Capture payment10app.post("/api/orders/:orderID/capture", async (req, res) => {11 const {12 orderID13 } = req.params;14 const captureData = await paypal.capturePayment(orderID);15 res.json(captureData);16});
Tip: When testing, you need to be logged into the iCloud account for your testing environment. Testing in the sandbox requires you to log into an iTunes Connect sandbox tester account, which you can create with an Apple Developer account. When you test in a live environment, log into a live iCloud account.
Check for device and merchant eligibility before setting up the Apple Pay button.
To check eligibility, use the PayPal JavaScript SDK API paypal.Applepay().config()
.
1<div id="applepay-container"></div>
1if (!window.ApplePaySession) {2 console.error('This device does not support Apple Pay');3}456if (!ApplePaySession.canMakePayments()) {7 console.error('This device is not capable of making Apple Pay payments');8}91011const applepay = paypal.Applepay();121314applepay.config()15 .then(applepayConfig => {16 if (applepayConfig.isEligible) {17 document.getElementById("applepay-container").innerHTML = '<apple-pay-button id="btn-appl" buttonstyle="black" type="buy" locale="en">';18 }19 })20 .catch(applepayConfigError => {21 console.error('Error while fetching Apple Pay configuration.');22 });
You can find more details on how to set up the Apple Pay button in Apple's developer documentation.
Create an Apple Pay sandbox account on the Apple Developer website to get a test wallet and test cards to test your Apple Pay integration.
If you already have an Apple sandbox account, you can use that account.
After you have created the Apple Pay session and added the callbacks, call the session's begin method to show the payment sheet. You can only call the begin
method when a payer explicitly requests a payment, such as inside an onclick
event. The begin
method throws a JavaScript exception if the buyer doesn't explicitly request the action:
1session.begin();
After the payer starts a payment in the browser, they use their Apple device to authorize the payment.
Customize payment using the Apple Pay JavaScript SDK.
The commonly used customizations for Apple Pay are:
Customization | Apple Pay SDK Details |
---|---|
A set of line items that explain the subtotal, tax, discount, and additional charges for the payment. | lineItems |
The billing information fields that the payer must provide to fulfill the order. | requiredBillingContactFields |
The shipping information fields that the payer must provide to fulfill the order. | requiredShippingContactFields |
The payer's billing contact information. | billingContact |
The payer's shipping contact information. |
Call the |
The shipping method for a payment request. |
ApplePayShippingMethod Call the onshippingmethodselected event handler when the user selects a shipping method in the payment sheet. |
Ensure your integration with Apple Pay is configured properly for sandbox and production environments.
Use your personal sandbox login information during checkout to complete a payment using Apple Pay. Then, log into the sandbox site sandbox.paypal.com to see that the money has moved into your account.
Make Apple Pay available to buyers using your website or app.
Important: Before going live, complete production onboarding to process Apple Pay payments with your live PayPal account.
Live environment
If you are a new partner setting up a marketplace or platform for individual sellers, contact us to become an approved partner. Then, see Get Started and Configure your account to sign up for a PayPal business account.
Use your personal production login information during checkout to complete an Apple Pay transaction. Log into paypal.com to see the money move out of your account.
Getting started in your live environment
You need to verify any domain names in your production environment that will show an Apple Pay button. If Apple hasn't verified a domain, they will reject any payments from that domain.
Important: The Apple Pay payment method won't work if the domain isn't registered. There is no option to override this.
/.well-known/apple-developer-merchantid-domain-association
.Important: The partner that owns the domain is responsible for registering that domain.
https://api.paypal.com/v1/oauth2/token
. Note the access token from the response body.merchant_payer_id
with the Merchant ID for which you are registering the domain.https://api-m.paypal.com/v1/customer/wallet-domains
.paypal-auth-assertion
header with the value your_generated_auth_assertion
."provider_type": "APPLE_PAY"
to indicate that this is an `APPLE_PAY` domain registration."domain": { "name": "example.com" }
, and replace "example.com" with the domain you would like to register.Example JSON request:
1// Register a domain2{3 "provider_type":"APPLE_PAY",4 "domain":{5 "name":"example.com"6 }7}
201 CREATED
response with the merchant and domain registration details if this is successful.Note: When Apple verifies a domain, it makes a request to retrieve the domain verification file. Ensure that:
3XX
status code. Apple does not support HTTP URL redirects for the domain association file.Content-Type: application/octet-stream
to indicate that this is a binary file download.https://api.paypal.com/v1/oauth2/token
. Note the access token from the response body.merchant_payer_id
with the merchant ID for which you are deregistering the domain.https://api-m.paypal.com/v1/customer/unregister-wallet-domain
.paypal-auth-assertion
header with the value your_generated_auth_assertion
."provider_type": "APPLE_PAY"
to indicate that this is an `APPLE_PAY` domain deregistration"domain": { "name": "example.com" }
, and replace "example.com" with the domain you would like to deregister."reason": "Why you are deregistering this domain"
to indicate the reason for deregistration.Example JSON request:
1// Deregister a domain2{3 "provider_type":"APPLE_PAY",4 "domain":{5 "name":"example.com"6 },7 "reason":"Merchant requested to deregister domain",8}
200 OK
response with the merchant and domain deregistration details if this is successful.https://api.paypal.com/v1/oauth2/token
. Note the access token from the response body.merchant_payer_id
with the merchant ID that you are registering the domain for.https://api.paypal.com/v1/customer/wallet-domains
.
Bearer: <your_access_token>
.paypal-auth-assertion
header with the value your_generated_auth_assertion
to indicate the merchant for which you are getting the domain.200 OK
response with the registered domains under the wallet_domains
field if this is successful.When testing a purchase in production, consider:
How to test Apple Pay payments in a live environment
Make sure that there are no browser console warnings or errors. The JavaScript SDK configuration attributes have distinct validation checks for input formatting and values.
If the validation fails, the web browser's developer console shows warning messages that say which property is incorrect and what you need to do to address the issue. The library generally attempts to revert to the safe default values if missing or incorrect inputs exist.
Get started testing, add security to your checkout experience, or create customizations for your audience.