@bitgo-beta/utxo-lib 8.0.3-beta.98 → 8.0.3-beta.981

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 (219) hide show
  1. package/dist/src/address.d.ts +0 -1
  2. package/dist/src/address.d.ts.map +1 -1
  3. package/dist/src/address.js +10 -10
  4. package/dist/src/addressFormat.d.ts +1 -2
  5. package/dist/src/addressFormat.d.ts.map +1 -1
  6. package/dist/src/addressFormat.js +21 -26
  7. package/dist/src/bitgo/Musig2.d.ts +1 -2
  8. package/dist/src/bitgo/Musig2.d.ts.map +1 -1
  9. package/dist/src/bitgo/Musig2.js +42 -42
  10. package/dist/src/bitgo/ProprietaryKeyValUtils.d.ts +27 -0
  11. package/dist/src/bitgo/ProprietaryKeyValUtils.d.ts.map +1 -0
  12. package/dist/src/bitgo/ProprietaryKeyValUtils.js +74 -0
  13. package/dist/src/bitgo/PsbtUtil.d.ts +22 -23
  14. package/dist/src/bitgo/PsbtUtil.d.ts.map +1 -1
  15. package/dist/src/bitgo/PsbtUtil.js +71 -22
  16. package/dist/src/bitgo/Unspent.d.ts +2 -3
  17. package/dist/src/bitgo/Unspent.d.ts.map +1 -1
  18. package/dist/src/bitgo/Unspent.js +14 -15
  19. package/dist/src/bitgo/UtxoPsbt.d.ts +21 -8
  20. package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -1
  21. package/dist/src/bitgo/UtxoPsbt.js +130 -117
  22. package/dist/src/bitgo/UtxoTransaction.d.ts +0 -1
  23. package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -1
  24. package/dist/src/bitgo/UtxoTransaction.js +12 -12
  25. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +0 -1
  26. package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -1
  27. package/dist/src/bitgo/UtxoTransactionBuilder.js +1 -1
  28. package/dist/src/bitgo/bitcoincash/address.d.ts +0 -1
  29. package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -1
  30. package/dist/src/bitgo/bitcoincash/address.js +11 -12
  31. package/dist/src/bitgo/bitcoincash/index.js +6 -2
  32. package/dist/src/bitgo/dash/DashPsbt.d.ts +1 -1
  33. package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -1
  34. package/dist/src/bitgo/dash/DashPsbt.js +4 -1
  35. package/dist/src/bitgo/dash/DashTransaction.d.ts +0 -1
  36. package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -1
  37. package/dist/src/bitgo/dash/DashTransaction.js +3 -3
  38. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +0 -1
  39. package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -1
  40. package/dist/src/bitgo/dash/DashTransactionBuilder.js +1 -1
  41. package/dist/src/bitgo/dash/index.js +6 -2
  42. package/dist/src/bitgo/index.d.ts +4 -1
  43. package/dist/src/bitgo/index.d.ts.map +1 -1
  44. package/dist/src/bitgo/index.js +10 -3
  45. package/dist/src/bitgo/keyutil.d.ts +9 -1
  46. package/dist/src/bitgo/keyutil.d.ts.map +1 -1
  47. package/dist/src/bitgo/keyutil.js +25 -4
  48. package/dist/src/bitgo/legacysafe/index.d.ts +0 -1
  49. package/dist/src/bitgo/legacysafe/index.d.ts.map +1 -1
  50. package/dist/src/bitgo/legacysafe/index.js +12 -9
  51. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts +1 -1
  52. package/dist/src/bitgo/litecoin/LitecoinPsbt.d.ts.map +1 -1
  53. package/dist/src/bitgo/litecoin/LitecoinPsbt.js +4 -1
  54. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts +1 -2
  55. package/dist/src/bitgo/litecoin/LitecoinTransaction.d.ts.map +1 -1
  56. package/dist/src/bitgo/litecoin/LitecoinTransaction.js +2 -2
  57. package/dist/src/bitgo/litecoin/index.js +6 -2
  58. package/dist/src/bitgo/nonStandardHalfSigned.js +2 -3
  59. package/dist/src/bitgo/outputScripts.d.ts +8 -8
  60. package/dist/src/bitgo/outputScripts.d.ts.map +1 -1
  61. package/dist/src/bitgo/outputScripts.js +56 -39
  62. package/dist/src/bitgo/parseInput.d.ts +7 -8
  63. package/dist/src/bitgo/parseInput.d.ts.map +1 -1
  64. package/dist/src/bitgo/parseInput.js +14 -15
  65. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +0 -1
  66. package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -1
  67. package/dist/src/bitgo/psbt/fromHalfSigned.js +7 -8
  68. package/dist/src/bitgo/psbt/scriptTypes.d.ts +0 -1
  69. package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -1
  70. package/dist/src/bitgo/psbt/scriptTypes.js +7 -8
  71. package/dist/src/bitgo/signature.d.ts +2 -3
  72. package/dist/src/bitgo/signature.d.ts.map +1 -1
  73. package/dist/src/bitgo/signature.js +25 -17
  74. package/dist/src/bitgo/tnumber.js +2 -3
  75. package/dist/src/bitgo/transaction.d.ts +13 -1
  76. package/dist/src/bitgo/transaction.d.ts.map +1 -1
  77. package/dist/src/bitgo/transaction.js +49 -23
  78. package/dist/src/bitgo/transactionAmounts.d.ts +9 -0
  79. package/dist/src/bitgo/transactionAmounts.d.ts.map +1 -0
  80. package/dist/src/bitgo/transactionAmounts.js +32 -0
  81. package/dist/src/bitgo/types.d.ts +8 -2
  82. package/dist/src/bitgo/types.d.ts.map +1 -1
  83. package/dist/src/bitgo/types.js +12 -4
  84. package/dist/src/bitgo/wallet/Psbt.d.ts +43 -19
  85. package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -1
  86. package/dist/src/bitgo/wallet/Psbt.js +112 -50
  87. package/dist/src/bitgo/wallet/ScriptId.d.ts +14 -0
  88. package/dist/src/bitgo/wallet/ScriptId.d.ts.map +1 -0
  89. package/dist/src/bitgo/wallet/ScriptId.js +28 -0
  90. package/dist/src/bitgo/wallet/Unspent.d.ts +23 -16
  91. package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -1
  92. package/dist/src/bitgo/wallet/Unspent.js +68 -64
  93. package/dist/src/bitgo/wallet/WalletKeys.d.ts +1 -2
  94. package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -1
  95. package/dist/src/bitgo/wallet/WalletKeys.js +3 -3
  96. package/dist/src/bitgo/wallet/WalletOutput.d.ts +60 -8
  97. package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -1
  98. package/dist/src/bitgo/wallet/WalletOutput.js +158 -63
  99. package/dist/src/bitgo/wallet/WalletScripts.js +4 -5
  100. package/dist/src/bitgo/wallet/WalletUnspentSigner.js +7 -7
  101. package/dist/src/bitgo/wallet/chains.d.ts +3 -3
  102. package/dist/src/bitgo/wallet/chains.d.ts.map +1 -1
  103. package/dist/src/bitgo/wallet/chains.js +10 -10
  104. package/dist/src/bitgo/wallet/index.d.ts +3 -0
  105. package/dist/src/bitgo/wallet/index.d.ts.map +1 -1
  106. package/dist/src/bitgo/wallet/index.js +9 -2
  107. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts +50 -0
  108. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.d.ts.map +1 -0
  109. package/dist/src/bitgo/wallet/psbt/PsbtOutputs.js +85 -0
  110. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts +32 -0
  111. package/dist/src/bitgo/wallet/psbt/RootNodes.d.ts.map +1 -0
  112. package/dist/src/bitgo/wallet/psbt/RootNodes.js +123 -0
  113. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +1 -2
  114. package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -1
  115. package/dist/src/bitgo/zcash/ZcashBufferutils.js +15 -15
  116. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +1 -2
  117. package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -1
  118. package/dist/src/bitgo/zcash/ZcashPsbt.js +12 -17
  119. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +3 -2
  120. package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -1
  121. package/dist/src/bitgo/zcash/ZcashTransaction.js +31 -21
  122. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +0 -1
  123. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -1
  124. package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +6 -4
  125. package/dist/src/bitgo/zcash/address.d.ts +0 -1
  126. package/dist/src/bitgo/zcash/address.d.ts.map +1 -1
  127. package/dist/src/bitgo/zcash/address.js +7 -8
  128. package/dist/src/bitgo/zcash/hashZip0244.d.ts +1 -2
  129. package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -1
  130. package/dist/src/bitgo/zcash/hashZip0244.js +9 -10
  131. package/dist/src/bitgo/zcash/index.js +6 -2
  132. package/dist/src/classify.d.ts +0 -1
  133. package/dist/src/classify.d.ts.map +1 -1
  134. package/dist/src/classify.js +5 -5
  135. package/dist/src/index.d.ts +1 -0
  136. package/dist/src/index.d.ts.map +1 -1
  137. package/dist/src/index.js +8 -3
  138. package/dist/src/networks.d.ts +2 -2
  139. package/dist/src/networks.d.ts.map +1 -1
  140. package/dist/src/networks.js +67 -21
  141. package/dist/src/noble_ecc.d.ts +7 -7
  142. package/dist/src/noble_ecc.d.ts.map +1 -1
  143. package/dist/src/noble_ecc.js +5 -5
  144. package/dist/src/payments/p2tr.js +13 -18
  145. package/dist/src/payments/p2tr_ns.js +3 -5
  146. package/dist/src/taproot.d.ts +1 -2
  147. package/dist/src/taproot.d.ts.map +1 -1
  148. package/dist/src/taproot.js +21 -22
  149. package/dist/src/templates/multisig/input.d.ts +0 -1
  150. package/dist/src/templates/multisig/input.d.ts.map +1 -1
  151. package/dist/src/templates/multisig/input.js +2 -3
  152. package/dist/src/templates/multisig/output.d.ts +0 -1
  153. package/dist/src/templates/multisig/output.d.ts.map +1 -1
  154. package/dist/src/templates/multisig/output.js +2 -3
  155. package/dist/src/templates/nulldata.d.ts +0 -1
  156. package/dist/src/templates/nulldata.d.ts.map +1 -1
  157. package/dist/src/templates/nulldata.js +3 -3
  158. package/dist/src/templates/pubkey/input.d.ts +0 -1
  159. package/dist/src/templates/pubkey/input.d.ts.map +1 -1
  160. package/dist/src/templates/pubkey/input.js +2 -3
  161. package/dist/src/templates/pubkey/output.d.ts +0 -1
  162. package/dist/src/templates/pubkey/output.d.ts.map +1 -1
  163. package/dist/src/templates/pubkey/output.js +2 -3
  164. package/dist/src/templates/pubkeyhash/input.d.ts +0 -1
  165. package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -1
  166. package/dist/src/templates/pubkeyhash/input.js +2 -3
  167. package/dist/src/templates/pubkeyhash/output.d.ts +0 -1
  168. package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -1
  169. package/dist/src/templates/pubkeyhash/output.js +2 -3
  170. package/dist/src/templates/scripthash/input.d.ts +0 -1
  171. package/dist/src/templates/scripthash/input.d.ts.map +1 -1
  172. package/dist/src/templates/scripthash/input.js +2 -3
  173. package/dist/src/templates/scripthash/output.d.ts +0 -1
  174. package/dist/src/templates/scripthash/output.d.ts.map +1 -1
  175. package/dist/src/templates/scripthash/output.js +2 -3
  176. package/dist/src/templates/taproot/input.d.ts +0 -1
  177. package/dist/src/templates/taproot/input.d.ts.map +1 -1
  178. package/dist/src/templates/taproot/input.js +2 -3
  179. package/dist/src/templates/taproot/output.d.ts +0 -1
  180. package/dist/src/templates/taproot/output.d.ts.map +1 -1
  181. package/dist/src/templates/taproot/output.js +2 -3
  182. package/dist/src/templates/taprootnofn/input.d.ts +0 -1
  183. package/dist/src/templates/taprootnofn/input.d.ts.map +1 -1
  184. package/dist/src/templates/taprootnofn/input.js +2 -3
  185. package/dist/src/templates/taprootnofn/output.d.ts +0 -1
  186. package/dist/src/templates/taprootnofn/output.d.ts.map +1 -1
  187. package/dist/src/templates/taprootnofn/output.js +2 -3
  188. package/dist/src/templates/witnesscommitment/output.d.ts +0 -1
  189. package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -1
  190. package/dist/src/templates/witnesscommitment/output.js +4 -5
  191. package/dist/src/templates/witnesspubkeyhash/input.d.ts +0 -1
  192. package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -1
  193. package/dist/src/templates/witnesspubkeyhash/input.js +2 -3
  194. package/dist/src/templates/witnesspubkeyhash/output.d.ts +0 -1
  195. package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -1
  196. package/dist/src/templates/witnesspubkeyhash/output.js +2 -3
  197. package/dist/src/templates/witnessscripthash/input.d.ts +0 -1
  198. package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -1
  199. package/dist/src/templates/witnessscripthash/input.js +2 -3
  200. package/dist/src/templates/witnessscripthash/output.d.ts +0 -1
  201. package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -1
  202. package/dist/src/templates/witnessscripthash/output.js +2 -3
  203. package/dist/src/testutil/index.js +6 -2
  204. package/dist/src/testutil/keys.d.ts +4 -4
  205. package/dist/src/testutil/keys.d.ts.map +1 -1
  206. package/dist/src/testutil/keys.js +10 -11
  207. package/dist/src/testutil/mock.d.ts +1 -2
  208. package/dist/src/testutil/mock.d.ts.map +1 -1
  209. package/dist/src/testutil/mock.js +21 -21
  210. package/dist/src/testutil/psbt.d.ts +36 -21
  211. package/dist/src/testutil/psbt.d.ts.map +1 -1
  212. package/dist/src/testutil/psbt.js +51 -37
  213. package/dist/src/testutil/transaction.d.ts +2 -2
  214. package/dist/src/testutil/transaction.d.ts.map +1 -1
  215. package/dist/src/testutil/transaction.js +18 -18
  216. package/dist/src/transaction_builder.d.ts +0 -1
  217. package/dist/src/transaction_builder.d.ts.map +1 -1
  218. package/dist/src/transaction_builder.js +13 -18
  219. package/package.json +9 -11
