Getting started

Register your account

You can register by following the steps below:

  1. Access the Bangkok Bank API Developer Portal through your browser
    Homepage
  2. Select the "Register" button
    On the homepage, click on the "Register" button located at the top right corner of the screen.
  3. Fill in your information to create an account
    Registration form
  4. Confirm and submit the information
    Review the information you have entered to ensure it is complete and accurate, then click the "Create New Account" button to submit the information.

Create an app to test API

  1. Select the main menu

  2. Select "My Account" then choose "My Apps".

  3. Click the "Add Application" button
  4. Fill in the information to create a new application. For example:
    • Application Name: Enter the desired name for the application.
    • API Product: Select the desired API product to register, such as:
      • AppToApp
      • Smart Bill Payment
      • Thai QR Payment
      • Thai QR Refund
      • Thai QR Validation
    • Description: Enter the description of the app

  5. Once all details are filled in, click "Save" to create the application.
     

Test API via API Explorer

You can use API Explorer from each API product’s page to try out sandbox API.

Test API via Postman

If you wish to test out sandbox APIs using Postman, download the collections below.

App To App APIs

For more information on how to import collection using postman, please refer to the guide Import an API to Postman

Digital Signature JWT Guide

Digital Signature JWT Specification

JSON Web Tokens (JWTs) consist of three main components: the Token Header, the Token Payload, and the Signature. These components work together to encode information securely for transmission between parties.

Header

The Token Header provides information about how the JWT is signed. It typically consists of two parts: the type of the token, which is JWT, and the signing algorithm being used, which is specified in the "alg" field.

ClaimDescriptionValue
typ
(Token Type)
Indicates the type of the token. For JWT, it is set to "JWT."JWT
alg
(Algorithm)
Specifies the algorithm used for signing the token. BANGKOK BANK employs the RS256 algorithm, which is a widely used and secure asymmetric algorithm.RS256

Payload

The Token Payload contains claims. Claims are statements about an entity and additional data. BANGKOK BANK uses specific claims to convey information about the API request.

ClaimDescriptionExample
body
(Custom Data)
Data to embedded as part of the payload

Contains JSON data JWT creator want to encode as part of the Payload.
{
  "transType": "APP2APP",
  "serviceCode": "PVT4CCM",
  "billerId": "010753600037451"
}
iat
(Issued At)
Time to create token (timestamp)

The "iat" claim indicates the timestamp at which the token was issued.
1655967073

(Represents the timestamp when the token is created. For details, specification, please refer to Unix Time in the glossary section)
exp
(Expiration Time)
Now + 1 Day (timestamp)

The "exp" claim defines the expiration time for the token. It is a timestamp indicating when the token should be considered invalid.
1655995873

(Represents a timestamp one day in the future. For details, specification, please refer to Unix Time in the glossary section)
jti
(JWT ID)
UUID

The "jti" claim provides a unique identifier for the JWT.
ba7544f4-a7c5-4362-8009-51f1ab25e132

(a UUID serving as the JWT ID)

Payload Example:

{
  "exp": 1655995873,
  "iat": 1655967073,
  "jti": "ba7544f4-a7c5-4362-8009-51f1ab25e132",
  "transType": "APP2APP",
  "serviceCode": "PVT4CCM",
  "billerId": "010753600037451",
  "reference1": "1234567890123",
  "totalAmount": 100.00,
  "shopName": "shopNameApigee",
  "osPlatform": "ANDROID",
  "currencyCode": "THB",
  "shippingFee": 0.00,
  "additionalInfo": [
    {
      "name": "test",
      "value": "partner"
    }
  ],
  "partnerAppUrl": "app2app://BANGKOK BANKpartner.app/result"
}

Signature

The Signature is a crucial part of the JWT structure. It is created by combining the encoded Token Header, encoded Token Payload, and a secret key. The resulting signature is used to verify the authenticity of the JWT.

Glossary of Terms

This section provides a glossary of key terms used throughout this API specification document. Understanding these terms is crucial for effective implementation and integration of JWTs within the BANGKOK BANK API framework. The glossary is presented in a table format for clarity and quick reference, delineating each term and its specific context or definition as it applies to JWT and API interactions.

TermsDefinition
JWT
(JSON Web Token)
A compact, self-contained method for securely transmitting information as a JSON object between parties. This information can be digitally signed and verified for authenticity and integrity.
Header
(JWT Header)
The first part of a JWT, indicating the token's type (JWT) and the algorithm used for signing (e.g., RS256).
Payload
(JWT Payload)
The second part of a JWT, containing the claims, which are statements about an entity (like a user) and additional data. It includes both standard and custom claims.
Signature
(JWT Signature)
The third part of a JWT, created by encoding the header and payload and then signing it with a secret key and algorithm. This signature ensures the JWT's authenticity and integrity.
Claims
(JWT Claims)
Statements within the JWT payload about an entity and additional metadata. They include standard claims (like exp, iat, jti) and custom claims tailored to specific application needs.
Standard Claims
(JWT Standard Claims)
Predefined claim names in a JWT payload, offering a set of useful, interoperable claims. Examples include exp (expiration time), iat (issued at), and jti (JWT ID).
Custom Claims
(JWT Custom Claims)
Custom-defined claims within the JWT payload, intended for conveying application-specific information or metadata.
API Request PayloadThe data sent in an API request, formatted in JSON. It includes any necessary information for the API's processing and may also contain a JWT for authentication purposes.
JSON DataJavaScript Object Notation (JSON), a lightweight and language-independent data format used for representing structured data. Commonly used in API communication and as a format for JWT.
Unix TimeUnix time is a date and time representation widely used in computing. It measures time by the number of seconds that have elapsed since 00:00:00 UTC on 1 January 1970, the Unix epoch.

