Pay Order
Once you have created the order, you can use the order to initiate payment. You can either use Cashfree’s user interface to capture payment details. You will do this by redirecting the customer to a cashfree hosted page, which can be customized for your needs.
The merchants can also build their own interface to capture payment instrument details (card numbers, UPI id etc) and call this API to initiate the payment. This API can be safely called from any device and does not require any authentication.
Pre-built Checkout Page
If you want to use a pre-built checkout page, then you just need to use the payment_link
parameter value from the create order response and redirect the customer to that page.
create order response
...
"payment_link": "https://payments-test.cashfree.com/order/#BtJEHHxOB9bFpNsaHmEL"
...
Custom Checkout Page
If you want to build a custom checkout page you need to build your own UI and send the payment details to Cashfree. We will assume that you have built your own custom checkout page.
Cashfree expects you to send the payment instrument details to an endpoint like /orders/pay
. The payload will change for every payment method - example cards, upi, net banking, apps etc.
Cards
To send card details from you UI just send the details to the below endpoint /orders/pay
.
curl --request POST \
--url https://sandbox.cashfree.com/pg/orders/pay \
--header 'Content-Type: application/json' \
--header 'x-version: <<x-api-version>>' \
--data '{
"order_token": "kAhvfP4q6US5cr6RnCBo",
"payment_method" : {
"card" : {
"channel": "link",
"card_number": "4444333322221111",
"card_holder_name": "rohit",
"card_expiry_mm" : "02",
"card_expiry_yy" : "22",
"card_cvv" : "123"
}
}
}'
{
"payment_method": "card",
"channel": "link",
"action": "link",
"data": {
"url": "https://sandbox.cashfree.com/pg/view/gateway/LGi51C905Z3uVgjzi1YSb7832c7d73d67f194164fd745dfdebdf",
"payload": null,
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
The response for all card payments will require you to redirect the customer to the bank's OTP page for 2FA. In the response the value of action
is what determines how you should parse the data. In case the action === link
. You need to access the data.url and redirect the customer to that url. To accept cards you need to have PCI DSS certification
UPI
There are multiple ways to perform a UPI payment. You can either use a upi intent link, a qrcode or send a payment collection request to the customers UPI app. Here is a brief snapshot of these payment methods.
Channel | Flow description |
---|---|
link | This channel is used for intent payments. If you send the channel as link , we will return you the intent links for different UPI applications. |
qrcode | This channel is used to generate a UPI qrcode. |
collect | This channel is used to send a payment collection notification to the customers UPI app. The customer should then approve the request to complete the payment. |
{
"order_token": "50d69USBiPF8i1PjRVk6",
"payment_method" : {
"upi" : {
"channel": "link"
}
}
}
{
"payment_method": "upi",
"channel": "link",
"action": "custom",
"data": {
"url": null,
"payload": {
"bhim": "bhim://upi/pay?pa=cashfree.pay@indus&pn=Cashfree&tr=244178447&am=2.00&cu=INR&mode=00&purpose=00&mc=5732&tn=Cashfree%20Payment",
"default": "upi://pay?pa=cashfree.pay@indus&pn=Cashfree&tr=244178447&am=2.00&cu=INR&mode=00&purpose=00&mc=5732&tn=Cashfree%20Payment",
"gpay": "tez://upi/pay?pa=cashfree.pay@indus&pn=Cashfree&tr=244178447&am=2.00&cu=INR&mode=00&purpose=00&mc=5732&tn=Cashfree%20Payment",
"paytm": "paytm://upi/pay?pa=cashfree.pay@indus&pn=Cashfree&tr=244178447&am=2.00&cu=INR&mode=00&purpose=00&mc=5732&tn=Cashfree%20Payment",
"phonepe": "phonepe://pay?pa=cashfree.pay@indus&pn=Cashfree&tr=244178447&am=2.00&cu=INR&mode=00&purpose=00&mc=5732&tn=Cashfree%20Payment"
},
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
{
"order_token": "50d69USBiPF8i1PjRVk6",
"payment_method" : {
"upi" : {
"channel": "qrcode"
}
}
}
{
"payment_method": "upi",
"channel": "qrcode",
"action": "custom",
"data": {
"url": null,
"payload": {
"qrcode": ""
},
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
{
"order_token": "50d69USBiPF8i1PjRVk6",
"payment_method" : {
"upi" : {
"channel": "collect",
"upi_id": "7798112345@ybl"
}
}
}
{
"payment_method": "upi",
"channel": "collect",
"action": "custom",
"data": {
"url": null,
"payload": null,
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
Parsing Response
The response for UPI will always have action
as custom
. This is because each payment flow needs to be handled differently.
-
Link: In the response we will send you a upi intent (or an app link). The default link will work on all android devices, since
upi://
is a registered intent scheme in Android. If you want to override the default intent link with the custom link for every app, you just need to change the scheme prefix with the app prefix. -
QR Code: In this response we will share a custom payload with you. The payload will contain the
qrcode
parameter which can be used to present the QR code to the customer. -
Collect: A successful response for a collect request will contain action as
custom
but the data payload will contain onlynull
values. This is because, if you receive a successful (200) response, we would have already sent the app notification to the customers UPI application. Now you need to wait for the webhook, which will be invoked once the user completes the payment. If the user does not complete the payment within a specific time, you can cancel this order for the user.
Net banking
To initiate a net banking payment, you need to pass us the net banking parameter. In response Cashfree will return a redirect link to you.
{
"order_token": "9dGxfNN4Ce62TUjxZhQg",
"payment_method": {
"netbanking": {
"channel": "link",
"netbanking_bank_code": 3009
}
}
}
{
"payment_method": "netbanking",
"channel": "link",
"action": "link",
"data": {
"url": "https://www.cashfree.com/PaymentGateway/txnreq.pg?id=902f1351-1d5c-45ee-a71b-06c8f90b7436",
"payload": null,
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
Apps
To initiate payment for a custom application like Airtel money, PhonePe, Google Pay etc. You will have to send us the customers phone number and the application name. In response we will return a https url using which the customer can pay using this app.
Valid app names are gpay
, phonepe
, ola
, paytm
, amazon
, airtel
, freecharge
, mobikwik
, jio
{
"order_token": "9dGxfNN4Ce62TUjxZhQg",
"payment_method": {
"app": {
"channel": "link",
"provider":"paytm",
"phone": "9930764185""
}
}
}
{
"payment_method": "app",
"channel": "link",
"action": "link",
"data": {
"url": "https://prod.cashfree.com/pgnextgenapi-test/api/v1/view/gateway/9dGxfNN4Ce62TUjxZhQg843317e97fef732632edf59b8e7144c2",
"payload": null,
"content_type": null,
"method": null
},
"cf_payment_id" : 1234
}
EMI
To process EMI payments on a card you need to pass the card_bank_name
and emi_tenure
in the API request. If the card does not belong to the card_bank_name
bank, the API will throw an error. Ensure you pass the bank names specified below within brackets for the card_bank_name
field.
The banks supported credit card EMI payments are:
- Standard Chartered Credit Card (Standard Chartered)
- ICICI Bank Credit Card (ICICI)
- Kotak Bank Credit Card (Kotak)
- HDFC Bank Credit Card (HDFC)
- Bank of Baroda Credit Card (BOB)
- RBL Credit Card (RBL)
- Axis Bank Credit Card (Axis)
- AU Small Finance Bank (AU)
curl --request POST \
--url https://api.cashfree.com/pg/orders/pay \
--header 'Content-Type: application/json' \
--header 'x-version: <<x-api-version>>' \
--data '{
"order_token": "t9qINHM625rHrx",
"payment_method" : {
"emi": {
"channel": "link",
"card_number": "41xxxxxxxxx150",
"card_expiry_mm": "11",
"card_expiry_yy": "25",
"card_cvv": "123",
"card_bank_name": "Kotak",
"emi_tenure": 3
}
}
}'
BNPL
Cashfree provides multiple BNPL options for payments. To process these payments take a look at the below curl requests. We support the following providers -
- cardless_emi providers -
flexmoney
,zestmoney
- paylater providers -
kotak
,flexipay
,zestmoney
,lazypay
,olapostpaid
curl --request POST \
--url https://api.cashfree.com/pg/orders/pay \
--header 'Content-Type: application/json' \
--header 'x-version: <<x-api-version>>' \
--data '{
"order_token": "n0hKSNHiPJZ83XqE8UnH",
"payment_method": {
"paylater": {
"channel": "link",
"provider":"lazypay",
"phone":"7428638946"
}
}
}'
curl --request POST \
--url https://api.cashfree.com/pg/orders/pay \
--header 'Content-Type: application/json' \
--header 'x-version: 2022-01-01' \
--data '{
"order_token": "n0hKSNHiPJZ83XqE8UnH",
"payment_method": {
"cardless_emi": {
"channel": "link",
"provider":"flexmoney",
"phone":"7428638946"
}
}
}'
Paypal
To process payments through Paypal you will have to provide the payment_method
as paypal. Please look at the API request and response below.
curl --request POST \
--url https://api.cashfree.com/pg/orders/pay \
--header 'Content-Type: application/json' \
--header 'x-api-version: <<x-api-version>>' \
--data '{
"order_token": "NSQXpOThJaJdCvacY8L7",
"payment_method": {
"paypal": {
"channel": "link",
"currency": "USD"
}
}
}'
{
"payment_method": "paypal",
"channel": "link",
"action": "link",
"data": {
"url": "https://api.cashfree.com/pg/view/gateway/NSQXpOThJaJdCvacY8L73376372d8a61c7546fd06de14f9fa76e",
"payload": null,
"content_type": null,
"method": null
},
"cf_payment_id": 80098154
}
Updated about 1 year ago
Once the customer has paid through their bank account, you still need to handle the thank you page and verify their response.