2011-05-04 17:02:56 +01:00
|
|
|
|
2013-02-17 00:39:15 -05:00
|
|
|
// https://en.bitcoin.it/wiki/Base58Check_encoding
|
|
|
|
|
|
|
|
var BigInteger = require('./jsbn/jsbn');
|
|
|
|
|
|
|
|
var alphabet = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz";
|
|
|
|
var base = BigInteger.valueOf(58);
|
|
|
|
|
|
|
|
var positions = {};
|
|
|
|
for (var i=0 ; i < alphabet.length ; ++i) {
|
|
|
|
positions[alphabet[i]] = i;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Convert a byte array to a base58-encoded string.
|
|
|
|
// Written by Mike Hearn for BitcoinJ.
|
|
|
|
// Copyright (c) 2011 Google Inc.
|
|
|
|
// Ported to JavaScript by Stefan Thomas.
|
|
|
|
module.exports.encode = function (input) {
|
|
|
|
var bi = BigInteger.fromByteArrayUnsigned(input);
|
|
|
|
var chars = [];
|
|
|
|
|
|
|
|
while (bi.compareTo(base) >= 0) {
|
|
|
|
var mod = bi.mod(base);
|
|
|
|
chars.push(alphabet[mod.intValue()]);
|
|
|
|
bi = bi.subtract(mod).divide(base);
|
|
|
|
}
|
|
|
|
chars.push(alphabet[bi.intValue()]);
|
|
|
|
|
|
|
|
// Convert leading zeros too.
|
|
|
|
for (var i = 0; i < input.length; i++) {
|
2012-01-11 02:40:45 +01:00
|
|
|
if (input[i] == 0x00) {
|
2013-02-17 00:39:15 -05:00
|
|
|
chars.push(alphabet[0]);
|
2012-01-11 02:40:45 +01:00
|
|
|
} else break;
|
2013-02-17 00:39:15 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
return chars.reverse().join('');
|
|
|
|
},
|
|
|
|
|
|
|
|
// decode a base58 string into a byte array
|
|
|
|
// input should be a base58 encoded string
|
|
|
|
// @return Array
|
|
|
|
module.exports.decode = function (input) {
|
|
|
|
|
|
|
|
var base = BigInteger.valueOf(58);
|
|
|
|
|
|
|
|
var length = input.length;
|
|
|
|
var num = BigInteger.valueOf(0);
|
|
|
|
var leading_zero = 0;
|
|
|
|
var seen_other = false;
|
|
|
|
for (var i=0; i<length ; ++i) {
|
|
|
|
var char = input[i];
|
|
|
|
var p = positions[char];
|
|
|
|
|
|
|
|
// if we encounter an invalid character, decoding fails
|
|
|
|
if (p === undefined) {
|
|
|
|
throw new Error('invalid base58 string: ' + input);
|
2012-01-11 02:40:45 +01:00
|
|
|
}
|
2011-05-04 17:02:56 +01:00
|
|
|
|
2013-02-17 00:39:15 -05:00
|
|
|
num = num.multiply(base).add(BigInteger.valueOf(p));
|
|
|
|
|
|
|
|
if (char == '1' && !seen_other) {
|
|
|
|
++leading_zero;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
seen_other = true;
|
2012-01-11 02:40:45 +01:00
|
|
|
}
|
2013-02-17 00:39:15 -05:00
|
|
|
}
|
2011-05-04 17:02:56 +01:00
|
|
|
|
2013-02-17 00:39:15 -05:00
|
|
|
var bytes = num.toByteArrayUnsigned();
|
2011-05-04 17:02:56 +01:00
|
|
|
|
2013-02-17 00:39:15 -05:00
|
|
|
// remove leading zeros
|
|
|
|
while (leading_zero-- > 0) {
|
|
|
|
bytes.unshift(0);
|
|
|
|
}
|
|
|
|
|
|
|
|
return bytes;
|
|
|
|
}
|
2011-09-26 21:28:13 +01:00
|
|
|
|