123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263 |
- var bs58check = require('bs58check')
- function decodeRaw (buffer, version) {
- // check version only if defined
- if (version !== undefined && buffer[0] !== version) throw new Error('Invalid network version')
- // uncompressed
- if (buffer.length === 33) {
- return {
- version: buffer[0],
- privateKey: buffer.slice(1, 33),
- compressed: false
- }
- }
- // invalid length
- if (buffer.length !== 34) throw new Error('Invalid WIF length')
- // invalid compression flag
- if (buffer[33] !== 0x01) throw new Error('Invalid compression flag')
- return {
- version: buffer[0],
- privateKey: buffer.slice(1, 33),
- compressed: true
- }
- }
- function encodeRaw (version, privateKey, compressed) {
- var result = new Buffer(compressed ? 34 : 33)
- result.writeUInt8(version, 0)
- privateKey.copy(result, 1)
- if (compressed) {
- result[33] = 0x01
- }
- return result
- }
- function decode (string, version) {
- return decodeRaw(bs58check.decode(string), version)
- }
- function encode (version, privateKey, compressed) {
- if (typeof version === 'number') return bs58check.encode(encodeRaw(version, privateKey, compressed))
- return bs58check.encode(
- encodeRaw(
- version.version,
- version.privateKey,
- version.compressed
- )
- )
- }
- module.exports = {
- decode: decode,
- decodeRaw: decodeRaw,
- encode: encode,
- encodeRaw: encodeRaw
- }
|