Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Socket
Sign inDemoInstall

@bitgo/utxo-lib

Package Overview
Dependencies
Maintainers
4
Versions
171
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@bitgo/utxo-lib - npm Package Compare versions

Comparing version 1.9.6 to 1.9.7-rc.0.0.1.0

dist/src/bitgo/outputScripts.js

23

dist/src/bitgo/index.js

@@ -1,4 +0,21 @@

module.exports = {
keyutil: require('./keyutil')
"use strict";
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXguanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxDQUFDLE9BQU8sR0FBRztJQUNmLE9BQU8sRUFBRSxPQUFPLENBQUMsV0FBVyxDQUFDO0NBQzlCLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJtb2R1bGUuZXhwb3J0cyA9IHtcbiAga2V5dXRpbDogcmVxdWlyZSgnLi9rZXl1dGlsJylcbn1cbiJdfQ==
Object.defineProperty(exports, "__esModule", { value: true });
exports.parseSignatureScript = exports.verifySignature = exports.getDefaultSigHash = exports.outputScripts = exports.keyutil = void 0;
exports.keyutil = require("./keyutil");
exports.outputScripts = require("./outputScripts");
var signature_1 = require("./signature");
Object.defineProperty(exports, "getDefaultSigHash", { enumerable: true, get: function () { return signature_1.getDefaultSigHash; } });
Object.defineProperty(exports, "verifySignature", { enumerable: true, get: function () { return signature_1.verifySignature; } });
Object.defineProperty(exports, "parseSignatureScript", { enumerable: true, get: function () { return signature_1.parseSignatureScript; } });
__exportStar(require("./transaction"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLHVDQUFxQztBQUNyQyxtREFBaUQ7QUFDakQseUNBQXVGO0FBQTlFLDhHQUFBLGlCQUFpQixPQUFBO0FBQUUsNEdBQUEsZUFBZSxPQUFBO0FBQUUsaUhBQUEsb0JBQW9CLE9BQUE7QUFDakUsZ0RBQThCIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogYXMga2V5dXRpbCBmcm9tICcuL2tleXV0aWwnO1xuZXhwb3J0ICogYXMgb3V0cHV0U2NyaXB0cyBmcm9tICcuL291dHB1dFNjcmlwdHMnO1xuZXhwb3J0IHsgZ2V0RGVmYXVsdFNpZ0hhc2gsIHZlcmlmeVNpZ25hdHVyZSwgcGFyc2VTaWduYXR1cmVTY3JpcHQgfSBmcm9tICcuL3NpZ25hdHVyZSc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uJztcbiJdfQ==

24

dist/src/bitgo/keyutil.js

@@ -1,4 +0,10 @@

var BigInteger = require('bigi');
var ECPair = require('../ecpair');
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.privateKeyBufferFromECPair = exports.privateKeyBufferToECPair = void 0;
/**
* @prettier
*/
const BigInteger = require('bigi');
const ECPair = require('../ecpair');
/**
* Create an ECPair from the raw private key bytes

@@ -13,5 +19,6 @@ * @param {Buffer} buffer - Private key for the ECPair. Must be exactly 32 bytes.

}
var d = BigInteger.fromBuffer(buffer);
return new ECPair(d, null, { network: network });
const d = BigInteger.fromBuffer(buffer);
return new ECPair(d, null, { network });
}
exports.privateKeyBufferToECPair = privateKeyBufferToECPair;
/**

@@ -24,3 +31,3 @@ * Get the private key as a 32 bytes buffer. If it is smaller than 32 bytes, pad it with zeros

if (!(ecPair instanceof ECPair)) {
throw new TypeError("invalid argument ecpair");
throw new TypeError(`invalid argument ecpair`);
}

@@ -31,6 +38,3 @@ if (!ecPair.d)

}
module.exports = {
privateKeyBufferToECPair: privateKeyBufferToECPair,
privateKeyBufferFromECPair: privateKeyBufferFromECPair
};
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5dXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9rZXl1dGlsLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLElBQU0sVUFBVSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FBQTtBQUNsQyxJQUFNLE1BQU0sR0FBRyxPQUFPLENBQUMsV0FBVyxDQUFDLENBQUE7QUFFbkM7Ozs7O0dBS0c7QUFDSCxTQUFTLHdCQUF3QixDQUFFLE1BQU0sRUFBRSxPQUFPO0lBQ2hELElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQTtLQUM5QztJQUVELElBQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUE7SUFDdkMsT0FBTyxJQUFJLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsT0FBTyxTQUFBLEVBQUUsQ0FBQyxDQUFBO0FBQ3pDLENBQUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBUywwQkFBMEIsQ0FBRSxNQUFNO0lBQ3pDLElBQUksQ0FBQyxDQUFDLE1BQU0sWUFBWSxNQUFNLENBQUMsRUFBRTtRQUMvQixNQUFNLElBQUksU0FBUyxDQUFDLHlCQUF5QixDQUFDLENBQUE7S0FDL0M7SUFFRCxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUM7UUFBRSxNQUFNLElBQUksS0FBSyxDQUFDLHFCQUFxQixDQUFDLENBQUE7SUFFckQsT0FBTyxNQUFNLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxFQUFFLENBQUMsQ0FBQTtBQUM5QixDQUFDO0FBRUQsTUFBTSxDQUFDLE9BQU8sR0FBRztJQUNmLHdCQUF3QiwwQkFBQTtJQUN4QiwwQkFBMEIsNEJBQUE7Q0FDM0IsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImNvbnN0IEJpZ0ludGVnZXIgPSByZXF1aXJlKCdiaWdpJylcbmNvbnN0IEVDUGFpciA9IHJlcXVpcmUoJy4uL2VjcGFpcicpXG5cbi8qKlxuICogQ3JlYXRlIGFuIEVDUGFpciBmcm9tIHRoZSByYXcgcHJpdmF0ZSBrZXkgYnl0ZXNcbiAqIEBwYXJhbSB7QnVmZmVyfSBidWZmZXIgLSBQcml2YXRlIGtleSBmb3IgdGhlIEVDUGFpci4gTXVzdCBiZSBleGFjdGx5IDMyIGJ5dGVzLlxuICogQHBhcmFtIHtPYmplY3R9IFtuZXR3b3JrXSAtIE5ldHdvcmsgZm9yIHRoZSBFQ1BhaXIuIERlZmF1bHRzIHRvIGJpdGNvaW4uXG4gKiBAcmV0dXJuIHtFQ1BhaXJ9XG4gKi9cbmZ1bmN0aW9uIHByaXZhdGVLZXlCdWZmZXJUb0VDUGFpciAoYnVmZmVyLCBuZXR3b3JrKSB7XG4gIGlmICghQnVmZmVyLmlzQnVmZmVyKGJ1ZmZlcikgfHwgYnVmZmVyLmxlbmd0aCAhPT0gMzIpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2ludmFsaWQgcHJpdmF0ZSBrZXkgYnVmZmVyJylcbiAgfVxuXG4gIGNvbnN0IGQgPSBCaWdJbnRlZ2VyLmZyb21CdWZmZXIoYnVmZmVyKVxuICByZXR1cm4gbmV3IEVDUGFpcihkLCBudWxsLCB7IG5ldHdvcmsgfSlcbn1cblxuLyoqXG4gKiBHZXQgdGhlIHByaXZhdGUga2V5IGFzIGEgMzIgYnl0ZXMgYnVmZmVyLiBJZiBpdCBpcyBzbWFsbGVyIHRoYW4gMzIgYnl0ZXMsIHBhZCBpdCB3aXRoIHplcm9zXG4gKiBAcGFyYW0ge0VDUGFpcn0gZWNQYWlyXG4gKiBAcmV0dXJuIHtCdWZmZXJ9IDMyIGJ5dGVzXG4gKi9cbmZ1bmN0aW9uIHByaXZhdGVLZXlCdWZmZXJGcm9tRUNQYWlyIChlY1BhaXIpIHtcbiAgaWYgKCEoZWNQYWlyIGluc3RhbmNlb2YgRUNQYWlyKSkge1xuICAgIHRocm93IG5ldyBUeXBlRXJyb3IoYGludmFsaWQgYXJndW1lbnQgZWNwYWlyYClcbiAgfVxuXG4gIGlmICghZWNQYWlyLmQpIHRocm93IG5ldyBFcnJvcignTWlzc2luZyBwcml2YXRlIGtleScpXG5cbiAgcmV0dXJuIGVjUGFpci5kLnRvQnVmZmVyKDMyKVxufVxuXG5tb2R1bGUuZXhwb3J0cyA9IHtcbiAgcHJpdmF0ZUtleUJ1ZmZlclRvRUNQYWlyLFxuICBwcml2YXRlS2V5QnVmZmVyRnJvbUVDUGFpclxufVxuIl19
exports.privateKeyBufferFromECPair = privateKeyBufferFromECPair;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5dXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9rZXl1dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ25DLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUVwQzs7Ozs7R0FLRztBQUNILFNBQWdCLHdCQUF3QixDQUFDLE1BQU0sRUFBRSxPQUFPO0lBQ3RELElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztLQUMvQztJQUVELE1BQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEMsT0FBTyxJQUFJLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztBQUMxQyxDQUFDO0FBUEQsNERBT0M7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQUMsTUFBTTtJQUMvQyxJQUFJLENBQUMsQ0FBQyxNQUFNLFlBQVksTUFBTSxDQUFDLEVBQUU7UUFDL0IsTUFBTSxJQUFJLFNBQVMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0tBQ2hEO0lBRUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBRXRELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDL0IsQ0FBQztBQVJELGdFQVFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcHJldHRpZXJcbiAqL1xuY29uc3QgQmlnSW50ZWdlciA9IHJlcXVpcmUoJ2JpZ2knKTtcbmNvbnN0IEVDUGFpciA9IHJlcXVpcmUoJy4uL2VjcGFpcicpO1xuXG4vKipcbiAqIENyZWF0ZSBhbiBFQ1BhaXIgZnJvbSB0aGUgcmF3IHByaXZhdGUga2V5IGJ5dGVzXG4gKiBAcGFyYW0ge0J1ZmZlcn0gYnVmZmVyIC0gUHJpdmF0ZSBrZXkgZm9yIHRoZSBFQ1BhaXIuIE11c3QgYmUgZXhhY3RseSAzMiBieXRlcy5cbiAqIEBwYXJhbSB7T2JqZWN0fSBbbmV0d29ya10gLSBOZXR3b3JrIGZvciB0aGUgRUNQYWlyLiBEZWZhdWx0cyB0byBiaXRjb2luLlxuICogQHJldHVybiB7RUNQYWlyfVxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpdmF0ZUtleUJ1ZmZlclRvRUNQYWlyKGJ1ZmZlciwgbmV0d29yaykge1xuICBpZiAoIUJ1ZmZlci5pc0J1ZmZlcihidWZmZXIpIHx8IGJ1ZmZlci5sZW5ndGggIT09IDMyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdpbnZhbGlkIHByaXZhdGUga2V5IGJ1ZmZlcicpO1xuICB9XG5cbiAgY29uc3QgZCA9IEJpZ0ludGVnZXIuZnJvbUJ1ZmZlcihidWZmZXIpO1xuICByZXR1cm4gbmV3IEVDUGFpcihkLCBudWxsLCB7IG5ldHdvcmsgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBwcml2YXRlIGtleSBhcyBhIDMyIGJ5dGVzIGJ1ZmZlci4gSWYgaXQgaXMgc21hbGxlciB0aGFuIDMyIGJ5dGVzLCBwYWQgaXQgd2l0aCB6ZXJvc1xuICogQHBhcmFtIHtFQ1BhaXJ9IGVjUGFpclxuICogQHJldHVybiB7QnVmZmVyfSAzMiBieXRlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpdmF0ZUtleUJ1ZmZlckZyb21FQ1BhaXIoZWNQYWlyKSB7XG4gIGlmICghKGVjUGFpciBpbnN0YW5jZW9mIEVDUGFpcikpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKGBpbnZhbGlkIGFyZ3VtZW50IGVjcGFpcmApO1xuICB9XG5cbiAgaWYgKCFlY1BhaXIuZCkgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHByaXZhdGUga2V5Jyk7XG5cbiAgcmV0dXJuIGVjUGFpci5kLnRvQnVmZmVyKDMyKTtcbn1cbiJdfQ==

@@ -13,2 +13,6 @@ var Buffer = require('safe-buffer').Buffer;

typeforce(types.maybe(types.Network), network);
if (coins.isZcash(network)) {
/* istanbul ignore next */
throw new Error('unsupported network');
}
network = network || networks.bitcoin;

@@ -22,10 +26,4 @@ this.version = 1;

this.network = network;
if (coins.isZcash(network)) {
this.finalSaplingRoot = null;
this.solutionSize = 0;
this.solution = null;
}
}
Block.HEADER_BYTE_SIZE = 80;
Block.ZCASH_HEADER_BYTE_SIZE = 1487;
Block.fromBuffer = function (buffer, network) {

@@ -35,3 +33,3 @@ if (buffer.length < 80)

network = network || networks.bitcoin;
var bufferReader = new bufferutils.BufferReader(buffer);
const bufferReader = new bufferutils.BufferReader(buffer);
var block = new Block(network);

@@ -41,16 +39,6 @@ block.version = bufferReader.readInt32();

block.merkleRoot = bufferReader.readSlice(32);
if (coins.isZcash(network)) {
block.finalSaplingRoot = bufferReader.readSlice(32);
}
block.timestamp = bufferReader.readUInt32();
block.bits = bufferReader.readUInt32();
if (coins.isZcash(network)) {
block.nonce = bufferReader.readSlice(32);
block.solutionSize = bufferReader.readVarInt();
block.solution = bufferReader.readSlice(1344);
}
else {
// Not sure sure why the nonce is read as UInt 32 and not as a slice
block.nonce = bufferReader.readUInt32();
}
// Not sure sure why the nonce is read as UInt 32 and not as a slice
block.nonce = bufferReader.readUInt32();
if (bufferReader.buffer.length === 80)

@@ -72,11 +60,2 @@ return block;

Block.prototype.byteLength = function (headersOnly) {
if (coins.isZcash(this.network)) {
if (headersOnly) {
return Block.ZCASH_HEADER_BYTE_SIZE;
}
return Block.ZCASH_HEADER_BYTE_SIZE +
varuint.encodingLength(this.transactions.length) + this.transactions.reduce(function (a, x) {
return a + x.byteLength();
}, 0);
}
if (headersOnly || !this.transactions)

@@ -110,18 +89,6 @@ return Block.HEADER_BYTE_SIZE;

bufferWriter.writeSlice(this.merkleRoot);
if (coins.isZcash(this.network)) {
bufferWriter.writeSlice(this.finalSaplingRoot);
}
bufferWriter.writeUInt32(this.timestamp);
bufferWriter.writeUInt32(this.bits);
if (coins.isZcash(this.network)) {
bufferWriter.writeSlice(this.nonce);
// TODO: use writeVarInt
varuint.encode(this.solutionSize, bufferWriter.buffer, bufferWriter.offset);
bufferWriter.offset += varuint.encode.bytes;
bufferWriter.writeSlice(this.solution);
}
else {
// Not sure sure why the nonce is interpreted as UInt 32 and not a slice in bitcoin
bufferWriter.writeUInt32(this.nonce);
}
// Not sure sure why the nonce is interpreted as UInt 32 and not a slice in bitcoin
bufferWriter.writeUInt32(this.nonce);
if (headersOnly || !this.transactions)

@@ -184,2 +151,2 @@ return buffer;

module.exports = Block;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block.js","sourceRoot":"","sources":["../../src/block.js"],"names":[],"mappings":"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","sourcesContent":["var Buffer = require('safe-buffer').Buffer\nvar bcrypto = require('./crypto')\nvar fastMerkleRoot = require('merkle-lib/fastRoot')\nvar typeforce = require('typeforce')\nvar types = require('./types')\nvar bufferutils = require('./bufferutils')\nvar varuint = require('varuint-bitcoin')\nvar networks = require('./networks')\nvar coins = require('./coins')\n\nvar Transaction = require('./transaction')\n\nfunction Block (network) {\n  typeforce(types.maybe(types.Network), network)\n  network = network || networks.bitcoin\n  this.version = 1\n  this.prevHash = null\n  this.merkleRoot = null\n  this.timestamp = 0\n  this.bits = 0\n  this.nonce = 0\n  this.network = network\n  if (coins.isZcash(network)) {\n    this.finalSaplingRoot = null\n    this.solutionSize = 0\n    this.solution = null\n  }\n}\n\nBlock.HEADER_BYTE_SIZE = 80\nBlock.ZCASH_HEADER_BYTE_SIZE = 1487\n\nBlock.fromBuffer = function (buffer, network) {\n  if (buffer.length < 80) throw new Error('Buffer too small (< 80 bytes)')\n  network = network || networks.bitcoin\n\n  const bufferReader = new bufferutils.BufferReader(buffer)\n\n  var block = new Block(network)\n  block.version = bufferReader.readInt32()\n  block.prevHash = bufferReader.readSlice(32)\n  block.merkleRoot = bufferReader.readSlice(32)\n  if (coins.isZcash(network)) {\n    block.finalSaplingRoot = bufferReader.readSlice(32)\n  }\n  block.timestamp = bufferReader.readUInt32()\n  block.bits = bufferReader.readUInt32()\n  if (coins.isZcash(network)) {\n    block.nonce = bufferReader.readSlice(32)\n    block.solutionSize = bufferReader.readVarInt()\n    block.solution = bufferReader.readSlice(1344)\n  } else {\n    // Not sure sure why the nonce is read as UInt 32 and not as a slice\n    block.nonce = bufferReader.readUInt32()\n  }\n\n  if (bufferReader.buffer.length === 80) return block\n\n  function readTransaction () {\n    var tx = Transaction.fromBuffer(buffer.slice(bufferReader.offset), network, true)\n    bufferReader.offset += tx.byteLength()\n    return tx\n  }\n\n  var nTransactions = bufferReader.readVarInt()\n  block.transactions = []\n\n  for (var i = 0; i < nTransactions; ++i) {\n    var tx = readTransaction()\n    block.transactions.push(tx)\n  }\n\n  return block\n}\n\nBlock.prototype.byteLength = function (headersOnly) {\n  if (coins.isZcash(this.network)) {\n    if (headersOnly) {\n      return Block.ZCASH_HEADER_BYTE_SIZE\n    }\n    return Block.ZCASH_HEADER_BYTE_SIZE +\n      varuint.encodingLength(this.transactions.length) + this.transactions.reduce(function (a, x) {\n        return a + x.byteLength()\n      }, 0)\n  }\n\n  if (headersOnly || !this.transactions) return Block.HEADER_BYTE_SIZE\n\n  return Block.HEADER_BYTE_SIZE +\n    varuint.encodingLength(this.transactions.length) + this.transactions.reduce(function (a, x) {\n      return a + x.byteLength()\n    }, 0)\n}\n\nBlock.fromHex = function (hex, network) {\n  return Block.fromBuffer(Buffer.from(hex, 'hex'), network)\n}\n\nBlock.prototype.getHash = function () {\n  return bcrypto.hash256(this.toBuffer(true))\n}\n\nBlock.prototype.getId = function () {\n  return this.getHash().reverse().toString('hex')\n}\n\nBlock.prototype.getUTCDate = function () {\n  var date = new Date(0) // epoch\n  date.setUTCSeconds(this.timestamp)\n\n  return date\n}\n\n// TODO: buffer, offset compatibility\nBlock.prototype.toBuffer = function (headersOnly) {\n  var buffer = Buffer.allocUnsafe(this.byteLength(headersOnly))\n  var bufferWriter = new bufferutils.BufferWriter(buffer)\n\n  bufferWriter.writeInt32(this.version)\n  bufferWriter.writeSlice(this.prevHash)\n  bufferWriter.writeSlice(this.merkleRoot)\n  if (coins.isZcash(this.network)) {\n    bufferWriter.writeSlice(this.finalSaplingRoot)\n  }\n  bufferWriter.writeUInt32(this.timestamp)\n  bufferWriter.writeUInt32(this.bits)\n  if (coins.isZcash(this.network)) {\n    bufferWriter.writeSlice(this.nonce)\n    // TODO: use writeVarInt\n    varuint.encode(this.solutionSize, bufferWriter.buffer, bufferWriter.offset)\n    bufferWriter.offset += varuint.encode.bytes\n    bufferWriter.writeSlice(this.solution)\n  } else {\n    // Not sure sure why the nonce is interpreted as UInt 32 and not a slice in bitcoin\n    bufferWriter.writeUInt32(this.nonce)\n  }\n\n  if (headersOnly || !this.transactions) return buffer\n\n  // TODO: use writeVarInt\n  varuint.encode(this.transactions.length, bufferWriter.buffer, bufferWriter.offset)\n  bufferWriter.offset += varuint.encode.bytes\n\n  // TODO: use writeVarInt\n  this.transactions.forEach(function (tx) {\n    var txSize = tx.byteLength() // TODO: extract from toBuffer?\n    tx.toBuffer(bufferWriter.buffer, bufferWriter.offset)\n    bufferWriter.offset += txSize\n  })\n\n  return buffer\n}\n\nBlock.prototype.toHex = function (headersOnly) {\n  return this.toBuffer(headersOnly).toString('hex')\n}\n\nBlock.calculateTarget = function (bits) {\n  var exponent = ((bits & 0xff000000) >> 24) - 3\n  var mantissa = bits & 0x007fffff\n  var target = Buffer.alloc(32, 0)\n  if (exponent < 0) {\n    // If it is negative, we will overflow the target buffer so we have to slice the mantissa to fit\n    mantissa = mantissa >> (8 * Math.abs(exponent))\n    target.writeUInt32BE(mantissa, 28)\n  } else if (exponent > 28) {\n    // If it is greater than 28, we need to shift the mantissa since the offset cannot be greater than 32 - 4\n    // (safe-buffer restriction)\n    mantissa <<= 8 * (exponent - 28)\n    target.writeUInt32BE(mantissa, 0)\n  } else {\n    target.writeUInt32BE(mantissa, 28 - exponent)\n  }\n  return target\n}\n\nBlock.calculateMerkleRoot = function (transactions) {\n  typeforce([{ getHash: types.Function }], transactions)\n  if (transactions.length === 0) throw TypeError('Cannot compute merkle root for zero transactions')\n\n  var hashes = transactions.map(function (transaction) {\n    return transaction.getHash()\n  })\n\n  return fastMerkleRoot(hashes, bcrypto.hash256)\n}\n\nBlock.prototype.checkMerkleRoot = function () {\n  if (!this.transactions) return false\n\n  var actualMerkleRoot = Block.calculateMerkleRoot(this.transactions)\n  return this.merkleRoot.compare(actualMerkleRoot) === 0\n}\n\nBlock.prototype.checkProofOfWork = function () {\n  var hash = this.getHash().reverse()\n  var target = Block.calculateTarget(this.bits)\n\n  return hash.compare(target) <= 0\n}\n\nmodule.exports = Block\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"block.js","sourceRoot":"","sources":["../../src/block.js"],"names":[],"mappings":"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","sourcesContent":["var Buffer = require('safe-buffer').Buffer\nvar bcrypto = require('./crypto')\nvar fastMerkleRoot = require('merkle-lib/fastRoot')\nvar typeforce = require('typeforce')\nvar types = require('./types')\nvar bufferutils = require('./bufferutils')\nvar varuint = require('varuint-bitcoin')\nvar networks = require('./networks')\nvar coins = require('./coins')\n\nvar Transaction = require('./transaction')\n\nfunction Block (network) {\n  typeforce(types.maybe(types.Network), network)\n  if (coins.isZcash(network)) {\n    /* istanbul ignore next */\n    throw new Error('unsupported network')\n  }\n  network = network || networks.bitcoin\n  this.version = 1\n  this.prevHash = null\n  this.merkleRoot = null\n  this.timestamp = 0\n  this.bits = 0\n  this.nonce = 0\n  this.network = network\n}\n\nBlock.HEADER_BYTE_SIZE = 80\n\nBlock.fromBuffer = function (buffer, network) {\n  if (buffer.length < 80) throw new Error('Buffer too small (< 80 bytes)')\n  network = network || networks.bitcoin\n\n  const bufferReader = new bufferutils.BufferReader(buffer)\n\n  var block = new Block(network)\n  block.version = bufferReader.readInt32()\n  block.prevHash = bufferReader.readSlice(32)\n  block.merkleRoot = bufferReader.readSlice(32)\n  block.timestamp = bufferReader.readUInt32()\n  block.bits = bufferReader.readUInt32()\n  // Not sure sure why the nonce is read as UInt 32 and not as a slice\n  block.nonce = bufferReader.readUInt32()\n\n  if (bufferReader.buffer.length === 80) return block\n\n  function readTransaction () {\n    var tx = Transaction.fromBuffer(buffer.slice(bufferReader.offset), network, true)\n    bufferReader.offset += tx.byteLength()\n    return tx\n  }\n\n  var nTransactions = bufferReader.readVarInt()\n  block.transactions = []\n\n  for (var i = 0; i < nTransactions; ++i) {\n    var tx = readTransaction()\n    block.transactions.push(tx)\n  }\n\n  return block\n}\n\nBlock.prototype.byteLength = function (headersOnly) {\n  if (headersOnly || !this.transactions) return Block.HEADER_BYTE_SIZE\n\n  return Block.HEADER_BYTE_SIZE +\n    varuint.encodingLength(this.transactions.length) + this.transactions.reduce(function (a, x) {\n      return a + x.byteLength()\n    }, 0)\n}\n\nBlock.fromHex = function (hex, network) {\n  return Block.fromBuffer(Buffer.from(hex, 'hex'), network)\n}\n\nBlock.prototype.getHash = function () {\n  return bcrypto.hash256(this.toBuffer(true))\n}\n\nBlock.prototype.getId = function () {\n  return this.getHash().reverse().toString('hex')\n}\n\nBlock.prototype.getUTCDate = function () {\n  var date = new Date(0) // epoch\n  date.setUTCSeconds(this.timestamp)\n\n  return date\n}\n\n// TODO: buffer, offset compatibility\nBlock.prototype.toBuffer = function (headersOnly) {\n  var buffer = Buffer.allocUnsafe(this.byteLength(headersOnly))\n  var bufferWriter = new bufferutils.BufferWriter(buffer)\n\n  bufferWriter.writeInt32(this.version)\n  bufferWriter.writeSlice(this.prevHash)\n  bufferWriter.writeSlice(this.merkleRoot)\n  bufferWriter.writeUInt32(this.timestamp)\n  bufferWriter.writeUInt32(this.bits)\n  // Not sure sure why the nonce is interpreted as UInt 32 and not a slice in bitcoin\n  bufferWriter.writeUInt32(this.nonce)\n\n  if (headersOnly || !this.transactions) return buffer\n\n  // TODO: use writeVarInt\n  varuint.encode(this.transactions.length, bufferWriter.buffer, bufferWriter.offset)\n  bufferWriter.offset += varuint.encode.bytes\n\n  // TODO: use writeVarInt\n  this.transactions.forEach(function (tx) {\n    var txSize = tx.byteLength() // TODO: extract from toBuffer?\n    tx.toBuffer(bufferWriter.buffer, bufferWriter.offset)\n    bufferWriter.offset += txSize\n  })\n\n  return buffer\n}\n\nBlock.prototype.toHex = function (headersOnly) {\n  return this.toBuffer(headersOnly).toString('hex')\n}\n\nBlock.calculateTarget = function (bits) {\n  var exponent = ((bits & 0xff000000) >> 24) - 3\n  var mantissa = bits & 0x007fffff\n  var target = Buffer.alloc(32, 0)\n  if (exponent < 0) {\n    // If it is negative, we will overflow the target buffer so we have to slice the mantissa to fit\n    mantissa = mantissa >> (8 * Math.abs(exponent))\n    target.writeUInt32BE(mantissa, 28)\n  } else if (exponent > 28) {\n    // If it is greater than 28, we need to shift the mantissa since the offset cannot be greater than 32 - 4\n    // (safe-buffer restriction)\n    mantissa <<= 8 * (exponent - 28)\n    target.writeUInt32BE(mantissa, 0)\n  } else {\n    target.writeUInt32BE(mantissa, 28 - exponent)\n  }\n  return target\n}\n\nBlock.calculateMerkleRoot = function (transactions) {\n  typeforce([{ getHash: types.Function }], transactions)\n  if (transactions.length === 0) throw TypeError('Cannot compute merkle root for zero transactions')\n\n  var hashes = transactions.map(function (transaction) {\n    return transaction.getHash()\n  })\n\n  return fastMerkleRoot(hashes, bcrypto.hash256)\n}\n\nBlock.prototype.checkMerkleRoot = function () {\n  if (!this.transactions) return false\n\n  var actualMerkleRoot = Block.calculateMerkleRoot(this.transactions)\n  return this.merkleRoot.compare(actualMerkleRoot) === 0\n}\n\nBlock.prototype.checkProofOfWork = function () {\n  var hash = this.getHash().reverse()\n  var target = Block.calculateTarget(this.bits)\n\n  return hash.compare(target) <= 0\n}\n\nmodule.exports = Block\n"]}
/* eslint-disable */
var types = require('./types');
var typeforce = require('typeforce');
var varuint = require('varuint-bitcoin');
const types = require('./types');
const typeforce = require('typeforce');
const varuint = require('varuint-bitcoin');
// https://github.com/feross/buffer/blob/master/index.js#L1127

@@ -17,4 +17,4 @@ function verifuint(value, max) {

function readUInt64LE(buffer, offset) {
var a = buffer.readUInt32LE(offset);
var b = buffer.readUInt32LE(offset + 4);
const a = buffer.readUInt32LE(offset);
let b = buffer.readUInt32LE(offset + 4);
b *= 0x100000000;

@@ -33,5 +33,5 @@ verifuint(b + a, 0x001fffffffffffff);

return buffer;
var j = buffer.length - 1;
var tmp = 0;
for (var i = 0; i < buffer.length / 2; i++) {
let j = buffer.length - 1;
let tmp = 0;
for (let i = 0; i < buffer.length / 2; i++) {
tmp = buffer[i];

@@ -47,5 +47,4 @@ buffer[i] = buffer[j];

*/
var BufferWriter = /** @class */ (function () {
function BufferWriter(buffer, offset) {
if (offset === void 0) { offset = 0; }
class BufferWriter {
constructor(buffer, offset = 0) {
this.buffer = buffer;

@@ -55,19 +54,19 @@ this.offset = offset;

}
BufferWriter.prototype.writeUInt8 = function (i) {
writeUInt8(i) {
this.offset = this.buffer.writeUInt8(i, this.offset);
};
BufferWriter.prototype.writeInt32 = function (i) {
}
writeInt32(i) {
this.offset = this.buffer.writeInt32LE(i, this.offset);
};
BufferWriter.prototype.writeUInt32 = function (i) {
}
writeUInt32(i) {
this.offset = this.buffer.writeUInt32LE(i, this.offset);
};
BufferWriter.prototype.writeUInt64 = function (i) {
}
writeUInt64(i) {
this.offset = writeUInt64LE(this.buffer, i, this.offset);
};
BufferWriter.prototype.writeVarInt = function (i) {
}
writeVarInt(i) {
varuint.encode(i, this.buffer, this.offset);
this.offset += varuint.encode.bytes;
};
BufferWriter.prototype.writeSlice = function (slice) {
}
writeSlice(slice) {
if (this.buffer.length < this.offset + slice.length) {

@@ -77,20 +76,17 @@ throw new Error('Cannot write slice out of bounds');

this.offset += slice.copy(this.buffer, this.offset);
};
BufferWriter.prototype.writeVarSlice = function (slice) {
}
writeVarSlice(slice) {
this.writeVarInt(slice.length);
this.writeSlice(slice);
};
BufferWriter.prototype.writeVector = function (vector) {
var _this = this;
}
writeVector(vector) {
this.writeVarInt(vector.length);
vector.forEach(function (buf) { return _this.writeVarSlice(buf); });
};
return BufferWriter;
}());
vector.forEach((buf) => this.writeVarSlice(buf));
}
}
/**
* Helper class for reading of bitcoin data types from a buffer.
*/
var BufferReader = /** @class */ (function () {
function BufferReader(buffer, offset) {
if (offset === void 0) { offset = 0; }
class BufferReader {
constructor(buffer, offset = 0) {
this.buffer = buffer;

@@ -100,54 +96,53 @@ this.offset = offset;

}
BufferReader.prototype.readUInt8 = function () {
var result = this.buffer.readUInt8(this.offset);
readUInt8() {
const result = this.buffer.readUInt8(this.offset);
this.offset++;
return result;
};
BufferReader.prototype.readInt32 = function () {
var result = this.buffer.readInt32LE(this.offset);
}
readInt32() {
const result = this.buffer.readInt32LE(this.offset);
this.offset += 4;
return result;
};
BufferReader.prototype.readUInt32 = function () {
var result = this.buffer.readUInt32LE(this.offset);
}
readUInt32() {
const result = this.buffer.readUInt32LE(this.offset);
this.offset += 4;
return result;
};
BufferReader.prototype.readUInt64 = function () {
var result = readUInt64LE(this.buffer, this.offset);
}
readUInt64() {
const result = readUInt64LE(this.buffer, this.offset);
this.offset += 8;
return result;
};
BufferReader.prototype.readVarInt = function () {
var vi = varuint.decode(this.buffer, this.offset);
}
readVarInt() {
const vi = varuint.decode(this.buffer, this.offset);
this.offset += varuint.decode.bytes;
return vi;
};
BufferReader.prototype.readSlice = function (n) {
}
readSlice(n) {
if (this.buffer.length < this.offset + n) {
throw new Error('Cannot read slice out of bounds');
}
var result = this.buffer.slice(this.offset, this.offset + n);
const result = this.buffer.slice(this.offset, this.offset + n);
this.offset += n;
return result;
};
BufferReader.prototype.readVarSlice = function () {
}
readVarSlice() {
return this.readSlice(this.readVarInt());
};
BufferReader.prototype.readVector = function () {
var count = this.readVarInt();
var vector = [];
for (var i = 0; i < count; i++)
}
readVector() {
const count = this.readVarInt();
const vector = [];
for (let i = 0; i < count; i++)
vector.push(this.readVarSlice());
return vector;
};
return BufferReader;
}());
}
}
module.exports = {
readUInt64LE: readUInt64LE,
writeUInt64LE: writeUInt64LE,
reverseBuffer: reverseBuffer,
BufferWriter: BufferWriter,
BufferReader: BufferReader,
readUInt64LE,
writeUInt64LE,
reverseBuffer,
BufferWriter,
BufferReader,
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bufferutils.js","sourceRoot":"","sources":["../../src/bufferutils.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nconst types = require('./types');\nconst typeforce = require('typeforce');\nconst varuint = require('varuint-bitcoin');\n// https://github.com/feross/buffer/blob/master/index.js#L1127\nfunction verifuint(value, max) {\n    if (typeof value !== 'number')\n        throw new Error('cannot write a non-number as a number');\n    if (value < 0)\n        throw new Error('specified a negative value for writing an unsigned value');\n    if (value > max)\n        throw new Error('RangeError: value out of range');\n    if (Math.floor(value) !== value)\n        throw new Error('value has a fractional component');\n}\nfunction readUInt64LE(buffer, offset) {\n    const a = buffer.readUInt32LE(offset);\n    let b = buffer.readUInt32LE(offset + 4);\n    b *= 0x100000000;\n    verifuint(b + a, 0x001fffffffffffff);\n    return b + a;\n}\nfunction writeUInt64LE(buffer, value, offset) {\n    verifuint(value, 0x001fffffffffffff);\n    buffer.writeInt32LE(value & -1, offset);\n    buffer.writeUInt32LE(Math.floor(value / 0x100000000), offset + 4);\n    return offset + 8;\n}\nfunction reverseBuffer(buffer) {\n    if (buffer.length < 1)\n        return buffer;\n    let j = buffer.length - 1;\n    let tmp = 0;\n    for (let i = 0; i < buffer.length / 2; i++) {\n        tmp = buffer[i];\n        buffer[i] = buffer[j];\n        buffer[j] = tmp;\n        j--;\n    }\n    return buffer;\n}\n/**\n * Helper class for serialization of bitcoin data types into a pre-allocated buffer.\n */\nclass BufferWriter {\n    constructor(buffer, offset = 0) {\n        this.buffer = buffer;\n        this.offset = offset;\n        typeforce(types.tuple(types.Buffer, types.UInt32), [buffer, offset]);\n    }\n    writeUInt8(i) {\n        this.offset = this.buffer.writeUInt8(i, this.offset);\n    }\n    writeInt32(i) {\n        this.offset = this.buffer.writeInt32LE(i, this.offset);\n    }\n    writeUInt32(i) {\n        this.offset = this.buffer.writeUInt32LE(i, this.offset);\n    }\n    writeUInt64(i) {\n        this.offset = writeUInt64LE(this.buffer, i, this.offset);\n    }\n    writeVarInt(i) {\n        varuint.encode(i, this.buffer, this.offset);\n        this.offset += varuint.encode.bytes;\n    }\n    writeSlice(slice) {\n        if (this.buffer.length < this.offset + slice.length) {\n            throw new Error('Cannot write slice out of bounds');\n        }\n        this.offset += slice.copy(this.buffer, this.offset);\n    }\n    writeVarSlice(slice) {\n        this.writeVarInt(slice.length);\n        this.writeSlice(slice);\n    }\n    writeVector(vector) {\n        this.writeVarInt(vector.length);\n        vector.forEach((buf) => this.writeVarSlice(buf));\n    }\n}\n/**\n * Helper class for reading of bitcoin data types from a buffer.\n */\nclass BufferReader {\n    constructor(buffer, offset = 0) {\n        this.buffer = buffer;\n        this.offset = offset;\n        typeforce(types.tuple(types.Buffer, types.UInt32), [buffer, offset]);\n    }\n    readUInt8() {\n        const result = this.buffer.readUInt8(this.offset);\n        this.offset++;\n        return result;\n    }\n    readInt32() {\n        const result = this.buffer.readInt32LE(this.offset);\n        this.offset += 4;\n        return result;\n    }\n    readUInt32() {\n        const result = this.buffer.readUInt32LE(this.offset);\n        this.offset += 4;\n        return result;\n    }\n    readUInt64() {\n        const result = readUInt64LE(this.buffer, this.offset);\n        this.offset += 8;\n        return result;\n    }\n    readVarInt() {\n        const vi = varuint.decode(this.buffer, this.offset);\n        this.offset += varuint.decode.bytes;\n        return vi;\n    }\n    readSlice(n) {\n        if (this.buffer.length < this.offset + n) {\n            throw new Error('Cannot read slice out of bounds');\n        }\n        const result = this.buffer.slice(this.offset, this.offset + n);\n        this.offset += n;\n        return result;\n    }\n    readVarSlice() {\n        return this.readSlice(this.readVarInt());\n    }\n    readVector() {\n        const count = this.readVarInt();\n        const vector = [];\n        for (let i = 0; i < count; i++)\n            vector.push(this.readVarSlice());\n        return vector;\n    }\n}\nmodule.exports = {\n    readUInt64LE,\n    writeUInt64LE,\n    reverseBuffer,\n    BufferWriter,\n    BufferReader,\n};\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bufferutils.js","sourceRoot":"","sources":["../../src/bufferutils.js"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\nconst types = require('./types');\nconst typeforce = require('typeforce');\nconst varuint = require('varuint-bitcoin');\n// https://github.com/feross/buffer/blob/master/index.js#L1127\nfunction verifuint(value, max) {\n    if (typeof value !== 'number')\n        throw new Error('cannot write a non-number as a number');\n    if (value < 0)\n        throw new Error('specified a negative value for writing an unsigned value');\n    if (value > max)\n        throw new Error('RangeError: value out of range');\n    if (Math.floor(value) !== value)\n        throw new Error('value has a fractional component');\n}\nfunction readUInt64LE(buffer, offset) {\n    const a = buffer.readUInt32LE(offset);\n    let b = buffer.readUInt32LE(offset + 4);\n    b *= 0x100000000;\n    verifuint(b + a, 0x001fffffffffffff);\n    return b + a;\n}\nfunction writeUInt64LE(buffer, value, offset) {\n    verifuint(value, 0x001fffffffffffff);\n    buffer.writeInt32LE(value & -1, offset);\n    buffer.writeUInt32LE(Math.floor(value / 0x100000000), offset + 4);\n    return offset + 8;\n}\nfunction reverseBuffer(buffer) {\n    if (buffer.length < 1)\n        return buffer;\n    let j = buffer.length - 1;\n    let tmp = 0;\n    for (let i = 0; i < buffer.length / 2; i++) {\n        tmp = buffer[i];\n        buffer[i] = buffer[j];\n        buffer[j] = tmp;\n        j--;\n    }\n    return buffer;\n}\n/**\n * Helper class for serialization of bitcoin data types into a pre-allocated buffer.\n */\nclass BufferWriter {\n    constructor(buffer, offset = 0) {\n        this.buffer = buffer;\n        this.offset = offset;\n        typeforce(types.tuple(types.Buffer, types.UInt32), [buffer, offset]);\n    }\n    writeUInt8(i) {\n        this.offset = this.buffer.writeUInt8(i, this.offset);\n    }\n    writeInt32(i) {\n        this.offset = this.buffer.writeInt32LE(i, this.offset);\n    }\n    writeUInt32(i) {\n        this.offset = this.buffer.writeUInt32LE(i, this.offset);\n    }\n    writeUInt64(i) {\n        this.offset = writeUInt64LE(this.buffer, i, this.offset);\n    }\n    writeVarInt(i) {\n        varuint.encode(i, this.buffer, this.offset);\n        this.offset += varuint.encode.bytes;\n    }\n    writeSlice(slice) {\n        if (this.buffer.length < this.offset + slice.length) {\n            throw new Error('Cannot write slice out of bounds');\n        }\n        this.offset += slice.copy(this.buffer, this.offset);\n    }\n    writeVarSlice(slice) {\n        this.writeVarInt(slice.length);\n        this.writeSlice(slice);\n    }\n    writeVector(vector) {\n        this.writeVarInt(vector.length);\n        vector.forEach((buf) => this.writeVarSlice(buf));\n    }\n}\n/**\n * Helper class for reading of bitcoin data types from a buffer.\n */\nclass BufferReader {\n    constructor(buffer, offset = 0) {\n        this.buffer = buffer;\n        this.offset = offset;\n        typeforce(types.tuple(types.Buffer, types.UInt32), [buffer, offset]);\n    }\n    readUInt8() {\n        const result = this.buffer.readUInt8(this.offset);\n        this.offset++;\n        return result;\n    }\n    readInt32() {\n        const result = this.buffer.readInt32LE(this.offset);\n        this.offset += 4;\n        return result;\n    }\n    readUInt32() {\n        const result = this.buffer.readUInt32LE(this.offset);\n        this.offset += 4;\n        return result;\n    }\n    readUInt64() {\n        const result = readUInt64LE(this.buffer, this.offset);\n        this.offset += 8;\n        return result;\n    }\n    readVarInt() {\n        const vi = varuint.decode(this.buffer, this.offset);\n        this.offset += varuint.decode.bytes;\n        return vi;\n    }\n    readSlice(n) {\n        if (this.buffer.length < this.offset + n) {\n            throw new Error('Cannot read slice out of bounds');\n        }\n        const result = this.buffer.slice(this.offset, this.offset + n);\n        this.offset += n;\n        return result;\n    }\n    readVarSlice() {\n        return this.readSlice(this.readVarInt());\n    }\n    readVector() {\n        const count = this.readVarInt();\n        const vector = [];\n        for (let i = 0; i < count; i++)\n            vector.push(this.readVarSlice());\n        return vector;\n    }\n}\nmodule.exports = {\n    readUInt64LE,\n    writeUInt64LE,\n    reverseBuffer,\n    BufferWriter,\n    BufferReader,\n};\n"]}

@@ -1,10 +0,17 @@

// Coins supported by bitgo-bitcoinjs-lib
var typeforce = require('typeforce');
var networks = require('./networks');
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.ZEC = exports.LTC = exports.DASH = exports.BTG = exports.BTC = exports.BSV = exports.BCH = exports.isValidNetwork = exports.isZcash = exports.isLitecoin = exports.isDash = exports.isBitcoinSV = exports.isBitcoinGold = exports.isBitcoinCash = exports.isBitcoin = exports.getTestnet = exports.isSameCoin = exports.isTestnet = exports.isMainnet = exports.getMainnet = exports.getNetworkName = exports.getNetworkList = void 0;
/**
* @prettier
*/
const networks = require("./networks");
const networkTypes_1 = require("./networkTypes");
const typeforce = require('typeforce');
/**
* @returns {Network[]} all known networks as array
*/
function getNetworkList() {
return Object.keys(networks).map(function (n) { return networks[n]; });
return Object.keys(networks).map((n) => networks[n]);
}
exports.getNetworkList = getNetworkList;
/**

@@ -16,4 +23,5 @@ * @param {Network} network

function getNetworkName(network) {
return Object.keys(networks).find(function (n) { return networks[n] === network; });
return Object.keys(networks).find((n) => networks[n] === network);
}
exports.getNetworkName = getNetworkName;
/**

@@ -47,4 +55,5 @@ * @param {Network} network

}
throw new TypeError("invalid network");
throw new TypeError(`invalid network`);
}
exports.getMainnet = getMainnet;
/**

@@ -57,2 +66,3 @@ * @param {Network} network

}
exports.isMainnet = isMainnet;
/**

@@ -65,2 +75,3 @@ * @param {Network} network

}
exports.isTestnet = isTestnet;
/**

@@ -75,4 +86,5 @@ *

}
var mainnets = getNetworkList().filter(isMainnet);
var testnets = getNetworkList().filter(isTestnet);
exports.isSameCoin = isSameCoin;
const mainnets = getNetworkList().filter(isMainnet);
const testnets = getNetworkList().filter(isTestnet);
/**

@@ -82,3 +94,3 @@ * Map where keys are mainnet networks and values are testnet networks

*/
var mainnetTestnetPairs = new Map(mainnets.map(function (m) { return [m, testnets.filter(function (t) { return getMainnet(t) === m; })]; }));
const mainnetTestnetPairs = new Map(mainnets.map((m) => [m, testnets.filter((t) => getMainnet(t) === m)]));
/**

@@ -93,5 +105,5 @@ * @param {Network} network

}
var testnets = mainnetTestnetPairs.get(network);
const testnets = mainnetTestnetPairs.get(network);
if (testnets === undefined) {
throw new Error("invalid argument");
throw new Error(`invalid argument`);
}

@@ -104,4 +116,5 @@ if (testnets.length === 0) {

}
throw new Error("more than one testnet for " + getNetworkName(network));
throw new Error(`more than one testnet for ${getNetworkName(network)}`);
}
exports.getTestnet = getTestnet;
/**

@@ -114,2 +127,3 @@ * @param {Network} network

}
exports.isBitcoin = isBitcoin;
/**

@@ -122,2 +136,3 @@ * @param {Network} network

}
exports.isBitcoinCash = isBitcoinCash;
/**

@@ -130,2 +145,3 @@ * @param {Network} network

}
exports.isBitcoinGold = isBitcoinGold;
/**

@@ -138,2 +154,3 @@ * @param {Network} network

}
exports.isBitcoinSV = isBitcoinSV;
/**

@@ -146,2 +163,3 @@ * @param {Network} network

}
exports.isDash = isDash;
/**

@@ -154,2 +172,3 @@ * @param {Network} network

}
exports.isLitecoin = isLitecoin;
/**

@@ -162,2 +181,3 @@ * @param {Network} network

}
exports.isZcash = isZcash;
/**

@@ -167,31 +187,17 @@ * @param {Network} network

*/
var isValidNetwork = typeforce.oneOf(isBitcoin, isBitcoinCash, isBitcoinGold, isBitcoinSV, isDash, isLitecoin, isZcash);
module.exports = {
BTC: networks.bitcoin.coin,
BCH: networks.bitcoincash.coin,
BSV: networks.bitcoinsv.coin,
BTG: networks.bitcoingold.coin,
DASH: networks.dash.coin,
LTC: networks.litecoin.coin,
ZEC: networks.zcash.coin,
getNetworkList: getNetworkList,
getNetworkName: getNetworkName,
getMainnet: getMainnet,
isMainnet: isMainnet,
getTestnet: getTestnet,
isTestnet: isTestnet,
isSameCoin: isSameCoin,
isBitcoin: isBitcoin,
isBitcoinCash: isBitcoinCash,
isBitcoinGold: isBitcoinGold,
isBitcoinSV: isBitcoinSV,
isDash: isDash,
isLitecoin: isLitecoin,
isZcash: isZcash,
isValidNetwork: isValidNetwork,
/**
* @deprecated: use isValidNetwork
*/
isValidCoin: isValidNetwork
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coins.js","sourceRoot":"","sources":["../../src/coins.js"],"names":[],"mappings":"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","sourcesContent":["// Coins supported by bitgo-bitcoinjs-lib\nconst typeforce = require('typeforce')\n\nconst networks = require('./networks')\n\n/**\n * @returns {Network[]} all known networks as array\n */\nfunction getNetworkList () {\n  return Object.keys(networks).map(n => networks[n])\n}\n\n/**\n * @param {Network} network\n * @returns {string} the name of the network. Returns undefined if network is not a value\n *                   of `networks`\n */\nfunction getNetworkName (network) {\n  return Object.keys(networks).find(n => networks[n] === network)\n}\n\n/**\n * @param {Network} network\n * @returns {Object} the mainnet corresponding to a testnet\n */\nfunction getMainnet (network) {\n  switch (network) {\n    case networks.bitcoin:\n    case networks.testnet:\n      return networks.bitcoin\n\n    case networks.bitcoincash:\n    case networks.bitcoincashTestnet:\n      return networks.bitcoincash\n\n    case networks.bitcoingold:\n    case networks.bitcoingoldTestnet:\n      return networks.bitcoingold\n\n    case networks.bitcoinsv:\n    case networks.bitcoinsvTestnet:\n      return networks.bitcoinsv\n\n    case networks.dash:\n    case networks.dashTest:\n      return networks.dash\n\n    case networks.litecoin:\n    case networks.litecoinTest:\n      return networks.litecoin\n\n    case networks.zcash:\n    case networks.zcashTest:\n      return networks.zcash\n  }\n  throw new TypeError(`invalid network`)\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is a mainnet\n */\nfunction isMainnet (network) {\n  return getMainnet(network) === network\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is a testnet\n */\nfunction isTestnet (network) {\n  return getMainnet(network) !== network\n}\n\n/**\n *\n * @param {Network} network\n * @param {Network} otherNetwork\n * @returns {boolean} true iff both networks are for the same coin\n */\nfunction isSameCoin (network, otherNetwork) {\n  return getMainnet(network) === getMainnet(otherNetwork)\n}\n\nconst mainnets = getNetworkList().filter(isMainnet)\nconst testnets = getNetworkList().filter(isTestnet)\n\n/**\n * Map where keys are mainnet networks and values are testnet networks\n * @type {Map<Network, Network[]>}\n */\nconst mainnetTestnetPairs = new Map(\n  mainnets.map(m => [m, testnets.filter(t => getMainnet(t) === m)])\n)\n\n/**\n * @param {Network} network\n * @returns {Network|undefined} - The testnet corresponding to a mainnet.\n *                               Returns undefined if a network has no testnet.\n */\nfunction getTestnet (network) {\n  if (isTestnet(network)) {\n    return network\n  }\n  const testnets = mainnetTestnetPairs.get(network)\n  if (testnets === undefined) {\n    throw new Error(`invalid argument`)\n  }\n  if (testnets.length === 0) {\n    return\n  }\n  if (testnets.length === 1) {\n    return testnets[0]\n  }\n  throw new Error(`more than one testnet for ${getNetworkName(network)}`)\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network bitcoin or testnet\n */\nfunction isBitcoin (network) {\n  return getMainnet(network) === networks.bitcoin\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoincash or bitcoincashTestnet\n */\nfunction isBitcoinCash (network) {\n  return getMainnet(network) === networks.bitcoincash\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoingold\n */\nfunction isBitcoinGold (network) {\n  return getMainnet(network) === networks.bitcoingold\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoinsv or bitcoinsvTestnet\n */\nfunction isBitcoinSV (network) {\n  return getMainnet(network) === networks.bitcoinsv\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is dash or dashTest\n */\nfunction isDash (network) {\n  return getMainnet(network) === networks.dash\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is litecoin or litecoinTest\n */\nfunction isLitecoin (network) {\n  return getMainnet(network) === networks.litecoin\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is zcash or zcashTest\n */\nfunction isZcash (network) {\n  return getMainnet(network) === networks.zcash\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} returns true iff network is any of the network stated in the argument\n */\nconst isValidNetwork = typeforce.oneOf(\n  isBitcoin,\n  isBitcoinCash,\n  isBitcoinGold,\n  isBitcoinSV,\n  isDash,\n  isLitecoin,\n  isZcash\n)\n\nmodule.exports = {\n  BTC: networks.bitcoin.coin,\n  BCH: networks.bitcoincash.coin,\n  BSV: networks.bitcoinsv.coin,\n  BTG: networks.bitcoingold.coin,\n  DASH: networks.dash.coin,\n  LTC: networks.litecoin.coin,\n  ZEC: networks.zcash.coin,\n\n  getNetworkList,\n  getNetworkName,\n\n  getMainnet,\n  isMainnet,\n  getTestnet,\n  isTestnet,\n  isSameCoin,\n\n  isBitcoin,\n  isBitcoinCash,\n  isBitcoinGold,\n  isBitcoinSV,\n  isDash,\n  isLitecoin,\n  isZcash,\n\n  isValidNetwork,\n  /**\n   * @deprecated: use isValidNetwork\n   */\n  isValidCoin: isValidNetwork\n}\n"]}
exports.isValidNetwork = typeforce.oneOf(isBitcoin, isBitcoinCash, isBitcoinGold, isBitcoinSV, isDash, isLitecoin, isZcash);
/** @deprecated */
exports.BCH = networkTypes_1.coins.BCH;
/** @deprecated */
exports.BSV = networkTypes_1.coins.BSV;
/** @deprecated */
exports.BTC = networkTypes_1.coins.BTC;
/** @deprecated */
exports.BTG = networkTypes_1.coins.BTG;
/** @deprecated */
exports.DASH = networkTypes_1.coins.DASH;
/** @deprecated */
exports.LTC = networkTypes_1.coins.LTC;
/** @deprecated */
exports.ZEC = networkTypes_1.coins.ZEC;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"coins.js","sourceRoot":"","sources":["../../src/coins.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as networks from './networks';\nimport { coins, Network } from './networkTypes';\n\nconst typeforce = require('typeforce');\n\n/**\n * @returns {Network[]} all known networks as array\n */\nexport function getNetworkList(): Network[] {\n  return Object.keys(networks).map((n) => networks[n]);\n}\n\n/**\n * @param {Network} network\n * @returns {string} the name of the network. Returns undefined if network is not a value\n *                   of `networks`\n */\nexport function getNetworkName(network: Network): string | undefined {\n  return Object.keys(networks).find((n) => networks[n] === network);\n}\n\n/**\n * @param {Network} network\n * @returns {Object} the mainnet corresponding to a testnet\n */\nexport function getMainnet(network: Network): Network {\n  switch (network) {\n    case networks.bitcoin:\n    case networks.testnet:\n      return networks.bitcoin;\n\n    case networks.bitcoincash:\n    case networks.bitcoincashTestnet:\n      return networks.bitcoincash;\n\n    case networks.bitcoingold:\n    case networks.bitcoingoldTestnet:\n      return networks.bitcoingold;\n\n    case networks.bitcoinsv:\n    case networks.bitcoinsvTestnet:\n      return networks.bitcoinsv;\n\n    case networks.dash:\n    case networks.dashTest:\n      return networks.dash;\n\n    case networks.litecoin:\n    case networks.litecoinTest:\n      return networks.litecoin;\n\n    case networks.zcash:\n    case networks.zcashTest:\n      return networks.zcash;\n  }\n  throw new TypeError(`invalid network`);\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is a mainnet\n */\nexport function isMainnet(network: Network): boolean {\n  return getMainnet(network) === network;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is a testnet\n */\nexport function isTestnet(network: Network): boolean {\n  return getMainnet(network) !== network;\n}\n\n/**\n *\n * @param {Network} network\n * @param {Network} otherNetwork\n * @returns {boolean} true iff both networks are for the same coin\n */\nexport function isSameCoin(network: Network, otherNetwork: Network) {\n  return getMainnet(network) === getMainnet(otherNetwork);\n}\n\nconst mainnets = getNetworkList().filter(isMainnet);\nconst testnets = getNetworkList().filter(isTestnet);\n\n/**\n * Map where keys are mainnet networks and values are testnet networks\n * @type {Map<Network, Network[]>}\n */\nconst mainnetTestnetPairs = new Map(mainnets.map((m) => [m, testnets.filter((t) => getMainnet(t) === m)]));\n\n/**\n * @param {Network} network\n * @returns {Network|undefined} - The testnet corresponding to a mainnet.\n *                               Returns undefined if a network has no testnet.\n */\nexport function getTestnet(network: Network): Network | undefined {\n  if (isTestnet(network)) {\n    return network;\n  }\n  const testnets = mainnetTestnetPairs.get(network);\n  if (testnets === undefined) {\n    throw new Error(`invalid argument`);\n  }\n  if (testnets.length === 0) {\n    return;\n  }\n  if (testnets.length === 1) {\n    return testnets[0];\n  }\n  throw new Error(`more than one testnet for ${getNetworkName(network)}`);\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network bitcoin or testnet\n */\nexport function isBitcoin(network: Network) {\n  return getMainnet(network) === networks.bitcoin;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoincash or bitcoincashTestnet\n */\nexport function isBitcoinCash(network: Network) {\n  return getMainnet(network) === networks.bitcoincash;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoingold\n */\nexport function isBitcoinGold(network: Network) {\n  return getMainnet(network) === networks.bitcoingold;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is bitcoinsv or bitcoinsvTestnet\n */\nexport function isBitcoinSV(network: Network) {\n  return getMainnet(network) === networks.bitcoinsv;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is dash or dashTest\n */\nexport function isDash(network: Network) {\n  return getMainnet(network) === networks.dash;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is litecoin or litecoinTest\n */\nexport function isLitecoin(network: Network) {\n  return getMainnet(network) === networks.litecoin;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} true iff network is zcash or zcashTest\n */\nexport function isZcash(network) {\n  return getMainnet(network) === networks.zcash;\n}\n\n/**\n * @param {Network} network\n * @returns {boolean} returns true iff network is any of the network stated in the argument\n */\nexport const isValidNetwork = typeforce.oneOf(\n  isBitcoin,\n  isBitcoinCash,\n  isBitcoinGold,\n  isBitcoinSV,\n  isDash,\n  isLitecoin,\n  isZcash\n);\n\n/** @deprecated */\nexport const BCH = coins.BCH;\n/** @deprecated */\nexport const BSV = coins.BSV;\n/** @deprecated */\nexport const BTC = coins.BTC;\n/** @deprecated */\nexport const BTG = coins.BTG;\n/** @deprecated */\nexport const DASH = coins.DASH;\n/** @deprecated */\nexport const LTC = coins.LTC;\n/** @deprecated */\nexport const ZEC = coins.ZEC;\n"]}

@@ -41,3 +41,3 @@ var baddress = require('./address');

if (!this.__Q && this.d) {
var qBuf = fastcurve.publicKeyCreate(this.d.toBuffer(32), false);
const qBuf = fastcurve.publicKeyCreate(this.d.toBuffer(32), false);
this.__Q = qBuf ? ecurve.Point.decodeFrom(curve, qBuf) : secp256k1.G.multiply(this.d);

@@ -138,2 +138,2 @@ }

module.exports = ECPair;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecpair.js","sourceRoot":"","sources":["../../src/ecpair.js"],"names":[],"mappings":"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","sourcesContent":["var baddress = require('./address')\nvar bcrypto = require('./crypto')\nvar ecdsa = require('./ecdsa')\nvar randomBytes = require('randombytes')\nvar typeforce = require('typeforce')\nvar types = require('./types')\nvar wif = require('wif')\n\nvar NETWORKS = require('./networks')\nvar BigInteger = require('bigi')\n\nvar ecurve = require('ecurve')\nvar curve = ecurve.getCurveByName('secp256k1')\nvar secp256k1 = ecdsa.__curve\n\nvar fastcurve = require('./fastcurve')\n\nfunction ECPair (d, Q, options) {\n  if (options) {\n    typeforce({\n      compressed: types.maybe(types.Boolean),\n      network: types.maybe(types.Network)\n    }, options)\n  }\n\n  options = options || {}\n\n  if (d) {\n    if (d.signum() <= 0) throw new Error('Private key must be greater than 0')\n    if (d.compareTo(secp256k1.n) >= 0) throw new Error('Private key must be less than the curve order')\n    if (Q) throw new TypeError('Unexpected publicKey parameter')\n\n    this.d = d\n  } else {\n    typeforce(types.ECPoint, Q)\n\n    this.__Q = Q\n  }\n\n  this.compressed = options.compressed === undefined ? true : options.compressed\n  this.network = options.network || NETWORKS.bitcoin\n}\n\nObject.defineProperty(ECPair.prototype, 'Q', {\n  get: function () {\n    if (!this.__Q && this.d) {\n      const qBuf = fastcurve.publicKeyCreate(this.d.toBuffer(32), false)\n      this.__Q = qBuf ? ecurve.Point.decodeFrom(curve, qBuf) : secp256k1.G.multiply(this.d)\n    }\n\n    return this.__Q\n  }\n})\n\nECPair.fromPublicKeyBuffer = function (buffer, network) {\n  var Q = ecurve.Point.decodeFrom(secp256k1, buffer)\n\n  return new ECPair(null, Q, {\n    compressed: Q.compressed,\n    network: network\n  })\n}\nECPair.fromWIF = function (string, network) {\n  var decoded = wif.decode(string)\n  var version = decoded.version\n\n  // list of networks?\n  if (types.Array(network)) {\n    network = network.filter(function (x) {\n      return version === x.wif\n    }).pop()\n\n    if (!network) throw new Error('Unknown network version')\n\n  // otherwise, assume a network object (or default to bitcoin)\n  } else {\n    network = network || NETWORKS.bitcoin\n\n    if (version !== network.wif) throw new Error('Invalid network version')\n  }\n\n  var d = BigInteger.fromBuffer(decoded.privateKey)\n\n  return new ECPair(d, null, {\n    compressed: decoded.compressed,\n    network: network\n  })\n}\n\nECPair.makeRandom = function (options) {\n  options = options || {}\n\n  var rng = options.rng || randomBytes\n\n  var d\n  do {\n    var buffer = rng(32)\n    typeforce(types.Buffer256bit, buffer)\n\n    d = BigInteger.fromBuffer(buffer)\n  } while (d.signum() <= 0 || d.compareTo(secp256k1.n) >= 0)\n\n  return new ECPair(d, null, options)\n}\n\nECPair.prototype.getAddress = function () {\n  return baddress.toBase58Check(bcrypto.hash160(this.getPublicKeyBuffer()), this.getNetwork().pubKeyHash)\n}\n\nECPair.prototype.getNetwork = function () {\n  return this.network\n}\n\nECPair.prototype.getPublicKeyBuffer = function () {\n  return this.Q.getEncoded(this.compressed)\n}\n\nECPair.prototype.sign = function (hash) {\n  if (!this.d) throw new Error('Missing private key')\n\n  var sig = fastcurve.sign(hash, this.d)\n  if (sig !== undefined) return sig\n  return ecdsa.sign(hash, this.d)\n}\n\nECPair.prototype.toWIF = function () {\n  if (!this.d) throw new Error('Missing private key')\n\n  return wif.encode(this.network.wif, this.d.toBuffer(32), this.compressed)\n}\n\nECPair.prototype.verify = function (hash, signature) {\n  var fastsig = fastcurve.verify(hash, signature, this.getPublicKeyBuffer())\n  if (fastsig !== undefined) return fastsig\n  return ecdsa.verify(hash, signature, this.Q)\n}\n\n/**\n * @deprecated\n * Use {@see keyutil.privateKeyBufferToECPair} instead\n * Will be removed in next major version (BLOCK-267)\n */\nECPair.fromPrivateKeyBuffer = function (buffer, network) {\n  // toplevel import unavailable due to circular dependency\n  var keyutil = require('./bitgo/keyutil')\n  return keyutil.privateKeyBufferToECPair(buffer, network)\n}\n\n/**\n * @deprecated\n * Use {@see keyutil.privateKeyBufferFromECPair} instead\n * Will be removed in next major version (BLOCK-267)\n */\nECPair.prototype.getPrivateKeyBuffer = function () {\n  // toplevel import unavailable due to circular dependency\n  var keyutil = require('./bitgo/keyutil')\n  return keyutil.privateKeyBufferFromECPair(this)\n}\n\nmodule.exports = ECPair\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ecpair.js","sourceRoot":"","sources":["../../src/ecpair.js"],"names":[],"mappings":"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","sourcesContent":["var baddress = require('./address')\nvar bcrypto = require('./crypto')\nvar ecdsa = require('./ecdsa')\nvar randomBytes = require('randombytes')\nvar typeforce = require('typeforce')\nvar types = require('./types')\nvar wif = require('wif')\n\nvar NETWORKS = require('./networks')\nvar BigInteger = require('bigi')\n\nvar ecurve = require('ecurve')\nvar curve = ecurve.getCurveByName('secp256k1')\nvar secp256k1 = ecdsa.__curve\n\nvar fastcurve = require('./fastcurve')\n\nfunction ECPair (d, Q, options) {\n  if (options) {\n    typeforce({\n      compressed: types.maybe(types.Boolean),\n      network: types.maybe(types.Network)\n    }, options)\n  }\n\n  options = options || {}\n\n  if (d) {\n    if (d.signum() <= 0) throw new Error('Private key must be greater than 0')\n    if (d.compareTo(secp256k1.n) >= 0) throw new Error('Private key must be less than the curve order')\n    if (Q) throw new TypeError('Unexpected publicKey parameter')\n\n    this.d = d\n  } else {\n    typeforce(types.ECPoint, Q)\n\n    this.__Q = Q\n  }\n\n  this.compressed = options.compressed === undefined ? true : options.compressed\n  this.network = options.network || NETWORKS.bitcoin\n}\n\nObject.defineProperty(ECPair.prototype, 'Q', {\n  get: function () {\n    if (!this.__Q && this.d) {\n      const qBuf = fastcurve.publicKeyCreate(this.d.toBuffer(32), false)\n      this.__Q = qBuf ? ecurve.Point.decodeFrom(curve, qBuf) : secp256k1.G.multiply(this.d)\n    }\n\n    return this.__Q\n  }\n})\n\nECPair.fromPublicKeyBuffer = function (buffer, network) {\n  var Q = ecurve.Point.decodeFrom(secp256k1, buffer)\n\n  return new ECPair(null, Q, {\n    compressed: Q.compressed,\n    network: network\n  })\n}\nECPair.fromWIF = function (string, network) {\n  var decoded = wif.decode(string)\n  var version = decoded.version\n\n  // list of networks?\n  if (types.Array(network)) {\n    network = network.filter(function (x) {\n      return version === x.wif\n    }).pop()\n\n    if (!network) throw new Error('Unknown network version')\n\n  // otherwise, assume a network object (or default to bitcoin)\n  } else {\n    network = network || NETWORKS.bitcoin\n\n    if (version !== network.wif) throw new Error('Invalid network version')\n  }\n\n  var d = BigInteger.fromBuffer(decoded.privateKey)\n\n  return new ECPair(d, null, {\n    compressed: decoded.compressed,\n    network: network\n  })\n}\n\nECPair.makeRandom = function (options) {\n  options = options || {}\n\n  var rng = options.rng || randomBytes\n\n  var d\n  do {\n    var buffer = rng(32)\n    typeforce(types.Buffer256bit, buffer)\n\n    d = BigInteger.fromBuffer(buffer)\n  } while (d.signum() <= 0 || d.compareTo(secp256k1.n) >= 0)\n\n  return new ECPair(d, null, options)\n}\n\nECPair.prototype.getAddress = function () {\n  return baddress.toBase58Check(bcrypto.hash160(this.getPublicKeyBuffer()), this.getNetwork().pubKeyHash)\n}\n\nECPair.prototype.getNetwork = function () {\n  return this.network\n}\n\nECPair.prototype.getPublicKeyBuffer = function () {\n  return this.Q.getEncoded(this.compressed)\n}\n\nECPair.prototype.sign = function (hash) {\n  if (!this.d) throw new Error('Missing private key')\n\n  var sig = fastcurve.sign(hash, this.d)\n  if (sig !== undefined) return sig\n  return ecdsa.sign(hash, this.d)\n}\n\nECPair.prototype.toWIF = function () {\n  if (!this.d) throw new Error('Missing private key')\n\n  return wif.encode(this.network.wif, this.d.toBuffer(32), this.compressed)\n}\n\nECPair.prototype.verify = function (hash, signature) {\n  var fastsig = fastcurve.verify(hash, signature, this.getPublicKeyBuffer())\n  if (fastsig !== undefined) return fastsig\n  return ecdsa.verify(hash, signature, this.Q)\n}\n\n/**\n * @deprecated\n * Use {@see keyutil.privateKeyBufferToECPair} instead\n * Will be removed in next major version (BLOCK-267)\n */\nECPair.fromPrivateKeyBuffer = function (buffer, network) {\n  // toplevel import unavailable due to circular dependency\n  var keyutil = require('./bitgo/keyutil')\n  return keyutil.privateKeyBufferToECPair(buffer, network)\n}\n\n/**\n * @deprecated\n * Use {@see keyutil.privateKeyBufferFromECPair} instead\n * Will be removed in next major version (BLOCK-267)\n */\nECPair.prototype.getPrivateKeyBuffer = function () {\n  // toplevel import unavailable due to circular dependency\n  var keyutil = require('./bitgo/keyutil')\n  return keyutil.privateKeyBufferFromECPair(this)\n}\n\nmodule.exports = ECPair\n"]}

@@ -1,41 +0,24 @@

var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
return extendStatics(d, b);
};
return function (d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var typeforce = require('typeforce');
var types = require('../../types');
var version = require('./version');
var _a = require('../../bufferutils'), BufferReader = _a.BufferReader, BufferWriter = _a.BufferWriter;
var NUM_JOINSPLITS_INPUTS = 2;
var NUM_JOINSPLITS_OUTPUTS = 2;
var NOTECIPHERTEXT_SIZE = 1 + 8 + 32 + 32 + 512 + 16;
var G1_PREFIX_MASK = 0x02;
var G2_PREFIX_MASK = 0x0a;
var ZcashBufferReader = /** @class */ (function (_super) {
__extends(ZcashBufferReader, _super);
function ZcashBufferReader(buffer, offset, txVersion) {
var _this = _super.call(this, buffer, offset) || this;
const typeforce = require('typeforce');
const types = require('../../types');
const version = require('./version');
const { BufferReader, BufferWriter } = require('../../bufferutils');
const NUM_JOINSPLITS_INPUTS = 2;
const NUM_JOINSPLITS_OUTPUTS = 2;
const NOTECIPHERTEXT_SIZE = 1 + 8 + 32 + 32 + 512 + 16;
const G1_PREFIX_MASK = 0x02;
const G2_PREFIX_MASK = 0x0a;
class ZcashBufferReader extends BufferReader {
constructor(buffer, offset, txVersion) {
super(buffer, offset);
typeforce(types.maybe(types.Int32), txVersion);
_this.txVersion = txVersion;
return _this;
this.txVersion = txVersion;
}
ZcashBufferReader.prototype.readInt64 = function () {
var a = this.buffer.readUInt32LE(this.offset);
var b = this.buffer.readInt32LE(this.offset + 4);
readInt64() {
const a = this.buffer.readUInt32LE(this.offset);
let b = this.buffer.readInt32LE(this.offset + 4);
b *= 0x100000000;
this.offset += 8;
return b + a;
};
ZcashBufferReader.prototype.readCompressedG1 = function () {
}
readCompressedG1() {
var yLsb = this.readUInt8() & 1;

@@ -47,4 +30,4 @@ var x = this.readSlice(32);

};
};
ZcashBufferReader.prototype.readCompressedG2 = function () {
}
readCompressedG2() {
var yLsb = this.readUInt8() & 1;

@@ -56,4 +39,4 @@ var x = this.readSlice(64);

};
};
ZcashBufferReader.prototype.readZKProof = function () {
}
readZKProof() {
var zkproof;

@@ -80,4 +63,4 @@ if (this.txVersion >= version.SAPLING) {

return zkproof;
};
ZcashBufferReader.prototype.readJoinSplit = function () {
}
readJoinSplit() {
var vpubOld = this.readUInt64();

@@ -117,4 +100,4 @@ var vpubNew = this.readUInt64();

};
};
ZcashBufferReader.prototype.readShieldedSpend = function () {
}
readShieldedSpend() {
var cv = this.readSlice(32);

@@ -134,4 +117,4 @@ var anchor = this.readSlice(32);

};
};
ZcashBufferReader.prototype.readShieldedOutput = function () {
}
readShieldedOutput() {
var cv = this.readSlice(32);

@@ -151,21 +134,15 @@ var cmu = this.readSlice(32);

};
};
return ZcashBufferReader;
}(BufferReader));
var ZcashBufferWriter = /** @class */ (function (_super) {
__extends(ZcashBufferWriter, _super);
function ZcashBufferWriter() {
return _super !== null && _super.apply(this, arguments) || this;
}
ZcashBufferWriter.prototype.writeCompressedG1 = function (i) {
}
class ZcashBufferWriter extends BufferWriter {
writeCompressedG1(i) {
this.writeUInt8(G1_PREFIX_MASK | i.yLsb);
this.writeSlice(i.x);
};
ZcashBufferWriter.prototype.writeCompressedG2 = function (i) {
}
writeCompressedG2(i) {
this.writeUInt8(G2_PREFIX_MASK | i.yLsb);
this.writeSlice(i.x);
};
return ZcashBufferWriter;
}(BufferWriter));
module.exports = { ZcashBufferReader: ZcashBufferReader, ZcashBufferWriter: ZcashBufferWriter };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bufferutils.js","sourceRoot":"","sources":["../../../../src/forks/zcash/bufferutils.js"],"names":[],"mappings":"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","sourcesContent":["const typeforce = require('typeforce')\nconst types = require('../../types')\nconst version = require('./version')\n\nconst { BufferReader, BufferWriter } = require('../../bufferutils')\n\nconst NUM_JOINSPLITS_INPUTS = 2\nconst NUM_JOINSPLITS_OUTPUTS = 2\nconst NOTECIPHERTEXT_SIZE = 1 + 8 + 32 + 32 + 512 + 16\n\nconst G1_PREFIX_MASK = 0x02\nconst G2_PREFIX_MASK = 0x0a\n\nclass ZcashBufferReader extends BufferReader {\n  constructor (buffer, offset, txVersion) {\n    super(buffer, offset)\n    typeforce(types.maybe(types.Int32), txVersion)\n    this.txVersion = txVersion\n  }\n\n  readInt64 () {\n    const a = this.buffer.readUInt32LE(this.offset)\n    let b = this.buffer.readInt32LE(this.offset + 4)\n    b *= 0x100000000\n    this.offset += 8\n    return b + a\n  }\n\n  readCompressedG1 () {\n    var yLsb = this.readUInt8() & 1\n    var x = this.readSlice(32)\n    return {\n      x: x,\n      yLsb: yLsb\n    }\n  }\n\n  readCompressedG2 () {\n    var yLsb = this.readUInt8() & 1\n    var x = this.readSlice(64)\n    return {\n      x: x,\n      yLsb: yLsb\n    }\n  }\n\n  readZKProof () {\n    var zkproof\n    if (this.txVersion >= version.SAPLING) {\n      zkproof = {\n        sA: this.readSlice(48),\n        sB: this.readSlice(96),\n        sC: this.readSlice(48)\n      }\n    } else {\n      zkproof = {\n        gA: this.readCompressedG1(),\n        gAPrime: this.readCompressedG1(),\n        gB: this.readCompressedG2(),\n        gBPrime: this.readCompressedG1(),\n        gC: this.readCompressedG1(),\n        gCPrime: this.readCompressedG1(),\n        gK: this.readCompressedG1(),\n        gH: this.readCompressedG1()\n      }\n    }\n    return zkproof\n  }\n\n  readJoinSplit () {\n    var vpubOld = this.readUInt64()\n    var vpubNew = this.readUInt64()\n    var anchor = this.readSlice(32)\n    var nullifiers = []\n    for (var j = 0; j < NUM_JOINSPLITS_INPUTS; j++) {\n      nullifiers.push(this.readSlice(32))\n    }\n    var commitments = []\n    for (j = 0; j < NUM_JOINSPLITS_OUTPUTS; j++) {\n      commitments.push(this.readSlice(32))\n    }\n    var ephemeralKey = this.readSlice(32)\n    var randomSeed = this.readSlice(32)\n    var macs = []\n    for (j = 0; j < NUM_JOINSPLITS_INPUTS; j++) {\n      macs.push(this.readSlice(32))\n    }\n\n    var zkproof = this.readZKProof()\n    var ciphertexts = []\n    for (j = 0; j < NUM_JOINSPLITS_OUTPUTS; j++) {\n      ciphertexts.push(this.readSlice(NOTECIPHERTEXT_SIZE))\n    }\n    return {\n      vpubOld: vpubOld,\n      vpubNew: vpubNew,\n      anchor: anchor,\n      nullifiers: nullifiers,\n      commitments: commitments,\n      ephemeralKey: ephemeralKey,\n      randomSeed: randomSeed,\n      macs: macs,\n      zkproof: zkproof,\n      ciphertexts: ciphertexts\n    }\n  }\n\n  readShieldedSpend () {\n    var cv = this.readSlice(32)\n    var anchor = this.readSlice(32)\n    var nullifier = this.readSlice(32)\n    var rk = this.readSlice(32)\n    var zkproof = this.readZKProof()\n    var spendAuthSig = this.readSlice(64)\n    return {\n      cv: cv,\n      anchor: anchor,\n      nullifier: nullifier,\n      rk: rk,\n      zkproof: zkproof,\n      spendAuthSig: spendAuthSig\n    }\n  }\n\n  readShieldedOutput () {\n    var cv = this.readSlice(32)\n    var cmu = this.readSlice(32)\n    var ephemeralKey = this.readSlice(32)\n    var encCiphertext = this.readSlice(580)\n    var outCiphertext = this.readSlice(80)\n    var zkproof = this.readZKProof()\n\n    return {\n      cv: cv,\n      cmu: cmu,\n      ephemeralKey: ephemeralKey,\n      encCiphertext: encCiphertext,\n      outCiphertext: outCiphertext,\n      zkproof: zkproof\n    }\n  }\n}\n\nclass ZcashBufferWriter extends BufferWriter {\n  writeCompressedG1 (i) {\n    this.writeUInt8(G1_PREFIX_MASK | i.yLsb)\n    this.writeSlice(i.x)\n  }\n\n  writeCompressedG2 (i) {\n    this.writeUInt8(G2_PREFIX_MASK | i.yLsb)\n    this.writeSlice(i.x)\n  }\n}\n\nmodule.exports = { ZcashBufferReader, ZcashBufferWriter }\n"]}
}
}
module.exports = { ZcashBufferReader, ZcashBufferWriter };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bufferutils.js","sourceRoot":"","sources":["../../../../src/forks/zcash/bufferutils.js"],"names":[],"mappings":"AAAA,MAAM,SAAS,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;AACtC,MAAM,KAAK,GAAG,OAAO,CAAC,aAAa,CAAC,CAAA;AACpC,MAAM,OAAO,GAAG,OAAO,CAAC,WAAW,CAAC,CAAA;AAEpC,MAAM,EAAE,YAAY,EAAE,YAAY,EAAE,GAAG,OAAO,CAAC,mBAAmB,CAAC,CAAA;AAEnE,MAAM,qBAAqB,GAAG,CAAC,CAAA;AAC/B,MAAM,sBAAsB,GAAG,CAAC,CAAA;AAChC,MAAM,mBAAmB,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,GAAG,EAAE,GAAG,GAAG,GAAG,EAAE,CAAA;AAEtD,MAAM,cAAc,GAAG,IAAI,CAAA;AAC3B,MAAM,cAAc,GAAG,IAAI,CAAA;AAE3B,MAAM,iBAAkB,SAAQ,YAAY;IAC1C,YAAa,MAAM,EAAE,MAAM,EAAE,SAAS;QACpC,KAAK,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QACrB,SAAS,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,KAAK,CAAC,EAAE,SAAS,CAAC,CAAA;QAC9C,IAAI,CAAC,SAAS,GAAG,SAAS,CAAA;IAC5B,CAAC;IAED,SAAS;QACP,MAAM,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,CAAA;QAC/C,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,WAAW,CAAC,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAA;QAChD,CAAC,IAAI,WAAW,CAAA;QAChB,IAAI,CAAC,MAAM,IAAI,CAAC,CAAA;QAChB,OAAO,CAAC,GAAG,CAAC,CAAA;IACd,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,CAAA;QAC/B,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC1B,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,IAAI,EAAE,IAAI;SACX,CAAA;IACH,CAAC;IAED,gBAAgB;QACd,IAAI,IAAI,GAAG,IAAI,CAAC,SAAS,EAAE,GAAG,CAAC,CAAA;QAC/B,IAAI,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC1B,OAAO;YACL,CAAC,EAAE,CAAC;YACJ,IAAI,EAAE,IAAI;SACX,CAAA;IACH,CAAC;IAED,WAAW;QACT,IAAI,OAAO,CAAA;QACX,IAAI,IAAI,CAAC,SAAS,IAAI,OAAO,CAAC,OAAO,EAAE;YACrC,OAAO,GAAG;gBACR,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;gBACtB,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;gBACtB,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC;aACvB,CAAA;SACF;aAAM;YACL,OAAO,GAAG;gBACR,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAC3B,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAChC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAC3B,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAChC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAC3B,OAAO,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAChC,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE;gBAC3B,EAAE,EAAE,IAAI,CAAC,gBAAgB,EAAE;aAC5B,CAAA;SACF;QACD,OAAO,OAAO,CAAA;IAChB,CAAC;IAED,aAAa;QACX,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QAC/B,IAAI,OAAO,GAAG,IAAI,CAAC,UAAU,EAAE,CAAA;QAC/B,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC/B,IAAI,UAAU,GAAG,EAAE,CAAA;QACnB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,qBAAqB,EAAE,CAAC,EAAE,EAAE;YAC9C,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAA;SACpC;QACD,IAAI,WAAW,GAAG,EAAE,CAAA;QACpB,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,sBAAsB,EAAE,CAAC,EAAE,EAAE;YAC3C,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAA;SACrC;QACD,IAAI,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACrC,IAAI,UAAU,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACnC,IAAI,IAAI,GAAG,EAAE,CAAA;QACb,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,qBAAqB,EAAE,CAAC,EAAE,EAAE;YAC1C,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAC,CAAA;SAC9B;QAED,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAA;QAChC,IAAI,WAAW,GAAG,EAAE,CAAA;QACpB,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,sBAAsB,EAAE,CAAC,EAAE,EAAE;YAC3C,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,mBAAmB,CAAC,CAAC,CAAA;SACtD;QACD,OAAO;YACL,OAAO,EAAE,OAAO;YAChB,OAAO,EAAE,OAAO;YAChB,MAAM,EAAE,MAAM;YACd,UAAU,EAAE,UAAU;YACtB,WAAW,EAAE,WAAW;YACxB,YAAY,EAAE,YAAY;YAC1B,UAAU,EAAE,UAAU;YACtB,IAAI,EAAE,IAAI;YACV,OAAO,EAAE,OAAO;YAChB,WAAW,EAAE,WAAW;SACzB,CAAA;IACH,CAAC;IAED,iBAAiB;QACf,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC3B,IAAI,MAAM,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC/B,IAAI,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAClC,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC3B,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAA;QAChC,IAAI,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACrC,OAAO;YACL,EAAE,EAAE,EAAE;YACN,MAAM,EAAE,MAAM;YACd,SAAS,EAAE,SAAS;YACpB,EAAE,EAAE,EAAE;YACN,OAAO,EAAE,OAAO;YAChB,YAAY,EAAE,YAAY;SAC3B,CAAA;IACH,CAAC;IAED,kBAAkB;QAChB,IAAI,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC3B,IAAI,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QAC5B,IAAI,YAAY,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACrC,IAAI,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,CAAA;QACvC,IAAI,aAAa,GAAG,IAAI,CAAC,SAAS,CAAC,EAAE,CAAC,CAAA;QACtC,IAAI,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAA;QAEhC,OAAO;YACL,EAAE,EAAE,EAAE;YACN,GAAG,EAAE,GAAG;YACR,YAAY,EAAE,YAAY;YAC1B,aAAa,EAAE,aAAa;YAC5B,aAAa,EAAE,aAAa;YAC5B,OAAO,EAAE,OAAO;SACjB,CAAA;IACH,CAAC;CACF;AAED,MAAM,iBAAkB,SAAQ,YAAY;IAC1C,iBAAiB,CAAE,CAAC;QAClB,IAAI,CAAC,UAAU,CAAC,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA;QACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACtB,CAAC;IAED,iBAAiB,CAAE,CAAC;QAClB,IAAI,CAAC,UAAU,CAAC,cAAc,GAAG,CAAC,CAAC,IAAI,CAAC,CAAA;QACxC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;IACtB,CAAC;CACF;AAED,MAAM,CAAC,OAAO,GAAG,EAAE,iBAAiB,EAAE,iBAAiB,EAAE,CAAA","sourcesContent":["const typeforce = require('typeforce')\nconst types = require('../../types')\nconst version = require('./version')\n\nconst { BufferReader, BufferWriter } = require('../../bufferutils')\n\nconst NUM_JOINSPLITS_INPUTS = 2\nconst NUM_JOINSPLITS_OUTPUTS = 2\nconst NOTECIPHERTEXT_SIZE = 1 + 8 + 32 + 32 + 512 + 16\n\nconst G1_PREFIX_MASK = 0x02\nconst G2_PREFIX_MASK = 0x0a\n\nclass ZcashBufferReader extends BufferReader {\n  constructor (buffer, offset, txVersion) {\n    super(buffer, offset)\n    typeforce(types.maybe(types.Int32), txVersion)\n    this.txVersion = txVersion\n  }\n\n  readInt64 () {\n    const a = this.buffer.readUInt32LE(this.offset)\n    let b = this.buffer.readInt32LE(this.offset + 4)\n    b *= 0x100000000\n    this.offset += 8\n    return b + a\n  }\n\n  readCompressedG1 () {\n    var yLsb = this.readUInt8() & 1\n    var x = this.readSlice(32)\n    return {\n      x: x,\n      yLsb: yLsb\n    }\n  }\n\n  readCompressedG2 () {\n    var yLsb = this.readUInt8() & 1\n    var x = this.readSlice(64)\n    return {\n      x: x,\n      yLsb: yLsb\n    }\n  }\n\n  readZKProof () {\n    var zkproof\n    if (this.txVersion >= version.SAPLING) {\n      zkproof = {\n        sA: this.readSlice(48),\n        sB: this.readSlice(96),\n        sC: this.readSlice(48)\n      }\n    } else {\n      zkproof = {\n        gA: this.readCompressedG1(),\n        gAPrime: this.readCompressedG1(),\n        gB: this.readCompressedG2(),\n        gBPrime: this.readCompressedG1(),\n        gC: this.readCompressedG1(),\n        gCPrime: this.readCompressedG1(),\n        gK: this.readCompressedG1(),\n        gH: this.readCompressedG1()\n      }\n    }\n    return zkproof\n  }\n\n  readJoinSplit () {\n    var vpubOld = this.readUInt64()\n    var vpubNew = this.readUInt64()\n    var anchor = this.readSlice(32)\n    var nullifiers = []\n    for (var j = 0; j < NUM_JOINSPLITS_INPUTS; j++) {\n      nullifiers.push(this.readSlice(32))\n    }\n    var commitments = []\n    for (j = 0; j < NUM_JOINSPLITS_OUTPUTS; j++) {\n      commitments.push(this.readSlice(32))\n    }\n    var ephemeralKey = this.readSlice(32)\n    var randomSeed = this.readSlice(32)\n    var macs = []\n    for (j = 0; j < NUM_JOINSPLITS_INPUTS; j++) {\n      macs.push(this.readSlice(32))\n    }\n\n    var zkproof = this.readZKProof()\n    var ciphertexts = []\n    for (j = 0; j < NUM_JOINSPLITS_OUTPUTS; j++) {\n      ciphertexts.push(this.readSlice(NOTECIPHERTEXT_SIZE))\n    }\n    return {\n      vpubOld: vpubOld,\n      vpubNew: vpubNew,\n      anchor: anchor,\n      nullifiers: nullifiers,\n      commitments: commitments,\n      ephemeralKey: ephemeralKey,\n      randomSeed: randomSeed,\n      macs: macs,\n      zkproof: zkproof,\n      ciphertexts: ciphertexts\n    }\n  }\n\n  readShieldedSpend () {\n    var cv = this.readSlice(32)\n    var anchor = this.readSlice(32)\n    var nullifier = this.readSlice(32)\n    var rk = this.readSlice(32)\n    var zkproof = this.readZKProof()\n    var spendAuthSig = this.readSlice(64)\n    return {\n      cv: cv,\n      anchor: anchor,\n      nullifier: nullifier,\n      rk: rk,\n      zkproof: zkproof,\n      spendAuthSig: spendAuthSig\n    }\n  }\n\n  readShieldedOutput () {\n    var cv = this.readSlice(32)\n    var cmu = this.readSlice(32)\n    var ephemeralKey = this.readSlice(32)\n    var encCiphertext = this.readSlice(580)\n    var outCiphertext = this.readSlice(80)\n    var zkproof = this.readZKProof()\n\n    return {\n      cv: cv,\n      cmu: cmu,\n      ephemeralKey: ephemeralKey,\n      encCiphertext: encCiphertext,\n      outCiphertext: outCiphertext,\n      zkproof: zkproof\n    }\n  }\n}\n\nclass ZcashBufferWriter extends BufferWriter {\n  writeCompressedG1 (i) {\n    this.writeUInt8(G1_PREFIX_MASK | i.yLsb)\n    this.writeSlice(i.x)\n  }\n\n  writeCompressedG2 (i) {\n    this.writeUInt8(G2_PREFIX_MASK | i.yLsb)\n    this.writeSlice(i.x)\n  }\n}\n\nmodule.exports = { ZcashBufferReader, ZcashBufferWriter }\n"]}

@@ -0,1 +1,5 @@

"use strict";
/**
* @prettier
*/
/*

@@ -17,11 +21,3 @@

*/
var coins = {
BCH: 'bch',
BSV: 'bsv',
BTC: 'btc',
BTG: 'btg',
LTC: 'ltc',
ZEC: 'zec',
DASH: 'dash'
};
const networkTypes_1 = require("./networkTypes");
function getDefaultBip32Mainnet() {

@@ -32,3 +28,3 @@ return {

// base58 'xprv'
private: 0x0488ade4
private: 0x0488ade4,
};

@@ -41,6 +37,6 @@ }

// base58 'tprv'
private: 0x04358394
private: 0x04358394,
};
}
module.exports = {
const networks = {
// https://github.com/bitcoin/bitcoin/blob/master/src/validation.cpp

@@ -55,3 +51,3 @@ // https://github.com/bitcoin/bitcoin/blob/master/src/chainparams.cpp

wif: 0x80,
coin: coins.BTC
coin: networkTypes_1.coins.BTC,
},

@@ -65,6 +61,7 @@ testnet: {

wif: 0xef,
coin: coins.BTC
coin: networkTypes_1.coins.BTC,
},
// https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/validation.cpp
// https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/chainparams.cpp
// https://github.com/bitcoincashorg/bitcoincash.org/blob/master/spec/cashaddr.md
bitcoincash: {

@@ -76,4 +73,9 @@ messagePrefix: '\x18Bitcoin Signed Message:\n',

wif: 0x80,
coin: coins.BCH,
forkId: 0x00
coin: networkTypes_1.coins.BCH,
forkId: 0x00,
cashAddr: {
prefix: 'bitcoincash',
pubKeyHash: 0x00,
scriptHash: 0x08,
},
},

@@ -86,3 +88,8 @@ bitcoincashTestnet: {

wif: 0xef,
coin: coins.BCH
coin: networkTypes_1.coins.BCH,
cashAddr: {
prefix: 'bchtest',
pubKeyHash: 0x00,
scriptHash: 0x08,
},
},

@@ -100,3 +107,3 @@ // https://github.com/BTCGPU/BTCGPU/blob/master/src/validation.cpp

forkId: 79,
coin: coins.BTG
coin: networkTypes_1.coins.BTG,
},

@@ -111,3 +118,3 @@ bitcoingoldTestnet: {

forkId: 79,
coin: coins.BTG
coin: networkTypes_1.coins.BTG,
},

@@ -122,4 +129,4 @@ // https://github.com/bitcoin-sv/bitcoin-sv/blob/master/src/validation.cpp

wif: 0x80,
coin: coins.BSV,
forkId: 0x00
coin: networkTypes_1.coins.BSV,
forkId: 0x00,
},

@@ -132,3 +139,3 @@ bitcoinsvTestnet: {

wif: 0xef,
coin: coins.BSV
coin: networkTypes_1.coins.BSV,
},

@@ -143,3 +150,3 @@ // https://github.com/dashpay/dash/blob/master/src/validation.cpp

wif: 0xcc,
coin: coins.DASH
coin: networkTypes_1.coins.DASH,
},

@@ -152,3 +159,3 @@ dashTest: {

wif: 0xef,
coin: coins.DASH
coin: networkTypes_1.coins.DASH,
},

@@ -164,3 +171,3 @@ // https://github.com/litecoin-project/litecoin/blob/master/src/validation.cpp

wif: 0xb0,
coin: coins.LTC
coin: networkTypes_1.coins.LTC,
},

@@ -174,3 +181,3 @@ litecoinTest: {

wif: 0xef,
coin: coins.LTC
coin: networkTypes_1.coins.LTC,
},

@@ -194,5 +201,5 @@ // https://github.com/zcash/zcash/blob/master/src/validation.cpp

// 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)
4: 0xe9ff75a6 // (Canopy branch id, see https://zips.z.cash/zip-0251)
4: 0xe9ff75a6, // (Canopy branch id, see https://zips.z.cash/zip-0251)
},
coin: coins.ZEC
coin: networkTypes_1.coins.ZEC,
},

@@ -212,7 +219,8 @@ zcashTest: {

// 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)
4: 0xe9ff75a6 // (Canopy branch id, see https://zips.z.cash/zip-0251)
4: 0xe9ff75a6, // (Canopy branch id, see https://zips.z.cash/zip-0251)
},
coin: coins.ZEC
}
coin: networkTypes_1.coins.ZEC,
},
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"networks.js","sourceRoot":"","sources":["../../src/networks.js"],"names":[],"mappings":"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","sourcesContent":["/*\n\nThe values for the various fork coins can be found in these files:\n\nproperty       filename                  varname                           notes\n------------------------------------------------------------------------------------------------------------------------\nmessagePrefix  src/validation.cpp        strMessageMagic                   Format `${CoinName} Signed Message`\nbech32_hrp     src/chainparams.cpp       bech32_hrp                        Only for some networks\nbip32.public   src/chainparams.cpp       base58Prefixes[EXT_PUBLIC_KEY]    Mainnets have same value, testnets have same value\nbip32.private  src/chainparams.cpp       base58Prefixes[EXT_SECRET_KEY]    Mainnets have same value, testnets have same value\npubKeyHash     src/chainparams.cpp       base58Prefixes[PUBKEY_ADDRESS]\nscriptHash     src/chainparams.cpp       base58Prefixes[SCRIPT_ADDRESS]\nwif            src/chainparams.cpp       base58Prefixes[SECRET_KEY]        Testnets have same value\nforkId         src/script/interpreter.h  FORKID_*\n\n*/\n\nconst coins = {\n  BCH: 'bch',\n  BSV: 'bsv',\n  BTC: 'btc',\n  BTG: 'btg',\n  LTC: 'ltc',\n  ZEC: 'zec',\n  DASH: 'dash'\n}\n\nfunction getDefaultBip32Mainnet () {\n  return {\n    // base58 'xpub'\n    public: 0x0488b21e,\n    // base58 'xprv'\n    private: 0x0488ade4\n  }\n}\n\nfunction getDefaultBip32Testnet () {\n  return {\n    // base58 'tpub'\n    public: 0x043587cf,\n    // base58 'tprv'\n    private: 0x04358394\n  }\n}\n\nmodule.exports = {\n\n  // https://github.com/bitcoin/bitcoin/blob/master/src/validation.cpp\n  // https://github.com/bitcoin/bitcoin/blob/master/src/chainparams.cpp\n  bitcoin: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bech32: 'bc',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BTC\n  },\n  testnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bech32: 'tb',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BTC\n  },\n\n  // https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/validation.cpp\n  // https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/chainparams.cpp\n  bitcoincash: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BCH,\n    forkId: 0x00\n  },\n  bitcoincashTestnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BCH\n  },\n\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/validation.cpp\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/chainparams.cpp\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/script/interpreter.h\n  bitcoingold: {\n    messagePrefix: '\\x18Bitcoin Gold Signed Message:\\n',\n    bech32: 'btg',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x26,\n    scriptHash: 0x17,\n    wif: 0x80,\n    forkId: 79,\n    coin: coins.BTG\n  },\n  bitcoingoldTestnet: {\n    messagePrefix: '\\x18Bitcoin Gold Signed Message:\\n',\n    bech32: 'tbtg',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 111,\n    scriptHash: 196,\n    wif: 0xef,\n    forkId: 79,\n    coin: coins.BTG\n  },\n\n  // https://github.com/bitcoin-sv/bitcoin-sv/blob/master/src/validation.cpp\n  // https://github.com/bitcoin-sv/bitcoin-sv/blob/master/src/chainparams.cpp\n  bitcoinsv: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BSV,\n    forkId: 0x00\n  },\n  bitcoinsvTestnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BSV\n  },\n\n  // https://github.com/dashpay/dash/blob/master/src/validation.cpp\n  // https://github.com/dashpay/dash/blob/master/src/chainparams.cpp\n  dash: {\n    messagePrefix: '\\x19DarkCoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x4c,\n    scriptHash: 0x10,\n    wif: 0xcc,\n    coin: coins.DASH\n  },\n  dashTest: {\n    messagePrefix: '\\x19DarkCoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x8c,\n    scriptHash: 0x13,\n    wif: 0xef,\n    coin: coins.DASH\n  },\n\n  // https://github.com/litecoin-project/litecoin/blob/master/src/validation.cpp\n  // https://github.com/litecoin-project/litecoin/blob/master/src/chainparams.cpp\n  litecoin: {\n    messagePrefix: '\\x19Litecoin Signed Message:\\n',\n    bech32: 'ltc',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x30,\n    scriptHash: 0x32,\n    wif: 0xb0,\n    coin: coins.LTC\n  },\n  litecoinTest: {\n    messagePrefix: '\\x19Litecoin Signed Message:\\n',\n    bech32: 'tltc',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0x3a,\n    wif: 0xef,\n    coin: coins.LTC\n  },\n\n  // https://github.com/zcash/zcash/blob/master/src/validation.cpp\n  // https://github.com/zcash/zcash/blob/master/src/chainparams.cpp\n  zcash: {\n    messagePrefix: '\\x18ZCash Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x1cb8,\n    scriptHash: 0x1cbd,\n    wif: 0x80,\n    // This parameter was introduced in version 3 to allow soft forks, for version 1 and 2 transactions we add a\n    // dummy value.\n    consensusBranchId: {\n      1: 0x00,\n      2: 0x00,\n      3: 0x5ba81b19,\n      // 4: 0x76b809bb (old Sapling branch id). Blossom branch id becomes effective after block 653600\n      // 4: 0x2bb40e60\n      // 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)\n      4: 0xe9ff75a6 // (Canopy branch id, see https://zips.z.cash/zip-0251)\n    },\n    coin: coins.ZEC\n  },\n  zcashTest: {\n    messagePrefix: '\\x18ZCash Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x1d25,\n    scriptHash: 0x1cba,\n    wif: 0xef,\n    consensusBranchId: {\n      1: 0x00,\n      2: 0x00,\n      3: 0x5ba81b19,\n      // 4: 0x76b809bb (old Sapling branch id)\n      // 4: 0x2bb40e60\n      // 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)\n      4: 0xe9ff75a6 // (Canopy branch id, see https://zips.z.cash/zip-0251)\n    },\n    coin: coins.ZEC\n  }\n}\n"]}
module.exports = networks;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"networks.js","sourceRoot":"","sources":["../../src/networks.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\n\n/*\n\nThe values for the various fork coins can be found in these files:\n\nproperty       filename                  varname                           notes\n------------------------------------------------------------------------------------------------------------------------\nmessagePrefix  src/validation.cpp        strMessageMagic                   Format `${CoinName} Signed Message`\nbech32_hrp     src/chainparams.cpp       bech32_hrp                        Only for some networks\nbip32.public   src/chainparams.cpp       base58Prefixes[EXT_PUBLIC_KEY]    Mainnets have same value, testnets have same value\nbip32.private  src/chainparams.cpp       base58Prefixes[EXT_SECRET_KEY]    Mainnets have same value, testnets have same value\npubKeyHash     src/chainparams.cpp       base58Prefixes[PUBKEY_ADDRESS]\nscriptHash     src/chainparams.cpp       base58Prefixes[SCRIPT_ADDRESS]\nwif            src/chainparams.cpp       base58Prefixes[SECRET_KEY]        Testnets have same value\nforkId         src/script/interpreter.h  FORKID_*\n\n*/\n\nimport { coins, BitcoinCashNetwork, Network, NetworkName, ZcashNetwork } from './networkTypes';\n\nfunction getDefaultBip32Mainnet(): Network['bip32'] {\n  return {\n    // base58 'xpub'\n    public: 0x0488b21e,\n    // base58 'xprv'\n    private: 0x0488ade4,\n  };\n}\n\nfunction getDefaultBip32Testnet(): Network['bip32'] {\n  return {\n    // base58 'tpub'\n    public: 0x043587cf,\n    // base58 'tprv'\n    private: 0x04358394,\n  };\n}\n\nconst networks: Record<NetworkName, Network> &\n  Record<'zcash' | 'zcashTest', ZcashNetwork> &\n  Record<'bitcoincash' | 'bitcoincashTestnet', BitcoinCashNetwork> = {\n  // https://github.com/bitcoin/bitcoin/blob/master/src/validation.cpp\n  // https://github.com/bitcoin/bitcoin/blob/master/src/chainparams.cpp\n  bitcoin: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bech32: 'bc',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BTC,\n  },\n  testnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bech32: 'tb',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BTC,\n  },\n\n  // https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/validation.cpp\n  // https://github.com/Bitcoin-ABC/bitcoin-abc/blob/master/src/chainparams.cpp\n  // https://github.com/bitcoincashorg/bitcoincash.org/blob/master/spec/cashaddr.md\n  bitcoincash: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BCH,\n    forkId: 0x00,\n    cashAddr: {\n      prefix: 'bitcoincash',\n      pubKeyHash: 0x00,\n      scriptHash: 0x08,\n    },\n  },\n  bitcoincashTestnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BCH,\n    cashAddr: {\n      prefix: 'bchtest',\n      pubKeyHash: 0x00,\n      scriptHash: 0x08,\n    },\n  },\n\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/validation.cpp\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/chainparams.cpp\n  // https://github.com/BTCGPU/BTCGPU/blob/master/src/script/interpreter.h\n  bitcoingold: {\n    messagePrefix: '\\x18Bitcoin Gold Signed Message:\\n',\n    bech32: 'btg',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x26,\n    scriptHash: 0x17,\n    wif: 0x80,\n    forkId: 79,\n    coin: coins.BTG,\n  },\n  bitcoingoldTestnet: {\n    messagePrefix: '\\x18Bitcoin Gold Signed Message:\\n',\n    bech32: 'tbtg',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 111,\n    scriptHash: 196,\n    wif: 0xef,\n    forkId: 79,\n    coin: coins.BTG,\n  },\n\n  // https://github.com/bitcoin-sv/bitcoin-sv/blob/master/src/validation.cpp\n  // https://github.com/bitcoin-sv/bitcoin-sv/blob/master/src/chainparams.cpp\n  bitcoinsv: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x00,\n    scriptHash: 0x05,\n    wif: 0x80,\n    coin: coins.BSV,\n    forkId: 0x00,\n  },\n  bitcoinsvTestnet: {\n    messagePrefix: '\\x18Bitcoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0xc4,\n    wif: 0xef,\n    coin: coins.BSV,\n  },\n\n  // https://github.com/dashpay/dash/blob/master/src/validation.cpp\n  // https://github.com/dashpay/dash/blob/master/src/chainparams.cpp\n  dash: {\n    messagePrefix: '\\x19DarkCoin Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x4c,\n    scriptHash: 0x10,\n    wif: 0xcc,\n    coin: coins.DASH,\n  },\n  dashTest: {\n    messagePrefix: '\\x19DarkCoin Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x8c,\n    scriptHash: 0x13,\n    wif: 0xef,\n    coin: coins.DASH,\n  },\n\n  // https://github.com/litecoin-project/litecoin/blob/master/src/validation.cpp\n  // https://github.com/litecoin-project/litecoin/blob/master/src/chainparams.cpp\n  litecoin: {\n    messagePrefix: '\\x19Litecoin Signed Message:\\n',\n    bech32: 'ltc',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x30,\n    scriptHash: 0x32,\n    wif: 0xb0,\n    coin: coins.LTC,\n  },\n  litecoinTest: {\n    messagePrefix: '\\x19Litecoin Signed Message:\\n',\n    bech32: 'tltc',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x6f,\n    scriptHash: 0x3a,\n    wif: 0xef,\n    coin: coins.LTC,\n  },\n\n  // https://github.com/zcash/zcash/blob/master/src/validation.cpp\n  // https://github.com/zcash/zcash/blob/master/src/chainparams.cpp\n  zcash: {\n    messagePrefix: '\\x18ZCash Signed Message:\\n',\n    bip32: getDefaultBip32Mainnet(),\n    pubKeyHash: 0x1cb8,\n    scriptHash: 0x1cbd,\n    wif: 0x80,\n    // This parameter was introduced in version 3 to allow soft forks, for version 1 and 2 transactions we add a\n    // dummy value.\n    consensusBranchId: {\n      1: 0x00,\n      2: 0x00,\n      3: 0x5ba81b19,\n      // 4: 0x76b809bb (old Sapling branch id). Blossom branch id becomes effective after block 653600\n      // 4: 0x2bb40e60\n      // 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)\n      4: 0xe9ff75a6, // (Canopy branch id, see https://zips.z.cash/zip-0251)\n    },\n    coin: coins.ZEC,\n  },\n  zcashTest: {\n    messagePrefix: '\\x18ZCash Signed Message:\\n',\n    bip32: getDefaultBip32Testnet(),\n    pubKeyHash: 0x1d25,\n    scriptHash: 0x1cba,\n    wif: 0xef,\n    consensusBranchId: {\n      1: 0x00,\n      2: 0x00,\n      3: 0x5ba81b19,\n      // 4: 0x76b809bb (old Sapling branch id)\n      // 4: 0x2bb40e60\n      // 4: 0xf5b9230b (Heartwood branch id, see https://zips.z.cash/zip-0250)\n      4: 0xe9ff75a6, // (Canopy branch id, see https://zips.z.cash/zip-0251)\n    },\n    coin: coins.ZEC,\n  },\n};\n\nexport = networks;\n"]}
{
"name": "@bitgo/utxo-lib",
"version": "1.9.6",
"version": "1.9.7-rc.0.0.1.0",
"description": "Client-side Bitcoin JavaScript library",

@@ -24,3 +24,3 @@ "main": "./dist/src/index.js",

"coverage-html": "nyc report --reporter=html",
"coverage": "npm run build && BITGO_UTXO_LIB_TEST_EXPECTED_COUNT=3539 nyc --check-coverage --branches 89 --functions 90 mocha",
"coverage": "npm run build && BITGO_UTXO_LIB_TEST_EXPECTED_COUNT=3594 nyc --check-coverage --branches 88 --functions 90 mocha",
"integration-test": "mocha test/integration/",

@@ -78,3 +78,3 @@ "standard": "standard",

},
"gitHead": "3d8946eb94fddc51924c8317fd70871062b4a755"
"gitHead": "97044012d54af712cd2196f8dc4dc9431523252f"
}

Sorry, the diff of this file is too big to display

Sorry, the diff of this file is too big to display

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc