Skip to main content

Direct Integration with Apple Pay API

This guide explains how to integrate directly with the Apple Pay API using decrypted card tokens.

Step 1: Configure Your Apple Pay Environment

  1. Set up your Apple Merchant ID in your Apple Developer account. Follow instructions presented on the Apple Developer's documentation.
  2. Register your web domain with Apple and verify it.

Step 2: Integrate Apple Payment Request API

  1. Integrate Apple Payment Request API by following Apple's Payment Request API documentation.
  2. Add Apple Pay buttons to your website following Apple's Display Pay Button documentation.
  3. Create a PaymentRequest object with the required parameters following Apple's guide. Here is an example configuration:
const applePayMethod = {
supportedMethods: "https://apple.com/apple-pay",
data: {
version: 3,
merchantIdentifier: "merchant.com.example",
merchantCapabilities: ["supports3DS", "supportsCredit", "supportsDebit"],
supportedNetworks: ["masterCard", "visa"],
countryCode: "GB",
},
};
Don't Forget to Replace

Replace merchant.com.example with your Apple Merchant ID configured in Step 1.

Step 3: Acquire a Payment Session

Perform merchant validation to acquire a payment session from Apple.

Back-End Server

This step must be executed on your back-end server for security reasons, unlike the other steps, which are front-end-based.

Step 4: Handle Payment Authorisation

Handle the authorisation response returned by Apple Pay, ensuring proper validation of the payment data.

Step 5: Obtain Payment Response

Retrieve the PaymentResponse and the associated ApplePayPayment dictionary, which contains the tokenised payment data.

Step 6: Extract Token

Extract the payment token from the ApplePayPayment dictionary for decryption.

Step 7: Decrypt Payment Data

Decrypt the paymentData field from the payment token to retrieve card details. The decrypted data should be in the following format:

{
"applicationPrimaryAccountNumber": "",
"applicationExpirationDate": "",
"currencyCode": "",
"transactionAmount": ,
"deviceManufacturerIdentifier": "",
"paymentDataType": "",
"paymentData": {
"onlinePaymentCryptogram": ""
}
}

Step 8: Send Parameters to Fondy Gateway API

Using the decrypted data, construct a payment request to the Enroll Card in 3DSecure Service endpoint with the following mapping:

applicationPrimaryAccountNumbercard_number

applicationExpirationDateexpiry_date

onlinePaymentCryptogramcavv

Add wallet = applepay to indicate the payment method.

Below, you can find an example of how that request should be formatted:

{
"request": {
"order_id": "Order_id123",
"merchant_id": 1549901,
"order_desc": "Apple Pay Payment with card token",
"amount": 1000,
"currency": "GBP",
"client_ip": "2.2.2.2",
"server_callback_url": "https://server.com/callback",
"preauth": "Y",
"version": "1.0.1",
"card_number": "4444555566661111",
"expiry_date": "0527",
"cavv": "AEBBjhMvE4xRAg97n9DpAoABFA==",
"wallet": "applepay"
"signature": "64d565cdf9bfb2ad556eac54bd57706e5dc6c412",
}
}

By following these steps, you can directly integrate with the Apple Pay API and process payments securely using decrypted card tokens.