BCA v1.0

DOKU has partnered with various banks and one of them is BCA to provide Virtual Account Payment. Learn more about how DOKU can help you integrate with BCA Virtual Account here.

Integration methods

There are two methods to integrate with BCA VA:

  1. Create VA: The VA number will be registered to DOKU and Acquirer will inquiry to our side when the customer make payment at the acquirer channel (ATM, mobile banking, internet banking, etc.)

    1. DOKU Generated Payment Code (DGPC): The VA number is generated by DOKU. Suitable for e-commerce business model.

    2. Merchant Generated Payment Code (MGPC): The VA number is generated by Merchant. Suitable for top up business model.

  2. Direct Inquiry (DIPC): The VA number is registered on merchant side and DOKU will forward Acquirer inquiry request to merchant side when the customer make payment at the acquirer channel (ATM, mobile banking, internet banking, etc.)

Integration Steps

Precondition

Get Token API

As client who hit DOKU's API such as Create VA, you need to obtain an access token first. Learn how to do it in this section.

Generate Signature

X- SIGNATURE is a security parameter that needs to be generated on merchant's Backend to verify the request authenticity.

So, it's very crucial for merchant to generate the X-SIGNATURE. Learn how to do it in this section

Here is the overview of how to integrate with Virtual Account:


1. Create VA

To create VA, you will need to hit this API through your Backend:

API Endpoint

TypeValue

Service Code

27

HTTP Method

POST

API Endpoint Sandbox

https://api-sandbox.doku.com/.../

API Endpoint Production

https://api.doku.com/..../

Path

/virtual-accounts/bi-snap-va/v1/transfer-va/create-va

Here is the sample request header, request body and response body for BCA VA

a. DOKU Generate Payment Code

Check this flow diagram to get know about this method

DOKU Generate Payment Code

Request Header

ParameterTypeMandatoryDescription

X- TIMESTAMP

String

Mandatory

Client's current local time in yyyy-MM-ddTHH:mm:ssZ format

X-SIGNATURE

String

Mandatory

Algorithm symmetric signature HMAC_SHA2512(clientSecret, stringToSign) Refer to this Docs

X-PARTNER-ID

String

Mandatory

Unique ID for a partner (Merchant Client ID )

X-EXTERNAL-ID

String

Mandatory

Numeric string. Reference number that should be unique in the same day ( request-id)

CHANNEL-ID

String

Mandatory

channel ID for VA

Authorization

String

Mandatory

Bearer "access token" obtainedn from Get B2B Token API , refer to this Docs

DOKU Generate Payment Code

DOKU Generate Payment Code

POSThttps://{api-domain}/virtual-accounts/bi-snap-va/v1/transfer-va/create-va
Header parameters
Body

Create VA SNAP request

partnerServiceId*string

similar to company code/BIN,8 digit left padding space. | Mandatory | min length: 1 | max length: 8

Example: " 190080"
virtualAccountName*string

Customer Name. | Mandatory | min length: 1 | max length: 255

Example: "Toru Yamashita"
virtualAccountEmailstring

Customer Email | min length: 1 | max length: 255

Example: "toru@oor.com"
virtualAccountPhonestring

Customer Phone, Format: 62xxxxxxxxx xxxx | min length: 9 | max length: 30

Example: "0816291271826"
trxId*string

Invoice number in Partner system. | Mandatory | min length: 1 | max length: 64

Example: "23219829713"
totalAmount*TotalAmountRef (object)
additionalInfoAdditionalInfoCreateVARequestRef (object)
virtualAccountTrxType*VirtualAccountTrxTypeRef (string)

Transaction ID in Partner system. 1 (Closed Payment) & 2 (Open Payment) | Mandatory | min length: 1 | max length: 1

Example: "1"
expiredDatestring

Expiration date for Virtual Account. ISO-8601

Example: "2023-01-01T10:55:00+07:00"
Response

item created

Body
responseCode*string

Response Code with format HTTP status code + service code + case code. service code and status code refer to: https://developers.doku.com/getting-started-with-doku-api/error-handling/http-status-and-case-code#id-1.-virtual-account . | Mandatory | min length: 1 | max length: 7.

Example: "2002700"
responseMessage*string

Response Description. | min length: 1 | max length: 150

