@bitgo-beta/abstract-utxo 1.6.1-alpha.425 → 1.6.1-alpha.427

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.
Files changed (130) hide show
  1. package/dist/cjs/src/abstractUtxoCoin.d.ts +22 -5
  2. package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -1
  3. package/dist/cjs/src/abstractUtxoCoin.js +53 -26
  4. package/dist/cjs/src/index.d.ts +2 -2
  5. package/dist/cjs/src/index.d.ts.map +1 -1
  6. package/dist/cjs/src/index.js +3 -3
  7. package/dist/cjs/src/recovery/backupKeyRecovery.js +4 -4
  8. package/dist/cjs/src/recovery/crossChainRecovery.d.ts +10 -0
  9. package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -1
  10. package/dist/cjs/src/recovery/crossChainRecovery.js +48 -4
  11. package/dist/cjs/src/transaction/decode.d.ts +11 -0
  12. package/dist/cjs/src/transaction/decode.d.ts.map +1 -0
  13. package/dist/cjs/src/transaction/decode.js +81 -0
  14. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -1
  15. package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +3 -2
  16. package/dist/cjs/src/transaction/explainTransaction.js +3 -3
  17. package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts +24 -0
  18. package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts.map +1 -0
  19. package/dist/cjs/src/transaction/fixedScript/SigningError.js +26 -0
  20. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +1 -1
  21. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -1
  22. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +1 -1
  23. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -1
  24. package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +2 -2
  25. package/dist/cjs/src/transaction/fixedScript/index.d.ts +3 -0
  26. package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -1
  27. package/dist/cjs/src/transaction/fixedScript/index.js +18 -1
  28. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts +4 -0
  29. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts.map +1 -0
  30. package/dist/cjs/src/transaction/fixedScript/musig2.js +3 -0
  31. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts +7 -0
  32. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  33. package/dist/cjs/src/transaction/fixedScript/replayProtection.js +78 -0
  34. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  35. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  36. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.js +152 -0
  37. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts +30 -0
  38. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  39. package/dist/cjs/src/transaction/fixedScript/signPsbt.js +174 -0
  40. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  41. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  42. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.js +129 -0
  43. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts +5 -6
  44. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -1
  45. package/dist/cjs/src/transaction/fixedScript/signTransaction.js +28 -79
  46. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -1
  47. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +3 -2
  48. package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -1
  49. package/dist/cjs/src/transaction/signTransaction.js +5 -2
  50. package/dist/cjs/src/transaction/types.d.ts +5 -0
  51. package/dist/cjs/src/transaction/types.d.ts.map +1 -1
  52. package/dist/cjs/src/transaction/types.js +5 -1
  53. package/dist/cjs/test/unit/recovery/crossChainRecovery.js +24 -1
  54. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +3 -3
  55. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.js +2 -2
  56. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts +2 -0
  57. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  58. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.js +59 -0
  59. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts +2 -0
  60. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  61. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.js +157 -0
  62. package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts.map +1 -1
  63. package/dist/cjs/test/unit/transaction/fixedScript/util.js +2 -1
  64. package/dist/cjs/test/unit/transaction.js +65 -42
  65. package/dist/cjs/tsconfig.tsbuildinfo +1 -1
  66. package/dist/esm/abstractUtxoCoin.d.ts +22 -5
  67. package/dist/esm/abstractUtxoCoin.d.ts.map +1 -1
  68. package/dist/esm/abstractUtxoCoin.js +54 -27
  69. package/dist/esm/index.d.ts +2 -2
  70. package/dist/esm/index.d.ts.map +1 -1
  71. package/dist/esm/index.js +3 -3
  72. package/dist/esm/recovery/backupKeyRecovery.js +2 -2
  73. package/dist/esm/recovery/crossChainRecovery.d.ts +10 -0
  74. package/dist/esm/recovery/crossChainRecovery.d.ts.map +1 -1
  75. package/dist/esm/recovery/crossChainRecovery.js +46 -3
  76. package/dist/esm/transaction/decode.d.ts +11 -0
  77. package/dist/esm/transaction/decode.d.ts.map +1 -0
  78. package/dist/esm/transaction/decode.js +43 -0
  79. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts.map +1 -1
  80. package/dist/esm/transaction/descriptor/verifyTransaction.js +3 -2
  81. package/dist/esm/transaction/explainTransaction.js +3 -3
  82. package/dist/esm/transaction/fixedScript/SigningError.d.ts +24 -0
  83. package/dist/esm/transaction/fixedScript/SigningError.d.ts.map +1 -0
  84. package/dist/esm/transaction/fixedScript/SigningError.js +21 -0
  85. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +1 -1
  86. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -1
  87. package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +1 -1
  88. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -1
  89. package/dist/esm/transaction/fixedScript/explainTransaction.js +2 -2
  90. package/dist/esm/transaction/fixedScript/index.d.ts +3 -0
  91. package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -1
  92. package/dist/esm/transaction/fixedScript/index.js +4 -1
  93. package/dist/esm/transaction/fixedScript/musig2.d.ts +4 -0
  94. package/dist/esm/transaction/fixedScript/musig2.d.ts.map +1 -0
  95. package/dist/esm/transaction/fixedScript/musig2.js +2 -0
  96. package/dist/esm/transaction/fixedScript/replayProtection.d.ts +7 -0
  97. package/dist/esm/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  98. package/dist/esm/transaction/fixedScript/replayProtection.js +39 -0
  99. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  100. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  101. package/dist/esm/transaction/fixedScript/signLegacyTransaction.js +112 -0
  102. package/dist/esm/transaction/fixedScript/signPsbt.d.ts +30 -0
  103. package/dist/esm/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  104. package/dist/esm/transaction/fixedScript/signPsbt.js +134 -0
  105. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  106. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  107. package/dist/esm/transaction/fixedScript/signPsbtWasm.js +122 -0
  108. package/dist/esm/transaction/fixedScript/signTransaction.d.ts +5 -6
  109. package/dist/esm/transaction/fixedScript/signTransaction.d.ts.map +1 -1
  110. package/dist/esm/transaction/fixedScript/signTransaction.js +28 -79
  111. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts.map +1 -1
  112. package/dist/esm/transaction/fixedScript/verifyTransaction.js +3 -2
  113. package/dist/esm/transaction/signTransaction.d.ts.map +1 -1
  114. package/dist/esm/transaction/signTransaction.js +5 -2
  115. package/dist/esm/transaction/types.d.ts +5 -0
  116. package/dist/esm/transaction/types.d.ts.map +1 -1
  117. package/dist/esm/transaction/types.js +4 -2
  118. package/package.json +13 -13
  119. package/dist/cjs/src/replayProtection.d.ts +0 -5
  120. package/dist/cjs/src/replayProtection.d.ts.map +0 -1
  121. package/dist/cjs/src/replayProtection.js +0 -58
  122. package/dist/cjs/src/sign.d.ts +0 -54
  123. package/dist/cjs/src/sign.d.ts.map +0 -1
  124. package/dist/cjs/src/sign.js +0 -205
  125. package/dist/esm/replayProtection.d.ts +0 -5
  126. package/dist/esm/replayProtection.d.ts.map +0 -1
  127. package/dist/esm/replayProtection.js +0 -20
  128. package/dist/esm/sign.d.ts +0 -54
  129. package/dist/esm/sign.d.ts.map +0 -1
  130. package/dist/esm/sign.js +0 -162
@@ -0,0 +1,129 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.signAndVerifyPsbtWasm = signAndVerifyPsbtWasm;
7
+ exports.signPsbtWithMusig2ParticipantWasm = signPsbtWithMusig2ParticipantWasm;
8
+ const assert_1 = __importDefault(require("assert"));
9
+ const wasm_utxo_1 = require("@bitgo/wasm-utxo");
10
+ const SigningError_1 = require("./SigningError");
11
+ /**
12
+ * Key Value: Unsigned tx id => PSBT
13
+ * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
14
+ * Reason: MuSig2 signer secure nonce is cached in the BitGoPsbt object. It will be required during the signing step.
15
+ * For more info, check SignTransactionOptions.signingStep
16
+ */
17
+ const PSBT_CACHE_WASM = new Map();
18
+ function hasKeyPathSpendInput(tx, rootWalletKeys, replayProtection) {
19
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
20
+ return parsed.inputs.some((input) => input.scriptType === 'p2trMusig2KeyPath');
21
+ }
22
+ /**
23
+ * Sign all inputs of a PSBT and verify signatures after signing.
24
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them failed.
25
+ *
26
+ * If it is the last signature, finalize and extract the transaction from the psbt.
27
+ */
28
+ function signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, replayProtection, { isLastSignature }) {
29
+ const wasmSigner = toWasmBIP32(signerKeychain);
30
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
31
+ const signErrors = [];
32
+ const verifyErrors = [];
33
+ // Sign all inputs (skipping replay protection inputs)
34
+ parsed.inputs.forEach((input, inputIndex) => {
35
+ if (input.scriptType === 'p2shP2pk') {
36
+ // Skip replay protection inputs - they are platform signed only
37
+ return;
38
+ }
39
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
40
+ try {
41
+ tx.sign(inputIndex, wasmSigner);
42
+ }
43
+ catch (e) {
44
+ signErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
45
+ }
46
+ });
47
+ // Verify signatures for all signed inputs
48
+ parsed.inputs.forEach((input, inputIndex) => {
49
+ if (input.scriptType === 'p2shP2pk') {
50
+ return;
51
+ }
52
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
53
+ try {
54
+ if (!tx.verifySignature(inputIndex, wasmSigner)) {
55
+ verifyErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, new Error('invalid signature')));
56
+ }
57
+ }
58
+ catch (e) {
59
+ verifyErrors.push(new SigningError_1.InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
60
+ }
61
+ });
62
+ if (signErrors.length || verifyErrors.length) {
63
+ throw new SigningError_1.TransactionSigningError(signErrors, verifyErrors);
64
+ }
65
+ if (isLastSignature) {
66
+ tx.finalizeAllInputs();
67
+ return Buffer.from(tx.extractTransaction());
68
+ }
69
+ return tx;
70
+ }
71
+ function toWasmBIP32(key) {
72
+ // Convert using base58 string to ensure private key is properly transferred
73
+ return wasm_utxo_1.BIP32.fromBase58(key.toBase58());
74
+ }
75
+ async function signPsbtWithMusig2ParticipantWasm(coin, tx, signerKeychain, rootWalletKeys, params) {
76
+ const wasmSigner = signerKeychain ? toWasmBIP32(signerKeychain) : undefined;
77
+ if (hasKeyPathSpendInput(tx, rootWalletKeys, params.replayProtection)) {
78
+ // We can only be the first signature on a transaction with taproot key path spend inputs because
79
+ // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
80
+ // deserialized from a hex.
81
+ if (params.isLastSignature) {
82
+ throw new Error('Cannot be last signature on a transaction with key path spend inputs');
83
+ }
84
+ switch (params.signingStep) {
85
+ case 'signerNonce':
86
+ (0, assert_1.default)(wasmSigner);
87
+ tx.generateMusig2Nonces(wasmSigner);
88
+ PSBT_CACHE_WASM.set(tx.unsignedTxid(), tx);
89
+ return tx;
90
+ case 'cosignerNonce':
91
+ (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
92
+ return await coin.getMusig2Nonces(tx, params.walletId);
93
+ case 'signerSignature': {
94
+ const txId = tx.unsignedTxid();
95
+ const cachedPsbt = PSBT_CACHE_WASM.get(txId);
96
+ (0, assert_1.default)(cachedPsbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE_WASM.size}).
97
+ This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
98
+ PSBT_CACHE_WASM.delete(txId);
99
+ cachedPsbt.combineMusig2Nonces(tx);
100
+ tx = cachedPsbt;
101
+ break;
102
+ }
103
+ default:
104
+ // this instance is not an external signer
105
+ (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
106
+ (0, assert_1.default)(wasmSigner);
107
+ tx.generateMusig2Nonces(wasmSigner);
108
+ const response = await coin.getMusig2Nonces(tx, params.walletId);
109
+ tx.combineMusig2Nonces(response);
110
+ break;
111
+ }
112
+ }
113
+ else {
114
+ switch (params.signingStep) {
115
+ case 'signerNonce':
116
+ case 'cosignerNonce':
117
+ /**
118
+ * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
119
+ * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
120
+ */
121
+ return tx;
122
+ }
123
+ }
124
+ (0, assert_1.default)(signerKeychain);
125
+ return signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, params.replayProtection, {
126
+ isLastSignature: params.isLastSignature,
127
+ });
128
+ }
129
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signPsbtWasm.js","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/signPsbtWasm.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport { BIP32Interface } from '@bitgo-beta/utxo-lib';\nimport { BIP32, ECPair, fixedScriptWallet } from '@bitgo/wasm-utxo';\n\nimport { InputSigningError, TransactionSigningError } from './SigningError';\nimport { Musig2Participant } from './musig2';\n\nexport type ReplayProtectionKeys = {\n  publicKeys: (Uint8Array | ECPair)[];\n};\n\n/**\n * Key Value: Unsigned tx id => PSBT\n * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.\n * Reason: MuSig2 signer secure nonce is cached in the BitGoPsbt object. It will be required during the signing step.\n * For more info, check SignTransactionOptions.signingStep\n */\nconst PSBT_CACHE_WASM = new Map<string, fixedScriptWallet.BitGoPsbt>();\n\nfunction hasKeyPathSpendInput(\n  tx: fixedScriptWallet.BitGoPsbt,\n  rootWalletKeys: fixedScriptWallet.RootWalletKeys,\n  replayProtection: ReplayProtectionKeys\n): boolean {\n  const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);\n  return parsed.inputs.some((input) => input.scriptType === 'p2trMusig2KeyPath');\n}\n\n/**\n * Sign all inputs of a PSBT and verify signatures after signing.\n * Collects and logs signing errors and verification errors, throws error in the end if any of them failed.\n *\n * If it is the last signature, finalize and extract the transaction from the psbt.\n */\nexport function signAndVerifyPsbtWasm(\n  tx: fixedScriptWallet.BitGoPsbt,\n  signerKeychain: BIP32Interface,\n  rootWalletKeys: fixedScriptWallet.RootWalletKeys,\n  replayProtection: ReplayProtectionKeys,\n  { isLastSignature }: { isLastSignature: boolean }\n): fixedScriptWallet.BitGoPsbt | Buffer {\n  const wasmSigner = toWasmBIP32(signerKeychain);\n  const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);\n\n  const signErrors: InputSigningError<bigint>[] = [];\n  const verifyErrors: InputSigningError<bigint>[] = [];\n\n  // Sign all inputs (skipping replay protection inputs)\n  parsed.inputs.forEach((input, inputIndex) => {\n    if (input.scriptType === 'p2shP2pk') {\n      // Skip replay protection inputs - they are platform signed only\n      return;\n    }\n\n    const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;\n    try {\n      tx.sign(inputIndex, wasmSigner);\n    } catch (e) {\n      signErrors.push(new InputSigningError<bigint>(inputIndex, input.scriptType, { id: outputId }, e));\n    }\n  });\n\n  // Verify signatures for all signed inputs\n  parsed.inputs.forEach((input, inputIndex) => {\n    if (input.scriptType === 'p2shP2pk') {\n      return;\n    }\n\n    const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;\n    try {\n      if (!tx.verifySignature(inputIndex, wasmSigner)) {\n        verifyErrors.push(\n          new InputSigningError(inputIndex, input.scriptType, { id: outputId }, new Error('invalid signature'))\n        );\n      }\n    } catch (e) {\n      verifyErrors.push(new InputSigningError<bigint>(inputIndex, input.scriptType, { id: outputId }, e));\n    }\n  });\n\n  if (signErrors.length || verifyErrors.length) {\n    throw new TransactionSigningError(signErrors, verifyErrors);\n  }\n\n  if (isLastSignature) {\n    tx.finalizeAllInputs();\n    return Buffer.from(tx.extractTransaction());\n  }\n\n  return tx;\n}\n\nfunction toWasmBIP32(key: BIP32Interface): BIP32 {\n  // Convert using base58 string to ensure private key is properly transferred\n  return BIP32.fromBase58(key.toBase58());\n}\n\nexport async function signPsbtWithMusig2ParticipantWasm(\n  coin: Musig2Participant<fixedScriptWallet.BitGoPsbt>,\n  tx: fixedScriptWallet.BitGoPsbt,\n  signerKeychain: BIP32Interface | undefined,\n  rootWalletKeys: fixedScriptWallet.RootWalletKeys,\n  params: {\n    replayProtection: ReplayProtectionKeys;\n    isLastSignature: boolean;\n    signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;\n    walletId: string | undefined;\n  }\n): Promise<fixedScriptWallet.BitGoPsbt | Buffer> {\n  const wasmSigner = signerKeychain ? toWasmBIP32(signerKeychain) : undefined;\n\n  if (hasKeyPathSpendInput(tx, rootWalletKeys, params.replayProtection)) {\n    // We can only be the first signature on a transaction with taproot key path spend inputs because\n    // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if\n    // deserialized from a hex.\n    if (params.isLastSignature) {\n      throw new Error('Cannot be last signature on a transaction with key path spend inputs');\n    }\n\n    switch (params.signingStep) {\n      case 'signerNonce':\n        assert(wasmSigner);\n        tx.generateMusig2Nonces(wasmSigner);\n        PSBT_CACHE_WASM.set(tx.unsignedTxid(), tx);\n        return tx;\n      case 'cosignerNonce':\n        assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');\n        return await coin.getMusig2Nonces(tx, params.walletId);\n      case 'signerSignature': {\n        const txId = tx.unsignedTxid();\n        const cachedPsbt = PSBT_CACHE_WASM.get(txId);\n        assert(\n          cachedPsbt,\n          `Psbt is missing from txCache (cache size ${PSBT_CACHE_WASM.size}).\n            This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`\n        );\n        PSBT_CACHE_WASM.delete(txId);\n        cachedPsbt.combineMusig2Nonces(tx);\n        tx = cachedPsbt;\n        break;\n      }\n      default:\n        // this instance is not an external signer\n        assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');\n        assert(wasmSigner);\n        tx.generateMusig2Nonces(wasmSigner);\n        const response = await coin.getMusig2Nonces(tx, params.walletId);\n        tx.combineMusig2Nonces(response);\n        break;\n    }\n  } else {\n    switch (params.signingStep) {\n      case 'signerNonce':\n      case 'cosignerNonce':\n        /**\n         * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).\n         * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.\n         */\n        return tx;\n    }\n  }\n\n  assert(signerKeychain);\n  return signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, params.replayProtection, {\n    isLastSignature: params.isLastSignature,\n  });\n}\n"]}
@@ -1,10 +1,11 @@
1
1
  import { BIP32Interface } from '@bitgo-beta/secp256k1';
