By following these steps, you can seamlessly integrate to your application using your own bank selections page while maintaining control and visibility over transaction statuses.
Authentication
LeanX uses Auth Token to authenticate in each request's header.
Request Header
Copy {
"auth-token": "LP-0D7C06DE-MM|7394e58e-edee-4c42-9ca5-bcbc449f1b9f|2141df4a3cb633d5ce8683bb0c55067e5caebfbe07390dde277dc455bcc95c91723a81b5e565c7c02d68fb84e396722563016bf99e576a4b8cdbe4423fbf226b"
}
Step 1: Getting Payment Service List
B2B payment service list are only available for payment type WEB_PAYMENT.
Jump to Getting B2B Payment Service List here
HTTP Method: POST
Copy https://api.leanx.dev/api/v1/merchant/list-payment-services
Request Body
Copy {
"payment_type": "WEB_PAYMENT",
"payment_status": "active",
"payment_model_reference_id": 1
}
Attributes
Payment service type
WEB_PAYMENT
= Web Payment (FPX)
GLOBAL_CARD_PAYMENT
= Card
DIGITAL_PAYMENT
= E-Wallet
BUY_NOW_PAY_LATER
= Buy Now Pay Later
SWITCH_PAYPAL
= PayPal
GLOBAL_CARD_PAYMENT_STRIPE
= Stripe
payment_model_reference_id*
The web payment (FPX) channel
1
= B2C
2
= B2B
If using other payment type than WEB_PAYMENT
, please use
1
= Default
Payment service channel status
active
or inactive
Response
Copy {
"response_code": 2000,
"description": "SUCCESS",
"app_version": "/api/v1",
"talk_to_server_before": "2023-11-28T19:22:13.243431",
"data": {
"list": {
"draw": 25,
"record_total": 25,
"record_filtered": 25,
"data": [
{
"WEB_PAYMENT": [
{
"payment_service_id": 16,
"payment_model_reference_id": 1,
"payment_model_reference": "B2C",
"unique_reference": "AFFIN_BANK_WEBPAY",
"payment_service": "WEB_PAYMENT",
"name": "Affin Bank",
"record_status_id": 1,
"record_status": "ACTIVE"
},
...........
{
"payment_service_id": 85,
"payment_model_reference_id": 1,
"payment_model_reference": "B2C",
"unique_reference": "UOB_TESTID_WEBPAY",
"payment_service": "WEB_PAYMENT",
"name": "United Overseas Bank - B2C Test",
"record_status_id": 1,
"record_status": "ACTIVE"
}
]
}
],
"next_page_start": null,
"next_page_length": null,
"previous_page_start": null,
"previous_page_length": null
}
},
"breakdown_errors": null,
"token": ""
}
Step 2 : Create Silent Bill
This will create a bill and return a link straight to the payment service that you chose through payment_service_id.
HTTP Method: POST
Copy https://api.leanx.dev/api/v1/merchant/create-bill-silent
Request Query
Request Body
Copy {
"collection_uuid": "CL-C0D7F54A90-LNP",
"amount": 10.00,
"redirect_url": "https://www.yourdomain.com/return-page",
"callback_url": "https://www.yourdomain.com/api-callback-url",
"full_name": "John Doe",
"email": "johndoe@email.com",
"phone_number": "0123456789",
"payment_service_id": 33,
"invoice_ref" : "INV202311280001"
}
Attributes
Total amount to be paid in MYR
Mobile number of the payer
Merchant Invoice Reference
Response
Copy {
"response_code": 2000,
"description": "SUCCESS",
"app_version": "/api/v1",
"talk_to_server_before": "2023-01-31T14:28:30.842232",
"data": {
"bill_no": "EXAMPLE-BILL-001",
"transaction_invoice_no": "FPX1700639540AlnAnAy0",
"redirect_url": "https://www.yourdomain.com/return-page"
}
}
Step 3 : Callback
Upon every successful transaction, a callback will be send to the link that you provided earlier through parameter
However, LeanX callback mechanism will send an encoded JWT message instead of plain text to provided link, which need to be decoded with a hash key before it can be read. Below are the sample of callback response before and after encoding and decoding process.
Sample callback response before JWT decode
Copy {
"data":"eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9.eyJpbnZvaWNlX25vIjoiQlAxNzAxMTU1ODgwdUJNd0I5cTAiLCJjbGllbnRfZGF0YSI6eyJtZXJjaGFudF9pbnZvaWNlX25vIjoiTFhQQVlldWJiNjhXMTcwMTE1NTg0MnVOSGhTIiwidXVpZCI6IjhlZjRjZTUwLWFlYmItNGQ4Yy1iMTQyLTRmYTJhMDg5ZmQwNiIsIm9yZGVyX2lkIjoiTm9uZSJ9LCJpbnZvaWNlX3N0YXR1c19pZCI6MiwiaW52b2ljZV90eXBlX2lkIjoxLCJpbnZvaWNlX3R5cGUiOiJOT1JNQUxfQ09MTEVDVElPTiIsImludm9pY2Vfc3RhdHVzIjoiU1VDQ0VTUyIsImFtb3VudCI6IjQ1Ni4yMCIsInBheW1lbnRfbW9kZWxfcmVmZXJlbmNlX2lkIjoxLCJyYXRlX3R5cGVfcmVmZXJlbmNlX2lkIjoyLCJwYXltZW50X3NlcnZpY2VfaWQiOjg5LCJjbGllbnRfcmVkaXJlY3RfdXJsIjoiaHR0cHM6Ly93d3cueW91cmRvbWFpbi5jb20vcmV0dXJuLXBhZ2UiLCJjbGllbnRfY2FsbGJhY2tfdXJsIjoiaHR0cHM6Ly93d3cueW91cmRvbWFpbi5jb20vYXBpLWNhbGxiYWNrLXVybCIsImNsaWVudF90cmFuc2FjdGlvbl9kZXRhaWxzIjpudWxsLCJwcmVmdW5kX2NvbGxlY3Rpb24iOnsiaXRlbSI6bnVsbCwicmVzcG9uc2VfY29kZSI6MjEwMH0sImRlc2NyaXB0aW9uIjpudWxsLCJjYXJkX3Rva2VuIjpudWxsLCJmcHhfZGViaXRfYXV0aF9jb2RlIjoiMDAiLCJmcHhfY3JlZGl0X2F1dGhfY29kZSI6IjAwIiwiZnB4X2RlYml0X3N0YXR1cyI6IkFwcHJvdmVkIiwidHJhbnNhY3Rpb25fcmVzcG9uc2VfdGltZSI6IjI4IE5vdmVtYmVyIDIzIDAzOjE4OjAzIFBNIiwib3JpZ2luYWxfdHJhbnNhY3Rpb25fcmVzcG9uc2VfdGltZSI6IjIwMjMtMTEtMjggMTU6MTg6MDMiLCJhbGciOiJIUzI1NiJ9.sbYhLQgR6Y4MRlAyMaVPHNWOc3Bp9NvFyKOFF-npyIU",
"response_code":2100
}
Sample callback response after JWT decode
Copy {
"invoice_no": "BP1701155880uBMwB9q0",
"client_data": {
"merchant_invoice_no": "LXPAYeubb68W1701155842uNHhS",
"uuid": "8ef4ce50-aebb-4d8c-b142-4fa2a089fd06",
"order_id": "None"
},
"invoice_status_id": 2,
"invoice_type_id": 1,
"invoice_type": "NORMAL_COLLECTION",
"invoice_status": "SUCCESS",
"amount": "456.20",
"payment_model_reference_id": 1,
"rate_type_reference_id": 2,
"payment_service_id": 89,
"client_redirect_url": "https://www.yourdomain.com/return-page",
"client_callback_url": "https://www.yourdomain.com/api-callback-url",
"client_transaction_details": null,
"prefund_collection": {
"item": null,
"response_code": 2100
},
"description": null,
"card_token": null,
"fpx_debit_auth_code": "00",
"fpx_credit_auth_code": "00",
"fpx_debit_status": "Approved",
"transaction_response_time": "28 November 23 03:18:03 PM",
"original_transaction_response_time": "2023-11-28 15:18:03"
}
Step 4 : Getting Transaction Status
The Transaction Status API provides a link to retrieve the status of previous transactions, encompassing all payment statuses. This method is recommended over the callback approach for checking transaction status.
HTTP Method: POST
Copy https://api.leanx.dev/api/v1/merchant/manual-checking-transaction
Request Query
Copy ?invoice_no=BP-AD5112621A-LNP
Attributes
The transaction invoice number for which you want to retrieve the status can be either a system-generated invoice number or an invoice_ref added by the merchant.
Response
Copy {
"response_code": 2000,
"description": "SUCCESS",
"app_version": "/api/v1",
"talk_to_server_before": "2024-03-29T15:59:17.597177",
"data": {
"transaction_details": {
"invoice_no": "BP-AD5112621A-LNP",
"fpx_invoice_no": "FPX17116902144iiAlu58",
"amount": "15.00",
"invoice_status": "SUCCESS",
"providerTypeReference": "FPX",
"bank_provider": "Maybank2U",
"category_code": "WEBPAY",
"amount_with_fee": 15.80,
"fee": 0.80,
"fee_by_customer": false
},
"customer_details": {
"name": "Ahmad Fuad",
"phone_number": "0123249478",
"email": "ahmadfuadzamri@gmail.com"
}
},
"breakdown_errors": "",
"token": ""
}
Last updated 7 months ago