@bitgo-beta/utxo-lib 8.0.3-beta.9 → 8.0.3-beta.900

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 (217) hide show
  1. package/README.md +19 -16
  2. package/dist/src/address.d.ts +0 -1
  3. package/dist/src/address.d.ts.map +1 -1
  4. package/dist/src/address.js +10 -10
  5. package/dist/src/addressFormat.d.ts +1 -2
  6. package/dist/src/addressFormat.d.ts.map +1 -1
  7. package/dist/src/addressFormat.js +21 -26
  8. package/dist/src/bitgo/Musig2.d.ts +5 -11
  9. package/dist/src/bitgo/Musig2.d.ts.map +1 -1
  10. package/dist/src/bitgo/Musig2.js +63 -88
  11. package/dist/src/bitgo/PsbtUtil.d.ts +70 -0
  12. package/dist/src/bitgo/PsbtUtil.d.ts.map +1 -0
  13. package/dist/src/bitgo/PsbtUtil.js +132 -0
  14. package/dist/src/bitgo/Unspent.d.ts +2 -3
  15. package/dist/src/bitgo/Unspent.d.ts.map +1 -1
  16. package/dist/src/bitgo/Unspent.js +14 -15
  17. package/dist/src/bitgo/UtxoPsbt.d.ts +26 -40
  18. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -1
  19. package/dist/src/bitgo/UtxoPsbt.js +221 -206
  20. package/dist/src/bitgo/UtxoTransaction.d.ts +0 -1
  21. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -1
  22. package/dist/src/bitgo/UtxoTransaction.js +12 -12
  23. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +0 -1
  24. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -1
  25. package/dist/src/bitgo/UtxoTransactionBuilder.js +1 -1
  26. package/dist/src/bitgo/bitcoincash/address.d.ts +0 -1
  27. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -1
  28. package/dist/src/bitgo/bitcoincash/address.js +11 -12
  29. package/dist/src/bitgo/bitcoincash/index.js +6 -2
  30. package/dist/src/bitgo/dash/DashPsbt.d.ts +1 -1
  31. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -1
  32. package/dist/src/bitgo/dash/DashPsbt.js +4 -1
  33. package/dist/src/bitgo/dash/DashTransaction.d.ts +0 -1
  34. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -1
  35. package/dist/src/bitgo/dash/DashTransaction.js +3 -3
  36. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +0 -1
  37. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -1
  38. package/dist/src/bitgo/dash/DashTransactionBuilder.js +1 -1
  39. package/dist/src/bitgo/dash/index.js +6 -2
  40. package/dist/src/bitgo/index.d.ts +10 -0
  41. package/dist/src/bitgo/index.d.ts.map +1 -1
  42. package/dist/src/bitgo/index.js +10 -3
  43. package/dist/src/bitgo/keyutil.d.ts +9 -1
  44. package/dist/src/bitgo/keyutil.d.ts.map +1 -1
  45. package/dist/src/bitgo/keyutil.js +25 -4
  46. package/dist/src/bitgo/legacysafe/index.d.ts +14 -0
  47. package/dist/src/bitgo/legacysafe/index.d.ts.map +1 -0
  48. package/dist/src/bitgo/legacysafe/index.js +60 -0
  49. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts +1 -1
  50. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts.map +1 -1
  51. package/dist/src/bitgo/litecoin/LitecoinPsbt.js +4 -1
  52. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts +1 -2
  53. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts.map +1 -1
  54. package/dist/src/bitgo/litecoin/LitecoinTransaction.js +2 -2
  55. package/dist/src/bitgo/litecoin/index.js +6 -2
  56. package/dist/src/bitgo/nonStandardHalfSigned.js +2 -3
  57. package/dist/src/bitgo/outputScripts.d.ts +8 -8
  58. package/dist/src/bitgo/outputScripts.d.ts.map +1 -1
  59. package/dist/src/bitgo/outputScripts.js +56 -39
  60. package/dist/src/bitgo/parseInput.d.ts +7 -8
  61. package/dist/src/bitgo/parseInput.d.ts.map +1 -1
  62. package/dist/src/bitgo/parseInput.js +15 -16
  63. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +0 -1
  64. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -1
  65. package/dist/src/bitgo/psbt/fromHalfSigned.js +7 -8
  66. package/dist/src/bitgo/psbt/scriptTypes.d.ts +0 -1
  67. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -1
  68. package/dist/src/bitgo/psbt/scriptTypes.js +7 -8
  69. package/dist/src/bitgo/signature.d.ts +4 -5
  70. package/dist/src/bitgo/signature.d.ts.map +1 -1
  71. package/dist/src/bitgo/signature.js +32 -18
  72. package/dist/src/bitgo/tnumber.js +2 -3
  73. package/dist/src/bitgo/transaction.d.ts +31 -4
  74. package/dist/src/bitgo/transaction.d.ts.map +1 -1
  75. package/dist/src/bitgo/transaction.js +55 -27
  76. package/dist/src/bitgo/transactionAmounts.d.ts +9 -0
  77. package/dist/src/bitgo/transactionAmounts.d.ts.map +1 -0
  78. package/dist/src/bitgo/transactionAmounts.js +32 -0
  79. package/dist/src/bitgo/types.d.ts +8 -2
  80. package/dist/src/bitgo/types.d.ts.map +1 -1
  81. package/dist/src/bitgo/types.js +12 -4
  82. package/dist/src/bitgo/wallet/Psbt.d.ts +90 -27
  83. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -1
  84. package/dist/src/bitgo/wallet/Psbt.js +246 -108
  85. package/dist/src/bitgo/wallet/ScriptId.d.ts +14 -0
  86. package/dist/src/bitgo/wallet/ScriptId.d.ts.map +1 -0
  87. package/dist/src/bitgo/wallet/ScriptId.js +28 -0
  88. package/dist/src/bitgo/wallet/Unspent.d.ts +43 -10
  89. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -1
  90. package/dist/src/bitgo/wallet/Unspent.js +174 -81
  91. package/dist/src/bitgo/wallet/WalletKeys.d.ts +1 -2
  92. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -1
  93. package/dist/src/bitgo/wallet/WalletKeys.js +3 -3
  94. package/dist/src/bitgo/wallet/WalletOutput.d.ts +70 -2
  95. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -1
  96. package/dist/src/bitgo/wallet/WalletOutput.js +179 -43
  97. package/dist/src/bitgo/wallet/WalletScripts.js +4 -5
  98. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +7 -7
  99. package/dist/src/bitgo/wallet/chains.d.ts +2 -2
  100. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -1
  101. package/dist/src/bitgo/wallet/chains.js +10 -10
  102. package/dist/src/bitgo/wallet/index.d.ts +3 -0
  103. package/dist/src/bitgo/wallet/index.d.ts.map +1 -1
  104. package/dist/src/bitgo/wallet/index.js +9 -2
  105. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts +50 -0
  106. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts.map +1 -0
  107. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.js +85 -0
  108. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts +32 -0
  109. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts.map +1 -0
  110. package/dist/src/bitgo/wallet/psbt/RootNodes.js +123 -0
  111. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +1 -2
  112. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -1
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.js +15 -15
  114. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +1 -2
  115. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -1
  116. package/dist/src/bitgo/zcash/ZcashPsbt.js +15 -19
  117. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +3 -2
  118. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -1
  119. package/dist/src/bitgo/zcash/ZcashTransaction.js +31 -21
  120. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +0 -1
  121. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -1
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +6 -4
  123. package/dist/src/bitgo/zcash/address.d.ts +0 -1
  124. package/dist/src/bitgo/zcash/address.d.ts.map +1 -1
  125. package/dist/src/bitgo/zcash/address.js +7 -8
  126. package/dist/src/bitgo/zcash/hashZip0244.d.ts +1 -2
  127. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -1
  128. package/dist/src/bitgo/zcash/hashZip0244.js +9 -10
  129. package/dist/src/bitgo/zcash/index.js +6 -2
  130. package/dist/src/classify.d.ts +0 -1
  131. package/dist/src/classify.d.ts.map +1 -1
  132. package/dist/src/classify.js +5 -5
  133. package/dist/src/index.js +6 -2
  134. package/dist/src/networks.d.ts +2 -2
  135. package/dist/src/networks.d.ts.map +1 -1
  136. package/dist/src/networks.js +67 -21
  137. package/dist/src/noble_ecc.d.ts +7 -7
  138. package/dist/src/noble_ecc.d.ts.map +1 -1
  139. package/dist/src/noble_ecc.js +5 -5
  140. package/dist/src/payments/p2tr.js +13 -18
  141. package/dist/src/payments/p2tr_ns.js +3 -5
  142. package/dist/src/taproot.d.ts +1 -2
  143. package/dist/src/taproot.d.ts.map +1 -1
  144. package/dist/src/taproot.js +21 -22
  145. package/dist/src/templates/multisig/input.d.ts +0 -1
  146. package/dist/src/templates/multisig/input.d.ts.map +1 -1
  147. package/dist/src/templates/multisig/input.js +2 -3
  148. package/dist/src/templates/multisig/output.d.ts +0 -1
  149. package/dist/src/templates/multisig/output.d.ts.map +1 -1
  150. package/dist/src/templates/multisig/output.js +2 -3
  151. package/dist/src/templates/nulldata.d.ts +0 -1
  152. package/dist/src/templates/nulldata.d.ts.map +1 -1
  153. package/dist/src/templates/nulldata.js +3 -3
  154. package/dist/src/templates/pubkey/input.d.ts +0 -1
  155. package/dist/src/templates/pubkey/input.d.ts.map +1 -1
  156. package/dist/src/templates/pubkey/input.js +2 -3
  157. package/dist/src/templates/pubkey/output.d.ts +0 -1
  158. package/dist/src/templates/pubkey/output.d.ts.map +1 -1
  159. package/dist/src/templates/pubkey/output.js +2 -3
  160. package/dist/src/templates/pubkeyhash/input.d.ts +0 -1
  161. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -1
  162. package/dist/src/templates/pubkeyhash/input.js +2 -3
  163. package/dist/src/templates/pubkeyhash/output.d.ts +0 -1
  164. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -1
  165. package/dist/src/templates/pubkeyhash/output.js +2 -3
  166. package/dist/src/templates/scripthash/input.d.ts +0 -1
  167. package/dist/src/templates/scripthash/input.d.ts.map +1 -1
  168. package/dist/src/templates/scripthash/input.js +2 -3
  169. package/dist/src/templates/scripthash/output.d.ts +0 -1
  170. package/dist/src/templates/scripthash/output.d.ts.map +1 -1
  171. package/dist/src/templates/scripthash/output.js +2 -3
  172. package/dist/src/templates/taproot/input.d.ts +0 -1
  173. package/dist/src/templates/taproot/input.d.ts.map +1 -1
  174. package/dist/src/templates/taproot/input.js +2 -3
  175. package/dist/src/templates/taproot/output.d.ts +0 -1
  176. package/dist/src/templates/taproot/output.d.ts.map +1 -1
  177. package/dist/src/templates/taproot/output.js +2 -3
  178. package/dist/src/templates/taprootnofn/input.d.ts +0 -1
  179. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -1
  180. package/dist/src/templates/taprootnofn/input.js +2 -3
  181. package/dist/src/templates/taprootnofn/output.d.ts +0 -1
  182. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -1
  183. package/dist/src/templates/taprootnofn/output.js +2 -3
  184. package/dist/src/templates/witnesscommitment/output.d.ts +0 -1
  185. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -1
  186. package/dist/src/templates/witnesscommitment/output.js +4 -5
  187. package/dist/src/templates/witnesspubkeyhash/input.d.ts +0 -1
  188. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -1
  189. package/dist/src/templates/witnesspubkeyhash/input.js +2 -3
  190. package/dist/src/templates/witnesspubkeyhash/output.d.ts +0 -1
  191. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -1
  192. package/dist/src/templates/witnesspubkeyhash/output.js +2 -3
  193. package/dist/src/templates/witnessscripthash/input.d.ts +0 -1
  194. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -1
  195. package/dist/src/templates/witnessscripthash/input.js +2 -3
  196. package/dist/src/templates/witnessscripthash/output.d.ts +0 -1
  197. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -1
  198. package/dist/src/templates/witnessscripthash/output.js +2 -3
  199. package/dist/src/testutil/index.d.ts +1 -0
  200. package/dist/src/testutil/index.d.ts.map +1 -1
  201. package/dist/src/testutil/index.js +7 -2
  202. package/dist/src/testutil/keys.d.ts +6 -3
  203. package/dist/src/testutil/keys.d.ts.map +1 -1
  204. package/dist/src/testutil/keys.js +24 -10
  205. package/dist/src/testutil/mock.d.ts +2 -3
  206. package/dist/src/testutil/mock.d.ts.map +1 -1
  207. package/dist/src/testutil/mock.js +31 -23
  208. package/dist/src/testutil/psbt.d.ts +40 -16
  209. package/dist/src/testutil/psbt.d.ts.map +1 -1
  210. package/dist/src/testutil/psbt.js +54 -39
  211. package/dist/src/testutil/transaction.d.ts +18 -7
  212. package/dist/src/testutil/transaction.d.ts.map +1 -1
  213. package/dist/src/testutil/transaction.js +33 -26
  214. package/dist/src/transaction_builder.d.ts +0 -1
  215. package/dist/src/transaction_builder.d.ts.map +1 -1
  216. package/dist/src/transaction_builder.js +13 -18
  217. package/package.json +10 -12