For example: The Unix time for January 1, 2024, at 00:00:00 UTC is 1704067200.

Usage in Sandbox

To generate the JWT signature for Sandbox, Our Developer portal has provided you with the utility API to easily construct a JWT signature based on the payload you are utilizing for the API calls.

Construct a POST request to our https://api-sandbox.bangkokbank.com/v1/jwt/partner endpoint.

Here's an example of the request:

curl --location "https://api-sandbox.bangkokbank.com/jwt/partner" \
--header "Content-Type: application/json" \
--header "Authorization: Bearer {{access-token}}" \
--data "{
  \"transType\": \"APP2APP\",
  \"serviceCode\": \"BBLSANDBOX\",
  \"billerId\": \"111222333456789\",
  \"reference1\": \"12345\",
  \"reference2\": \"12345678\",
  \"shippingFee\": 300.01,
  \"totalAmount\": 250111111.01,
  \"shopName\": \"shopNameTest\",
  \"shopImage\": \"UE5HDQoaCgAAAA1JSERSAAAAGAAAABgIBAAAAEp+cwAAAARnQU1BAAALYQUAAAAgY0hSTQAAeiYAAAAAAAAAAAB1MAAAYAAAOgAAF3BRPAAAAAJiS0dEAAAjMgAAAAlwSFlzAAAOAAAOASsOGwAAAAd0SU1FBwQTBTAHAAABPklEQVQ4L0xbU\",
  \"osPlatform\": \"ANDROID\",
  \"currencyCode\": \"THB\",
  \"partnerAppUrl\": \"com.bangkokbank.mobilepartnersandbox://payment\",
  \"buyerName\": \"TestBuyerName\",
}"

Ensure you replace {{access-token}} with your actual API token obtained from your Application credentials. The request body contains the payload for which you want to generate the JWT signature. Customize the payload according to your requests.

Upon successful API request, you will receive a response containing the generated JWT signature. Use this JWT signature in the appropriate headers or authentication mechanisms for subsequent API requests on our platform. The JWT signature acts as proof of authentication and authorization.

Usage in Production

Generating Private and Public Keys

  1. Generate a Private Key (Used for signing digital signatures)
    Run bash command:
    openssl genrsa -aes256 -out private_key.pem 2048
    Example:
    -----BEGIN RSA PRIVATE KEY-----
    MIIEowIBAAKCAQEAt1QfiA4ZH+HQ2RB03seKDSh8/2XeVNN/7IBzlcM7tAD2f+NY...
    -----END RSA PRIVATE KEY-----
  2. Generate a Public Key (Used for validating digital signatures)
    Run bash command:
    openssl rsa -pubout -in private_key.pem -out public_key.pem
    Example:
    -----BEGIN PUBLIC KEY-----
    MIIBIjANBgkqhkiG9w0BAQEFAAOCAQ8AMIIBCgKCAQEAt1QfiA4ZH+HQ2RB03seK...
    -----END PUBLIC KEY-----

Generating the JWT

To generate the JWT, prepare the private key and payload, then use the following example code.

Code Example in NodeJS:

const jwt = require('jsonwebtoken');
const fs = require('fs');

const privateKey = fs.readFileSync('private_key.pem', 'utf8');

const payload = {
    "transType": "APP2APP",
    "serviceCode": "PVT4CCM",
    "billerId": "010753600037451",
    "reference1": "1234567890123",
    "totalAmount": 100.00,
    "shopName": "shopNameApigee",
    "osPlatform": "ANDROID",
    "currencyCode": "THB",
    "shippingFee": 0.00,
    "additionalInfo": [ { "name": "test", "value": "partner" } ],
    "partnerAppUrl": "app2app://BANGKOK BANKpartner.app/result"
}

const token = jwt.sign(payload, privateKey, { algorithm: 'RS256', expiresIn: '1d', jwtid: "ba7544f4-a7c5-4362-8009-51f1ab25e132" });

console.log(token);

Verifying the JWT

In certain scenarios, BANGKOK BANK may require merchants to verify the JWT sent from the Bangkok Bank API Gateway. Merchants are expected to verify the token using the provided BANGKOK BANK public key to ensure the validity of the request.

Please refer to jsonwebtoken for the usage of the library.

Code Example in NodeJS:

const jwt = require('jsonwebtoken');
const fs = require('fs');

const publicKey = fs.readFileSync('public_key.pem', 'utf8');

// Replace with the received token
const token = 'recieved-token';

jwt.verify(token, publicKey, { algorithms: ['RS256'] }, (err, decoded) => {
    if (err) {
        console.error('Token verification failed:', err.message);
    } else {
        console.log('Token verified:', decoded);
    }
});