@@ -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
  }
@@ -50,26 +52,31 @@ export declare function psbtIncludesUnspentAtIndex(psbt: UtxoPsbt, inputIndex: n
50
52
  * @param u
51
53
  * @param redeemScript Only overrides if there is no redeemScript in the input currently
52
54
  */
53
- export declare function updateReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, inputIndex: number, u: Unspent<bigint>, redeemScript?: Buffer): void;
54
- export declare function addReplayProtectionUnspentToPsbt(psbt: UtxoPsbt, u: Unspent<bigint>, redeemScript: Buffer,
55
- /**
56
- * @deprecated
57
- */
58
- network?: Network): void;
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;
59
61
  /**
60
62
  * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
61
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
+ *
62
67
  * @param psbt
63
68
  * @param inputIndex
64
69
  * @param u
65
70
  * @param rootWalletKeys
66
71
  * @param signer
67
72
  * @param cosigner
73
+ * @param customParams
68
74
  */
69
- export declare function updateWalletUnspentForPsbt(psbt: UtxoPsbt, inputIndex: number, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName): void;
70
- export declare function addWalletUnspentToPsbt(psbt: UtxoPsbt, u: WalletUnspent<bigint>, rootWalletKeys: RootWalletKeys, signer: KeyName, cosigner: KeyName,
71
- /**
72
- * @deprecated
73
- */
74
- 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;
75
82
  //# sourceMappingURL=Unspent.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"Unspent.d.ts","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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"}
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.updateWalletUnspentForPsbt = exports.addReplayProtectionUnspentToPsbt = exports.updateReplayProtectionUnspentToPsbt = exports.psbtIncludesUnspentAtIndex = 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");
@@ -12,21 +20,25 @@ const transaction_1 = require("../transaction");
12
20
  const parseInput_1 = require("../parseInput");
13
21
  const utils_1 = require("bip174/src/lib/utils");
14
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;
15
29
  function isWalletUnspent(u) {
16
30
  return u.chain !== undefined;
17
31
  }
18
- exports.isWalletUnspent = isWalletUnspent;
19
32
  function signInputWithUnspent(txBuilder, inputIndex, unspent, unspentSigner) {
20
33
  const { walletKeys, signer, cosigner } = unspentSigner.deriveForChainAndIndex(unspent.chain, unspent.index);
21
- const scriptType = outputScripts_1.scriptTypeForChain(unspent.chain);
22
- const pubScript = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType).scriptPubKey;
23
- 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);
24
37
  if (!pubScript.equals(pubScriptExpected)) {
25
38
  throw new Error(`pubscript mismatch: expected ${pubScriptExpected.toString('hex')} got ${pubScript.toString('hex')}`);
26
39
  }
27
- 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);
28
41
  }
29
- exports.signInputWithUnspent = signInputWithUnspent;
30
42
  /**
31
43
  * @param tx
32
44
  * @param inputIndex
@@ -35,7 +47,6 @@ exports.signInputWithUnspent = signInputWithUnspent;
35
47
  * @return triple of booleans indicating a valid signature for each pubkey
36
48
  */
37
49
  function verifySignatureWithUnspent(tx, inputIndex, unspents, walletKeys) {
38
- var _a, _b;
39
50
  if (tx.ins.length !== unspents.length) {
40
51
  throw new Error(`input length must match unspents length`);
41
52
  }
@@ -45,21 +56,20 @@ function verifySignatureWithUnspent(tx, inputIndex, unspents, walletKeys) {
45
56
  throw new Error(`no input at index ${inputIndex}`);
46
57
  }
47
58
  const unspent = unspents[inputIndex];
48
- 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)) {
49
60
  return [false, false, false];
50
61
  }
51
- const parsedInput = parseInput_1.parseSignatureScript(input);
52
- 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));
53
64
  // If it is a taproot keyPathSpend input, the only valid signature combinations is user-bitgo. We can
54
65
  // only verify that the aggregated signature is valid, not that the individual partial-signature is valid.
55
66
  // Therefore, we can only say that either all partial signatures are valid, or none are.
56
67
  if (parsedInput.scriptType === 'taprootKeyPathSpend') {
57
- const result = signature_1.getSignatureVerifications(tx, inputIndex, unspent.value, undefined, prevOutputs);
68
+ const result = (0, signature_1.getSignatureVerifications)(tx, inputIndex, unspent.value, undefined, prevOutputs);
58
69
  return result.length === 1 && result[0].signature ? [true, false, true] : [false, false, false];
59
70
  }
60
- 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);
61
72
  }
62
- exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
63
73
  /**
64
74
  * @param psbt
65
75
  * @param inputIndex
@@ -67,12 +77,11 @@ exports.verifySignatureWithUnspent = verifySignatureWithUnspent;
67
77
  * @returns true iff the unspent ID on the unspent and psbt input match
68
78
  */
69
79
  function psbtIncludesUnspentAtIndex(psbt, inputIndex, id) {
70
- utils_1.checkForInput(psbt.data.inputs, inputIndex);
71
- const { txid, vout } = Unspent_1.parseOutputId(id);
72
- const psbtOutPoint = Unspent_1.getOutputIdForInput(psbt.txInputs[inputIndex]);
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]);
73
83
  return psbtOutPoint.txid === txid && psbtOutPoint.vout === vout;
74
84
  }
75
- exports.psbtIncludesUnspentAtIndex = psbtIncludesUnspentAtIndex;
76
85
  /**
77
86
  * Update the psbt input at the given index
78
87
  * @param psbt
@@ -80,87 +89,87 @@ exports.psbtIncludesUnspentAtIndex = psbtIncludesUnspentAtIndex;
80
89
  * @param u
81
90
  * @param redeemScript Only overrides if there is no redeemScript in the input currently
82
91
  */