Example: "Successful"
virtualAccountDataobject
Request
const response = await fetch('https://{api-domain}/virtual-accounts/bi-snap-va/v1/transfer-va/create-va', {
    method: 'POST',
    headers: {
      "X-TIMESTAMP": "2024-03-19T14:39:01+07:00",
      "X-SIGNATURE": "85be817c55b2c135157c7e89f52499bf0c25ad6eeebe04a986e8c862561b19a5",
      "X-PARTNER-ID": "BRN-0259-1678068334526",
      "X-EXTERNAL-ID": "418075533589",
      "CHANNEL-ID": "VA001",
      "Authorization": "Bearer eyJhbGciOiJSUzI1NiJ9.eyJleHAiOjE2OTgwNTA3NDMsImlzcyI6IkRPS1UiLCJjbGllbnRJZCI6IkJSTi0wMjExLTE2OTY5MTk2NTE5MTgifQ.x-D5VlK6TlVZbLPUSCr-Gbfgh4tnp0QDJmedYFHJGHFjg1c4x39pszU4sLvRhr0Jk0vKdMIzxUZeNhKoesWqDJitnG3kfrNZNsMb_WYUC0tJW91onXzYOKXiTgsHwRNFoWPQHlXIEtT3RQm-SRlCpk_E0gsavgkQn2-kbJEBnPhIs4eKg5IUY9GYi4hRr-_GHsudDl8sd2B5UBB_rHYq36BRmLXH7i7MQADHPsB1ktPVgk3ZWF0jebEjI-lJ88p-omL1vQNvRseXej2HKBa9chGLmPDvXYBQaRmmstHz-tv1boFrHfwsHJebcUec-i3WE1vMvP_3EPXdbqb45N4ciQ",
      "Content-Type": "application/json"
    },
    body: JSON.stringify({
      "partnerServiceId": "  190080",
      "virtualAccountName": "Toru Yamashita",
      "trxId": "23219829713",
      "virtualAccountTrxType": "1",
      "totalAmount": {
        "value": "11500.00",
        "currency": "IDR"
      }
    }),
});
const data = await response.json();
Response
{
  "responseCode": "2002700",
  "responseMessage": "Successful",
  "virtualAccountData": {
    "partnerServiceId": "  190080",
    "customerNo": "00000000000000000001",
    "virtualAccountNo": "  19008000000000000000000001",
    "virtualAccountName": "Toru Yamashita",
    "virtualAccountEmail": "toru@oor.com",
    "virtualAccountPhone": "081293912081",
    "trxId": "23219829713",
    "totalAmount": {
      "value": "11500.00",
      "currency": "IDR"
    },
    "virtualAccountTrxType": "1",
    "expiredDate": "2023-01-01T10:55:00+07:00",
    "additionalInfo": {
      "channel": "VIRTUAL_ACCOUNT_BCA",
      "howToPayPage": "https://app.doku.com/how-to-pay/virtual-account/mandiri/9596260000000005321/2226240319101120691107165798734001192511",
      "howToPayApi": "https://api.doku.com/pay-instruction/mandiri/9596260000000005321/2226240319101120691107165798734001192511"
    }
  }
}

Learn what are the response codes!

b. Merchant Generate Payment Code

Check this flow diagram to get know about this method

Merchant Generate Payment Code

Request Header

ParameterTypeMandatoryDescription

X- TIMESTAMP

String

Mandatory

Client's current local time in yyyy-MM-ddTHH:mm:ssZ format

X-SIGNATURE

String

Mandatory

Algorithm symmetric signature HMAC_SHA2512(clientSecret, stringToSign) Refer to this Docs

X-PARTNER-ID

String

Mandatory

Unique ID for a partner (Merchant Client ID )

X-EXTERNAL-ID

String

Mandatory

Numeric string. Reference number that should be unique in the same day ( request-id)

CHANNEL-ID

String

Mandatory

channel ID for VA

Authorization

String

Mandatory

Bearer "access token" obtainedn from Get B2B Token API , refer to this Docs

Learn what are the response codes!

Pro Tips!

  1. You can also show payment instruction link to your customer by using additionalInfo.howToPayPage

  2. If you wish to customize the UI for the payment instruction, you can use the additionalInfo.howToPayApi

c. Display Virtual Account

You can display the payment code to your customer by using virtualAccountData.virtualAccountNo that you retrieved from the API response.

d. Acknowledge payment result

After the payment is being made by your customer, DOKU will send HTTP Notification to your defined Notification URL. Learn how to handle the notification from DOKU .

