Apple Pay
Introduction
Create Merchant ID
To create your Merchant ID, follow these steps.
- In the personal area of the Apple Member Center, go to Certificates, Identifiers & Profiles.
- In the Identifiers section select Merchant IDs.
- On the resulting page click + (Add) in the right upper corner.
- In the Merchant ID Description and Identifier fields enter a description of your Apple merchant identifier and the identifier itself accordingly.
- Click Continue.
- On the resulting page check the data you entered and click Register.
- On the resulting page click Done.
Certificate registration
To receive payments via Apple Pay, you need to have a key pair (private and public key) and the corresponding public key certificate. The required actions in the personal cabinet depend on whether you already have a key pair and the corresponding certificate or not.
Initial conditions | Required steps |
---|---|
You do not have a key pair and the public key certificate |
After that the following actions will become available. |
You have a key pair and your public key certificate is registered at Apple Pay |
Upload the file containing your key pair After that the following actions will become available. |
Create new certificate
To create a key pair, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Apple Pay.
- Click Create key pair.
The following form will display.
- Fill in the required fields (see the table below).
Setting | Description |
---|---|
Encryption algorithm |
This radio button allows to select one of the two cryptographic algorithms that will be used for key pair generation.
|
Country (C) |
Enter two-letter code of the country where your organization is located. |
Locality Name (L) |
Enter the name of the locality where your organization is located. |
Organization Name (O) |
Enter the name of your organization. |
Apple ID |
Merchant Apple ID. |
State Name (ST) |
Enter state name where your organization is located. |
Common Name (CN) |
Enter the domain name of your site, for example, test.com . |
Organization Unit (OU) |
Enter the name of your organization unit. |
- After making the necessary changes click Create.
The created key pair will be displayed in the Apple Pay section (see the figure below).
Proceed to CSR download
Upload previously created certificate
To upload an existing key pair, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Apple Pay.
- In the Merchant identification certificates section click Add key.
The following form will be displayed.
- Fill in the following fields.
- Apple ID - enter your Merchant Apple ID.
- Password - enter the password for your PKCS12 file.
- Default domain - enter the domain of your online store.
- Drag your key pair file to the designated area on the page.
It will be displayed below.
- Click Create. The uploaded key pair will be displayed in the Merchant identification certificates section.
After uploading your key pair the following actions will become available.
Export CSR
To download CSR, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select the required payment service (Apple Pay, Google Pay, or Samsung Pay).
- Click next to your certificate and select Download CSR (see the figure below).
Save file dialog will display. - Specify the path to which the file will be saved or save it to the default folder.
Also, the following actions are available.
Edit Merchant ID
To edit your Apple Merchant ID, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Apple Pay.
- Click and select Edit. (see the figure below).
The following form will be displayed.
- Edit Apple ID field and click Confirm.
Disable certificate
To disable a certificate (key), follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select the required payment service (Apple Pay, Google Pay, or Samsung Pay).
- Click next to your certificate and select Disable key (see the figure below).
The following dialog will display.
- Click Confirm.
Whether a disabled certificate is displayed in the personal cabinet depends on Allowed certificates setting that is at the upper left corner of the Certificates section (see the figure below).
Setting | Description |
---|---|
Allowed certificates enabled | Disabled certificates are not displayed in the Keys list. |
Allowed certificates disabled | Disabled certificates are displayed in the Keys list. Allowed cell will have False value (see the figure below). |
Actions necessary for web integration
For Web integration, follow these steps.
- Register and confirm your domain in Apple.
- If the payment page is located on your side, register your domain.
- If the payment page is located on the payment gateway side, specify the payment gateway domain.
- Create a merchant identification certificate, convert it to a
.pem
file, and upload it to your server.
This certificate is used to authenticate connections to Apple Pay servers.
Registration of a domain in Apple
To register a certificate in Apple, follow these steps.
- Log in to your Apple developer account at https://developer.apple.com.
- Follow Apple developer account help instructions to register a domain.
Select the previously created merchant ID when prompted.
Integration scheme
- The user in the mobile application selects the payment option using Apple Pay.
- The payment data is sent to the Apple Pay system for processing.
- To process the payment data an object
PKPaymentToken
object, which haspaymentData
attribute, is created in the Apple Pay system (here and further see Apple Pay documentation). - Apple Pay sends a response to the merchant (mobile application).
- The merchant exctracts paymentData attribute out of received
PKPaymentToken
object and encodes its contents in Base64. - The merchant creates a
payment request
containingpaymentDataattribute
, which is received from the Apple Pay response and encoded in Base64, and sends it astoken
to the Payment Gateway for processing (see API Reference for details). - The payment system processes the request.
- The payment system returns a response with the result.
- The mobile application displays the payment result to the user.
Reference links
Link | Description |
---|---|
Apple Pay | A section of the apple.com site containing general information on Apple Pay. |
Developer Apple Pay | A section of the apple.com site dedicated to developers and containing links and reference information concerning Apple Pay. |
Apple Pay Sandbox | A section of the apple.com site containing information on testing. |
Apple Pay Guide | A section of the apple.com site containing a programming reference. |
Apple Pay Guidelines | A section of the App Store reference dedicated to Apple Pay. |
Apple Pay API | API reference (application programming interface). |
PKPaymentToken Object structure | Description of the PKPaymentToken Object structure. |
Login page | The development environment login page. |
Getting Started with Apple Pay | PDF document containing general information on Apple Pay and reference links. |
Apple Pay Marketing Guidelines | Description of how to add the Apple Pay button on your website. |
Google Pay
Introduction
There are several implementation options for Google Pay™.
Payment option | Description |
---|---|
From your mobile application | Payment is made from your mobile application installed on customer's mobile device. In this scenario the application requests encrypted data from Google Pay. This data must be sent to the payment gateway. To use this option, you must integrate your application with Google Pay API. |
From a Web payment page located on the side of the payment gateway | Payment is made from a Web page. In this case, the merchant redirects the customer to the payment page on the payment gateway side, and must meet Google Pay requirements: |
How to integrate with Google Pay API
If you want to use Google Pay as a Payment method on your Android app, you need to integrate your Android app with the Google Pay API via Google Pay & Wallet Console. Please follow this instruction: Google Pay API & Google Pay & Wallet Console.
On step 4 of the instruction (for Android app), when completing the tutorial, specify the tokenization type 'PAYMENT_GATEWAY':
const tokenizationSpecification = {
type: 'PAYMENT_GATEWAY',
parameters: {
'gateway': 'example',
'gatewayMerchantId': 'exampleGatewayMerchantId'
}
};
and replace example
and exampleGatewayMerchantId
with the values for BPC payment provider from the table of payment providers:
-
gateway
=bpcpay
-
gatewayMerchantId
- merchant login in payment gateway
As a result of integration with Google Pay API, you will be assigned Google Merchant ID that is displayed on the top-right corner of the page in Google Pay & Wallet Console.
Integration schemes
Payment from a mobile app
- A customer selects to pay via Google Pay.
- The application requests masked card data from Google Pay.
- Google Pay returns masked card data to the application.
- The application displays the masked card data to the customer.
- The customer confirms payment.
- The application requests encrypted card data from Google Pay .
- Google Pay encrypts the data using merchant's public key.
- Google returns the encrypted payment data to the application.
- The application sends a payment request to the payment gateway, the request contains the token received from Google Pay.
- The payment gateway decrypts the received token and processes the payment.
- The payment gateway returns the payment result to the application.
- The application displays the payment result to the customer.
Payment page is on the payment gateway side
If the payment page is located on the Google Pay side, the scheme is the following.
- A customer creates an session on the merchant's Website.
- The merchant registers the session in the payment gateway.
- The payment gateway returns a unique session number and the payment URL to which the customer must be redirected.
- The store system redirects the customer to the URL from step 3.
- The customer's browser opens the URL.
- The customer receives a payment form.
- The customer choose to pay via Google Pay and confirms the choice.
- The payment data is exchanged between the payment gateway and Google Pay - the payment gateway receives the payment data.
- The payment gateway processes the payment.
- The customer is redirected to the final page where the payment status is displayed.
Payment via Google Pay using 3DS 2.0
When you use payment via Google Pay with the payment request, you can use customer authentication with 3DS 2.0. In this case, you must send a payment request to the payment gateway twice for each payment. Sending the first request initiates the 3DS 2.0 authentication procedure, and sending the second request continues the procedure with the data received from the 3DS server (an additional component that interacts with payment systems and ACS).
Below is the scheme of payment request (token decryption on the Payment Gateway side) using 3DS 2.0.
(decrypted token in Base64) PG ->> PG: Token decryption PG -->> Merchant: Response with the ``redirectUrl`` parameter opt Redirection to ACS is required Merchant ->> ACS: CReq (Challenge request) ACS -->> Customer: HTML form to pass authentication Customer ->> ACS: Confirmation of authenticity ACS -->> Customer: Authentication result and redirection to the store page end Merchant ->> PG: Retrieves the details of a Payment PG -->> Merchant: Response to the request Merchant -->> Customer: Displaying the result
- A customer chooses to pay via Google Pay.
- The application requests Google Pay masked card data.
- Google Pay returns the masked card data.
- The application displays the masked card data to the customer.
- The customer confirms payment.
- The application requests Google Pay the encrypted card data.
- Google Pay encrypts the data using your public key.
- Google Pay returns the encrypted payment data to the application.
- The merchant sends decrypted paymentToken to the payment gateway by sending the payment request.
- The payment gateway decrypts the received token.
- The payment gateway checks on the 3DS server whether the customer can authenticate using the 2.0 Protocol and sends the response. The response also returns the
redirectUrl
parameter. - The payment gateway interacts with 3DS server and ACS to find out if the customer needs to authenticate on ACS and sends the response to the payment request.
- ACS displays an HTML form for authentication to the customer.
- The customer is authenticated.
- ACS redirects the customer to the store's page.
- The merchant sends a request to retrieve the details of a payment.
- The payment gateway sends a response to the request.
- The merchant displays the result page to the customer.
Using individual keys
If you don’t want to use BPC payment provider for some reason and want to use direct integration with Google Pay, you can use an individual key pair for decryption of the encrypted payment data from Google Pay. This key pair can be generated via the Merchant Portal and then uploaded to your Google account.
Create key pair
To create a key pair, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Google Pay.
- In the Keys section click Create key pair.
The following form will be displayed.
- Fill in the Google ID field with your Google Merchant ID obtained from Google Pay during integration with Google API, then click Confirm.
- The created key pair will be displayed in the Keys section (see the figure below).
Download public key
To download your public key, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Google Pay.
- Click next to your certificate and select Download key (see the figure below).
- In the Save file window select the path to which the file will be saved or save it to your default folder.
Also, the following action are available.
Edit Google ID
To edit your Google ID, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Google Pay.
- Click next to your certificate and select Edit (see the figure below).
The following form will be displayed.
- Edit the Google ID field, then click Confirm.
Disable certificate
To disable a certificate (key), follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select the required payment service (Apple Pay, Google Pay, or Samsung Pay).
- Click next to your certificate and select Disable key (see the figure below).
The following dialog will display.
- Click Confirm.
Whether a disabled certificate is displayed in the personal cabinet depends on Allowed certificates setting that is at the upper left corner of the Certificates section (see the figure below).
Setting | Description |
---|---|
Allowed certificates enabled | Disabled certificates are not displayed in the Keys list. |
Allowed certificates disabled | Disabled certificates are displayed in the Keys list. Allowed cell will have False value (see the figure below). |
Samsung Pay
General information
Before accepting payments via Samsung Pay, follow these steps.
- Create an account at https://account.samsung.com.
- Using the created account, register at https://pay.samsung.com/developers.
- At https://pay.samsung.com/developers create Service and select BPC as your Payment Gateway.
- Proceed to the actions in the personal cabinet of the payment gateway:
Create key pair
To create a key pair, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select Samsung Pay.
- In the Keys section click Create key pair.
The following form will be displayed.
- Fill in the fields (see the table below).
Field | Description |
---|---|
Country (C) |
Enter two-letter code of the country where your organization is located. |
State Name (ST) |
Enter state name where your organization is located. |
Locality Name (L) |
Enter the name of the locality where your organization is located. |
Common Name (CN) |
Enter the domain name of your site, for example, test.com . |
Organization Name (O) |
Enter the name of your organization. |
Organization Unit (OU) |
Enter the name of your organization unit. |
- After making the necessary changes click Create.
The created key pair will be displayed in the Keys section (see the figure below).
Proceed to CSR download.
Export CSR
To download CSR, follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select the required payment service (Apple Pay, Google Pay, or Samsung Pay).
- Click next to your certificate and select Download CSR (see the figure below).
Save file dialog will display. - Specify the path to which the file will be saved or save it to the default folder.
Now you can register your certificate by uploading the CSR to Samsung Pay.
Also, you can disable your certificate.
Complete registration
In your profile at https://pay.samsung.com/developers upload the certificate signing request as Merchant CSR (merchant certificate signing request).
Disable certificate
To disable a certificate (key), follow these steps.
- Log in to your personal cabinet and click in the left panel (Certificates section).
- Select the required payment service (Apple Pay, Google Pay, or Samsung Pay).
- Click next to your certificate and select Disable key (see the figure below).
The following dialog will display.
- Click Confirm.
Whether a disabled certificate is displayed in the personal cabinet depends on Allowed certificates setting that is at the upper left corner of the Certificates section (see the figure below).
Setting | Description |
---|---|
Allowed certificates enabled | Disabled certificates are not displayed in the Keys list. |
Allowed certificates disabled | Disabled certificates are displayed in the Keys list. Allowed cell will have False value (see the figure below). |
Integration schemes
Integration schemes
- Integration scheme for payment from a mobile application
- Integration scheme for payment from a web page (payment form on the payment gateway side)
Payment from a mobile application
- A Customer selects Samsung Pay as a payment method.
- The application sends payment details to Samsung.
- Samsung checks the application.
- Samsung sends a response to the application containing, among other things, the
3ds.data
parameter with the encrypted data about the payment. - The merchant sends a payment request to the payment gateway. The contents of
3ds.data
received from Samsung is included in thetoken
parameter. - The payment gateway decrypts the contents of
paymentToken
and makes the payment. - The payment gateway sends the payment result to the application.
- The application displays the result to the customer.
Payment from a Web page on the payment gateway side
- A customer creates a session and starts the payment procedure.
- The merchant sends a session registration to the payment gateway.
- The merchant sends a payment request to the payment gateway.
- The customer selects to pay via Samsung Pay.
- The payment gateway communicates with Samsung Pay.
- The customer is redirected to the Samsung Pay page.
- The customer enters their login.
- The application on the customer's mobile device requests authentication data.
- The customer is authenticated on their device.
- The payment gateway exchanges payment data with Samsung Pay.
- The customer is redirected to the payment result page.