83
- function updateReplayProtectionUnspentToPsbt(psbt, inputIndex, u, redeemScript) {
92
+ function updateReplayProtectionUnspentToPsbt(psbt, inputIndex, u, redeemScript, customParams) {
84
93
  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
85
94
  throw new Error(`unspent does not correspond to psbt input`);
86
95
  }
87
- const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
96
+ const input = (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
88
97
  if (redeemScript && !input.redeemScript) {
89
98
  psbt.updateInput(inputIndex, { redeemScript });
90
99
  }
91
100
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
92
101
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
93
102
  // segwit transactions
94
- const isZcash = __1.getMainnet(psbt.network) === __1.networks.zcash;
95
- 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) {
96
105
  throw new Error('Error, require previous tx to add to PSBT');
97
106
  }
98
- if (isZcash && !input.witnessUtxo) {
99
- const { script, value } = Unspent_1.toPrevOutput(u, psbt.network);
107
+ if ((isZcash && !input.witnessUtxo) || customParams?.skipNonWitnessUtxo) {
108
+ const { script, value } = (0, Unspent_1.toPrevOutput)(u, psbt.network);
100
109
  psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
101
110
  }
102
111
  else if (!isZcash && !input.nonWitnessUtxo) {
103
112
  psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
104
113
  }
114
+ const sighashType = (0, signature_1.getDefaultSigHash)(psbt.network);
115
+ if (psbt.data.inputs[inputIndex].sighashType === undefined) {
116
+ psbt.updateInput(inputIndex, { sighashType });
117
+ }
105
118
  }
106
- exports.updateReplayProtectionUnspentToPsbt = updateReplayProtectionUnspentToPsbt;
107
- function addUnspentToPsbt(psbt, id) {
108
- const { txid, vout } = Unspent_1.parseOutputId(id);
119
+ function addUnspentToPsbt(psbt, id, { sequenceNumber = exports.TX_INPUT_SEQUENCE_NUMBER_FINAL } = {}) {
120
+ const { txid, vout } = (0, Unspent_1.parseOutputId)(id);
109
121
  psbt.addInput({
110
122
  hash: txid,
111
123
  index: vout,
124
+ sequence: sequenceNumber,
112
125
  });
113
126
  }
114
- function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript,
115
- /**
116
- * @deprecated
117
- */
118
- network = psbt.network) {
119
- if (psbt.network !== network) {
120
- throw new Error('psbt network does not match network');
121
- }
127
+ function addReplayProtectionUnspentToPsbt(psbt, u, redeemScript, customParams) {
122
128
  addUnspentToPsbt(psbt, u.id);
123
- updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript);
129
+ updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript, customParams);
124
130
  }
125
- exports.addReplayProtectionUnspentToPsbt = addReplayProtectionUnspentToPsbt;
126
131
  /**
127
132
  * Update the PSBT with the unspent data for the input at the given index if the data is not there already.
128
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
+ *
129
137
  * @param psbt
130
138
  * @param inputIndex
131
139
  * @param u
132
140
  * @param rootWalletKeys
133
141
  * @param signer
134
142
  * @param cosigner
143
+ * @param customParams
135
144
  */
136
- function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer, cosigner) {
145
+ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer, cosigner, customParams) {
137
146
  if (!psbtIncludesUnspentAtIndex(psbt, inputIndex, u.id)) {
138
147
  throw new Error(`unspent does not correspond to psbt input`);
139
148
  }
140
- const input = utils_1.checkForInput(psbt.data.inputs, inputIndex);
149
+ const input = (0, utils_1.checkForInput)(psbt.data.inputs, inputIndex);
141
150
  // Because Zcash directly hashes the value for non-segwit transactions, we do not need to check indirectly
142
151
  // with the previous transaction. Therefore, we can treat Zcash non-segwit transactions as Bitcoin
143
152
  // segwit transactions
144
- const isZcashOrSegwit = chains_1.isSegwit(u.chain) || __1.getMainnet(psbt.network) === __1.networks.zcash;
145
- if (isZcashOrSegwit && !input.witnessUtxo) {
146
- const { script, value } = Unspent_1.toPrevOutput(u, psbt.network);
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);
147
156
  psbt.updateInput(inputIndex, { witnessUtxo: { script, value } });
148
157
  }
