UNPKG

wifgrs

Version:

Groestlcoin Wallet Import Format (WIF) decoding/encoding module

66 lines (52 loc) 1.51 kB
var bs58grscheck = require('bs58grscheck') 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) { if (privateKey.length !== 32) throw new TypeError('Invalid privateKey length') var result = new Uint8Array(compressed ? 34 : 33) var view = new DataView(result.buffer) view.setUint8(0, version) result.set(privateKey, 1) if (compressed) { result[33] = 0x01 } return result } function decode (string, version) { return decodeRaw(bs58grscheck.decode(string), version) } function encode (version, privateKey, compressed) { if (typeof version === 'number') return bs58grscheck.encode(encodeRaw(version, privateKey, compressed)) return bs58grscheck.encode( encodeRaw( version.version, version.privateKey, version.compressed ) ) } module.exports = { decode: decode, decodeRaw: decodeRaw, encode: encode, encodeRaw: encodeRaw }