method 1 - payment journey
order creation
the API-key of our sandbox testing merchant: {{API_KEY}}
step 1. create the payment order on divit
curl -v -X POST https://sandbox-api.divit.dev/paynow/orders \
-H 'api-key: {{API_KEY}}' \
-H 'content-type: application/json; charset=utf-8' \
--data-binary @- << EOF
{
"customer": {
"firstName": "Stephen",
"lastName": "Chow",
"email": "[email protected]",
"tel": "+85293920190",
"language": "en"
},
"order": {
"totalAmount": {
"amount": 520000,
"currency": "HKD"
},
"expiredAt": 1696654130,
"merchantRef": "1665118687247",
"merchantUniqueOrderID": "1665118687247",
"orderType": "retail",
"orderItems": [],
"webhookSuccess": "https://youmall.divit.dev/payment-success.html?order-number=1665118687247",
"webhookFailure": "https://youmall.divit.dev/payment-failure.html?order-number=1665118687247",
"webhookEvents": "https://divit.requestcatcher.com",
language: "en"
}
}
EOF
response (note: the sample token already expired)
{
"code": 0,
"message": "OK",
"data": {
"redirectURI": "https://sandbox-consumer.divit.dev/paynow/7bcbf826-d684-4f59-9634-60d816a660db/fast?merchant=UAT Testing&mRef=UATTESTING",
"orderID": "7bcbf826-d684-4f59-9634-60d816a660db",
"token": "eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2NjUxMjI0OTUsIm9yZCI6IjdiY2JmODI2LWQ2ODQtNGY1OS05NjM0LTYwZDgxNmE2NjBkYiIsIm9yaWdfaWF0IjoxNjY1MTE4ODk1LCJzY29wZSI6InRtcGVuZHVzZXIiLCJzdWIiOiJjOWI3MGM1OC1hODJhLTQzOGItOGRlOS03MDg5ZjY2OWNiNDMifQ.JTfgZDKxYJ6S52tXqPbyi90fyeUIAKT60bXKVKADcIP0wAdscWeCIA11bk9stF8c07svhQfH7MNqq1NodrBLtT2UcGkf06tVNbwImaWnLDXDf9pEaPor5fSOnaK0HfRXUyuPwW5KPnL1350fHbnfchjHEiLUlFkbBbzRk2m6VOUvyvSZ4_73JkSubTkjXn77cILkKk5aaXooQGDbBF5xMga6klShsgHKr8v3iqmCWnLtEcKi3unjguoQNCv5osOw89-jCNPx0EsQLDuohy3a0lKOCX7bBbk6cNe54X9YqsQXd7xtNEaGEk_9WA1MDmTD2SjbeqTxibwOsOrFElCYdA"
}
}
step 2. open the divit payment URL
redirect front-end to {{redirectURI}}&token={{token}}
, for example
https://sandbox-consumer.divit.dev/paynow/7bcbf826-d684-4f59-9634-60d816a660db/fast?merchant=UAT Testing&mRef=UATTESTING&token=eyJhbGciOiJSUzI1NiIsInR5cCI6IkpXVCJ9.eyJleHAiOjE2NjUxMjI0OTUsIm9yZCI6IjdiY2JmODI2LWQ2ODQtNGY1OS05NjM0LTYwZDgxNmE2NjBkYiIsIm9yaWdfaWF0IjoxNjY1MTE4ODk1LCJzY29wZSI6InRtcGVuZHVzZXIiLCJzdWIiOiJjOWI3MGM1OC1hODJhLTQzOGItOGRlOS03MDg5ZjY2OWNiNDMifQ.JTfgZDKxYJ6S52tXqPbyi90fyeUIAKT60bXKVKADcIP0wAdscWeCIA11bk9stF8c07svhQfH7MNqq1NodrBLtT2UcGkf06tVNbwImaWnLDXDf9pEaPor5fSOnaK0HfRXUyuPwW5KPnL1350fHbnfchjHEiLUlFkbBbzRk2m6VOUvyvSZ4_73JkSubTkjXn77cILkKk5aaXooQGDbBF5xMga6klShsgHKr8v3iqmCWnLtEcKi3unjguoQNCv5osOw89-jCNPx0EsQLDuohy3a0lKOCX7bBbk6cNe54X9YqsQXd7xtNEaGEk_9WA1MDmTD2SjbeqTxibwOsOrFElCYdA
you will see the FPS payment screen
step 3. customer scan the QR with banking app
for testing purpose, we use https://bank.divit.dev/ to simulate banking app payment.
- best to use on mobile, pick "scan to pay", then you can scan the QR using your phone's camera
- make sure you choose the “sandbox” under the "settings" option.
- scan the QR with your phone camera. you will find the “scanned payment information" in the review payment page
- you can test a failure payment by switching the “is failure payment” button on in the "advanced options" at the review payment screen
- press “confirm”
step 4. webhook event will be sent to webhookEvents
webhook event will be sent to the URI defined in webhookEvents
during the order creation.
please verify the signature of the event by the method describes here, webhook from divit
POST / HTTP/1.1
Host: divit.requestcatcher.com
Accept-Encoding: gzip
Content-Length: 305
Content-Type: application/json
User-Agent: Go-http-client/1.1
X-Divit-Signature: t=1665119487,s1=T2TzkjYFjTbtDIDtMrxV3LzVVOmBlRYF6pRLaEpV/fg=
{
"event": {
"eventId":2001,
"eventDescription":"Order has been activated by the customer"
},
"eventData":{
"orderID":"7bcbf826-d684-4f59-9634-60d816a660db",
"customerID":"c9b70c58-a82a-438b-8de9-7089f669cb43",
"totalAmount":{"amount":520000,"currency":"HKD"},
"partnerRef":"1665118687247"
}
}
step 5. redirect back to merchant site
if the payment is complete successfully, there is a button on divit success payment page, customer will be redirected back to the URI defined in webhookSuccess
if the payment is failed, divit will redirect the customer back to the URI defined in webhookFailure