149
158
  else if (!isZcashOrSegwit) {
150
- if (!Unspent_1.isUnspentWithPrevTx(u)) {
159
+ if (!(0, Unspent_1.isUnspentWithPrevTx)(u)) {
151
160
  throw new Error('Error, require previous tx to add to PSBT');
152
161
  }
153
162
  if (!input.witnessUtxo && !input.nonWitnessUtxo) {
154
163
  // Force the litecoin transaction to have no MWEB advanced transaction flag
155
- if (__1.getMainnet(psbt.network) === __1.networks.litecoin) {
156
- u.prevTx = transaction_1.createTransactionFromBuffer(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();
164
+ if ((0, __1.getMainnet)(psbt.network) === __1.networks.litecoin) {
165
+ u.prevTx = (0, transaction_1.createTransactionFromBuffer)(u.prevTx, psbt.network, { amountType: 'bigint' }).toBuffer();
157
166
  }
158
167
  psbt.updateInput(inputIndex, { nonWitnessUtxo: u.prevTx });
159
168
  }
160
169
  }
161
170
  const walletKeys = rootWalletKeys.deriveForChainAndIndex(u.chain, u.index);
162
- const scriptType = outputScripts_1.scriptTypeForChain(u.chain);
163
- const sighashType = signature_1.getDefaultSigHash(psbt.network, scriptType);
171
+ const scriptType = (0, outputScripts_1.scriptTypeForChain)(u.chain);
172
+ const sighashType = (0, signature_1.getDefaultSigHash)(psbt.network, scriptType);
164
173
  if (psbt.data.inputs[inputIndex].sighashType === undefined) {
165
174
  psbt.updateInput(inputIndex, { sighashType });
166
175
  }
@@ -183,7 +192,7 @@ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer,
183
192
  psbt.updateInput(inputIndex, {
184
193
  tapBip32Derivation: [signer, cosigner].map((key) => ({
185
194
  leafHashes: [leafHash],
186
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
195
+ pubkey: (0, outputScripts_1.toXOnlyPublicKey)(walletKeys[key].publicKey),
187
196
  path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
188
197
  masterFingerprint: rootWalletKeys[key].fingerprint,
189
198
  })),
@@ -191,12 +200,12 @@ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer,
191
200
  }
192
201
  }
193
202
  else if (scriptType === 'p2trMusig2') {
194
- const { internalPubkey: tapInternalKey, outputPubkey: tapOutputKey, taptreeRoot, } = outputScripts_1.createKeyPathP2trMusig2(walletKeys.publicKeys);
203
+ const { internalPubkey: tapInternalKey, outputPubkey: tapOutputKey, taptreeRoot, } = (0, outputScripts_1.createKeyPathP2trMusig2)(walletKeys.publicKeys);
195
204
  if (psbt.getProprietaryKeyVals(inputIndex, {
196
205
  identifier: PsbtUtil_1.PSBT_PROPRIETARY_IDENTIFIER,
197
206
  subtype: PsbtUtil_1.ProprietaryKeySubtype.MUSIG2_PARTICIPANT_PUB_KEYS,
198
207
  }).length === 0) {
199
- const participantsKeyValData = Musig2_1.encodePsbtMusig2Participants({
208
+ const participantsKeyValData = (0, Musig2_1.encodePsbtMusig2Participants)({
200
209
  tapOutputKey,
201
210
  tapInternalKey,
202
211
  participantPubKeys: [walletKeys.user.publicKey, walletKeys.bitgo.publicKey],
@@ -217,7 +226,7 @@ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer,
217
226
  psbt.updateInput(inputIndex, {
218
227
  tapBip32Derivation: [signer, cosigner].map((key) => ({
219
228
  leafHashes: [],
220
- pubkey: outputScripts_1.toXOnlyPublicKey(walletKeys[key].publicKey),
229
+ pubkey: (0, outputScripts_1.toXOnlyPublicKey)(walletKeys[key].publicKey),
221
230
  path: rootWalletKeys.getDerivationPath(rootWalletKeys[key], u.chain, u.index),
222
231
  masterFingerprint: rootWalletKeys[key].fingerprint,
223
232
  })),
@@ -234,7 +243,7 @@ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer,
234
243
  })),
235
244
  });
236
245
  }
237
- const { witnessScript, redeemScript } = outputScripts_1.createOutputScript2of3(walletKeys.publicKeys, scriptType);
246
+ const { witnessScript, redeemScript } = (0, outputScripts_1.createOutputScript2of3)(walletKeys.publicKeys, scriptType);
238
247
  if (witnessScript && !input.witnessScript) {
239
248
  psbt.updateInput(inputIndex, { witnessScript });
240
249
  }
@@ -243,17 +252,12 @@ function updateWalletUnspentForPsbt(psbt, inputIndex, u, rootWalletKeys, signer,
243
252
  }
244
253
  }
245
254
  }
246
- exports.updateWalletUnspentForPsbt = updateWalletUnspentForPsbt;
247
- function addWalletUnspentToPsbt(psbt, u, rootWalletKeys, signer, cosigner,
248
- /**
249
- * @deprecated
250
- */
251
- network = psbt.network) {
252
- if (psbt.network !== network) {
253
- throw new Error('psbt network does not match network');
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;
254
259
  }
255
- addUnspentToPsbt(psbt, u.id);
256
- updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner);
260
+ addUnspentToPsbt(psbt, u.id, { sequenceNumber });
261
+ updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner, customParams ? { skipNonWitnessUtxo: customParams.skipNonWitnessUtxo } : {});
257
262
  }
258
- exports.addWalletUnspentToPsbt = addWalletUnspentToPsbt;
259
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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","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\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\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): 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) {\n    throw new Error('Error, require previous tx to add to PSBT');\n  }\n  if (isZcash && !input.witnessUtxo) {\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\nfunction addUnspentToPsbt(psbt: UtxoPsbt, id: string): void {\n  const { txid, vout } = parseOutputId(id);\n  psbt.addInput({\n    hash: txid,\n    index: vout,\n  });\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 (psbt.network !== network) {\n    throw new Error('psbt network does not match network');\n  }\n  addUnspentToPsbt(psbt, u.id);\n  updateReplayProtectionUnspentToPsbt(psbt, psbt.inputCount - 1, u, redeemScript);\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 * @param psbt\n * @param inputIndex\n * @param u\n * @param rootWalletKeys\n * @param signer\n * @param cosigner\n */\nexport function updateWalletUnspentForPsbt(\n  psbt: UtxoPsbt,\n  inputIndex: number,\n  u: WalletUnspent<bigint>,\n  rootWalletKeys: RootWalletKeys,\n  signer: KeyName,\n  cosigner: KeyName\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 && !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  /**\n   * @deprecated\n   */\n  network: Network = psbt.network\n): void {\n  if (psbt.network !== network) {\n    throw new Error('psbt network does not match network');\n  }\n  addUnspentToPsbt(psbt, u.id);\n  updateWalletUnspentForPsbt(psbt, psbt.inputCount - 1, u, rootWalletKeys, signer, cosigner);\n}\n"]}
263
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"Unspent.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/Unspent.ts"],"names":[],"mappings":"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","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"}
@@ -1,10 +1,10 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RootWalletKeys = exports.DerivedWalletKeys = exports.WalletKeys = exports.eqPublicKey = void 0;
3
+ exports.RootWalletKeys = exports.DerivedWalletKeys = exports.WalletKeys = void 0;
4
+ exports.eqPublicKey = eqPublicKey;
4
5
  function eqPublicKey(a, b) {
5
6
  return a.publicKey.equals(b.publicKey);
6
7
  }
