vietqrjs
v1.1.3
Published
Support generate VietQR Code
Downloads
43
Maintainers
Readme
Overview
This library be implemented follow the VietQR specified document from NAPAS on vietqr.net
Vietqrjs library supports some features:
- Create QR string|code from data: account number, account name, bank ID, bank name, transaction amount, description ...
- Decrypt an QR string (string read from QR code image) to get information for payment.(from v1.1.0)
Vietqrjs supports 4 service types:
Cash withdraw service (QRCASH)
Products payment service (QRPUSH)
transfer by account number (QRIBFTTA)
transfer by card number (QRIBFTTC)
Buy me a coffee
If you feel my lib is useful, buy me a coffee, thanks! MoMo Wallet transfer QR code:
Change Logs:
v1.1.3
- Update donation information :)
v1.1.2
- Add the 2nd parameter for VietQrV1Decryptor decrypt function to support return lean|full decrypted QR data object
- Set the setmerchantCategoryCode and getQrCodeString function in VietQRV1Builder class is deprecated, instead by setMerchantCategoryCode and getQrString function
- Update function generateQR of VietQRV1Builder class
- Update docs on README
v1.1.1
- Fixed some bugs related to function check valid CRC code of QR string in Decryptor class
v1.1.0
- Add VietQrV1Decryptor to support decrypt QR string to get Merchant/Consumer information.
- Update Unit tests for VietQRV1Builder and VietQrV1Decryptor functions
v1.0.2
- Add new service codes: QRPUSH and QRCASH
Installation
npm i --save vietqrjs
Interfaces
interface IVietQrDataV1
interface IVietQrDataV1 {
version: VietQrVersion; // ID 00
initMethod: VietQrInitiateMethod; // ID 01
merchantAccInfo: IMerchantAccountInfo; // ID = 38
merchantCategoryCode?: MerchantCategoryCode | string | null | undefined; // ID 52
txnCurrency: number; // ID 53
txnAmount?: string; // ID 54
tipConvenienceIndicator?: TipOrConvenienceIndicatorType | string | null | undefined; // ID 55
convenienceFeeFixed?: StringOrNot; // ID 56
convenienceFeePercentage?: StringOrNot; // ID 57
countryCode: string; // ID 58
merchantName?: StringOrNot; // ID 59
merchantCity?: StringOrNot; // ID 60
postalCode?: StringOrNot; // ID 61
additionalData?: IAdditionalData | null | undefined; // ID 62
languageTemplate?: ILanguageTemplate | null | undefined; // ID 64
crcCode: string; // ID 63
}
interface IBasicVietQrData
interface IBasicVietQrData {
acquierId: BankBIN; // ID DVCNTT
merchantId: string; // Tài khoản/Số thẻ thụ hưởng
serviceCode?: ServiceCode;
amount?: number;
txnDescription?: string;
}
interface IMerchantAccountInfo
interface IMerchantAccountInfo {
guid?: GUID | string; // ID 38 - 00 (Required Field)
beneficiaryOrg: IBeneficiaryOrganiation; // ID 38 - 01 (Required Field)
serviceCode?: ServiceCode; // ID 38 - 02 (Conditional Field)
}
interface IBeneficiaryOrganiation
interface IBeneficiaryOrganiation {
acquierId: BankBIN | string; // ID 38 - 01 - 00 (Required Field)
merchantId: string; // ID 38 - 01 - 01 (Required Field)
}
interface IAdditionalData
interface IAdditionalData {
billNumber?: StringOrNot; // ID 62 - 01 (Conditional Field)
mobileNumber?: StringOrNot; // ID 62 - 02 (Conditional Field)
storeLabel?: StringOrNot; // ID 62 - 03 (Optional Field)
loyaltyNumber?: StringOrNot; // ID 62 - 04 (Optional Field)
referenceLabel?: StringOrNot; // ID 62 - 05 (Conditional Field)
customerLabel?: StringOrNot; // ID 62 - 06 (Conditional Field)
terminalLabel?: StringOrNot; // ID 62 - 07 (Optional Field)
purposeOfTxn?: StringOrNot; // ID 62 - 08 (Conditional Field)
additionalConsumerDataReq?: StringOrNot; // ID 62 - 09 (Optional Field)
}
interface ILanguageTemplate
interface ILanguageTemplate {
preference: string; // ID 64 - 00 (Required Field)
merchantName: string; // ID 64 - 01 (Required Field)
merchantCity?: StringOrNot; // ID 64 - 02 (Optional Field)
}
interface IDecryptedQrDataOptions
interface IDecryptedQrDataOptions {
/**
* Remove all decrypted data object fields is optional and have value is empty or undefined
* @default true
*/
lean?: boolean;
}
interface
interface IGenerateQROptions {
logo?: string; // path to image file or base64 image string, if null will be render vietQR logo
margin?: number; // margin of QR code and image frame. default is 4
width?: number; // width of canvas object to draw QR code // default is 250
bgColor?: string; // background color of QR code - default is '#ffffff'
color?: string; // color of QR code - default is '#000000'
errorCorrectionLevel?: 'L' | 'M' | 'Q' | 'H'; // default is 'H'
}
Usage
VietQRV1Builder
Functions:
- quickBuild(data; IBasicVietQrData): VietQRV1Builder; // quick build QR string from minimum required VietQR data
- getQrString(): string; // Get the result of quickbuild or build function from builder
- build(): VietQRV1Builder; // build the QR string after set some VietQR data
- refresh(): VietQRV1Builder; // Refresh VietQR data of builder to initialization
- getQrCodeString(): string; // (deprecated) // Get the result of quickbuild or build function from builder
- generateQR(options?: IGenerateQROptions): string; // generate base64 QR image
- setMerchantAccountInfo(data: IMerchantAccountInfo): VietQRV1Builder;
- setMerchantName(merchantName: string): VietQRV1Builder;
- setMerchantCity(merchantCity: string): VietQRV1Builder;
- setTxnCurrency(currencyCode: number): VietQRV1Builder;
- setTxnCountry(countryCode: string): VietQRV1Builder;
- setMerchantCategoryCode(mcc: string): VietQRV1Builder;
- setAdditionalData(data: IAdditionalData): VietQRV1Builder;
- setLanguageTemplate(template: ILanguageTemplate): VietQRV1Builder;
- setTxnDescription(description: string): VietQRV1Builder;
- setTxnAmount(amount: number): VietQRV1Builder;
- setPostalCode(postalCode: string): VietQRV1Builder;
Quick generate QR string
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const builder = new VietQRV1Builder();
const qrDataString = builder.quickBuild({ // IBasicVietQrData
acquierId: BankBIN.VIETINBANK, // ID DVCNTT
merchantId: '', // Account number
serviceCode: ServiceCode.BY_ACCOUNT_NUMBER,
}).getQrString();
Build an QR string to render static QR code with account number
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const builder = new VietQRV1Builder();
const qrDataStr = builder.setMerchantAccountInfo({
// IMerchantAccountInfo
beneficiaryOrg: { // IBeneficiaryOrganiation
acquierId: BankBIN.VIETCOMBANK,
merchantId: '03123445xxx', // account number
},
serviceCode: ServiceCode.BY_ACCOUNT_NUMBER,
})
.build()
.getQrString();
Build an QR string to render static QR code with card number
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const builder = new VietQRV1Builder();
const qrString = builder.setMerchantAccountInfo({
beneficiaryOrg: {
acquierId: BankBIN.ACB,
merchantId: '040812344454xxx', // card number
},
serviceCode: ServiceCode.BY_CARD_NUMBER,
})
.build()
.getQrString();
Build an QR string to render QR code to cash withdrawl
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const vietqr = new VietQRV1Builder();
const qrString = vietqr.setMerchantAccountInfo({
beneficiaryOrg: {
acquierId: BankBIN.ACB,
merchantId: '12345678', // ATM ID
},
serviceCode: ServiceCode.BY_CASH_WITHDRAWL_SERVICE,
})
.setMerchantName('NGUYEN VAN A')
.setMerchantCity('HA NOI')
.setTxnCurrency()
.setTxnCountry()
.setMerchantCategoryCode(MerchantCategoryCode.FINANCIAL_INSTITUTIONS_WITH_CASH_DISBURSEMENTS)
.setAdditionalData({
referenceLabel: '201901091557142283847',
terminalLabel: '00001111',
}).build()
.getQrString();
console.log(qrString);
// expect
// 00020101021138500010A000000727012200069704160108123456780206QRCASH5204601153037045802VN5912NGUYEN VAN A6006HA NOI6237052120190109155714228384707080000111163049CE4
Build an QR string to render dynamic QR code with account number
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const builder = new VietQRV1Builder();
const qrDataStr = builder.setMerchantAccountInfo({
beneficiaryOrg: {
acquierId: BankBIN.MB_BANK,
merchantId: '03123445xxx', // account number
},
serviceCode: ServiceCode.BY_ACCOUNT_NUMBER,
})
.setTxnAmount(86000)
.setMerchantName('Cua hang tien loi') // optional
.setMerchantCity('NANOI') // optional
.setPostalCode('10000') // optional
.setTxnDescription('Thanh toan hoa don') // optional
.setAdditionalData({ // optional
billNumber: 'B123456',
storeLabel: 'NPS124',
})
.build()
.getQrString();
Build QR code from payment account information
Example:
import {VietQRV1Builder, BankBIN, ServiceCode} from 'vietqrjs';
const builder = new VietQRV1Builder();
const qrBase64Image = await builder
.quickBuild({
acquierId: BankBIN.TP_BANK, // ID DVCNTT
merchantId: '123456789', // Tài khoản/Số thẻ thụ hưởng
serviceCode: ServiceCode.BY_ACCOUNT_NUMBER,
})
.generateQR({
width: 300,
margin: 2,
color: '#555555',
bgColor: '#EEEEEE',
});
console.log(qrBase64Image);
// 
VietQrV1Decryptor (supported from v1.1.0)
Decrypt QR string to get information for payment.
Check CRC checksum of QR string
isValidChecksum(qrString: string): boolean;
Example:
import { VietQrV1Decryptor } from 'vietqrjs';
const decryptor = new VietQrV1Decryptor();
const isValid = decryptor.isValidChecksum('00020101021238500010A000000727012200069704030108123456780206QRCASH5204601153037045802VN5915NGUYEN HUU HUAN6005HANOI6105100006237052120190109155714228384707080000111164260002en0107shop vn0205Hanoi63047611');
console.log(isValid) // false
Decrypt QR string to get information for payment
decrypt(qrString: string, options?: IDecryptedQrDataOptions): IVietQrDataV1
Example:
import { VietQrV1Decryptor } from 'vietqrjs';
const decryptor = new VietQrV1Decryptor();
// decrypt QR string and get full fields QR data
const qrData = decryptor.decrypt(
'00020101021238500010A000000727012200069704030108123456780206QRCASH5204601153037045802VN5915NGUYEN HUU HUAN6005HANOI6105100006237052120190109155714228384707080000111164260002en0107shop vn0205Hanoi630476DA',
{ lean: false },
);
console.log(qrData);
// {
// version: '01',
// initMethod: '12',
// merchantAccInfo: {
// guid: 'A000000727',
// beneficiaryOrg: {
// acquierId: '970403',
// merchantId: '12345678'
// },
// serviceCode: 'QRCASH'
// },
// merchantCategoryCode: '6011',
// txnCurrency: 704,
// txnAmount: undefined,
// tipConvenienceIndicator: undefined,
// convenienceFeeFixed: undefined,
// convenienceFeePercentage: undefined,
// countryCode: 'VN',
// merchantName: 'NGUYEN HUU HUAN',
// merchantCity: 'HANOI',
// postalCode: '10000',
// additionalData: {
// billNumber: undefined,
// mobileNumber: undefined,
// storeLabel: undefined,
// loyaltyNumber: undefined,
// referenceLabel: '201901091557142283847',
// customerLabel: undefined,
// terminalLabel: '00001111',
// purposeOfTxn: undefined,
// additionalConsumerDataReq: undefined
// },
// languageTemplate: {
// preference: 'en',
// merchantName: 'shop vn',
// merchantCity: 'Hanoi',
// },
// crcCode: '76DA'
// }
const leanQrData = decryptor.decrypt(
'00020101021238500010A000000727012200069704030108123456780206QRCASH5204601153037045802VN5915NGUYEN HUU HUAN6005HANOI6105100006237052120190109155714228384707080000111164260002en0107shop vn0205Hanoi630476DA',
);
console.log(leanQrData);
// {
// version: '01',
// initMethod: '12',
// merchantAccInfo: {
// guid: 'A000000727',
// beneficiaryOrg: {
// acquierId: '970403',
// merchantId: '12345678'
// },
// serviceCode: 'QRCASH'
// },
// merchantCategoryCode: '6011',
// txnCurrency: 704,
// countryCode: 'VN',
// merchantName: 'NGUYEN HUU HUAN',
// merchantCity: 'HANOI',
// postalCode: '10000',
// additionalData: {
// referenceLabel: '201901091557142283847',
// terminalLabel: '00001111',
// },
// languageTemplate: {
// preference: 'en',
// merchantName: 'shop vn',
// merchantCity: 'Hanoi',
// },
// crcCode: '76DA'
// }