Credit Card Payment Flow

Merchant can integrate with Core Payment API in 2 ways:

Non-UI: For merchant who already has their own payment page or would like to have total control over the behavior of payment journey by implementing payment form themselves, and

UI with Redirection: For merchant who want to use 2C2P standard Payment Page for faster time to market which already support mobile responsive design with integrated payment selection menu.

Payment Selection

Payment Selection

Payment Page for Credit Card

Payment Page for Credit Card

Call Flow

Call Flow

Non-UI

StepDescription
1.Merchant frontend gather payment detail on their own payment form
2.Merchant backend server call to 2C2P /nonUI method of Payment API
3.2C2P performs authentication/authorization and update payment status
4.2C2P returns payment status back

UI with Redirection (prePaymentUI)

StepDescription
1.Merchant frontend (may) gather preferred payment method and/or partial information of payment details. This information is referred to as incomplete payment details.
2.Merchant backend call /prePaymentUI method of Payment API
3.2C2P persist detail of incomplete payment and then response back with redirect URL.
4.Client frontend then instructed to redirect back to the URL of 2C2P Payment Page
5.2C2P will inquiry and pull in incomplete payment data then present those information on Payment Page
6.Customer then fill in payment details such as card number and expiry date on Payment Page
7.Payment Page will invoke /nonUI method once customer click to proceed their payment with entered data
8.2C2P performs authentication/authorization and update payment status
9.2C2P returns payment status back. At this point customer will be presented with payment result page
10.Payment Page will internally save acknowledgement status. The payment is considered success according to PGW.
11.2C2P will send backend notification request to merchant backend to inform payment result. Merchant backend supposed to update the payment status accordingly.
12.Merchant backend may optionally send acknowledgement back. Simply response to the notification request with HTTP Status 200 is suffice.
13.2C2P will then send frontend notification to merchant frontend. Depend on payment outcome, the destination URL can be confirmationURL, failedURL or cancellationURL for success, failed and cancelled outcome respectively.

Sample Payment Request

This is a lightweight payment request example to prePaymentUI. Please refer to full message specification on dedicated Payment API page.

📘

Payment API

nonUI API

prePaymentUI API

❗️

Encryption Warning

The payment request must be encrypted from JSON to JOSE, as specified on the Integration Page, before being sent to the PACO Payment API in both non-production and production environments.