solutaut
Version:
Multicoin address validator for Bitcoin and other Altcoins.
134 lines (125 loc) • 3.75 kB
JavaScript
var jsSHA = require('jssha');
var sha512256 = require('js-sha512').sha512_256
var Blake256 = require('./blake256');
var keccak256 = require('./sha3')['keccak256'];
var Blake2B = require('./blake2b');
var base58 = require('./base58');
var base32 = require('./base32');
var BigNum = require('browserify-bignum');
var Buffer = require('buffer/').Buffer
function numberToHex(number, length) {
var hex = number.toString(16);
if (hex.length % 2 === 1) {
hex = '0' + hex;
}
return hex.padStart(length, '0');
}
function isHexChar(c) {
if ((c >= 'A' && c <= 'F') ||
(c >= 'a' && c <= 'f') ||
(c >= '0' && c <= '9')) {
return 1;
}
return 0;
}
/* Convert a hex char to value */
function hexChar2byte(c) {
var d = 0;
if (c >= 'A' && c <= 'F') {
d = c.charCodeAt(0) - 'A'.charCodeAt(0) + 10;
}
else if (c >= 'a' && c <= 'f') {
d = c.charCodeAt(0) - 'a'.charCodeAt(0) + 10;
}
else if (c >= '0' && c <= '9') {
d = c.charCodeAt(0) - '0'.charCodeAt(0);
}
return d;
}
/* Convert a byte to string */
function byte2hexStr(byte) {
var hexByteMap = "0123456789ABCDEF";
var str = "";
str += hexByteMap.charAt(byte >> 4);
str += hexByteMap.charAt(byte & 0x0f);
return str;
}
function byteArray2hexStr(byteArray) {
var str = "";
for (var i = 0; i < (byteArray.length - 1); i++) {
str += byte2hexStr(byteArray[i]);
}
str += byte2hexStr(byteArray[i]);
return str;
}
function hexStr2byteArray(str) {
var byteArray = Array();
var d = 0;
var i = 0;
var j = 0;
var k = 0;
for (i = 0; i < str.length; i++) {
var c = str.charAt(i);
if (isHexChar(c)) {
d <<= 4;
d += hexChar2byte(c);
j++;
if (0 === (j % 2)) {
byteArray[k++] = d;
d = 0;
}
}
}
return byteArray;
}
module.exports = {
numberToHex: numberToHex,
toHex: function (arrayOfBytes) {
var hex = '';
for (var i = 0; i < arrayOfBytes.length; i++) {
hex += numberToHex(arrayOfBytes[i]);
}
return hex;
},
sha256: function (payload, format = 'HEX') {
var sha = new jsSHA('SHA-256', format);
sha.update(payload);
return sha.getHash(format);
},
sha256x2: function (buffer, format = 'HEX') {
return this.sha256(this.sha256(buffer, format), format);
},
sha256Checksum: function (payload) {
return this.sha256(this.sha256(payload)).substr(0, 8);
},
sha512_256: function (payload, format = 'HEX') {
const hash = sha512256.create()
hash.update(Buffer.from(payload, format))
return hash.hex().toUpperCase();
},
blake256: function (hexString) {
return new Blake256().update(hexString, 'hex').digest('hex');
},
blake256Checksum: function (payload) {
return this.blake256(this.blake256(payload)).substr(0, 8);
},
blake2b: function (hexString, outlen) {
return new Blake2B(outlen).update(Buffer.from(hexString, 'hex')).digest('hex');
},
keccak256: function (hexString) {
return keccak256(hexString);
},
keccak256Checksum: function (payload) {
return keccak256(payload).toString().substr(0, 8);
},
blake2b256: function (hexString) {
return new Blake2B(32).update(Buffer.from(hexString, 'hex'), 32).digest('hex');
},
base58: base58.decode,
byteArray2hexStr: byteArray2hexStr,
hexStr2byteArray: hexStr2byteArray,
bigNumberToBuffer: function(bignumber, size){
return new BigNum(bignumber).toBuffer({ size, endian: 'big' });
},
base32: base32
}