const ALPHABET = "123456789ABCDEFGHJKLMNPQRSTUVWXYZabcdefghijkmnopqrstuvwxyz"; const BASE_MAP = Buffer.alloc(256); for (let j = 0; j < BASE_MAP.length; j++) { BASE_MAP[j] = 255; } for (let i = 0; i < ALPHABET.length; i++) { let x = ALPHABET.charAt(i); let xc = x.charCodeAt(0); if (BASE_MAP[xc] !== 255) { throw new TypeError(`${x} is ambiguous`); } BASE_MAP[xc] = i; } const BASE = ALPHABET.length; const LEADER = ALPHABET.charAt(0); const FACTOR = Math.log(BASE) / Math.log(256); // log(BASE) / log(256), rounded up const iFACTOR = Math.log(256) / Math.log(BASE); // log(256) / log(BASE), rounded up function encode(source: Buffer) { if (source.length === 0) { return ""; } // Skip & count leading zeroes. let zeroes = 0; let length = 0; let pbegin = 0; let pend = source.length; while (pbegin !== pend && source[pbegin] === 0) { pbegin++; zeroes++; } // Allocate enough space in big-endian base58 representation. let size = ((pend - pbegin) * iFACTOR + 1) >>> 0; let b58 = Buffer.alloc(size); // Process the bytes. while (pbegin !== pend) { let carry = source[pbegin]; // Apply "b58 = b58 * 256 + ch". let i = 0; for ( let it1 = size - 1; (carry !== 0 || i < length) && it1 !== -1; it1--, i++ ) { carry += (256 * b58[it1]) >>> 0; b58[it1] = carry % BASE >>> 0; carry = (carry / BASE) >>> 0; } if (carry !== 0) { throw new Error("Non-zero carry"); } length = i; pbegin++; } // Skip leading zeroes in base58 result. let it2 = size - length; while (it2 !== size && b58[it2] === 0) { it2++; } // Translate the result into a string. let str = LEADER.repeat(zeroes); for (; it2 < size; ++it2) { str += ALPHABET.charAt(b58[it2]); } return str; } function decode(source: string) { if (source.length === 0) return Buffer.alloc(0); let psz = 0; // Skip leading spaces. if (source[psz] === " ") throw Error("Leading space"); // Skip and count leading '1's. let zeroes = 0; let length = 0; while (source[psz] === LEADER) { zeroes++; psz++; } // Allocate enough space in big-endian base256 representation. let size = ((source.length - psz) * FACTOR + 1) >>> 0; // log(58) / log(256), rounded up. let b256 = new Uint8Array(size); // Process the characters. while (source[psz]) { // Decode character const charCode = source.charCodeAt(psz); let carry = charCode < BASE_MAP.length ? BASE_MAP[charCode] : 255; // Invalid character if (carry === 255) throw Error("Invalid character"); let i = 0; for ( let it3 = size - 1; (carry !== 0 || i < length) && it3 !== -1; it3--, i++ ) { carry += (BASE * b256[it3]) >>> 0; b256[it3] = carry % 256 >>> 0; carry = (carry / 256) >>> 0; } if (carry !== 0) { throw new Error("Non-zero carry"); } length = i; psz++; } // Skip trailing spaces. if (source[psz] === " ") throw Error("Trailing space"); // Skip leading zeroes in b256. let it4 = size - length; while (it4 !== size && b256[it4] === 0) { it4++; } let vch = Buffer.allocUnsafe(zeroes + (size - it4)); vch.fill(0x00, 0, zeroes); let j = zeroes; while (it4 !== size) { vch[j++] = b256[it4++]; } return vch; } const Base58 = { encode, decode }; export default Base58;