BchAddr.js: Bitcoin Cash general purpose address translation for Node.js and web browsers.
Plug & Play JavaScript library for all Bitcoin Cash address format translation needs. Easy-to-use, thoroughly tested, and feature complete.
Support for the new Bitcoin Cash address format which improves upon BIP 173, as well as the Bitpay and Legacy formats.
Test out a demo address translator powered by BchAddr.js here.
Installation
Using NPM or Yarn
$ npm install bchaddrjs
$ yarn add bchaddrjs
Manually
You may also download the distribution file manually and place it within your third-party scripts directory: dist/bchaddrjs-0.5.2.min.js.
Usage
In Node.js
var bchaddr = require('bchaddrjs');
import bchaddr from 'bchaddrjs';
Browser
Script Tag
You may include a script tag in your HTML and the bchaddr
module will be defined globally on subsequent scripts.
<html>
<head>
...
<script src="https://unpkg.com/bchaddrjs@0.5.2/dist/bchaddrjs-0.5.2.min.js"></script>
</head>
...
</html>
Code Examples
Supported formats, networks and address types.
var Format = bchaddr.Format;
var Network = bchaddr.Network;
var Type = bchaddr.Type;
Test if a string is a valid Bitcoin Cash address of any type, in any format.
var isValidAddress = bchaddr.isValidAddress;
isValidAddress(null)
isValidAddress('')
isValidAddress('some invalid address')
isValidAddress('bc1qar0srrr7xfkvy5l643lydnw9re59gtzzwf5mdq')
isValidAddress('1B9UNtBfkkpgt8kVbwLN9ktE62QKnMbDzR')
isValidAddress('CScMwvXjdooDnGevHgfHjGWFi9cjk75Aaj')
isValidAddress('qph5kuz78czq00e3t85ugpgd7xmer5kr7c5f6jdpwk')
isValidAddress('bitcoincash:qph5kuz78czq00e3t85ugpgd7xmer5kr7c5f6jdpwk')
Note: You can use this function to check if any input is a valid Bitcoin Cash address.
Other functions in this library will throw an InvalidAddressError
on invalid inputs.
Test for address format.
var isLegacyAddress = bchaddr.isLegacyAddress;
var isBitpayAddress = bchaddr.isBitpayAddress;
var isCashAddress = bchaddr.isCashAddress;
isLegacyAddress('1B9UNtBfkkpgt8kVbwLN9ktE62QKnMbDzR')
isLegacyAddress('qph5kuz78czq00e3t85ugpgd7xmer5kr7c5f6jdpwk')
isBitpayAddress('CScMwvXjdooDnGevHgfHjGWFi9cjk75Aaj')
isBitpayAddress('1B9UNtBfkkpgt8kVbwLN9ktE62QKnMbDzR')
isCashAddress('qph5kuz78czq00e3t85ugpgd7xmer5kr7c5f6jdpwk')
isCashAddress('CScMwvXjdooDnGevHgfHjGWFi9cjk75Aaj')
Test for address network.
var isMainnetAddress = bchaddr.isMainnetAddress;
var isTestnetAddress = bchaddr.isTestnetAddress;
isMainnetAddress('1P238gziZdeS5Wj9nqLhQHSBK2Lz6zPSke')
isMainnetAddress('mnbGP2FeRsbgdQCzDT35zPWDcYSKm4wrcg')
isTestnetAddress('qqdcsl6c879esyxyacmz7g6vtzwjjwtznsggspc457')
isTestnetAddress('CeUvhjLnSgcxyedaUafcyo4Cw9ZPwGq9JJ')
Test for address type.
var isP2PKHAddress = bchaddr.isP2PKHAddress;
var isP2SHAddress = bchaddr.isP2SHAddress;
isP2PKHAddress('1Mdob5JY1yuwoj6y76Vf3AQpoqUH5Aft8z')
isP2PKHAddress('2NFGG7yRBizUANU48b4dASrnNftqsNwzSM1')
isP2SHAddress('H92i9XpREZiBscxGu6Vx3M8jNGBKqscBBB')
isP2SHAddress('CeUvhjLnSgcxyedaUafcyo4Cw9ZPwGq9JJ')
Detect address format.
var detectAddressFormat = bchaddr.detectAddressFormat;
detectAddressFormat('qqdcsl6c879esyxyacmz7g6vtzwjjwtznsggspc457')
detectAddressFormat('CScMwvXjdooDnGevHgfHjGWFi9cjk75Aaj')
Detect address network.
var detectAddressNetwork = bchaddr.detectAddressNetwork;
detectAddressNetwork('1P238gziZdeS5Wj9nqLhQHSBK2Lz6zPSke')
detectAddressNetwork('qqdcsl6c879esyxyacmz7g6vtzwjjwtznsggspc457')
Detect address type.
var detectAddressType = bchaddr.detectAddressType;
detectAddressType('1P238gziZdeS5Wj9nqLhQHSBK2Lz6zPSke')
detectAddressType('3NKpWcnyZtEKttoQECAFTnmkxMkzgbT4WX')
Translate address from any address format into a specific format.
var toLegacyAddress = bchaddr.toLegacyAddress;
var toBitpayAddress = bchaddr.toBitpayAddress;
var toCashAddress = bchaddr.toCashAddress;
toLegacyAddress('qph5kuz78czq00e3t85ugpgd7xmer5kr7c5f6jdpwk')
toBitpayAddress('1B9UNtBfkkpgt8kVbwLN9ktE62QKnMbDzR')
toCashAddress('1B9UNtBfkkpgt8kVbwLN9ktE62QKnMbDzR')
Documentation
Generate and Browse Locally
$ npm run docs
Online
Browse automatically generated jsdocs online.