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.10.0-rc.12 to 2.0.0-rc.0

dist/src/address.d.ts

125

dist/src/address.js

@@ -1,99 +0,40 @@

var Buffer = require('safe-buffer').Buffer;
var bech32 = require('bech32');
var bs58check = require('bs58check');
var bscript = require('./script');
var btemplates = require('./templates');
var networks = require('./networks');
var typeforce = require('typeforce');
var types = require('./types');
function fromBase58Check(address) {
var payload = bs58check.decode(address);
// TODO: 4.0.0, move to "toOutputScript"
if (payload.length < 21)
throw new TypeError(address + ' is too short');
if (payload.length > 22)
throw new TypeError(address + ' is too long');
var multibyte = payload.length === 22;
var offset = multibyte ? 2 : 1;
var version = multibyte ? payload.readUInt16BE(0) : payload[0];
var hash = payload.slice(offset);
return { version: version, hash: hash };
}
function fromBech32(address) {
var result = bech32.decode(address);
var data = bech32.fromWords(result.words.slice(1));
return {
version: result.words[0],
prefix: result.prefix,
data: Buffer.from(data)
};
}
function toBase58Check(hash, version) {
typeforce(types.tuple(types.Hash160bit, types.UInt16), arguments);
// Zcash adds an extra prefix resulting in a bigger (22 bytes) payload. We identify them Zcash by checking if the
// version is multibyte (2 bytes instead of 1)
var multibyte = version > 0xff;
var size = multibyte ? 22 : 21;
var offset = multibyte ? 2 : 1;
var payload = Buffer.allocUnsafe(size);
multibyte ? payload.writeUInt16BE(version, 0) : payload.writeUInt8(version, 0);
hash.copy(payload, offset);
return bs58check.encode(payload);
}
function toBech32(data, version, prefix) {
var words = bech32.toWords(data);
words.unshift(version);
return bech32.encode(prefix, words);
}
"use strict";
var _a;
Object.defineProperty(exports, "__esModule", { value: true });
exports.toBech32 = exports.fromBech32 = exports.fromBase58Check = exports.toBase58Check = exports.toOutputScript = exports.fromOutputScript = void 0;
/**
* @prettier
*/
const bitcoinjs = require("bitcoinjs-lib");
const zcashAddress = require("../src/bitgo/zcash/address");
const coins_1 = require("./coins");
function fromOutputScript(outputScript, network) {
network = network || networks.bitcoin;
if (btemplates.pubKeyHash.output.check(outputScript))
return toBase58Check(bscript.compile(outputScript).slice(3, 23), network.pubKeyHash);
if (btemplates.scriptHash.output.check(outputScript))
return toBase58Check(bscript.compile(outputScript).slice(2, 22), network.scriptHash);
if (btemplates.witnessPubKeyHash.output.check(outputScript))
return toBech32(bscript.compile(outputScript).slice(2, 22), 0, network.bech32);
if (btemplates.witnessScriptHash.output.check(outputScript))
return toBech32(bscript.compile(outputScript).slice(2, 34), 0, network.bech32);
throw new Error(bscript.toASM(outputScript) + ' has no matching Address');
if ((0, coins_1.isValidNetwork)(network) && (0, coins_1.isZcash)(network)) {
return zcashAddress.fromOutputScript(outputScript, network);
}
return bitcoinjs.address.fromOutputScript(outputScript, network);
}
exports.fromOutputScript = fromOutputScript;
function toOutputScript(address, network) {
network = network || networks.bitcoin;
var decode;
try {
decode = fromBase58Check(address);
if ((0, coins_1.isValidNetwork)(network) && (0, coins_1.isZcash)(network)) {
return zcashAddress.toOutputScript(address, network);
}
catch (e) { }
if (decode) {
if (decode.version === network.pubKeyHash)
return btemplates.pubKeyHash.output.encode(decode.hash);
if (decode.version === network.scriptHash)
return btemplates.scriptHash.output.encode(decode.hash);
return bitcoinjs.address.toOutputScript(address, network);
}
exports.toOutputScript = toOutputScript;
function toBase58Check(hash, version, network) {
if ((0, coins_1.isValidNetwork)(network) && (0, coins_1.isZcash)(network)) {
return zcashAddress.toBase58Check(hash, version);
}
else {
try {
decode = fromBech32(address);
}
catch (e) { }
if (decode) {
if (decode.prefix !== network.bech32)
throw new Error(address + ' has an invalid prefix');
if (decode.version === 0) {
if (decode.data.length === 20)
return btemplates.witnessPubKeyHash.output.encode(decode.data);
if (decode.data.length === 32)
return btemplates.witnessScriptHash.output.encode(decode.data);
}
}
return bitcoinjs.address.toBase58Check(hash, version);
}
exports.toBase58Check = toBase58Check;
function fromBase58Check(address, network) {
if ((0, coins_1.isValidNetwork)(network) && (0, coins_1.isZcash)(network)) {
return zcashAddress.fromBase58Check(address);
}
throw new Error(address + ' has no matching Script');
return bitcoinjs.address.fromBase58Check(address);
}
module.exports = {
fromBase58Check: fromBase58Check,
fromBech32: fromBech32,
fromOutputScript: fromOutputScript,
toBase58Check: toBase58Check,
toBech32: toBech32,
toOutputScript: toOutputScript
};
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"address.js","sourceRoot":"","sources":["../../src/address.js"],"names":[],"mappings":"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","sourcesContent":["var Buffer = require('safe-buffer').Buffer\nvar bech32 = require('bech32')\nvar bs58check = require('bs58check')\nvar bscript = require('./script')\nvar btemplates = require('./templates')\nvar networks = require('./networks')\nvar typeforce = require('typeforce')\nvar types = require('./types')\n\nfunction fromBase58Check (address) {\n  var payload = bs58check.decode(address)\n\n  // TODO: 4.0.0, move to \"toOutputScript\"\n  if (payload.length < 21) throw new TypeError(address + ' is too short')\n  if (payload.length > 22) throw new TypeError(address + ' is too long')\n\n  var multibyte = payload.length === 22\n  var offset = multibyte ? 2 : 1\n\n  var version = multibyte ? payload.readUInt16BE(0) : payload[0]\n  var hash = payload.slice(offset)\n\n  return { version: version, hash: hash }\n}\n\nfunction fromBech32 (address) {\n  var result = bech32.decode(address)\n  var data = bech32.fromWords(result.words.slice(1))\n\n  return {\n    version: result.words[0],\n    prefix: result.prefix,\n    data: Buffer.from(data)\n  }\n}\n\nfunction toBase58Check (hash, version) {\n  typeforce(types.tuple(types.Hash160bit, types.UInt16), arguments)\n\n  // Zcash adds an extra prefix resulting in a bigger (22 bytes) payload. We identify them Zcash by checking if the\n  // version is multibyte (2 bytes instead of 1)\n  var multibyte = version > 0xff\n  var size = multibyte ? 22 : 21\n  var offset = multibyte ? 2 : 1\n\n  var payload = Buffer.allocUnsafe(size)\n  multibyte ? payload.writeUInt16BE(version, 0) : payload.writeUInt8(version, 0)\n  hash.copy(payload, offset)\n\n  return bs58check.encode(payload)\n}\n\nfunction toBech32 (data, version, prefix) {\n  var words = bech32.toWords(data)\n  words.unshift(version)\n\n  return bech32.encode(prefix, words)\n}\n\nfunction fromOutputScript (outputScript, network) {\n  network = network || networks.bitcoin\n\n  if (btemplates.pubKeyHash.output.check(outputScript)) return toBase58Check(bscript.compile(outputScript).slice(3, 23), network.pubKeyHash)\n  if (btemplates.scriptHash.output.check(outputScript)) return toBase58Check(bscript.compile(outputScript).slice(2, 22), network.scriptHash)\n  if (btemplates.witnessPubKeyHash.output.check(outputScript)) return toBech32(bscript.compile(outputScript).slice(2, 22), 0, network.bech32)\n  if (btemplates.witnessScriptHash.output.check(outputScript)) return toBech32(bscript.compile(outputScript).slice(2, 34), 0, network.bech32)\n\n  throw new Error(bscript.toASM(outputScript) + ' has no matching Address')\n}\n\nfunction toOutputScript (address, network) {\n  network = network || networks.bitcoin\n\n  var decode\n  try {\n    decode = fromBase58Check(address)\n  } catch (e) {}\n\n  if (decode) {\n    if (decode.version === network.pubKeyHash) return btemplates.pubKeyHash.output.encode(decode.hash)\n    if (decode.version === network.scriptHash) return btemplates.scriptHash.output.encode(decode.hash)\n  } else {\n    try {\n      decode = fromBech32(address)\n    } catch (e) {}\n\n    if (decode) {\n      if (decode.prefix !== network.bech32) throw new Error(address + ' has an invalid prefix')\n      if (decode.version === 0) {\n        if (decode.data.length === 20) return btemplates.witnessPubKeyHash.output.encode(decode.data)\n        if (decode.data.length === 32) return btemplates.witnessScriptHash.output.encode(decode.data)\n      }\n    }\n  }\n\n  throw new Error(address + ' has no matching Script')\n}\n\nmodule.exports = {\n  fromBase58Check: fromBase58Check,\n  fromBech32: fromBech32,\n  fromOutputScript: fromOutputScript,\n  toBase58Check: toBase58Check,\n  toBech32: toBech32,\n  toOutputScript: toOutputScript\n}\n"]}
exports.fromBase58Check = fromBase58Check;
_a = bitcoinjs.address, exports.fromBech32 = _a.fromBech32, exports.toBech32 = _a.toBech32;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYWRkcmVzcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9hZGRyZXNzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTs7R0FFRztBQUNILDJDQUEyQztBQUUzQywyREFBMkQ7QUFHM0QsbUNBQWtEO0FBR2xELFNBQWdCLGdCQUFnQixDQUFDLFlBQW9CLEVBQUUsT0FBZ0I7SUFDckUsSUFBSSxJQUFBLHNCQUFjLEVBQUMsT0FBTyxDQUFDLElBQUksSUFBQSxlQUFPLEVBQUMsT0FBTyxDQUFDLEVBQUU7UUFDL0MsT0FBTyxZQUFZLENBQUMsZ0JBQWdCLENBQUMsWUFBWSxFQUFFLE9BQU8sQ0FBQyxDQUFDO0tBQzdEO0lBQ0QsT0FBTyxTQUFTLENBQUMsT0FBTyxDQUFDLGdCQUFnQixDQUFDLFlBQVksRUFBRSxPQUE0QixDQUFDLENBQUM7QUFDeEYsQ0FBQztBQUxELDRDQUtDO0FBRUQsU0FBZ0IsY0FBYyxDQUFDLE9BQWUsRUFBRSxPQUFnQjtJQUM5RCxJQUFJLElBQUEsc0JBQWMsRUFBQyxPQUFPLENBQUMsSUFBSSxJQUFBLGVBQU8sRUFBQyxPQUFPLENBQUMsRUFBRTtRQUMvQyxPQUFPLFlBQVksQ0FBQyxjQUFjLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0tBQ3REO0lBQ0QsT0FBTyxTQUFTLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUUsT0FBNEIsQ0FBQyxDQUFDO0FBQ2pGLENBQUM7QUFMRCx3Q0FLQztBQUVELFNBQWdCLGFBQWEsQ0FBQyxJQUFZLEVBQUUsT0FBZSxFQUFFLE9BQWdCO0lBQzNFLElBQUksSUFBQSxzQkFBYyxFQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUEsZUFBTyxFQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQy9DLE9BQU8sWUFBWSxDQUFDLGFBQWEsQ0FBQyxJQUFJLEVBQUUsT0FBTyxDQUFDLENBQUM7S0FDbEQ7SUFDRCxPQUFPLFNBQVMsQ0FBQyxPQUFPLENBQUMsYUFBYSxDQUFDLElBQUksRUFBRSxPQUFPLENBQUMsQ0FBQztBQUN4RCxDQUFDO0FBTEQsc0NBS0M7QUFFRCxTQUFnQixlQUFlLENBQUMsT0FBZSxFQUFFLE9BQWdCO0lBQy9ELElBQUksSUFBQSxzQkFBYyxFQUFDLE9BQU8sQ0FBQyxJQUFJLElBQUEsZUFBTyxFQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQy9DLE9BQU8sWUFBWSxDQUFDLGVBQWUsQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUM5QztJQUNELE9BQU8sU0FBUyxDQUFDLE9BQU8sQ0FBQyxlQUFlLENBQUMsT0FBTyxDQUFDLENBQUM7QUFDcEQsQ0FBQztBQUxELDBDQUtDO0FBRVksS0FBMkIsU0FBUyxDQUFDLE9BQU8sRUFBMUMsa0JBQVUsa0JBQUUsZ0JBQVEsZUFBdUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBwcmV0dGllclxuICovXG5pbXBvcnQgKiBhcyBiaXRjb2luanMgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5cbmltcG9ydCAqIGFzIHpjYXNoQWRkcmVzcyBmcm9tICcuLi9zcmMvYml0Z28vemNhc2gvYWRkcmVzcyc7XG5cbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuL25ldHdvcmtUeXBlcyc7XG5pbXBvcnQgeyBpc1ZhbGlkTmV0d29yaywgaXNaY2FzaCB9IGZyb20gJy4vY29pbnMnO1xuaW1wb3J0IHsgQmFzZTU4Q2hlY2tSZXN1bHQgfSBmcm9tICdiaXRjb2luanMtbGliL3R5cGVzL2FkZHJlc3MnO1xuXG5leHBvcnQgZnVuY3Rpb24gZnJvbU91dHB1dFNjcmlwdChvdXRwdXRTY3JpcHQ6IEJ1ZmZlciwgbmV0d29yazogTmV0d29yaykge1xuICBpZiAoaXNWYWxpZE5ldHdvcmsobmV0d29yaykgJiYgaXNaY2FzaChuZXR3b3JrKSkge1xuICAgIHJldHVybiB6Y2FzaEFkZHJlc3MuZnJvbU91dHB1dFNjcmlwdChvdXRwdXRTY3JpcHQsIG5ldHdvcmspO1xuICB9XG4gIHJldHVybiBiaXRjb2luanMuYWRkcmVzcy5mcm9tT3V0cHV0U2NyaXB0KG91dHB1dFNjcmlwdCwgbmV0d29yayBhcyBiaXRjb2luanMuTmV0d29yayk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiB0b091dHB1dFNjcmlwdChhZGRyZXNzOiBzdHJpbmcsIG5ldHdvcms6IE5ldHdvcmspIHtcbiAgaWYgKGlzVmFsaWROZXR3b3JrKG5ldHdvcmspICYmIGlzWmNhc2gobmV0d29yaykpIHtcbiAgICByZXR1cm4gemNhc2hBZGRyZXNzLnRvT3V0cHV0U2NyaXB0KGFkZHJlc3MsIG5ldHdvcmspO1xuICB9XG4gIHJldHVybiBiaXRjb2luanMuYWRkcmVzcy50b091dHB1dFNjcmlwdChhZGRyZXNzLCBuZXR3b3JrIGFzIGJpdGNvaW5qcy5OZXR3b3JrKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHRvQmFzZTU4Q2hlY2soaGFzaDogQnVmZmVyLCB2ZXJzaW9uOiBudW1iZXIsIG5ldHdvcms6IE5ldHdvcmspOiBzdHJpbmcge1xuICBpZiAoaXNWYWxpZE5ldHdvcmsobmV0d29yaykgJiYgaXNaY2FzaChuZXR3b3JrKSkge1xuICAgIHJldHVybiB6Y2FzaEFkZHJlc3MudG9CYXNlNThDaGVjayhoYXNoLCB2ZXJzaW9uKTtcbiAgfVxuICByZXR1cm4gYml0Y29pbmpzLmFkZHJlc3MudG9CYXNlNThDaGVjayhoYXNoLCB2ZXJzaW9uKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGZyb21CYXNlNThDaGVjayhhZGRyZXNzOiBzdHJpbmcsIG5ldHdvcms6IE5ldHdvcmspOiBCYXNlNThDaGVja1Jlc3VsdCB7XG4gIGlmIChpc1ZhbGlkTmV0d29yayhuZXR3b3JrKSAmJiBpc1pjYXNoKG5ldHdvcmspKSB7XG4gICAgcmV0dXJuIHpjYXNoQWRkcmVzcy5mcm9tQmFzZTU4Q2hlY2soYWRkcmVzcyk7XG4gIH1cbiAgcmV0dXJuIGJpdGNvaW5qcy5hZGRyZXNzLmZyb21CYXNlNThDaGVjayhhZGRyZXNzKTtcbn1cblxuZXhwb3J0IGNvbnN0IHsgZnJvbUJlY2gzMiwgdG9CZWNoMzIgfSA9IGJpdGNvaW5qcy5hZGRyZXNzO1xuIl19

@@ -22,2 +22,6 @@ "use strict";

__exportStar(require("./transaction"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztHQUVHO0FBQ0gsdUNBQXFDO0FBQ3JDLG1EQUFpRDtBQUNqRCxtRUFBaUU7QUFDakUsOENBQTRCO0FBQzVCLGdEQUE4QiIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHByZXR0aWVyXG4gKi9cbmV4cG9ydCAqIGFzIGtleXV0aWwgZnJvbSAnLi9rZXl1dGlsJztcbmV4cG9ydCAqIGFzIG91dHB1dFNjcmlwdHMgZnJvbSAnLi9vdXRwdXRTY3JpcHRzJztcbmV4cG9ydCAqIGFzIG5vblN0YW5kYXJkSGFsZlNpZ25lZCBmcm9tICcuL25vblN0YW5kYXJkSGFsZlNpZ25lZCc7XG5leHBvcnQgKiBmcm9tICcuL3NpZ25hdHVyZSc7XG5leHBvcnQgKiBmcm9tICcuL3RyYW5zYWN0aW9uJztcbiJdfQ==
__exportStar(require("./UtxoTransaction"), exports);
__exportStar(require("./UtxoTransactionBuilder"), exports);
__exportStar(require("./zcash"), exports);
__exportStar(require("./dash"), exports);
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBOztHQUVHO0FBQ0gsdUNBQXFDO0FBQ3JDLG1EQUFpRDtBQUNqRCxtRUFBaUU7QUFDakUsOENBQTRCO0FBQzVCLGdEQUE4QjtBQUM5QixvREFBa0M7QUFDbEMsMkRBQXlDO0FBQ3pDLDBDQUF3QjtBQUN4Qix5Q0FBdUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBwcmV0dGllclxuICovXG5leHBvcnQgKiBhcyBrZXl1dGlsIGZyb20gJy4va2V5dXRpbCc7XG5leHBvcnQgKiBhcyBvdXRwdXRTY3JpcHRzIGZyb20gJy4vb3V0cHV0U2NyaXB0cyc7XG5leHBvcnQgKiBhcyBub25TdGFuZGFyZEhhbGZTaWduZWQgZnJvbSAnLi9ub25TdGFuZGFyZEhhbGZTaWduZWQnO1xuZXhwb3J0ICogZnJvbSAnLi9zaWduYXR1cmUnO1xuZXhwb3J0ICogZnJvbSAnLi90cmFuc2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbic7XG5leHBvcnQgKiBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbkJ1aWxkZXInO1xuZXhwb3J0ICogZnJvbSAnLi96Y2FzaCc7XG5leHBvcnQgKiBmcm9tICcuL2Rhc2gnO1xuIl19

@@ -7,4 +7,3 @@ "use strict";

*/
const BigInteger = require('bigi');
const ECPair = require('../ecpair');
const ECPair = require("bitcoinjs-lib/src/ecpair");
/**

@@ -20,4 +19,3 @@ * Create an ECPair from the raw private key bytes

}
const d = BigInteger.fromBuffer(buffer);
return new ECPair(d, null, { network });
return ECPair.fromPrivateKey(buffer);
}

@@ -31,10 +29,15 @@ exports.privateKeyBufferToECPair = privateKeyBufferToECPair;

function privateKeyBufferFromECPair(ecPair) {
if (!(ecPair instanceof ECPair)) {
if (ecPair.constructor.name !== 'ECPair') {
throw new TypeError(`invalid argument ecpair`);
}
if (!ecPair.d)
throw new Error('Missing private key');
return ecPair.d.toBuffer(32);
const privkey = ecPair.privateKey;
if (!Buffer.isBuffer(privkey)) {
throw new Error(`unexpected privkey type`);
}
if (privkey.length !== 32) {
throw new Error(`unexpected privkey length`);
}
return privkey;
}
exports.privateKeyBufferFromECPair = privateKeyBufferFromECPair;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5dXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9rZXl1dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsTUFBTSxVQUFVLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0FBQ25DLE1BQU0sTUFBTSxHQUFHLE9BQU8sQ0FBQyxXQUFXLENBQUMsQ0FBQztBQUVwQzs7Ozs7R0FLRztBQUNILFNBQWdCLHdCQUF3QixDQUFDLE1BQU0sRUFBRSxPQUFPO0lBQ3RELElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztLQUMvQztJQUVELE1BQU0sQ0FBQyxHQUFHLFVBQVUsQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDeEMsT0FBTyxJQUFJLE1BQU0sQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztBQUMxQyxDQUFDO0FBUEQsNERBT0M7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQUMsTUFBTTtJQUMvQyxJQUFJLENBQUMsQ0FBQyxNQUFNLFlBQVksTUFBTSxDQUFDLEVBQUU7UUFDL0IsTUFBTSxJQUFJLFNBQVMsQ0FBQyx5QkFBeUIsQ0FBQyxDQUFDO0tBQ2hEO0lBRUQsSUFBSSxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQUUsTUFBTSxJQUFJLEtBQUssQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO0lBRXRELE9BQU8sTUFBTSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsRUFBRSxDQUFDLENBQUM7QUFDL0IsQ0FBQztBQVJELGdFQVFDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcHJldHRpZXJcbiAqL1xuY29uc3QgQmlnSW50ZWdlciA9IHJlcXVpcmUoJ2JpZ2knKTtcbmNvbnN0IEVDUGFpciA9IHJlcXVpcmUoJy4uL2VjcGFpcicpO1xuXG4vKipcbiAqIENyZWF0ZSBhbiBFQ1BhaXIgZnJvbSB0aGUgcmF3IHByaXZhdGUga2V5IGJ5dGVzXG4gKiBAcGFyYW0ge0J1ZmZlcn0gYnVmZmVyIC0gUHJpdmF0ZSBrZXkgZm9yIHRoZSBFQ1BhaXIuIE11c3QgYmUgZXhhY3RseSAzMiBieXRlcy5cbiAqIEBwYXJhbSB7T2JqZWN0fSBbbmV0d29ya10gLSBOZXR3b3JrIGZvciB0aGUgRUNQYWlyLiBEZWZhdWx0cyB0byBiaXRjb2luLlxuICogQHJldHVybiB7RUNQYWlyfVxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpdmF0ZUtleUJ1ZmZlclRvRUNQYWlyKGJ1ZmZlciwgbmV0d29yaykge1xuICBpZiAoIUJ1ZmZlci5pc0J1ZmZlcihidWZmZXIpIHx8IGJ1ZmZlci5sZW5ndGggIT09IDMyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdpbnZhbGlkIHByaXZhdGUga2V5IGJ1ZmZlcicpO1xuICB9XG5cbiAgY29uc3QgZCA9IEJpZ0ludGVnZXIuZnJvbUJ1ZmZlcihidWZmZXIpO1xuICByZXR1cm4gbmV3IEVDUGFpcihkLCBudWxsLCB7IG5ldHdvcmsgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBwcml2YXRlIGtleSBhcyBhIDMyIGJ5dGVzIGJ1ZmZlci4gSWYgaXQgaXMgc21hbGxlciB0aGFuIDMyIGJ5dGVzLCBwYWQgaXQgd2l0aCB6ZXJvc1xuICogQHBhcmFtIHtFQ1BhaXJ9IGVjUGFpclxuICogQHJldHVybiB7QnVmZmVyfSAzMiBieXRlc1xuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpdmF0ZUtleUJ1ZmZlckZyb21FQ1BhaXIoZWNQYWlyKSB7XG4gIGlmICghKGVjUGFpciBpbnN0YW5jZW9mIEVDUGFpcikpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKGBpbnZhbGlkIGFyZ3VtZW50IGVjcGFpcmApO1xuICB9XG5cbiAgaWYgKCFlY1BhaXIuZCkgdGhyb3cgbmV3IEVycm9yKCdNaXNzaW5nIHByaXZhdGUga2V5Jyk7XG5cbiAgcmV0dXJuIGVjUGFpci5kLnRvQnVmZmVyKDMyKTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2V5dXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9rZXl1dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsbURBQW1EO0FBSW5EOzs7OztHQUtHO0FBQ0gsU0FBZ0Isd0JBQXdCLENBQUMsTUFBYyxFQUFFLE9BQWlCO0lBQ3hFLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLE1BQU0sQ0FBQyxNQUFNLEtBQUssRUFBRSxFQUFFO1FBQ3BELE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztLQUMvQztJQUVELE9BQU8sTUFBTSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztBQUN2QyxDQUFDO0FBTkQsNERBTUM7QUFFRDs7OztHQUlHO0FBQ0gsU0FBZ0IsMEJBQTBCLENBQUMsTUFBYztJQUN2RCxJQUFJLE1BQU0sQ0FBQyxXQUFXLENBQUMsSUFBSSxLQUFLLFFBQVEsRUFBRTtRQUN4QyxNQUFNLElBQUksU0FBUyxDQUFDLHlCQUF5QixDQUFDLENBQUM7S0FDaEQ7SUFFRCxNQUFNLE9BQU8sR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO0lBQ2xDLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzdCLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztLQUM1QztJQUNELElBQUksT0FBTyxDQUFDLE1BQU0sS0FBSyxFQUFFLEVBQUU7UUFDekIsTUFBTSxJQUFJLEtBQUssQ0FBQywyQkFBMkIsQ0FBQyxDQUFDO0tBQzlDO0lBRUQsT0FBTyxPQUFPLENBQUM7QUFDakIsQ0FBQztBQWRELGdFQWNDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcHJldHRpZXJcbiAqL1xuaW1wb3J0ICogYXMgRUNQYWlyIGZyb20gJ2JpdGNvaW5qcy1saWIvc3JjL2VjcGFpcic7XG5cbmltcG9ydCB7IE5ldHdvcmsgfSBmcm9tICcuLi9uZXR3b3JrVHlwZXMnO1xuXG4vKipcbiAqIENyZWF0ZSBhbiBFQ1BhaXIgZnJvbSB0aGUgcmF3IHByaXZhdGUga2V5IGJ5dGVzXG4gKiBAcGFyYW0ge0J1ZmZlcn0gYnVmZmVyIC0gUHJpdmF0ZSBrZXkgZm9yIHRoZSBFQ1BhaXIuIE11c3QgYmUgZXhhY3RseSAzMiBieXRlcy5cbiAqIEBwYXJhbSB7T2JqZWN0fSBbbmV0d29ya10gLSBOZXR3b3JrIGZvciB0aGUgRUNQYWlyLiBEZWZhdWx0cyB0byBiaXRjb2luLlxuICogQHJldHVybiB7RUNQYWlyfVxuICovXG5leHBvcnQgZnVuY3Rpb24gcHJpdmF0ZUtleUJ1ZmZlclRvRUNQYWlyKGJ1ZmZlcjogQnVmZmVyLCBuZXR3b3JrPzogTmV0d29yaykge1xuICBpZiAoIUJ1ZmZlci5pc0J1ZmZlcihidWZmZXIpIHx8IGJ1ZmZlci5sZW5ndGggIT09IDMyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdpbnZhbGlkIHByaXZhdGUga2V5IGJ1ZmZlcicpO1xuICB9XG5cbiAgcmV0dXJuIEVDUGFpci5mcm9tUHJpdmF0ZUtleShidWZmZXIpO1xufVxuXG4vKipcbiAqIEdldCB0aGUgcHJpdmF0ZSBrZXkgYXMgYSAzMiBieXRlcyBidWZmZXIuIElmIGl0IGlzIHNtYWxsZXIgdGhhbiAzMiBieXRlcywgcGFkIGl0IHdpdGggemVyb3NcbiAqIEBwYXJhbSB7RUNQYWlyfSBlY1BhaXJcbiAqIEByZXR1cm4ge0J1ZmZlcn0gMzIgYnl0ZXNcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIHByaXZhdGVLZXlCdWZmZXJGcm9tRUNQYWlyKGVjUGFpcjogRUNQYWlyKSB7XG4gIGlmIChlY1BhaXIuY29uc3RydWN0b3IubmFtZSAhPT0gJ0VDUGFpcicpIHtcbiAgICB0aHJvdyBuZXcgVHlwZUVycm9yKGBpbnZhbGlkIGFyZ3VtZW50IGVjcGFpcmApO1xuICB9XG5cbiAgY29uc3QgcHJpdmtleSA9IGVjUGFpci5wcml2YXRlS2V5O1xuICBpZiAoIUJ1ZmZlci5pc0J1ZmZlcihwcml2a2V5KSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgdW5leHBlY3RlZCBwcml2a2V5IHR5cGVgKTtcbiAgfVxuICBpZiAocHJpdmtleS5sZW5ndGggIT09IDMyKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGB1bmV4cGVjdGVkIHByaXZrZXkgbGVuZ3RoYCk7XG4gIH1cblxuICByZXR1cm4gcHJpdmtleTtcbn1cbiJdfQ==

@@ -7,4 +7,5 @@ "use strict";

*/
const assert = require("assert");
const opcodes = require("bitcoin-ops");
const bscript = require("../script");
const __1 = require("../");
/**

@@ -18,13 +19,8 @@ * @param input - Input of non-standard half-signed transaction created with `tx.build()` instead of `tx.buildIncomplete()`.

}
// We only use `txb.build()` on certain legacy v1 SDKs.
// Since native segwit was never enabled in v1 we do not have to worry about p2wsh inputs
// and can focus on p2sh and p2shP2wsh.
if (!input.script) {
throw new Error(`native segwit not supported`);
let decompiledSigScript;
if (input.witness && input.witness.length > 0) {
decompiledSigScript = input.witness;
}
const inputClassification = bscript.classifyInput(input.script, true);
const decompiledSigScript = input.witness.length ? input.witness : bscript.decompile(input.script);
const expectedScriptType = inputClassification === bscript.types.P2SH || inputClassification === bscript.types.P2WSH;
if (!expectedScriptType) {
return;
else {
decompiledSigScript = __1.script.decompile(input.script);
}

@@ -38,4 +34,7 @@ // The shape of a non-standard half-signed input is

if (op0 !== opcodes.OP_0 && !(Buffer.isBuffer(op0) && op0.length === 0)) {
throw new Error(`unexpected instruction`);
return;
}
if (__1.classify.output(sigScript) !== __1.classify.types.P2MS) {
return;
}
const paddedSigScript = [

@@ -47,10 +46,10 @@ op0,

if (input.witness.length) {
paddedSigScript.forEach((b) => assert(Buffer.isBuffer(b)));
input.witness = paddedSigScript;
}
else {
// @ts-ignore: bscript uses an odd "Buffer" type (per jsdoc)
input.script = bscript.compile(paddedSigScript);
input.script = __1.script.compile(paddedSigScript);
}
}
exports.padInputScript = padInputScript;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9uU3RhbmRhcmRIYWxmU2lnbmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL25vblN0YW5kYXJkSGFsZlNpZ25lZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7R0FFRztBQUNILHVDQUF1QztBQUN2QyxxQ0FBcUM7QUFJckM7OztHQUdHO0FBQ0gsU0FBZ0IsY0FBYyxDQUFDLEtBQVksRUFBRSxjQUFzQjtJQUNqRSxJQUFJLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxjQUFjLENBQUMsRUFBRTtRQUN2QyxNQUFNLElBQUksS0FBSyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7S0FDdEU7SUFFRCx1REFBdUQ7SUFDdkQseUZBQXlGO0lBQ3pGLHVDQUF1QztJQUN2QyxJQUFJLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRTtRQUNqQixNQUFNLElBQUksS0FBSyxDQUFDLDZCQUE2QixDQUFDLENBQUM7S0FDaEQ7SUFFRCxNQUFNLG1CQUFtQixHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsS0FBSyxDQUFDLE1BQU0sRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN0RSxNQUFNLG1CQUFtQixHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxLQUFLLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNuRyxNQUFNLGtCQUFrQixHQUFHLG1CQUFtQixLQUFLLE9BQU8sQ0FBQyxLQUFLLENBQUMsSUFBSSxJQUFJLG1CQUFtQixLQUFLLE9BQU8sQ0FBQyxLQUFLLENBQUMsS0FBSyxDQUFDO0lBRXJILElBQUksQ0FBQyxrQkFBa0IsRUFBRTtRQUN2QixPQUFPO0tBQ1I7SUFFRCxtREFBbUQ7SUFDbkQsNEJBQTRCO0lBQzVCLElBQUksbUJBQW1CLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUNwQyxPQUFPO0tBQ1I7SUFFRCxNQUFNLENBQUMsR0FBRyxFQUFFLGVBQWUsRUFBRSxTQUFTLENBQUMsR0FBRyxtQkFBbUIsQ0FBQztJQUU5RCxJQUFJLEdBQUcsS0FBSyxPQUFPLENBQUMsSUFBSSxJQUFJLENBQUMsQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLEdBQUcsQ0FBQyxJQUFJLEdBQUcsQ0FBQyxNQUFNLEtBQUssQ0FBQyxDQUFDLEVBQUU7UUFDdkUsTUFBTSxJQUFJLEtBQUssQ0FBQyx3QkFBd0IsQ0FBQyxDQUFDO0tBQzNDO0lBRUQsTUFBTSxlQUFlLEdBQUc7UUFDdEIsR0FBRztRQUNILEdBQUcsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLEtBQUssY0FBYyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQztRQUNuRixTQUFTO0tBQ1YsQ0FBQztJQUVGLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUU7UUFDeEIsS0FBSyxDQUFDLE9BQU8sR0FBRyxlQUFlLENBQUM7S0FDakM7U0FBTTtRQUNMLDREQUE0RDtRQUM1RCxLQUFLLENBQUMsTUFBTSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7S0FDakQ7QUFDSCxDQUFDO0FBNUNELHdDQTRDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHByZXR0aWVyXG4gKi9cbmltcG9ydCAqIGFzIG9wY29kZXMgZnJvbSAnYml0Y29pbi1vcHMnO1xuaW1wb3J0ICogYXMgYnNjcmlwdCBmcm9tICcuLi9zY3JpcHQnO1xuXG5pbXBvcnQgeyBJbnB1dCB9IGZyb20gJy4vc2lnbmF0dXJlJztcblxuLyoqXG4gKiBAcGFyYW0gaW5wdXQgLSBJbnB1dCBvZiBub24tc3RhbmRhcmQgaGFsZi1zaWduZWQgdHJhbnNhY3Rpb24gY3JlYXRlZCB3aXRoIGB0eC5idWlsZCgpYCBpbnN0ZWFkIG9mIGB0eC5idWlsZEluY29tcGxldGUoKWAuXG4gKiBAcGFyYW0gc2lnbmF0dXJlSW5kZXggLSBQb3NpdGlvbiB0byBtYXAgdGhlIGV4aXN0aW5nIHNpZ25hdHVyZXMgdG8uIE90aGVyIHNpZ25hdHVyZXMgd2lsbCBiZSBwYWRkZWQgd2l0aCBPUF8wLlxuICovXG5leHBvcnQgZnVuY3Rpb24gcGFkSW5wdXRTY3JpcHQoaW5wdXQ6IElucHV0LCBzaWduYXR1cmVJbmRleDogbnVtYmVyKTogdm9pZCB7XG4gIGlmICghWzAsIDEsIDJdLmluY2x1ZGVzKHNpZ25hdHVyZUluZGV4KSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBzaWduYXR1cmUgaW5kZXg6IG11c3QgYmUgb25lIG9mIFswLCAxLCAyXWApO1xuICB9XG5cbiAgLy8gV2Ugb25seSB1c2UgYHR4Yi5idWlsZCgpYCBvbiBjZXJ0YWluIGxlZ2FjeSB2MSBTREtzLlxuICAvLyBTaW5jZSBuYXRpdmUgc2Vnd2l0IHdhcyBuZXZlciBlbmFibGVkIGluIHYxIHdlIGRvIG5vdCBoYXZlIHRvIHdvcnJ5IGFib3V0IHAyd3NoIGlucHV0c1xuICAvLyBhbmQgY2FuIGZvY3VzIG9uIHAyc2ggYW5kIHAyc2hQMndzaC5cbiAgaWYgKCFpbnB1dC5zY3JpcHQpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYG5hdGl2ZSBzZWd3aXQgbm90IHN1cHBvcnRlZGApO1xuICB9XG5cbiAgY29uc3QgaW5wdXRDbGFzc2lmaWNhdGlvbiA9IGJzY3JpcHQuY2xhc3NpZnlJbnB1dChpbnB1dC5zY3JpcHQsIHRydWUpO1xuICBjb25zdCBkZWNvbXBpbGVkU2lnU2NyaXB0ID0gaW5wdXQud2l0bmVzcy5sZW5ndGggPyBpbnB1dC53aXRuZXNzIDogYnNjcmlwdC5kZWNvbXBpbGUoaW5wdXQuc2NyaXB0KTtcbiAgY29uc3QgZXhwZWN0ZWRTY3JpcHRUeXBlID0gaW5wdXRDbGFzc2lmaWNhdGlvbiA9PT0gYnNjcmlwdC50eXBlcy5QMlNIIHx8IGlucHV0Q2xhc3NpZmljYXRpb24gPT09IGJzY3JpcHQudHlwZXMuUDJXU0g7XG5cbiAgaWYgKCFleHBlY3RlZFNjcmlwdFR5cGUpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICAvLyBUaGUgc2hhcGUgb2YgYSBub24tc3RhbmRhcmQgaGFsZi1zaWduZWQgaW5wdXQgaXNcbiAgLy8gICBPUF8wIDxzaWduYXR1cmU+IDxwMm1zPlxuICBpZiAoZGVjb21waWxlZFNpZ1NjcmlwdC5sZW5ndGggIT09IDMpIHtcbiAgICByZXR1cm47XG4gIH1cblxuICBjb25zdCBbb3AwLCBzaWduYXR1cmVCdWZmZXIsIHNpZ1NjcmlwdF0gPSBkZWNvbXBpbGVkU2lnU2NyaXB0O1xuXG4gIGlmIChvcDAgIT09IG9wY29kZXMuT1BfMCAmJiAhKEJ1ZmZlci5pc0J1ZmZlcihvcDApICYmIG9wMC5sZW5ndGggPT09IDApKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGB1bmV4cGVjdGVkIGluc3RydWN0aW9uYCk7XG4gIH1cblxuICBjb25zdCBwYWRkZWRTaWdTY3JpcHQgPSBbXG4gICAgb3AwLFxuICAgIC4uLlswLCAxLCAyXS5tYXAoKGkpID0+IChpID09PSBzaWduYXR1cmVJbmRleCA/IHNpZ25hdHVyZUJ1ZmZlciA6IEJ1ZmZlci5mcm9tKFtdKSkpLFxuICAgIHNpZ1NjcmlwdCxcbiAgXTtcblxuICBpZiAoaW5wdXQud2l0bmVzcy5sZW5ndGgpIHtcbiAgICBpbnB1dC53aXRuZXNzID0gcGFkZGVkU2lnU2NyaXB0O1xuICB9IGVsc2Uge1xuICAgIC8vIEB0cy1pZ25vcmU6IGJzY3JpcHQgdXNlcyBhbiBvZGQgXCJCdWZmZXJcIiB0eXBlIChwZXIganNkb2MpXG4gICAgaW5wdXQuc2NyaXB0ID0gYnNjcmlwdC5jb21waWxlKHBhZGRlZFNpZ1NjcmlwdCk7XG4gIH1cbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibm9uU3RhbmRhcmRIYWxmU2lnbmVkLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL2JpdGdvL25vblN0YW5kYXJkSGFsZlNpZ25lZC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7QUFBQTs7R0FFRztBQUNILGlDQUFpQztBQUNqQyx1Q0FBdUM7QUFDdkMsMkJBQTJEO0FBRTNEOzs7R0FHRztBQUNILFNBQWdCLGNBQWMsQ0FBQyxLQUFjLEVBQUUsY0FBc0I7SUFDbkUsSUFBSSxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxRQUFRLENBQUMsY0FBYyxDQUFDLEVBQUU7UUFDdkMsTUFBTSxJQUFJLEtBQUssQ0FBQyxtREFBbUQsQ0FBQyxDQUFDO0tBQ3RFO0lBRUQsSUFBSSxtQkFBbUIsQ0FBQztJQUN4QixJQUFJLEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLE9BQU8sQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFO1FBQzdDLG1CQUFtQixHQUFHLEtBQUssQ0FBQyxPQUFPLENBQUM7S0FDckM7U0FBTTtRQUNMLG1CQUFtQixHQUFHLFVBQU8sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLE1BQU0sQ0FBQyxDQUFDO0tBQ3ZEO0lBRUQsbURBQW1EO0lBQ25ELDRCQUE0QjtJQUM1QixJQUFJLG1CQUFtQixDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUU7UUFDcEMsT0FBTztLQUNSO0lBRUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxlQUFlLEVBQUUsU0FBUyxDQUFDLEdBQUcsbUJBQW1CLENBQUM7SUFDOUQsSUFBSSxHQUFHLEtBQUssT0FBTyxDQUFDLElBQUksSUFBSSxDQUFDLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxHQUFHLENBQUMsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLENBQUMsQ0FBQyxFQUFFO1FBQ3ZFLE9BQU87S0FDUjtJQUVELElBQUksWUFBUSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsS0FBSyxZQUFRLENBQUMsS0FBSyxDQUFDLElBQUksRUFBRTtRQUN0RCxPQUFPO0tBQ1I7SUFFRCxNQUFNLGVBQWUsR0FBRztRQUN0QixHQUFHO1FBQ0gsR0FBRyxDQUFDLENBQUMsRUFBRSxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUMsS0FBSyxjQUFjLENBQUMsQ0FBQyxDQUFDLGVBQWUsQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDO1FBQ25GLFNBQVM7S0FDVixDQUFDO0lBRUYsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRTtRQUN4QixlQUFlLENBQUMsT0FBTyxDQUFDLENBQUMsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDM0QsS0FBSyxDQUFDLE9BQU8sR0FBRyxlQUEyQixDQUFDO0tBQzdDO1NBQU07UUFDTCxLQUFLLENBQUMsTUFBTSxHQUFHLFVBQU8sQ0FBQyxPQUFPLENBQUMsZUFBZSxDQUFDLENBQUM7S0FDakQ7QUFDSCxDQUFDO0FBdkNELHdDQXVDQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHByZXR0aWVyXG4gKi9cbmltcG9ydCAqIGFzIGFzc2VydCBmcm9tICdhc3NlcnQnO1xuaW1wb3J0ICogYXMgb3Bjb2RlcyBmcm9tICdiaXRjb2luLW9wcyc7XG5pbXBvcnQgeyBjbGFzc2lmeSwgc2NyaXB0IGFzIGJzY3JpcHQsIFR4SW5wdXQgfSBmcm9tICcuLi8nO1xuXG4vKipcbiAqIEBwYXJhbSBpbnB1dCAtIElucHV0IG9mIG5vbi1zdGFuZGFyZCBoYWxmLXNpZ25lZCB0cmFuc2FjdGlvbiBjcmVhdGVkIHdpdGggYHR4LmJ1aWxkKClgIGluc3RlYWQgb2YgYHR4LmJ1aWxkSW5jb21wbGV0ZSgpYC5cbiAqIEBwYXJhbSBzaWduYXR1cmVJbmRleCAtIFBvc2l0aW9uIHRvIG1hcCB0aGUgZXhpc3Rpbmcgc2lnbmF0dXJlcyB0by4gT3RoZXIgc2lnbmF0dXJlcyB3aWxsIGJlIHBhZGRlZCB3aXRoIE9QXzAuXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYWRJbnB1dFNjcmlwdChpbnB1dDogVHhJbnB1dCwgc2lnbmF0dXJlSW5kZXg6IG51bWJlcik6IHZvaWQge1xuICBpZiAoIVswLCAxLCAyXS5pbmNsdWRlcyhzaWduYXR1cmVJbmRleCkpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgc2lnbmF0dXJlIGluZGV4OiBtdXN0IGJlIG9uZSBvZiBbMCwgMSwgMl1gKTtcbiAgfVxuXG4gIGxldCBkZWNvbXBpbGVkU2lnU2NyaXB0O1xuICBpZiAoaW5wdXQud2l0bmVzcyAmJiBpbnB1dC53aXRuZXNzLmxlbmd0aCA+IDApIHtcbiAgICBkZWNvbXBpbGVkU2lnU2NyaXB0ID0gaW5wdXQud2l0bmVzcztcbiAgfSBlbHNlIHtcbiAgICBkZWNvbXBpbGVkU2lnU2NyaXB0ID0gYnNjcmlwdC5kZWNvbXBpbGUoaW5wdXQuc2NyaXB0KTtcbiAgfVxuXG4gIC8vIFRoZSBzaGFwZSBvZiBhIG5vbi1zdGFuZGFyZCBoYWxmLXNpZ25lZCBpbnB1dCBpc1xuICAvLyAgIE9QXzAgPHNpZ25hdHVyZT4gPHAybXM+XG4gIGlmIChkZWNvbXBpbGVkU2lnU2NyaXB0Lmxlbmd0aCAhPT0gMykge1xuICAgIHJldHVybjtcbiAgfVxuXG4gIGNvbnN0IFtvcDAsIHNpZ25hdHVyZUJ1ZmZlciwgc2lnU2NyaXB0XSA9IGRlY29tcGlsZWRTaWdTY3JpcHQ7XG4gIGlmIChvcDAgIT09IG9wY29kZXMuT1BfMCAmJiAhKEJ1ZmZlci5pc0J1ZmZlcihvcDApICYmIG9wMC5sZW5ndGggPT09IDApKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgaWYgKGNsYXNzaWZ5Lm91dHB1dChzaWdTY3JpcHQpICE9PSBjbGFzc2lmeS50eXBlcy5QMk1TKSB7XG4gICAgcmV0dXJuO1xuICB9XG5cbiAgY29uc3QgcGFkZGVkU2lnU2NyaXB0ID0gW1xuICAgIG9wMCxcbiAgICAuLi5bMCwgMSwgMl0ubWFwKChpKSA9PiAoaSA9PT0gc2lnbmF0dXJlSW5kZXggPyBzaWduYXR1cmVCdWZmZXIgOiBCdWZmZXIuZnJvbShbXSkpKSxcbiAgICBzaWdTY3JpcHQsXG4gIF07XG5cbiAgaWYgKGlucHV0LndpdG5lc3MubGVuZ3RoKSB7XG4gICAgcGFkZGVkU2lnU2NyaXB0LmZvckVhY2goKGIpID0+IGFzc2VydChCdWZmZXIuaXNCdWZmZXIoYikpKTtcbiAgICBpbnB1dC53aXRuZXNzID0gcGFkZGVkU2lnU2NyaXB0IGFzIEJ1ZmZlcltdO1xuICB9IGVsc2Uge1xuICAgIGlucHV0LnNjcmlwdCA9IGJzY3JpcHQuY29tcGlsZShwYWRkZWRTaWdTY3JpcHQpO1xuICB9XG59XG4iXX0=

@@ -7,4 +7,4 @@ "use strict";

*/
const script = require("../script");
const crypto = require("../crypto");
const assert = require("assert");
const bitcoinjs = require("bitcoinjs-lib");
exports.scriptTypes2Of3 = ['p2sh', 'p2shP2wsh', 'p2wsh'];

@@ -30,4 +30,5 @@ function isScriptType2Of3(t) {

});
const script2of3 = script.multisig.output.encode(2, pubkeys);
const p2wshOutputScript = script.witnessScriptHash.output.encode(crypto.sha256(script2of3));
const script2of3 = bitcoinjs.payments.p2ms({ m: 2, pubkeys });
assert(script2of3.output);
let scriptPubKey;
let redeemScript;

@@ -38,9 +39,12 @@ let witnessScript;

redeemScript = script2of3;
scriptPubKey = bitcoinjs.payments.p2sh({ redeem: script2of3 });
break;
case 'p2shP2wsh':
witnessScript = script2of3;
redeemScript = p2wshOutputScript;
redeemScript = bitcoinjs.payments.p2wsh({ redeem: script2of3 });
scriptPubKey = bitcoinjs.payments.p2sh({ redeem: redeemScript });
break;
case 'p2wsh':
witnessScript = script2of3;
scriptPubKey = bitcoinjs.payments.p2wsh({ redeem: witnessScript });
break;

@@ -50,13 +54,10 @@ default:

}
let scriptPubKey;
if (scriptType === 'p2wsh') {
scriptPubKey = p2wshOutputScript;
}
else {
const redeemScriptHash = crypto.hash160(redeemScript);
scriptPubKey = script.scriptHash.output.encode(redeemScriptHash);
}
return { redeemScript, witnessScript, scriptPubKey };
assert(scriptPubKey);
return {
scriptPubKey: scriptPubKey === null || scriptPubKey === void 0 ? void 0 : scriptPubKey.output,
redeemScript: redeemScript === null || redeemScript === void 0 ? void 0 : redeemScript.output,
witnessScript: witnessScript === null || witnessScript === void 0 ? void 0 : witnessScript.output,
};
}
exports.createOutputScript2of3 = createOutputScript2of3;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0cHV0U2NyaXB0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9vdXRwdXRTY3JpcHRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsb0NBQW9DO0FBQ3BDLG9DQUFvQztBQUV2QixRQUFBLGVBQWUsR0FBRyxDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFVLENBQUM7QUFHdkUsU0FBZ0IsZ0JBQWdCLENBQUMsQ0FBUztJQUN4QyxPQUFPLHVCQUFlLENBQUMsUUFBUSxDQUFDLENBQW1CLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBRkQsNENBRUM7QUFRRDs7Ozs7R0FLRztBQUNILFNBQWdCLHNCQUFzQixDQUFDLE9BQWlCLEVBQUUsVUFBMEI7SUFDbEYsSUFBSSxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN4QixNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7S0FDM0M7SUFDRCxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7UUFDdEIsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLEVBQUUsRUFBRTtZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixHQUFHLENBQUMsTUFBTSw2QkFBNkIsQ0FBQyxDQUFDO1NBQ25GO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBQzdELE1BQU0saUJBQWlCLEdBQUcsTUFBTSxDQUFDLGlCQUFpQixDQUFDLE1BQU0sQ0FBQyxNQUFNLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDO0lBQzVGLElBQUksWUFBWSxDQUFDO0lBQ2pCLElBQUksYUFBYSxDQUFDO0lBQ2xCLFFBQVEsVUFBVSxFQUFFO1FBQ2xCLEtBQUssTUFBTTtZQUNULFlBQVksR0FBRyxVQUFVLENBQUM7WUFDMUIsTUFBTTtRQUNSLEtBQUssV0FBVztZQUNkLGFBQWEsR0FBRyxVQUFVLENBQUM7WUFDM0IsWUFBWSxHQUFHLGlCQUFpQixDQUFDO1lBQ2pDLE1BQU07UUFDUixLQUFLLE9BQU87WUFDVixhQUFhLEdBQUcsVUFBVSxDQUFDO1lBQzNCLE1BQU07UUFDUjtZQUNFLE1BQU0sSUFBSSxLQUFLLENBQUMsZ0NBQWdDLFVBQVUsRUFBRSxDQUFDLENBQUM7S0FDakU7SUFFRCxJQUFJLFlBQVksQ0FBQztJQUNqQixJQUFJLFVBQVUsS0FBSyxPQUFPLEVBQUU7UUFDMUIsWUFBWSxHQUFHLGlCQUFpQixDQUFDO0tBQ2xDO1NBQU07UUFDTCxNQUFNLGdCQUFnQixHQUFHLE1BQU0sQ0FBQyxPQUFPLENBQUMsWUFBWSxDQUFDLENBQUM7UUFDdEQsWUFBWSxHQUFHLE1BQU0sQ0FBQyxVQUFVLENBQUMsTUFBTSxDQUFDLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0tBQ2xFO0lBRUQsT0FBTyxFQUFFLFlBQVksRUFBRSxhQUFhLEVBQUUsWUFBWSxFQUFFLENBQUM7QUFDdkQsQ0FBQztBQXRDRCx3REFzQ0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBwcmV0dGllclxuICovXG5pbXBvcnQgKiBhcyBzY3JpcHQgZnJvbSAnLi4vc2NyaXB0JztcbmltcG9ydCAqIGFzIGNyeXB0byBmcm9tICcuLi9jcnlwdG8nO1xuXG5leHBvcnQgY29uc3Qgc2NyaXB0VHlwZXMyT2YzID0gWydwMnNoJywgJ3Ayc2hQMndzaCcsICdwMndzaCddIGFzIGNvbnN0O1xuZXhwb3J0IHR5cGUgU2NyaXB0VHlwZTJPZjMgPSB0eXBlb2Ygc2NyaXB0VHlwZXMyT2YzW251bWJlcl07XG5cbmV4cG9ydCBmdW5jdGlvbiBpc1NjcmlwdFR5cGUyT2YzKHQ6IHN0cmluZyk6IHQgaXMgU2NyaXB0VHlwZTJPZjMge1xuICByZXR1cm4gc2NyaXB0VHlwZXMyT2YzLmluY2x1ZGVzKHQgYXMgU2NyaXB0VHlwZTJPZjMpO1xufVxuXG5leHBvcnQgdHlwZSBTcGVuZGFibGVTY3JpcHQgPSB7XG4gIHNjcmlwdFB1YktleTogQnVmZmVyO1xuICByZWRlZW1TY3JpcHQ/OiBCdWZmZXI7XG4gIHdpdG5lc3NTY3JpcHQ/OiBCdWZmZXI7XG59O1xuXG4vKipcbiAqIFJldHVybiBzY3JpcHRzIGZvciAyLW9mLTMgbXVsdGlzaWcgb3V0cHV0XG4gKiBAcGFyYW0gcHVia2V5cyAtIHRoZSBrZXkgYXJyYXkgZm9yIG11bHRpc2lnXG4gKiBAcGFyYW0gc2NyaXB0VHlwZVxuICogQHJldHVybnMge3tyZWRlZW1TY3JpcHQsIHdpdG5lc3NTY3JpcHQsIGFkZHJlc3N9fVxuICovXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlT3V0cHV0U2NyaXB0Mm9mMyhwdWJrZXlzOiBCdWZmZXJbXSwgc2NyaXB0VHlwZTogU2NyaXB0VHlwZTJPZjMpOiBTcGVuZGFibGVTY3JpcHQge1xuICBpZiAocHVia2V5cy5sZW5ndGggIT09IDMpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYG11c3QgcHJvdmlkZSAzIHB1YmtleXNgKTtcbiAgfVxuICBwdWJrZXlzLmZvckVhY2goKGtleSkgPT4ge1xuICAgIGlmIChrZXkubGVuZ3RoICE9PSAzMykge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKGBVbmV4cGVjdGVkIGtleSBsZW5ndGggJHtrZXkubGVuZ3RofS4gTXVzdCB1c2UgY29tcHJlc3NlZCBrZXlzLmApO1xuICAgIH1cbiAgfSk7XG5cbiAgY29uc3Qgc2NyaXB0Mm9mMyA9IHNjcmlwdC5tdWx0aXNpZy5vdXRwdXQuZW5jb2RlKDIsIHB1YmtleXMpO1xuICBjb25zdCBwMndzaE91dHB1dFNjcmlwdCA9IHNjcmlwdC53aXRuZXNzU2NyaXB0SGFzaC5vdXRwdXQuZW5jb2RlKGNyeXB0by5zaGEyNTYoc2NyaXB0Mm9mMykpO1xuICBsZXQgcmVkZWVtU2NyaXB0O1xuICBsZXQgd2l0bmVzc1NjcmlwdDtcbiAgc3dpdGNoIChzY3JpcHRUeXBlKSB7XG4gICAgY2FzZSAncDJzaCc6XG4gICAgICByZWRlZW1TY3JpcHQgPSBzY3JpcHQyb2YzO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSAncDJzaFAyd3NoJzpcbiAgICAgIHdpdG5lc3NTY3JpcHQgPSBzY3JpcHQyb2YzO1xuICAgICAgcmVkZWVtU2NyaXB0ID0gcDJ3c2hPdXRwdXRTY3JpcHQ7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdwMndzaCc6XG4gICAgICB3aXRuZXNzU2NyaXB0ID0gc2NyaXB0Mm9mMztcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVua25vd24gbXVsdGlzaWcgc2NyaXB0IHR5cGUgJHtzY3JpcHRUeXBlfWApO1xuICB9XG5cbiAgbGV0IHNjcmlwdFB1YktleTtcbiAgaWYgKHNjcmlwdFR5cGUgPT09ICdwMndzaCcpIHtcbiAgICBzY3JpcHRQdWJLZXkgPSBwMndzaE91dHB1dFNjcmlwdDtcbiAgfSBlbHNlIHtcbiAgICBjb25zdCByZWRlZW1TY3JpcHRIYXNoID0gY3J5cHRvLmhhc2gxNjAocmVkZWVtU2NyaXB0KTtcbiAgICBzY3JpcHRQdWJLZXkgPSBzY3JpcHQuc2NyaXB0SGFzaC5vdXRwdXQuZW5jb2RlKHJlZGVlbVNjcmlwdEhhc2gpO1xuICB9XG5cbiAgcmV0dXJuIHsgcmVkZWVtU2NyaXB0LCB3aXRuZXNzU2NyaXB0LCBzY3JpcHRQdWJLZXkgfTtcbn1cbiJdfQ==
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3V0cHV0U2NyaXB0cy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9iaXRnby9vdXRwdXRTY3JpcHRzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQUFBOztHQUVHO0FBQ0gsaUNBQWlDO0FBQ2pDLDJDQUEyQztBQUU5QixRQUFBLGVBQWUsR0FBRyxDQUFDLE1BQU0sRUFBRSxXQUFXLEVBQUUsT0FBTyxDQUFVLENBQUM7QUFHdkUsU0FBZ0IsZ0JBQWdCLENBQUMsQ0FBUztJQUN4QyxPQUFPLHVCQUFlLENBQUMsUUFBUSxDQUFDLENBQW1CLENBQUMsQ0FBQztBQUN2RCxDQUFDO0FBRkQsNENBRUM7QUFRRDs7Ozs7R0FLRztBQUNILFNBQWdCLHNCQUFzQixDQUFDLE9BQWlCLEVBQUUsVUFBMEI7SUFDbEYsSUFBSSxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRTtRQUN4QixNQUFNLElBQUksS0FBSyxDQUFDLHdCQUF3QixDQUFDLENBQUM7S0FDM0M7SUFDRCxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUU7UUFDdEIsSUFBSSxHQUFHLENBQUMsTUFBTSxLQUFLLEVBQUUsRUFBRTtZQUNyQixNQUFNLElBQUksS0FBSyxDQUFDLHlCQUF5QixHQUFHLENBQUMsTUFBTSw2QkFBNkIsQ0FBQyxDQUFDO1NBQ25GO0lBQ0gsQ0FBQyxDQUFDLENBQUM7SUFFSCxNQUFNLFVBQVUsR0FBRyxTQUFTLENBQUMsUUFBUSxDQUFDLElBQUksQ0FBQyxFQUFFLENBQUMsRUFBRSxDQUFDLEVBQUUsT0FBTyxFQUFFLENBQUMsQ0FBQztJQUM5RCxNQUFNLENBQUMsVUFBVSxDQUFDLE1BQU0sQ0FBQyxDQUFDO0lBRTFCLElBQUksWUFBWSxDQUFDO0lBQ2pCLElBQUksWUFBWSxDQUFDO0lBQ2pCLElBQUksYUFBYSxDQUFDO0lBQ2xCLFFBQVEsVUFBVSxFQUFFO1FBQ2xCLEtBQUssTUFBTTtZQUNULFlBQVksR0FBRyxVQUFVLENBQUM7WUFDMUIsWUFBWSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7WUFDL0QsTUFBTTtRQUNSLEtBQUssV0FBVztZQUNkLGFBQWEsR0FBRyxVQUFVLENBQUM7WUFDM0IsWUFBWSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLFVBQVUsRUFBRSxDQUFDLENBQUM7WUFDaEUsWUFBWSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLEVBQUUsTUFBTSxFQUFFLFlBQVksRUFBRSxDQUFDLENBQUM7WUFDakUsTUFBTTtRQUNSLEtBQUssT0FBTztZQUNWLGFBQWEsR0FBRyxVQUFVLENBQUM7WUFDM0IsWUFBWSxHQUFHLFNBQVMsQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxDQUFDLENBQUM7WUFDbkUsTUFBTTtRQUNSO1lBQ0UsTUFBTSxJQUFJLEtBQUssQ0FBQyxnQ0FBZ0MsVUFBVSxFQUFFLENBQUMsQ0FBQztLQUNqRTtJQUVELE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQztJQUVyQixPQUFPO1FBQ0wsWUFBWSxFQUFFLFlBQVksYUFBWixZQUFZLHVCQUFaLFlBQVksQ0FBRSxNQUFNO1FBQ2xDLFlBQVksRUFBRSxZQUFZLGFBQVosWUFBWSx1QkFBWixZQUFZLENBQUUsTUFBTTtRQUNsQyxhQUFhLEVBQUUsYUFBYSxhQUFiLGFBQWEsdUJBQWIsYUFBYSxDQUFFLE1BQU07S0FDckMsQ0FBQztBQUNKLENBQUM7QUF6Q0Qsd0RBeUNDIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKiBAcHJldHRpZXJcbiAqL1xuaW1wb3J0ICogYXMgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5pbXBvcnQgKiBhcyBiaXRjb2luanMgZnJvbSAnYml0Y29pbmpzLWxpYic7XG5cbmV4cG9ydCBjb25zdCBzY3JpcHRUeXBlczJPZjMgPSBbJ3Ayc2gnLCAncDJzaFAyd3NoJywgJ3Ayd3NoJ10gYXMgY29uc3Q7XG5leHBvcnQgdHlwZSBTY3JpcHRUeXBlMk9mMyA9IHR5cGVvZiBzY3JpcHRUeXBlczJPZjNbbnVtYmVyXTtcblxuZXhwb3J0IGZ1bmN0aW9uIGlzU2NyaXB0VHlwZTJPZjModDogc3RyaW5nKTogdCBpcyBTY3JpcHRUeXBlMk9mMyB7XG4gIHJldHVybiBzY3JpcHRUeXBlczJPZjMuaW5jbHVkZXModCBhcyBTY3JpcHRUeXBlMk9mMyk7XG59XG5cbmV4cG9ydCB0eXBlIFNwZW5kYWJsZVNjcmlwdCA9IHtcbiAgc2NyaXB0UHViS2V5OiBCdWZmZXI7XG4gIHJlZGVlbVNjcmlwdD86IEJ1ZmZlcjtcbiAgd2l0bmVzc1NjcmlwdD86IEJ1ZmZlcjtcbn07XG5cbi8qKlxuICogUmV0dXJuIHNjcmlwdHMgZm9yIDItb2YtMyBtdWx0aXNpZyBvdXRwdXRcbiAqIEBwYXJhbSBwdWJrZXlzIC0gdGhlIGtleSBhcnJheSBmb3IgbXVsdGlzaWdcbiAqIEBwYXJhbSBzY3JpcHRUeXBlXG4gKiBAcmV0dXJucyB7e3JlZGVlbVNjcmlwdCwgd2l0bmVzc1NjcmlwdCwgYWRkcmVzc319XG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVPdXRwdXRTY3JpcHQyb2YzKHB1YmtleXM6IEJ1ZmZlcltdLCBzY3JpcHRUeXBlOiBTY3JpcHRUeXBlMk9mMyk6IFNwZW5kYWJsZVNjcmlwdCB7XG4gIGlmIChwdWJrZXlzLmxlbmd0aCAhPT0gMykge1xuICAgIHRocm93IG5ldyBFcnJvcihgbXVzdCBwcm92aWRlIDMgcHVia2V5c2ApO1xuICB9XG4gIHB1YmtleXMuZm9yRWFjaCgoa2V5KSA9PiB7XG4gICAgaWYgKGtleS5sZW5ndGggIT09IDMzKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYFVuZXhwZWN0ZWQga2V5IGxlbmd0aCAke2tleS5sZW5ndGh9LiBNdXN0IHVzZSBjb21wcmVzc2VkIGtleXMuYCk7XG4gICAgfVxuICB9KTtcblxuICBjb25zdCBzY3JpcHQyb2YzID0gYml0Y29pbmpzLnBheW1lbnRzLnAybXMoeyBtOiAyLCBwdWJrZXlzIH0pO1xuICBhc3NlcnQoc2NyaXB0Mm9mMy5vdXRwdXQpO1xuXG4gIGxldCBzY3JpcHRQdWJLZXk7XG4gIGxldCByZWRlZW1TY3JpcHQ7XG4gIGxldCB3aXRuZXNzU2NyaXB0O1xuICBzd2l0Y2ggKHNjcmlwdFR5cGUpIHtcbiAgICBjYXNlICdwMnNoJzpcbiAgICAgIHJlZGVlbVNjcmlwdCA9IHNjcmlwdDJvZjM7XG4gICAgICBzY3JpcHRQdWJLZXkgPSBiaXRjb2luanMucGF5bWVudHMucDJzaCh7IHJlZGVlbTogc2NyaXB0Mm9mMyB9KTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgJ3Ayc2hQMndzaCc6XG4gICAgICB3aXRuZXNzU2NyaXB0ID0gc2NyaXB0Mm9mMztcbiAgICAgIHJlZGVlbVNjcmlwdCA9IGJpdGNvaW5qcy5wYXltZW50cy5wMndzaCh7IHJlZGVlbTogc2NyaXB0Mm9mMyB9KTtcbiAgICAgIHNjcmlwdFB1YktleSA9IGJpdGNvaW5qcy5wYXltZW50cy5wMnNoKHsgcmVkZWVtOiByZWRlZW1TY3JpcHQgfSk7XG4gICAgICBicmVhaztcbiAgICBjYXNlICdwMndzaCc6XG4gICAgICB3aXRuZXNzU2NyaXB0ID0gc2NyaXB0Mm9mMztcbiAgICAgIHNjcmlwdFB1YktleSA9IGJpdGNvaW5qcy5wYXltZW50cy5wMndzaCh7IHJlZGVlbTogd2l0bmVzc1NjcmlwdCB9KTtcbiAgICAgIGJyZWFrO1xuICAgIGRlZmF1bHQ6XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYHVua25vd24gbXVsdGlzaWcgc2NyaXB0IHR5cGUgJHtzY3JpcHRUeXBlfWApO1xuICB9XG5cbiAgYXNzZXJ0KHNjcmlwdFB1YktleSk7XG5cbiAgcmV0dXJuIHtcbiAgICBzY3JpcHRQdWJLZXk6IHNjcmlwdFB1YktleT8ub3V0cHV0LFxuICAgIHJlZGVlbVNjcmlwdDogcmVkZWVtU2NyaXB0Py5vdXRwdXQsXG4gICAgd2l0bmVzc1NjcmlwdDogd2l0bmVzc1NjcmlwdD8ub3V0cHV0LFxuICB9O1xufVxuIl19

@@ -8,9 +8,8 @@ "use strict";

const opcodes = require("bitcoin-ops");
const script = require("../script");
const crypto = require("../crypto");
const ECPair = require("../ecpair");
const Transaction = require("../transaction");
const ECSignature = require("../ecsignature");
const bitcoinjs_lib_1 = require("bitcoinjs-lib");
const classify = require("bitcoinjs-lib/src/classify");
const ScriptSignature = require("bitcoinjs-lib/src/script_signature");
const networks = require("../networks");
const coins_1 = require("../coins");
const UtxoTransaction_1 = require("./UtxoTransaction");
const inputTypes = [

@@ -28,9 +27,9 @@ 'multisig',

function getDefaultSigHash(network) {
switch (coins_1.getMainnet(network)) {
switch ((0, coins_1.getMainnet)(network)) {
case networks.bitcoincash:
case networks.bitcoinsv:
case networks.bitcoingold:
return Transaction.SIGHASH_ALL | Transaction.SIGHASH_BITCOINCASHBIP143;
return bitcoinjs_lib_1.Transaction.SIGHASH_ALL | UtxoTransaction_1.UtxoTransaction.SIGHASH_FORKID;
default:
return Transaction.SIGHASH_ALL;
return bitcoinjs_lib_1.Transaction.SIGHASH_ALL;
}

@@ -59,17 +58,17 @@ }

if (isNativeSegwitInput) {
inputClassification = script.classifyWitness(script.compile(decompiledSigScript), true);
inputClassification = classify.witness(bitcoinjs_lib_1.script.compile(decompiledSigScript), true);
}
else {
inputClassification = script.classifyInput(input.script, true);
inputClassification = classify.input(input.script, true);
}
}
else {
inputClassification = script.classifyInput(input.script, true);
decompiledSigScript = script.decompile(input.script);
inputClassification = classify.input(input.script, true);
decompiledSigScript = bitcoinjs_lib_1.script.decompile(input.script);
}
if (inputClassification === script.types.P2PKH) {
if (inputClassification === classify.types.P2PKH) {
const [signature, publicKey] = decompiledSigScript;
const publicKeys = [publicKey];
const signatures = [signature];
const pubScript = script.pubKeyHash.output.encode(crypto.hash160(publicKey));
const pubScript = bitcoinjs_lib_1.payments.p2pkh({ pubkey: publicKey }).output;
return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };

@@ -90,3 +89,3 @@ }

// Transactions built with `.buildIncomplete()` have three signatures, where missing signatures are substituted with `OP_0`.
const expectedScriptType = inputClassification === script.types.P2SH || inputClassification === script.types.P2WSH;
const expectedScriptType = inputClassification === classify.types.P2SH || inputClassification === classify.types.P2WSH;
const expectedScriptLength =

@@ -116,3 +115,6 @@ // complete transactions with 2 signatures

const pubScript = decompiledSigScript[decompiledSigScript.length - 1];
const decompiledPubScript = script.decompile(pubScript);
const decompiledPubScript = bitcoinjs_lib_1.script.decompile(pubScript);
if (decompiledPubScript === null) {
throw new Error(`could not decompile pubScript`);
}
if (decompiledPubScript.length !== 6) {

@@ -122,2 +124,7 @@ throw new Error(`unexpected decompiledPubScript length`);

const publicKeys = decompiledPubScript.slice(1, -2);
publicKeys.forEach((b) => {
if (!Buffer.isBuffer(b)) {
throw new Error();
}
});
if (publicKeys.length !== 3) {

@@ -146,3 +153,3 @@ throw new Error(`expected 3 public keys, got ${publicKeys.length}`);

const result = parseSignatureScript(input);
if (![script.types.P2WSH, script.types.P2SH, script.types.P2PKH].includes(result.inputClassification)) {
if (![classify.types.P2WSH, classify.types.P2SH, classify.types.P2PKH].includes(result.inputClassification)) {
throw new Error(`unexpected inputClassification ${result.inputClassification}`);

@@ -187,6 +194,7 @@ }

// slice the last byte from the signature hash input because it's the hash type
const signature = ECSignature.fromDER(signatureBuffer.slice(0, -1));
const hashType = signatureBuffer[signatureBuffer.length - 1];
const transactionHash = transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType, parsedScript.isSegwitInput);
const signedBy = publicKeys.filter((publicKey) => ECPair.fromPublicKeyBuffer(publicKey).verify(transactionHash, signature));
const { signature, hashType } = ScriptSignature.decode(signatureBuffer);
const transactionHash = parsedScript.isSegwitInput
? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)
: transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);
const signedBy = publicKeys.filter((publicKey) => bitcoinjs_lib_1.ECPair.fromPublicKey(publicKey).verify(transactionHash, signature));
if (signedBy.length === 0) {

@@ -210,4 +218,4 @@ return { signedBy: undefined };

const signatureVerifications = getSignatureVerifications(transaction, inputIndex, amount, verificationSettings).filter((v) =>
// If a publicKey constraint is set, a single valid signature by the specified pubkey is sufficient.
// Otherwise, all signatures must be valid.
// If no publicKey is set in verificationSettings, all signatures must be valid.
// Otherwise, a single valid signature by the specified pubkey is sufficient.
verificationSettings.publicKey === undefined ||

@@ -218,2 +226,2 @@ (v.signedBy !== undefined && verificationSettings.publicKey.equals(v.signedBy)));

exports.verifySignature = verifySignature;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as opcodes from 'bitcoin-ops';\n\nimport * as script from '../script';\nimport * as crypto from '../crypto';\nimport * as ECPair from '../ecpair';\nimport * as Transaction from '../transaction';\nimport * as ECSignature from '../ecsignature';\nimport { Network } from '../networkTypes';\nimport * as networks from '../networks';\nimport { getMainnet } from '../coins';\n\nexport interface Input {\n  hash: Buffer;\n  index: number;\n  sequence: number;\n  witness: Buffer[];\n  script: Buffer;\n  signScript: Buffer;\n}\n\nconst inputTypes = [\n  'multisig',\n  'nonstandard',\n  'nulldata',\n  'pubkey',\n  'pubkeyhash',\n  'scripthash',\n  'witnesspubkeyhash',\n  'witnessscripthash',\n  'witnesscommitment',\n] as const;\n\ntype InputType = typeof inputTypes[number];\n\nexport interface ParsedSignatureScript {\n  isSegwitInput: boolean;\n  inputClassification: InputType;\n}\n\nexport interface ParsedSignatureP2PKH extends ParsedSignatureScript {\n  signatures: [Buffer];\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    | [Buffer, Buffer, Buffer]; // partially signed transactions with placeholder signatures\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport function getDefaultSigHash(network: Network): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return Transaction.SIGHASH_ALL | Transaction.SIGHASH_BITCOINCASHBIP143;\n    default:\n      return Transaction.SIGHASH_ALL;\n  }\n}\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: Input\n): ParsedSignatureScript | ParsedSignatureP2PKH | ParsedSignatureScript2Of3 {\n  const isSegwitInput = input.witness.length > 0;\n  const isNativeSegwitInput = input.script.length === 0;\n  let decompiledSigScript, inputClassification;\n  if (isSegwitInput) {\n    // The decompiledSigScript is the script containing the signatures, public keys, and the script that was committed\n    // to (pubScript). If this is a segwit input the decompiledSigScript is in the witness, regardless of whether it\n    // is native or not. The inputClassification is determined based on whether or not the input is native to give an\n    // accurate classification. Note that p2shP2wsh inputs will be classified as p2sh and not p2wsh.\n    decompiledSigScript = input.witness;\n    if (isNativeSegwitInput) {\n      inputClassification = script.classifyWitness(script.compile(decompiledSigScript), true);\n    } else {\n      inputClassification = script.classifyInput(input.script, true);\n    }\n  } else {\n    inputClassification = script.classifyInput(input.script, true);\n    decompiledSigScript = script.decompile(input.script);\n  }\n\n  if (inputClassification === script.types.P2PKH) {\n    const [signature, publicKey] = decompiledSigScript;\n    const publicKeys: [Buffer] = [publicKey];\n    const signatures: [Buffer] = [signature];\n    const pubScript: Buffer = script.pubKeyHash.output.encode(crypto.hash160(publicKey));\n\n    return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n  }\n\n  // Note the assumption here that if we have a p2sh or p2wsh input it will be multisig (appropriate because the\n  // BitGo platform only supports multisig within these types of inputs, with the exception of replay protection inputs,\n  // which are single signature p2sh). Signatures are all but the last entry in the decompiledSigScript.\n  // The redeemScript/witnessScript (depending on which type of input this is) is the last entry in\n  // the decompiledSigScript (denoted here as the pubScript). The public keys are the second through\n  // antepenultimate entries in the decompiledPubScript. See below for a visual representation of the typical 2-of-3\n  // multisig setup:\n  //\n  //   decompiledSigScript = 0 <sig1> <sig2> [<sig3>] <pubScript>\n  //   decompiledPubScript = 2 <pub1> <pub2> <pub3> 3 OP_CHECKMULTISIG\n  //\n  // Transactions built with `.build()` only have two signatures `<sig1>` and `<sig2>` in _decompiledSigScript_.\n  // Transactions built with `.buildIncomplete()` have three signatures, where missing signatures are substituted with `OP_0`.\n  const expectedScriptType = inputClassification === script.types.P2SH || inputClassification === script.types.P2WSH;\n  const expectedScriptLength =\n    // complete transactions with 2 signatures\n    decompiledSigScript.length === 4 ||\n    // incomplete transaction with 3 signatures or signature placeholders\n    decompiledSigScript.length === 5;\n\n  if (!expectedScriptType || !expectedScriptLength) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (isSegwitInput) {\n    if (!Buffer.isBuffer(decompiledSigScript[0])) {\n      throw new Error(`expected decompiledSigScript[0] to be a buffer for segwit inputs`);\n    }\n    if (decompiledSigScript[0].length !== 0) {\n      throw new Error(`witness stack expected to start with empty buffer`);\n    }\n  } else if (decompiledSigScript[0] !== opcodes.OP_0) {\n    throw new Error(`sigScript expected to start with OP_0`);\n  }\n\n  const signatures = decompiledSigScript.slice(1 /* ignore leading OP_0 */, -1 /* ignore trailing pubScript */);\n  if (signatures.length !== 2 && signatures.length !== 3) {\n    throw new Error(`expected 2 or 3 signatures, got ${signatures.length}`);\n  }\n\n  const pubScript = decompiledSigScript[decompiledSigScript.length - 1];\n  const decompiledPubScript = script.decompile(pubScript);\n  if (decompiledPubScript.length !== 6) {\n    throw new Error(`unexpected decompiledPubScript length`);\n  }\n  const publicKeys = decompiledPubScript.slice(1, -2);\n  if (publicKeys.length !== 3) {\n    throw new Error(`expected 3 public keys, got ${publicKeys.length}`);\n  }\n\n  // Op codes 81 through 96 represent numbers 1 through 16 (see https://en.bitcoin.it/wiki/Script#Opcodes), which is\n  // why we subtract by 80 to get the number of signatures (n) and the number of public keys (m) in an n-of-m setup.\n  const len = decompiledPubScript.length;\n  const signatureThreshold = decompiledPubScript[0] - 80;\n  if (signatureThreshold !== 2) {\n    throw new Error(`expected signatureThreshold 2, got ${signatureThreshold}`);\n  }\n  const nPubKeys = decompiledPubScript[len - 2] - 80;\n  if (nPubKeys !== 3) {\n    throw new Error(`expected nPubKeys 3, got ${nPubKeys}`);\n  }\n\n  const lastOpCode = decompiledPubScript[len - 1];\n  if (lastOpCode !== opcodes.OP_CHECKMULTISIG) {\n    throw new Error(`expected opcode #${opcodes.OP_CHECKMULTISIG}, got opcode #${lastOpCode}`);\n  }\n\n  return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n}\n\nexport function parseSignatureScript2Of3(input: Input): ParsedSignatureScript2Of3 {\n  const result = parseSignatureScript(input) as ParsedSignatureScript2Of3;\n\n  if (![script.types.P2WSH, script.types.P2SH, script.types.P2PKH].includes(result.inputClassification)) {\n    throw new Error(`unexpected inputClassification ${result.inputClassification}`);\n  }\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (result.publicKeys.length !== 3) {\n    throw new Error(`unexpected pubkey count`);\n  }\n  if (!result.pubScript || result.pubScript.length === 0) {\n    throw new Error(`pubScript missing or empty`);\n  }\n\n  return result;\n}\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The hex of the public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification = {\n  /** Set to the public key that signed for the signature */\n  signedBy: Buffer | undefined;\n};\n\n/**\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications(\n  transaction: Transaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {}\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) => verificationSettings.publicKey === undefined || verificationSettings.publicKey.equals(buf)\n  );\n\n  return signatures.map((signatureBuffer) => {\n    // slice the last byte from the signature hash input because it's the hash type\n    const signature = ECSignature.fromDER(signatureBuffer.slice(0, -1));\n    const hashType = signatureBuffer[signatureBuffer.length - 1];\n    const transactionHash = transaction.hashForSignatureByNetwork(\n      inputIndex,\n      parsedScript.pubScript,\n      amount,\n      hashType,\n      parsedScript.isSegwitInput\n    );\n    const signedBy = publicKeys.filter((publicKey) =>\n      ECPair.fromPublicKeyBuffer(publicKey).verify(transactionHash, signature)\n    );\n\n    if (signedBy.length === 0) {\n      return { signedBy: undefined };\n    }\n    if (signedBy.length === 1) {\n      return { signedBy: signedBy[0] };\n    }\n    throw new Error(`illegal state: signed by multiple public keys`);\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n */\nexport function verifySignature(\n  transaction: Transaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {}\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings\n  ).filter(\n    (v) =>\n      // If a publicKey constraint is set, a single valid signature by the specified pubkey is sufficient.\n      // Otherwise, all signatures must be valid.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined && verificationSettings.publicKey.equals(v.signedBy))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n"]}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signature.js","sourceRoot":"","sources":["../../../src/bitgo/signature.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @prettier\n */\nimport * as opcodes from 'bitcoin-ops';\n\nimport { ECPair, payments, script, Transaction, TxInput } from 'bitcoinjs-lib';\nimport * as classify from 'bitcoinjs-lib/src/classify';\nimport * as ScriptSignature from 'bitcoinjs-lib/src/script_signature';\n\nimport { Network } from '../networkTypes';\nimport * as networks from '../networks';\nimport { getMainnet } from '../coins';\nimport { UtxoTransaction } from './UtxoTransaction';\n\nconst inputTypes = [\n  'multisig',\n  'nonstandard',\n  'nulldata',\n  'pubkey',\n  'pubkeyhash',\n  'scripthash',\n  'witnesspubkeyhash',\n  'witnessscripthash',\n  'witnesscommitment',\n] as const;\n\ntype InputType = typeof inputTypes[number];\n\nexport interface ParsedSignatureScript {\n  isSegwitInput: boolean;\n  inputClassification: InputType;\n  publicKeys?: Buffer[];\n}\n\nexport interface ParsedSignatureP2PKH extends ParsedSignatureScript {\n  signatures: [Buffer];\n  publicKeys: [Buffer];\n  pubScript: Buffer;\n}\n\nexport interface ParsedSignatureScript2Of3 extends ParsedSignatureScript {\n  signatures:\n    | [Buffer, Buffer] // fully-signed transactions with signatures\n    | [Buffer, Buffer, Buffer]; // partially signed transactions with placeholder signatures\n  publicKeys: [Buffer, Buffer, Buffer];\n  pubScript: Buffer;\n}\n\nexport function getDefaultSigHash(network: Network): number {\n  switch (getMainnet(network)) {\n    case networks.bitcoincash:\n    case networks.bitcoinsv:\n    case networks.bitcoingold:\n      return Transaction.SIGHASH_ALL | UtxoTransaction.SIGHASH_FORKID;\n    default:\n      return Transaction.SIGHASH_ALL;\n  }\n}\n\n/**\n * Parse a transaction's signature script to obtain public keys, signatures, the sig script,\n * and other properties.\n *\n * Only supports script types used in BitGo transactions.\n *\n * @param input\n * @returns ParsedSignatureScript\n */\nexport function parseSignatureScript(\n  input: TxInput\n): ParsedSignatureScript | ParsedSignatureP2PKH | ParsedSignatureScript2Of3 {\n  const isSegwitInput = input.witness.length > 0;\n  const isNativeSegwitInput = input.script.length === 0;\n  let decompiledSigScript, inputClassification;\n  if (isSegwitInput) {\n    // The decompiledSigScript is the script containing the signatures, public keys, and the script that was committed\n    // to (pubScript). If this is a segwit input the decompiledSigScript is in the witness, regardless of whether it\n    // is native or not. The inputClassification is determined based on whether or not the input is native to give an\n    // accurate classification. Note that p2shP2wsh inputs will be classified as p2sh and not p2wsh.\n    decompiledSigScript = input.witness;\n    if (isNativeSegwitInput) {\n      inputClassification = classify.witness(script.compile(decompiledSigScript), true);\n    } else {\n      inputClassification = classify.input(input.script, true);\n    }\n  } else {\n    inputClassification = classify.input(input.script, true);\n    decompiledSigScript = script.decompile(input.script);\n  }\n\n  if (inputClassification === classify.types.P2PKH) {\n    const [signature, publicKey] = decompiledSigScript;\n    const publicKeys = [publicKey];\n    const signatures: [Buffer] = [signature];\n    const pubScript = payments.p2pkh({ pubkey: publicKey }).output;\n\n    return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n  }\n\n  // Note the assumption here that if we have a p2sh or p2wsh input it will be multisig (appropriate because the\n  // BitGo platform only supports multisig within these types of inputs, with the exception of replay protection inputs,\n  // which are single signature p2sh). Signatures are all but the last entry in the decompiledSigScript.\n  // The redeemScript/witnessScript (depending on which type of input this is) is the last entry in\n  // the decompiledSigScript (denoted here as the pubScript). The public keys are the second through\n  // antepenultimate entries in the decompiledPubScript. See below for a visual representation of the typical 2-of-3\n  // multisig setup:\n  //\n  //   decompiledSigScript = 0 <sig1> <sig2> [<sig3>] <pubScript>\n  //   decompiledPubScript = 2 <pub1> <pub2> <pub3> 3 OP_CHECKMULTISIG\n  //\n  // Transactions built with `.build()` only have two signatures `<sig1>` and `<sig2>` in _decompiledSigScript_.\n  // Transactions built with `.buildIncomplete()` have three signatures, where missing signatures are substituted with `OP_0`.\n  const expectedScriptType =\n    inputClassification === classify.types.P2SH || inputClassification === classify.types.P2WSH;\n  const expectedScriptLength =\n    // complete transactions with 2 signatures\n    decompiledSigScript.length === 4 ||\n    // incomplete transaction with 3 signatures or signature placeholders\n    decompiledSigScript.length === 5;\n\n  if (!expectedScriptType || !expectedScriptLength) {\n    return { isSegwitInput, inputClassification };\n  }\n\n  if (isSegwitInput) {\n    if (!Buffer.isBuffer(decompiledSigScript[0])) {\n      throw new Error(`expected decompiledSigScript[0] to be a buffer for segwit inputs`);\n    }\n    if (decompiledSigScript[0].length !== 0) {\n      throw new Error(`witness stack expected to start with empty buffer`);\n    }\n  } else if (decompiledSigScript[0] !== opcodes.OP_0) {\n    throw new Error(`sigScript expected to start with OP_0`);\n  }\n\n  const signatures = decompiledSigScript.slice(1 /* ignore leading OP_0 */, -1 /* ignore trailing pubScript */);\n  if (signatures.length !== 2 && signatures.length !== 3) {\n    throw new Error(`expected 2 or 3 signatures, got ${signatures.length}`);\n  }\n\n  const pubScript = decompiledSigScript[decompiledSigScript.length - 1];\n  const decompiledPubScript = script.decompile(pubScript);\n  if (decompiledPubScript === null) {\n    throw new Error(`could not decompile pubScript`);\n  }\n  if (decompiledPubScript.length !== 6) {\n    throw new Error(`unexpected decompiledPubScript length`);\n  }\n  const publicKeys = decompiledPubScript.slice(1, -2) as Buffer[];\n  publicKeys.forEach((b) => {\n    if (!Buffer.isBuffer(b)) {\n      throw new Error();\n    }\n  });\n  if (publicKeys.length !== 3) {\n    throw new Error(`expected 3 public keys, got ${publicKeys.length}`);\n  }\n\n  // Op codes 81 through 96 represent numbers 1 through 16 (see https://en.bitcoin.it/wiki/Script#Opcodes), which is\n  // why we subtract by 80 to get the number of signatures (n) and the number of public keys (m) in an n-of-m setup.\n  const len = decompiledPubScript.length;\n  const signatureThreshold = (decompiledPubScript[0] as number) - 80;\n  if (signatureThreshold !== 2) {\n    throw new Error(`expected signatureThreshold 2, got ${signatureThreshold}`);\n  }\n  const nPubKeys = (decompiledPubScript[len - 2] as number) - 80;\n  if (nPubKeys !== 3) {\n    throw new Error(`expected nPubKeys 3, got ${nPubKeys}`);\n  }\n\n  const lastOpCode = decompiledPubScript[len - 1];\n  if (lastOpCode !== opcodes.OP_CHECKMULTISIG) {\n    throw new Error(`expected opcode #${opcodes.OP_CHECKMULTISIG}, got opcode #${lastOpCode}`);\n  }\n\n  return { isSegwitInput, inputClassification, signatures, publicKeys, pubScript };\n}\n\nexport function parseSignatureScript2Of3(input: TxInput): ParsedSignatureScript2Of3 {\n  const result = parseSignatureScript(input) as ParsedSignatureScript2Of3;\n\n  if (![classify.types.P2WSH, classify.types.P2SH, classify.types.P2PKH].includes(result.inputClassification)) {\n    throw new Error(`unexpected inputClassification ${result.inputClassification}`);\n  }\n  if (!result.signatures) {\n    throw new Error(`missing signatures`);\n  }\n  if (result.publicKeys.length !== 3) {\n    throw new Error(`unexpected pubkey count`);\n  }\n  if (!result.pubScript || result.pubScript.length === 0) {\n    throw new Error(`pubScript missing or empty`);\n  }\n\n  return result;\n}\n\n/**\n * Constraints for signature verifications.\n * Parameters are conjunctive: if multiple parameters are set, a verification for an individual\n * signature must satisfy all of them.\n */\nexport type VerificationSettings = {\n  /**\n   * The index of the signature to verify. Only iterates over non-empty signatures.\n   */\n  signatureIndex?: number;\n  /**\n   * The hex of the public key to verify.\n   */\n  publicKey?: Buffer;\n};\n\n/**\n * Result for a individual signature verification\n */\nexport type SignatureVerification = {\n  /** Set to the public key that signed for the signature */\n  signedBy: Buffer | undefined;\n};\n\n/**\n * Get signature verifications for multsig transaction\n * @param transaction\n * @param inputIndex\n * @param amount - must be set for segwit transactions and BIP143 transactions\n * @param verificationSettings\n * @returns SignatureVerification[] - in order of parsed non-empty signatures\n */\nexport function getSignatureVerifications(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {}\n): SignatureVerification[] {\n  /* istanbul ignore next */\n  if (!transaction.ins) {\n    throw new Error(`invalid transaction`);\n  }\n\n  const input = transaction.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const parsedScript = parseSignatureScript2Of3(input);\n\n  const signatures = parsedScript.signatures\n    .filter((s) => s && s.length)\n    .filter((s, i) => verificationSettings.signatureIndex === undefined || verificationSettings.signatureIndex === i);\n\n  const publicKeys = parsedScript.publicKeys.filter(\n    (buf) => verificationSettings.publicKey === undefined || verificationSettings.publicKey.equals(buf)\n  );\n\n  return signatures.map((signatureBuffer) => {\n    // slice the last byte from the signature hash input because it's the hash type\n    const { signature, hashType } = ScriptSignature.decode(signatureBuffer);\n    const transactionHash = parsedScript.isSegwitInput\n      ? transaction.hashForWitnessV0(inputIndex, parsedScript.pubScript, amount, hashType)\n      : transaction.hashForSignatureByNetwork(inputIndex, parsedScript.pubScript, amount, hashType);\n    const signedBy = publicKeys.filter((publicKey) =>\n      ECPair.fromPublicKey(publicKey).verify(transactionHash, signature)\n    );\n\n    if (signedBy.length === 0) {\n      return { signedBy: undefined };\n    }\n    if (signedBy.length === 1) {\n      return { signedBy: signedBy[0] };\n    }\n    throw new Error(`illegal state: signed by multiple public keys`);\n  });\n}\n\n/**\n * @param transaction\n * @param inputIndex\n * @param amount\n * @param verificationSettings - if publicKey is specified, returns true iff any signature is signed by publicKey.\n */\nexport function verifySignature(\n  transaction: UtxoTransaction,\n  inputIndex: number,\n  amount: number,\n  verificationSettings: VerificationSettings = {}\n): boolean {\n  const signatureVerifications = getSignatureVerifications(\n    transaction,\n    inputIndex,\n    amount,\n    verificationSettings\n  ).filter(\n    (v) =>\n      // If no publicKey is set in verificationSettings, all signatures must be valid.\n      // Otherwise, a single valid signature by the specified pubkey is sufficient.\n      verificationSettings.publicKey === undefined ||\n      (v.signedBy !== undefined && verificationSettings.publicKey.equals(v.signedBy))\n  );\n\n  return signatureVerifications.length > 0 && signatureVerifications.every((v) => v.signedBy !== undefined);\n}\n"]}
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
exports.createTransactionBuilderFromTransaction = exports.createTransactionBuilderForNetwork = exports.setTransactionBuilderDefaults = exports.createTransactionFromHex = exports.createTransactionFromBuffer = exports.createTransactionForNetwork = void 0;
exports.createTransactionBuilderFromTransaction = exports.createTransactionBuilderForNetwork = exports.setTransactionBuilderDefaults = exports.createTransactionFromHex = exports.createTransactionFromBuffer = void 0;
/**

@@ -9,6 +9,10 @@ * @prettier

const coins_1 = require("../coins");
const Transaction = require('../transaction');
const TransactionBuilder = require('../transaction_builder');
function createTransactionForNetwork(network) {
switch (coins_1.getMainnet(network)) {
const UtxoTransaction_1 = require("./UtxoTransaction");
const UtxoTransactionBuilder_1 = require("./UtxoTransactionBuilder");
const DashTransaction_1 = require("./dash/DashTransaction");
const DashTransactionBuilder_1 = require("./dash/DashTransactionBuilder");
const ZcashTransactionBuilder_1 = require("./zcash/ZcashTransactionBuilder");
const ZcashTransaction_1 = require("./zcash/ZcashTransaction");
function createTransactionFromBuffer(buf, network) {
switch ((0, coins_1.getMainnet)(network)) {
case networks.bitcoin:

@@ -18,21 +22,8 @@ case networks.bitcoincash:

case networks.bitcoingold:
case networks.dash:
case networks.litecoin:
case networks.zcash:
return new Transaction(network);
}
/* istanbul ignore next */
throw new Error(`invalid network`);
}
exports.createTransactionForNetwork = createTransactionForNetwork;
function createTransactionFromBuffer(buf, network) {
switch (coins_1.getMainnet(network)) {
case networks.bitcoin:
case networks.bitcoincash:
case networks.bitcoinsv:
case networks.bitcoingold:
return UtxoTransaction_1.UtxoTransaction.fromBuffer(buf, false, network);
case networks.dash:
case networks.litecoin:
return DashTransaction_1.DashTransaction.fromBuffer(buf, false, network);
case networks.zcash:
return Transaction.fromBuffer(buf, network);
return ZcashTransaction_1.ZcashTransaction.fromBuffer(buf, false, network);
}

@@ -43,2 +34,3 @@ /* istanbul ignore next */

exports.createTransactionFromBuffer = createTransactionFromBuffer;
/* istanbul ignore next */
function createTransactionFromHex(hex, network) {

@@ -49,3 +41,3 @@ return createTransactionFromBuffer(Buffer.from(hex, 'hex'), network);

function setTransactionBuilderDefaults(txb, network) {
switch (coins_1.getMainnet(network)) {
switch ((0, coins_1.getMainnet)(network)) {
case networks.bitcoincash:

@@ -67,3 +59,3 @@ case networks.bitcoinsv:

let txb;
switch (coins_1.getMainnet(network)) {
switch ((0, coins_1.getMainnet)(network)) {
case networks.bitcoin:

@@ -73,10 +65,13 @@ case networks.bitcoincash:

case networks.bitcoingold:
case networks.litecoin: {
txb = new UtxoTransactionBuilder_1.UtxoTransactionBuilder(network);
break;
}
case networks.dash:
case networks.litecoin:
case networks.zcash:
txb = new TransactionBuilder(network);
txb = new DashTransactionBuilder_1.DashTransactionBuilder(network);
break;
default:
/* istanbul ignore next */
throw new Error(`invalid network`);
case networks.zcash: {
txb = new ZcashTransactionBuilder_1.ZcashTransactionBuilder(network);
break;
}
}

@@ -88,3 +83,3 @@ setTransactionBuilderDefaults(txb, network);

function createTransactionBuilderFromTransaction(tx) {
switch (coins_1.getMainnet(tx.network)) {
switch ((0, coins_1.getMainnet)(tx.network)) {
case networks.bitcoin:

@@ -94,11 +89,12 @@ case networks.bitcoincash:

case networks.bitcoingold:
case networks.litecoin:
return UtxoTransactionBuilder_1.UtxoTransactionBuilder.fromTransaction(tx);
case networks.dash:
case networks.litecoin:
return DashTransactionBuilder_1.DashTransactionBuilder.fromTransaction(tx);
case networks.zcash:
return TransactionBuilder.fromTransaction(tx, tx.network);
return ZcashTransactionBuilder_1.ZcashTransactionBuilder.fromTransaction(tx);
}
/* istanbul ignore next */
throw new Error(`invalid network`);
}
exports.createTransactionBuilderFromTransaction = createTransactionBuilderFromTransaction;
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCx3Q0FBd0M7QUFFeEMsb0NBQXNDO0FBRXRDLE1BQU0sV0FBVyxHQUFHLE9BQU8sQ0FBQyxnQkFBZ0IsQ0FBQyxDQUFDO0FBQzlDLE1BQU0sa0JBQWtCLEdBQUcsT0FBTyxDQUFDLHdCQUF3QixDQUFDLENBQUM7QUFNN0QsU0FBZ0IsMkJBQTJCLENBQUMsT0FBZ0I7SUFDMUQsUUFBUSxrQkFBVSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzNCLEtBQUssUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUN0QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxJQUFJLENBQUM7UUFDbkIsS0FBSyxRQUFRLENBQUMsUUFBUSxDQUFDO1FBQ3ZCLEtBQUssUUFBUSxDQUFDLEtBQUs7WUFDakIsT0FBTyxJQUFJLFdBQVcsQ0FBQyxPQUFPLENBQUMsQ0FBQztLQUNuQztJQUVELDBCQUEwQjtJQUMxQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFDckMsQ0FBQztBQWRELGtFQWNDO0FBRUQsU0FBZ0IsMkJBQTJCLENBQUMsR0FBVyxFQUFFLE9BQWdCO0lBQ3ZFLFFBQVEsa0JBQVUsQ0FBQyxPQUFPLENBQUMsRUFBRTtRQUMzQixLQUFLLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDdEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLFNBQVMsQ0FBQztRQUN4QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsSUFBSSxDQUFDO1FBQ25CLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQztRQUN2QixLQUFLLFFBQVEsQ0FBQyxLQUFLO1lBQ2pCLE9BQU8sV0FBVyxDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsT0FBTyxDQUFDLENBQUM7S0FDL0M7SUFFRCwwQkFBMEI7SUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ3JDLENBQUM7QUFkRCxrRUFjQztBQUVELFNBQWdCLHdCQUF3QixDQUFDLEdBQVcsRUFBRSxPQUFnQjtJQUNwRSxPQUFPLDJCQUEyQixDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsR0FBRyxFQUFFLEtBQUssQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0FBQ3ZFLENBQUM7QUFGRCw0REFFQztBQUVELFNBQWdCLDZCQUE2QixDQUFDLEdBQXVCLEVBQUUsT0FBZ0I7SUFDckYsUUFBUSxrQkFBVSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzNCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVztZQUN2QixHQUFHLENBQUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDO1lBQ2xCLE1BQU07UUFDUixLQUFLLFFBQVEsQ0FBQyxLQUFLO1lBQ2pCLEdBQUcsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7WUFDbEIsR0FBRyxDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ2xDLGdFQUFnRTtZQUNoRSxHQUFHLENBQUMsb0JBQW9CLENBQUMsVUFBVSxDQUFDLENBQUM7WUFDckMsTUFBTTtLQUNUO0FBQ0gsQ0FBQztBQWRELHNFQWNDO0FBRUQsU0FBZ0Isa0NBQWtDLENBQUMsT0FBZ0I7SUFDakUsSUFBSSxHQUFHLENBQUM7SUFDUixRQUFRLGtCQUFVLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDM0IsS0FBSyxRQUFRLENBQUMsT0FBTyxDQUFDO1FBQ3RCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLElBQUksQ0FBQztRQUNuQixLQUFLLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDdkIsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNqQixHQUFHLEdBQUcsSUFBSSxrQkFBa0IsQ0FBQyxPQUFPLENBQUMsQ0FBQztZQUN0QyxNQUFNO1FBQ1I7WUFDRSwwQkFBMEI7WUFDMUIsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0tBQ3RDO0lBRUQsNkJBQTZCLENBQUMsR0FBRyxFQUFFLE9BQU8sQ0FBQyxDQUFDO0lBRTVDLE9BQU8sR0FBRyxDQUFDO0FBQ2IsQ0FBQztBQXBCRCxnRkFvQkM7QUFFRCxTQUFnQix1Q0FBdUMsQ0FBQyxFQUFlO0lBQ3JFLFFBQVEsa0JBQVUsQ0FBQyxFQUFFLENBQUMsT0FBTyxDQUFDLEVBQUU7UUFDOUIsS0FBSyxRQUFRLENBQUMsT0FBTyxDQUFDO1FBQ3RCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLElBQUksQ0FBQztRQUNuQixLQUFLLFFBQVEsQ0FBQyxRQUFRLENBQUM7UUFDdkIsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNqQixPQUFPLGtCQUFrQixDQUFDLGVBQWUsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxDQUFDO0tBQzdEO0lBRUQsMEJBQTBCO0lBQzFCLE1BQU0sSUFBSSxLQUFLLENBQUMsaUJBQWlCLENBQUMsQ0FBQztBQUNyQyxDQUFDO0FBZEQsMEZBY0MiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcbiAqIEBwcmV0dGllclxuICovXG5pbXBvcnQgKiBhcyBuZXR3b3JrcyBmcm9tICcuLi9uZXR3b3Jrcyc7XG5pbXBvcnQgeyBOZXR3b3JrLCBaY2FzaE5ldHdvcmsgfSBmcm9tICcuLi9uZXR3b3JrVHlwZXMnO1xuaW1wb3J0IHsgZ2V0TWFpbm5ldCB9IGZyb20gJy4uL2NvaW5zJztcblxuY29uc3QgVHJhbnNhY3Rpb24gPSByZXF1aXJlKCcuLi90cmFuc2FjdGlvbicpO1xuY29uc3QgVHJhbnNhY3Rpb25CdWlsZGVyID0gcmVxdWlyZSgnLi4vdHJhbnNhY3Rpb25fYnVpbGRlcicpO1xuXG50eXBlIFRyYW5zYWN0aW9uID0gYW55O1xuXG50eXBlIFRyYW5zYWN0aW9uQnVpbGRlciA9IGFueTtcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uRm9yTmV0d29yayhuZXR3b3JrOiBOZXR3b3JrKTogVHJhbnNhY3Rpb24ge1xuICBzd2l0Y2ggKGdldE1haW5uZXQobmV0d29yaykpIHtcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW46XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luY2FzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5nb2xkOlxuICAgIGNhc2UgbmV0d29ya3MuZGFzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmxpdGVjb2luOlxuICAgIGNhc2UgbmV0d29ya3MuemNhc2g6XG4gICAgICByZXR1cm4gbmV3IFRyYW5zYWN0aW9uKG5ldHdvcmspO1xuICB9XG5cbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIG5ldHdvcmtgKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uRnJvbUJ1ZmZlcihidWY6IEJ1ZmZlciwgbmV0d29yazogTmV0d29yayk6IFRyYW5zYWN0aW9uIHtcbiAgc3dpdGNoIChnZXRNYWlubmV0KG5ldHdvcmspKSB7XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmNhc2g6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luc3Y6XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luZ29sZDpcbiAgICBjYXNlIG5ldHdvcmtzLmRhc2g6XG4gICAgY2FzZSBuZXR3b3Jrcy5saXRlY29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLnpjYXNoOlxuICAgICAgcmV0dXJuIFRyYW5zYWN0aW9uLmZyb21CdWZmZXIoYnVmLCBuZXR3b3JrKTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBuZXR3b3JrYCk7XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUcmFuc2FjdGlvbkZyb21IZXgoaGV4OiBzdHJpbmcsIG5ldHdvcms6IE5ldHdvcmspOiBUcmFuc2FjdGlvbiB7XG4gIHJldHVybiBjcmVhdGVUcmFuc2FjdGlvbkZyb21CdWZmZXIoQnVmZmVyLmZyb20oaGV4LCAnaGV4JyksIG5ldHdvcmspO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gc2V0VHJhbnNhY3Rpb25CdWlsZGVyRGVmYXVsdHModHhiOiBUcmFuc2FjdGlvbkJ1aWxkZXIsIG5ldHdvcms6IE5ldHdvcmspOiB2b2lkIHtcbiAgc3dpdGNoIChnZXRNYWlubmV0KG5ldHdvcmspKSB7XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luY2FzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5nb2xkOlxuICAgICAgdHhiLnNldFZlcnNpb24oMik7XG4gICAgICBicmVhaztcbiAgICBjYXNlIG5ldHdvcmtzLnpjYXNoOlxuICAgICAgdHhiLnNldFZlcnNpb24oNCk7XG4gICAgICB0eGIuc2V0VmVyc2lvbkdyb3VwSWQoMHg4OTJmMjA4NSk7XG4gICAgICAvLyBVc2UgXCJDYW5vcHlcIiBjb25zZW5zdXMgYnJhbmNoIElEIGh0dHBzOi8vemlwcy56LmNhc2gvemlwLTAyNTFcbiAgICAgIHR4Yi5zZXRDb25zZW5zdXNCcmFuY2hJZCgweGU5ZmY3NWE2KTtcbiAgICAgIGJyZWFrO1xuICB9XG59XG5cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUcmFuc2FjdGlvbkJ1aWxkZXJGb3JOZXR3b3JrKG5ldHdvcms6IE5ldHdvcmspOiBUcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBsZXQgdHhiO1xuICBzd2l0Y2ggKGdldE1haW5uZXQobmV0d29yaykpIHtcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW46XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luY2FzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5nb2xkOlxuICAgIGNhc2UgbmV0d29ya3MuZGFzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmxpdGVjb2luOlxuICAgIGNhc2UgbmV0d29ya3MuemNhc2g6XG4gICAgICB0eGIgPSBuZXcgVHJhbnNhY3Rpb25CdWlsZGVyKG5ldHdvcmspO1xuICAgICAgYnJlYWs7XG4gICAgZGVmYXVsdDpcbiAgICAgIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gICAgICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgbmV0d29ya2ApO1xuICB9XG5cbiAgc2V0VHJhbnNhY3Rpb25CdWlsZGVyRGVmYXVsdHModHhiLCBuZXR3b3JrKTtcblxuICByZXR1cm4gdHhiO1xufVxuXG5leHBvcnQgZnVuY3Rpb24gY3JlYXRlVHJhbnNhY3Rpb25CdWlsZGVyRnJvbVRyYW5zYWN0aW9uKHR4OiBUcmFuc2FjdGlvbik6IFRyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldCh0eC5uZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSBuZXR3b3Jrcy5kYXNoOlxuICAgIGNhc2UgbmV0d29ya3MubGl0ZWNvaW46XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgIHJldHVybiBUcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4LCB0eC5uZXR3b3JrKTtcbiAgfVxuXG4gIC8qIGlzdGFuYnVsIGlnbm9yZSBuZXh0ICovXG4gIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBuZXR3b3JrYCk7XG59XG4iXX0=
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNhY3Rpb24uanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYml0Z28vdHJhbnNhY3Rpb24udHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUE7O0dBRUc7QUFDSCx3Q0FBd0M7QUFFeEMsb0NBQXNDO0FBRXRDLHVEQUFvRDtBQUNwRCxxRUFBa0U7QUFDbEUsNERBQXlEO0FBQ3pELDBFQUF1RTtBQUN2RSw2RUFBMEU7QUFDMUUsK0RBQTREO0FBRTVELFNBQWdCLDJCQUEyQixDQUFDLEdBQVcsRUFBRSxPQUFnQjtJQUN2RSxRQUFRLElBQUEsa0JBQVUsRUFBQyxPQUFPLENBQUMsRUFBRTtRQUMzQixLQUFLLFFBQVEsQ0FBQyxPQUFPLENBQUM7UUFDdEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLFNBQVMsQ0FBQztRQUN4QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsUUFBUTtZQUNwQixPQUFPLGlDQUFlLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDekQsS0FBSyxRQUFRLENBQUMsSUFBSTtZQUNoQixPQUFPLGlDQUFlLENBQUMsVUFBVSxDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsT0FBTyxDQUFDLENBQUM7UUFDekQsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNqQixPQUFPLG1DQUFnQixDQUFDLFVBQVUsQ0FBQyxHQUFHLEVBQUUsS0FBSyxFQUFFLE9BQXVCLENBQUMsQ0FBQztLQUMzRTtJQUVELDBCQUEwQjtJQUMxQixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixDQUFDLENBQUM7QUFDckMsQ0FBQztBQWhCRCxrRUFnQkM7QUFFRCwwQkFBMEI7QUFDMUIsU0FBZ0Isd0JBQXdCLENBQUMsR0FBVyxFQUFFLE9BQWdCO0lBQ3BFLE9BQU8sMkJBQTJCLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsS0FBSyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUM7QUFDdkUsQ0FBQztBQUZELDREQUVDO0FBRUQsU0FBZ0IsNkJBQTZCLENBQUMsR0FBMkIsRUFBRSxPQUFnQjtJQUN6RixRQUFRLElBQUEsa0JBQVUsRUFBQyxPQUFPLENBQUMsRUFBRTtRQUMzQixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVc7WUFDdkIsR0FBRyxDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUNsQixNQUFNO1FBQ1IsS0FBSyxRQUFRLENBQUMsS0FBSztZQUNoQixHQUErQixDQUFDLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQztZQUM5QyxHQUErQixDQUFDLGlCQUFpQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQy9ELGdFQUFnRTtZQUMvRCxHQUErQixDQUFDLG9CQUFvQixDQUFDLFVBQVUsQ0FBQyxDQUFDO1lBQ2xFLE1BQU07S0FDVDtBQUNILENBQUM7QUFkRCxzRUFjQztBQUVELFNBQWdCLGtDQUFrQyxDQUFDLE9BQWdCO0lBQ2pFLElBQUksR0FBRyxDQUFDO0lBQ1IsUUFBUSxJQUFBLGtCQUFVLEVBQUMsT0FBTyxDQUFDLEVBQUU7UUFDM0IsS0FBSyxRQUFRLENBQUMsT0FBTyxDQUFDO1FBQ3RCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxTQUFTLENBQUM7UUFDeEIsS0FBSyxRQUFRLENBQUMsV0FBVyxDQUFDO1FBQzFCLEtBQUssUUFBUSxDQUFDLFFBQVEsQ0FBQyxDQUFDO1lBQ3RCLEdBQUcsR0FBRyxJQUFJLCtDQUFzQixDQUFDLE9BQU8sQ0FBQyxDQUFDO1lBQzFDLE1BQU07U0FDUDtRQUNELEtBQUssUUFBUSxDQUFDLElBQUk7WUFDaEIsR0FBRyxHQUFHLElBQUksK0NBQXNCLENBQUMsT0FBTyxDQUFDLENBQUM7WUFDMUMsTUFBTTtRQUNSLEtBQUssUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1lBQ25CLEdBQUcsR0FBRyxJQUFJLGlEQUF1QixDQUFDLE9BQXVCLENBQUMsQ0FBQztZQUMzRCxNQUFNO1NBQ1A7S0FDRjtJQUVELDZCQUE2QixDQUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQztJQUU1QyxPQUFPLEdBQUcsQ0FBQztBQUNiLENBQUM7QUF2QkQsZ0ZBdUJDO0FBRUQsU0FBZ0IsdUNBQXVDLENBQUMsRUFBbUI7SUFDekUsUUFBUSxJQUFBLGtCQUFVLEVBQUMsRUFBRSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQzlCLEtBQUssUUFBUSxDQUFDLE9BQU8sQ0FBQztRQUN0QixLQUFLLFFBQVEsQ0FBQyxXQUFXLENBQUM7UUFDMUIsS0FBSyxRQUFRLENBQUMsU0FBUyxDQUFDO1FBQ3hCLEtBQUssUUFBUSxDQUFDLFdBQVcsQ0FBQztRQUMxQixLQUFLLFFBQVEsQ0FBQyxRQUFRO1lBQ3BCLE9BQU8sK0NBQXNCLENBQUMsZUFBZSxDQUFDLEVBQUUsQ0FBQyxDQUFDO1FBQ3BELEtBQUssUUFBUSxDQUFDLElBQUk7WUFDaEIsT0FBTywrQ0FBc0IsQ0FBQyxlQUFlLENBQUMsRUFBcUIsQ0FBQyxDQUFDO1FBQ3ZFLEtBQUssUUFBUSxDQUFDLEtBQUs7WUFDakIsT0FBTyxpREFBdUIsQ0FBQyxlQUFlLENBQUMsRUFBc0IsQ0FBQyxDQUFDO0tBQzFFO0lBRUQsTUFBTSxJQUFJLEtBQUssQ0FBQyxpQkFBaUIsQ0FBQyxDQUFDO0FBQ3JDLENBQUM7QUFmRCwwRkFlQyIsInNvdXJjZXNDb250ZW50IjpbIi8qKlxuICogQHByZXR0aWVyXG4gKi9cbmltcG9ydCAqIGFzIG5ldHdvcmtzIGZyb20gJy4uL25ldHdvcmtzJztcbmltcG9ydCB7IE5ldHdvcmssIFpjYXNoTmV0d29yayB9IGZyb20gJy4uL25ldHdvcmtUeXBlcyc7XG5pbXBvcnQgeyBnZXRNYWlubmV0IH0gZnJvbSAnLi4vY29pbnMnO1xuXG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb24gfSBmcm9tICcuL1V0eG9UcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi9VdHhvVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IERhc2hUcmFuc2FjdGlvbiB9IGZyb20gJy4vZGFzaC9EYXNoVHJhbnNhY3Rpb24nO1xuaW1wb3J0IHsgRGFzaFRyYW5zYWN0aW9uQnVpbGRlciB9IGZyb20gJy4vZGFzaC9EYXNoVHJhbnNhY3Rpb25CdWlsZGVyJztcbmltcG9ydCB7IFpjYXNoVHJhbnNhY3Rpb25CdWlsZGVyIH0gZnJvbSAnLi96Y2FzaC9aY2FzaFRyYW5zYWN0aW9uQnVpbGRlcic7XG5pbXBvcnQgeyBaY2FzaFRyYW5zYWN0aW9uIH0gZnJvbSAnLi96Y2FzaC9aY2FzaFRyYW5zYWN0aW9uJztcblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uRnJvbUJ1ZmZlcihidWY6IEJ1ZmZlciwgbmV0d29yazogTmV0d29yayk6IFV0eG9UcmFuc2FjdGlvbiB7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldChuZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSBuZXR3b3Jrcy5saXRlY29pbjpcbiAgICAgIHJldHVybiBVdHhvVHJhbnNhY3Rpb24uZnJvbUJ1ZmZlcihidWYsIGZhbHNlLCBuZXR3b3JrKTtcbiAgICBjYXNlIG5ldHdvcmtzLmRhc2g6XG4gICAgICByZXR1cm4gRGFzaFRyYW5zYWN0aW9uLmZyb21CdWZmZXIoYnVmLCBmYWxzZSwgbmV0d29yayk7XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgIHJldHVybiBaY2FzaFRyYW5zYWN0aW9uLmZyb21CdWZmZXIoYnVmLCBmYWxzZSwgbmV0d29yayBhcyBaY2FzaE5ldHdvcmspO1xuICB9XG5cbiAgLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbiAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIG5ldHdvcmtgKTtcbn1cblxuLyogaXN0YW5idWwgaWdub3JlIG5leHQgKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVUcmFuc2FjdGlvbkZyb21IZXgoaGV4OiBzdHJpbmcsIG5ldHdvcms6IE5ldHdvcmspOiBVdHhvVHJhbnNhY3Rpb24ge1xuICByZXR1cm4gY3JlYXRlVHJhbnNhY3Rpb25Gcm9tQnVmZmVyKEJ1ZmZlci5mcm9tKGhleCwgJ2hleCcpLCBuZXR3b3JrKTtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNldFRyYW5zYWN0aW9uQnVpbGRlckRlZmF1bHRzKHR4YjogVXR4b1RyYW5zYWN0aW9uQnVpbGRlciwgbmV0d29yazogTmV0d29yayk6IHZvaWQge1xuICBzd2l0Y2ggKGdldE1haW5uZXQobmV0d29yaykpIHtcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgICB0eGIuc2V0VmVyc2lvbigyKTtcbiAgICAgIGJyZWFrO1xuICAgIGNhc2UgbmV0d29ya3MuemNhc2g6XG4gICAgICAodHhiIGFzIFpjYXNoVHJhbnNhY3Rpb25CdWlsZGVyKS5zZXRWZXJzaW9uKDQpO1xuICAgICAgKHR4YiBhcyBaY2FzaFRyYW5zYWN0aW9uQnVpbGRlcikuc2V0VmVyc2lvbkdyb3VwSWQoMHg4OTJmMjA4NSk7XG4gICAgICAvLyBVc2UgXCJDYW5vcHlcIiBjb25zZW5zdXMgYnJhbmNoIElEIGh0dHBzOi8vemlwcy56LmNhc2gvemlwLTAyNTFcbiAgICAgICh0eGIgYXMgWmNhc2hUcmFuc2FjdGlvbkJ1aWxkZXIpLnNldENvbnNlbnN1c0JyYW5jaElkKDB4ZTlmZjc1YTYpO1xuICAgICAgYnJlYWs7XG4gIH1cbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uQnVpbGRlckZvck5ldHdvcmsobmV0d29yazogTmV0d29yayk6IFV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIge1xuICBsZXQgdHhiO1xuICBzd2l0Y2ggKGdldE1haW5uZXQobmV0d29yaykpIHtcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW46XG4gICAgY2FzZSBuZXR3b3Jrcy5iaXRjb2luY2FzaDpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5zdjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5nb2xkOlxuICAgIGNhc2UgbmV0d29ya3MubGl0ZWNvaW46IHtcbiAgICAgIHR4YiA9IG5ldyBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyKG5ldHdvcmspO1xuICAgICAgYnJlYWs7XG4gICAgfVxuICAgIGNhc2UgbmV0d29ya3MuZGFzaDpcbiAgICAgIHR4YiA9IG5ldyBEYXNoVHJhbnNhY3Rpb25CdWlsZGVyKG5ldHdvcmspO1xuICAgICAgYnJlYWs7XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDoge1xuICAgICAgdHhiID0gbmV3IFpjYXNoVHJhbnNhY3Rpb25CdWlsZGVyKG5ldHdvcmsgYXMgWmNhc2hOZXR3b3JrKTtcbiAgICAgIGJyZWFrO1xuICAgIH1cbiAgfVxuXG4gIHNldFRyYW5zYWN0aW9uQnVpbGRlckRlZmF1bHRzKHR4YiwgbmV0d29yayk7XG5cbiAgcmV0dXJuIHR4Yjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVRyYW5zYWN0aW9uQnVpbGRlckZyb21UcmFuc2FjdGlvbih0eDogVXR4b1RyYW5zYWN0aW9uKTogVXR4b1RyYW5zYWN0aW9uQnVpbGRlciB7XG4gIHN3aXRjaCAoZ2V0TWFpbm5ldCh0eC5uZXR3b3JrKSkge1xuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbjpcbiAgICBjYXNlIG5ldHdvcmtzLmJpdGNvaW5jYXNoOlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbnN2OlxuICAgIGNhc2UgbmV0d29ya3MuYml0Y29pbmdvbGQ6XG4gICAgY2FzZSBuZXR3b3Jrcy5saXRlY29pbjpcbiAgICAgIHJldHVybiBVdHhvVHJhbnNhY3Rpb25CdWlsZGVyLmZyb21UcmFuc2FjdGlvbih0eCk7XG4gICAgY2FzZSBuZXR3b3Jrcy5kYXNoOlxuICAgICAgcmV0dXJuIERhc2hUcmFuc2FjdGlvbkJ1aWxkZXIuZnJvbVRyYW5zYWN0aW9uKHR4IGFzIERhc2hUcmFuc2FjdGlvbik7XG4gICAgY2FzZSBuZXR3b3Jrcy56Y2FzaDpcbiAgICAgIHJldHVybiBaY2FzaFRyYW5zYWN0aW9uQnVpbGRlci5mcm9tVHJhbnNhY3Rpb24odHggYXMgWmNhc2hUcmFuc2FjdGlvbik7XG4gIH1cblxuICB0aHJvdyBuZXcgRXJyb3IoYGludmFsaWQgbmV0d29ya2ApO1xufVxuIl19

@@ -9,3 +9,2 @@ "use strict";

const networkTypes_1 = require("./networkTypes");
const typeforce = require('typeforce');
/**

@@ -170,6 +169,9 @@ * @returns {Network[]} all known networks as array

/**
* @param {Network} network
* @param {unknown} network
* @returns {boolean} returns true iff network is any of the network stated in the argument
*/
exports.isValidNetwork = typeforce.oneOf(isBitcoin, isBitcoinCash, isBitcoinGold, isBitcoinSV, isDash, isLitecoin, isZcash);
function isValidNetwork(network) {
return Object.values(networks).includes(network);
}
exports.isValidNetwork = isValidNetwork;
/** @deprecated */

@@ -189,2 +191,2 @@ exports.BCH = networkTypes_1.coins.BCH;

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"]}
//# 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\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 {unknown} network\n * @returns {boolean} returns true iff network is any of the network stated in the argument\n */\nexport function isValidNetwork(network: unknown): network is Network {\n  return Object.values(networks).includes(network as Network);\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"]}

@@ -1,22 +0,20 @@

var script = require('./script');
var templates = require('./templates');
for (var key in templates) {
script[key] = templates[key];
}
module.exports = {
bitgo: require('./bitgo'),
bufferutils: require('./bufferutils'),
Block: require('./block'),
ECPair: require('./ecpair'),
ECSignature: require('./ecsignature'),
HDNode: require('./hdnode'),
Transaction: require('./transaction'),
TransactionBuilder: require('./transaction_builder'),
address: require('./address'),
coins: require('./coins'),
crypto: require('./crypto'),
networks: require('./networks'),
opcodes: require('bitcoin-ops'),
script: script
"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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXguanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsSUFBSSxNQUFNLEdBQUcsT0FBTyxDQUFDLFVBQVUsQ0FBQyxDQUFBO0FBRWhDLElBQUksU0FBUyxHQUFHLE9BQU8sQ0FBQyxhQUFhLENBQUMsQ0FBQTtBQUN0QyxLQUFLLElBQUksR0FBRyxJQUFJLFNBQVMsRUFBRTtJQUN6QixNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsU0FBUyxDQUFDLEdBQUcsQ0FBQyxDQUFBO0NBQzdCO0FBRUQsTUFBTSxDQUFDLE9BQU8sR0FBRztJQUNmLEtBQUssRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDO0lBQ3pCLFdBQVcsRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDO0lBRXJDLEtBQUssRUFBRSxPQUFPLENBQUMsU0FBUyxDQUFDO0lBQ3pCLE1BQU0sRUFBRSxPQUFPLENBQUMsVUFBVSxDQUFDO0lBQzNCLFdBQVcsRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDO0lBQ3JDLE1BQU0sRUFBRSxPQUFPLENBQUMsVUFBVSxDQUFDO0lBQzNCLFdBQVcsRUFBRSxPQUFPLENBQUMsZUFBZSxDQUFDO0lBQ3JDLGtCQUFrQixFQUFFLE9BQU8sQ0FBQyx1QkFBdUIsQ0FBQztJQUVwRCxPQUFPLEVBQUUsT0FBTyxDQUFDLFdBQVcsQ0FBQztJQUM3QixLQUFLLEVBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQztJQUN6QixNQUFNLEVBQUUsT0FBTyxDQUFDLFVBQVUsQ0FBQztJQUMzQixRQUFRLEVBQUUsT0FBTyxDQUFDLFlBQVksQ0FBQztJQUMvQixPQUFPLEVBQUUsT0FBTyxDQUFDLGFBQWEsQ0FBQztJQUMvQixNQUFNLEVBQUUsTUFBTTtDQUNmLENBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJ2YXIgc2NyaXB0ID0gcmVxdWlyZSgnLi9zY3JpcHQnKVxuXG52YXIgdGVtcGxhdGVzID0gcmVxdWlyZSgnLi90ZW1wbGF0ZXMnKVxuZm9yICh2YXIga2V5IGluIHRlbXBsYXRlcykge1xuICBzY3JpcHRba2V5XSA9IHRlbXBsYXRlc1trZXldXG59XG5cbm1vZHVsZS5leHBvcnRzID0ge1xuICBiaXRnbzogcmVxdWlyZSgnLi9iaXRnbycpLFxuICBidWZmZXJ1dGlsczogcmVxdWlyZSgnLi9idWZmZXJ1dGlscycpLCAvLyBUT0RPOiByZW1vdmUgaW4gNC4wLjBcblxuICBCbG9jazogcmVxdWlyZSgnLi9ibG9jaycpLFxuICBFQ1BhaXI6IHJlcXVpcmUoJy4vZWNwYWlyJyksXG4gIEVDU2lnbmF0dXJlOiByZXF1aXJlKCcuL2Vjc2lnbmF0dXJlJyksXG4gIEhETm9kZTogcmVxdWlyZSgnLi9oZG5vZGUnKSxcbiAgVHJhbnNhY3Rpb246IHJlcXVpcmUoJy4vdHJhbnNhY3Rpb24nKSxcbiAgVHJhbnNhY3Rpb25CdWlsZGVyOiByZXF1aXJlKCcuL3RyYW5zYWN0aW9uX2J1aWxkZXInKSxcblxuICBhZGRyZXNzOiByZXF1aXJlKCcuL2FkZHJlc3MnKSxcbiAgY29pbnM6IHJlcXVpcmUoJy4vY29pbnMnKSxcbiAgY3J5cHRvOiByZXF1aXJlKCcuL2NyeXB0bycpLFxuICBuZXR3b3JrczogcmVxdWlyZSgnLi9uZXR3b3JrcycpLFxuICBvcGNvZGVzOiByZXF1aXJlKCdiaXRjb2luLW9wcycpLFxuICBzY3JpcHQ6IHNjcmlwdFxufVxuIl19
Object.defineProperty(exports, "__esModule", { value: true });
exports.networks = exports.address = exports.coins = exports.bitgo = exports.classify = void 0;
__exportStar(require("bitcoinjs-lib"), exports);
exports.classify = require("bitcoinjs-lib/src/classify");
exports.bitgo = require("./bitgo");
exports.coins = require("./coins");
exports.address = require("./address");
exports.networks = require('./networks');
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7OztBQUFBLGdEQUE4QjtBQUM5Qix5REFBdUQ7QUFFdkQsbUNBQWlDO0FBQ2pDLG1DQUFpQztBQUVqQyx1Q0FBcUM7QUFHeEIsUUFBQSxRQUFRLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnYml0Y29pbmpzLWxpYic7XG5leHBvcnQgKiBhcyBjbGFzc2lmeSBmcm9tICdiaXRjb2luanMtbGliL3NyYy9jbGFzc2lmeSc7XG5cbmV4cG9ydCAqIGFzIGJpdGdvIGZyb20gJy4vYml0Z28nO1xuZXhwb3J0ICogYXMgY29pbnMgZnJvbSAnLi9jb2lucyc7XG5cbmV4cG9ydCAqIGFzIGFkZHJlc3MgZnJvbSAnLi9hZGRyZXNzJztcblxuXG5leHBvcnQgY29uc3QgbmV0d29ya3MgPSByZXF1aXJlKCcuL25ldHdvcmtzJyk7XG5cbmV4cG9ydCB7IE5ldHdvcmssIFpjYXNoTmV0d29yaywgQml0Y29pbkNhc2hOZXR3b3JrIH0gZnJvbSAnLi9uZXR3b3JrVHlwZXMnO1xuZXhwb3J0IHsgTmV0d29yayBhcyBCaXRjb2luSlNOZXR3b3JrIH0gZnJvbSAnYml0Y29pbmpzLWxpYic7XG4iXX0=

@@ -130,2 +130,3 @@ "use strict";

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

@@ -210,2 +211,2 @@ // https://github.com/dashpay/dash/blob/master/src/validation.cpp

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"]}
//# 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    forkId: 0x00,\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.10.0-rc.12",
"version": "2.0.0-rc.0",
"description": "Client-side Bitcoin JavaScript library",

@@ -21,11 +21,17 @@ "main": "./dist/src/index.js",

"scripts": {
"prepare": "npm run build",
"build": "tsc --project tsconfig.build.json",
"coverage-report": "nyc report --reporter=lcov",
"coverage-html": "nyc report --reporter=html",
"coverage": "npm run build && BITGO_UTXO_LIB_TEST_EXPECTED_COUNT=3594 nyc --check-coverage --branches 88 --functions 90 mocha",
"integration-test": "mocha test/integration/",
"standard": "standard",
"test": "npm run standard && npm run coverage",
"coverage": "npm run build && nyc --check-coverage mocha",
"test": "npm run coverage",
"unit-test": "mocha"
},
"nyc": {
"include": [
"src/**"
],
"branches": 78,
"functions": 90
},
"repository": {

@@ -41,18 +47,7 @@ "type": "git",

"@bitgo/blake2b": "^3.0.1",
"bech32": "0.0.3",
"bigi": "^1.4.0",
"bip66": "^1.1.0",
"bitcoin-ops": "^1.3.0",
"bitcoinjs-lib": "git+https://github.com/BitGo/bitcoinjs-lib.git#19fd098772",
"bs58check": "^2.0.0",
"create-hash": "^1.1.0",
"create-hmac": "^1.1.3",
"debug": "~3.1.0",
"ecurve": "^1.0.0",
"merkle-lib": "^2.0.10",
"pushdata-bitcoin": "^1.0.1",
"randombytes": "^2.0.1",
"safe-buffer": "^5.0.1",
"typeforce": "^1.11.3",
"varuint-bitcoin": "^1.0.4",
"wif": "^2.0.1"
"varuint-bitcoin": "^1.0.4"
},

@@ -62,20 +57,11 @@ "devDependencies": {

"axios": "^0.21.1",
"bip39": "^2.3.0",
"bip65": "^1.0.1",
"bs58": "^4.0.0",
"dhttp": "^2.4.2",
"debug": "^3.1.0",
"fs-extra": "^9.1.0",
"minimaldata": "^1.0.2",
"mocha": "^8.4.0",
"nyc": "^15.1.0",
"proxyquire": "^1.4.0",
"sinon": "^1.12.2",
"standard": "^9.0.2",
"ts-node": "^9.1.1"
"ts-node": "^9.1.1",
"typescript": "^4.4.3"
},
"license": "MIT",
"optionalDependencies": {
"secp256k1": "^3.5.2"
},
"gitHead": "fce052925597b7ca2e83e233499c8ea2eec06b4b"
"gitHead": "1fdf39e7637218635778c98281cf73cccb7bcb47"
}

@@ -1,28 +0,6 @@

# BitGo UTXO library (bitgo-utxo-lib)
[![Build Status](https://travis-ci.org/BitGo/bitgo-utxo-lib.png?branch=master)](https://travis-ci.org/BitGo/bitgo-utxo-lib)
[![NPM](https://img.shields.io/npm/v/bitgo-utxo-lib.svg)](https://www.npmjs.org/package/bitgo-utxo-lib)
[![Known Vulnerabilities](https://snyk.io/test/github/BitGo/bitgo-utxo-lib/badge.svg?targetFile=package.json)](https://snyk.io/test/github/BitGo/bitgo-utxo-lib?targetFile=package.json)
# BitGo UTXO library
[![js-standard-style](https://cdn.rawgit.com/feross/standard/master/badge.svg)](https://github.com/feross/standard)
This library is a wrapper around [bitcoinjs-lib](https://github.com/bitcoinjs/bitcoinjs-lib) adding altcoin support.
Originally a fork of [bitcoinjs-lib](https://github.com/BitGo/bitcoinjs-lib); we evolved this library to support the transaction building process of different UTXO based coins.
## Supported coins
- Bitcoin
- Bitcoin Cash
- Bitcoin Gold
- Bitcoin SV (Satoshi Vision)
- Dash
- Litecoin
- Zcash (Sapling compatible)
## Features
- Clean: Pure JavaScript, concise code, easy to read.
- Tested: Coverage > 90%, third-party integration tests.
- Compatible: Works on Node.js and all modern browsers.
- Powerful: Support for advanced features, such as multi-sig, HD Wallets.
- Secure: Strong random number generation, PGP signed releases, trusted developers.
- Principled: No support for browsers with RNG (IE < 11)
- Standardized: Node community coding style, Browserify, Node's stdlib and Buffers.
- Experiment-friendly: Mainnet and Testnet support.
- Multicoin support: Configurable behaviour based on [network](https://github.com/BitGo/bitgo-utxo-lib/blob/master/src/networks.js) objects.

@@ -38,112 +16,28 @@ - Backed by [BitGo](https://www.bitgo.com/info/)

### Node.js
``` javascript
var bitGoUTXO = require('@bitgo/utxo-lib')
```typescript
import * as utxolib from '@bitgo/utxo-lib'
```
### Browser
If you're familiar with how to use browserify, ignore this and proceed normally.
These steps are advisory only, and may not be suitable for your application.
[Browserify](https://github.com/substack/node-browserify) is assumed to be installed for these steps.
## Usage
For your project, create an `index.js` file
``` javascript
let bitGoUTXO = require('@bitgo/utxo-lib')
Support for parsing and building altcoin transactions is provided by the following methods
// your code here
function myFunction () {
return bitGoUTXO.ECPair.makeRandom().toWIF()
}
* `utxolib.bitgo.createTransactionFromBuffer(buffer, network): UtxoTransaction` (similarly `createTransactionFromHex(string, network)`)
* `utxolib.bitgo.createTransactionBuilderForNetwork(network): UtxoTransactionBuilder`
* `utxolib.bitgo.createTransactionBuilderFromTransaction(tx): UtxoTransactionBuilder`
module.exports = {
myFunction
}
```
The `UtxoTransaction(Builder)` classes have the same interface as the `Transaction` type in `bitcoinjs-lib` .
Now, to compile for the browser:
``` bash
browserify index.js --standalone foo > app.js
```
## Supported coins
You can now put `<script src="app.js" />` in your web page, using `foo.myFunction` to create a new Bitcoin private key.
|Network|Mainnet|Testnet|
|---|---|---|
|Bitcoin|`utxolib.networks.bitcoin`|`utxolib.networks.testnet`|
|Bitcoin Cash|`utxolib.networks.bitcoincash`|`utxolib.networks.bitcoincashTestnet`|
|Bitcoin Gold|`utxolib.networks.bitcoingold`|`utxolib.networks.bitcoingoldTestnet`|
|Bitcoin SV (Satoshi Vision)|`utxolib.networks.bitcoinsv`|`utxolib.networks.bitcoinsvTestnet`|
|Dash|`utxolib.networks.dash`|`utxolib.networks.dash`|
|Litecoin|`utxolib.networks.litecoin`|`utxolib.networks.litecoinTest`|
|Zcash|`utxolib.networks.zcash`|`utxolib.networks.zcashTest`|
**NOTE**: If you uglify the javascript, you must exclude the following variable names from being mangled: `BigInteger`, `ECPair`, `Point`.
This is because of the function-name-duck-typing used in [typeforce](https://github.com/dcousens/typeforce).
Example:
``` bash
uglifyjs ... --mangle --reserved 'BigInteger,ECPair,Point'
```
**NOTE**: This library tracks Node LTS features, if you need strict ES5, use [`--transform babelify`](https://github.com/babel/babelify) in conjunction with your `browserify` step (using an [`es2015`](http://babeljs.io/docs/plugins/preset-es2015/) preset).
**NOTE**: If you expect this library to run on an iOS 10 device, ensure that you are using [buffer@5.0.5](https://github.com/feross/buffer/pull/155) or greater.
## Examples
The below examples are implemented as integration tests, they should be very easy to understand.
Otherwise, pull requests are appreciated.
Some examples interact (via HTTPS) with a 3rd Party Blockchain Provider (3PBP).
### Bitcoin
- [Generate a random address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L12)
- [Generate an address from a SHA256 hash](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L19)
- [Import an address via WIF](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L29)
- [Generate a 2-of-3 P2SH multisig address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L36)
- [Generate a SegWit address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L50)
- [Generate a SegWit P2SH address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L60)
- [Generate a SegWit 3-of-4 multisig address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L71)
- [Generate a SegWit 2-of-2 P2SH multisig address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L86)
- [Support the retrieval of transactions for an address (3rd party blockchain)](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L100)
- [Generate a Testnet address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L121)
- [Generate a Litecoin address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/addresses.js#L131)
- [Create a 1-to-1 Transaction](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L14)
- [Create a 2-to-2 Transaction](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L28)
- [Create (and broadcast via 3PBP) a typical Transaction](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L46)
- [Create (and broadcast via 3PBP) a Transaction with an OP\_RETURN output](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L88)
- [Create (and broadcast via 3PBP) a Transaction with a 2-of-4 P2SH(multisig) input](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L115)
- [Create (and broadcast via 3PBP) a Transaction with a SegWit P2SH(P2WPKH) input](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L151)
- [Create (and broadcast via 3PBP) a Transaction with a SegWit 3-of-4 P2SH(P2WSH(multisig)) input](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/transactions.js#L183)
- [Import a BIP32 testnet xpriv and export to WIF](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L8)
- [Export a BIP32 xpriv, then import it](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L15)
- [Export a BIP32 xpub](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L26)
- [Create a BIP32, bitcoin, account 0, external address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L35)
- [Create a BIP44, bitcoin, account 0, external address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L50)
- [Create a BIP49, bitcoin testnet, account 0, external address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L66)
- [Use BIP39 to generate BIP32 addresses](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/bip32.js#L83)
- [Create (and broadcast via 3PBP) a Transaction where Alice can redeem the output after the expiry](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/cltv.js#L37)
- [Create (and broadcast via 3PBP) a Transaction where Alice and Bob can redeem the output at any time](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/cltv.js#L71)
- [Create (but fail to broadcast via 3PBP) a Transaction where Alice attempts to redeem before the expiry](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/cltv.js#L104)
- [Recover a private key from duplicate R values](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/crypto.js#L14)
- [Recover a BIP32 parent private key from the parent public key, and a derived, non-hardened child private key](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/crypto.js#L115)
- [Generate a single-key stealth address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/stealth.js#L70:)
- [Generate a single-key stealth address (randomly)](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/stealth.js#L89:)
- [Recover parent recipient.d, if a derived private key is leaked (and nonce was revealed)](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/stealth.js#L105)
- [Generate a dual-key stealth address](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/stealth.js#L122)
- [Generate a dual-key stealth address (randomly)](https://github.com/BitGo/BitGoJS/tree/master/modules/utxo-lib/test/integration/stealth.js#L145)
If you have a use case that you feel could be listed here, please [ask for it](https://github.com/BitGo/bitgo-utxo-lib/issues/new)!
### Running the test suite
``` bash
npm test
npm run-script coverage
```
## Complementing Libraries
- [BIP21](https://github.com/bitcoinjs/bip21) - A BIP21 compatible URL encoding utility library
- [BIP38](https://github.com/bitcoinjs/bip38) - Passphrase-protected private keys
- [BIP39](https://github.com/bitcoinjs/bip39) - Mnemonic generation for deterministic keys
- [BIP32-Utils](https://github.com/bitcoinjs/bip32-utils) - A set of utilities for working with BIP32
- [BIP66](https://github.com/bitcoinjs/bip66) - Strict DER signature decoding
- [BIP69](https://github.com/bitcoinjs/bip69) - Lexicographical Indexing of Transaction Inputs and Outputs
- [Base58](https://github.com/cryptocoinjs/bs58) - Base58 encoding/decoding
- [Base58 Check](https://github.com/bitcoinjs/bs58check) - Base58 check encoding/decoding
- [Bech32](https://github.com/bitcoinjs/bech32) - A BIP173 compliant Bech32 encoding library
- [coinselect](https://github.com/bitcoinjs/coinselect) - A fee-optimizing, transaction input selection module for bitcoinjs-lib.
- [merkle-lib](https://github.com/bitcoinjs/merkle-lib) - A performance conscious library for merkle root and tree calculations.
- [minimaldata](https://github.com/bitcoinjs/minimaldata) - A module to check bitcoin policy: SCRIPT_VERIFY_MINIMALDATA
## LICENSE [MIT](LICENSE)

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