BNI Virtual Account is a bank transfer payment method facilitated by Bank BNI. Despite the name, customers can pay using any Indonesian Bank account to complete payment. Payment can be made trough ATM Bersama, Prima, or Alto ATM networks.
Steps to integrate :
- Send the charge API request to Midtrans.
- Redirect your customer back to your page by configuring Finish URL in Midtrans's Dashboard > Snap Preferences or via [API Request] (/docs/snap-advanced-feature#custom-finish-url).
- Handle notifications.
Open amount and close amount VA has the exact same API contract - by default close amount VA type is activated for you. If you want to activate open amount VA, contact Midtrans support or your sales PIC for further assistance.
By default, default expiry time for bank transfer is 24 hours unless specified by merchant (min 20s, max 180 days).
Sample JSON Request Body
{
"transaction_details": {
"order_id": "ORDER-101",
"gross_amount": 10000
},
"item_details": [{
"id": "ITEM1",
"price": 10000,
"quantity": 1,
"name": "Midtrans Bear",
"brand": "Midtrans",
"category": "Toys",
"merchant_name": "Midtrans"
}],
"customer_details": {
"first_name": "TEST",
"last_name": "MIDTRANSER",
"email": "[email protected]",
"phone": "+628123456"
},
"enabled_payments": ["bni_va"],
"bni_va": {
"va_number": "12345678"
}
}
Parameter | Description |
---|---|
transactiondetails Transaction Details Object (required)_ | Unique transaction ID |
itemdetails Item Details Object (optional)_ | Shopping item details will be paid by customer |
customerdetails Customer Details Object (optional)_ | Details of the customer |
enabledpayments _Array (optional) | Set what payment method to show in Snap's payment list. Value: bni_va |
bniva BNI Virtual Account (optional)_ | BNI Virtual Account payment options |
For a full list of request body parameters please refer to the Request Body (JSON Parameter) section
Note: Please also refer to the Custom VA Number section if you're looking to define your own VA number for your customers.