2
2
  import * as utxolib from '@bitgo-beta/utxo-lib';
3
- import { AbstractUtxoCoin, DecodedTransaction } from '../../abstractUtxoCoin';
4
- export declare function signTransaction<TNumber extends number | bigint>(coin: AbstractUtxoCoin, tx: DecodedTransaction<TNumber>, signerKeychain: BIP32Interface | undefined, params: {
3
+ import { fixedScriptWallet } from '@bitgo/wasm-utxo';
4
+ import { Musig2Participant } from './musig2';
5
+ export declare function signTransaction<T extends utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt>(coin: Musig2Participant<utxolib.bitgo.UtxoPsbt> | Musig2Participant<fixedScriptWallet.BitGoPsbt>, tx: T, signerKeychain: BIP32Interface | undefined, network: utxolib.Network, params: {
5
6
  walletId: string | undefined;
6
7
  txInfo: {
7
- unspents?: utxolib.bitgo.Unspent<TNumber>[];
8
+ unspents?: utxolib.bitgo.Unspent<bigint | number>[];
8
9
  } | undefined;
9
10
  isLastSignature: boolean;
10
11
  signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
@@ -12,7 +13,5 @@ export declare function signTransaction<TNumber extends number | bigint>(coin: A
12
13
  allowNonSegwitSigningWithoutPrevTx: boolean;
13
14
  pubs: string[] | undefined;
14
15
  cosignerPub: string | undefined;
15
- }): Promise<{
16
- txHex: string;
17
- }>;
16
+ }): Promise<utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt | Buffer>;
18
17
  //# sourceMappingURL=signTransaction.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/signTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,cAAc,EAAS,MAAM,uBAAuB,CAAC;AAE9D,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAIhD,OAAO,EAAE,gBAAgB,EAAE,kBAAkB,EAAkB,MAAM,wBAAwB,CAAC;AAY9F,wBAAsB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACnE,IAAI,EAAE,gBAAgB,EACtB,EAAE,EAAE,kBAAkB,CAAC,OAAO,CAAC,EAC/B,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,MAAM,EAAE;IACN,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,MAAM,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAA;KAAE,GAAG,SAAS,CAAC;IACpE,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,iBAAiB;IACjB,kCAAkC,EAAE,OAAO,CAAC;IAC5C,IAAI,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC3B,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,GACA,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAuF5B"}
1
+ {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/signTransaction.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAM7C,wBAAsB,eAAe,CACnC,CAAC,SAAS,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,EAE/G,IAAI,EAAE,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAChG,EAAE,EAAE,CAAC,EACL,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE;IACN,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,MAAM,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;KAAE,GAAG,SAAS,CAAC;IAC5E,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,iBAAiB;IACjB,kCAAkC,EAAE,OAAO,CAAC;IAC5C,IAAI,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC3B,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,GACA,OAAO,CACR,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAC/G,CAwCA"}
@@ -5,97 +5,46 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
6
  exports.signTransaction = signTransaction;
7
7
  const assert_1 = __importDefault(require("assert"));
8
+ const sdk_core_1 = require("@bitgo-beta/sdk-core");
8
9
  const lodash_1 = __importDefault(require("lodash"));
9
- const secp256k1_1 = require("@bitgo-beta/secp256k1");
10
10
  const utxo_lib_1 = require("@bitgo-beta/utxo-lib");
11
- const sdk_core_1 = require("@bitgo-beta/sdk-core");
12
- const sign_1 = require("../../sign");
13
- /**
14
- * Key Value: Unsigned tx id => PSBT
15
- * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
16
- * Reason: MuSig2 signer secure nonce is cached in the UtxoPsbt object. It will be required during the signing step.
17
- * For more info, check SignTransactionOptions.signingStep
18
- *
19
- * TODO BTC-276: This cache may need to be done with LRU like memory safe caching if memory issues comes up.
20
- */
21
- const PSBT_CACHE = new Map();
22
- async function signTransaction(coin, tx, signerKeychain, params) {
23
- const isTxWithKeyPathSpendInput = tx instanceof utxo_lib_1.bitgo.UtxoPsbt && utxo_lib_1.bitgo.isTransactionWithKeyPathSpendInput(tx);
11
+ const wasm_utxo_1 = require("@bitgo/wasm-utxo");
12
+ const signLegacyTransaction_1 = require("./signLegacyTransaction");
13
+ const signPsbt_1 = require("./signPsbt");
14
+ const signPsbtWasm_1 = require("./signPsbtWasm");
15
+ const replayProtection_1 = require("./replayProtection");
16
+ async function signTransaction(coin, tx, signerKeychain, network, params) {
24
17
  let isLastSignature = false;
25
18
  if (lodash_1.default.isBoolean(params.isLastSignature)) {
26
- // We can only be the first signature on a transaction with taproot key path spend inputs because
27
- // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
28
- // deserialized from a hex.
29
- if (params.isLastSignature && isTxWithKeyPathSpendInput) {
30
- throw new Error('Cannot be last signature on a transaction with key path spend inputs');
31
- }
32
19
  // if build is called instead of buildIncomplete, no signature placeholders are left in the sig script
33
20
  isLastSignature = params.isLastSignature;
34
21
  }
35
- if (tx instanceof utxo_lib_1.bitgo.UtxoPsbt && isTxWithKeyPathSpendInput) {
36
- switch (params.signingStep) {
37
- case 'signerNonce':
38
- (0, assert_1.default)(signerKeychain);
39
- tx.setAllInputsMusig2NonceHD(signerKeychain);
40
- PSBT_CACHE.set(tx.getUnsignedTx().getId(), tx);
41
- return { txHex: tx.toHex() };
42
- case 'cosignerNonce':
43
- (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
44
- return { txHex: (await coin.signPsbt(tx.toHex(), params.walletId)).psbt };
45
- case 'signerSignature':
46
- const txId = tx.getUnsignedTx().getId();
47
- const psbt = PSBT_CACHE.get(txId);
48
- (0, assert_1.default)(psbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE.size}).
49
- This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
50
- PSBT_CACHE.delete(txId);
51
- tx = psbt.combine(tx);
52
- break;
53
- default:
54
- // this instance is not an external signer
55
- (0, assert_1.default)(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
56
- (0, assert_1.default)(signerKeychain);
57
- tx.setAllInputsMusig2NonceHD(signerKeychain);
58
- const response = await coin.signPsbt(tx.toHex(), params.walletId);
59
- tx.combine(utxo_lib_1.bitgo.createPsbtFromHex(response.psbt, coin.network));
60
- break;
61
- }
62
- }
63
- else {
64
- switch (params.signingStep) {
65
- case 'signerNonce':
66
- case 'cosignerNonce':
67
- /**
68
- * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
69
- * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
70
- */
71
- return { txHex: tx.toHex() };
72
- }
73
- }
74
- let signedTransaction;
75
22
  if (tx instanceof utxo_lib_1.bitgo.UtxoPsbt) {
76
- (0, assert_1.default)(signerKeychain);
77
- signedTransaction = (0, sign_1.signAndVerifyPsbt)(tx, signerKeychain, {
23
+ return (0, signPsbt_1.signPsbtWithMusig2Participant)(coin, tx, signerKeychain, {
78
24
  isLastSignature,
25
+ signingStep: params.signingStep,
26
+ walletId: params.walletId,
79
27
  });
80
28
  }
81
- else {
82
- if (tx.ins.length !== params.txInfo?.unspents?.length) {
83
- throw new Error('length of unspents array should equal to the number of transaction inputs');
84
- }
85
- if (!params.pubs || !(0, sdk_core_1.isTriple)(params.pubs)) {
86
- throw new Error(`must provide xpub array`);
87
- }
88
- const keychains = params.pubs.map((pub) => secp256k1_1.bip32.fromBase58(pub));
89
- const cosignerPub = params.cosignerPub ?? params.pubs[2];
90
- const cosignerKeychain = secp256k1_1.bip32.fromBase58(cosignerPub);
91
- (0, assert_1.default)(signerKeychain);
92
- const walletSigner = new utxo_lib_1.bitgo.WalletUnspentSigner(keychains, signerKeychain, cosignerKeychain);
93
- signedTransaction = (0, sign_1.signAndVerifyWalletTransaction)(tx, params.txInfo.unspents, walletSigner, {
29
+ else if (tx instanceof wasm_utxo_1.fixedScriptWallet.BitGoPsbt) {
30
+ (0, assert_1.default)(params.pubs, 'pubs are required for fixed script signing');
31
+ (0, assert_1.default)((0, sdk_core_1.isTriple)(params.pubs), 'pubs must be a triple');
32
+ const rootWalletKeys = wasm_utxo_1.fixedScriptWallet.RootWalletKeys.fromXpubs(params.pubs);
33
+ return (0, signPsbtWasm_1.signPsbtWithMusig2ParticipantWasm)(coin, tx, signerKeychain, rootWalletKeys, {
34
+ replayProtection: {
35
+ publicKeys: (0, replayProtection_1.getReplayProtectionPubkeys)(network),
36
+ },
94
37
  isLastSignature,
38
+ signingStep: params.signingStep,
39
+ walletId: params.walletId,
95
40
  });
96
41
  }
97
- return {
98
- txHex: signedTransaction.toBuffer().toString('hex'),
99
- };
42
+ return (0, signLegacyTransaction_1.signLegacyTransaction)(tx, signerKeychain, {
43
+ isLastSignature,
44
+ signingStep: params.signingStep,
45
+ txInfo: params.txInfo,
46
+ pubs: params.pubs,
47
+ cosignerPub: params.cosignerPub,
48
+ });
100
49
  }
101
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signTransaction.js","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/signTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'assert';\n\nimport _ from 'lodash';\nimport { BIP32Interface, bip32 } from '@bitgo-beta/secp256k1';\nimport { bitgo } from '@bitgo-beta/utxo-lib';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { isTriple, Triple } from '@bitgo-beta/sdk-core';\n\nimport { signAndVerifyPsbt, signAndVerifyWalletTransaction } from '../../sign';\nimport { AbstractUtxoCoin, DecodedTransaction, RootWalletKeys } from '../../abstractUtxoCoin';\n\n/**\n * Key Value: Unsigned tx id => PSBT\n * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.\n * Reason: MuSig2 signer secure nonce is cached in the UtxoPsbt object. It will be required during the signing step.\n * For more info, check SignTransactionOptions.signingStep\n *\n * TODO BTC-276: This cache may need to be done with LRU like memory safe caching if memory issues comes up.\n */\nconst PSBT_CACHE = new Map<string, utxolib.bitgo.UtxoPsbt>();\n\nexport async function signTransaction<TNumber extends number | bigint>(\n  coin: AbstractUtxoCoin,\n  tx: DecodedTransaction<TNumber>,\n  signerKeychain: BIP32Interface | undefined,\n  params: {\n    walletId: string | undefined;\n    txInfo: { unspents?: utxolib.bitgo.Unspent<TNumber>[] } | undefined;\n    isLastSignature: boolean;\n    signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;\n    /** deprecated */\n    allowNonSegwitSigningWithoutPrevTx: boolean;\n    pubs: string[] | undefined;\n    cosignerPub: string | undefined;\n  }\n): Promise<{ txHex: string }> {\n  const isTxWithKeyPathSpendInput = tx instanceof bitgo.UtxoPsbt && bitgo.isTransactionWithKeyPathSpendInput(tx);\n\n  let isLastSignature = false;\n  if (_.isBoolean(params.isLastSignature)) {\n    // We can only be the first signature on a transaction with taproot key path spend inputs because\n    // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if\n    // deserialized from a hex.\n    if (params.isLastSignature && isTxWithKeyPathSpendInput) {\n      throw new Error('Cannot be last signature on a transaction with key path spend inputs');\n    }\n\n    // if build is called instead of buildIncomplete, no signature placeholders are left in the sig script\n    isLastSignature = params.isLastSignature;\n  }\n\n  if (tx instanceof bitgo.UtxoPsbt && isTxWithKeyPathSpendInput) {\n    switch (params.signingStep) {\n      case 'signerNonce':\n        assert(signerKeychain);\n        tx.setAllInputsMusig2NonceHD(signerKeychain);\n        PSBT_CACHE.set(tx.getUnsignedTx().getId(), tx);\n        return { txHex: tx.toHex() };\n      case 'cosignerNonce':\n        assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');\n        return { txHex: (await coin.signPsbt(tx.toHex(), params.walletId)).psbt };\n      case 'signerSignature':\n        const txId = tx.getUnsignedTx().getId();\n        const psbt = PSBT_CACHE.get(txId);\n        assert(\n          psbt,\n          `Psbt is missing from txCache (cache size ${PSBT_CACHE.size}).\n            This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`\n        );\n        PSBT_CACHE.delete(txId);\n        tx = psbt.combine(tx);\n        break;\n      default:\n        // this instance is not an external signer\n        assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');\n        assert(signerKeychain);\n        tx.setAllInputsMusig2NonceHD(signerKeychain);\n        const response = await coin.signPsbt(tx.toHex(), params.walletId);\n        tx.combine(bitgo.createPsbtFromHex(response.psbt, coin.network));\n        break;\n    }\n  } else {\n    switch (params.signingStep) {\n      case 'signerNonce':\n      case 'cosignerNonce':\n        /**\n         * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).\n         * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.\n         */\n        return { txHex: tx.toHex() };\n    }\n  }\n\n  let signedTransaction: bitgo.UtxoTransaction<bigint> | bitgo.UtxoPsbt;\n  if (tx instanceof bitgo.UtxoPsbt) {\n    assert(signerKeychain);\n    signedTransaction = signAndVerifyPsbt(tx, signerKeychain, {\n      isLastSignature,\n    });\n  } else {\n    if (tx.ins.length !== params.txInfo?.unspents?.length) {\n      throw new Error('length of unspents array should equal to the number of transaction inputs');\n    }\n\n    if (!params.pubs || !isTriple(params.pubs)) {\n      throw new Error(`must provide xpub array`);\n    }\n\n    const keychains = params.pubs.map((pub) => bip32.fromBase58(pub)) as Triple<BIP32Interface>;\n    const cosignerPub = params.cosignerPub ?? params.pubs[2];\n    const cosignerKeychain = bip32.fromBase58(cosignerPub);\n\n    assert(signerKeychain);\n    const walletSigner = new bitgo.WalletUnspentSigner<RootWalletKeys>(keychains, signerKeychain, cosignerKeychain);\n    signedTransaction = signAndVerifyWalletTransaction(tx, params.txInfo.unspents, walletSigner, {\n      isLastSignature,\n    }) as bitgo.UtxoTransaction<bigint>;\n  }\n\n  return {\n    txHex: signedTransaction.toBuffer().toString('hex'),\n  };\n}\n"]}
50
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7OztBQWVBLDBDQTJEQztBQTFFRCxvREFBNEI7QUFFNUIsbURBQWdEO0FBQ2hELG9EQUF1QjtBQUV2QixtREFBNkM7QUFFN0MsZ0RBQXFEO0FBR3JELG1FQUFnRTtBQUNoRSx5Q0FBMkQ7QUFDM0QsaURBQW1FO0FBQ25FLHlEQUFnRTtBQUV6RCxLQUFLLFVBQVUsZUFBZSxDQUduQyxJQUFnRyxFQUNoRyxFQUFLLEVBQ0wsY0FBMEMsRUFDMUMsT0FBd0IsRUFDeEIsTUFTQztJQUlELElBQUksZUFBZSxHQUFHLEtBQUssQ0FBQztJQUM1QixJQUFJLGdCQUFDLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxlQUFlLENBQUMsRUFBRSxDQUFDO1FBQ3hDLHNHQUFzRztRQUN0RyxlQUFlLEdBQUcsTUFBTSxDQUFDLGVBQWUsQ0FBQztJQUMzQyxDQUFDO0lBRUQsSUFBSSxFQUFFLFlBQVksZ0JBQUssQ0FBQyxRQUFRLEVBQUUsQ0FBQztRQUNqQyxPQUFPLElBQUEsd0NBQTZCLEVBQUMsSUFBaUQsRUFBRSxFQUFFLEVBQUUsY0FBYyxFQUFFO1lBQzFHLGVBQWU7WUFDZixXQUFXLEVBQUUsTUFBTSxDQUFDLFdBQVc7WUFDL0IsUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRO1NBQzFCLENBQUMsQ0FBQztJQUNMLENBQUM7U0FBTSxJQUFJLEVBQUUsWUFBWSw2QkFBaUIsQ0FBQyxTQUFTLEVBQUUsQ0FBQztRQUNyRCxJQUFBLGdCQUFNLEVBQUMsTUFBTSxDQUFDLElBQUksRUFBRSw0Q0FBNEMsQ0FBQyxDQUFDO1FBQ2xFLElBQUEsZ0JBQU0sRUFBQyxJQUFBLG1CQUFRLEVBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxFQUFFLHVCQUF1QixDQUFDLENBQUM7UUFDdkQsTUFBTSxjQUFjLEdBQUcsNkJBQWlCLENBQUMsY0FBYyxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUM7UUFDL0UsT0FBTyxJQUFBLGdEQUFpQyxFQUN0QyxJQUFzRCxFQUN0RCxFQUFFLEVBQ0YsY0FBYyxFQUNkLGNBQWMsRUFDZDtZQUNFLGdCQUFnQixFQUFFO2dCQUNoQixVQUFVLEVBQUUsSUFBQSw2Q0FBMEIsRUFBQyxPQUFPLENBQUM7YUFDaEQ7WUFDRCxlQUFlO1lBQ2YsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXO1lBQy9CLFFBQVEsRUFBRSxNQUFNLENBQUMsUUFBUTtTQUMxQixDQUNGLENBQUM7SUFDSixDQUFDO0lBRUQsT0FBTyxJQUFBLDZDQUFxQixFQUFDLEVBQUUsRUFBRSxjQUFjLEVBQUU7UUFDL0MsZUFBZTtRQUNmLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVztRQUMvQixNQUFNLEVBQUUsTUFBTSxDQUFDLE1BQU07UUFDckIsSUFBSSxFQUFFLE1BQU0sQ0FBQyxJQUFJO1FBQ2pCLFdBQVcsRUFBRSxNQUFNLENBQUMsV0FBVztLQUNoQyxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IGFzc2VydCBmcm9tICdhc3NlcnQnO1xuXG5pbXBvcnQgeyBpc1RyaXBsZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCBfIGZyb20gJ2xvZGFzaCc7XG5pbXBvcnQgeyBCSVAzMkludGVyZmFjZSB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgeyBiaXRnbyB9IGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgZml4ZWRTY3JpcHRXYWxsZXQgfSBmcm9tICdAYml0Z28vd2FzbS11dHhvJztcblxuaW1wb3J0IHsgTXVzaWcyUGFydGljaXBhbnQgfSBmcm9tICcuL211c2lnMic7XG5pbXBvcnQgeyBzaWduTGVnYWN5VHJhbnNhY3Rpb24gfSBmcm9tICcuL3NpZ25MZWdhY3lUcmFuc2FjdGlvbic7XG5pbXBvcnQgeyBzaWduUHNidFdpdGhNdXNpZzJQYXJ0aWNpcGFudCB9IGZyb20gJy4vc2lnblBzYnQnO1xuaW1wb3J0IHsgc2lnblBzYnRXaXRoTXVzaWcyUGFydGljaXBhbnRXYXNtIH0gZnJvbSAnLi9zaWduUHNidFdhc20nO1xuaW1wb3J0IHsgZ2V0UmVwbGF5UHJvdGVjdGlvblB1YmtleXMgfSBmcm9tICcuL3JlcGxheVByb3RlY3Rpb24nO1xuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gc2lnblRyYW5zYWN0aW9uPFxuICBUIGV4dGVuZHMgdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludCB8IG51bWJlcj4gfCBmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnRcbj4oXG4gIGNvaW46IE11c2lnMlBhcnRpY2lwYW50PHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+IHwgTXVzaWcyUGFydGljaXBhbnQ8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PixcbiAgdHg6IFQsXG4gIHNpZ25lcktleWNoYWluOiBCSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCxcbiAgbmV0d29yazogdXR4b2xpYi5OZXR3b3JrLFxuICBwYXJhbXM6IHtcbiAgICB3YWxsZXRJZDogc3RyaW5nIHwgdW5kZWZpbmVkO1xuICAgIHR4SW5mbzogeyB1bnNwZW50cz86IHV0eG9saWIuYml0Z28uVW5zcGVudDxiaWdpbnQgfCBudW1iZXI+W10gfSB8IHVuZGVmaW5lZDtcbiAgICBpc0xhc3RTaWduYXR1cmU6IGJvb2xlYW47XG4gICAgc2lnbmluZ1N0ZXA6ICdzaWduZXJOb25jZScgfCAnY29zaWduZXJOb25jZScgfCAnc2lnbmVyU2lnbmF0dXJlJyB8IHVuZGVmaW5lZDtcbiAgICAvKiogZGVwcmVjYXRlZCAqL1xuICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IGJvb2xlYW47XG4gICAgcHViczogc3RyaW5nW10gfCB1bmRlZmluZWQ7XG4gICAgY29zaWduZXJQdWI6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgfVxuKTogUHJvbWlzZTxcbiAgdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludCB8IG51bWJlcj4gfCBmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnQgfCBCdWZmZXJcbj4ge1xuICBsZXQgaXNMYXN0U2lnbmF0dXJlID0gZmFsc2U7XG4gIGlmIChfLmlzQm9vbGVhbihwYXJhbXMuaXNMYXN0U2lnbmF0dXJlKSkge1xuICAgIC8vIGlmIGJ1aWxkIGlzIGNhbGxlZCBpbnN0ZWFkIG9mIGJ1aWxkSW5jb21wbGV0ZSwgbm8gc2lnbmF0dXJlIHBsYWNlaG9sZGVycyBhcmUgbGVmdCBpbiB0aGUgc2lnIHNjcmlwdFxuICAgIGlzTGFzdFNpZ25hdHVyZSA9IHBhcmFtcy5pc0xhc3RTaWduYXR1cmU7XG4gIH1cblxuICBpZiAodHggaW5zdGFuY2VvZiBiaXRnby5VdHhvUHNidCkge1xuICAgIHJldHVybiBzaWduUHNidFdpdGhNdXNpZzJQYXJ0aWNpcGFudChjb2luIGFzIE11c2lnMlBhcnRpY2lwYW50PHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+LCB0eCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgIGlzTGFzdFNpZ25hdHVyZSxcbiAgICAgIHNpZ25pbmdTdGVwOiBwYXJhbXMuc2lnbmluZ1N0ZXAsXG4gICAgICB3YWxsZXRJZDogcGFyYW1zLndhbGxldElkLFxuICAgIH0pO1xuICB9IGVsc2UgaWYgKHR4IGluc3RhbmNlb2YgZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0KSB7XG4gICAgYXNzZXJ0KHBhcmFtcy5wdWJzLCAncHVicyBhcmUgcmVxdWlyZWQgZm9yIGZpeGVkIHNjcmlwdCBzaWduaW5nJyk7XG4gICAgYXNzZXJ0KGlzVHJpcGxlKHBhcmFtcy5wdWJzKSwgJ3B1YnMgbXVzdCBiZSBhIHRyaXBsZScpO1xuICAgIGNvbnN0IHJvb3RXYWxsZXRLZXlzID0gZml4ZWRTY3JpcHRXYWxsZXQuUm9vdFdhbGxldEtleXMuZnJvbVhwdWJzKHBhcmFtcy5wdWJzKTtcbiAgICByZXR1cm4gc2lnblBzYnRXaXRoTXVzaWcyUGFydGljaXBhbnRXYXNtKFxuICAgICAgY29pbiBhcyBNdXNpZzJQYXJ0aWNpcGFudDxmaXhlZFNjcmlwdFdhbGxldC5CaXRHb1BzYnQ+LFxuICAgICAgdHgsXG4gICAgICBzaWduZXJLZXljaGFpbixcbiAgICAgIHJvb3RXYWxsZXRLZXlzLFxuICAgICAge1xuICAgICAgICByZXBsYXlQcm90ZWN0aW9uOiB7XG4gICAgICAgICAgcHVibGljS2V5czogZ2V0UmVwbGF5UHJvdGVjdGlvblB1YmtleXMobmV0d29yayksXG4gICAgICAgIH0sXG4gICAgICAgIGlzTGFzdFNpZ25hdHVyZSxcbiAgICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgICAgd2FsbGV0SWQ6IHBhcmFtcy53YWxsZXRJZCxcbiAgICAgIH1cbiAgICApO1xuICB9XG5cbiAgcmV0dXJuIHNpZ25MZWdhY3lUcmFuc2FjdGlvbih0eCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICBpc0xhc3RTaWduYXR1cmUsXG4gICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICB0eEluZm86IHBhcmFtcy50eEluZm8sXG4gICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgY29zaWduZXJQdWI6IHBhcmFtcy5jb3NpZ25lclB1YixcbiAgfSk7XG59XG4iXX0=
@@ -1 +1 @@
1
- {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAyB,MAAM,sBAAsB,CAAC;AAGxE,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAsBpF;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,CAiJlB"}
1
+ {"version":3,"file":"verifyTransaction.d.ts","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"AAGA,OAAO,EAAE,SAAS,EAAoC,MAAM,sBAAsB,CAAC;AAGnF,OAAO,EAAE,gBAAgB,EAAE,wBAAwB,EAAE,MAAM,wBAAwB,CAAC;AAsBpF;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAsB,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACrE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,wBAAwB,CAAC,OAAO,CAAC,GACxC,OAAO,CAAC,OAAO,CAAC,CAmJlB"}
@@ -78,9 +78,10 @@ function getPayGoLimit(allowPaygoOutput) {
78
78
  */
79
79
  async function verifyTransaction(coin, bitgo, params) {
80
80
  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;
81
+ const txExplanation = await sdk_core_1.TxIntentMismatchError.tryGetTxExplanation(coin, txPrebuild);
81
82
  // Helper to throw TxIntentMismatchError with consistent context
82
83
  const throwTxMismatch = (message) => {
83
- throw new sdk_core_1.TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex);
84
+ throw new sdk_core_1.TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex, txExplanation);
84
85
  };
85
86
  if (!lodash_1.default.isUndefined(verification.disableNetworking) && !lodash_1.default.isBoolean(verification.disableNetworking)) {
86
87
  throw new TypeError('verification.disableNetworking must be a boolean');
@@ -195,4 +196,4 @@ async function verifyTransaction(coin, bitgo, params) {
195
196
  }
196
197
  return true;
197
198
  }
198
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verifyTransaction.js","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BitGoBase, TxIntentMismatchError } from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { AbstractUtxoCoin, VerifyTransactionOptions } from '../../abstractUtxoCoin';\nimport { Output, ParsedTransaction } from '../types';\nimport { verifyCustomChangeKeySignatures, verifyKeySignature, verifyUserPublicKey } from '../../verifyKey';\nimport { getPsbtTxInputs, getTxInputs } from '../fetchInputs';\n\nconst debug = buildDebug('bitgo:abstract-utxo:verifyTransaction');\n\n/**\n * Get the maximum percentage limit for pay-as-you-go outputs\n *\n * @protected\n */\nfunction getPayGoLimit(allowPaygoOutput?: boolean): number {\n  // allowing paygo outputs needs to be the default behavior, so only disallow paygo outputs if the\n  // relevant verification option is both set and false\n  if (!_.isNil(allowPaygoOutput) && !allowPaygoOutput) {\n    return 0;\n  }\n  // 150 basis points is the absolute permitted maximum if paygo outputs are allowed\n  return 0.015;\n}\n\n/**\n * Verify that a transaction prebuild complies with the original intention for fixed-script wallets\n *\n * This implementation handles transaction verification for traditional UTXO coins using fixed scripts\n * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.\n *\n * @param coin - The UTXO coin instance\n * @param bitgo - BitGo API instance for network calls\n * @param params - Verification parameters\n * @param params.txParams - Transaction parameters passed to send\n * @param params.txPrebuild - Prebuild object returned by server\n * @param params.wallet - Wallet object to obtain keys to verify against\n * @param params.verification - Verification options (disableNetworking, keychains, addresses)\n * @param params.reqId - Optional request ID for logging\n * @returns {boolean} True if verification passes\n * @throws {TxIntentMismatchError} if transaction validation fails\n */\nexport async function verifyTransaction<TNumber extends bigint | number>(\n  coin: AbstractUtxoCoin,\n  bitgo: BitGoBase,\n  params: VerifyTransactionOptions<TNumber>\n): Promise<boolean> {\n  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;\n\n  // Helper to throw TxIntentMismatchError with consistent context\n  const throwTxMismatch = (message: string): never => {\n    throw new TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex);\n  };\n\n  if (!_.isUndefined(verification.disableNetworking) && !_.isBoolean(verification.disableNetworking)) {\n    throw new TypeError('verification.disableNetworking must be a boolean');\n  }\n  const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);\n  if (isPsbt && txPrebuild.txInfo?.unspents) {\n    throw new Error('should not have unspents in txInfo for psbt');\n  }\n  const disableNetworking = !!verification.disableNetworking;\n  const parsedTransaction: ParsedTransaction<TNumber> = await coin.parseTransaction<TNumber>({\n    txParams,\n    txPrebuild,\n    wallet,\n    verification,\n    reqId,\n  });\n\n  const keychains = parsedTransaction.keychains;\n\n  // verify that the claimed user public key corresponds to the wallet's user private key\n  let userPublicKeyVerified = false;\n  try {\n    // verify the user public key matches the private key - this will throw if there is no match\n    userPublicKeyVerified = verifyUserPublicKey(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });\n  } catch (e) {\n    debug('failed to verify user public key!', e);\n  }\n\n  // let's verify these keychains\n  const keySignatures = parsedTransaction.keySignatures;\n  if (!_.isEmpty(keySignatures)) {\n    const verify = (key, pub) => {\n      if (!keychains.user || !keychains.user.pub) {\n        throwTxMismatch('missing user keychain');\n      }\n      return verifyKeySignature({\n        userKeychain: keychains.user as { pub: string },\n        keychainToVerify: key,\n        keySignature: pub,\n      });\n    };\n    const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);\n    const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);\n    if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {\n      throw new Error('secondary public key signatures invalid');\n    }\n    debug('successfully verified backup and bitgo key signatures');\n  } else if (!disableNetworking) {\n    // these keys were obtained online and their signatures were not verified\n    // this could be dangerous\n    console.log('unsigned keys obtained online are being used for address verification');\n  }\n\n  if (parsedTransaction.needsCustomChangeKeySignatureVerification) {\n    if (!keychains.user || !userPublicKeyVerified) {\n      throw new Error('transaction requires verification of user public key, but it was unable to be verified');\n    }\n    const customChangeKeySignaturesVerified = verifyCustomChangeKeySignatures(parsedTransaction, keychains.user);\n    if (!customChangeKeySignaturesVerified) {\n      throw new Error(\n        'transaction requires verification of custom change key signatures, but they were unable to be verified'\n      );\n    }\n    debug('successfully verified user public key and custom change key signatures');\n  }\n\n  const missingOutputs = parsedTransaction.missingOutputs;\n  if (missingOutputs.length !== 0) {\n    // there are some outputs in the recipients list that have not made it into the actual transaction\n    throwTxMismatch('expected outputs missing in transaction prebuild');\n  }\n\n  const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;\n\n  // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended\n  const payAsYouGoLimit = new BigNumber(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(\n    intendedExternalSpend.toString()\n  );\n\n  /*\n  Some explanation for why we're doing what we're doing:\n  Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for\n  it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a\n  threshold for the output's value above which we'll throw an error, because the paygo output should never be that\n  high.\n   */\n\n  // make sure that all the extra addresses are change addresses\n  // get all the additional external outputs the server added and calculate their values\n  const nonChangeAmount = new BigNumber(parsedTransaction.implicitExternalSpendAmount.toString());\n\n  debug(\n    'Intended spend is %s, Non-change amount is %s, paygo limit is %s',\n    intendedExternalSpend.toString(),\n    nonChangeAmount.toString(),\n    payAsYouGoLimit.toString()\n  );\n\n  // There are two instances where we will get into this point here\n  if (nonChangeAmount.gt(payAsYouGoLimit)) {\n    if (isPsbt && parsedTransaction.customChange) {\n      // In the case that we have a custom change address on a wallet and we are building the transaction\n      // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor\n      // can we fetch that information from the other wallet because we may not have the credentials. Therefore,\n      // we will not throw an error here, but we will log a warning.\n      debug(`cannot verify some of the addresses because it belongs to a separate wallet`);\n    } else {\n      // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address\n      // there are some addresses that are outside the scope of intended recipients that are not change addresses\n      throwTxMismatch('prebuild attempts to spend to unintended external recipients');\n    }\n  }\n\n  const allOutputs = parsedTransaction.outputs;\n  if (!txPrebuild.txHex) {\n    throw new Error(`txPrebuild.txHex not set`);\n  }\n  const inputs = isPsbt\n    ? getPsbtTxInputs(txPrebuild.txHex, coin.network).map((v) => ({\n        ...v,\n        value: utxolib.bitgo.toTNumber(v.value, coin.amountType),\n      }))\n    : await getTxInputs({ txPrebuild, bitgo, coin, disableNetworking, reqId });\n  // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field\n  const inputAmount = inputs.reduce(\n    (sum: bigint, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value),\n    BigInt(0)\n  );\n  const outputAmount = allOutputs.reduce((sum: bigint, o: Output) => sum + BigInt(o.amount), BigInt(0));\n  const fee = inputAmount - outputAmount;\n\n  if (fee < 0) {\n    throw new Error(\n      `attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`\n    );\n  }\n\n  return true;\n}\n"]}
199
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"verifyTransaction.js","sourceRoot":"","sources":["../../../../../src/transaction/fixedScript/verifyTransaction.ts"],"names":[],"mappings":"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","sourcesContent":["import buildDebug from 'debug';\nimport _ from 'lodash';\nimport BigNumber from 'bignumber.js';\nimport { BitGoBase, TxIntentMismatchError, IBaseCoin } from '@bitgo-beta/sdk-core';\nimport * as utxolib from '@bitgo-beta/utxo-lib';\n\nimport { AbstractUtxoCoin, VerifyTransactionOptions } from '../../abstractUtxoCoin';\nimport { Output, ParsedTransaction } from '../types';\nimport { verifyCustomChangeKeySignatures, verifyKeySignature, verifyUserPublicKey } from '../../verifyKey';\nimport { getPsbtTxInputs, getTxInputs } from '../fetchInputs';\n\nconst debug = buildDebug('bitgo:abstract-utxo:verifyTransaction');\n\n/**\n * Get the maximum percentage limit for pay-as-you-go outputs\n *\n * @protected\n */\nfunction getPayGoLimit(allowPaygoOutput?: boolean): number {\n  // allowing paygo outputs needs to be the default behavior, so only disallow paygo outputs if the\n  // relevant verification option is both set and false\n  if (!_.isNil(allowPaygoOutput) && !allowPaygoOutput) {\n    return 0;\n  }\n  // 150 basis points is the absolute permitted maximum if paygo outputs are allowed\n  return 0.015;\n}\n\n/**\n * Verify that a transaction prebuild complies with the original intention for fixed-script wallets\n *\n * This implementation handles transaction verification for traditional UTXO coins using fixed scripts\n * (non-descriptor wallets). It validates keychains, signatures, outputs, and amounts.\n *\n * @param coin - The UTXO coin instance\n * @param bitgo - BitGo API instance for network calls\n * @param params - Verification parameters\n * @param params.txParams - Transaction parameters passed to send\n * @param params.txPrebuild - Prebuild object returned by server\n * @param params.wallet - Wallet object to obtain keys to verify against\n * @param params.verification - Verification options (disableNetworking, keychains, addresses)\n * @param params.reqId - Optional request ID for logging\n * @returns {boolean} True if verification passes\n * @throws {TxIntentMismatchError} if transaction validation fails\n */\nexport async function verifyTransaction<TNumber extends bigint | number>(\n  coin: AbstractUtxoCoin,\n  bitgo: BitGoBase,\n  params: VerifyTransactionOptions<TNumber>\n): Promise<boolean> {\n  const { txParams, txPrebuild, wallet, verification = {}, reqId } = params;\n\n  const txExplanation = await TxIntentMismatchError.tryGetTxExplanation(coin as unknown as IBaseCoin, txPrebuild);\n\n  // Helper to throw TxIntentMismatchError with consistent context\n  const throwTxMismatch = (message: string): never => {\n    throw new TxIntentMismatchError(message, reqId, [txParams], txPrebuild.txHex, txExplanation);\n  };\n\n  if (!_.isUndefined(verification.disableNetworking) && !_.isBoolean(verification.disableNetworking)) {\n    throw new TypeError('verification.disableNetworking must be a boolean');\n  }\n  const isPsbt = txPrebuild.txHex && utxolib.bitgo.isPsbt(txPrebuild.txHex);\n  if (isPsbt && txPrebuild.txInfo?.unspents) {\n    throw new Error('should not have unspents in txInfo for psbt');\n  }\n  const disableNetworking = !!verification.disableNetworking;\n  const parsedTransaction: ParsedTransaction<TNumber> = await coin.parseTransaction<TNumber>({\n    txParams,\n    txPrebuild,\n    wallet,\n    verification,\n    reqId,\n  });\n\n  const keychains = parsedTransaction.keychains;\n\n  // verify that the claimed user public key corresponds to the wallet's user private key\n  let userPublicKeyVerified = false;\n  try {\n    // verify the user public key matches the private key - this will throw if there is no match\n    userPublicKeyVerified = verifyUserPublicKey(bitgo, { userKeychain: keychains.user, disableNetworking, txParams });\n  } catch (e) {\n    debug('failed to verify user public key!', e);\n  }\n\n  // let's verify these keychains\n  const keySignatures = parsedTransaction.keySignatures;\n  if (!_.isEmpty(keySignatures)) {\n    const verify = (key, pub) => {\n      if (!keychains.user || !keychains.user.pub) {\n        throwTxMismatch('missing user keychain');\n      }\n      return verifyKeySignature({\n        userKeychain: keychains.user as { pub: string },\n        keychainToVerify: key,\n        keySignature: pub,\n      });\n    };\n    const isBackupKeySignatureValid = verify(keychains.backup, keySignatures.backupPub);\n    const isBitgoKeySignatureValid = verify(keychains.bitgo, keySignatures.bitgoPub);\n    if (!isBackupKeySignatureValid || !isBitgoKeySignatureValid) {\n      throw new Error('secondary public key signatures invalid');\n    }\n    debug('successfully verified backup and bitgo key signatures');\n  } else if (!disableNetworking) {\n    // these keys were obtained online and their signatures were not verified\n    // this could be dangerous\n    console.log('unsigned keys obtained online are being used for address verification');\n  }\n\n  if (parsedTransaction.needsCustomChangeKeySignatureVerification) {\n    if (!keychains.user || !userPublicKeyVerified) {\n      throw new Error('transaction requires verification of user public key, but it was unable to be verified');\n    }\n    const customChangeKeySignaturesVerified = verifyCustomChangeKeySignatures(parsedTransaction, keychains.user);\n    if (!customChangeKeySignaturesVerified) {\n      throw new Error(\n        'transaction requires verification of custom change key signatures, but they were unable to be verified'\n      );\n    }\n    debug('successfully verified user public key and custom change key signatures');\n  }\n\n  const missingOutputs = parsedTransaction.missingOutputs;\n  if (missingOutputs.length !== 0) {\n    // there are some outputs in the recipients list that have not made it into the actual transaction\n    throwTxMismatch('expected outputs missing in transaction prebuild');\n  }\n\n  const intendedExternalSpend = parsedTransaction.explicitExternalSpendAmount;\n\n  // this is a limit we impose for the total value that is amended to the transaction beyond what was originally intended\n  const payAsYouGoLimit = new BigNumber(getPayGoLimit(verification.allowPaygoOutput)).multipliedBy(\n    intendedExternalSpend.toString()\n  );\n\n  /*\n  Some explanation for why we're doing what we're doing:\n  Some customers will have an output to BitGo's PAYGo wallet added to their transaction, and we need to account for\n  it here. To protect someone tampering with the output to make it send more than it should to BitGo, we define a\n  threshold for the output's value above which we'll throw an error, because the paygo output should never be that\n  high.\n   */\n\n  // make sure that all the extra addresses are change addresses\n  // get all the additional external outputs the server added and calculate their values\n  const nonChangeAmount = new BigNumber(parsedTransaction.implicitExternalSpendAmount.toString());\n\n  debug(\n    'Intended spend is %s, Non-change amount is %s, paygo limit is %s',\n    intendedExternalSpend.toString(),\n    nonChangeAmount.toString(),\n    payAsYouGoLimit.toString()\n  );\n\n  // There are two instances where we will get into this point here\n  if (nonChangeAmount.gt(payAsYouGoLimit)) {\n    if (isPsbt && parsedTransaction.customChange) {\n      // In the case that we have a custom change address on a wallet and we are building the transaction\n      // with a PSBT, we do not have the metadata to verify the address from the custom change wallet, nor\n      // can we fetch that information from the other wallet because we may not have the credentials. Therefore,\n      // we will not throw an error here, but we will log a warning.\n      debug(`cannot verify some of the addresses because it belongs to a separate wallet`);\n    } else {\n      // the additional external outputs can only be BitGo's pay-as-you-go fee, but we cannot verify the wallet address\n      // there are some addresses that are outside the scope of intended recipients that are not change addresses\n      throwTxMismatch('prebuild attempts to spend to unintended external recipients');\n    }\n  }\n\n  const allOutputs = parsedTransaction.outputs;\n  if (!txPrebuild.txHex) {\n    throw new Error(`txPrebuild.txHex not set`);\n  }\n  const inputs = isPsbt\n    ? getPsbtTxInputs(txPrebuild.txHex, coin.network).map((v) => ({\n        ...v,\n        value: utxolib.bitgo.toTNumber(v.value, coin.amountType),\n      }))\n    : await getTxInputs({ txPrebuild, bitgo, coin, disableNetworking, reqId });\n  // coins (doge) that can exceed number limits (and thus will use bigint) will have the `valueString` field\n  const inputAmount = inputs.reduce(\n    (sum: bigint, i) => sum + BigInt(coin.amountType === 'bigint' ? i.valueString : i.value),\n    BigInt(0)\n  );\n  const outputAmount = allOutputs.reduce((sum: bigint, o: Output) => sum + BigInt(o.amount), BigInt(0));\n  const fee = inputAmount - outputAmount;\n\n  if (fee < 0) {\n    throw new Error(\n      `attempting to spend ${outputAmount} satoshis, which exceeds the input amount (${inputAmount} satoshis) by ${-fee}`\n    );\n  }\n\n  return true;\n}\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/signTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAKjD,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAwB/E,wBAAsB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACnE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,sBAAsB,CAAC,OAAO,CAAC,GACtC,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CAyC5B"}
1
+ {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/signTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAKjD,OAAO,EAAE,gBAAgB,EAAE,sBAAsB,EAAE,MAAM,qBAAqB,CAAC;AAyB/E,wBAAsB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACnE,IAAI,EAAE,gBAAgB,EACtB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,sBAAsB,CAAC,OAAO,CAAC,GACtC,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAA;CAAE,CAAC,CA2C5B"}
@@ -45,6 +45,7 @@ const descriptor_1 = require("../descriptor");
45
45
  const keychains_1 = require("../keychains");
46
46
  const fixedScript = __importStar(require("./fixedScript"));
47
47
  const descriptor = __importStar(require("./descriptor"));
48
+ const decode_1 = require("./decode");
48
49
  const debug = (0, debug_1.default)('bitgo:abstract-utxo:transaction:signTransaction');
49
50
  function getSignerKeychain(userPrv) {
50
51
  if (userPrv === undefined) {
@@ -88,7 +89,7 @@ async function signTransaction(coin, bitgo, params) {
88
89
  }
89
90
  }
90
91
  else {
91
- return fixedScript.signTransaction(coin, tx, getSignerKeychain(params.prv), {
92
+ const signedTx = await fixedScript.signTransaction(coin, tx, getSignerKeychain(params.prv), coin.network, {
92
93
  walletId: params.txPrebuild.walletId,
93
94
  txInfo: params.txPrebuild.txInfo,
94
95
  isLastSignature: params.isLastSignature ?? false,
@@ -97,6 +98,8 @@ async function signTransaction(coin, bitgo, params) {
97
98
  pubs: params.pubs,
98
99
  cosignerPub: params.cosignerPub,
99
100
  });
101
+ const buffer = Buffer.isBuffer(signedTx) ? signedTx : (0, decode_1.encodeTransaction)(signedTx);
102
+ return { txHex: buffer.toString('hex') };
100
103
  }
101
104
  }
102
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQThCQSwwQ0E2Q0M7QUEzRUQsb0RBQXVCO0FBRXZCLDhEQUFnRDtBQUNoRCxxREFBOEM7QUFDOUMsa0RBQStCO0FBRy9CLDhDQUFnRztBQUNoRyw0Q0FBNkQ7QUFFN0QsMkRBQTZDO0FBQzdDLHlEQUEyQztBQUUzQyxNQUFNLEtBQUssR0FBRyxJQUFBLGVBQVUsRUFBQyxpREFBaUQsQ0FBQyxDQUFDO0FBRTVFLFNBQVMsaUJBQWlCLENBQUMsT0FBZ0I7SUFDekMsSUFBSSxPQUFPLEtBQUssU0FBUyxFQUFFLENBQUM7UUFDMUIsT0FBTyxTQUFTLENBQUM7SUFDbkIsQ0FBQztJQUNELElBQUksT0FBTyxPQUFPLEtBQUssUUFBUSxFQUFFLENBQUM7UUFDaEMsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsQ0FBQyxDQUFDO0lBQzlELENBQUM7SUFDRCxNQUFNLGNBQWMsR0FBRyxpQkFBSyxDQUFDLFVBQVUsQ0FBQyxPQUFPLEVBQUUsT0FBTyxDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUMzRSxJQUFJLGNBQWMsQ0FBQyxVQUFVLEVBQUUsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sSUFBSSxLQUFLLENBQUMsbURBQW1ELENBQUMsQ0FBQztJQUN2RSxDQUFDO0lBQ0QsS0FBSyxDQUFDLHdEQUF3RCxjQUFjLENBQUMsUUFBUSxFQUFFLENBQUMsUUFBUSxFQUFFLEVBQUUsQ0FBQyxDQUFDO0lBQ3RHLE9BQU8sY0FBYyxDQUFDO0FBQ3hCLENBQUM7QUFFTSxLQUFLLFVBQVUsZUFBZSxDQUNuQyxJQUFzQixFQUN0QixLQUFnQixFQUNoQixNQUF1QztJQUV2QyxNQUFNLFVBQVUsR0FBRyxNQUFNLENBQUMsVUFBVSxDQUFDO0lBRXJDLElBQUksZ0JBQUMsQ0FBQyxXQUFXLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBQyxDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsRUFBRSxDQUFDO1FBQ3pELElBQUksQ0FBQyxnQkFBQyxDQUFDLFdBQVcsQ0FBQyxVQUFVLENBQUMsSUFBSSxDQUFDLGdCQUFDLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxFQUFFLENBQUM7WUFDMUQsTUFBTSxJQUFJLEtBQUssQ0FBQywwQ0FBMEMsT0FBTyxVQUFVLEVBQUUsQ0FBQyxDQUFDO1FBQ2pGLENBQUM7UUFDRCxNQUFNLElBQUksS0FBSyxDQUFDLDhCQUE4QixDQUFDLENBQUM7SUFDbEQsQ0FBQztJQUVELE1BQU0sRUFBRSxHQUFHLElBQUksQ0FBQyw2QkFBNkIsQ0FBQyxNQUFNLENBQUMsVUFBVSxDQUFDLENBQUM7SUFFakUsTUFBTSxjQUFjLEdBQUcsaUJBQWlCLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBRXJELE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxNQUFNLENBQUM7SUFFMUIsSUFBSSxNQUFNLElBQUksSUFBQSwrQkFBa0IsRUFBQyxNQUFNLENBQUMsRUFBRSxDQUFDO1FBQ3pDLElBQUksQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUNwQixNQUFNLElBQUksS0FBSyxDQUFDLGdCQUFnQixDQUFDLENBQUM7UUFDcEMsQ0FBQztRQUNELE1BQU0sVUFBVSxHQUFHLElBQUEseUJBQWEsRUFBQyxNQUFNLElBQUEsMEJBQWMsRUFBQyxJQUFJLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQztRQUNyRSxNQUFNLGFBQWEsR0FBRyxJQUFBLHVDQUEwQixFQUFDLE1BQU0sRUFBRSxVQUFVLEVBQUUsSUFBQSw0QkFBZSxFQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1FBQ2pHLElBQUksRUFBRSxZQUFZLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUM7WUFDekMsVUFBVSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsYUFBYSxFQUFFLGNBQWMsRUFBRTtnQkFDckQsY0FBYyxFQUFFLE9BQU87YUFDeEIsQ0FBQyxDQUFDO1lBQ0gsT0FBTyxFQUFFLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxFQUFFLEVBQUUsQ0FBQztRQUMvQixDQUFDO2FBQU0sQ0FBQztZQUNOLE1BQU0sSUFBSSxLQUFLLENBQUMsNEJBQTRCLENBQUMsQ0FBQztRQUNoRCxDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDTixPQUFPLFdBQVcsQ0FBQyxlQUFlLENBQUMsSUFBSSxFQUFFLEVBQUUsRUFBRSxpQkFBaUIsQ0FBQyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUU7WUFDMUUsUUFBUSxFQUFFLE1BQU0sQ0FBQyxVQUFVLENBQUMsUUFBUTtZQUNwQyxNQUFNLEVBQUUsTUFBTSxDQUFDLFVBQVUsQ0FBQyxNQUFNO1lBQ2hDLGVBQWUsRUFBRSxNQUFNLENBQUMsZUFBZSxJQUFJLEtBQUs7WUFDaEQsV0FBVyxFQUFFLE1BQU0sQ0FBQyxXQUFXO1lBQy9CLGtDQUFrQyxFQUFFLE1BQU0sQ0FBQyxrQ0FBa0MsSUFBSSxLQUFLO1lBQ3RGLElBQUksRUFBRSxNQUFNLENBQUMsSUFBSTtZQUNqQixXQUFXLEVBQUUsTUFBTSxDQUFDLFdBQVc7U0FDaEMsQ0FBQyxDQUFDO0lBQ0wsQ0FBQztBQUNILENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgXyBmcm9tICdsb2Rhc2gnO1xuaW1wb3J0IHsgQml0R29CYXNlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBiaXAzMiB9IGZyb20gJ0BiaXRnby1iZXRhL3NlY3AyNTZrMSc7XG5pbXBvcnQgYnVpbGREZWJ1ZyBmcm9tICdkZWJ1Zyc7XG5cbmltcG9ydCB7IEFic3RyYWN0VXR4b0NvaW4sIFNpZ25UcmFuc2FjdGlvbk9wdGlvbnMgfSBmcm9tICcuLi9hYnN0cmFjdFV0eG9Db2luJztcbmltcG9ydCB7IGdldERlc2NyaXB0b3JNYXBGcm9tV2FsbGV0LCBnZXRQb2xpY3lGb3JFbnYsIGlzRGVzY3JpcHRvcldhbGxldCB9IGZyb20gJy4uL2Rlc2NyaXB0b3InO1xuaW1wb3J0IHsgZmV0Y2hLZXljaGFpbnMsIHRvQmlwMzJUcmlwbGUgfSBmcm9tICcuLi9rZXljaGFpbnMnO1xuXG5pbXBvcnQgKiBhcyBmaXhlZFNjcmlwdCBmcm9tICcuL2ZpeGVkU2NyaXB0JztcbmltcG9ydCAqIGFzIGRlc2NyaXB0b3IgZnJvbSAnLi9kZXNjcmlwdG9yJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnRyYW5zYWN0aW9uOnNpZ25UcmFuc2FjdGlvbicpO1xuXG5mdW5jdGlvbiBnZXRTaWduZXJLZXljaGFpbih1c2VyUHJ2OiB1bmtub3duKTogdXR4b2xpYi5CSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCB7XG4gIGlmICh1c2VyUHJ2ID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG4gIGlmICh0eXBlb2YgdXNlclBydiAhPT0gJ3N0cmluZycpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2V4cGVjdGVkIHVzZXIgcHJpdmF0ZSBrZXkgdG8gYmUgYSBzdHJpbmcnKTtcbiAgfVxuICBjb25zdCBzaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgodXNlclBydiwgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luKTtcbiAgaWYgKHNpZ25lcktleWNoYWluLmlzTmV1dGVyZWQoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgdXNlciBwcml2YXRlIGtleSBidXQgcmVjZWl2ZWQgcHVibGljIGtleScpO1xuICB9XG4gIGRlYnVnKGBIZXJlIGlzIHRoZSBwdWJsaWMga2V5IG9mIHRoZSB4cHJ2IHlvdSB1c2VkIHRvIHNpZ246ICR7c2lnbmVyS2V5Y2hhaW4ubmV1dGVyZWQoKS50b0Jhc2U1OCgpfWApO1xuICByZXR1cm4gc2lnbmVyS2V5Y2hhaW47XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIGJpdGdvOiBCaXRHb0Jhc2UsXG4gIHBhcmFtczogU2lnblRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTx7IHR4SGV4OiBzdHJpbmcgfT4ge1xuICBjb25zdCB0eFByZWJ1aWxkID0gcGFyYW1zLnR4UHJlYnVpbGQ7XG5cbiAgaWYgKF8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgfHwgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICBpZiAoIV8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgJiYgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdHhQcmVidWlsZCBtdXN0IGJlIGFuIG9iamVjdCwgZ290IHR5cGUgJHt0eXBlb2YgdHhQcmVidWlsZH1gKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHR4UHJlYnVpbGQgcGFyYW1ldGVyJyk7XG4gIH1cblxuICBjb25zdCB0eCA9IGNvaW4uZGVjb2RlVHJhbnNhY3Rpb25Gcm9tUHJlYnVpbGQocGFyYW1zLnR4UHJlYnVpbGQpO1xuXG4gIGNvbnN0IHNpZ25lcktleWNoYWluID0gZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydik7XG5cbiAgY29uc3QgeyB3YWxsZXQgfSA9IHBhcmFtcztcblxuICBpZiAod2FsbGV0ICYmIGlzRGVzY3JpcHRvcldhbGxldCh3YWxsZXQpKSB7XG4gICAgaWYgKCFzaWduZXJLZXljaGFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHNpZ25lcicpO1xuICAgIH1cbiAgICBjb25zdCB3YWxsZXRLZXlzID0gdG9CaXAzMlRyaXBsZShhd2FpdCBmZXRjaEtleWNoYWlucyhjb2luLCB3YWxsZXQpKTtcbiAgICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvck1hcEZyb21XYWxsZXQod2FsbGV0LCB3YWxsZXRLZXlzLCBnZXRQb2xpY3lGb3JFbnYoYml0Z28uZW52KSk7XG4gICAgaWYgKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkge1xuICAgICAgZGVzY3JpcHRvci5zaWduUHNidCh0eCwgZGVzY3JpcHRvck1hcCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgICAgb25Vbmtub3duSW5wdXQ6ICd0aHJvdycsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7IHR4SGV4OiB0eC50b0hleCgpIH07XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgYSBVdHhvUHNidCBvYmplY3QnKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgcmV0dXJuIGZpeGVkU2NyaXB0LnNpZ25UcmFuc2FjdGlvbihjb2luLCB0eCwgZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydiksIHtcbiAgICAgIHdhbGxldElkOiBwYXJhbXMudHhQcmVidWlsZC53YWxsZXRJZCxcbiAgICAgIHR4SW5mbzogcGFyYW1zLnR4UHJlYnVpbGQudHhJbmZvLFxuICAgICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlID8/IGZhbHNlLFxuICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IHBhcmFtcy5hbGxvd05vblNlZ3dpdFNpZ25pbmdXaXRob3V0UHJldlR4ID8/IGZhbHNlLFxuICAgICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgICBjb3NpZ25lclB1YjogcGFyYW1zLmNvc2lnbmVyUHViLFxuICAgIH0pO1xuICB9XG59XG4iXX0=
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL3NpZ25UcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQStCQSwwQ0ErQ0M7QUE5RUQsb0RBQXVCO0FBRXZCLDhEQUFnRDtBQUNoRCxxREFBOEM7QUFDOUMsa0RBQStCO0FBRy9CLDhDQUFnRztBQUNoRyw0Q0FBNkQ7QUFFN0QsMkRBQTZDO0FBQzdDLHlEQUEyQztBQUMzQyxxQ0FBNkM7QUFFN0MsTUFBTSxLQUFLLEdBQUcsSUFBQSxlQUFVLEVBQUMsaURBQWlELENBQUMsQ0FBQztBQUU1RSxTQUFTLGlCQUFpQixDQUFDLE9BQWdCO0lBQ3pDLElBQUksT0FBTyxLQUFLLFNBQVMsRUFBRSxDQUFDO1FBQzFCLE9BQU8sU0FBUyxDQUFDO0lBQ25CLENBQUM7SUFDRCxJQUFJLE9BQU8sT0FBTyxLQUFLLFFBQVEsRUFBRSxDQUFDO1FBQ2hDLE1BQU0sSUFBSSxLQUFLLENBQUMsMENBQTBDLENBQUMsQ0FBQztJQUM5RCxDQUFDO0lBQ0QsTUFBTSxjQUFjLEdBQUcsaUJBQUssQ0FBQyxVQUFVLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxRQUFRLENBQUMsT0FBTyxDQUFDLENBQUM7SUFDM0UsSUFBSSxjQUFjLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQztRQUNoQyxNQUFNLElBQUksS0FBSyxDQUFDLG1EQUFtRCxDQUFDLENBQUM7SUFDdkUsQ0FBQztJQUNELEtBQUssQ0FBQyx3REFBd0QsY0FBYyxDQUFDLFFBQVEsRUFBRSxDQUFDLFFBQVEsRUFBRSxFQUFFLENBQUMsQ0FBQztJQUN0RyxPQUFPLGNBQWMsQ0FBQztBQUN4QixDQUFDO0FBRU0sS0FBSyxVQUFVLGVBQWUsQ0FDbkMsSUFBc0IsRUFDdEIsS0FBZ0IsRUFDaEIsTUFBdUM7SUFFdkMs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dCB7IEJpdEdvQmFzZSB9IGZyb20gJ0BiaXRnby1iZXRhL3Nkay1jb3JlJztcbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgYmlwMzIgfSBmcm9tICdAYml0Z28tYmV0YS9zZWNwMjU2azEnO1xuaW1wb3J0IGJ1aWxkRGVidWcgZnJvbSAnZGVidWcnO1xuXG5pbXBvcnQgeyBBYnN0cmFjdFV0eG9Db2luLCBTaWduVHJhbnNhY3Rpb25PcHRpb25zIH0gZnJvbSAnLi4vYWJzdHJhY3RVdHhvQ29pbic7XG5pbXBvcnQgeyBnZXREZXNjcmlwdG9yTWFwRnJvbVdhbGxldCwgZ2V0UG9saWN5Rm9yRW52LCBpc0Rlc2NyaXB0b3JXYWxsZXQgfSBmcm9tICcuLi9kZXNjcmlwdG9yJztcbmltcG9ydCB7IGZldGNoS2V5Y2hhaW5zLCB0b0JpcDMyVHJpcGxlIH0gZnJvbSAnLi4va2V5Y2hhaW5zJztcblxuaW1wb3J0ICogYXMgZml4ZWRTY3JpcHQgZnJvbSAnLi9maXhlZFNjcmlwdCc7XG5pbXBvcnQgKiBhcyBkZXNjcmlwdG9yIGZyb20gJy4vZGVzY3JpcHRvcic7XG5pbXBvcnQgeyBlbmNvZGVUcmFuc2FjdGlvbiB9IGZyb20gJy4vZGVjb2RlJztcblxuY29uc3QgZGVidWcgPSBidWlsZERlYnVnKCdiaXRnbzphYnN0cmFjdC11dHhvOnRyYW5zYWN0aW9uOnNpZ25UcmFuc2FjdGlvbicpO1xuXG5mdW5jdGlvbiBnZXRTaWduZXJLZXljaGFpbih1c2VyUHJ2OiB1bmtub3duKTogdXR4b2xpYi5CSVAzMkludGVyZmFjZSB8IHVuZGVmaW5lZCB7XG4gIGlmICh1c2VyUHJ2ID09PSB1bmRlZmluZWQpIHtcbiAgICByZXR1cm4gdW5kZWZpbmVkO1xuICB9XG4gIGlmICh0eXBlb2YgdXNlclBydiAhPT0gJ3N0cmluZycpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2V4cGVjdGVkIHVzZXIgcHJpdmF0ZSBrZXkgdG8gYmUgYSBzdHJpbmcnKTtcbiAgfVxuICBjb25zdCBzaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgodXNlclBydiwgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luKTtcbiAgaWYgKHNpZ25lcktleWNoYWluLmlzTmV1dGVyZWQoKSkge1xuICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgdXNlciBwcml2YXRlIGtleSBidXQgcmVjZWl2ZWQgcHVibGljIGtleScpO1xuICB9XG4gIGRlYnVnKGBIZXJlIGlzIHRoZSBwdWJsaWMga2V5IG9mIHRoZSB4cHJ2IHlvdSB1c2VkIHRvIHNpZ246ICR7c2lnbmVyS2V5Y2hhaW4ubmV1dGVyZWQoKS50b0Jhc2U1OCgpfWApO1xuICByZXR1cm4gc2lnbmVyS2V5Y2hhaW47XG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4oXG4gIGNvaW46IEFic3RyYWN0VXR4b0NvaW4sXG4gIGJpdGdvOiBCaXRHb0Jhc2UsXG4gIHBhcmFtczogU2lnblRyYW5zYWN0aW9uT3B0aW9uczxUTnVtYmVyPlxuKTogUHJvbWlzZTx7IHR4SGV4OiBzdHJpbmcgfT4ge1xuICBjb25zdCB0eFByZWJ1aWxkID0gcGFyYW1zLnR4UHJlYnVpbGQ7XG5cbiAgaWYgKF8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgfHwgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICBpZiAoIV8uaXNVbmRlZmluZWQodHhQcmVidWlsZCkgJiYgIV8uaXNPYmplY3QodHhQcmVidWlsZCkpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdHhQcmVidWlsZCBtdXN0IGJlIGFuIG9iamVjdCwgZ290IHR5cGUgJHt0eXBlb2YgdHhQcmVidWlsZH1gKTtcbiAgICB9XG4gICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHR4UHJlYnVpbGQgcGFyYW1ldGVyJyk7XG4gIH1cblxuICBjb25zdCB0eCA9IGNvaW4uZGVjb2RlVHJhbnNhY3Rpb25Gcm9tUHJlYnVpbGQocGFyYW1zLnR4UHJlYnVpbGQpO1xuXG4gIGNvbnN0IHNpZ25lcktleWNoYWluID0gZ2V0U2lnbmVyS2V5Y2hhaW4ocGFyYW1zLnBydik7XG5cbiAgY29uc3QgeyB3YWxsZXQgfSA9IHBhcmFtcztcblxuICBpZiAod2FsbGV0ICYmIGlzRGVzY3JpcHRvcldhbGxldCh3YWxsZXQpKSB7XG4gICAgaWYgKCFzaWduZXJLZXljaGFpbikge1xuICAgICAgdGhyb3cgbmV3IEVycm9yKCdtaXNzaW5nIHNpZ25lcicpO1xuICAgIH1cbiAgICBjb25zdCB3YWxsZXRLZXlzID0gdG9CaXAzMlRyaXBsZShhd2FpdCBmZXRjaEtleWNoYWlucyhjb2luLCB3YWxsZXQpKTtcbiAgICBjb25zdCBkZXNjcmlwdG9yTWFwID0gZ2V0RGVzY3JpcHRvck1hcEZyb21XYWxsZXQod2FsbGV0LCB3YWxsZXRLZXlzLCBnZXRQb2xpY3lGb3JFbnYoYml0Z28uZW52KSk7XG4gICAgaWYgKHR4IGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvUHNidCkge1xuICAgICAgZGVzY3JpcHRvci5zaWduUHNidCh0eCwgZGVzY3JpcHRvck1hcCwgc2lnbmVyS2V5Y2hhaW4sIHtcbiAgICAgICAgb25Vbmtub3duSW5wdXQ6ICd0aHJvdycsXG4gICAgICB9KTtcbiAgICAgIHJldHVybiB7IHR4SGV4OiB0eC50b0hleCgpIH07XG4gICAgfSBlbHNlIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignZXhwZWN0ZWQgYSBVdHhvUHNidCBvYmplY3QnKTtcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgY29uc3Qgc2lnbmVkVHggPSBhd2FpdCBmaXhlZFNjcmlwdC5zaWduVHJhbnNhY3Rpb24oY29pbiwgdHgsIGdldFNpZ25lcktleWNoYWluKHBhcmFtcy5wcnYpLCBjb2luLm5ldHdvcmssIHtcbiAgICAgIHdhbGxldElkOiBwYXJhbXMudHhQcmVidWlsZC53YWxsZXRJZCxcbiAgICAgIHR4SW5mbzogcGFyYW1zLnR4UHJlYnVpbGQudHhJbmZvLFxuICAgICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlID8/IGZhbHNlLFxuICAgICAgc2lnbmluZ1N0ZXA6IHBhcmFtcy5zaWduaW5nU3RlcCxcbiAgICAgIGFsbG93Tm9uU2Vnd2l0U2lnbmluZ1dpdGhvdXRQcmV2VHg6IHBhcmFtcy5hbGxvd05vblNlZ3dpdFNpZ25pbmdXaXRob3V0UHJldlR4ID8/IGZhbHNlLFxuICAgICAgcHViczogcGFyYW1zLnB1YnMsXG4gICAgICBjb3NpZ25lclB1YjogcGFyYW1zLmNvc2lnbmVyUHViLFxuICAgIH0pO1xuICAgIGNvbnN0IGJ1ZmZlciA9IEJ1ZmZlci5pc0J1ZmZlcihzaWduZWRUeCkgPyBzaWduZWRUeCA6IGVuY29kZVRyYW5zYWN0aW9uKHNpZ25lZFR4KTtcbiAgICByZXR1cm4geyB0eEhleDogYnVmZmVyLnRvU3RyaW5nKCdoZXgnKSB9O1xuICB9XG59XG4iXX0=
@@ -1,5 +1,10 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import { fixedScriptWallet } from '@bitgo/wasm-utxo';
1
3
  import type { UtxoNamedKeychains } from '../keychains';
2
4
  import type { CustomChangeOptions } from './fixedScript';
5
+ export type SdkBackend = 'utxolib' | 'wasm-utxo';
6
+ export declare function isSdkBackend(backend: string): backend is SdkBackend;
7
+ export type DecodedTransaction<TNumber extends number | bigint> = utxolib.bitgo.UtxoTransaction<TNumber> | utxolib.bitgo.UtxoPsbt | fixedScriptWallet.BitGoPsbt;
3
8
  export interface BaseOutput<TAmount = string | number> {
4
9
  address: string;
5
10
  amount: TAmount;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/transaction/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAEvD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAEzD,MAAM,WAAW,UAAU,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM;IACnD,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,OAAO,CAAC;IAGhB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,uBAAuB,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,UAAU,CAAC,OAAO,CAAC;IAC7F,yCAAyC,CAAC,EAAE,OAAO,CAAC;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,MAAM,MAAM,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;AAEvG,MAAM,MAAM,4BAA4B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,OAAO,IAAI;IACnF,8BAA8B;IAC9B,OAAO,EAAE,OAAO,EAAE,CAAC;IACnB,iGAAiG;IACjG,cAAc,EAAE,OAAO,EAAE,CAAC;IAC1B,+FAA+F;IAC/F,uBAAuB,EAAE,OAAO,EAAE,CAAC;IACnC,mGAAmG;IACnG,uBAAuB,EAAE,OAAO,EAAE,CAAC;IACnC,kDAAkD;IAClD,aAAa,EAAE,OAAO,EAAE,CAAC;IACzB,2CAA2C;IAC3C,2BAA2B,EAAE,OAAO,CAAC;IACrC,2CAA2C;IAC3C,2BAA2B,EAAE,OAAO,CAAC;CACtC,CAAC;AAEF,MAAM,MAAM,qBAAqB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,OAAO,IAAI,4BAA4B,CACxG,OAAO,EACP,OAAO,CACR,CAAC,mFAAmF,GAAG;IACtF,SAAS,EAAE,kBAAkB,CAAC;IAC9B,aAAa,EAAE;QACb,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,yCAAyC,EAAE,OAAO,CAAC;IACnD,YAAY,CAAC,EAAE,mBAAmB,CAAC;CACpC,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,qBAAqB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/transaction/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,KAAK,EAAE,kBAAkB,EAAE,MAAM,cAAc,CAAC;AAEvD,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AAEzD,MAAM,MAAM,UAAU,GAAG,SAAS,GAAG,WAAW,CAAC;AAEjD,wBAAgB,YAAY,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,IAAI,UAAU,CAEnE;AAED,MAAM,MAAM,kBAAkB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,IAC1D,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,GACtC,OAAO,CAAC,KAAK,CAAC,QAAQ,GACtB,iBAAiB,CAAC,SAAS,CAAC;AAEhC,MAAM,WAAW,UAAU,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM;IACnD,OAAO,EAAE,MAAM,CAAC;IAChB,MAAM,EAAE,OAAO,CAAC;IAGhB,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB;AAED,MAAM,WAAW,uBAAuB,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,UAAU,CAAC,OAAO,CAAC;IAC7F,yCAAyC,CAAC,EAAE,OAAO,CAAC;IACpD,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,MAAM,MAAM,CAAC,OAAO,GAAG,MAAM,GAAG,MAAM,IAAI,UAAU,CAAC,OAAO,CAAC,GAAG,uBAAuB,CAAC,OAAO,CAAC,CAAC;AAEvG,MAAM,MAAM,4BAA4B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,OAAO,IAAI;IACnF,8BAA8B;IAC9B,OAAO,EAAE,OAAO,EAAE,CAAC;IACnB,iGAAiG;IACjG,cAAc,EAAE,OAAO,EAAE,CAAC;IAC1B,+FAA+F;IAC/F,uBAAuB,EAAE,OAAO,EAAE,CAAC;IACnC,mGAAmG;IACnG,uBAAuB,EAAE,OAAO,EAAE,CAAC;IACnC,kDAAkD;IAClD,aAAa,EAAE,OAAO,EAAE,CAAC;IACzB,2CAA2C;IAC3C,2BAA2B,EAAE,OAAO,CAAC;IACrC,2CAA2C;IAC3C,2BAA2B,EAAE,OAAO,CAAC;CACtC,CAAC;AAEF,MAAM,MAAM,qBAAqB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,OAAO,IAAI,4BAA4B,CACxG,OAAO,EACP,OAAO,CACR,CAAC,mFAAmF,GAAG;IACtF,SAAS,EAAE,kBAAkB,CAAC;IAC9B,aAAa,EAAE;QACb,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,QAAQ,CAAC,EAAE,MAAM,CAAC;KACnB,CAAC;IACF,yCAAyC,EAAE,OAAO,CAAC;IACnD,YAAY,CAAC,EAAE,mBAAmB,CAAC;CACpC,CAAC;AAEF;;;GAGG;AACH,MAAM,MAAM,iBAAiB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,qBAAqB,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC"}
@@ -1,3 +1,7 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgVXR4b05hbWVkS2V5Y2hhaW5zIH0gZnJvbSAnLi4va2V5Y2hhaW5zJztcblxuaW1wb3J0IHR5cGUgeyBDdXN0b21DaGFuZ2VPcHRpb25zIH0gZnJvbSAnLi9maXhlZFNjcmlwdCc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgQmFzZU91dHB1dDxUQW1vdW50ID0gc3RyaW5nIHwgbnVtYmVyPiB7XG4gIGFkZHJlc3M6IHN0cmluZztcbiAgYW1vdW50OiBUQW1vdW50O1xuICAvLyBFdmVuIHRob3VnaCB0aGlzIGV4dGVybmFsIGZsYWcgaXMgcmVkdW5kYW50IHdpdGggdGhlIGNoYWluIHByb3BlcnR5LCBpdCBpcyBuZWNlc3NhcnkgZm9yIGJhY2t3YXJkcyBjb21wYXRpYmlsaXR5XG4gIC8vIHdpdGggbGVnYWN5IHRyYW5zYWN0aW9uIGZvcm1hdC5cbiAgZXh0ZXJuYWw/OiBib29sZWFuO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIEZpeGVkU2NyaXB0V2FsbGV0T3V0cHV0PFRBbW91bnQgPSBzdHJpbmcgfCBudW1iZXI+IGV4dGVuZHMgQmFzZU91dHB1dDxUQW1vdW50PiB7XG4gIG5lZWRzQ3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlVmVyaWZpY2F0aW9uPzogYm9vbGVhbjtcbiAgY2hhaW46IG51bWJlcjtcbiAgaW5kZXg6IG51bWJlcjtcbn1cblxuZXhwb3J0IHR5cGUgT3V0cHV0PFRBbW91bnQgPSBzdHJpbmcgfCBudW1iZXI+ID0gQmFzZU91dHB1dDxUQW1vdW50PiB8IEZpeGVkU2NyaXB0V2FsbGV0T3V0cHV0PFRBbW91bnQ+O1xuXG5leHBvcnQgdHlwZSBCYXNlUGFyc2VkVHJhbnNhY3Rpb25PdXRwdXRzPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQsIFRPdXRwdXQ+ID0ge1xuICAvKiogYWxsIHRyYW5zYWN0aW9uIG91dHB1dHMgKi9cbiAgb3V0cHV0czogVE91dHB1dFtdO1xuICAvKiogdHJhbnNhY3Rpb24gb3V0cHV0cyB0aGF0IHdlcmUgc3BlY2lmaWVkIGFzIHJlY2lwaWVudHMgYnV0IGFyZSBtaXNzaW5nIGZyb20gdGhlIHRyYW5zYWN0aW9uICovXG4gIG1pc3NpbmdPdXRwdXRzOiBUT3V0cHV0W107XG4gIC8qKiB0cmFuc2FjdGlvbiBvdXRwdXRzIHRoYXQgd2VyZSBzcGVjaWZpZWQgYXMgcmVjaXBpZW50cyBhbmQgYXJlIHByZXNlbnQgaW4gdGhlIHRyYW5zYWN0aW9uICovXG4gIGV4cGxpY2l0RXh0ZXJuYWxPdXRwdXRzOiBUT3V0cHV0W107XG4gIC8qKiB0cmFuc2FjdGlvbiBvdXRwdXRzIHRoYXQgd2VyZSBub3Qgc3BlY2lmaWVkIGFzIHJlY2lwaWVudHMgYnV0IGFyZSBwcmVzZW50IGluIHRoZSB0cmFuc2FjdGlvbiAqL1xuICBpbXBsaWNpdEV4dGVybmFsT3V0cHV0czogVE91dHB1dFtdO1xuICAvKiogdHJhbnNhY3Rpb24gb3V0cHV0cyB0aGF0IGFyZSBjaGFuZ2Ugb3V0cHV0cyAqL1xuICBjaGFuZ2VPdXRwdXRzOiBUT3V0cHV0W107XG4gIC8qKiBzdW0gb2YgYWxsIGV4cGxpY2l0IGV4dGVybmFsIG91dHB1dHMgKi9cbiAgZXhwbGljaXRFeHRlcm5hbFNwZW5kQW1vdW50OiBUTnVtYmVyO1xuICAvKiogc3VtIG9mIGFsbCBpbXBsaWNpdCBleHRlcm5hbCBvdXRwdXRzICovXG4gIGltcGxpY2l0RXh0ZXJuYWxTcGVuZEFtb3VudDogVE51bWJlcjtcbn07XG5cbmV4cG9ydCB0eXBlIEJhc2VQYXJzZWRUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50LCBUT3V0cHV0PiA9IEJhc2VQYXJzZWRUcmFuc2FjdGlvbk91dHB1dHM8XG4gIFROdW1iZXIsXG4gIFRPdXRwdXRcbj4gLyoqIFNvbWUgZXh0cmEgcHJvcGVydGllcyB0aGF0IGhhdmUgbm90aGluZyB0byBkbyB3aXRoIGFuIGluZGl2aWR1YWwgdHJhbnNhY3Rpb24gKi8gJiB7XG4gIGtleWNoYWluczogVXR4b05hbWVkS2V5Y2hhaW5zO1xuICBrZXlTaWduYXR1cmVzOiB7XG4gICAgYmFja3VwUHViPzogc3RyaW5nO1xuICAgIGJpdGdvUHViPzogc3RyaW5nO1xuICB9O1xuICBuZWVkc0N1c3RvbUNoYW5nZUtleVNpZ25hdHVyZVZlcmlmaWNhdGlvbjogYm9vbGVhbjtcbiAgY3VzdG9tQ2hhbmdlPzogQ3VzdG9tQ2hhbmdlT3B0aW9ucztcbn07XG5cbi8qKlxuICogVGhpcyB0eXBlIGlzIGEgYml0IHNpbGx5IGJlY2F1c2UgaXQgYWxsb3dzIHRoZSB0eXBlIGZvciB0aGUgYWdncmVnYXRlIGFtb3VudHMgdG8gYmUgZGlmZmVyZW50IGZyb20gdGhlIHR5cGUgb2ZcbiAqIGluZGl2aWR1YWwgYW1vdW50cy5cbiAqL1xuZXhwb3J0IHR5cGUgUGFyc2VkVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludCA9IG51bWJlcj4gPSBCYXNlUGFyc2VkVHJhbnNhY3Rpb248VE51bWJlciwgT3V0cHV0PjtcbiJdfQ==
3
+ exports.isSdkBackend = isSdkBackend;
4
+ function isSdkBackend(backend) {
5
+ return backend === 'utxolib' || backend === 'wasm-utxo';
6
+ }
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7QUFTQSxvQ0FFQztBQUZELFNBQWdCLFlBQVksQ0FBQyxPQUFlO0lBQzFDLE9BQU8sT0FBTyxLQUFLLFNBQVMsSUFBSSxPQUFPLEtBQUssV0FBVyxDQUFDO0FBQzFELENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyB1dHhvbGliIGZyb20gJ0BiaXRnby1iZXRhL3V0eG8tbGliJztcbmltcG9ydCB7IGZpeGVkU2NyaXB0V2FsbGV0IH0gZnJvbSAnQGJpdGdvL3dhc20tdXR4byc7XG5cbmltcG9ydCB0eXBlIHsgVXR4b05hbWVkS2V5Y2hhaW5zIH0gZnJvbSAnLi4va2V5Y2hhaW5zJztcblxuaW1wb3J0IHR5cGUgeyBDdXN0b21DaGFuZ2VPcHRpb25zIH0gZnJvbSAnLi9maXhlZFNjcmlwdCc7XG5cbmV4cG9ydCB0eXBlIFNka0JhY2tlbmQgPSAndXR4b2xpYicgfCAnd2FzbS11dHhvJztcblxuZXhwb3J0IGZ1bmN0aW9uIGlzU2RrQmFja2VuZChiYWNrZW5kOiBzdHJpbmcpOiBiYWNrZW5kIGlzIFNka0JhY2tlbmQge1xuICByZXR1cm4gYmFja2VuZCA9PT0gJ3V0eG9saWInIHx8IGJhY2tlbmQgPT09ICd3YXNtLXV0eG8nO1xufVxuXG5leHBvcnQgdHlwZSBEZWNvZGVkVHJhbnNhY3Rpb248VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludD4gPVxuICB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+XG4gIHwgdXR4b2xpYi5iaXRnby5VdHhvUHNidFxuICB8IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidDtcblxuZXhwb3J0IGludGVyZmFjZSBCYXNlT3V0cHV0PFRBbW91bnQgPSBzdHJpbmcgfCBudW1iZXI+IHtcbiAgYWRkcmVzczogc3RyaW5nO1xuICBhbW91bnQ6IFRBbW91bnQ7XG4gIC8vIEV2ZW4gdGhvdWdoIHRoaXMgZXh0ZXJuYWwgZmxhZyBpcyByZWR1bmRhbnQgd2l0aCB0aGUgY2hhaW4gcHJvcGVydHksIGl0IGlzIG5lY2Vzc2FyeSBmb3IgYmFja3dhcmRzIGNvbXBhdGliaWxpdHlcbiAgLy8gd2l0aCBsZWdhY3kgdHJhbnNhY3Rpb24gZm9ybWF0LlxuICBleHRlcm5hbD86IGJvb2xlYW47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgRml4ZWRTY3JpcHRXYWxsZXRPdXRwdXQ8VEFtb3VudCA9IHN0cmluZyB8IG51bWJlcj4gZXh0ZW5kcyBCYXNlT3V0cHV0PFRBbW91bnQ+IHtcbiAgbmVlZHNDdXN0b21DaGFuZ2VLZXlTaWduYXR1cmVWZXJpZmljYXRpb24/OiBib29sZWFuO1xuICBjaGFpbjogbnVtYmVyO1xuICBpbmRleDogbnVtYmVyO1xufVxuXG5leHBvcnQgdHlwZSBPdXRwdXQ8VEFtb3VudCA9IHN0cmluZyB8IG51bWJlcj4gPSBCYXNlT3V0cHV0PFRBbW91bnQ+IHwgRml4ZWRTY3JpcHRXYWxsZXRPdXRwdXQ8VEFtb3VudD47XG5cbmV4cG9ydCB0eXBlIEJhc2VQYXJzZWRUcmFuc2FjdGlvbk91dHB1dHM8VE51bWJlciBleHRlbmRzIG51bWJlciB8IGJpZ2ludCwgVE91dHB1dD4gPSB7XG4gIC8qKiBhbGwgdHJhbnNhY3Rpb24gb3V0cHV0cyAqL1xuICBvdXRwdXRzOiBUT3V0cHV0W107XG4gIC8qKiB0cmFuc2FjdGlvbiBvdXRwdXRzIHRoYXQgd2VyZSBzcGVjaWZpZWQgYXMgcmVjaXBpZW50cyBidXQgYXJlIG1pc3NpbmcgZnJvbSB0aGUgdHJhbnNhY3Rpb24gKi9cbiAgbWlzc2luZ091dHB1dHM6IFRPdXRwdXRbXTtcbiAgLyoqIHRyYW5zYWN0aW9uIG91dHB1dHMgdGhhdCB3ZXJlIHNwZWNpZmllZCBhcyByZWNpcGllbnRzIGFuZCBhcmUgcHJlc2VudCBpbiB0aGUgdHJhbnNhY3Rpb24gKi9cbiAgZXhwbGljaXRFeHRlcm5hbE91dHB1dHM6IFRPdXRwdXRbXTtcbiAgLyoqIHRyYW5zYWN0aW9uIG91dHB1dHMgdGhhdCB3ZXJlIG5vdCBzcGVjaWZpZWQgYXMgcmVjaXBpZW50cyBidXQgYXJlIHByZXNlbnQgaW4gdGhlIHRyYW5zYWN0aW9uICovXG4gIGltcGxpY2l0RXh0ZXJuYWxPdXRwdXRzOiBUT3V0cHV0W107XG4gIC8qKiB0cmFuc2FjdGlvbiBvdXRwdXRzIHRoYXQgYXJlIGNoYW5nZSBvdXRwdXRzICovXG4gIGNoYW5nZU91dHB1dHM6IFRPdXRwdXRbXTtcbiAgLyoqIHN1bSBvZiBhbGwgZXhwbGljaXQgZXh0ZXJuYWwgb3V0cHV0cyAqL1xuICBleHBsaWNpdEV4dGVybmFsU3BlbmRBbW91bnQ6IFROdW1iZXI7XG4gIC8qKiBzdW0gb2YgYWxsIGltcGxpY2l0IGV4dGVybmFsIG91dHB1dHMgKi9cbiAgaW1wbGljaXRFeHRlcm5hbFNwZW5kQW1vdW50OiBUTnVtYmVyO1xufTtcblxuZXhwb3J0IHR5cGUgQmFzZVBhcnNlZFRyYW5zYWN0aW9uPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQsIFRPdXRwdXQ+ID0gQmFzZVBhcnNlZFRyYW5zYWN0aW9uT3V0cHV0czxcbiAgVE51bWJlcixcbiAgVE91dHB1dFxuPiAvKiogU29tZSBleHRyYSBwcm9wZXJ0aWVzIHRoYXQgaGF2ZSBub3RoaW5nIHRvIGRvIHdpdGggYW4gaW5kaXZpZHVhbCB0cmFuc2FjdGlvbiAqLyAmIHtcbiAga2V5Y2hhaW5zOiBVdHhvTmFtZWRLZXljaGFpbnM7XG4gIGtleVNpZ25hdHVyZXM6IHtcbiAgICBiYWNrdXBQdWI/OiBzdHJpbmc7XG4gICAgYml0Z29QdWI/OiBzdHJpbmc7XG4gIH07XG4gIG5lZWRzQ3VzdG9tQ2hhbmdlS2V5U2lnbmF0dXJlVmVyaWZpY2F0aW9uOiBib29sZWFuO1xuICBjdXN0b21DaGFuZ2U/OiBDdXN0b21DaGFuZ2VPcHRpb25zO1xufTtcblxuLyoqXG4gKiBUaGlzIHR5cGUgaXMgYSBiaXQgc2lsbHkgYmVjYXVzZSBpdCBhbGxvd3MgdGhlIHR5cGUgZm9yIHRoZSBhZ2dyZWdhdGUgYW1vdW50cyB0byBiZSBkaWZmZXJlbnQgZnJvbSB0aGUgdHlwZSBvZlxuICogaW5kaXZpZHVhbCBhbW91bnRzLlxuICovXG5leHBvcnQgdHlwZSBQYXJzZWRUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50ID0gbnVtYmVyPiA9IEJhc2VQYXJzZWRUcmFuc2FjdGlvbjxUTnVtYmVyLCBPdXRwdXQ+O1xuIl19