7
- exports.eqPublicKey = eqPublicKey;
8
8
  /**
9
9
  * Base class for RootWalletKeys and DerivedWalletKeys.
10
10
  * Keys can be either public keys or private keys.
@@ -101,4 +101,4 @@ class RootWalletKeys extends WalletKeys {
101
101
  }
102
102
  exports.RootWalletKeys = RootWalletKeys;
103
103
  RootWalletKeys.defaultPrefix = '0/0';
104
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"WalletKeys.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletKeys.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Classes for deriving key triples for wallet addresses.\n *\n * By default, BitGo wallets consist of a triple of bip32 extend keypairs.\n * Every wallet address can be identified by _(chain: number, index: number)_.\n * The key set for a particular address can be obtained by deriving with the path\n * `0/0/${chain}/${index}`. (In rare cases the prefix 0/0 can be different)\n *\n * Since we never use other derivations for utxo address scripts, the classes defined here only\n * allow exactly one level of derivation.\n */\nimport { BIP32Interface } from 'bip32';\n\nimport { Triple } from '../types';\n\nexport type KeyName = 'user' | 'backup' | 'bitgo';\n\nexport function eqPublicKey(a: BIP32Interface, b: BIP32Interface): boolean {\n  return a.publicKey.equals(b.publicKey);\n}\n\n/**\n * Base class for RootWalletKeys and DerivedWalletKeys.\n * Keys can be either public keys or private keys.\n */\nexport class WalletKeys {\n  public readonly publicKeys: Triple<Buffer>;\n\n  /**\n   * @param triple - bip32 key triple\n   */\n  constructor(public readonly triple: Triple<BIP32Interface>) {\n    triple.forEach((a, i) => {\n      triple.forEach((b, j) => {\n        if (eqPublicKey(a, b) && i !== j) {\n          throw new Error(`wallet keys must be distinct`);\n        }\n      });\n    });\n\n    this.publicKeys = this.triple.map((k) => k.publicKey) as Triple<Buffer>;\n  }\n\n  get user(): BIP32Interface {\n    return this.triple[0];\n  }\n\n  get backup(): BIP32Interface {\n    return this.triple[1];\n  }\n\n  get bitgo(): BIP32Interface {\n    return this.triple[2];\n  }\n}\n\n/**\n * Set of WalletKeys derived from RootWalletKeys. Suitable for signing transaction inputs.\n * Contains reference to the RootWalletKeys this was derived from as well as the paths used\n * for derivation.\n */\nexport class DerivedWalletKeys extends WalletKeys {\n  /**\n   * @param parent - wallet keys to derive from\n   * @param paths - paths to derive with\n   */\n  constructor(public parent: RootWalletKeys, public paths: Triple<string>) {\n    super(parent.triple.map((k, i) => k.derivePath(paths[i])) as Triple<BIP32Interface>);\n  }\n}\n\n/**\n * Set of root wallet keys, typically instantiated using the wallet xpub triple.\n */\nexport class RootWalletKeys extends WalletKeys {\n  static readonly defaultPrefix = '0/0';\n\n  /**\n   * @param triple - bip32 key triple\n   * @param derivationPrefixes - Certain v1 wallets or their migrated v2 counterparts\n   *                             can have a nonstandard prefix.\n   */\n  constructor(\n    triple: Triple<BIP32Interface>,\n    public readonly derivationPrefixes: Triple<string> = [\n      RootWalletKeys.defaultPrefix,\n      RootWalletKeys.defaultPrefix,\n      RootWalletKeys.defaultPrefix,\n    ]\n  ) {\n    super(triple);\n\n    derivationPrefixes.forEach((p) => {\n      if (p.startsWith('/') || p.endsWith('/')) {\n        throw new Error(`derivation prefix must not start or end with a slash`);\n      }\n    });\n  }\n\n  /**\n   * @param key\n   * @param chain\n   * @param index\n   * @return full derivation path for key, including key-specific prefix\n   */\n  getDerivationPath(key: BIP32Interface, chain: number, index: number): string {\n    if (!this.derivationPrefixes) {\n      throw new Error(`no derivation prefixes`);\n    }\n    const prefix = this.derivationPrefixes.find((prefix, i) => eqPublicKey(key, this.triple[i]));\n    if (prefix === undefined) {\n      throw new Error(`key not in walletKeys`);\n    }\n    return `${prefix}/${chain}/${index}`;\n  }\n\n  /**\n   * @param chain\n   * @param index\n   * @return walletKeys for a particular address identified by (chain, index)\n   */\n  deriveForChainAndIndex(chain: number, index: number): DerivedWalletKeys {\n    return new DerivedWalletKeys(\n      this,\n      this.triple.map((k) => this.getDerivationPath(k, chain, index)) as Triple<string>\n    );\n  }\n}\n"]}
104
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"WalletKeys.js","sourceRoot":"","sources":["../../../../src/bitgo/wallet/WalletKeys.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * Classes for deriving key triples for wallet addresses.\n *\n * By default, BitGo wallets consist of a triple of bip32 extend keypairs.\n * Every wallet address can be identified by _(chain: number, index: number)_.\n * The key set for a particular address can be obtained by deriving with the path\n * `0/0/${chain}/${index}`. (In rare cases the prefix 0/0 can be different)\n *\n * Since we never use other derivations for utxo address scripts, the classes defined here only\n * allow exactly one level of derivation.\n */\nimport { BIP32Interface } from 'bip32';\n\nimport { Triple } from '../types';\n\nexport type KeyName = 'user' | 'backup' | 'bitgo';\n\nexport function eqPublicKey(a: BIP32Interface, b: BIP32Interface): boolean {\n  return a.publicKey.equals(b.publicKey);\n}\n\n/**\n * Base class for RootWalletKeys and DerivedWalletKeys.\n * Keys can be either public keys or private keys.\n */\nexport class WalletKeys {\n  public readonly publicKeys: Triple<Buffer>;\n\n  /**\n   * @param triple - bip32 key triple\n   */\n  constructor(public readonly triple: Triple<BIP32Interface>) {\n    triple.forEach((a, i) => {\n      triple.forEach((b, j) => {\n        if (eqPublicKey(a, b) && i !== j) {\n          throw new Error(`wallet keys must be distinct`);\n        }\n      });\n    });\n\n    this.publicKeys = this.triple.map((k) => k.publicKey) as Triple<Buffer>;\n  }\n\n  get user(): BIP32Interface {\n    return this.triple[0];\n  }\n\n  get backup(): BIP32Interface {\n    return this.triple[1];\n  }\n\n  get bitgo(): BIP32Interface {\n    return this.triple[2];\n  }\n}\n\n/**\n * Set of WalletKeys derived from RootWalletKeys. Suitable for signing transaction inputs.\n * Contains reference to the RootWalletKeys this was derived from as well as the paths used\n * for derivation.\n */\nexport class DerivedWalletKeys extends WalletKeys {\n  /**\n   * @param parent - wallet keys to derive from\n   * @param paths - paths to derive with\n   */\n  constructor(public parent: RootWalletKeys, public paths: Triple<string>) {\n    super(parent.triple.map((k, i) => k.derivePath(paths[i])) as Triple<BIP32Interface>);\n  }\n}\n\n/**\n * Set of root wallet keys, typically instantiated using the wallet xpub triple.\n */\nexport class RootWalletKeys extends WalletKeys {\n  static readonly defaultPrefix = '0/0';\n\n  /**\n   * @param triple - bip32 key triple\n   * @param derivationPrefixes - Certain v1 wallets or their migrated v2 counterparts\n   *                             can have a nonstandard prefix.\n   */\n  constructor(\n    triple: Triple<BIP32Interface>,\n    public readonly derivationPrefixes: Triple<string> = [\n      RootWalletKeys.defaultPrefix,\n      RootWalletKeys.defaultPrefix,\n      RootWalletKeys.defaultPrefix,\n    ]\n  ) {\n    super(triple);\n\n    derivationPrefixes.forEach((p) => {\n      if (p.startsWith('/') || p.endsWith('/')) {\n        throw new Error(`derivation prefix must not start or end with a slash`);\n      }\n    });\n  }\n\n  /**\n   * @param key\n   * @param chain\n   * @param index\n   * @return full derivation path for key, including key-specific prefix\n   */\n  getDerivationPath(key: BIP32Interface, chain: number, index: number): string {\n    if (!this.derivationPrefixes) {\n      throw new Error(`no derivation prefixes`);\n    }\n    const prefix = this.derivationPrefixes.find((prefix, i) => eqPublicKey(key, this.triple[i]));\n    if (prefix === undefined) {\n      throw new Error(`key not in walletKeys`);\n    }\n    return `${prefix}/${chain}/${index}`;\n  }\n\n  /**\n   * @param chain\n   * @param index\n   * @return walletKeys for a particular address identified by (chain, index)\n   */\n  deriveForChainAndIndex(chain: number, index: number): DerivedWalletKeys {\n    return new DerivedWalletKeys(\n      this,\n      this.triple.map((k) => this.getDerivationPath(k, chain, index)) as Triple<string>\n    );\n  }\n}\n"]}