@@ -0,0 +1,14 @@
1
+ import { ChainCode } from './chains';
2
+ export type ScriptId = {
3
+ chain: ChainCode;
4
+ index: number;
5
+ };
6
+ /**
7
+ * Get the chain and index from a bip32 path.
8
+ *
9
+ * @param path
10
+ */
11
+ export declare function getScriptIdFromPath(path: string): ScriptId;
12
+ /** @deprecated use getScriptId */
13
+ export declare const getChainAndIndexFromPath: typeof getScriptIdFromPath;
14
+ //# sourceMappingURL=ScriptId.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScriptId.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/ScriptId.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAe,MAAM,UAAU,CAAC;AAElD,MAAM,MAAM,QAAQ,GAAG;IACrB,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;CACf,CAAC;AAEF;;;;GAIG;AACH,wBAAgB,mBAAmB,CAAC,IAAI,EAAE,MAAM,GAAG,QAAQ,CAe1D;AAED,kCAAkC;AAClC,eAAO,MAAM,wBAAwB,4BAAsB,CAAC"}
@@ -0,0 +1,28 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.getChainAndIndexFromPath = void 0;
4
+ exports.getScriptIdFromPath = getScriptIdFromPath;
5
+ const chains_1 = require("./chains");
6
+ /**
7
+ * Get the chain and index from a bip32 path.
8
+ *
9
+ * @param path
10
+ */
11
+ function getScriptIdFromPath(path) {
12
+ const parts = path.split('/');
13
+ if (parts.length <= 2) {
14
+ throw new Error(`invalid path "${path}"`);
15
+ }
16
+ const chain = Number(parts[parts.length - 2]);
17
+ const index = Number(parts[parts.length - 1]);
18
+ if (!(0, chains_1.isChainCode)(chain)) {
19
+ throw new Error(`invalid chain "${chain}"`);
20
+ }
21
+ if (!Number.isInteger(index) || index < 0) {
22
+ throw new Error(`invalid index "${index}"`);
23
+ }
24
+ return { chain, index };
25
+ }
26
+ /** @deprecated use getScriptId */
27
+ exports.getChainAndIndexFromPath = getScriptIdFromPath;
28
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiU2NyaXB0SWQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvYml0Z28vd2FsbGV0L1NjcmlwdElkLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7OztBQVlBLGtEQWVDO0FBM0JELHFDQUFrRDtBQU9sRDs7OztHQUlHO0FBQ0gsU0FBZ0IsbUJBQW1CLENBQUMsSUFBWTtJQUM5QyxNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLEdBQUcsQ0FBQyxDQUFDO0lBQzlCLElBQUksS0FBSyxDQUFDLE1BQU0sSUFBSSxDQUFDLEVBQUUsQ0FBQztRQUN0QixNQUFNLElBQUksS0FBSyxDQUFDLGlCQUFpQixJQUFJLEdBQUcsQ0FBQyxDQUFDO0lBQzVDLENBQUM7SUFDRCxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5QyxNQUFNLEtBQUssR0FBRyxNQUFNLENBQUMsS0FBSyxDQUFDLEtBQUssQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQztJQUM5QyxJQUFJLENBQUMsSUFBQSxvQkFBVyxFQUFDLEtBQUssQ0FBQyxFQUFFLENBQUM7UUFDeEIsTUFBTSxJQUFJLEtBQUssQ0FBQyxrQkFBa0IsS0FBSyxHQUFHLENBQUMsQ0FBQztJQUM5QyxDQUFDO0lBQ0QsSUFBSSxDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLElBQUksS0FBSyxHQUFHLENBQUMsRUFBRSxDQUFDO1FBQzFDLE1BQU0sSUFBSSxLQUFLLENBQUMsa0JBQWtCLEtBQUssR0FBRyxDQUFDLENBQUM7SUFDOUMsQ0FBQztJQUVELE9BQU8sRUFBRSxLQUFLLEVBQUUsS0FBSyxFQUFFLENBQUM7QUFDMUIsQ0FBQztBQUVELGtDQUFrQztBQUNyQixRQUFBLHdCQUF3QixHQUFHLG1CQUFtQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ2hhaW5Db2RlLCBpc0NoYWluQ29kZSB9IGZyb20gJy4vY2hhaW5zJztcblxuZXhwb3J0IHR5cGUgU2NyaXB0SWQgPSB7XG4gIGNoYWluOiBDaGFpbkNvZGU7XG4gIGluZGV4OiBudW1iZXI7XG59O1xuXG4vKipcbiAqIEdldCB0aGUgY2hhaW4gYW5kIGluZGV4IGZyb20gYSBiaXAzMiBwYXRoLlxuICpcbiAqIEBwYXJhbSBwYXRoXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRTY3JpcHRJZEZyb21QYXRoKHBhdGg6IHN0cmluZyk6IFNjcmlwdElkIHtcbiAgY29uc3QgcGFydHMgPSBwYXRoLnNwbGl0KCcvJyk7XG4gIGlmIChwYXJ0cy5sZW5ndGggPD0gMikge1xuICAgIHRocm93IG5ldyBFcnJvcihgaW52YWxpZCBwYXRoIFwiJHtwYXRofVwiYCk7XG4gIH1cbiAgY29uc3QgY2hhaW4gPSBOdW1iZXIocGFydHNbcGFydHMubGVuZ3RoIC0gMl0pO1xuICBjb25zdCBpbmRleCA9IE51bWJlcihwYXJ0c1twYXJ0cy5sZW5ndGggLSAxXSk7XG4gIGlmICghaXNDaGFpbkNvZGUoY2hhaW4pKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIGNoYWluIFwiJHtjaGFpbn1cImApO1xuICB9XG4gIGlmICghTnVtYmVyLmlzSW50ZWdlcihpbmRleCkgfHwgaW5kZXggPCAwKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKGBpbnZhbGlkIGluZGV4IFwiJHtpbmRleH1cImApO1xuICB9XG5cbiAgcmV0dXJuIHsgY2hhaW4sIGluZGV4IH07XG59XG5cbi8qKiBAZGVwcmVjYXRlZCB1c2UgZ2V0U2NyaXB0SWQgKi9cbmV4cG9ydCBjb25zdCBnZXRDaGFpbkFuZEluZGV4RnJvbVBhdGggPSBnZXRTY3JpcHRJZEZyb21QYXRoO1xuIl19
@@ -1,5 +1,3 @@
1
- /// <reference types="node" />
2
- import { Network } from '../..';
3
1
  import { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';
4
2
  import { WalletUnspentSigner } from './WalletUnspentSigner';
5
3
  import { KeyName, RootWalletKeys } from './WalletKeys';
@@ -8,11 +6,15 @@ import { Triple } from '../types';
8
6
  import { UnspentWithPrevTx, Unspent } from '../Unspent';
9
7
  import { ChainCode } from './chains';
10
8
  import { UtxoPsbt } from '../UtxoPsbt';
9
+ /** Final (non-replaceable) */
10
+ export declare const TX_INPUT_SEQUENCE_NUMBER_FINAL = 4294967295;
11
+ /** Non-Final (Replaceable)
12
+ * Reference: https://github.com/bitcoin/bitcoin/blob/v25.1/src/rpc/rawtransaction_util.cpp#L49
13
+ * */
14
+ export declare const MAX_BIP125_RBF_SEQUENCE: number;
11
15
  export interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {
12
16
  chain: ChainCode;
13
17
  index: number;
14
- witnessScript?: string;
15
- valueString?: string;
16
18
  }
17
19
  export interface NonWitnessWalletUnspent<TNumber extends number | bigint = number> extends UnspentWithPrevTx<TNumber>, WalletUnspent<TNumber> {
18
20
  }
@@ -36,14 +38,45 @@ export interface WalletUnspentLegacy<TNumber extends number | bigint = number> e
36
38
  /** @deprecated - obviated by verifyWithUnspent */
37
39
  witnessScript?: string;
38
40
  }
39
- export declare function addReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, u: Unspent<bigint>, redeemScript: Buffer,
40
41
  /**
41
- * @deprecated
42
+ * @param psbt
43
+ * @param inputIndex
44
+ * @param id Unspent ID
45
+ * @returns true iff the unspent ID on the unspent and psbt input match
42
46
  */
43
- network?: Network): void;
44
- export declare function addWalletUnspentToPsbt(psbt: UtxoPsbt, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName,
47
+ export declare function psbtIncludesUnspentAtIndex(psbt: UtxoPsbt, inputIndex: number, id: string): boolean;
45
48
  /**
46
- * @deprecated
49
+ * Update the psbt input at the given index
50
+ * @param psbt
51
+ * @param inputIndex
52
+ * @param u
53
+ * @param redeemScript Only overrides if there is no redeemScript in the input currently
54
+ */
55
+ export declare function updateReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, inputIndex: number, u: Unspent<bigint>, redeemScript?: Buffer, customParams?: {
56
+ skipNonWitnessUtxo?: boolean;
57
+ }): void;
58
+ export declare function addReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, u: Unspent<bigint>, redeemScript: Buffer, customParams?: {
59
+ skipNonWitnessUtxo?: boolean;
60
+ }): void;
61
+ /**
62
+ * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
63
+ *
64
+ * If skipNonWitnessUtxo is true, then the nonWitnessUtxo will not be added for an input that requires it (e.g. non-segwit)
65
+ * and instead the witnessUtxo will be added
66
+ *
67
+ * @param psbt
68
+ * @param inputIndex
69
+ * @param u
70
+ * @param rootWalletKeys
71
+ * @param signer
72
+ * @param cosigner
73
+ * @param customParams
47
74
  */
