Asynchronous Notification and Synchronous Return
- The server returns after receiving the payment notification from the payment provider.
- For asynchronous notifications, you need to provide the interface URL for us to configure in the background, or upload the parameter notify_url when pre-ordering; for synchronous returns, you need to upload the parameter return_url when pre-ordering.
Note: OCT, FDMS, JETCOHK currently only have synchronous notifications without asynchronous notifications, and NUVEI, online UnionPay only notifies once, please actively call the query to get the order status. - The request parameters for the asynchronous notification merchant interface and the synchronous return merchant page, where the Content-Type of the asynchronous notification merchant interface is application/json, and the Content-Type of the synchronous return merchant page is x-www-form-urlencode, POST submission method returns to the merchant for reception and processing.
- After receiving the asynchronous notification, you must return the response parameters to inform that the notification has been successfully received and processed. If it is a synchronous return, the merchant does not need to return.
Info
You need to provide notify_url
/ return_url
when placing an order
Name | Type | Description | Requirement |
---|---|---|---|
notify_type | String(30) | Notification type Fixed: trade_status_sync | |
user_confirm_key | String | User Key, provided by eftPay | |
trade_no | String(64) | Payment provider's order number | |
transaction_id | String(64) | Payment provider's order number | |
out_trade_no | String(28) | Merchant's order number | |
eft_trade_no | String(28) | eftPay's order number | |
eftpay_trade_no | String(28) | eftPay's order number | |
total_fee | String(8) | Amount | |
currency | String(5) | Currency type | |
trade_status | String(32) | Transaction status, see Appendix 2 | |
gmt_payment | String | Transaction time, format:yyyy-MM-dd HH:mm:ss | |
wallet | String(20) | Wallet type | |
tid | String(20) | Merchant's terminal number | |
trade_type | String(10) | Transaction typeSALE | |
card_scheme | String(8) | Card type, returned by Mpgs/AE/NUVEI transaction configuration. Such as:VISA /MASTERCARD | |
card_number | String(8) | Card number, returned by Mpgs/AE/NUVEI transaction configuration | |
time | String | Time, format:yyyyMMddHHmmss | |
sign | String(64) | Signature |
Name | Type | Description | Requirement |
---|---|---|---|
return_status | String(3) | Return status code, represents . Note: This parameter cannot be used to determine whether the transaction status is successful Other status codes see Appendix 3 | |
return_char | String(100) | Return description, may change, cannot be used for condition judgment | |
time | String | Time, format:yyyyMMddHHmmss return_status >= 00 return | |
sign | String(64) | Signaturereturn_status >= 00 return |
You must return the following parameters after receiving the transaction asynchronous notification
Name | Type | Description | Requirement |
---|---|---|---|
return_code | String(10) | Return code success/false | |
time | String | Time, format:yyyyMMddHHmmss | |
sign | String(64) | Signature |
{
"notify_type": "trade_status_sync",
"user_confirm_key": "12345678",
"trade_no": "2019082422001386450540290447",
"out_trade_no": "20190824021916",
"eft_trade_no": "08520005269190824021901723",
"total_fee": "0.02",
"currency": "HKD",
"trade_status": "TRADE_SUCCESS",
"sign": "d37d17a7243b2ae49a865275531a9a7c42f80623e673d0ccf5a79ef62bf14913",
"time": "20190824022030",
"gmt_payment": "2019-09-24 02:20:29",
"wallet": "ALIPAYCN",
"trade_type": "SALE"
}
{
"time": "20230609110646",
"sign": "2c418bfb1085b0cabbf2f5c6de71db0694a5a78b7271b05ca6d5a8b70227ebb2",
"return_code": "success"
}