bitaddress.org/src/bs58.js
2017-10-26 23:00:20 +11:00

74 lines
No EOL
1.9 KiB
JavaScript

// Base58 encoding/decoding
// Originally written by Mike Hearn for BitcoinJ
// Copyright (c) 2011 Google Inc
// Ported to JavaScript by Stefan Thomas
// Merged Buffer refactorings from base58-native by Stephen Pair
// Copyright (c) 2013 BitPay Inc
var ALPHABET = '123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz'
var ALPHABET_MAP = {}
for(var i = 0; i < ALPHABET.length; i++) {
ALPHABET_MAP[ALPHABET.charAt(i)] = i
}
var BASE = 58
function bs58_encode(buffer) {
if (buffer.length === 0) return ''
var i, j, digits = [0]
for (i = 0; i < buffer.length; i++) {
for (j = 0; j < digits.length; j++) digits[j] <<= 8
digits[digits.length - 1] += buffer[i]
var carry = 0
for (j = digits.length - 1; j >= 0; j--){
digits[j] += carry
carry = (digits[j] / BASE) | 0
digits[j] %= BASE
}
while (carry) {
digits.unshift(carry)
carry = (digits[0] / BASE) | 0
digits[0] %= BASE
}
}
// deal with leading zeros
for (i = 0; i < buffer.length - 1 && buffer[i] == 0; i++) digits.unshift(0)
return digits.map(function(digit) { return ALPHABET[digit] }).join('')
}
function bs58_decode(string) {
if (string.length === 0) return 0
var input = string.split('').map(function(c){
//assert.notEqual(ALPHABET_MAP[c], undefined, 'Non-base58 character')
return ALPHABET_MAP[c]
})
var i, j, bytes = [0]
for (i = 0; i < input.length; i++) {
for (j = 0; j < bytes.length; j++) bytes[j] *= BASE
bytes[bytes.length - 1] += input[i]
var carry = 0
for (j = bytes.length - 1; j >= 0; j--){
bytes[j] += carry
carry = bytes[j] >> 8
bytes[j] &= 0xff
}
while (carry) {
bytes.unshift(carry)
carry = bytes[0] >> 8
bytes[0] &= 0xff
}
}
// deal with leading zeros
for (i = 0; i < input.length - 1 && input[i] == 0; i++) bytes.unshift(0)
return bytes
}