e. Hit DOKU Check Status API

If you do not receive notifications from DOKU due to some issue, you can perform an API status check on the DOKU side to determine the updated transaction status. See the detailed request and response here Check Status API.


f. Delete Payment Code

If you wish to delete your virtual account, you can do that by hitting the API with this API :

Request Header

ParameterTypeMandatoryDescription

X- TIMESTAMP

String

Mandatory

Client's current local time in yyyy-MM-ddTHH:mm:ssZ format

X-SIGNATURE

String

Mandatory

Algorithm symmetric signature HMAC_SHA2512(clientSecret, stringToSign) Refer to this Docs

X-PARTNER-ID

String

Mandatory

Unique ID for a partner (Merchant Client ID )

X-EXTERNAL-ID

String

Mandatory

Numeric string. Reference number that should be unique in the same day ( request-id)

CHANNEL-ID

String

Mandatory

channel ID for VA

Authorization

String

Mandatory

Bearer "access token" obtainedn from Get B2B Token API , refer to this Docs

g. Update Payment Code

If you wish to update your virtual account, you can do that by hitting the API with this API :

Request Header

ParameterTypeMandatoryDescription

X- TIMESTAMP

String

Mandatory

Client's current local time in yyyy-MM-ddTHH:mm:ssZ format

X-SIGNATURE

String

Mandatory

Algorithm symmetric signature HMAC_SHA2512(clientSecret, stringToSign) Refer to this Docs

X-PARTNER-ID

String

Mandatory

Unique ID for a partner (Merchant Client ID )

X-EXTERNAL-ID

String

Mandatory

Numeric string. Reference number that should be unique in the same day ( request-id)

CHANNEL-ID

String

Mandatory

channel ID for VA

Authorization

String

Mandatory

Bearer "access token" obtainedn from Get B2B Token API , refer to this Docs


Additional Feature

Open Payment

DOKU supports open payment meaning that your customer can input their own payment amount. To use open amount, you need to set virtualAccountTrxType = 2 and you need to send totalAmount.value = 0and totalAmount.currency = IDR DOKU. Here is the sample:

{
    "partnerServiceId": "  888994",
        ...
    "totalAmount": {
        "value": "0",
        "currency": "IDR"
      },
      ...
    "virtualAccountTrxType": "2",
    ...
}

2. Direct Inquiry

TypeValue

Service Code

24

HTTP Method

POST

API Endpoint Sandbox

https://api-sandbox.doku.com/.../

API Endpoint Production

https://api.doku.com/..../

Path

/virtual-accounts/bi-snap-va/v1/transfer-va/create-va

Here is the overview of how to integrate Direct Inquiry BCA VA :

Check this flow to diagram to get know about this API :

Direct Inquiry

To get Inquiry Request from DOKU, you will need to hit this API through your Backend:

a. Setup Inquiry URL on DOKU Dashboard

To receive the inquiry request from DOKU. You must set your Inquiry URL to DOKU. Please contact our team for the setup.

Please inform the Inquiry URL for Sandbox environment and Production environment.

b. Generate Payment Code on your end

Generate payment is done in your system. The payment code length maximum is 23 digits.

c. Receive Inquiry Request from DOKU

Here is the sample request header, request body from DOKU

Request Header

ParameterTypeMandatoryDescription

X- TIMESTAMP

String

Mandatory

Client's current local time in yyyy-MM-ddTHH:mm:ssZ format

X-SIGNATURE

String

Mandatory

Algorithm symmetric signature HMAC_SHA2512(clientSecret, stringToSign) Refer to this Docs

X-PARTNER-ID

String

Mandatory

Unique ID for a partner (Merchant Client ID )

X-EXTERNAL-ID

String

Mandatory

Numeric string. Reference number that should be unique in the same day ( request-id)

CHANNEL-ID

String

Mandatory

channel ID for VA

Authorization

String

Mandatory

Bearer "access token" obtainedn from Get B2B Token API , refer to this Docs

d. Acknowledge payment notification

After the payment is being made by your customer, DOKU will send HTTP Notification to your defined Notification URL. Learn how to handle the notification from DOKU .

e. Hit DOKU Check Status API

If you do not receive notifications from DOKU due to some issue, you can perform an API status check on the DOKU side to determine the updated transaction status. See the detailed request and response here Check Status API.


Last updated