48
- network?: Network): void;
75
+ export declare function updateWalletUnspentForPsbt(psbt: UtxoPsbt, inputIndex: number, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName, customParams?: {
76
+ skipNonWitnessUtxo?: boolean;
77
+ }): void;
78
+ export declare function addWalletUnspentToPsbt(psbt: UtxoPsbt, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName, customParams?: {
79
+ isReplaceableByFee?: boolean;
80
+ skipNonWitnessUtxo?: boolean;
81
+ }): void;
49
82
  //# sourceMappingURL=Unspent.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Unspent.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":";AAAA,OAAO,EAAc,OAAO,EAAY,MAAM,OAAO,CAAC;AACtD,OAAO,EAAE,sBAAsB,EAAE,MAAM,2BAA2B,CAAC;AAWnE,OAAO,EAAE,mBAAmB,EAAE,MAAM,uBAAuB,CAAC;AAC5D,OAAO,EAAE,OAAO,EAAE,cAAc,EAAE,MAAM,cAAc,CAAC;AACvD,OAAO,EAAE,eAAe,EAAE,MAAM,oBAAoB,CAAC;AACrD,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAY,iBAAiB,EAAE,OAAO,EAAqC,MAAM,YAAY,CAAC;AACrG,OAAO,EAAE,SAAS,EAAY,MAAM,UAAU,CAAC;AAC/C,OAAO,EAAE,QAAQ,EAAE,MAAM,aAAa,CAAC;AAKvC,MAAM,WAAW,aAAa,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,OAAO,CAAC,OAAO,CAAC;IAC/F,KAAK,EAAE,SAAS,CAAC;IACjB,KAAK,EAAE,MAAM,CAAC;IACd,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,MAAM,WAAW,uBAAuB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAC/E,SAAQ,iBAAiB,CAAC,OAAO,CAAC,EAChC,aAAa,CAAC,OAAO,CAAC;CAAG;AAE7B,wBAAgB,eAAe,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAAE,CAAC,EAAE,OAAO,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,aAAa,CAAC,OAAO,CAAC,CAEjH;AAED,wBAAgB,oBAAoB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAClE,SAAS,EAAE,sBAAsB,CAAC,OAAO,CAAC,EAC1C,UAAU,EAAE,MAAM,EAClB,OAAO,EAAE,aAAa,CAAC,OAAO,CAAC,EAC/B,aAAa,EAAE,mBAAmB,CAAC,cAAc,CAAC,GACjD,IAAI,CAmBN;AAED;;;;;;GAMG;AACH,wBAAgB,0BAA0B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACxE,EAAE,EAAE,eAAe,CAAC,OAAO,CAAC,EAC5B,UAAU,EAAE,MAAM,EAClB,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,EAC5B,UAAU,EAAE,cAAc,GACzB,MAAM,CAAC,OAAO,CAAC,CAiCjB;AAED;;;GAGG;AACH,MAAM,WAAW,mBAAmB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,CAAE,SAAQ,aAAa,CAAC,OAAO,CAAC;IAC3G,gDAAgD;IAChD,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,kDAAkD;IAClD,aAAa,CAAC,EAAE,MAAM,CAAC;CACxB;AAED,wBAAgB,gCAAgC,CAC9C,IAAI,EAAE,QAAQ,EACd,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,EAClB,YAAY,EAAE,MAAM;AACpB;;GAEG;AACH,OAAO,GAAE,OAAsB,GAC9B,IAAI,CAqBN;AAED,wBAAgB,sBAAsB,CACpC,IAAI,EAAE,QAAQ,EACd,CAAC,EAAE,aAAa,CAAC,MAAM,CAAC,EACxB,cAAc,EAAE,cAAc,EAC9B,MAAM,EAAE,OAAO,EACf,QAAQ,EAAE,OAAO;AACjB;;GAEG;AACH,OAAO,GAAE,OAAsB,GAC9B,IAAI,CAkFN"}
1
+ {"version":3,"file":"Unspent.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,14 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.addWalletUnspentToPsbt = exports.addReplayProtectionUnspentToPsbt = exports.verifySignatureWithUnspent = exports.signInputWithUnspent = exports.isWalletUnspent = void 0;
3
+ exports.MAX_BIP125_RBF_SEQUENCE = exports.TX_INPUT_SEQUENCE_NUMBER_FINAL = void 0;
4
+ exports.isWalletUnspent = isWalletUnspent;
5
+ exports.signInputWithUnspent = signInputWithUnspent;
6
+ exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
7
+ exports.psbtIncludesUnspentAtIndex = psbtIncludesUnspentAtIndex;
8
+ exports.updateReplayProtectionUnspentToPsbt = updateReplayProtectionUnspentToPsbt;
9
+ exports.addReplayProtectionUnspentToPsbt = addReplayProtectionUnspentToPsbt;
10
+ exports.updateWalletUnspentForPsbt = updateWalletUnspentForPsbt;
11
+ exports.addWalletUnspentToPsbt = addWalletUnspentToPsbt;
4
12
  const __1 = require("../..");
5
13
  const outputScripts_1 = require("../outputScripts");
6
14
  const address_1 = require("../../address");
@@ -10,21 +18,27 @@ const chains_1 = require("./chains");
10
18
  const Musig2_1 = require("../Musig2");
11
19
  const transaction_1 = require("../transaction");
12
20
  const parseInput_1 = require("../parseInput");
21
+ const utils_1 = require("bip174/src/lib/utils");
22
+ const PsbtUtil_1 = require("../PsbtUtil");
23
+ /** Final (non-replaceable) */
24
+ exports.TX_INPUT_SEQUENCE_NUMBER_FINAL = 0xffffffff;
25
+ /** Non-Final (Replaceable)
26
+ * Reference: https://github.com/bitcoin/bitcoin/blob/v25.1/src/rpc/rawtransaction_util.cpp#L49
27
+ * */
28
+ exports.MAX_BIP125_RBF_SEQUENCE = 0xffffffff - 2;
13
29
  function isWalletUnspent(u) {
14
30
  return u.chain !== undefined;
15
31
  }
16
- exports.isWalletUnspent = isWalletUnspent;
17
32
  function signInputWithUnspent(txBuilder, inputIndex, unspent, unspentSigner) {
18
33
  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);
19
- const scriptType = outputScripts_1.scriptTypeForChain(unspent.chain);
20
- const pubScript = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;
21
- const pubScriptExpected = address_1.toOutputScript(unspent.address, txBuilder.network);
34
+ const scriptType = (0, outputScripts_1.scriptTypeForChain)(unspent.chain);
35
+ const pubScript = (0, outputScripts_1.createOutputScript2of3)(walletKeys.publicKeys, scriptType).scriptPubKey;
36
+ const pubScriptExpected = (0, address_1.toOutputScript)(unspent.address, txBuilder.network);
22
37
  if (!pubScript.equals(pubScriptExpected)) {
23
38
  throw new Error(`pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`);
24
39
  }
25
- signature_1.signInput2Of3(txBuilder, inputIndex, scriptType, walletKeys.publicKeys, signer, cosigner.publicKey, unspent.value);
40
+ (0, signature_1.signInput2Of3)(txBuilder, inputIndex, scriptType, walletKeys.publicKeys, signer, cosigner.publicKey, unspent.value);
26
41
  }
27
- exports.signInputWithUnspent = signInputWithUnspent;
28
42
  /**
29
43
  * @param tx
30
44
  * @param inputIndex
@@ -33,7 +47,6 @@ exports.signInputWithUnspent = signInputWithUnspent;
33
47
  * @return triple of booleans indicating a valid signature for each pubkey
34
48
  */
35
49
  function verifySignatureWithUnspent(tx, inputIndex, unspents, walletKeys) {
36
- var _a, _b;
37
50
  if (tx.ins.length !== unspents.length) {
38
51
  throw new Error(`input length must match unspents length`);
39
52
  }
@@ -43,128 +56,208 @@ function verifySignatureWithUnspent(tx, inputIndex, unspents, walletKeys) {
43
56
  throw new Error(`no input at index ${inputIndex}`);
44
57
  }
45
58
  const unspent = unspents[inputIndex];
46
- if (!isWalletUnspent(unspent) || (!((_a = input.script) === null || _a === void 0 ? void 0 : _a.length) && !((_b = input.witness) === null || _b === void 0 ? void 0 : _b.length))) {
59
+ if (!isWalletUnspent(unspent) || (!input.script?.length && !input.witness?.length)) {
47
60
  return [false, false, false];
48
61
  }
49
- const parsedInput = parseInput_1.parseSignatureScript(input);
50
- const prevOutputs = unspents.map((u) => Unspent_1.toOutput(u, tx.network));
62
+ const parsedInput = (0, parseInput_1.parseSignatureScript)(input);
63
+ const prevOutputs = unspents.map((u) => (0, Unspent_1.toOutput)(u, tx.network));
51
64
  // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can
52
65
  // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.
53
66
  // Therefore, we can only say that either all partial signatures are valid, or none are.
54
67
  if (parsedInput.scriptType === 'taprootKeyPathSpend') {
55
- const result = signature_1.getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);
68
+ const result = (0, signature_1.getSignatureVerifications)(tx, inputIndex, unspent.value, undefined, prevOutputs);
56
69
  return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];
57
70
  }
58
- return signature_1.verifySignatureWithPublicKeys(tx, inputIndex, prevOutputs, walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys);
71
+ return (0, signature_1.verifySignatureWithPublicKeys)(tx, inputIndex, prevOutputs, walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys);
59
72
  }
60
- exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
61
- function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript,
62
73
  /**
63
- * @deprecated
74
+ * @param psbt
75
+ * @param inputIndex
76
+ * @param id Unspent ID
77
+ * @returns true iff the unspent ID on the unspent and psbt input match
64
78
  */
