UNPKG

solutaut

Version:

Multicoin address validator for Bitcoin and other Altcoins.

65 lines (55 loc) 1.93 kB
var cryptoUtils = require('./crypto/utils') var cnBase58 = require('./crypto/cnBase58') var DEFAULT_NETWORK_TYPE = 'prod' var addressRegTest = new RegExp( '^[123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz]{95}$' ) var integratedAddressRegTest = new RegExp( '^[123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz]{106}$' ) function validateNetwork(decoded, currency, networkType, addressType) { var network = currency.addressTypes if (addressType == 'integrated') { network = currency.iAddressTypes } var at = parseInt(decoded.substr(0, 2), 16).toString() switch (networkType) { case 'prod': return network.prod.indexOf(at) >= 0 case 'testnet': return network.testnet.indexOf(at) >= 0 case 'stagenet': return network.stagenet.indexOf(at) >= 0 case 'both': return network.prod.indexOf(at) >= 0 || network.testnet.indexOf(at) >= 0 || network.stagenet.indexOf(at) >= 0 default: return false } } function hextobin(hex) { if (hex.length % 2 !== 0) return null var res = new Uint8Array(hex.length / 2) for (var i = 0; i < hex.length / 2; ++i) { res[i] = parseInt(hex.slice(i * 2, i * 2 + 2), 16) } return res } module.exports = { isValidAddress: function(address, currency, opts = {}) { const { networkType = DEFAULT_NETWORK_TYPE} = opts; var addressType = 'standard' if (!addressRegTest.test(address)) { if (integratedAddressRegTest.test(address)) { addressType = 'integrated' } else { return false } } var decodedAddrStr = cnBase58.decode(address) if (!decodedAddrStr) return false if (!validateNetwork(decodedAddrStr, currency, networkType, addressType)) return false var addrChecksum = decodedAddrStr.slice(-8) var hashChecksum = cryptoUtils.keccak256Checksum(hextobin(decodedAddrStr.slice(0, -8))) return addrChecksum === hashChecksum } }