@bitgo-beta/utxo-core 1.0.1-alpha.112 → 1.0.1-alpha.113

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -1 +1 @@
1
- {"version":3,"file":"toSign.d.ts","sourceRoot":"","sources":["../../../src/bip322/toSign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAY,MAAM,sBAAsB,CAAC;AAM7D,MAAM,MAAM,cAAc,GAAG;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AACF,eAAO,MAAM,qBAAqB,MAAM,CAAC;AAEzC;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,cAAc,CAAC,EAAE,KAAK,CAAC,cAAc,GAAG,KAAK,CAAC,QAAQ,CAmB1F;AAED;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,cAAc,EAAE,GAAG,SAAa,GAAG,IAAI,CA4BlH;AAED,wBAAgB,+BAA+B,CAC7C,IAAI,EAAE,KAAK,CAAC,QAAQ,EACpB,OAAO,EAAE,MAAM,EACf,cAAc,EAAE,KAAK,CAAC,cAAc,EACpC,QAAQ,EAAE,KAAK,CAAC,QAAQ,GACvB,IAAI,CA0EN"}
1
+ {"version":3,"file":"toSign.d.ts","sourceRoot":"","sources":["../../../src/bip322/toSign.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,IAAI,EAAE,KAAK,EAAyB,MAAM,sBAAsB,CAAC;AAM1E,MAAM,MAAM,cAAc,GAAG;IAC3B,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,YAAY,EAAE,MAAM,CAAC;CACtB,CAAC;AACF,eAAO,MAAM,qBAAqB,MAAM,CAAC;AAEzC;;;GAGG;AACH,wBAAgB,oBAAoB,CAAC,cAAc,CAAC,EAAE,KAAK,CAAC,cAAc,GAAG,KAAK,CAAC,QAAQ,CAmB1F;AAED;;;;;;;;;GASG;AACH,wBAAgB,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,EAAE,cAAc,EAAE,cAAc,EAAE,GAAG,SAAa,GAAG,IAAI,CA6BlH;AAED,wBAAgB,+BAA+B,CAC7C,IAAI,EAAE,KAAK,CAAC,QAAQ,EACpB,OAAO,EAAE,MAAM,EACf,cAAc,EAAE,KAAK,CAAC,cAAc,EACpC,QAAQ,EAAE,KAAK,CAAC,QAAQ,GACvB,IAAI,CA0EN"}
@@ -50,6 +50,7 @@ function addBip322Input(psbt, message, addressDetails, tag = toSpend_1.BIP322_TA
50
50
  index: 0, // vin[0].prevout.n = 0
51
51
  sequence: 0, // vin[0].nSequence = 0
52
52
  nonWitnessUtxo: toSpendTx.toBuffer(), // previous transaction for us to rebuild later to verify
53
+ sighashType: utxo_lib_1.Transaction.SIGHASH_ALL,
53
54
  });
54
55
  const inputIndex = psbt.data.inputs.length - 1;
55
56
  psbt.updateInput(inputIndex, {
@@ -122,4 +123,4 @@ function addBip322InputWithChainAndIndex(psbt, message, rootWalletKeys, scriptId
122
123
  psbt.updateInput(inputIndex, utxo_lib_1.bitgo.getPsbtBip32DerivationOutputUpdate(rootWalletKeys, walletKeys, utxo_lib_1.bitgo.scriptTypeForChain(scriptId.chain)));
123
124
  }
124
125
  }
125
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toSign.js","sourceRoot":"","sources":["../../../src/bip322/toSign.ts"],"names":[],"mappings":"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","sourcesContent":["import { Psbt, bitgo, networks } from '@bitgo-beta/utxo-lib';\nimport { toXOnlyPublicKey } from '@bitgo-beta/utxo-lib/dist/src/bitgo/outputScripts';\n\nimport { addBip322ProofMessage } from './utils';\nimport { BIP322_TAG, buildToSpendTransaction } from './toSpend';\n\nexport type AddressDetails = {\n  redeemScript?: Buffer;\n  witnessScript?: Buffer;\n  scriptPubKey: Buffer;\n};\nexport const MAX_NUM_BIP322_INPUTS = 200;\n\n/**\n * Create the base PSBT for the to_sign transaction for BIP322 signing.\n * There will be ever 1 output.\n */\nexport function createBaseToSignPsbt(rootWalletKeys?: bitgo.RootWalletKeys): bitgo.UtxoPsbt {\n  // Create PSBT object for constructing the transaction\n  const psbt = bitgo.createPsbtForNetwork({ network: networks.bitcoin });\n  // Set default value for nVersion and nLockTime\n  psbt.setVersion(0); // nVersion = 0\n  psbt.setLocktime(0); // nLockTime = 0\n\n  // Set the output\n  psbt.addOutput({\n    value: BigInt(0), // vout[0].nValue = 0\n    script: Buffer.from([0x6a]), // vout[0].scriptPubKey = OP_RETURN\n  });\n\n  // If rootWalletKeys are provided, add them to the PSBT as global xpubs\n  if (rootWalletKeys) {\n    bitgo.addXpubsToPsbt(psbt, rootWalletKeys);\n  }\n\n  return psbt;\n}\n\n/**\n * Add a BIP322 input to the PSBT.\n * Source implementation:\n * https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#full\n *\n * @param {string} message - The message that is hashed into the `to_spend` transaction.\n * @param {AddressDetails} addressDetails - The details of the address, including redeemScript and/or witnessScript.\n * @param {string} [tag=BIP322_TAG] - The tag to use for hashing, defaults to BIP322_TAG.\n * @returns {Psbt} - The hex representation of the constructed PSBT.\n */\nexport function addBip322Input(psbt: Psbt, message: string, addressDetails: AddressDetails, tag = BIP322_TAG): void {\n  const toSpendTx = buildToSpendTransaction(addressDetails.scriptPubKey, message, tag);\n  if (psbt.data.inputs.length >= MAX_NUM_BIP322_INPUTS) {\n    throw new Error(`Exceeded maximum number of BIP322 inputs (${MAX_NUM_BIP322_INPUTS})`);\n  }\n\n  psbt.addInput({\n    hash: toSpendTx.getId(), // vin[0].prevout.hash = to_spend.txid\n    index: 0, // vin[0].prevout.n = 0\n    sequence: 0, // vin[0].nSequence = 0\n    nonWitnessUtxo: toSpendTx.toBuffer(), // previous transaction for us to rebuild later to verify\n  });\n  const inputIndex = psbt.data.inputs.length - 1;\n  psbt.updateInput(inputIndex, {\n    witnessUtxo: { value: BigInt(0), script: addressDetails.scriptPubKey },\n  });\n\n  if (addressDetails.redeemScript) {\n    psbt.updateInput(inputIndex, { redeemScript: addressDetails.redeemScript });\n  }\n  if (addressDetails.witnessScript) {\n    psbt.updateInput(inputIndex, {\n      witnessScript: addressDetails.witnessScript,\n    });\n  }\n\n  // Add the message as a proprietary key value to the PSBT so we can verify it later\n  addBip322ProofMessage(psbt, inputIndex, Buffer.from(message));\n}\n\nexport function addBip322InputWithChainAndIndex(\n  psbt: bitgo.UtxoPsbt,\n  message: string,\n  rootWalletKeys: bitgo.RootWalletKeys,\n  scriptId: bitgo.ScriptId\n): void {\n  const scriptType = bitgo.scriptTypeForChain(scriptId.chain);\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(scriptId.chain, scriptId.index);\n  const output = bitgo.outputScripts.createOutputScript2of3(\n    walletKeys.publicKeys,\n    bitgo.scriptTypeForChain(scriptId.chain)\n  );\n\n  addBip322Input(psbt as Psbt, message, {\n    scriptPubKey: output.scriptPubKey,\n    redeemScript: output.redeemScript,\n    witnessScript: output.witnessScript,\n  });\n\n  const inputIndex = psbt.data.inputs.length - 1;\n\n  // When adding the taproot metadata, we assume that we are NOT using the backup path\n  // For script type p2tr, it means that we are using signer and bitgo keys when creating the tap tree\n  // spending paths. For p2trMusig2, it means that we are using the taproot key path spending\n  const keyNames = ['user', 'bitgo'] as bitgo.KeyName[];\n  if (scriptType === 'p2tr') {\n    const { controlBlock, witnessScript, leafVersion, leafHash } = bitgo.outputScripts.createSpendScriptP2tr(\n      walletKeys.publicKeys,\n      [walletKeys.user.publicKey, walletKeys.bitgo.publicKey]\n    );\n    psbt.updateInput(inputIndex, {\n      tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: keyNames.map((key) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], scriptId.chain, scriptId.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = bitgo.outputScripts.createKeyPathP2trMusig2(walletKeys.publicKeys);\n\n    const participantsKeyValData = bitgo.musig2.encodePsbtMusig2Participants({\n      tapOutputKey,\n      tapInternalKey,\n      participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],\n    });\n    bitgo.addProprietaryKeyValuesFromUnknownKeyValues(psbt, 'input', inputIndex, participantsKeyValData);\n\n    psbt.updateInput(inputIndex, {\n      tapInternalKey: tapInternalKey,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapMerkleRoot: taptreeRoot,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: keyNames.map((key) => ({\n        leafHashes: [],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], scriptId.chain, scriptId.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else {\n    // Add bip32 derivation information for the input\n    psbt.updateInput(\n      inputIndex,\n      bitgo.getPsbtBip32DerivationOutputUpdate(rootWalletKeys, walletKeys, bitgo.scriptTypeForChain(scriptId.chain))\n    );\n  }\n}\n"]}
126
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"toSign.js","sourceRoot":"","sources":["../../../src/bip322/toSign.ts"],"names":[],"mappings":"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","sourcesContent":["import { Psbt, bitgo, networks, Transaction } from '@bitgo-beta/utxo-lib';\nimport { toXOnlyPublicKey } from '@bitgo-beta/utxo-lib/dist/src/bitgo/outputScripts';\n\nimport { addBip322ProofMessage } from './utils';\nimport { BIP322_TAG, buildToSpendTransaction } from './toSpend';\n\nexport type AddressDetails = {\n  redeemScript?: Buffer;\n  witnessScript?: Buffer;\n  scriptPubKey: Buffer;\n};\nexport const MAX_NUM_BIP322_INPUTS = 200;\n\n/**\n * Create the base PSBT for the to_sign transaction for BIP322 signing.\n * There will be ever 1 output.\n */\nexport function createBaseToSignPsbt(rootWalletKeys?: bitgo.RootWalletKeys): bitgo.UtxoPsbt {\n  // Create PSBT object for constructing the transaction\n  const psbt = bitgo.createPsbtForNetwork({ network: networks.bitcoin });\n  // Set default value for nVersion and nLockTime\n  psbt.setVersion(0); // nVersion = 0\n  psbt.setLocktime(0); // nLockTime = 0\n\n  // Set the output\n  psbt.addOutput({\n    value: BigInt(0), // vout[0].nValue = 0\n    script: Buffer.from([0x6a]), // vout[0].scriptPubKey = OP_RETURN\n  });\n\n  // If rootWalletKeys are provided, add them to the PSBT as global xpubs\n  if (rootWalletKeys) {\n    bitgo.addXpubsToPsbt(psbt, rootWalletKeys);\n  }\n\n  return psbt;\n}\n\n/**\n * Add a BIP322 input to the PSBT.\n * Source implementation:\n * https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#full\n *\n * @param {string} message - The message that is hashed into the `to_spend` transaction.\n * @param {AddressDetails} addressDetails - The details of the address, including redeemScript and/or witnessScript.\n * @param {string} [tag=BIP322_TAG] - The tag to use for hashing, defaults to BIP322_TAG.\n * @returns {Psbt} - The hex representation of the constructed PSBT.\n */\nexport function addBip322Input(psbt: Psbt, message: string, addressDetails: AddressDetails, tag = BIP322_TAG): void {\n  const toSpendTx = buildToSpendTransaction(addressDetails.scriptPubKey, message, tag);\n  if (psbt.data.inputs.length >= MAX_NUM_BIP322_INPUTS) {\n    throw new Error(`Exceeded maximum number of BIP322 inputs (${MAX_NUM_BIP322_INPUTS})`);\n  }\n\n  psbt.addInput({\n    hash: toSpendTx.getId(), // vin[0].prevout.hash = to_spend.txid\n    index: 0, // vin[0].prevout.n = 0\n    sequence: 0, // vin[0].nSequence = 0\n    nonWitnessUtxo: toSpendTx.toBuffer(), // previous transaction for us to rebuild later to verify\n    sighashType: Transaction.SIGHASH_ALL,\n  });\n  const inputIndex = psbt.data.inputs.length - 1;\n  psbt.updateInput(inputIndex, {\n    witnessUtxo: { value: BigInt(0), script: addressDetails.scriptPubKey },\n  });\n\n  if (addressDetails.redeemScript) {\n    psbt.updateInput(inputIndex, { redeemScript: addressDetails.redeemScript });\n  }\n  if (addressDetails.witnessScript) {\n    psbt.updateInput(inputIndex, {\n      witnessScript: addressDetails.witnessScript,\n    });\n  }\n\n  // Add the message as a proprietary key value to the PSBT so we can verify it later\n  addBip322ProofMessage(psbt, inputIndex, Buffer.from(message));\n}\n\nexport function addBip322InputWithChainAndIndex(\n  psbt: bitgo.UtxoPsbt,\n  message: string,\n  rootWalletKeys: bitgo.RootWalletKeys,\n  scriptId: bitgo.ScriptId\n): void {\n  const scriptType = bitgo.scriptTypeForChain(scriptId.chain);\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(scriptId.chain, scriptId.index);\n  const output = bitgo.outputScripts.createOutputScript2of3(\n    walletKeys.publicKeys,\n    bitgo.scriptTypeForChain(scriptId.chain)\n  );\n\n  addBip322Input(psbt as Psbt, message, {\n    scriptPubKey: output.scriptPubKey,\n    redeemScript: output.redeemScript,\n    witnessScript: output.witnessScript,\n  });\n\n  const inputIndex = psbt.data.inputs.length - 1;\n\n  // When adding the taproot metadata, we assume that we are NOT using the backup path\n  // For script type p2tr, it means that we are using signer and bitgo keys when creating the tap tree\n  // spending paths. For p2trMusig2, it means that we are using the taproot key path spending\n  const keyNames = ['user', 'bitgo'] as bitgo.KeyName[];\n  if (scriptType === 'p2tr') {\n    const { controlBlock, witnessScript, leafVersion, leafHash } = bitgo.outputScripts.createSpendScriptP2tr(\n      walletKeys.publicKeys,\n      [walletKeys.user.publicKey, walletKeys.bitgo.publicKey]\n    );\n    psbt.updateInput(inputIndex, {\n      tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: keyNames.map((key) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], scriptId.chain, scriptId.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = bitgo.outputScripts.createKeyPathP2trMusig2(walletKeys.publicKeys);\n\n    const participantsKeyValData = bitgo.musig2.encodePsbtMusig2Participants({\n      tapOutputKey,\n      tapInternalKey,\n      participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],\n    });\n    bitgo.addProprietaryKeyValuesFromUnknownKeyValues(psbt, 'input', inputIndex, participantsKeyValData);\n\n    psbt.updateInput(inputIndex, {\n      tapInternalKey: tapInternalKey,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapMerkleRoot: taptreeRoot,\n    });\n\n    psbt.updateInput(inputIndex, {\n      tapBip32Derivation: keyNames.map((key) => ({\n        leafHashes: [],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], scriptId.chain, scriptId.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else {\n    // Add bip32 derivation information for the input\n    psbt.updateInput(\n      inputIndex,\n      bitgo.getPsbtBip32DerivationOutputUpdate(rootWalletKeys, walletKeys, bitgo.scriptTypeForChain(scriptId.chain))\n    );\n  }\n}\n"]}
@@ -7,4 +7,12 @@ export declare function addBip322ProofMessage(psbt: utxolib.Psbt, inputIndex: nu
7
7
  * @returns The BIP322 proof message as a Buffer, or undefined if not found
8
8
  */
9
9
  export declare function getBip322ProofMessageAtIndex(psbt: utxolib.Psbt, inputIndex: number): Buffer | undefined;
10
+ /**
11
+ * checks if the transaction contains a BIP322 proof
12
+ * does not check if the proof is valid
13
+ * Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#user-content-Full
14
+ * @params tx The transaction or the PSBT to check
15
+ * @returns boolean
16
+ */
17
+ export declare function isBip322ProofCheck(tx: utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint>): boolean;
10
18
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/bip322/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CASnG;AAED;;;;;GAKG;AACH,wBAAgB,4BAA4B,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAevG"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../../src/bip322/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,wBAAgB,qBAAqB,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI,CASnG;AAED;;;;;GAKG;AACH,wBAAgB,4BAA4B,CAAC,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,UAAU,EAAE,MAAM,GAAG,MAAM,GAAG,SAAS,CAevG;AAED;;;;;;GAMG;AACH,wBAAgB,kBAAkB,CAAC,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,GAAG,OAAO,CAmC9G"}
@@ -35,6 +35,7 @@ var __importStar = (this && this.__importStar) || (function () {
35
35
  Object.defineProperty(exports, "__esModule", { value: true });
36
36
  exports.addBip322ProofMessage = addBip322ProofMessage;
37
37
  exports.getBip322ProofMessageAtIndex = getBip322ProofMessageAtIndex;
38
+ exports.isBip322ProofCheck = isBip322ProofCheck;
38
39
  const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
39
40
  function addBip322ProofMessage(psbt, inputIndex, message) {
40
41
  utxolib.bitgo.addProprietaryKeyValuesFromUnknownKeyValues(psbt, 'input', inputIndex, {
@@ -69,4 +70,46 @@ function getBip322ProofMessageAtIndex(psbt, inputIndex) {
69
70
  }
70
71
  return Buffer.from(proprietaryKeyVals[0].value);
71
72
  }
72
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmlwMzIyL3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsc0RBU0M7QUFRRCxvRUFlQztBQWxDRCw4REFBZ0Q7QUFFaEQsU0FBZ0IscUJBQXFCLENBQUMsSUFBa0IsRUFBRSxVQUFrQixFQUFFLE9BQWU7SUFDM0YsT0FBTyxDQUFDLEtBQUssQ0FBQywyQ0FBMkMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUNuRixHQUFHLEVBQUU7WUFDSCxVQUFVLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkI7WUFDckQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsY0FBYztZQUMzRCxPQUFPLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDekI7UUFDRCxLQUFLLEVBQUUsT0FBTztLQUNmLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLDRCQUE0QixDQUFDLElBQWtCLEVBQUUsVUFBa0I7SUFDakYsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksVUFBVSxFQUFFLENBQUM7UUFDMUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxlQUFlLFVBQVUsZ0NBQWdDLENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBQ0QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDM0MsTUFBTSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLDhCQUE4QixDQUFDLEtBQUssRUFBRTtRQUM3RSxVQUFVLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkI7UUFDckQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsY0FBYztLQUM1RCxDQUFDLENBQUM7SUFDSCxJQUFJLGtCQUFrQixDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNwQyxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO1NBQU0sSUFBSSxrQkFBa0IsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDekMsTUFBTSxJQUFJLEtBQUssQ0FBQyxpREFBaUQsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQ2xELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcblxuZXhwb3J0IGZ1bmN0aW9uIGFkZEJpcDMyMlByb29mTWVzc2FnZShwc2J0OiB1dHhvbGliLlBzYnQsIGlucHV0SW5kZXg6IG51bWJlciwgbWVzc2FnZTogQnVmZmVyKTogdm9pZCB7XG4gIHV0eG9saWIuYml0Z28uYWRkUHJvcHJpZXRhcnlLZXlWYWx1ZXNGcm9tVW5rbm93bktleVZhbHVlcyhwc2J0LCAnaW5wdXQnLCBpbnB1dEluZGV4LCB7XG4gICAga2V5OiB7XG4gICAgICBpZGVudGlmaWVyOiB1dHhvbGliLmJpdGdvLlBTQlRfUFJPUFJJRVRBUllfSURFTlRJRklFUixcbiAgICAgIHN1YnR5cGU6IHV0eG9saWIuYml0Z28uUHJvcHJpZXRhcnlLZXlTdWJ0eXBlLkJJUDMyMl9NRVNTQUdFLFxuICAgICAga2V5ZGF0YTogQnVmZmVyLmFsbG9jKDApLFxuICAgIH0sXG4gICAgdmFsdWU6IG1lc3NhZ2UsXG4gIH0pO1xufVxuXG4vKipcbiAqIEdldCB0aGUgQklQMzIyIHByb29mIG1lc3NhZ2UgYXQgYSBzcGVjaWZpYyBpbnB1dCBpbmRleCBvZiB0aGUgUFNCVFxuICogQHBhcmFtIHBzYnRcbiAqIEBwYXJhbSBpbnB1dEluZGV4XG4gKiBAcmV0dXJucyBUaGUgQklQMzIyIHByb29mIG1lc3NhZ2UgYXMgYSBCdWZmZXIsIG9yIHVuZGVmaW5lZCBpZiBub3QgZm91bmRcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEJpcDMyMlByb29mTWVzc2FnZUF0SW5kZXgocHNidDogdXR4b2xpYi5Qc2J0LCBpbnB1dEluZGV4OiBudW1iZXIpOiBCdWZmZXIgfCB1bmRlZmluZWQge1xuICBpZiAocHNidC5kYXRhLmlucHV0cy5sZW5ndGggPD0gaW5wdXRJbmRleCkge1xuICAgIHRocm93IG5ldyBFcnJvcihgSW5wdXQgaW5kZXggJHtpbnB1dEluZGV4fSBpcyBvdXQgb2YgYm91bmRzIGZvciB0aGUgUFNCVGApO1xuICB9XG4gIGNvbnN0IGlucHV0ID0gcHNidC5kYXRhLmlucHV0c1tpbnB1dEluZGV4XTtcbiAgY29uc3QgcHJvcHJpZXRhcnlLZXlWYWxzID0gdXR4b2xpYi5iaXRnby5nZXRQc2J0SW5wdXRQcm9wcmlldGFyeUtleVZhbHMoaW5wdXQsIHtcbiAgICBpZGVudGlmaWVyOiB1dHhvbGliLmJpdGdvLlBTQlRfUFJPUFJJRVRBUllfSURFTlRJRklFUixcbiAgICBzdWJ0eXBlOiB1dHhvbGliLmJpdGdvLlByb3ByaWV0YXJ5S2V5U3VidHlwZS5CSVAzMjJfTUVTU0FHRSxcbiAgfSk7XG4gIGlmIChwcm9wcmlldGFyeUtleVZhbHMubGVuZ3RoID09PSAwKSB7XG4gICAgcmV0dXJuIHVuZGVmaW5lZDtcbiAgfSBlbHNlIGlmIChwcm9wcmlldGFyeUtleVZhbHMubGVuZ3RoID4gMSkge1xuICAgIHRocm93IG5ldyBFcnJvcihgTXVsdGlwbGUgQklQMzIyIG1lc3NhZ2VzIGZvdW5kIGF0IGlucHV0IGluZGV4ICR7aW5wdXRJbmRleH1gKTtcbiAgfVxuICByZXR1cm4gQnVmZmVyLmZyb20ocHJvcHJpZXRhcnlLZXlWYWxzWzBdLnZhbHVlKTtcbn1cbiJdfQ==
73
+ /**
74
+ * checks if the transaction contains a BIP322 proof
75
+ * does not check if the proof is valid
76
+ * Source: https://github.com/bitcoin/bips/blob/master/bip-0322.mediawiki#user-content-Full
77
+ * @params tx The transaction or the PSBT to check
78
+ * @returns boolean
79
+ */
80
+ function isBip322ProofCheck(tx) {
81
+ if (tx instanceof utxolib.bitgo.UtxoPsbt) {
82
+ if (tx.version !== 0 || tx.locktime !== 0 || tx.data.outputs.length !== 1) {
83
+ return false;
84
+ }
85
+ const output = tx.txOutputs[0];
86
+ if (output.script.toString('hex') !== '6a' || output.value !== 0n) {
87
+ return false;
88
+ }
89
+ // Return true if there is a message encoded in every input in the proprietary field
90
+ return tx.data.inputs.every((input, index) => getBip322ProofMessageAtIndex(tx, index) !== undefined);
91
+ }
92
+ else if (tx instanceof utxolib.bitgo.UtxoTransaction) {
93
+ if (tx.version !== 0 || tx.locktime !== 0 || tx.outs.length !== 1) {
94
+ return false;
95
+ }
96
+ if (tx.outs.length !== 1) {
97
+ return false;
98
+ }
99
+ const output = tx.outs[0];
100
+ // check that the only output is an OP_RETURN with 0 value
101
+ if (output.script.toString('hex') !== '6a' || output.value !== 0n) {
102
+ return false;
103
+ }
104
+ for (const input of tx.ins) {
105
+ if (input.index !== 0 || input.sequence !== 0) {
106
+ return false;
107
+ }
108
+ }
109
+ return true;
110
+ }
111
+ else {
112
+ throw new Error('Unsupported transaction type for BIP322 proof check');
113
+ }
114
+ }
115
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvYmlwMzIyL3V0aWxzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsc0RBU0M7QUFRRCxvRUFlQztBQVNELGdEQW1DQztBQTlFRCw4REFBZ0Q7QUFFaEQsU0FBZ0IscUJBQXFCLENBQUMsSUFBa0IsRUFBRSxVQUFrQixFQUFFLE9BQWU7SUFDM0YsT0FBTyxDQUFDLEtBQUssQ0FBQywyQ0FBMkMsQ0FBQyxJQUFJLEVBQUUsT0FBTyxFQUFFLFVBQVUsRUFBRTtRQUNuRixHQUFHLEVBQUU7WUFDSCxVQUFVLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkI7WUFDckQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsY0FBYztZQUMzRCxPQUFPLEVBQUUsTUFBTSxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7U0FDekI7UUFDRCxLQUFLLEVBQUUsT0FBTztLQUNmLENBQUMsQ0FBQztBQUNMLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILFNBQWdCLDRCQUE0QixDQUFDLElBQWtCLEVBQUUsVUFBa0I7SUFDakYsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxNQUFNLElBQUksVUFBVSxFQUFFLENBQUM7UUFDMUMsTUFBTSxJQUFJLEtBQUssQ0FBQyxlQUFlLFVBQVUsZ0NBQWdDLENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBQ0QsTUFBTSxLQUFLLEdBQUcsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFDM0MsTUFBTSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLDhCQUE4QixDQUFDLEtBQUssRUFBRTtRQUM3RSxVQUFVLEVBQUUsT0FBTyxDQUFDLEtBQUssQ0FBQywyQkFBMkI7UUFDckQsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMscUJBQXFCLENBQUMsY0FBYztLQUM1RCxDQUFDLENBQUM7SUFDSCxJQUFJLGtCQUFrQixDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztRQUNwQyxPQUFPLFNBQVMsQ0FBQztJQUNuQixDQUFDO1NBQU0sSUFBSSxrQkFBa0IsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxFQUFFLENBQUM7UUFDekMsTUFBTSxJQUFJLEtBQUssQ0FBQyxpREFBaUQsVUFBVSxFQUFFLENBQUMsQ0FBQztJQUNqRixDQUFDO0lBQ0QsT0FBTyxNQUFNLENBQUMsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUMsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDO0FBQ2xELENBQUM7QUFFRDs7Ozs7O0dBTUc7QUFDSCxTQUFnQixrQkFBa0IsQ0FBQyxFQUFrRTtJQUNuRyxJQUFJLEVBQUUsWUFBWSxPQUFPLENBQUMsS0FBSyxDQUFDLFFBQVEsRUFBRSxDQUFDO1FBQ3pDLElBQUksRUFBRSxDQUFDLE9BQU8sS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLFFBQVEsS0FBSyxDQUFDLElBQUksRUFBRSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQzFFLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELE1BQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQyxTQUFTLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDL0IsSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxLQUFLLENBQUMsS0FBSyxJQUFJLElBQUksTUFBTSxDQUFDLEtBQUssS0FBSyxFQUFFLEVBQUUsQ0FBQztZQUNsRSxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFFRCxvRkFBb0Y7UUFDcEYsT0FBTyxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sQ0FBQyxLQUFLLENBQUMsQ0FBQyxLQUFLLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyw0QkFBNEIsQ0FBQyxFQUFFLEVBQUUsS0FBSyxDQUFDLEtBQUssU0FBUyxDQUFDLENBQUM7SUFDdkcsQ0FBQztTQUFNLElBQUksRUFBRSxZQUFZLE9BQU8sQ0FBQyxLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDdkQsSUFBSSxFQUFFLENBQUMsT0FBTyxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsUUFBUSxLQUFLLENBQUMsSUFBSSxFQUFFLENBQUMsSUFBSSxDQUFDLE1BQU0sS0FBSyxDQUFDLEVBQUUsQ0FBQztZQUNsRSxPQUFPLEtBQUssQ0FBQztRQUNmLENBQUM7UUFDRCxJQUFJLEVBQUUsQ0FBQyxJQUFJLENBQUMsTUFBTSxLQUFLLENBQUMsRUFBRSxDQUFDO1lBQ3pCLE9BQU8sS0FBSyxDQUFDO1FBQ2YsQ0FBQztRQUNELE1BQU0sTUFBTSxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUIsMERBQTBEO1FBQzFELElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxJQUFJLE1BQU0sQ0FBQyxLQUFLLEtBQUssRUFBRSxFQUFFLENBQUM7WUFDbEUsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDO1FBRUQsS0FBSyxNQUFNLEtBQUssSUFBSSxFQUFFLENBQUMsR0FBRyxFQUFFLENBQUM7WUFDM0IsSUFBSSxLQUFLLENBQUMsS0FBSyxLQUFLLENBQUMsSUFBSSxLQUFLLENBQUMsUUFBUSxLQUFLLENBQUMsRUFBRSxDQUFDO2dCQUM5QyxPQUFPLEtBQUssQ0FBQztZQUNmLENBQUM7UUFDSCxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUM7SUFDZCxDQUFDO1NBQU0sQ0FBQztRQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMscURBQXFELENBQUMsQ0FBQztJQUN6RSxDQUFDO0FBQ0gsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5leHBvcnQgZnVuY3Rpb24gYWRkQmlwMzIyUHJvb2ZNZXNzYWdlKHBzYnQ6IHV0eG9saWIuUHNidCwgaW5wdXRJbmRleDogbnVtYmVyLCBtZXNzYWdlOiBCdWZmZXIpOiB2b2lkIHtcbiAgdXR4b2xpYi5iaXRnby5hZGRQcm9wcmlldGFyeUtleVZhbHVlc0Zyb21Vbmtub3duS2V5VmFsdWVzKHBzYnQsICdpbnB1dCcsIGlucHV0SW5kZXgsIHtcbiAgICBrZXk6IHtcbiAgICAgIGlkZW50aWZpZXI6IHV0eG9saWIuYml0Z28uUFNCVF9QUk9QUklFVEFSWV9JREVOVElGSUVSLFxuICAgICAgc3VidHlwZTogdXR4b2xpYi5iaXRnby5Qcm9wcmlldGFyeUtleVN1YnR5cGUuQklQMzIyX01FU1NBR0UsXG4gICAgICBrZXlkYXRhOiBCdWZmZXIuYWxsb2MoMCksXG4gICAgfSxcbiAgICB2YWx1ZTogbWVzc2FnZSxcbiAgfSk7XG59XG5cbi8qKlxuICogR2V0IHRoZSBCSVAzMjIgcHJvb2YgbWVzc2FnZSBhdCBhIHNwZWNpZmljIGlucHV0IGluZGV4IG9mIHRoZSBQU0JUXG4gKiBAcGFyYW0gcHNidFxuICogQHBhcmFtIGlucHV0SW5kZXhcbiAqIEByZXR1cm5zIFRoZSBCSVAzMjIgcHJvb2YgbWVzc2FnZSBhcyBhIEJ1ZmZlciwgb3IgdW5kZWZpbmVkIGlmIG5vdCBmb3VuZFxuICovXG5leHBvcnQgZnVuY3Rpb24gZ2V0QmlwMzIyUHJvb2ZNZXNzYWdlQXRJbmRleChwc2J0OiB1dHhvbGliLlBzYnQsIGlucHV0SW5kZXg6IG51bWJlcik6IEJ1ZmZlciB8IHVuZGVmaW5lZCB7XG4gIGlmIChwc2J0LmRhdGEuaW5wdXRzLmxlbmd0aCA8PSBpbnB1dEluZGV4KSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBJbnB1dCBpbmRleCAke2lucHV0SW5kZXh9IGlzIG91dCBvZiBib3VuZHMgZm9yIHRoZSBQU0JUYCk7XG4gIH1cbiAgY29uc3QgaW5wdXQgPSBwc2J0LmRhdGEuaW5wdXRzW2lucHV0SW5kZXhdO1xuICBjb25zdCBwcm9wcmlldGFyeUtleVZhbHMgPSB1dHhvbGliLmJpdGdvLmdldFBzYnRJbnB1dFByb3ByaWV0YXJ5S2V5VmFscyhpbnB1dCwge1xuICAgIGlkZW50aWZpZXI6IHV0eG9saWIuYml0Z28uUFNCVF9QUk9QUklFVEFSWV9JREVOVElGSUVSLFxuICAgIHN1YnR5cGU6IHV0eG9saWIuYml0Z28uUHJvcHJpZXRhcnlLZXlTdWJ0eXBlLkJJUDMyMl9NRVNTQUdFLFxuICB9KTtcbiAgaWYgKHByb3ByaWV0YXJ5S2V5VmFscy5sZW5ndGggPT09IDApIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9IGVsc2UgaWYgKHByb3ByaWV0YXJ5S2V5VmFscy5sZW5ndGggPiAxKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBNdWx0aXBsZSBCSVAzMjIgbWVzc2FnZXMgZm91bmQgYXQgaW5wdXQgaW5kZXggJHtpbnB1dEluZGV4fWApO1xuICB9XG4gIHJldHVybiBCdWZmZXIuZnJvbShwcm9wcmlldGFyeUtleVZhbHNbMF0udmFsdWUpO1xufVxuXG4vKipcbiAqIGNoZWNrcyBpZiB0aGUgdHJhbnNhY3Rpb24gY29udGFpbnMgYSBCSVAzMjIgcHJvb2ZcbiAqIGRvZXMgbm90IGNoZWNrIGlmIHRoZSBwcm9vZiBpcyB2YWxpZFxuICogU291cmNlOiBodHRwczovL2dpdGh1Yi5jb20vYml0Y29pbi9iaXBzL2Jsb2IvbWFzdGVyL2JpcC0wMzIyLm1lZGlhd2lraSN1c2VyLWNvbnRlbnQtRnVsbFxuICogQHBhcmFtcyB0eCBUaGUgdHJhbnNhY3Rpb24gb3IgdGhlIFBTQlQgdG8gY2hlY2tcbiAqIEByZXR1cm5zIGJvb2xlYW5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGlzQmlwMzIyUHJvb2ZDaGVjayh0eDogdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludD4pOiBib29sZWFuIHtcbiAgaWYgKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkge1xuICAgIGlmICh0eC52ZXJzaW9uICE9PSAwIHx8IHR4LmxvY2t0aW1lICE9PSAwIHx8IHR4LmRhdGEub3V0cHV0cy5sZW5ndGggIT09IDEpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgY29uc3Qgb3V0cHV0ID0gdHgudHhPdXRwdXRzWzBdO1xuICAgIGlmIChvdXRwdXQuc2NyaXB0LnRvU3RyaW5nKCdoZXgnKSAhPT0gJzZhJyB8fCBvdXRwdXQudmFsdWUgIT09IDBuKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgLy8gUmV0dXJuIHRydWUgaWYgdGhlcmUgaXMgYSBtZXNzYWdlIGVuY29kZWQgaW4gZXZlcnkgaW5wdXQgaW4gdGhlIHByb3ByaWV0YXJ5IGZpZWxkXG4gICAgcmV0dXJuIHR4LmRhdGEuaW5wdXRzLmV2ZXJ5KChpbnB1dCwgaW5kZXgpID0+IGdldEJpcDMyMlByb29mTWVzc2FnZUF0SW5kZXgodHgsIGluZGV4KSAhPT0gdW5kZWZpbmVkKTtcbiAgfSBlbHNlIGlmICh0eCBpbnN0YW5jZW9mIHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uKSB7XG4gICAgaWYgKHR4LnZlcnNpb24gIT09IDAgfHwgdHgubG9ja3RpbWUgIT09IDAgfHwgdHgub3V0cy5sZW5ndGggIT09IDEpIHtcbiAgICAgIHJldHVybiBmYWxzZTtcbiAgICB9XG4gICAgaWYgKHR4Lm91dHMubGVuZ3RoICE9PSAxKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuICAgIGNvbnN0IG91dHB1dCA9IHR4Lm91dHNbMF07XG4gICAgLy8gY2hlY2sgdGhhdCB0aGUgb25seSBvdXRwdXQgaXMgYW4gT1BfUkVUVVJOIHdpdGggMCB2YWx1ZVxuICAgIGlmIChvdXRwdXQuc2NyaXB0LnRvU3RyaW5nKCdoZXgnKSAhPT0gJzZhJyB8fCBvdXRwdXQudmFsdWUgIT09IDBuKSB7XG4gICAgICByZXR1cm4gZmFsc2U7XG4gICAgfVxuXG4gICAgZm9yIChjb25zdCBpbnB1dCBvZiB0eC5pbnMpIHtcbiAgICAgIGlmIChpbnB1dC5pbmRleCAhPT0gMCB8fCBpbnB1dC5zZXF1ZW5jZSAhPT0gMCkge1xuICAgICAgICByZXR1cm4gZmFsc2U7XG4gICAgICB9XG4gICAgfVxuXG4gICAgcmV0dXJuIHRydWU7XG4gIH0gZWxzZSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdVbnN1cHBvcnRlZCB0cmFuc2FjdGlvbiB0eXBlIGZvciBCSVAzMjIgcHJvb2YgY2hlY2snKTtcbiAgfVxufVxuIl19
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@bitgo-beta/utxo-core",
3
- "version": "1.0.1-alpha.112",
3
+ "version": "1.0.1-alpha.113",
4
4
  "description": "BitGo UTXO Core types",
5
5
  "main": "./dist/src/index.js",
6
6
  "types": "./dist/src/index.d.ts",
@@ -27,7 +27,7 @@
27
27
  "lint": "eslint --quiet .",
28
28
  "prepare": "npm run build",
29
29
  "test": "npm run unit-test",
30
- "unit-test": "mocha --recursive \"dist/test/**/*.js\""
30
+ "unit-test": "mocha --recursive \"test/**/*.ts\""
31
31
  },
32
32
  "author": "BitGo SDK Team <sdkteam@bitgo.com>",
33
33
  "license": "MIT",
@@ -52,12 +52,12 @@
52
52
  ]
53
53
  },
54
54
  "dependencies": {
55
- "@bitgo-beta/unspents": "0.11.3-alpha.382",
56
- "@bitgo-beta/utxo-lib": "4.0.1-alpha.382",
55
+ "@bitgo-beta/unspents": "0.11.3-alpha.383",
56
+ "@bitgo-beta/utxo-lib": "4.0.1-alpha.383",
57
57
  "@bitgo/wasm-miniscript": "2.0.0-beta.7",
58
58
  "bip174": "npm:@bitgo-forks/bip174@3.1.0-master.4",
59
59
  "bitcoinjs-message": "npm:@bitgo-forks/bitcoinjs-message@1.0.0-master.3",
60
60
  "fast-sha256": "^1.3.0"
61
61
  },
62
- "gitHead": "ce7315b39cfe1bf8ecbad8017bcc3e1c6f72171a"
62
+ "gitHead": "9da2c7d0ae9cbf83612543939c3cf88bac200a79"
63
63
  }