65
- network = psbt.network) {
66
- if (network !== psbt.network) {
67
- throw new Error(`network parameter does not match psbt.network`);
79
+ function psbtIncludesUnspentAtIndex(psbt, inputIndex, id) {
80
+ (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
81
+ const { txid, vout } = (0, Unspent_1.parseOutputId)(id);
82
+ const psbtOutPoint = (0, Unspent_1.getOutputIdForInput)(psbt.txInputs[inputIndex]);
83
+ return psbtOutPoint.txid === txid && psbtOutPoint.vout === vout;
84
+ }
85
+ /**
86
+ * Update the psbt input at the given index
87
+ * @param psbt
88
+ * @param inputIndex
89
+ * @param u
90
+ * @param redeemScript Only overrides if there is no redeemScript in the input currently
91
+ */
92
+ function updateReplayProtectionUnspentToPsbt(psbt, inputIndex, u, redeemScript, customParams) {
93
+ if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
94
+ throw new Error(`unspent does not correspond to psbt input`);
95
+ }
96
+ const input = (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
97
+ if (redeemScript && !input.redeemScript) {
98
+ psbt.updateInput(inputIndex, { redeemScript });
68
99
  }
69
- const { txid, vout } = Unspent_1.toPrevOutput(u, psbt.network);
70
- const isZcash = __1.getMainnet(psbt.network) === __1.networks.zcash;
71
100
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
72
101
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
73
102
  // segwit transactions
74
- if (!Unspent_1.isUnspentWithPrevTx(u) && !isZcash) {
103
+ const isZcash = (0, __1.getMainnet)(psbt.network) === __1.networks.zcash;
104
+ if (!(0, Unspent_1.isUnspentWithPrevTx)(u) && !isZcash && !customParams?.skipNonWitnessUtxo) {
75
105
  throw new Error('Error, require previous tx to add to PSBT');
76
106
  }
107
+ if ((isZcash && !input.witnessUtxo) || customParams?.skipNonWitnessUtxo) {
108
+ const { script, value } = (0, Unspent_1.toPrevOutput)(u, psbt.network);
109
+ psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
110
+ }
111
+ else if (!isZcash && !input.nonWitnessUtxo) {
112
+ psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
113
+ }
114
+ const sighashType = (0, signature_1.getDefaultSigHash)(psbt.network);
115
+ if (psbt.data.inputs[inputIndex].sighashType === undefined) {
116
+ psbt.updateInput(inputIndex, { sighashType });
117
+ }
118
+ }
119
+ function addUnspentToPsbt(psbt, id, { sequenceNumber = exports.TX_INPUT_SEQUENCE_NUMBER_FINAL } = {}) {
120
+ const { txid, vout } = (0, Unspent_1.parseOutputId)(id);
77
121
  psbt.addInput({
78
122
  hash: txid,
79
123
  index: vout,
80
- redeemScript,
124
+ sequence: sequenceNumber,
81
125
  });
82
- if (!isZcash) {
83
- psbt.updateInput(psbt.inputCount - 1, { nonWitnessUtxo: u.prevTx });
84
- }
85
126
  }
86
- exports.addReplayProtectionUnspentToPsbt = addReplayProtectionUnspentToPsbt;
87
- function addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signer, cosigner,
127
+ function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript, customParams) {
128
+ addUnspentToPsbt(psbt, u.id);
129
+ updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript, customParams);
130
+ }
88
131
  /**
89
- * @deprecated
132
+ * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
133
+ *
134
+ * If skipNonWitnessUtxo is true, then the nonWitnessUtxo will not be added for an input that requires it (e.g. non-segwit)
135
+ * and instead the witnessUtxo will be added
136
+ *
137
+ * @param psbt
138
+ * @param inputIndex
139
+ * @param u
140
+ * @param rootWalletKeys
141
+ * @param signer
142
+ * @param cosigner
143
+ * @param customParams
90
144
  */
91
- network = psbt.network) {
92
- if (network !== psbt.network) {
93
- throw new Error(`network parameter does not match psbt.network`);
145
+ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer, cosigner, customParams) {
146
+ if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
147
+ throw new Error(`unspent does not correspond to psbt input`);
94
148
  }
95
- const { txid, vout, script, value } = Unspent_1.toPrevOutput(u, psbt.network);
96
- psbt.addInput({ hash: txid, index: vout });
97
- const inputIndex = psbt.inputCount - 1;
149
+ const input = (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
98
150
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
99
151
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
100
152
  // segwit transactions
101
- if (chains_1.isSegwit(u.chain) || __1.getMainnet(psbt.network) === __1.networks.zcash) {
153
+ const isZcashOrSegwit = (0, chains_1.isSegwit)(u.chain) || (0, __1.getMainnet)(psbt.network) === __1.networks.zcash;
154
+ if ((isZcashOrSegwit || customParams?.skipNonWitnessUtxo) && !input.witnessUtxo) {
155
+ const { script, value } = (0, Unspent_1.toPrevOutput)(u, psbt.network);
102
156
  psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
103
157
  }
104
- else {
105
- if (!Unspent_1.isUnspentWithPrevTx(u)) {
158
+ else if (!isZcashOrSegwit) {
159
+ if (!(0, Unspent_1.isUnspentWithPrevTx)(u)) {
106
160
  throw new Error('Error, require previous tx to add to PSBT');
107
161
  }
108
- // Force the litecoin transaction to have no MWEB advanced transaction flag
109
- if (__1.getMainnet(psbt.network) === __1.networks.litecoin) {
110
- u.prevTx = transaction_1.createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();
162
+ if (!input.witnessUtxo && !input.nonWitnessUtxo) {
163
+ // Force the litecoin transaction to have no MWEB advanced transaction flag
164
+ if ((0, __1.getMainnet)(psbt.network) === __1.networks.litecoin) {
165
+ u.prevTx = (0, transaction_1.createTransactionFromBuffer)(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();
166
+ }
167
+ psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
111
168
  }
112
- psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
113
169
  }
114
170
  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);
115
- const scriptType = outputScripts_1.scriptTypeForChain(u.chain);
171
+ const scriptType = (0, outputScripts_1.scriptTypeForChain)(u.chain);
172
+ const sighashType = (0, signature_1.getDefaultSigHash)(psbt.network, scriptType);
173
+ if (psbt.data.inputs[inputIndex].sighashType === undefined) {
174
+ psbt.updateInput(inputIndex, { sighashType });
175
+ }
116
176
  const isBackupFlow = signer === 'backup' || cosigner === 'backup';
117
177
  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {
178
+ if (input.tapLeafScript && input.tapBip32Derivation) {
179
+ return;
180
+ }
118
181
  const createSpendScriptP2trFn = scriptType === 'p2tr' ? outputScripts_1.createSpendScriptP2tr : outputScripts_1.createSpendScriptP2trMusig2;
119
182
  const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [
120
183
  walletKeys[signer].publicKey,
121
184
  walletKeys[cosigner].publicKey,
122
185
  ]);
123
- psbt.updateInput(inputIndex, {
124
- tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],
125
- tapBip32Derivation: [signer, cosigner].map((key) => ({
126
- leafHashes: [leafHash],
127
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
128
- path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
129
- masterFingerprint: rootWalletKeys[key].fingerprint,
130
- })),
131
- });
186
+ if (!input.tapLeafScript) {
187
+ psbt.updateInput(inputIndex, {
188
+ tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],
189
+ });
190
+ }
191
+ if (!input.tapBip32Derivation) {
192
+ psbt.updateInput(inputIndex, {
193
+ tapBip32Derivation: [signer, cosigner].map((key) => ({
194
+ leafHashes: [leafHash],
195
+ pubkey: (0, outputScripts_1.toXOnlyPublicKey)(walletKeys[key].publicKey),
196
+ path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
197
+ masterFingerprint: rootWalletKeys[key].fingerprint,
198
+ })),
199
+ });
200
+ }
132
201
  }
133
202
  else if (scriptType === 'p2trMusig2') {
134
- const { internalPubkey: tapInternalKey, outputPubkey: tapOutputKey, taptreeRoot, } = outputScripts_1.createKeyPathP2trMusig2(walletKeys.publicKeys);
135
- const participantsKeyValData = Musig2_1.encodePsbtMusig2Participants({
136
- tapOutputKey,
137
- tapInternalKey,
138
- participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],
139
- });
140
- psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);
141
- psbt.updateInput(inputIndex, {
142
- tapInternalKey: tapInternalKey,
143
- tapMerkleRoot: taptreeRoot,
144
- tapBip32Derivation: [signer, cosigner].map((key) => ({
145
- leafHashes: [],
146
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
147
- path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
148
- masterFingerprint: rootWalletKeys[key].fingerprint,
149
- })),
150
- });
203
+ const { internalPubkey: tapInternalKey, outputPubkey: tapOutputKey, taptreeRoot, } = (0, outputScripts_1.createKeyPathP2trMusig2)(walletKeys.publicKeys);
204
+ if (psbt.getProprietaryKeyVals(inputIndex, {
205
+ identifier: PsbtUtil_1.PSBT_PROPRIETARY_IDENTIFIER,
206
+ subtype: PsbtUtil_1.ProprietaryKeySubtype.MUSIG2_PARTICIPANT_PUB_KEYS,
207
+ }).length === 0) {
208
+ const participantsKeyValData = (0, Musig2_1.encodePsbtMusig2Participants)({
209
+ tapOutputKey,
210
+ tapInternalKey,
211
+ participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],
212
+ });
213
+ psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);
214
+ }
215
+ if (!input.tapInternalKey) {
216
+ psbt.updateInput(inputIndex, {
217
+ tapInternalKey: tapInternalKey,
218
+ });
219
+ }
220
+ if (!input.tapMerkleRoot) {
221
+ psbt.updateInput(inputIndex, {
222
+ tapMerkleRoot: taptreeRoot,
223
+ });
224
+ }
225
+ if (!input.tapBip32Derivation) {
226
+ psbt.updateInput(inputIndex, {
227
+ tapBip32Derivation: [signer, cosigner].map((key) => ({
228
+ leafHashes: [],
229
+ pubkey: (0, outputScripts_1.toXOnlyPublicKey)(walletKeys[key].publicKey),
230
+ path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
231
+ masterFingerprint: rootWalletKeys[key].fingerprint,
232
+ })),
233
+ });
234
+ }
151
235
  }
