Set up Apple Pay
This topic describes how to use FramePay to tokenize payments made using Apple Pay.
If you want to use Apple Pay inside an iOS application, contact us.
1. Obtain IDs and a publishable API key
When you first log in to Rebilly, you create an organization as part of the setup process. A default website is created when a new organization is created. For more information, see Organizations and websites.
- Log in or sign up to Rebilly.
- Obtain your organization ID and website ID:
- In the left navigation bar, press Settings .
- In the Management section, press My organization & websites.
- In the Organization details section, note the ID value.
- In the Website section, note the ID value.
- Obtain your publishable API key:
- In the left navigation bar, press Automations .
- In the Development section, press API keys.
- Optionally, if you have not created a publishable key:
- In top right of the screen, press Create API key.
- In the API key type section, select Publishable.
- Optionally, in the Organizations dropdown, select the organizations that can use the API key.
- Optionally, in the Allowed IPs field, enter the IP addresses that are permitted to use the API key.
- Press Save API key.
- Go to the API keys page.
- Select a publishable key and copy the Key value.
2. Set up Apple Pay
This step describes how to use FramePay to tokenize payments made using Apple Pay.
Initial set up
Set up the library and provide the HTML.
Include the FramePay stylesheet
This adds default styles to FramePay elements on the page.
Include the FramePay script
This exposes FramePay in the global JS scope as Framepay
.
Include the HTML mounting points
You must specify an empty HTML element where FramePay renders the Apple Pay button.
Edit your checkout form to add new HTML element with a unique ID.
Configure FramePay
This step describes the basic set up for mounting.
Rebilly data
Provide your publishable API key, organization ID, and website ID to connect with the Rebilly API.
Transaction data
Provide the transaction data. Apple Pay requires amount, currency, and label.
Get the payment token
Mount FramePay onto your page and listen for a payment token.
To pass Apple Pay authentication parameters, the initial transaction must be completed using the payment token, and not using a payment instrument.
After completing a transaction using the token, the payment instrument will be returned and can be re-used.
Apple Pay authentication parameters are not persisted to the payment instrument but the gateway will have reference of this initial customer-facing transaction.
Creating a payment instrument from the token and using that will only include the basic card data (device PAN, expiry).
For more information, see Payment instruction.
Mount the Apple Pay button
After initialization, mount the Apple Pay button in the container element.
Listen for the generated payment token
When a customer completes the Apple Pay flow, Rebilly creates a payment token.
To retrieve it, listen for the token-ready
event.
Basic set up complete
To learn more about Apple Pay and FramePay, see: - Apple Pay domain registration - Apple Pay testing - Configuration reference
- example.html
- client.js
1<!doctype HTML>2<HTML>3 <head>4 <link href="https://framepay.rebilly.com/framepay.css" rel="stylesheet">5 <script src="https://framepay.rebilly.com/framepay.js"></script>6 <script src="./client.js" defer></script>7 </head>8 <body>9 <form>10 <div id="apple-pay-mount"></div>11 </form>12 </body>13</HTML>
1Framepay.initialize({2 publishableKey: 'pk_sandbox_123',3 organizationId: 'org-123',4 websiteId: 'website-123',5 transactionData: {6 currency: 'USD',7 amount: 10,8 label: 'Demo purchase label',9 lineItems: [10 {11 label: 'Subtotal',12 amount: '8.70',13 },14 {15 label: 'Tax',16 amount: '1.30',17 }18 ]19 },20});21Framepay.on('ready', function () {22 const applePay = Framepay.applePay.mount('#apple-pay-mount');23});24Framepay.on('token-ready', (data) => {25 // At this point, you can use the token for other operations26 // for example to create a payment instrument or transaction27 console.log('Payment token:', data);28});