A Javascript library to identify Iranian banks based on card numbers (first 6 digits) and IBANs. It also includes utility functions to validate card numbers and IBANs using standard algorithms.
Note: This project uses part of the publicly available bank dataset from: https://github.com/masihgh/iranian-bank-list
To get started with this package, you first need to install it via npm or yarn:
npm install iranian-bank-listor
yarn add iranian-bank-listThen, you can import and use the methods in your JavaScript or TypeScript project:
import { getAllBanks, findByCardNumber, validateIbanChecksum } from 'iranian-bank-list';
const banks = getAllBanks();
const bank = findByCardNumber('6037991234567890');
const isValidIban = validateIbanChecksum('IR820540102680020817909002');
console.log(banks, bank, isValidIban);Returns an array of all bank objects with their inline SVG logos.
Returns:
Array<Object>Example:
import { getAllBanks } from 'iranian-bank-list';
const banks = getAllBanks();
console.log(banks[0]);
// {
// bank_name: "...",
// bank_logo: "<svg>...</svg>",
// card_regex: "...",
// iban_regex: "...",
// ...
// }Finds a bank object matching a given full card number using the bank's regex pattern.
Parameters:
cardNumber(string | number): The full bank card number to check.
Returns:
Object | undefined— The matching bank object orundefinedif not found.
Example:
import { getBankByCardNumber } from 'iranian-bank-list';
const bank = getBankByCardNumber('6273811234567890');
if (bank) {
console.log(bank.bank_name);
}Finds a bank object matching a given IBAN string using the bank's regex pattern.
Parameters:
iban(string): The full IBAN string to check.
Returns:
Object | undefined— The matching bank object orundefinedif not found.
Example:
import { getBankByIban } from 'iranian-bank-list';
const bank = getBankByIban('IR820540102680020817909002');
if (bank) {
console.log(bank.bank_name);
}Checks if the IBAN belongs to a known bank (using getBankByIban).
Parameters:
iban(string): The IBAN string to validate.
Returns:
boolean—trueif IBAN matches a known bank,falseotherwise.
Example:
import { validateIban } from 'iranian-bank-list';
console.log(validateIban('IR820540102680020817909002')); // true or falseValidates an Iranian bank card number using the Luhn algorithm.
Parameters:
cardNumber(string | number): The full 16-digit bank card number.
Returns:
boolean—trueif the card number is valid,falseotherwise.
Example:
import { validateIranianCard } from 'iranian-bank-list';
console.log(validateIranianCard('6273811234567890')); // true or falseValidates an IBAN string using the international standard mod-97 checksum.
Parameters:
iban(string): The full IBAN string to validate.
Returns:
boolean—trueif the IBAN checksum is valid,falseotherwise.
Example:
import { validateIbanChecksum } from 'iranian-bank-list';
console.log(validateIbanChecksum('IR820540102680020817909002')); // true or falseFinds a bank by its exact bank name (case-insensitive).
Parameters:
name(string): The bank name to search for.
Returns:
Object | undefined— Bank object if found, otherwiseundefined.
Example:
import { findByName } from './index.js';
const bank = findByName('melli');
console.log(bank);Finds a bank by full card number using the bank's card regex.
Parameters:
cardNumber(string|number): The full card number.
Returns:
Object | undefined— Bank object if found, otherwiseundefined.
Example:
import { findByCardNumber } from './index.js';
const bank = findByCardNumber('6037991234567890');
console.log(bank);Finds a bank by full IBAN number using the bank's IBAN regex.
Parameters:
iban(string): The full IBAN string.
Returns:
Object | undefined— Bank object if found, otherwiseundefined.
Example:
import { findByIBan } from './index.js';
const bank = findByIBan('IR820540102680020817909002');
console.log(bank);This project is licensed under the MIT License.
Contributions are welcome! Please see CONTRIBUTING.md for guidelines.