152
236
  else {
153
- const { witnessScript, redeemScript } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
154
- psbt.updateInput(inputIndex, {
155
- bip32Derivation: [0, 1, 2].map((idx) => ({
156
- pubkey: walletKeys.triple[idx].publicKey,
157
- path: walletKeys.paths[idx],
158
- masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
159
- })),
160
- });
161
- if (witnessScript) {
237
+ if (!input.bip32Derivation) {
238
+ psbt.updateInput(inputIndex, {
239
+ bip32Derivation: [0, 1, 2].map((idx) => ({
240
+ pubkey: walletKeys.triple[idx].publicKey,
241
+ path: walletKeys.paths[idx],
242
+ masterFingerprint: rootWalletKeys.triple[idx].fingerprint,
243
+ })),
244
+ });
245
+ }
246
+ const { witnessScript, redeemScript } = (0, outputScripts_1.createOutputScript2of3)(walletKeys.publicKeys, scriptType);
247
+ if (witnessScript && !input.witnessScript) {
162
248
  psbt.updateInput(inputIndex, { witnessScript });
163
249
  }
164
- if (redeemScript) {
250
+ if (redeemScript && !input.redeemScript) {
165
251
  psbt.updateInput(inputIndex, { redeemScript });
166
252
  }
167
253
  }
168
254
  }
169
- exports.addWalletUnspentToPsbt = addWalletUnspentToPsbt;
170
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":";;;AAAA,6BAAsD;AAEtD,oDAO0B;AAC1B,2CAA+C;AAC/C,4CAAuG;AAKvG,wCAAqG;AACrG,qCAA+C;AAE/C,sCAAyD;AACzD,gDAA6D;AAC7D,8CAAqD;AAarD,SAAgB,eAAe,CAAkC,CAAmB;IAClF,OAAQ,CAA4B,CAAC,KAAK,KAAK,SAAS,CAAC;AAC3D,CAAC;AAFD,0CAEC;AAED,SAAgB,oBAAoB,CAClC,SAA0C,EAC1C,UAAkB,EAClB,OAA+B,EAC/B,aAAkD;IAElD,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC5G,MAAM,UAAU,GAAG,kCAAkB,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,sCAAsB,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,YAAY,CAAC;IACzF,MAAM,iBAAiB,GAAG,wBAAc,CAAC,OAAO,CAAC,OAAO,EAAE,SAAS,CAAC,OAAkB,CAAC,CAAC;IACxF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE;QACxC,MAAM,IAAI,KAAK,CACb,gCAAgC,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CACrG,CAAC;KACH;IACD,yBAAa,CACX,SAAS,EACT,UAAU,EACV,UAAU,EACV,UAAU,CAAC,UAAU,EACrB,MAAM,EACN,QAAQ,CAAC,SAAS,EAClB,OAAO,CAAC,KAAK,CACd,CAAC;AACJ,CAAC;AAxBD,oDAwBC;AAED;;;;;;GAMG;AACH,SAAgB,0BAA0B,CACxC,EAA4B,EAC5B,UAAkB,EAClB,QAA4B,EAC5B,UAA0B;;IAE1B,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,EAAE;QACrC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;KAC5D;IAED,MAAM,KAAK,GAAG,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACjC,0BAA0B;IAC1B,IAAI,CAAC,KAAK,EAAE;QACV,MAAM,IAAI,KAAK,CAAC,qBAAqB,UAAU,EAAE,CAAC,CAAC;KACpD;IAED,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IACrC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAA,MAAA,KAAK,CAAC,MAAM,0CAAE,MAAM,CAAA,IAAI,CAAC,CAAA,MAAA,KAAK,CAAC,OAAO,0CAAE,MAAM,CAAA,CAAC,EAAE;QAClF,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;KAC9B;IAED,MAAM,WAAW,GAAG,iCAAoB,CAAC,KAAK,CAAC,CAAC;IAChD,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,kBAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEjE,qGAAqG;IACrG,0GAA0G;IAC1G,wFAAwF;IACxF,IAAI,WAAW,CAAC,UAAU,KAAK,qBAAqB,EAAE;QACpD,MAAM,MAAM,GAAG,qCAAyB,CAAC,EAAE,EAAE,UAAU,EAAE,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QAChG,OAAO,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;KACjG;IAED,OAAO,yCAA6B,CAClC,EAAE,EACF,UAAU,EACV,WAAW,EACX,UAAU,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CACxD,CAAC;AACvB,CAAC;AAtCD,gEAsCC;AAaD,SAAgB,gCAAgC,CAC9C,IAAc,EACd,CAAkB,EAClB,YAAoB;AACpB;;GAEG;AACH,UAAmB,IAAI,CAAC,OAAO;IAE/B,IAAI,OAAO,KAAK,IAAI,CAAC,OAAO,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;KAClE;IACD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,sBAAY,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IACrD,MAAM,OAAO,GAAG,cAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,CAAC;IAE5D,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,IAAI,CAAC,6BAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE;QACvC,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;KAC9D;IACD,IAAI,CAAC,QAAQ,CAAC;QACZ,IAAI,EAAE,IAAI;QACV,KAAK,EAAE,IAAI;QACX,YAAY;KACb,CAAC,CAAC;IACH,IAAI,CAAC,OAAO,EAAE;QACZ,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,EAAE,cAAc,EAAG,CAA+B,CAAC,MAAM,EAAE,CAAC,CAAC;KACpG;AACH,CAAC;AA7BD,4EA6BC;AAED,SAAgB,sBAAsB,CACpC,IAAc,EACd,CAAwB,EACxB,cAA8B,EAC9B,MAAe,EACf,QAAiB;AACjB;;GAEG;AACH,UAAmB,IAAI,CAAC,OAAO;IAE/B,IAAI,OAAO,KAAK,IAAI,CAAC,OAAO,EAAE;QAC5B,MAAM,IAAI,KAAK,CAAC,+CAA+C,CAAC,CAAC;KAClE;IACD,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,sBAAY,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;IAEpE,IAAI,CAAC,QAAQ,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IAC3C,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,GAAG,CAAC,CAAC;IAEvC,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,IAAI,iBAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,cAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,EAAE;QACpE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;KAClE;SAAM;QACL,IAAI,CAAC,6BAAmB,CAAC,CAAC,CAAC,EAAE;YAC3B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;SAC9D;QACD,2EAA2E;QAC3E,IAAI,cAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,QAAQ,EAAE;YAClD,CAAC,CAAC,MAAM,GAAG,yCAA2B,CAAC,CAAC,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;SACrG;QACD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;KAC5D;IAED,MAAM,UAAU,GAAG,cAAc,CAAC,sBAAsB,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;IAC3E,MAAM,UAAU,GAAG,kCAAkB,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/C,MAAM,YAAY,GAAG,MAAM,KAAK,QAAQ,IAAI,QAAQ,KAAK,QAAQ,CAAC;IAElE,IAAI,UAAU,KAAK,MAAM,IAAI,CAAC,UAAU,KAAK,YAAY,IAAI,YAAY,CAAC,EAAE;QAC1E,MAAM,uBAAuB,GAAG,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,qCAAqB,CAAC,CAAC,CAAC,2CAA2B,CAAC;QAC5G,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,uBAAuB,CAAC,UAAU,CAAC,UAAU,EAAE;YAC5G,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS;YAC5B,UAAU,CAAC,QAAQ,CAAC,CAAC,SAAS;SAC/B,CAAC,CAAC;QACH,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,aAAa,EAAE,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;YACrE,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnD,UAAU,EAAE,CAAC,QAAQ,CAAC;gBACtB,MAAM,EAAE,gCAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;gBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;gBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;aACnD,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;SAAM,IAAI,UAAU,KAAK,YAAY,EAAE;QACtC,MAAM,EACJ,cAAc,EAAE,cAAc,EAC9B,YAAY,EAAE,YAAY,EAC1B,WAAW,GACZ,GAAG,uCAAuB,CAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QACnD,MAAM,sBAAsB,GAAG,qCAA4B,CAAC;YAC1D,YAAY;YACZ,cAAc;YACd,kBAAkB,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC;SAC5E,CAAC,CAAC;QACH,IAAI,CAAC,2BAA2B,CAAC,UAAU,EAAE,sBAAsB,CAAC,CAAC;QACrE,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,cAAc,EAAE,cAAc;YAC9B,aAAa,EAAE,WAAW;YAC1B,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACnD,UAAU,EAAE,EAAE;gBACd,MAAM,EAAE,gCAAgB,CAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;gBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;gBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;aACnD,CAAC,CAAC;SACJ,CAAC,CAAC;KACJ;SAAM;QACL,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,sCAAsB,CAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAClG,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;YAC3B,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;gBACvC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS;gBACxC,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC;gBAC3B,iBAAiB,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW;aAC1D,CAAC,CAAC;SACJ,CAAC,CAAC;QACH,IAAI,aAAa,EAAE;YACjB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;SACjD;QACD,IAAI,YAAY,EAAE;YAChB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;SAChD;KACF;AACH,CAAC;AA5FD,wDA4FC","sourcesContent":["import { getMainnet, Network, networks } from '../..';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport {\n  createKeyPathP2trMusig2,\n  createOutputScript2of3,\n  createSpendScriptP2tr,\n  createSpendScriptP2trMusig2,\n  scriptTypeForChain,\n  toXOnlyPublicKey,\n} from '../outputScripts';\nimport { toOutputScript } from '../../address';\nimport { getSignatureVerifications, signInput2Of3, verifySignatureWithPublicKeys } from '../signature';\nimport { WalletUnspentSigner } from './WalletUnspentSigner';\nimport { KeyName, RootWalletKeys } from './WalletKeys';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { Triple } from '../types';\nimport { toOutput, UnspentWithPrevTx, Unspent, isUnspentWithPrevTx, toPrevOutput } from '../Unspent';\nimport { ChainCode, isSegwit } from './chains';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { encodePsbtMusig2Participants } from '../Musig2';\nimport { createTransactionFromBuffer } from '../transaction';\nimport { parseSignatureScript } from '../parseInput';\n\nexport interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {\n  chain: ChainCode;\n  index: number;\n  witnessScript?: string;\n  valueString?: string;\n}\n\nexport interface NonWitnessWalletUnspent<TNumber extends number | bigint = number>\n  extends UnspentWithPrevTx<TNumber>,\n    WalletUnspent<TNumber> {}\n\nexport function isWalletUnspent<TNumber extends number | bigint>(u: Unspent<TNumber>): u is WalletUnspent<TNumber> {\n  return (u as WalletUnspent<TNumber>).chain !== undefined;\n}\n\nexport function signInputWithUnspent<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  inputIndex: number,\n  unspent: WalletUnspent<TNumber>,\n  unspentSigner: WalletUnspentSigner<RootWalletKeys>\n): void {\n  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  const pubScript = createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;\n  const pubScriptExpected = toOutputScript(unspent.address, txBuilder.network as Network);\n  if (!pubScript.equals(pubScriptExpected)) {\n    throw new Error(\n      `pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`\n    );\n  }\n  signInput2Of3<TNumber>(\n    txBuilder,\n    inputIndex,\n    scriptType,\n    walletKeys.publicKeys,\n    signer,\n    cosigner.publicKey,\n    unspent.value\n  );\n}\n\n/**\n * @param tx\n * @param inputIndex\n * @param unspents\n * @param walletKeys\n * @return triple of booleans indicating a valid signature for each pubkey\n */\nexport function verifySignatureWithUnspent<TNumber extends number | bigint>(\n  tx: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  unspents: Unspent<TNumber>[],\n  walletKeys: RootWalletKeys\n): Triple<boolean> {\n  if (tx.ins.length !== unspents.length) {\n    throw new Error(`input length must match unspents length`);\n  }\n\n  const input = tx.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const unspent = unspents[inputIndex];\n  if (!isWalletUnspent(unspent) || (!input.script?.length && !input.witness?.length)) {\n    return [false, false, false];\n  }\n\n  const parsedInput = parseSignatureScript(input);\n  const prevOutputs = unspents.map((u) => toOutput(u, tx.network));\n\n  // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can\n  // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.\n  // Therefore, we can only say that either all partial signatures are valid, or none are.\n  if (parsedInput.scriptType === 'taprootKeyPathSpend') {\n    const result = getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);\n    return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];\n  }\n\n  return verifySignatureWithPublicKeys(\n    tx,\n    inputIndex,\n    prevOutputs,\n    walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys\n  ) as Triple<boolean>;\n}\n\n/**\n * @deprecated\n * Used in certain legacy signing methods that do not derive signing data from index/chain\n */\nexport interface WalletUnspentLegacy<TNumber extends number | bigint = number> extends WalletUnspent<TNumber> {\n  /** @deprecated - obviated by signWithUnspent */\n  redeemScript?: string;\n  /** @deprecated - obviated by verifyWithUnspent */\n  witnessScript?: string;\n}\n\nexport function addReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: Unspent<bigint>,\n  redeemScript: Buffer,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (network !== psbt.network) {\n    throw new Error(`network parameter does not match psbt.network`);\n  }\n  const { txid, vout } = toPrevOutput(u, psbt.network);\n  const isZcash = getMainnet(psbt.network) === networks.zcash;\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  if (!isUnspentWithPrevTx(u) && !isZcash) {\n    throw new Error('Error, require previous tx to add to PSBT');\n  }\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n    redeemScript,\n  });\n  if (!isZcash) {\n    psbt.updateInput(psbt.inputCount - 1, { nonWitnessUtxo: (u as UnspentWithPrevTx<bigint>).prevTx });\n  }\n}\n\nexport function addWalletUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName,\n  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (network !== psbt.network) {\n    throw new Error(`network parameter does not match psbt.network`);\n  }\n  const { txid, vout, script, value } = toPrevOutput(u, psbt.network);\n\n  psbt.addInput({ hash: txid, index: vout });\n  const inputIndex = psbt.inputCount - 1;\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  if (isSegwit(u.chain) || getMainnet(psbt.network) === networks.zcash) {\n    psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });\n  } else {\n    if (!isUnspentWithPrevTx(u)) {\n      throw new Error('Error, require previous tx to add to PSBT');\n    }\n    // Force the litecoin transaction to have no MWEB advanced transaction flag\n    if (getMainnet(psbt.network) === networks.litecoin) {\n      u.prevTx = createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();\n    }\n    psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });\n  }\n\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);\n  const scriptType = scriptTypeForChain(u.chain);\n  const isBackupFlow = signer === 'backup' || cosigner === 'backup';\n\n  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {\n    const createSpendScriptP2trFn = scriptType === 'p2tr' ? createSpendScriptP2tr : createSpendScriptP2trMusig2;\n    const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [\n      walletKeys[signer].publicKey,\n      walletKeys[cosigner].publicKey,\n    ]);\n    psbt.updateInput(inputIndex, {\n      tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n      tapBip32Derivation: [signer, cosigner].map((key) => ({\n        leafHashes: [leafHash],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = createKeyPathP2trMusig2(walletKeys.publicKeys);\n    const participantsKeyValData = encodePsbtMusig2Participants({\n      tapOutputKey,\n      tapInternalKey,\n      participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],\n    });\n    psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);\n    psbt.updateInput(inputIndex, {\n      tapInternalKey: tapInternalKey,\n      tapMerkleRoot: taptreeRoot,\n      tapBip32Derivation: [signer, cosigner].map((key) => ({\n        leafHashes: [],\n        pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n        path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n        masterFingerprint: rootWalletKeys[key].fingerprint,\n      })),\n    });\n  } else {\n    const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    psbt.updateInput(inputIndex, {\n      bip32Derivation: [0, 1, 2].map((idx) => ({\n        pubkey: walletKeys.triple[idx].publicKey,\n        path: walletKeys.paths[idx],\n        masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n      })),\n    });\n    if (witnessScript) {\n      psbt.updateInput(inputIndex, { witnessScript });\n    }\n    if (redeemScript) {\n      psbt.updateInput(inputIndex, { redeemScript });\n    }\n  }\n}\n"]}
255
+ function addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signer, cosigner, customParams) {
256
+ let sequenceNumber = exports.TX_INPUT_SEQUENCE_NUMBER_FINAL;
257
+ if (customParams && customParams.isReplaceableByFee) {
258
+ sequenceNumber = exports.MAX_BIP125_RBF_SEQUENCE;
259
+ }
260
+ addUnspentToPsbt(psbt, u.id, { sequenceNumber });
261
+ updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner, customParams ? { skipNonWitnessUtxo: customParams.skipNonWitnessUtxo } : {});
262
+ }
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":";;;AAuDA,0CAEC;AAED,oDAwBC;AASD,gEAsCC;AAmBD,gEAMC;AASD,kFAkCC;AAeD,4EAQC;AAgBD,gEAkIC;AAED,wDAuBC;AAxYD,6BAAsD;AAEtD,oDAO0B;AAC1B,2CAA+C;AAC/C,4CAKsB;AAKtB,wCAQoB;AACpB,qCAA+C;AAE/C,sCAAyD;AACzD,gDAA6D;AAC7D,8CAAqD;AACrD,gDAAqD;AACrD,0CAAiF;AAEjF,8BAA8B;AACjB,QAAA,8BAA8B,GAAG,UAAU,CAAC;AAEzD;;KAEK;AACQ,QAAA,uBAAuB,GAAG,UAAU,GAAG,CAAC,CAAC;AAWtD,SAAgB,eAAe,CAAkC,CAAmB;IAClF,OAAQ,CAA4B,CAAC,KAAK,KAAK,SAAS,CAAC;AAC3D,CAAC;AAED,SAAgB,oBAAoB,CAClC,SAA0C,EAC1C,UAAkB,EAClB,OAA+B,EAC/B,aAAkD;IAElD,MAAM,EAAE,UAAU,EAAE,MAAM,EAAE,QAAQ,EAAE,GAAG,aAAa,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC;IAC5G,MAAM,UAAU,GAAG,IAAA,kCAAkB,EAAC,OAAO,CAAC,KAAK,CAAC,CAAC;IACrD,MAAM,SAAS,GAAG,IAAA,sCAAsB,EAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC,YAAY,CAAC;IACzF,MAAM,iBAAiB,GAAG,IAAA,wBAAc,EAAC,OAAO,CAAC,OAAO,EAAE,SAAS,CAAC,OAAkB,CAAC,CAAC;IACxF,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,iBAAiB,CAAC,EAAE,CAAC;QACzC,MAAM,IAAI,KAAK,CACb,gCAAgC,iBAAiB,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,SAAS,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE,CACrG,CAAC;IACJ,CAAC;IACD,IAAA,yBAAa,EACX,SAAS,EACT,UAAU,EACV,UAAU,EACV,UAAU,CAAC,UAAU,EACrB,MAAM,EACN,QAAQ,CAAC,SAAS,EAClB,OAAO,CAAC,KAAK,CACd,CAAC;AACJ,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,0BAA0B,CACxC,EAA4B,EAC5B,UAAkB,EAClB,QAA4B,EAC5B,UAA0B;IAE1B,IAAI,EAAE,CAAC,GAAG,CAAC,MAAM,KAAK,QAAQ,CAAC,MAAM,EAAE,CAAC;QACtC,MAAM,IAAI,KAAK,CAAC,yCAAyC,CAAC,CAAC;IAC7D,CAAC;IAED,MAAM,KAAK,GAAG,EAAE,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;IACjC,0BAA0B;IAC1B,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,MAAM,IAAI,KAAK,CAAC,qBAAqB,UAAU,EAAE,CAAC,CAAC;IACrD,CAAC;IAED,MAAM,OAAO,GAAG,QAAQ,CAAC,UAAU,CAAC,CAAC;IACrC,IAAI,CAAC,eAAe,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,MAAM,EAAE,MAAM,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,CAAC;QACnF,OAAO,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAC/B,CAAC;IAED,MAAM,WAAW,GAAG,IAAA,iCAAoB,EAAC,KAAK,CAAC,CAAC;IAChD,MAAM,WAAW,GAAG,QAAQ,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,IAAA,kBAAQ,EAAC,CAAC,EAAE,EAAE,CAAC,OAAO,CAAC,CAAC,CAAC;IAEjE,qGAAqG;IACrG,0GAA0G;IAC1G,wFAAwF;IACxF,IAAI,WAAW,CAAC,UAAU,KAAK,qBAAqB,EAAE,CAAC;QACrD,MAAM,MAAM,GAAG,IAAA,qCAAyB,EAAC,EAAE,EAAE,UAAU,EAAE,OAAO,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,CAAC,CAAC;QAChG,OAAO,MAAM,CAAC,MAAM,KAAK,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,CAAC,CAAC;IAClG,CAAC;IAED,OAAO,IAAA,yCAA6B,EAClC,EAAE,EACF,UAAU,EACV,WAAW,EACX,UAAU,CAAC,sBAAsB,CAAC,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,KAAK,CAAC,CAAC,UAAU,CACxD,CAAC;AACvB,CAAC;AAaD;;;;;GAKG;AACH,SAAgB,0BAA0B,CAAC,IAAc,EAAE,UAAkB,EAAE,EAAU;IACvF,IAAA,qBAAa,EAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAE5C,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAA,uBAAa,EAAC,EAAE,CAAC,CAAC;IACzC,MAAM,YAAY,GAAG,IAAA,6BAAmB,EAAC,IAAI,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC;IACpE,OAAO,YAAY,CAAC,IAAI,KAAK,IAAI,IAAI,YAAY,CAAC,IAAI,KAAK,IAAI,CAAC;AAClE,CAAC;AAED;;;;;;GAMG;AACH,SAAgB,mCAAmC,CACjD,IAAc,EACd,UAAkB,EAClB,CAAkB,EAClB,YAAqB,EACrB,YAA+C;IAE/C,IAAI,CAAC,0BAA0B,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QACxD,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IACD,MAAM,KAAK,GAAG,IAAA,qBAAa,EAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAE1D,IAAI,YAAY,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;QACxC,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;IACjD,CAAC;IAED,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,MAAM,OAAO,GAAG,IAAA,cAAU,EAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,CAAC;IAC5D,IAAI,CAAC,IAAA,6BAAmB,EAAC,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,CAAC,YAAY,EAAE,kBAAkB,EAAE,CAAC;QAC7E,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IACD,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,WAAW,CAAC,IAAI,YAAY,EAAE,kBAAkB,EAAE,CAAC;QACxE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,sBAAY,EAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACxD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;IACnE,CAAC;SAAM,IAAI,CAAC,OAAO,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;QAC7C,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,cAAc,EAAG,CAA+B,CAAC,MAAM,EAAE,CAAC,CAAC;IAC5F,CAAC;IAED,MAAM,WAAW,GAAG,IAAA,6BAAiB,EAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACpD,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;QAC3D,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IAChD,CAAC;AACH,CAAC;AAED,SAAS,gBAAgB,CACvB,IAAc,EACd,EAAU,EACV,EAAE,cAAc,GAAG,sCAA8B,KAAkC,EAAE;IAErF,MAAM,EAAE,IAAI,EAAE,IAAI,EAAE,GAAG,IAAA,uBAAa,EAAC,EAAE,CAAC,CAAC;IACzC,IAAI,CAAC,QAAQ,CAAC;QACZ,IAAI,EAAE,IAAI;QACV,KAAK,EAAE,IAAI;QACX,QAAQ,EAAE,cAAc;KACzB,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,gCAAgC,CAC9C,IAAc,EACd,CAAkB,EAClB,YAAoB,EACpB,YAA+C;IAE/C,gBAAgB,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,CAAC,CAAC;IAC7B,mCAAmC,CAAC,IAAI,EAAE,IAAI,CAAC,UAAU,GAAG,CAAC,EAAE,CAAC,EAAE,YAAY,EAAE,YAAY,CAAC,CAAC;AAChG,CAAC;AAED;;;;;;;;;;;;;GAaG;AACH,SAAgB,0BAA0B,CACxC,IAAc,EACd,UAAkB,EAClB,CAAwB,EACxB,cAA8B,EAC9B,MAAe,EACf,QAAiB,EACjB,YAA+C;IAE/C,IAAI,CAAC,0BAA0B,CAAC,IAAI,EAAE,UAAU,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC;QACxD,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;IAC/D,CAAC;IACD,MAAM,KAAK,GAAG,IAAA,qBAAa,EAAC,IAAI,CAAC,IAAI,CAAC,MAAM,EAAE,UAAU,CAAC,CAAC;IAE1D,0GAA0G;IAC1G,kGAAkG;IAClG,sBAAsB;IACtB,MAAM,eAAe,GAAG,IAAA,iBAAQ,EAAC,CAAC,CAAC,KAAK,CAAC,IAAI,IAAA,cAAU,EAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,KAAK,CAAC;IACzF,IAAI,CAAC,eAAe,IAAI,YAAY,EAAE,kBAAkB,CAAC,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;QAChF,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,IAAA,sBAAY,EAAC,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,CAAC;QACxD,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,CAAC;IACnE,CAAC;SAAM,IAAI,CAAC,eAAe,EAAE,CAAC;QAC5B,IAAI,CAAC,IAAA,6BAAmB,EAAC,CAAC,CAAC,EAAE,CAAC;YAC5B,MAAM,IAAI,KAAK,CAAC,2CAA2C,CAAC,CAAC;QAC/D,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,WAAW,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;YAChD,2EAA2E;YAC3E,IAAI,IAAA,cAAU,EAAC,IAAI,CAAC,OAAO,CAAC,KAAK,YAAQ,CAAC,QAAQ,EAAE,CAAC;gBACnD,CAAC,CAAC,MAAM,GAAG,IAAA,yCAA2B,EAAC,CAAC,CAAC,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,EAAE,UAAU,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAE,CAAC;YACtG,CAAC;YAED,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,cAAc,EAAE,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC;QAC7D,CAAC;IACH,CAAC;IAED,MAAM,UAAU,GAAG,cAAc,CAAC,sBAAsB,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC;IAC3E,MAAM,UAAU,GAAG,IAAA,kCAAkB,EAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IAC/C,MAAM,WAAW,GAAG,IAAA,6BAAiB,EAAC,IAAI,CAAC,OAAO,EAAE,UAAU,CAAC,CAAC;IAChE,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,WAAW,KAAK,SAAS,EAAE,CAAC;QAC3D,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,WAAW,EAAE,CAAC,CAAC;IAChD,CAAC;IACD,MAAM,YAAY,GAAG,MAAM,KAAK,QAAQ,IAAI,QAAQ,KAAK,QAAQ,CAAC;IAElE,IAAI,UAAU,KAAK,MAAM,IAAI,CAAC,UAAU,KAAK,YAAY,IAAI,YAAY,CAAC,EAAE,CAAC;QAC3E,IAAI,KAAK,CAAC,aAAa,IAAI,KAAK,CAAC,kBAAkB,EAAE,CAAC;YACpD,OAAO;QACT,CAAC;QACD,MAAM,uBAAuB,GAAG,UAAU,KAAK,MAAM,CAAC,CAAC,CAAC,qCAAqB,CAAC,CAAC,CAAC,2CAA2B,CAAC;QAC5G,MAAM,EAAE,YAAY,EAAE,aAAa,EAAE,WAAW,EAAE,QAAQ,EAAE,GAAG,uBAAuB,CAAC,UAAU,CAAC,UAAU,EAAE;YAC5G,UAAU,CAAC,MAAM,CAAC,CAAC,SAAS;YAC5B,UAAU,CAAC,QAAQ,CAAC,CAAC,SAAS;SAC/B,CAAC,CAAC;QACH,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,aAAa,EAAE,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,aAAa,EAAE,WAAW,EAAE,CAAC;aACtE,CAAC,CAAC;QACL,CAAC;QACD,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBACnD,UAAU,EAAE,CAAC,QAAQ,CAAC;oBACtB,MAAM,EAAE,IAAA,gCAAgB,EAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;oBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;oBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;iBACnD,CAAC,CAAC;aACJ,CAAC,CAAC;QACL,CAAC;IACH,CAAC;SAAM,IAAI,UAAU,KAAK,YAAY,EAAE,CAAC;QACvC,MAAM,EACJ,cAAc,EAAE,cAAc,EAC9B,YAAY,EAAE,YAAY,EAC1B,WAAW,GACZ,GAAG,IAAA,uCAAuB,EAAC,UAAU,CAAC,UAAU,CAAC,CAAC;QAEnD,IACE,IAAI,CAAC,qBAAqB,CAAC,UAAU,EAAE;YACrC,UAAU,EAAE,sCAA2B;YACvC,OAAO,EAAE,gCAAqB,CAAC,2BAA2B;SAC3D,CAAC,CAAC,MAAM,KAAK,CAAC,EACf,CAAC;YACD,MAAM,sBAAsB,GAAG,IAAA,qCAA4B,EAAC;gBAC1D,YAAY;gBACZ,cAAc;gBACd,kBAAkB,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,UAAU,CAAC,KAAK,CAAC,SAAS,CAAC;aAC5E,CAAC,CAAC;YACH,IAAI,CAAC,2BAA2B,CAAC,UAAU,EAAE,sBAAsB,CAAC,CAAC;QACvE,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,cAAc,EAAE,CAAC;YAC1B,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,cAAc,EAAE,cAAc;aAC/B,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YACzB,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,aAAa,EAAE,WAAW;aAC3B,CAAC,CAAC;QACL,CAAC;QAED,IAAI,CAAC,KAAK,CAAC,kBAAkB,EAAE,CAAC;YAC9B,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,kBAAkB,EAAE,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBACnD,UAAU,EAAE,EAAE;oBACd,MAAM,EAAE,IAAA,gCAAgB,EAAC,UAAU,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;oBACnD,IAAI,EAAE,cAAc,CAAC,iBAAiB,CAAC,cAAc,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC;oBAC7E,iBAAiB,EAAE,cAAc,CAAC,GAAG,CAAC,CAAC,WAAW;iBACnD,CAAC,CAAC;aACJ,CAAC,CAAC;QACL,CAAC;IACH,CAAC;SAAM,CAAC;QACN,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;YAC3B,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE;gBAC3B,eAAe,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;oBACvC,MAAM,EAAE,UAAU,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,SAAS;oBACxC,IAAI,EAAE,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC;oBAC3B,iBAAiB,EAAE,cAAc,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC,WAAW;iBAC1D,CAAC,CAAC;aACJ,CAAC,CAAC;QACL,CAAC;QAED,MAAM,EAAE,aAAa,EAAE,YAAY,EAAE,GAAG,IAAA,sCAAsB,EAAC,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,CAAC;QAClG,IAAI,aAAa,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;YAC1C,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,CAAC,CAAC;QAClD,CAAC;QACD,IAAI,YAAY,IAAI,CAAC,KAAK,CAAC,YAAY,EAAE,CAAC;YACxC,IAAI,CAAC,WAAW,CAAC,UAAU,EAAE,EAAE,YAAY,EAAE,CAAC,CAAC;QACjD,CAAC;IACH,CAAC;AACH,CAAC;AAED,SAAgB,sBAAsB,CACpC,IAAc,EACd,CAAwB,EACxB,cAA8B,EAC9B,MAAe,EACf,QAAiB,EACjB,YAA6E;IAE7E,IAAI,cAAc,GAAG,sCAA8B,CAAC;IACpD,IAAI,YAAY,IAAI,YAAY,CAAC,kBAAkB,EAAE,CAAC;QACpD,cAAc,GAAG,+BAAuB,CAAC;IAC3C,CAAC;IAED,gBAAgB,CAAC,IAAI,EAAE,CAAC,CAAC,EAAE,EAAE,EAAE,cAAc,EAAE,CAAC,CAAC;IACjD,0BAA0B,CACxB,IAAI,EACJ,IAAI,CAAC,UAAU,GAAG,CAAC,EACnB,CAAC,EACD,cAAc,EACd,MAAM,EACN,QAAQ,EACR,YAAY,CAAC,CAAC,CAAC,EAAE,kBAAkB,EAAE,YAAY,CAAC,kBAAkB,EAAE,CAAC,CAAC,CAAC,EAAE,CAC5E,CAAC;AACJ,CAAC","sourcesContent":["import { getMainnet, Network, networks } from '../..';\nimport { UtxoTransactionBuilder } from '../UtxoTransactionBuilder';\nimport {\n  createKeyPathP2trMusig2,\n  createOutputScript2of3,\n  createSpendScriptP2tr,\n  createSpendScriptP2trMusig2,\n  scriptTypeForChain,\n  toXOnlyPublicKey,\n} from '../outputScripts';\nimport { toOutputScript } from '../../address';\nimport {\n  getDefaultSigHash,\n  getSignatureVerifications,\n  signInput2Of3,\n  verifySignatureWithPublicKeys,\n} from '../signature';\nimport { WalletUnspentSigner } from './WalletUnspentSigner';\nimport { KeyName, RootWalletKeys } from './WalletKeys';\nimport { UtxoTransaction } from '../UtxoTransaction';\nimport { Triple } from '../types';\nimport {\n  toOutput,\n  UnspentWithPrevTx,\n  Unspent,\n  isUnspentWithPrevTx,\n  toPrevOutput,\n  parseOutputId,\n  getOutputIdForInput,\n} from '../Unspent';\nimport { ChainCode, isSegwit } from './chains';\nimport { UtxoPsbt } from '../UtxoPsbt';\nimport { encodePsbtMusig2Participants } from '../Musig2';\nimport { createTransactionFromBuffer } from '../transaction';\nimport { parseSignatureScript } from '../parseInput';\nimport { checkForInput } from 'bip174/src/lib/utils';\nimport { ProprietaryKeySubtype, PSBT_PROPRIETARY_IDENTIFIER } from '../PsbtUtil';\n\n/** Final (non-replaceable) */\nexport const TX_INPUT_SEQUENCE_NUMBER_FINAL = 0xffffffff;\n\n/** Non-Final (Replaceable)\n * Reference: https://github.com/bitcoin/bitcoin/blob/v25.1/src/rpc/rawtransaction_util.cpp#L49\n * */\nexport const MAX_BIP125_RBF_SEQUENCE = 0xffffffff - 2;\n\nexport interface WalletUnspent<TNumber extends number | bigint = number> extends Unspent<TNumber> {\n  chain: ChainCode;\n  index: number;\n}\n\nexport interface NonWitnessWalletUnspent<TNumber extends number | bigint = number>\n  extends UnspentWithPrevTx<TNumber>,\n    WalletUnspent<TNumber> {}\n\nexport function isWalletUnspent<TNumber extends number | bigint>(u: Unspent<TNumber>): u is WalletUnspent<TNumber> {\n  return (u as WalletUnspent<TNumber>).chain !== undefined;\n}\n\nexport function signInputWithUnspent<TNumber extends number | bigint>(\n  txBuilder: UtxoTransactionBuilder<TNumber>,\n  inputIndex: number,\n  unspent: WalletUnspent<TNumber>,\n  unspentSigner: WalletUnspentSigner<RootWalletKeys>\n): void {\n  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);\n  const scriptType = scriptTypeForChain(unspent.chain);\n  const pubScript = createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;\n  const pubScriptExpected = toOutputScript(unspent.address, txBuilder.network as Network);\n  if (!pubScript.equals(pubScriptExpected)) {\n    throw new Error(\n      `pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`\n    );\n  }\n  signInput2Of3<TNumber>(\n    txBuilder,\n    inputIndex,\n    scriptType,\n    walletKeys.publicKeys,\n    signer,\n    cosigner.publicKey,\n    unspent.value\n  );\n}\n\n/**\n * @param tx\n * @param inputIndex\n * @param unspents\n * @param walletKeys\n * @return triple of booleans indicating a valid signature for each pubkey\n */\nexport function verifySignatureWithUnspent<TNumber extends number | bigint>(\n  tx: UtxoTransaction<TNumber>,\n  inputIndex: number,\n  unspents: Unspent<TNumber>[],\n  walletKeys: RootWalletKeys\n): Triple<boolean> {\n  if (tx.ins.length !== unspents.length) {\n    throw new Error(`input length must match unspents length`);\n  }\n\n  const input = tx.ins[inputIndex];\n  /* istanbul ignore next */\n  if (!input) {\n    throw new Error(`no input at index ${inputIndex}`);\n  }\n\n  const unspent = unspents[inputIndex];\n  if (!isWalletUnspent(unspent) || (!input.script?.length && !input.witness?.length)) {\n    return [false, false, false];\n  }\n\n  const parsedInput = parseSignatureScript(input);\n  const prevOutputs = unspents.map((u) => toOutput(u, tx.network));\n\n  // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can\n  // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.\n  // Therefore, we can only say that either all partial signatures are valid, or none are.\n  if (parsedInput.scriptType === 'taprootKeyPathSpend') {\n    const result = getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);\n    return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];\n  }\n\n  return verifySignatureWithPublicKeys(\n    tx,\n    inputIndex,\n    prevOutputs,\n    walletKeys.deriveForChainAndIndex(unspent.chain, unspent.index).publicKeys\n  ) as Triple<boolean>;\n}\n\n/**\n * @deprecated\n * Used in certain legacy signing methods that do not derive signing data from index/chain\n */\nexport interface WalletUnspentLegacy<TNumber extends number | bigint = number> extends WalletUnspent<TNumber> {\n  /** @deprecated - obviated by signWithUnspent */\n  redeemScript?: string;\n  /** @deprecated - obviated by verifyWithUnspent */\n  witnessScript?: string;\n}\n\n/**\n * @param psbt\n * @param inputIndex\n * @param id Unspent ID\n * @returns true iff the unspent ID on the unspent and psbt input match\n */\nexport function psbtIncludesUnspentAtIndex(psbt: UtxoPsbt, inputIndex: number, id: string): boolean {\n  checkForInput(psbt.data.inputs, inputIndex);\n\n  const { txid, vout } = parseOutputId(id);\n  const psbtOutPoint = getOutputIdForInput(psbt.txInputs[inputIndex]);\n  return psbtOutPoint.txid === txid && psbtOutPoint.vout === vout;\n}\n\n/**\n * Update the psbt input at the given index\n * @param psbt\n * @param inputIndex\n * @param u\n * @param redeemScript Only overrides if there is no redeemScript in the input currently\n */\nexport function updateReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  u: Unspent<bigint>,\n  redeemScript?: Buffer,\n  customParams?: { skipNonWitnessUtxo?: boolean }\n): void {\n  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {\n    throw new Error(`unspent does not correspond to psbt input`);\n  }\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n\n  if (redeemScript && !input.redeemScript) {\n    psbt.updateInput(inputIndex, { redeemScript });\n  }\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  const isZcash = getMainnet(psbt.network) === networks.zcash;\n  if (!isUnspentWithPrevTx(u) && !isZcash && !customParams?.skipNonWitnessUtxo) {\n    throw new Error('Error, require previous tx to add to PSBT');\n  }\n  if ((isZcash && !input.witnessUtxo) || customParams?.skipNonWitnessUtxo) {\n    const { script, value } = toPrevOutput(u, psbt.network);\n    psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });\n  } else if (!isZcash && !input.nonWitnessUtxo) {\n    psbt.updateInput(inputIndex, { nonWitnessUtxo: (u as UnspentWithPrevTx<bigint>).prevTx });\n  }\n\n  const sighashType = getDefaultSigHash(psbt.network);\n  if (psbt.data.inputs[inputIndex].sighashType === undefined) {\n    psbt.updateInput(inputIndex, { sighashType });\n  }\n}\n\nfunction addUnspentToPsbt(\n  psbt: UtxoPsbt,\n  id: string,\n  { sequenceNumber = TX_INPUT_SEQUENCE_NUMBER_FINAL }: { sequenceNumber?: number } = {}\n): void {\n  const { txid, vout } = parseOutputId(id);\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n    sequence: sequenceNumber,\n  });\n}\n\nexport function addReplayProtectionUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: Unspent<bigint>,\n  redeemScript: Buffer,\n  customParams?: { skipNonWitnessUtxo?: boolean }\n): void {\n  addUnspentToPsbt(psbt, u.id);\n  updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript, customParams);\n}\n\n/**\n * Update the PSBT with the unspent data for the input at the given index if the data is not there already.\n *\n * If skipNonWitnessUtxo is true, then the nonWitnessUtxo will not be added for an input that requires it (e.g. non-segwit)\n * and instead the witnessUtxo will be added\n *\n * @param psbt\n * @param inputIndex\n * @param u\n * @param rootWalletKeys\n * @param signer\n * @param cosigner\n * @param customParams\n */\nexport function updateWalletUnspentForPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName,\n  customParams?: { skipNonWitnessUtxo?: boolean }\n): void {\n  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {\n    throw new Error(`unspent does not correspond to psbt input`);\n  }\n  const input = checkForInput(psbt.data.inputs, inputIndex);\n\n  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly\n  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin\n  // segwit transactions\n  const isZcashOrSegwit = isSegwit(u.chain) || getMainnet(psbt.network) === networks.zcash;\n  if ((isZcashOrSegwit || customParams?.skipNonWitnessUtxo) && !input.witnessUtxo) {\n    const { script, value } = toPrevOutput(u, psbt.network);\n    psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });\n  } else if (!isZcashOrSegwit) {\n    if (!isUnspentWithPrevTx(u)) {\n      throw new Error('Error, require previous tx to add to PSBT');\n    }\n\n    if (!input.witnessUtxo && !input.nonWitnessUtxo) {\n      // Force the litecoin transaction to have no MWEB advanced transaction flag\n      if (getMainnet(psbt.network) === networks.litecoin) {\n        u.prevTx = createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();\n      }\n\n      psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });\n    }\n  }\n\n  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);\n  const scriptType = scriptTypeForChain(u.chain);\n  const sighashType = getDefaultSigHash(psbt.network, scriptType);\n  if (psbt.data.inputs[inputIndex].sighashType === undefined) {\n    psbt.updateInput(inputIndex, { sighashType });\n  }\n  const isBackupFlow = signer === 'backup' || cosigner === 'backup';\n\n  if (scriptType === 'p2tr' || (scriptType === 'p2trMusig2' && isBackupFlow)) {\n    if (input.tapLeafScript && input.tapBip32Derivation) {\n      return;\n    }\n    const createSpendScriptP2trFn = scriptType === 'p2tr' ? createSpendScriptP2tr : createSpendScriptP2trMusig2;\n    const { controlBlock, witnessScript, leafVersion, leafHash } = createSpendScriptP2trFn(walletKeys.publicKeys, [\n      walletKeys[signer].publicKey,\n      walletKeys[cosigner].publicKey,\n    ]);\n    if (!input.tapLeafScript) {\n      psbt.updateInput(inputIndex, {\n        tapLeafScript: [{ controlBlock, script: witnessScript, leafVersion }],\n      });\n    }\n    if (!input.tapBip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        tapBip32Derivation: [signer, cosigner].map((key) => ({\n          leafHashes: [leafHash],\n          pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n          path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n          masterFingerprint: rootWalletKeys[key].fingerprint,\n        })),\n      });\n    }\n  } else if (scriptType === 'p2trMusig2') {\n    const {\n      internalPubkey: tapInternalKey,\n      outputPubkey: tapOutputKey,\n      taptreeRoot,\n    } = createKeyPathP2trMusig2(walletKeys.publicKeys);\n\n    if (\n      psbt.getProprietaryKeyVals(inputIndex, {\n        identifier: PSBT_PROPRIETARY_IDENTIFIER,\n        subtype: ProprietaryKeySubtype.MUSIG2_PARTICIPANT_PUB_KEYS,\n      }).length === 0\n    ) {\n      const participantsKeyValData = encodePsbtMusig2Participants({\n        tapOutputKey,\n        tapInternalKey,\n        participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],\n      });\n      psbt.addProprietaryKeyValToInput(inputIndex, participantsKeyValData);\n    }\n\n    if (!input.tapInternalKey) {\n      psbt.updateInput(inputIndex, {\n        tapInternalKey: tapInternalKey,\n      });\n    }\n\n    if (!input.tapMerkleRoot) {\n      psbt.updateInput(inputIndex, {\n        tapMerkleRoot: taptreeRoot,\n      });\n    }\n\n    if (!input.tapBip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        tapBip32Derivation: [signer, cosigner].map((key) => ({\n          leafHashes: [],\n          pubkey: toXOnlyPublicKey(walletKeys[key].publicKey),\n          path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),\n          masterFingerprint: rootWalletKeys[key].fingerprint,\n        })),\n      });\n    }\n  } else {\n    if (!input.bip32Derivation) {\n      psbt.updateInput(inputIndex, {\n        bip32Derivation: [0, 1, 2].map((idx) => ({\n          pubkey: walletKeys.triple[idx].publicKey,\n          path: walletKeys.paths[idx],\n          masterFingerprint: rootWalletKeys.triple[idx].fingerprint,\n        })),\n      });\n    }\n\n    const { witnessScript, redeemScript } = createOutputScript2of3(walletKeys.publicKeys, scriptType);\n    if (witnessScript && !input.witnessScript) {\n      psbt.updateInput(inputIndex, { witnessScript });\n    }\n    if (redeemScript && !input.redeemScript) {\n      psbt.updateInput(inputIndex, { redeemScript });\n    }\n  }\n}\n\nexport function addWalletUnspentToPsbt(\n  psbt: UtxoPsbt,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName,\n  customParams?: { isReplaceableByFee?: boolean; skipNonWitnessUtxo?: boolean }\n): void {\n  let sequenceNumber = TX_INPUT_SEQUENCE_NUMBER_FINAL;\n  if (customParams && customParams.isReplaceableByFee) {\n    sequenceNumber = MAX_BIP125_RBF_SEQUENCE;\n  }\n\n  addUnspentToPsbt(psbt, u.id, { sequenceNumber });\n  updateWalletUnspentForPsbt(\n    psbt,\n    psbt.inputCount - 1,\n    u,\n    rootWalletKeys,\n    signer,\n    cosigner,\n    customParams ? { skipNonWitnessUtxo: customParams.skipNonWitnessUtxo } : {}\n  );\n}\n"]}
@@ -1,4 +1,3 @@
1
- /// <reference types="node" />
2
1
  /**
3
2
  * Classes for deriving key triples for wallet addresses.
4
3
  *
@@ -12,7 +11,7 @@
12
11
  */
13
12
  import { BIP32Interface } from 'bip32';
14
13
  import { Triple } from '../types';
15
- export declare type KeyName = 'user' | 'backup' | 'bitgo';
14
+ export type KeyName = 'user' | 'backup' | 'bitgo';
16
15
  export declare function eqPublicKey(a: BIP32Interface, b: BIP32Interface): boolean;
17
16
  /**
18
17
  * Base class for RootWalletKeys and DerivedWalletKeys.
@@ -1 +1 @@
1
- {"version":3,"file":"WalletKeys.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletKeys.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;GAUG;AACH,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAEvC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,oBAAY,OAAO,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;AAElD,wBAAgB,WAAW,CAAC,CAAC,EAAE,cAAc,EAAE,CAAC,EAAE,cAAc,GAAG,OAAO,CAEzE;AAED;;;GAGG;AACH,qBAAa,UAAU;aAMO,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAL1D,SAAgB,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAE3C;;OAEG;gBACyB,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAY1D,IAAI,IAAI,IAAI,cAAc,CAEzB;IAED,IAAI,MAAM,IAAI,cAAc,CAE3B;IAED,IAAI,KAAK,IAAI,cAAc,CAE1B;CACF;AAED;;;;GAIG;AACH,qBAAa,iBAAkB,SAAQ,UAAU;IAK5B,MAAM,EAAE,cAAc;IAAS,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC;IAJvE;;;OAGG;gBACgB,MAAM,EAAE,cAAc,EAAS,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC;CAGxE;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,UAAU;aAU1B,kBAAkB,EAAE,MAAM,CAAC,MAAM,CAAC;IATpD,MAAM,CAAC,QAAQ,CAAC,aAAa,SAAS;IAEtC;;;;OAIG;gBAED,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC,EACd,kBAAkB,GAAE,MAAM,CAAC,MAAM,CAIhD;IAWH;;;;;OAKG;IACH,iBAAiB,CAAC,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;IAW5E;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,iBAAiB;CAMxE"}
1
+ {"version":3,"file":"WalletKeys.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletKeys.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AACH,OAAO,EAAE,cAAc,EAAE,MAAM,OAAO,CAAC;AAEvC,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAElC,MAAM,MAAM,OAAO,GAAG,MAAM,GAAG,QAAQ,GAAG,OAAO,CAAC;AAElD,wBAAgB,WAAW,CAAC,CAAC,EAAE,cAAc,EAAE,CAAC,EAAE,cAAc,GAAG,OAAO,CAEzE;AAED;;;GAGG;AACH,qBAAa,UAAU;aAMO,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAL1D,SAAgB,UAAU,EAAE,MAAM,CAAC,MAAM,CAAC,CAAC;IAE3C;;OAEG;gBACyB,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC;IAY1D,IAAI,IAAI,IAAI,cAAc,CAEzB;IAED,IAAI,MAAM,IAAI,cAAc,CAE3B;IAED,IAAI,KAAK,IAAI,cAAc,CAE1B;CACF;AAED;;;;GAIG;AACH,qBAAa,iBAAkB,SAAQ,UAAU;IAK5B,MAAM,EAAE,cAAc;IAAS,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC;IAJvE;;;OAGG;gBACgB,MAAM,EAAE,cAAc,EAAS,KAAK,EAAE,MAAM,CAAC,MAAM,CAAC;CAGxE;AAED;;GAEG;AACH,qBAAa,cAAe,SAAQ,UAAU;aAU1B,kBAAkB,EAAE,MAAM,CAAC,MAAM,CAAC;IATpD,MAAM,CAAC,QAAQ,CAAC,aAAa,SAAS;IAEtC;;;;OAIG;gBAED,MAAM,EAAE,MAAM,CAAC,cAAc,CAAC,EACd,kBAAkB,GAAE,MAAM,CAAC,MAAM,CAIhD;IAWH;;;;;OAKG;IACH,iBAAiB,CAAC,GAAG,EAAE,cAAc,EAAE,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,MAAM;IAW5E;;;;OAIG;IACH,sBAAsB,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,iBAAiB;CAMxE"}