@bitgo-beta/abstract-utxo 1.6.1-alpha.44 → 1.6.1-alpha.441

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 (795) hide show
  1. package/README.md +76 -0
  2. package/dist/cjs/src/abstractUtxoCoin.d.ts +435 -0
  3. package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -0
  4. package/dist/cjs/src/abstractUtxoCoin.js +657 -0
  5. package/dist/cjs/src/address/fixedScript.d.ts +49 -0
  6. package/dist/cjs/src/address/fixedScript.d.ts.map +1 -0
  7. package/dist/cjs/src/address/fixedScript.js +155 -0
  8. package/dist/cjs/src/address/index.d.ts +2 -0
  9. package/dist/cjs/src/address/index.d.ts.map +1 -0
  10. package/dist/cjs/src/address/index.js +8 -0
  11. package/dist/cjs/src/config.d.ts.map +1 -0
  12. package/dist/cjs/src/config.js +14 -0
  13. package/dist/cjs/src/descriptor/NamedDescriptor.d.ts +20 -0
  14. package/dist/cjs/src/descriptor/NamedDescriptor.d.ts.map +1 -0
  15. package/dist/cjs/src/descriptor/NamedDescriptor.js +79 -0
  16. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  17. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  18. package/dist/cjs/src/descriptor/assertDescriptorWalletAddress.js +66 -0
  19. package/dist/cjs/src/descriptor/builder/builder.d.ts +13 -0
  20. package/dist/cjs/src/descriptor/builder/builder.d.ts.map +1 -0
  21. package/dist/cjs/src/descriptor/builder/builder.js +37 -0
  22. package/dist/cjs/src/descriptor/builder/index.d.ts +3 -0
  23. package/dist/cjs/src/descriptor/builder/index.d.ts.map +1 -0
  24. package/dist/cjs/src/descriptor/builder/index.js +8 -0
  25. package/dist/cjs/src/descriptor/builder/parse.d.ts +5 -0
  26. package/dist/cjs/src/descriptor/builder/parse.d.ts.map +1 -0
  27. package/dist/cjs/src/descriptor/builder/parse.js +116 -0
  28. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  29. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  30. package/dist/cjs/src/descriptor/createWallet/createDescriptorWallet.js +41 -0
  31. package/dist/cjs/src/descriptor/createWallet/createDescriptors.d.ts +12 -0
  32. package/dist/cjs/src/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  33. package/dist/cjs/src/descriptor/createWallet/createDescriptors.js +33 -0
  34. package/dist/cjs/src/descriptor/createWallet/index.d.ts +3 -0
  35. package/dist/cjs/src/descriptor/createWallet/index.d.ts.map +1 -0
  36. package/dist/cjs/src/descriptor/createWallet/index.js +19 -0
  37. package/dist/cjs/src/descriptor/descriptorWallet.d.ts +19 -0
  38. package/dist/cjs/src/descriptor/descriptorWallet.d.ts.map +1 -0
  39. package/dist/cjs/src/descriptor/descriptorWallet.js +54 -0
  40. package/dist/cjs/src/descriptor/index.d.ts +8 -0
  41. package/dist/cjs/src/descriptor/index.d.ts.map +1 -0
  42. package/dist/cjs/src/descriptor/index.js +53 -0
  43. package/dist/cjs/src/descriptor/validatePolicy.d.ts +22 -0
  44. package/dist/cjs/src/descriptor/validatePolicy.d.ts.map +1 -0
  45. package/dist/cjs/src/descriptor/validatePolicy.js +92 -0
  46. package/dist/cjs/src/impl/bch/bch.d.ts +20 -0
  47. package/dist/cjs/src/impl/bch/bch.d.ts.map +1 -0
  48. package/dist/cjs/src/impl/bch/bch.js +74 -0
  49. package/dist/cjs/src/impl/bch/index.d.ts +3 -0
  50. package/dist/cjs/src/impl/bch/index.d.ts.map +1 -0
  51. package/dist/cjs/src/impl/bch/index.js +19 -0
  52. package/dist/cjs/src/impl/bch/tbch.d.ts +10 -0
  53. package/dist/cjs/src/impl/bch/tbch.d.ts.map +1 -0
  54. package/dist/cjs/src/impl/bch/tbch.js +48 -0
  55. package/dist/cjs/src/impl/bcha/bcha.d.ts +8 -0
  56. package/dist/cjs/src/impl/bcha/bcha.d.ts.map +1 -0
  57. package/dist/cjs/src/impl/bcha/bcha.js +48 -0
  58. package/dist/cjs/src/impl/bcha/index.d.ts +3 -0
  59. package/dist/cjs/src/impl/bcha/index.d.ts.map +1 -0
  60. package/dist/cjs/src/impl/bcha/index.js +19 -0
  61. package/dist/cjs/src/impl/bcha/tbcha.d.ts +10 -0
  62. package/dist/cjs/src/impl/bcha/tbcha.d.ts.map +1 -0
  63. package/dist/cjs/src/impl/bcha/tbcha.js +48 -0
  64. package/dist/cjs/src/impl/bsv/bsv.d.ts +8 -0
  65. package/dist/cjs/src/impl/bsv/bsv.d.ts.map +1 -0
  66. package/dist/cjs/src/impl/bsv/bsv.js +48 -0
  67. package/dist/cjs/src/impl/bsv/index.d.ts +3 -0
  68. package/dist/cjs/src/impl/bsv/index.d.ts.map +1 -0
  69. package/dist/cjs/src/impl/bsv/index.js +19 -0
  70. package/dist/cjs/src/impl/bsv/tbsv.d.ts +10 -0
  71. package/dist/cjs/src/impl/bsv/tbsv.d.ts.map +1 -0
  72. package/dist/cjs/src/impl/bsv/tbsv.js +48 -0
  73. package/dist/cjs/src/impl/btc/btc.d.ts +13 -0
  74. package/dist/cjs/src/impl/btc/btc.d.ts.map +1 -0
  75. package/dist/cjs/src/impl/btc/btc.js +55 -0
  76. package/dist/cjs/src/impl/btc/index.d.ts +7 -0
  77. package/dist/cjs/src/impl/btc/index.d.ts.map +1 -0
  78. package/dist/cjs/src/impl/btc/index.js +23 -0
  79. package/dist/cjs/src/impl/btc/inscriptionBuilder.d.ts +51 -0
  80. package/dist/cjs/src/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  81. package/dist/cjs/src/impl/btc/inscriptionBuilder.js +183 -0
  82. package/dist/cjs/src/impl/btc/tbtc.d.ts +10 -0
  83. package/dist/cjs/src/impl/btc/tbtc.d.ts.map +1 -0
  84. package/dist/cjs/src/impl/btc/tbtc.js +48 -0
  85. package/dist/cjs/src/impl/btc/tbtc4.d.ts +10 -0
  86. package/dist/cjs/src/impl/btc/tbtc4.d.ts.map +1 -0
  87. package/dist/cjs/src/impl/btc/tbtc4.js +48 -0
  88. package/dist/cjs/src/impl/btc/tbtcbgsig.d.ts +10 -0
  89. package/dist/cjs/src/impl/btc/tbtcbgsig.d.ts.map +1 -0
  90. package/dist/cjs/src/impl/btc/tbtcbgsig.js +48 -0
  91. package/dist/cjs/src/impl/btc/tbtcsig.d.ts +10 -0
  92. package/dist/cjs/src/impl/btc/tbtcsig.d.ts.map +1 -0
  93. package/dist/cjs/src/impl/btc/tbtcsig.js +48 -0
  94. package/dist/cjs/src/impl/btg/btg.d.ts +7 -0
  95. package/dist/cjs/src/impl/btg/btg.d.ts.map +1 -0
  96. package/dist/cjs/src/impl/btg/btg.js +48 -0
  97. package/dist/cjs/src/impl/btg/index.d.ts +2 -0
  98. package/dist/cjs/src/impl/btg/index.d.ts.map +1 -0
  99. package/dist/cjs/src/impl/btg/index.js +18 -0
  100. package/dist/cjs/src/impl/dash/dash.d.ts +7 -0
  101. package/dist/cjs/src/impl/dash/dash.d.ts.map +1 -0
  102. package/dist/cjs/src/impl/dash/dash.js +48 -0
  103. package/dist/cjs/src/impl/dash/index.d.ts +3 -0
  104. package/dist/cjs/src/impl/dash/index.d.ts.map +1 -0
  105. package/dist/cjs/src/impl/dash/index.js +19 -0
  106. package/dist/cjs/src/impl/dash/tdash.d.ts +10 -0
  107. package/dist/cjs/src/impl/dash/tdash.d.ts.map +1 -0
  108. package/dist/cjs/src/impl/dash/tdash.js +48 -0
  109. package/dist/cjs/src/impl/doge/doge.d.ts +32 -0
  110. package/dist/cjs/src/impl/doge/doge.d.ts.map +1 -0
  111. package/dist/cjs/src/impl/doge/doge.js +79 -0
  112. package/dist/cjs/src/impl/doge/index.d.ts +3 -0
  113. package/dist/cjs/src/impl/doge/index.d.ts.map +1 -0
  114. package/dist/cjs/src/impl/doge/index.js +19 -0
  115. package/dist/cjs/src/impl/doge/tdoge.d.ts +10 -0
  116. package/dist/cjs/src/impl/doge/tdoge.d.ts.map +1 -0
  117. package/dist/cjs/src/impl/doge/tdoge.js +48 -0
  118. package/dist/cjs/src/impl/index.d.ts +10 -0
  119. package/dist/cjs/src/impl/index.d.ts.map +1 -0
  120. package/dist/cjs/src/impl/index.js +46 -0
  121. package/dist/cjs/src/impl/ltc/index.d.ts +3 -0
  122. package/dist/cjs/src/impl/ltc/index.d.ts.map +1 -0
  123. package/dist/cjs/src/impl/ltc/index.js +19 -0
  124. package/dist/cjs/src/impl/ltc/ltc.d.ts +7 -0
  125. package/dist/cjs/src/impl/ltc/ltc.d.ts.map +1 -0
  126. package/dist/cjs/src/impl/ltc/ltc.js +52 -0
  127. package/dist/cjs/src/impl/ltc/tltc.d.ts +7 -0
  128. package/dist/cjs/src/impl/ltc/tltc.d.ts.map +1 -0
  129. package/dist/cjs/src/impl/ltc/tltc.js +51 -0
  130. package/dist/cjs/src/impl/zec/index.d.ts +3 -0
  131. package/dist/cjs/src/impl/zec/index.d.ts.map +1 -0
  132. package/dist/cjs/src/impl/zec/index.js +19 -0
  133. package/dist/cjs/src/impl/zec/tzec.d.ts +7 -0
  134. package/dist/cjs/src/impl/zec/tzec.d.ts.map +1 -0
  135. package/dist/cjs/src/impl/zec/tzec.js +48 -0
  136. package/dist/cjs/src/impl/zec/zec.d.ts +10 -0
  137. package/dist/cjs/src/impl/zec/zec.d.ts.map +1 -0
  138. package/dist/cjs/src/impl/zec/zec.js +48 -0
  139. package/dist/cjs/src/index.d.ts +21 -0
  140. package/dist/cjs/src/index.d.ts.map +1 -0
  141. package/dist/cjs/src/index.js +60 -0
  142. package/dist/cjs/src/keychains.d.ts +52 -0
  143. package/dist/cjs/src/keychains.d.ts.map +1 -0
  144. package/dist/cjs/src/keychains.js +136 -0
  145. package/dist/cjs/src/names.d.ts +26 -0
  146. package/dist/cjs/src/names.d.ts.map +1 -0
  147. package/dist/cjs/src/names.js +214 -0
  148. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  149. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  150. package/dist/cjs/src/offlineVault/OfflineVaultHalfSigned.js +26 -0
  151. package/dist/cjs/src/offlineVault/OfflineVaultSignable.d.ts +46 -0
  152. package/dist/cjs/src/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  153. package/dist/cjs/src/offlineVault/OfflineVaultSignable.js +55 -0
  154. package/dist/cjs/src/offlineVault/TransactionExplanation.d.ts +15 -0
  155. package/dist/cjs/src/offlineVault/TransactionExplanation.d.ts.map +1 -0
  156. package/dist/cjs/src/offlineVault/TransactionExplanation.js +16 -0
  157. package/dist/cjs/src/offlineVault/descriptor/index.d.ts +2 -0
  158. package/dist/cjs/src/offlineVault/descriptor/index.d.ts.map +1 -0
  159. package/dist/cjs/src/offlineVault/descriptor/index.js +18 -0
  160. package/dist/cjs/src/offlineVault/descriptor/transaction.d.ts +38 -0
  161. package/dist/cjs/src/offlineVault/descriptor/transaction.d.ts.map +1 -0
  162. package/dist/cjs/src/offlineVault/descriptor/transaction.js +80 -0
  163. package/dist/cjs/src/offlineVault/index.d.ts +6 -0
  164. package/dist/cjs/src/offlineVault/index.d.ts.map +1 -0
  165. package/dist/cjs/src/offlineVault/index.js +44 -0
  166. package/dist/{src → cjs/src}/recovery/RecoveryProvider.d.ts +1 -1
  167. package/dist/cjs/src/recovery/RecoveryProvider.d.ts.map +1 -0
  168. package/dist/cjs/src/recovery/RecoveryProvider.js +22 -0
  169. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts +89 -0
  170. package/dist/cjs/src/recovery/backupKeyRecovery.d.ts.map +1 -0
  171. package/dist/cjs/src/recovery/backupKeyRecovery.js +359 -0
  172. package/dist/{src → cjs/src}/recovery/baseApi.d.ts +3 -6
  173. package/dist/cjs/src/recovery/baseApi.d.ts.map +1 -0
  174. package/dist/cjs/src/recovery/baseApi.js +73 -0
  175. package/dist/{src → cjs/src}/recovery/coingeckoApi.d.ts +0 -3
  176. package/dist/cjs/src/recovery/coingeckoApi.d.ts.map +1 -0
  177. package/dist/cjs/src/recovery/coingeckoApi.js +44 -0
  178. package/dist/{src → cjs/src}/recovery/crossChainRecovery.d.ts +18 -7
  179. package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -0
  180. package/dist/cjs/src/recovery/crossChainRecovery.js +343 -0
  181. package/dist/{src → cjs/src}/recovery/index.d.ts +0 -1
  182. package/dist/cjs/src/recovery/index.d.ts.map +1 -0
  183. package/dist/{src → cjs/src}/recovery/index.js +6 -3
  184. package/dist/cjs/src/recovery/mempoolApi.d.ts.map +1 -0
  185. package/dist/cjs/src/recovery/mempoolApi.js +36 -0
  186. package/dist/cjs/src/recovery/psbt.d.ts +30 -0
  187. package/dist/cjs/src/recovery/psbt.d.ts.map +1 -0
  188. package/dist/cjs/src/recovery/psbt.js +204 -0
  189. package/dist/cjs/src/transaction/bip322.d.ts +27 -0
  190. package/dist/cjs/src/transaction/bip322.d.ts.map +1 -0
  191. package/dist/cjs/src/transaction/bip322.js +125 -0
  192. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts +2 -0
  193. package/dist/cjs/src/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  194. package/dist/cjs/src/transaction/common/verifyPayGoAmount.js +3 -0
  195. package/dist/cjs/src/transaction/decode.d.ts +11 -0
  196. package/dist/cjs/src/transaction/decode.d.ts.map +1 -0
  197. package/dist/cjs/src/transaction/decode.js +81 -0
  198. package/dist/cjs/src/transaction/descriptor/explainPsbt.d.ts +5 -0
  199. package/dist/cjs/src/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  200. package/dist/cjs/src/transaction/descriptor/explainPsbt.js +80 -0
  201. package/dist/cjs/src/transaction/descriptor/index.d.ts +7 -0
  202. package/dist/cjs/src/transaction/descriptor/index.d.ts.map +1 -0
  203. package/dist/cjs/src/transaction/descriptor/index.js +14 -0
  204. package/dist/cjs/src/transaction/descriptor/parse.d.ts +16 -0
  205. package/dist/cjs/src/transaction/descriptor/parse.d.ts.map +1 -0
  206. package/dist/cjs/src/transaction/descriptor/parse.js +116 -0
  207. package/dist/cjs/src/transaction/descriptor/parseToAmountType.d.ts +14 -0
  208. package/dist/cjs/src/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  209. package/dist/cjs/src/transaction/descriptor/parseToAmountType.js +60 -0
  210. package/dist/cjs/src/transaction/descriptor/recipient.d.ts +5 -0
  211. package/dist/cjs/src/transaction/descriptor/recipient.d.ts.map +1 -0
  212. package/dist/cjs/src/transaction/descriptor/recipient.js +3 -0
  213. package/dist/cjs/src/transaction/descriptor/signPsbt.d.ts +25 -0
  214. package/dist/cjs/src/transaction/descriptor/signPsbt.d.ts.map +1 -0
  215. package/dist/cjs/src/transaction/descriptor/signPsbt.js +43 -0
  216. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts +36 -0
  217. package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  218. package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +109 -0
  219. package/dist/cjs/src/transaction/explainTransaction.d.ts +18 -0
  220. package/dist/cjs/src/transaction/explainTransaction.d.ts.map +1 -0
  221. package/dist/cjs/src/transaction/explainTransaction.js +88 -0
  222. package/dist/cjs/src/transaction/fetchInputs.d.ts +26 -0
  223. package/dist/cjs/src/transaction/fetchInputs.d.ts.map +1 -0
  224. package/dist/cjs/src/transaction/fetchInputs.js +109 -0
  225. package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts +24 -0
  226. package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts.map +1 -0
  227. package/dist/cjs/src/transaction/fixedScript/SigningError.js +26 -0
  228. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +11 -0
  229. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  230. package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +67 -0
  231. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts +73 -0
  232. package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  233. package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +344 -0
  234. package/dist/cjs/src/transaction/fixedScript/index.d.ts +10 -0
  235. package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -0
  236. package/dist/cjs/src/transaction/fixedScript/index.js +32 -0
  237. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts +4 -0
  238. package/dist/cjs/src/transaction/fixedScript/musig2.d.ts.map +1 -0
  239. package/dist/cjs/src/transaction/fixedScript/musig2.js +3 -0
  240. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts +28 -0
  241. package/dist/cjs/src/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  242. package/dist/cjs/src/transaction/fixedScript/parseOutput.js +220 -0
  243. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts +8 -0
  244. package/dist/cjs/src/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  245. package/dist/cjs/src/transaction/fixedScript/parseTransaction.js +215 -0
  246. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts +7 -0
  247. package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  248. package/dist/cjs/src/transaction/fixedScript/replayProtection.js +78 -0
  249. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  250. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  251. package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.js +152 -0
  252. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts +30 -0
  253. package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  254. package/dist/cjs/src/transaction/fixedScript/signPsbt.js +174 -0
  255. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  256. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  257. package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.js +129 -0
  258. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts +17 -0
  259. package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  260. package/dist/cjs/src/transaction/fixedScript/signTransaction.js +50 -0
  261. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  262. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  263. package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +199 -0
  264. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  265. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  266. package/dist/cjs/src/transaction/getPayGoVerificationPubkey.js +53 -0
  267. package/dist/cjs/src/transaction/index.d.ts +8 -0
  268. package/dist/cjs/src/transaction/index.d.ts.map +1 -0
  269. package/dist/cjs/src/transaction/index.js +50 -0
  270. package/dist/cjs/src/transaction/outputDifference.d.ts +40 -0
  271. package/dist/cjs/src/transaction/outputDifference.d.ts.map +1 -0
  272. package/dist/cjs/src/transaction/outputDifference.js +47 -0
  273. package/dist/cjs/src/transaction/parseTransaction.d.ts +4 -0
  274. package/dist/cjs/src/transaction/parseTransaction.d.ts.map +1 -0
  275. package/dist/cjs/src/transaction/parseTransaction.js +48 -0
  276. package/dist/cjs/src/transaction/recipient.d.ts +29 -0
  277. package/dist/cjs/src/transaction/recipient.d.ts.map +1 -0
  278. package/dist/cjs/src/transaction/recipient.js +88 -0
  279. package/dist/cjs/src/transaction/signTransaction.d.ts +6 -0
  280. package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -0
  281. package/dist/cjs/src/transaction/signTransaction.js +105 -0
  282. package/dist/cjs/src/transaction/types.d.ts +49 -0
  283. package/dist/cjs/src/transaction/types.d.ts.map +1 -0
  284. package/dist/cjs/src/transaction/types.js +7 -0
  285. package/dist/cjs/src/transaction/verifyTransaction.d.ts +4 -0
  286. package/dist/cjs/src/transaction/verifyTransaction.d.ts.map +1 -0
  287. package/dist/cjs/src/transaction/verifyTransaction.js +50 -0
  288. package/dist/cjs/src/verifyKey.d.ts +29 -0
  289. package/dist/cjs/src/verifyKey.d.ts.map +1 -0
  290. package/dist/cjs/src/verifyKey.js +164 -0
  291. package/dist/cjs/src/wallet.d.ts +15 -0
  292. package/dist/cjs/src/wallet.d.ts.map +1 -0
  293. package/dist/cjs/src/wallet.js +8 -0
  294. package/dist/cjs/test/integration/impl/bch/bch.d.ts +2 -0
  295. package/dist/cjs/test/integration/impl/bch/bch.d.ts.map +1 -0
  296. package/dist/cjs/test/integration/impl/bch/bch.js +74 -0
  297. package/dist/cjs/test/unit/address.d.ts +2 -0
  298. package/dist/cjs/test/unit/address.d.ts.map +1 -0
  299. package/dist/cjs/test/unit/address.js +182 -0
  300. package/dist/cjs/test/unit/bip322.d.ts +2 -0
  301. package/dist/cjs/test/unit/bip322.d.ts.map +1 -0
  302. package/dist/cjs/test/unit/bip322.js +45 -0
  303. package/dist/cjs/test/unit/coins.d.ts +2 -0
  304. package/dist/cjs/test/unit/coins.d.ts.map +1 -0
  305. package/dist/cjs/test/unit/coins.js +97 -0
  306. package/dist/cjs/test/unit/customChangeWallet.d.ts +2 -0
  307. package/dist/cjs/test/unit/customChangeWallet.d.ts.map +1 -0
  308. package/dist/cjs/test/unit/customChangeWallet.js +154 -0
  309. package/dist/cjs/test/unit/customSigner.d.ts +3 -0
  310. package/dist/cjs/test/unit/customSigner.d.ts.map +1 -0
  311. package/dist/cjs/test/unit/customSigner.js +108 -0
  312. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts +2 -0
  313. package/dist/cjs/test/unit/descriptor/NamedDescriptor.d.ts.map +1 -0
  314. package/dist/cjs/test/unit/descriptor/NamedDescriptor.js +18 -0
  315. package/dist/cjs/test/unit/descriptor/builder.d.ts +2 -0
  316. package/dist/cjs/test/unit/descriptor/builder.d.ts.map +1 -0
  317. package/dist/cjs/test/unit/descriptor/builder.js +72 -0
  318. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts +2 -0
  319. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  320. package/dist/cjs/test/unit/descriptor/createWallet/createDescriptors.js +20 -0
  321. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts +2 -0
  322. package/dist/cjs/test/unit/descriptor/descriptorWallet.d.ts.map +1 -0
  323. package/dist/cjs/test/unit/descriptor/descriptorWallet.js +28 -0
  324. package/dist/cjs/test/unit/descriptorAddress.d.ts +3 -0
  325. package/dist/cjs/test/unit/descriptorAddress.d.ts.map +1 -0
  326. package/dist/cjs/test/unit/descriptorAddress.js +102 -0
  327. package/dist/cjs/test/unit/explainTransaction.d.ts +2 -0
  328. package/dist/cjs/test/unit/explainTransaction.d.ts.map +1 -0
  329. package/dist/cjs/test/unit/explainTransaction.js +74 -0
  330. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts +15 -0
  331. package/dist/cjs/test/unit/fixtures/bip322/fixtures.d.ts.map +1 -0
  332. package/dist/cjs/test/unit/fixtures/bip322/fixtures.js +51 -0
  333. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts +4 -0
  334. package/dist/cjs/test/unit/fixtures/psbtHexProof.d.ts.map +1 -0
  335. package/dist/cjs/test/unit/fixtures/psbtHexProof.js +9 -0
  336. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts +2 -0
  337. package/dist/cjs/test/unit/impl/bch/unit/bch.d.ts.map +1 -0
  338. package/dist/cjs/test/unit/impl/bch/unit/bch.js +138 -0
  339. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts +2 -0
  340. package/dist/cjs/test/unit/impl/bcha/unit/index.d.ts.map +1 -0
  341. package/dist/cjs/test/unit/impl/bcha/unit/index.js +47 -0
  342. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts +2 -0
  343. package/dist/cjs/test/unit/impl/bsv/unit/index.d.ts.map +1 -0
  344. package/dist/cjs/test/unit/impl/bsv/unit/index.js +32 -0
  345. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts +2 -0
  346. package/dist/cjs/test/unit/impl/btc/unit/btc.d.ts.map +1 -0
  347. package/dist/cjs/test/unit/impl/btc/unit/btc.js +220 -0
  348. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts +4 -0
  349. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.d.ts.map +1 -0
  350. package/dist/cjs/test/unit/impl/btc/unit/fixtures/btcBackupKey.js +10 -0
  351. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts +2 -0
  352. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.d.ts.map +1 -0
  353. package/dist/cjs/test/unit/impl/btc/unit/fixtures/index.js +18 -0
  354. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts +2 -0
  355. package/dist/cjs/test/unit/impl/btg/unit/index.d.ts.map +1 -0
  356. package/dist/cjs/test/unit/impl/btg/unit/index.js +29 -0
  357. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts +2 -0
  358. package/dist/cjs/test/unit/impl/dash/unit/index.d.ts.map +1 -0
  359. package/dist/cjs/test/unit/impl/dash/unit/index.js +32 -0
  360. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts +2 -0
  361. package/dist/cjs/test/unit/impl/doge/unit/index.d.ts.map +1 -0
  362. package/dist/cjs/test/unit/impl/doge/unit/index.js +32 -0
  363. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts +2 -0
  364. package/dist/cjs/test/unit/impl/ltc/unit/index.d.ts.map +1 -0
  365. package/dist/cjs/test/unit/impl/ltc/unit/index.js +39 -0
  366. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts +2 -0
  367. package/dist/cjs/test/unit/impl/zec/unit/index.d.ts.map +1 -0
  368. package/dist/cjs/test/unit/impl/zec/unit/index.js +29 -0
  369. package/dist/cjs/test/unit/keySignatures.d.ts +2 -0
  370. package/dist/cjs/test/unit/keySignatures.d.ts.map +1 -0
  371. package/dist/cjs/test/unit/keySignatures.js +54 -0
  372. package/dist/cjs/test/unit/keychains.d.ts +2 -0
  373. package/dist/cjs/test/unit/keychains.d.ts.map +1 -0
  374. package/dist/cjs/test/unit/keychains.js +49 -0
  375. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts +2 -0
  376. package/dist/cjs/test/unit/offlineVault/halfSigned.d.ts.map +1 -0
  377. package/dist/cjs/test/unit/offlineVault/halfSigned.js +124 -0
  378. package/dist/cjs/test/unit/parseTransaction.d.ts +2 -0
  379. package/dist/cjs/test/unit/parseTransaction.d.ts.map +1 -0
  380. package/dist/cjs/test/unit/parseTransaction.js +125 -0
  381. package/dist/cjs/test/unit/prebuildAndSign.d.ts +6 -0
  382. package/dist/cjs/test/unit/prebuildAndSign.d.ts.map +1 -0
  383. package/dist/cjs/test/unit/prebuildAndSign.js +270 -0
  384. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts +2 -0
  385. package/dist/cjs/test/unit/recovery/backupKeyRecovery.d.ts.map +1 -0
  386. package/dist/cjs/test/unit/recovery/backupKeyRecovery.js +296 -0
  387. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts +2 -0
  388. package/dist/cjs/test/unit/recovery/crossChainRecovery.d.ts.map +1 -0
  389. package/dist/cjs/test/unit/recovery/crossChainRecovery.js +295 -0
  390. package/dist/cjs/test/unit/recovery/mock.d.ts +30 -0
  391. package/dist/cjs/test/unit/recovery/mock.d.ts.map +1 -0
  392. package/dist/cjs/test/unit/recovery/mock.js +138 -0
  393. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts +2 -0
  394. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  395. package/dist/cjs/test/unit/transaction/descriptor/explainPsbt.js +30 -0
  396. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts +6 -0
  397. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.d.ts.map +1 -0
  398. package/dist/cjs/test/unit/transaction/descriptor/fixtures.utils.js +17 -0
  399. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts +2 -0
  400. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.d.ts.map +1 -0
  401. package/dist/cjs/test/unit/transaction/descriptor/outputDifference.js +76 -0
  402. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts +2 -0
  403. package/dist/cjs/test/unit/transaction/descriptor/parse.d.ts.map +1 -0
  404. package/dist/cjs/test/unit/transaction/descriptor/parse.js +135 -0
  405. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts +2 -0
  406. package/dist/cjs/test/unit/transaction/descriptor/sign.d.ts.map +1 -0
  407. package/dist/cjs/test/unit/transaction/descriptor/sign.js +32 -0
  408. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts +2 -0
  409. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.d.ts.map +1 -0
  410. package/dist/cjs/test/unit/transaction/descriptor/validatePolicy.js +48 -0
  411. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts +2 -0
  412. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.d.ts.map +1 -0
  413. package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +132 -0
  414. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.d.ts +2 -0
  415. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.d.ts.map +1 -0
  416. package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.js +288 -0
  417. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts +2 -0
  418. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  419. package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.js +59 -0
  420. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts +2 -0
  421. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  422. package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.js +157 -0
  423. package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts +3 -0
  424. package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts.map +1 -0
  425. package/dist/cjs/test/unit/transaction/fixedScript/util.js +41 -0
  426. package/dist/cjs/test/unit/transaction.d.ts +2 -0
  427. package/dist/cjs/test/unit/transaction.d.ts.map +1 -0
  428. package/dist/cjs/test/unit/transaction.js +528 -0
  429. package/dist/cjs/test/unit/txFormat.d.ts +30 -0
  430. package/dist/cjs/test/unit/txFormat.d.ts.map +1 -0
  431. package/dist/cjs/test/unit/txFormat.js +174 -0
  432. package/dist/cjs/test/unit/util/fixtures.d.ts +14 -0
  433. package/dist/cjs/test/unit/util/fixtures.d.ts.map +1 -0
  434. package/dist/cjs/test/unit/util/fixtures.js +102 -0
  435. package/dist/cjs/test/unit/util/index.d.ts +7 -0
  436. package/dist/cjs/test/unit/util/index.d.ts.map +1 -0
  437. package/dist/cjs/test/unit/util/index.js +23 -0
  438. package/dist/cjs/test/unit/util/keychains.d.ts +26 -0
  439. package/dist/cjs/test/unit/util/keychains.d.ts.map +1 -0
  440. package/dist/cjs/test/unit/util/keychains.js +72 -0
  441. package/dist/cjs/test/unit/util/nockBitGo.d.ts +3 -0
  442. package/dist/cjs/test/unit/util/nockBitGo.d.ts.map +1 -0
  443. package/dist/cjs/test/unit/util/nockBitGo.js +11 -0
  444. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts +8 -0
  445. package/dist/cjs/test/unit/util/nockIndexerAPI.d.ts.map +1 -0
  446. package/dist/cjs/test/unit/util/nockIndexerAPI.js +56 -0
  447. package/dist/cjs/test/unit/util/transaction.d.ts +24 -0
  448. package/dist/cjs/test/unit/util/transaction.d.ts.map +1 -0
  449. package/dist/cjs/test/unit/util/transaction.js +107 -0
  450. package/dist/cjs/test/unit/util/unspents.d.ts +13 -0
  451. package/dist/cjs/test/unit/util/unspents.d.ts.map +1 -0
  452. package/dist/cjs/test/unit/util/unspents.js +106 -0
  453. package/dist/cjs/test/unit/util/utxoCoins.d.ts +8 -0
  454. package/dist/cjs/test/unit/util/utxoCoins.d.ts.map +1 -0
  455. package/dist/cjs/test/unit/util/utxoCoins.js +95 -0
  456. package/dist/cjs/test/unit/util/wallet.d.ts +4 -0
  457. package/dist/cjs/test/unit/util/wallet.d.ts.map +1 -0
  458. package/dist/cjs/test/unit/util/wallet.js +9 -0
  459. package/dist/cjs/test/unit/verifyTransaction.d.ts +2 -0
  460. package/dist/cjs/test/unit/verifyTransaction.d.ts.map +1 -0
  461. package/dist/cjs/test/unit/verifyTransaction.js +327 -0
  462. package/dist/cjs/test/unit/wallet.d.ts +2 -0
  463. package/dist/cjs/test/unit/wallet.d.ts.map +1 -0
  464. package/dist/cjs/test/unit/wallet.js +248 -0
  465. package/dist/cjs/tsconfig.tsbuildinfo +1 -0
  466. package/dist/esm/abstractUtxoCoin.d.ts +435 -0
  467. package/dist/esm/abstractUtxoCoin.d.ts.map +1 -0
  468. package/dist/esm/abstractUtxoCoin.js +616 -0
  469. package/dist/esm/address/fixedScript.d.ts +49 -0
  470. package/dist/esm/address/fixedScript.d.ts.map +1 -0
  471. package/dist/esm/address/fixedScript.js +114 -0
  472. package/dist/esm/address/index.d.ts +2 -0
  473. package/dist/esm/address/index.d.ts.map +1 -0
  474. package/dist/esm/address/index.js +2 -0
  475. package/dist/esm/config.d.ts +9 -0
  476. package/dist/esm/config.js +11 -0
  477. package/dist/esm/descriptor/NamedDescriptor.d.ts +20 -0
  478. package/dist/esm/descriptor/NamedDescriptor.d.ts.map +1 -0
  479. package/dist/esm/descriptor/NamedDescriptor.js +39 -0
  480. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts +5 -0
  481. package/dist/esm/descriptor/assertDescriptorWalletAddress.d.ts.map +1 -0
  482. package/dist/esm/descriptor/assertDescriptorWalletAddress.js +27 -0
  483. package/dist/esm/descriptor/builder/builder.d.ts +13 -0
  484. package/dist/esm/descriptor/builder/builder.d.ts.map +1 -0
  485. package/dist/esm/descriptor/builder/builder.js +34 -0
  486. package/dist/esm/descriptor/builder/index.d.ts +3 -0
  487. package/dist/esm/descriptor/builder/index.d.ts.map +1 -0
  488. package/dist/esm/descriptor/builder/index.js +3 -0
  489. package/dist/esm/descriptor/builder/parse.d.ts +5 -0
  490. package/dist/esm/descriptor/builder/parse.d.ts.map +1 -0
  491. package/dist/esm/descriptor/builder/parse.js +112 -0
  492. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts +20 -0
  493. package/dist/esm/descriptor/createWallet/createDescriptorWallet.d.ts.map +1 -0
  494. package/dist/esm/descriptor/createWallet/createDescriptorWallet.js +37 -0
  495. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts +12 -0
  496. package/dist/esm/descriptor/createWallet/createDescriptors.d.ts.map +1 -0
  497. package/dist/esm/descriptor/createWallet/createDescriptors.js +29 -0
  498. package/dist/esm/descriptor/createWallet/index.d.ts +3 -0
  499. package/dist/esm/descriptor/createWallet/index.d.ts.map +1 -0
  500. package/dist/esm/descriptor/createWallet/index.js +3 -0
  501. package/dist/esm/descriptor/descriptorWallet.d.ts +19 -0
  502. package/dist/esm/descriptor/descriptorWallet.d.ts.map +1 -0
  503. package/dist/esm/descriptor/descriptorWallet.js +16 -0
  504. package/dist/esm/descriptor/index.d.ts +8 -0
  505. package/dist/esm/descriptor/index.d.ts.map +1 -0
  506. package/dist/esm/descriptor/index.js +7 -0
  507. package/dist/esm/descriptor/validatePolicy.d.ts +22 -0
  508. package/dist/esm/descriptor/validatePolicy.d.ts.map +1 -0
  509. package/dist/esm/descriptor/validatePolicy.js +80 -0
  510. package/dist/esm/impl/bch/bch.d.ts +20 -0
  511. package/dist/esm/impl/bch/bch.d.ts.map +1 -0
  512. package/dist/esm/impl/bch/bch.js +37 -0
  513. package/dist/esm/impl/bch/index.d.ts +3 -0
  514. package/dist/esm/impl/bch/index.d.ts.map +1 -0
  515. package/dist/esm/impl/bch/index.js +3 -0
  516. package/dist/esm/impl/bch/tbch.d.ts +10 -0
  517. package/dist/esm/impl/bch/tbch.d.ts.map +1 -0
  518. package/dist/esm/impl/bch/tbch.js +11 -0
  519. package/dist/esm/impl/bcha/bcha.d.ts +8 -0
  520. package/dist/esm/impl/bcha/bcha.d.ts.map +1 -0
  521. package/dist/esm/impl/bcha/bcha.js +11 -0
  522. package/dist/esm/impl/bcha/index.d.ts +3 -0
  523. package/dist/esm/impl/bcha/index.d.ts.map +1 -0
  524. package/dist/esm/impl/bcha/index.js +3 -0
  525. package/dist/esm/impl/bcha/tbcha.d.ts +10 -0
  526. package/dist/esm/impl/bcha/tbcha.d.ts.map +1 -0
  527. package/dist/esm/impl/bcha/tbcha.js +11 -0
  528. package/dist/esm/impl/bsv/bsv.d.ts +8 -0
  529. package/dist/esm/impl/bsv/bsv.d.ts.map +1 -0
  530. package/dist/esm/impl/bsv/bsv.js +11 -0
  531. package/dist/esm/impl/bsv/index.d.ts +3 -0
  532. package/dist/esm/impl/bsv/index.d.ts.map +1 -0
  533. package/dist/esm/impl/bsv/index.js +3 -0
  534. package/dist/esm/impl/bsv/tbsv.d.ts +10 -0
  535. package/dist/esm/impl/bsv/tbsv.d.ts.map +1 -0
  536. package/dist/esm/impl/bsv/tbsv.js +11 -0
  537. package/dist/esm/impl/btc/btc.d.ts +13 -0
  538. package/dist/esm/impl/btc/btc.d.ts.map +1 -0
  539. package/dist/esm/impl/btc/btc.js +18 -0
  540. package/dist/esm/impl/btc/index.d.ts +7 -0
  541. package/dist/esm/impl/btc/index.d.ts.map +1 -0
  542. package/dist/esm/impl/btc/index.js +7 -0
  543. package/dist/esm/impl/btc/inscriptionBuilder.d.ts +51 -0
  544. package/dist/esm/impl/btc/inscriptionBuilder.d.ts.map +1 -0
  545. package/dist/esm/impl/btc/inscriptionBuilder.js +143 -0
  546. package/dist/esm/impl/btc/tbtc.d.ts +10 -0
  547. package/dist/esm/impl/btc/tbtc.d.ts.map +1 -0
  548. package/dist/esm/impl/btc/tbtc.js +11 -0
  549. package/dist/esm/impl/btc/tbtc4.d.ts +10 -0
  550. package/dist/esm/impl/btc/tbtc4.d.ts.map +1 -0
  551. package/dist/esm/impl/btc/tbtc4.js +11 -0
  552. package/dist/esm/impl/btc/tbtcbgsig.d.ts +10 -0
  553. package/dist/esm/impl/btc/tbtcbgsig.d.ts.map +1 -0
  554. package/dist/esm/impl/btc/tbtcbgsig.js +11 -0
  555. package/dist/esm/impl/btc/tbtcsig.d.ts +10 -0
  556. package/dist/esm/impl/btc/tbtcsig.d.ts.map +1 -0
  557. package/dist/esm/impl/btc/tbtcsig.js +11 -0
  558. package/dist/esm/impl/btg/btg.d.ts +7 -0
  559. package/dist/esm/impl/btg/btg.d.ts.map +1 -0
  560. package/dist/esm/impl/btg/btg.js +11 -0
  561. package/dist/esm/impl/btg/index.d.ts +2 -0
  562. package/dist/esm/impl/btg/index.d.ts.map +1 -0
  563. package/dist/esm/impl/btg/index.js +2 -0
  564. package/dist/esm/impl/dash/dash.d.ts +7 -0
  565. package/dist/esm/impl/dash/dash.d.ts.map +1 -0
  566. package/dist/esm/impl/dash/dash.js +11 -0
  567. package/dist/esm/impl/dash/index.d.ts +3 -0
  568. package/dist/esm/impl/dash/index.d.ts.map +1 -0
  569. package/dist/esm/impl/dash/index.js +3 -0
  570. package/dist/esm/impl/dash/tdash.d.ts +10 -0
  571. package/dist/esm/impl/dash/tdash.d.ts.map +1 -0
  572. package/dist/esm/impl/dash/tdash.js +11 -0
  573. package/dist/esm/impl/doge/doge.d.ts +32 -0
  574. package/dist/esm/impl/doge/doge.d.ts.map +1 -0
  575. package/dist/esm/impl/doge/doge.js +75 -0
  576. package/dist/esm/impl/doge/index.d.ts +3 -0
  577. package/dist/esm/impl/doge/index.d.ts.map +1 -0
  578. package/dist/esm/impl/doge/index.js +3 -0
  579. package/dist/esm/impl/doge/tdoge.d.ts +10 -0
  580. package/dist/esm/impl/doge/tdoge.d.ts.map +1 -0
  581. package/dist/esm/impl/doge/tdoge.js +11 -0
  582. package/dist/esm/impl/index.d.ts +10 -0
  583. package/dist/esm/impl/index.d.ts.map +1 -0
  584. package/dist/esm/impl/index.js +10 -0
  585. package/dist/esm/impl/ltc/index.d.ts +3 -0
  586. package/dist/esm/impl/ltc/index.d.ts.map +1 -0
  587. package/dist/esm/impl/ltc/index.js +3 -0
  588. package/dist/esm/impl/ltc/ltc.d.ts +7 -0
  589. package/dist/esm/impl/ltc/ltc.d.ts.map +1 -0
  590. package/dist/esm/impl/ltc/ltc.js +15 -0
  591. package/dist/esm/impl/ltc/tltc.d.ts +7 -0
  592. package/dist/esm/impl/ltc/tltc.d.ts.map +1 -0
  593. package/dist/esm/impl/ltc/tltc.js +14 -0
  594. package/dist/esm/impl/zec/index.d.ts +3 -0
  595. package/dist/esm/impl/zec/index.d.ts.map +1 -0
  596. package/dist/esm/impl/zec/index.js +3 -0
  597. package/dist/esm/impl/zec/tzec.d.ts +7 -0
  598. package/dist/esm/impl/zec/tzec.d.ts.map +1 -0
  599. package/dist/esm/impl/zec/tzec.js +11 -0
  600. package/dist/esm/impl/zec/zec.d.ts +10 -0
  601. package/dist/esm/impl/zec/zec.d.ts.map +1 -0
  602. package/dist/esm/impl/zec/zec.js +11 -0
  603. package/dist/esm/index.d.ts +21 -0
  604. package/dist/esm/index.d.ts.map +1 -0
  605. package/dist/esm/index.js +21 -0
  606. package/dist/esm/keychains.d.ts +52 -0
  607. package/dist/esm/keychains.d.ts.map +1 -0
  608. package/dist/esm/keychains.js +92 -0
  609. package/dist/esm/names.d.ts +26 -0
  610. package/dist/esm/names.d.ts.map +1 -0
  611. package/dist/esm/names.js +171 -0
  612. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts +8 -0
  613. package/dist/esm/offlineVault/OfflineVaultHalfSigned.d.ts.map +1 -0
  614. package/dist/esm/offlineVault/OfflineVaultHalfSigned.js +23 -0
  615. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts +46 -0
  616. package/dist/esm/offlineVault/OfflineVaultSignable.d.ts.map +1 -0
  617. package/dist/esm/offlineVault/OfflineVaultSignable.js +18 -0
  618. package/dist/esm/offlineVault/TransactionExplanation.d.ts +15 -0
  619. package/dist/esm/offlineVault/TransactionExplanation.d.ts.map +1 -0
  620. package/dist/esm/offlineVault/TransactionExplanation.js +13 -0
  621. package/dist/esm/offlineVault/descriptor/index.d.ts +2 -0
  622. package/dist/esm/offlineVault/descriptor/index.d.ts.map +1 -0
  623. package/dist/esm/offlineVault/descriptor/index.js +2 -0
  624. package/dist/esm/offlineVault/descriptor/transaction.d.ts +38 -0
  625. package/dist/esm/offlineVault/descriptor/transaction.d.ts.map +1 -0
  626. package/dist/esm/offlineVault/descriptor/transaction.js +41 -0
  627. package/dist/esm/offlineVault/index.d.ts +6 -0
  628. package/dist/esm/offlineVault/index.d.ts.map +1 -0
  629. package/dist/esm/offlineVault/index.js +4 -0
  630. package/dist/esm/recovery/RecoveryProvider.d.ts +22 -0
  631. package/dist/{src → esm}/recovery/RecoveryProvider.d.ts.map +1 -1
  632. package/dist/esm/recovery/RecoveryProvider.js +19 -0
  633. package/dist/esm/recovery/backupKeyRecovery.d.ts +89 -0
  634. package/dist/esm/recovery/backupKeyRecovery.d.ts.map +1 -0
  635. package/dist/esm/recovery/backupKeyRecovery.js +317 -0
  636. package/dist/esm/recovery/baseApi.d.ts +24 -0
  637. package/dist/esm/recovery/baseApi.d.ts.map +1 -0
  638. package/dist/esm/recovery/baseApi.js +64 -0
  639. package/dist/esm/recovery/coingeckoApi.d.ts +6 -0
  640. package/dist/esm/recovery/coingeckoApi.d.ts.map +1 -0
  641. package/dist/esm/recovery/coingeckoApi.js +40 -0
  642. package/dist/esm/recovery/crossChainRecovery.d.ts +96 -0
  643. package/dist/esm/recovery/crossChainRecovery.d.ts.map +1 -0
  644. package/dist/esm/recovery/crossChainRecovery.js +303 -0
  645. package/dist/esm/recovery/index.d.ts +7 -0
  646. package/dist/{src → esm}/recovery/index.d.ts.map +1 -1
  647. package/dist/esm/recovery/index.js +7 -0
  648. package/dist/esm/recovery/mempoolApi.d.ts +7 -0
  649. package/dist/{src → esm}/recovery/mempoolApi.d.ts.map +1 -1
  650. package/dist/esm/recovery/mempoolApi.js +29 -0
  651. package/dist/esm/recovery/psbt.d.ts +30 -0
  652. package/dist/esm/recovery/psbt.d.ts.map +1 -0
  653. package/dist/esm/recovery/psbt.js +167 -0
  654. package/dist/esm/transaction/bip322.d.ts +27 -0
  655. package/dist/esm/transaction/bip322.d.ts.map +1 -0
  656. package/dist/esm/transaction/bip322.js +86 -0
  657. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts +1 -0
  658. package/dist/esm/transaction/common/verifyPayGoAmount.d.ts.map +1 -0
  659. package/dist/esm/transaction/common/verifyPayGoAmount.js +1 -0
  660. package/dist/esm/transaction/decode.d.ts +11 -0
  661. package/dist/esm/transaction/decode.d.ts.map +1 -0
  662. package/dist/esm/transaction/decode.js +43 -0
  663. package/dist/esm/transaction/descriptor/explainPsbt.d.ts +5 -0
  664. package/dist/esm/transaction/descriptor/explainPsbt.d.ts.map +1 -0
  665. package/dist/esm/transaction/descriptor/explainPsbt.js +44 -0
  666. package/dist/esm/transaction/descriptor/index.d.ts +7 -0
  667. package/dist/esm/transaction/descriptor/index.d.ts.map +1 -0
  668. package/dist/esm/transaction/descriptor/index.js +6 -0
  669. package/dist/esm/transaction/descriptor/parse.d.ts +16 -0
  670. package/dist/esm/transaction/descriptor/parse.d.ts.map +1 -0
  671. package/dist/esm/transaction/descriptor/parse.js +79 -0
  672. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts +14 -0
  673. package/dist/esm/transaction/descriptor/parseToAmountType.d.ts.map +1 -0
  674. package/dist/esm/transaction/descriptor/parseToAmountType.js +55 -0
  675. package/dist/esm/transaction/descriptor/recipient.d.ts +5 -0
  676. package/dist/esm/transaction/descriptor/recipient.d.ts.map +1 -0
  677. package/dist/esm/transaction/descriptor/recipient.js +2 -0
  678. package/dist/esm/transaction/descriptor/signPsbt.d.ts +25 -0
  679. package/dist/esm/transaction/descriptor/signPsbt.d.ts.map +1 -0
  680. package/dist/esm/transaction/descriptor/signPsbt.js +38 -0
  681. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts +36 -0
  682. package/dist/esm/transaction/descriptor/verifyTransaction.d.ts.map +1 -0
  683. package/dist/esm/transaction/descriptor/verifyTransaction.js +66 -0
  684. package/dist/esm/transaction/explainTransaction.d.ts +18 -0
  685. package/dist/esm/transaction/explainTransaction.d.ts.map +1 -0
  686. package/dist/esm/transaction/explainTransaction.js +52 -0
  687. package/dist/esm/transaction/fetchInputs.d.ts +26 -0
  688. package/dist/esm/transaction/fetchInputs.d.ts.map +1 -0
  689. package/dist/esm/transaction/fetchInputs.js +72 -0
  690. package/dist/esm/transaction/fixedScript/SigningError.d.ts +24 -0
  691. package/dist/esm/transaction/fixedScript/SigningError.d.ts.map +1 -0
  692. package/dist/esm/transaction/fixedScript/SigningError.js +21 -0
  693. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +11 -0
  694. package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -0
  695. package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +64 -0
  696. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts +73 -0
  697. package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -0
  698. package/dist/esm/transaction/fixedScript/explainTransaction.js +307 -0
  699. package/dist/esm/transaction/fixedScript/index.d.ts +10 -0
  700. package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -0
  701. package/dist/esm/transaction/fixedScript/index.js +9 -0
  702. package/dist/esm/transaction/fixedScript/musig2.d.ts +4 -0
  703. package/dist/esm/transaction/fixedScript/musig2.d.ts.map +1 -0
  704. package/dist/esm/transaction/fixedScript/musig2.js +2 -0
  705. package/dist/esm/transaction/fixedScript/parseOutput.d.ts +28 -0
  706. package/dist/esm/transaction/fixedScript/parseOutput.d.ts.map +1 -0
  707. package/dist/esm/transaction/fixedScript/parseOutput.js +213 -0
  708. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts +8 -0
  709. package/dist/esm/transaction/fixedScript/parseTransaction.d.ts.map +1 -0
  710. package/dist/esm/transaction/fixedScript/parseTransaction.js +176 -0
  711. package/dist/esm/transaction/fixedScript/replayProtection.d.ts +7 -0
  712. package/dist/esm/transaction/fixedScript/replayProtection.d.ts.map +1 -0
  713. package/dist/esm/transaction/fixedScript/replayProtection.js +39 -0
  714. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
  715. package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
  716. package/dist/esm/transaction/fixedScript/signLegacyTransaction.js +112 -0
  717. package/dist/esm/transaction/fixedScript/signPsbt.d.ts +30 -0
  718. package/dist/esm/transaction/fixedScript/signPsbt.d.ts.map +1 -0
  719. package/dist/esm/transaction/fixedScript/signPsbt.js +134 -0
  720. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
  721. package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
  722. package/dist/esm/transaction/fixedScript/signPsbtWasm.js +122 -0
  723. package/dist/esm/transaction/fixedScript/signTransaction.d.ts +17 -0
  724. package/dist/esm/transaction/fixedScript/signTransaction.d.ts.map +1 -0
  725. package/dist/esm/transaction/fixedScript/signTransaction.js +44 -0
  726. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts +21 -0
  727. package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts.map +1 -0
  728. package/dist/esm/transaction/fixedScript/verifyTransaction.js +160 -0
  729. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts +9 -0
  730. package/dist/esm/transaction/getPayGoVerificationPubkey.d.ts.map +1 -0
  731. package/dist/esm/transaction/getPayGoVerificationPubkey.js +17 -0
  732. package/dist/esm/transaction/index.d.ts +8 -0
  733. package/dist/esm/transaction/index.d.ts.map +1 -0
  734. package/dist/esm/transaction/index.js +8 -0
  735. package/dist/esm/transaction/outputDifference.d.ts +40 -0
  736. package/dist/esm/transaction/outputDifference.d.ts.map +1 -0
  737. package/dist/esm/transaction/outputDifference.js +42 -0
  738. package/dist/esm/transaction/parseTransaction.d.ts +4 -0
  739. package/dist/esm/transaction/parseTransaction.d.ts.map +1 -0
  740. package/dist/esm/transaction/parseTransaction.js +12 -0
  741. package/dist/esm/transaction/recipient.d.ts +29 -0
  742. package/dist/esm/transaction/recipient.d.ts.map +1 -0
  743. package/dist/esm/transaction/recipient.js +48 -0
  744. package/dist/esm/transaction/signTransaction.d.ts +6 -0
  745. package/dist/esm/transaction/signTransaction.d.ts.map +1 -0
  746. package/dist/esm/transaction/signTransaction.js +66 -0
  747. package/dist/esm/transaction/types.d.ts +49 -0
  748. package/dist/esm/transaction/types.d.ts.map +1 -0
  749. package/dist/esm/transaction/types.js +4 -0
  750. package/dist/esm/transaction/verifyTransaction.d.ts +4 -0
  751. package/dist/esm/transaction/verifyTransaction.d.ts.map +1 -0
  752. package/dist/esm/transaction/verifyTransaction.js +14 -0
  753. package/dist/esm/verifyKey.d.ts +29 -0
  754. package/dist/esm/verifyKey.d.ts.map +1 -0
  755. package/dist/esm/verifyKey.js +123 -0
  756. package/dist/esm/wallet.d.ts +15 -0
  757. package/dist/esm/wallet.d.ts.map +1 -0
  758. package/dist/esm/wallet.js +5 -0
  759. package/package.json +48 -18
  760. package/.eslintignore +0 -5
  761. package/CHANGELOG.md +0 -253
  762. package/dist/src/abstractUtxoCoin.d.ts +0 -392
  763. package/dist/src/abstractUtxoCoin.d.ts.map +0 -1
  764. package/dist/src/abstractUtxoCoin.js +0 -931
  765. package/dist/src/config.js +0 -14
  766. package/dist/src/index.d.ts +0 -6
  767. package/dist/src/index.d.ts.map +0 -1
  768. package/dist/src/index.js +0 -18
  769. package/dist/src/parseOutput.d.ts +0 -22
  770. package/dist/src/parseOutput.d.ts.map +0 -1
  771. package/dist/src/parseOutput.js +0 -181
  772. package/dist/src/recovery/RecoveryProvider.js +0 -24
  773. package/dist/src/recovery/backupKeyRecovery.d.ts +0 -62
  774. package/dist/src/recovery/backupKeyRecovery.d.ts.map +0 -1
  775. package/dist/src/recovery/backupKeyRecovery.js +0 -293
  776. package/dist/src/recovery/baseApi.d.ts.map +0 -1
  777. package/dist/src/recovery/baseApi.js +0 -73
  778. package/dist/src/recovery/coingeckoApi.d.ts.map +0 -1
  779. package/dist/src/recovery/coingeckoApi.js +0 -47
  780. package/dist/src/recovery/crossChainRecovery.d.ts.map +0 -1
  781. package/dist/src/recovery/crossChainRecovery.js +0 -294
  782. package/dist/src/recovery/mempoolApi.js +0 -33
  783. package/dist/src/recovery/smartbitApi.d.ts +0 -11
  784. package/dist/src/recovery/smartbitApi.d.ts.map +0 -1
  785. package/dist/src/recovery/smartbitApi.js +0 -36
  786. package/dist/src/replayProtection.d.ts +0 -4
  787. package/dist/src/replayProtection.d.ts.map +0 -1
  788. package/dist/src/replayProtection.js +0 -21
  789. package/dist/src/sign.d.ts +0 -31
  790. package/dist/src/sign.d.ts.map +0 -1
  791. package/dist/src/sign.js +0 -104
  792. package/dist/tsconfig.tsbuildinfo +0 -8179
  793. /package/dist/{src → cjs/src}/config.d.ts +0 -0
  794. /package/dist/{src → cjs/src}/recovery/mempoolApi.d.ts +0 -0
  795. /package/dist/{src → esm}/config.d.ts.map +0 -0
@@ -0,0 +1,30 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import { BIP32Interface } from '@bitgo-beta/secp256k1';
3
+ type Unspent<TNumber extends number | bigint = number> = utxolib.bitgo.Unspent<TNumber>;
4
+ type RootWalletKeys = utxolib.bitgo.RootWalletKeys;
5
+ /**
6
+ * Sign all inputs of a wallet transaction and verify signatures after signing.
7
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
8
+ * failed.
9
+ *
10
+ * @param transaction - wallet transaction (builder) to be signed
11
+ * @param unspents - transaction unspents
12
+ * @param walletSigner - signing parameters
13
+ * @param isLastSignature - Returns full-signed transaction when true. Builds half-signed when false.
14
+ * @param replayProtectionAddresses - List of replay protection addresses to skip signing
15
+ */
16
+ export declare function signAndVerifyWalletTransaction<TNumber extends number | bigint>(transaction: utxolib.bitgo.UtxoTransaction<TNumber> | utxolib.bitgo.UtxoTransactionBuilder<TNumber>, unspents: Unspent<TNumber>[], walletSigner: utxolib.bitgo.WalletUnspentSigner<RootWalletKeys>, { isLastSignature, replayProtectionAddresses, }: {
17
+ isLastSignature: boolean;
18
+ replayProtectionAddresses?: string[];
19
+ }): utxolib.bitgo.UtxoTransaction<TNumber>;
20
+ export declare function signLegacyTransaction<TNumber extends number | bigint>(tx: utxolib.bitgo.UtxoTransaction<TNumber>, signerKeychain: BIP32Interface | undefined, params: {
21
+ isLastSignature: boolean;
22
+ signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
23
+ txInfo: {
24
+ unspents?: utxolib.bitgo.Unspent<TNumber>[];
25
+ } | undefined;
26
+ pubs: string[] | undefined;
27
+ cosignerPub: string | undefined;
28
+ }): utxolib.bitgo.UtxoTransaction<TNumber>;
29
+ export {};
30
+ //# sourceMappingURL=signLegacyTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signLegacyTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/signLegacyTransaction.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAS,MAAM,uBAAuB,CAAC;AAY9D,KAAK,OAAO,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,GAAG,MAAM,IAAI,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,CAAC;AAExF,KAAK,cAAc,GAAG,OAAO,CAAC,KAAK,CAAC,cAAc,CAAC;AAEnD;;;;;;;;;;GAUG;AACH,wBAAgB,8BAA8B,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EAC5E,WAAW,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC,sBAAsB,CAAC,OAAO,CAAC,EACnG,QAAQ,EAAE,OAAO,CAAC,OAAO,CAAC,EAAE,EAC5B,YAAY,EAAE,OAAO,CAAC,KAAK,CAAC,mBAAmB,CAAC,cAAc,CAAC,EAC/D,EACE,eAAe,EACf,yBAAyB,GAC1B,EAAE;IACD,eAAe,EAAE,OAAO,CAAC;IACzB,yBAAyB,CAAC,EAAE,MAAM,EAAE,CAAC;CACtC,GACA,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CAwExC;AAED,wBAAgB,qBAAqB,CAAC,OAAO,SAAS,MAAM,GAAG,MAAM,EACnE,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,EAC1C,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,MAAM,EAAE;IACN,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,MAAM,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAA;KAAE,GAAG,SAAS,CAAC;IACpE,IAAI,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC3B,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,GACA,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,OAAO,CAAC,CA4BxC"}
@@ -0,0 +1,112 @@
1
+ import assert from 'assert';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ import { bip32 } from '@bitgo-beta/secp256k1';
4
+ import { bitgo } from '@bitgo-beta/utxo-lib';
5
+ import { isTriple } from '@bitgo-beta/sdk-core';
6
+ import debugLib from 'debug';
7
+ import { getReplayProtectionAddresses } from './replayProtection';
8
+ import { InputSigningError, TransactionSigningError } from './SigningError';
9
+ const debug = debugLib('bitgo:v2:utxo');
10
+ const { isWalletUnspent, signInputWithUnspent, toOutput } = utxolib.bitgo;
11
+ /**
12
+ * Sign all inputs of a wallet transaction and verify signatures after signing.
13
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
14
+ * failed.
15
+ *
16
+ * @param transaction - wallet transaction (builder) to be signed
17
+ * @param unspents - transaction unspents
18
+ * @param walletSigner - signing parameters
19
+ * @param isLastSignature - Returns full-signed transaction when true. Builds half-signed when false.
20
+ * @param replayProtectionAddresses - List of replay protection addresses to skip signing
21
+ */
22
+ export function signAndVerifyWalletTransaction(transaction, unspents, walletSigner, { isLastSignature, replayProtectionAddresses, }) {
23
+ const network = transaction.network;
24
+ if (replayProtectionAddresses === undefined) {
25
+ replayProtectionAddresses = getReplayProtectionAddresses(network);
26
+ }
27
+ const prevOutputs = unspents.map((u) => toOutput(u, network));
28
+ let txBuilder;
29
+ if (transaction instanceof utxolib.bitgo.UtxoTransaction) {
30
+ txBuilder = utxolib.bitgo.createTransactionBuilderFromTransaction(transaction, prevOutputs);
31
+ if (transaction.ins.length !== unspents.length) {
32
+ throw new Error(`transaction inputs must match unspents`);
33
+ }
34
+ }
35
+ else if (transaction instanceof utxolib.bitgo.UtxoTransactionBuilder) {
36
+ txBuilder = transaction;
37
+ }
38
+ else {
39
+ throw new Error(`must pass UtxoTransaction or UtxoTransactionBuilder`);
40
+ }
41
+ const signErrors = unspents
42
+ .map((unspent, inputIndex) => {
43
+ if (replayProtectionAddresses.includes(unspent.address)) {
44
+ debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, unspents.length);
45
+ return;
46
+ }
47
+ if (!isWalletUnspent(unspent)) {
48
+ return InputSigningError.expectedWalletUnspent(inputIndex, null, unspent);
49
+ }
50
+ try {
51
+ signInputWithUnspent(txBuilder, inputIndex, unspent, walletSigner);
52
+ debug('Successfully signed input %d of %d', inputIndex + 1, unspents.length);
53
+ }
54
+ catch (e) {
55
+ return new InputSigningError(inputIndex, null, unspent, e);
56
+ }
57
+ })
58
+ .filter((e) => e !== undefined);
59
+ const signedTransaction = isLastSignature ? txBuilder.build() : txBuilder.buildIncomplete();
60
+ const verifyErrors = signedTransaction.ins
61
+ .map((input, inputIndex) => {
62
+ const unspent = unspents[inputIndex];
63
+ if (replayProtectionAddresses.includes(unspent.address)) {
64
+ debug('Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)', inputIndex + 1, unspents.length);
65
+ return;
66
+ }
67
+ if (!isWalletUnspent(unspent)) {
68
+ return InputSigningError.expectedWalletUnspent(inputIndex, null, unspent);
69
+ }
70
+ try {
71
+ const publicKey = walletSigner.deriveForChainAndIndex(unspent.chain, unspent.index).signer.publicKey;
72
+ if (!utxolib.bitgo.verifySignatureWithPublicKey(signedTransaction, inputIndex, prevOutputs, publicKey)) {
73
+ return new InputSigningError(inputIndex, null, unspent, new Error(`invalid signature`));
74
+ }
75
+ }
76
+ catch (e) {
77
+ debug('Invalid signature');
78
+ return new InputSigningError(inputIndex, null, unspent, e);
79
+ }
80
+ })
81
+ .filter((e) => e !== undefined);
82
+ if (signErrors.length || verifyErrors.length) {
83
+ throw new TransactionSigningError(signErrors, verifyErrors);
84
+ }
85
+ return signedTransaction;
86
+ }
87
+ export function signLegacyTransaction(tx, signerKeychain, params) {
88
+ switch (params.signingStep) {
89
+ case 'signerNonce':
90
+ case 'cosignerNonce':
91
+ /**
92
+ * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
93
+ * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
94
+ */
95
+ return tx;
96
+ }
97
+ if (tx.ins.length !== params.txInfo?.unspents?.length) {
98
+ throw new Error('length of unspents array should equal to the number of transaction inputs');
99
+ }
100
+ if (!params.pubs || !isTriple(params.pubs)) {
101
+ throw new Error(`must provide xpub array`);
102
+ }
103
+ const keychains = params.pubs.map((pub) => bip32.fromBase58(pub));
104
+ const cosignerPub = params.cosignerPub ?? params.pubs[2];
105
+ const cosignerKeychain = bip32.fromBase58(cosignerPub);
106
+ assert(signerKeychain);
107
+ const walletSigner = new bitgo.WalletUnspentSigner(keychains, signerKeychain, cosignerKeychain);
108
+ return signAndVerifyWalletTransaction(tx, params.txInfo.unspents, walletSigner, {
109
+ isLastSignature: params.isLastSignature,
110
+ });
111
+ }
112
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnbkxlZ2FjeVRyYW5zYWN0aW9uLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25MZWdhY3lUcmFuc2FjdGlvbi50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFFNUIsT0FBTyxLQUFLLE9BQU8sTUFBTSxzQkFBc0IsQ0FBQztBQUNoRCxPQUFPLEVBQWtCLEtBQUssRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQzlELE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUM3QyxPQUFPLEVBQUUsUUFBUSxFQUFVLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxRQUFRLE1BQU0sT0FBTyxDQUFDO0FBRTdCLE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQ2xFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRTVFLE1BQU0sS0FBSyxHQUFHLFFBQVEsQ0FBQyxlQUFlLENBQUMsQ0FBQztBQUV4QyxNQUFNLEVBQUUsZUFBZSxFQUFFLG9CQUFvQixFQUFFLFFBQVEsRUFBRSxHQUFHLE9BQU8sQ0FBQyxLQUFLLENBQUM7QUFNMUU7Ozs7Ozs7Ozs7R0FVRztBQUNILE1BQU0sVUFBVSw4QkFBOEIsQ0FDNUMsV0FBbUcsRUFDbkcsUUFBNEIsRUFDNUIsWUFBK0QsRUFDL0QsRUFDRSxlQUFlLEVBQ2YseUJBQXlCLEdBSTFCO0lBRUQsTUFBTSxPQUFPLEdBQUcsV0FBVyxDQUFDLE9BQTBCLENBQUM7SUFDdkQsSUFBSSx5QkFBeUIsS0FBSyxTQUFTLEVBQUUsQ0FBQztRQUM1Qyx5QkFBeUIsR0FBRyw0QkFBNEIsQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUNwRSxDQUFDO0lBQ0QsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLEdBQUcsQ0FB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QztRQUN0RCxNQUFNLElBQUksS0FBSyxDQUFDLDJFQUEyRSxDQUFDLENBQUM7SUFDL0YsQ0FBQztJQUVELElBQUksQ0FBQyxNQUFNLENBQUMsSUFBSSxJQUFJLENBQUMsUUFBUSxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUMsRUFBRSxDQUFDO1FBQzNDLE1BQU0sSUFBSSxLQUFLLENBQUMseUJBQXlCLENBQUMsQ0FBQztJQUM3QyxDQUFDO0lBRUQsTUFBTSxTQUFTLEdBQUcsTUFBTSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxHQUFHLEVBQUUsRUFBRSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQTJCLENBQUM7SUFDNUYsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFdBQVcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLENBQUMsQ0FBQyxDQUFDO0lBQ3pELE1BQU0sZ0JBQWdCLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQyxXQUFXLENBQUMsQ0FBQztJQUV2RCxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDdkIsTUFBTSxZQUFZLEdBQUcsSUFBSSxLQUFLLENBQUMsbUJBQW1CLENBQWlCLFNBQVMsRUFBRSxjQUFjLEVBQUUsZ0JBQWdCLENBQUMsQ0FBQztJQUNoSCxPQUFPLDhCQUE4QixDQUFDLEVBQUUsRUFBRSxNQUFNLENBQUMsTUFBTSxDQUFDLFFBQVEsRUFBRSxZQUFZLEVBQUU7UUFDOUUsZUFBZSxFQUFFLE1BQU0sQ0FBQyxlQUFlO0tBQ3hDLENBQTJDLENBQUM7QUFDL0MsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBhc3NlcnQgZnJvbSAnYXNzZXJ0JztcblxuaW1wb3J0ICogYXMgdXR4b2xpYiBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBCSVAzMkludGVyZmFjZSwgYmlwMzIgfSBmcm9tICdAYml0Z28tYmV0YS9zZWNwMjU2azEnO1xuaW1wb3J0IHsgYml0Z28gfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgeyBpc1RyaXBsZSwgVHJpcGxlIH0gZnJvbSAnQGJpdGdvLWJldGEvc2RrLWNvcmUnO1xuaW1wb3J0IGRlYnVnTGliIGZyb20gJ2RlYnVnJztcblxuaW1wb3J0IHsgZ2V0UmVwbGF5UHJvdGVjdGlvbkFkZHJlc3NlcyB9IGZyb20gJy4vcmVwbGF5UHJvdGVjdGlvbic7XG5pbXBvcnQgeyBJbnB1dFNpZ25pbmdFcnJvciwgVHJhbnNhY3Rpb25TaWduaW5nRXJyb3IgfSBmcm9tICcuL1NpZ25pbmdFcnJvcic7XG5cbmNvbnN0IGRlYnVnID0gZGVidWdMaWIoJ2JpdGdvOnYyOnV0eG8nKTtcblxuY29uc3QgeyBpc1dhbGxldFVuc3BlbnQsIHNpZ25JbnB1dFdpdGhVbnNwZW50LCB0b091dHB1dCB9ID0gdXR4b2xpYi5iaXRnbztcblxudHlwZSBVbnNwZW50PFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQgPSBudW1iZXI+ID0gdXR4b2xpYi5iaXRnby5VbnNwZW50PFROdW1iZXI+O1xuXG50eXBlIFJvb3RXYWxsZXRLZXlzID0gdXR4b2xpYi5iaXRnby5Sb290V2FsbGV0S2V5cztcblxuLyoqXG4gKiBTaWduIGFsbCBpbnB1dHMgb2YgYSB3YWxsZXQgdHJhbnNhY3Rpb24gYW5kIHZlcmlmeSBzaWduYXR1cmVzIGFmdGVyIHNpZ25pbmcuXG4gKiBDb2xsZWN0cyBhbmQgbG9ncyBzaWduaW5nIGVycm9ycyBhbmQgdmVyaWZpY2F0aW9uIGVycm9ycywgdGhyb3dzIGVycm9yIGluIHRoZSBlbmQgaWYgYW55IG9mIHRoZW1cbiAqIGZhaWxlZC5cbiAqXG4gKiBAcGFyYW0gdHJhbnNhY3Rpb24gLSB3YWxsZXQgdHJhbnNhY3Rpb24gKGJ1aWxkZXIpIHRvIGJlIHNpZ25lZFxuICogQHBhcmFtIHVuc3BlbnRzIC0gdHJhbnNhY3Rpb24gdW5zcGVudHNcbiAqIEBwYXJhbSB3YWxsZXRTaWduZXIgLSBzaWduaW5nIHBhcmFtZXRlcnNcbiAqIEBwYXJhbSBpc0xhc3RTaWduYXR1cmUgLSBSZXR1cm5zIGZ1bGwtc2lnbmVkIHRyYW5zYWN0aW9uIHdoZW4gdHJ1ZS4gQnVpbGRzIGhhbGYtc2lnbmVkIHdoZW4gZmFsc2UuXG4gKiBAcGFyYW0gcmVwbGF5UHJvdGVjdGlvbkFkZHJlc3NlcyAtIExpc3Qgb2YgcmVwbGF5IHByb3RlY3Rpb24gYWRkcmVzc2VzIHRvIHNraXAgc2lnbmluZ1xuICovXG5leHBvcnQgZnVuY3Rpb24gc2lnbkFuZFZlcmlmeVdhbGxldFRyYW5zYWN0aW9uPFROdW1iZXIgZXh0ZW5kcyBudW1iZXIgfCBiaWdpbnQ+KFxuICB0cmFuc2FjdGlvbjogdXR4b2xpYi5iaXRnby5VdHhvVHJhbnNhY3Rpb248VE51bWJlcj4gfCB1dHhvbGliLmJpdGdvLlV0eG9UcmFuc2FjdGlvbkJ1aWxkZXI8VE51bWJlcj4sXG4gIHVuc3BlbnRzOiBVbnNwZW50PFROdW1iZXI+W10sXG4gIHdhbGxldFNpZ25lcjogdXR4b2xpYi5iaXRnby5XYWxsZXRVbnNwZW50U2lnbmVyPFJvb3RXYWxsZXRLZXlzPixcbiAge1xuICAgIGlzTGFzdFNpZ25hdHVyZSxcbiAgICByZXBsYXlQcm90ZWN0aW9uQWRkcmVzc2VzLFxuICB9OiB7XG4gICAgaXNMYXN0U2lnbmF0dXJlOiBib29sZWFuO1xuICAgIHJlcGxheVByb3RlY3Rpb25BZGRyZXNzZXM/OiBzdHJpbmdbXTtcbiAgfVxuKTogdXR4b2xpYi5iaXRnby5VdHhvVHJhbnNhY3Rpb248VE51bWJlcj4ge1xuICBjb25zdCBuZXR3b3JrID0gdHJhbnNhY3Rpb24ubmV0d29yayBhcyB1dHhvbGliLk5ldHdvcms7XG4gIGlmIChyZXBsYXlQcm90ZWN0aW9uQWRkcmVzc2VzID09PSB1bmRlZmluZWQpIHtcbiAgICByZXBsYXlQcm90ZWN0aW9uQWRkcmVzc2VzID0gZ2V0UmVwbGF5UHJvdGVjdGlvbkFkZHJlc3NlcyhuZXR3b3JrKTtcbiAgfVxuICBjb25zdCBwcmV2T3V0cHV0cyA9IHVuc3BlbnRzLm1hcCgodSkgPT4gdG9PdXRwdXQodSwgbmV0d29yaykpO1xuXG4gIGxldCB0eEJ1aWxkZXI6IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uQnVpbGRlcjxUTnVtYmVyPjtcbiAgaWYgKHRyYW5zYWN0aW9uIGluc3RhbmNlb2YgdXR4b2xpYi5iaXRnby5VdHhvVHJhbnNhY3Rpb24pIHtcbiAgICB0eEJ1aWxkZXIgPSB1dHhvbGliLmJpdGdvLmNyZWF0ZVRyYW5zYWN0aW9uQnVpbGRlckZyb21UcmFuc2FjdGlvbjxUTnVtYmVyPih0cmFuc2FjdGlvbiwgcHJldk91dHB1dHMpO1xuICAgIGlmICh0cmFuc2FjdGlvbi5pbnMubGVuZ3RoICE9PSB1bnNwZW50cy5sZW5ndGgpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcihgdHJhbnNhY3Rpb24gaW5wdXRzIG11c3QgbWF0Y2ggdW5zcGVudHNgKTtcbiAgICB9XG4gIH0gZWxzZSBpZiAodHJhbnNhY3Rpb24gaW5zdGFuY2VvZiB1dHhvbGliLmJpdGdvLlV0eG9UcmFuc2FjdGlvbkJ1aWxkZXIpIHtcbiAgICB0eEJ1aWxkZXIgPSB0cmFuc2FjdGlvbjtcbiAgfSBlbHNlIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYG11c3QgcGFzcyBVdHhvVHJhbnNhY3Rpb24gb3IgVXR4b1RyYW5zYWN0aW9uQnVpbGRlcmApO1xuICB9XG5cbiAgY29uc3Qgc2lnbkVycm9yczogSW5wdXRTaWduaW5nRXJyb3I8VE51bWJlcj5bXSA9IHVuc3BlbnRzXG4gICAgLm1hcCgodW5zcGVudDogVW5zcGVudDxUTnVtYmVyPiwgaW5wdXRJbmRleDogbnVtYmVyKSA9PiB7XG4gICAgICBpZiAocmVwbGF5UHJvdGVjdGlvbkFkZHJlc3Nlcy5pbmNsdWRlcyh1bnNwZW50LmFkZHJlc3MpKSB7XG4gICAgICAgIGRlYnVnKCdTa2lwcGluZyBzaWduYXR1cmUgZm9yIGlucHV0ICVkIG9mICVkIChSUCBpbnB1dD8pJywgaW5wdXRJbmRleCArIDEsIHVuc3BlbnRzLmxlbmd0aCk7XG4gICAgICAgIHJldHVybjtcbiAgICAgIH1cbiAgICAgIGlmICghaXNXYWxsZXRVbnNwZW50PFROdW1iZXI+KHVuc3BlbnQpKSB7XG4gICAgICAgIHJldHVybiBJbnB1dFNpZ25pbmdFcnJvci5leHBlY3RlZFdhbGxldFVuc3BlbnQ8VE51bWJlcj4oaW5wdXRJbmRleCwgbnVsbCwgdW5zcGVudCk7XG4gICAgICB9XG4gICAgICB0cnkge1xuICAgICAgICBzaWduSW5wdXRXaXRoVW5zcGVudDxUTnVtYmVyPih0eEJ1aWxkZXIsIGlucHV0SW5kZXgsIHVuc3BlbnQsIHdhbGxldFNpZ25lcik7XG4gICAgICAgIGRlYnVnKCdTdWNjZXNzZnVsbHkgc2lnbmVkIGlucHV0ICVkIG9mICVkJywgaW5wdXRJbmRleCArIDEsIHVuc3BlbnRzLmxlbmd0aCk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIHJldHVybiBuZXcgSW5wdXRTaWduaW5nRXJyb3I8VE51bWJlcj4oaW5wdXRJbmRleCwgbnVsbCwgdW5zcGVudCwgZSk7XG4gICAgICB9XG4gICAgfSlcbiAgICAuZmlsdGVyKChlKTogZSBpcyBJbnB1dFNpZ25pbmdFcnJvcjxUTnVtYmVyPiA9PiBlICE9PSB1bmRlZmluZWQpO1xuXG4gIGNvbnN0IHNpZ25lZFRyYW5zYWN0aW9uID0gaXNMYXN0U2lnbmF0dXJlID8gdHhCdWlsZGVyLmJ1aWxkKCkgOiB0eEJ1aWxkZXIuYnVpbGRJbmNvbXBsZXRlKCk7XG5cbiAgY29uc3QgdmVyaWZ5RXJyb3JzOiBJbnB1dFNpZ25pbmdFcnJvcjxUTnVtYmVyPltdID0gc2lnbmVkVHJhbnNhY3Rpb24uaW5zXG4gICAgLm1hcCgoaW5wdXQsIGlucHV0SW5kZXgpID0+IHtcbiAgICAgIGNvbnN0IHVuc3BlbnQgPSB1bnNwZW50c1tpbnB1dEluZGV4XSBhcyBVbnNwZW50PFROdW1iZXI+O1xuICAgICAgaWYgKHJlcGxheVByb3RlY3Rpb25BZGRyZXNzZXMuaW5jbHVkZXModW5zcGVudC5hZGRyZXNzKSkge1xuICAgICAgICBkZWJ1ZyhcbiAgICAgICAgICAnU2tpcHBpbmcgaW5wdXQgc2lnbmF0dXJlICVkIG9mICVkICh1bnNwZW50IGZyb20gcmVwbGF5IHByb3RlY3Rpb24gYWRkcmVzcyB3aGljaCBpcyBwbGF0Zm9ybSBzaWduZWQgb25seSknLFxuICAgICAgICAgIGlucHV0SW5kZXggKyAxLFxuICAgICAgICAgIHVuc3BlbnRzLmxlbmd0aFxuICAgICAgICApO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG4gICAgICBpZiAoIWlzV2FsbGV0VW5zcGVudDxUTnVtYmVyPih1bnNwZW50KSkge1xuICAgICAgICByZXR1cm4gSW5wdXRTaWduaW5nRXJyb3IuZXhwZWN0ZWRXYWxsZXRVbnNwZW50PFROdW1iZXI+KGlucHV0SW5kZXgsIG51bGwsIHVuc3BlbnQpO1xuICAgICAgfVxuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgcHVibGljS2V5ID0gd2FsbGV0U2lnbmVyLmRlcml2ZUZvckNoYWluQW5kSW5kZXgodW5zcGVudC5jaGFpbiwgdW5zcGVudC5pbmRleCkuc2lnbmVyLnB1YmxpY0tleTtcbiAgICAgICAgaWYgKFxuICAgICAgICAgICF1dHhvbGliLmJpdGdvLnZlcmlmeVNpZ25hdHVyZVdpdGhQdWJsaWNLZXk8VE51bWJlcj4oc2lnbmVkVHJhbnNhY3Rpb24sIGlucHV0SW5kZXgsIHByZXZPdXRwdXRzLCBwdWJsaWNLZXkpXG4gICAgICAgICkge1xuICAgICAgICAgIHJldHVybiBuZXcgSW5wdXRTaWduaW5nRXJyb3IoaW5wdXRJbmRleCwgbnVsbCwgdW5zcGVudCwgbmV3IEVycm9yKGBpbnZhbGlkIHNpZ25hdHVyZWApKTtcbiAgICAgICAgfVxuICAgICAgfSBjYXRjaCAoZSkge1xuICAgICAgICBkZWJ1ZygnSW52YWxpZCBzaWduYXR1cmUnKTtcbiAgICAgICAgcmV0dXJuIG5ldyBJbnB1dFNpZ25pbmdFcnJvcjxUTnVtYmVyPihpbnB1dEluZGV4LCBudWxsLCB1bnNwZW50LCBlKTtcbiAgICAgIH1cbiAgICB9KVxuICAgIC5maWx0ZXIoKGUpOiBlIGlzIElucHV0U2lnbmluZ0Vycm9yPFROdW1iZXI+ID0+IGUgIT09IHVuZGVmaW5lZCk7XG5cbiAgaWYgKHNpZ25FcnJvcnMubGVuZ3RoIHx8IHZlcmlmeUVycm9ycy5sZW5ndGgpIHtcbiAgICB0aHJvdyBuZXcgVHJhbnNhY3Rpb25TaWduaW5nRXJyb3Ioc2lnbkVycm9ycywgdmVyaWZ5RXJyb3JzKTtcbiAgfVxuXG4gIHJldHVybiBzaWduZWRUcmFuc2FjdGlvbjtcbn1cblxuZXhwb3J0IGZ1bmN0aW9uIHNpZ25MZWdhY3lUcmFuc2FjdGlvbjxUTnVtYmVyIGV4dGVuZHMgbnVtYmVyIHwgYmlnaW50PihcbiAgdHg6IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPFROdW1iZXI+LFxuICBzaWduZXJLZXljaGFpbjogQklQMzJJbnRlcmZhY2UgfCB1bmRlZmluZWQsXG4gIHBhcmFtczoge1xuICAgIGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjtcbiAgICBzaWduaW5nU3RlcDogJ3NpZ25lck5vbmNlJyB8ICdjb3NpZ25lck5vbmNlJyB8ICdzaWduZXJTaWduYXR1cmUnIHwgdW5kZWZpbmVkO1xuICAgIHR4SW5mbzogeyB1bnNwZW50cz86IHV0eG9saWIuYml0Z28uVW5zcGVudDxUTnVtYmVyPltdIH0gfCB1bmRlZmluZWQ7XG4gICAgcHViczogc3RyaW5nW10gfCB1bmRlZmluZWQ7XG4gICAgY29zaWduZXJQdWI6IHN0cmluZyB8IHVuZGVmaW5lZDtcbiAgfVxuKTogdXR4b2xpYi5iaXRnby5VdHhvVHJhbnNhY3Rpb248VE51bWJlcj4ge1xuICBzd2l0Y2ggKHBhcmFtcy5zaWduaW5nU3RlcCkge1xuICAgIGNhc2UgJ3NpZ25lck5vbmNlJzpcbiAgICBjYXNlICdjb3NpZ25lck5vbmNlJzpcbiAgICAgIC8qKlxuICAgICAgICogSW4gY2VydGFpbiBjYXNlcywgdGhlIGNhbGxlciBvZiB0aGlzIG1ldGhvZCBtYXkgbm90IGtub3cgd2hldGhlciB0aGUgdHhIZXggY29udGFpbnMgYSBwc2J0IHdpdGggdGFwcm9vdCBrZXkgcGF0aCBzcGVuZCBpbnB1dChzKS5cbiAgICAgICAqIEluc3RlYWQgb2YgdGhyb3dpbmcgZXJyb3IsIG5vLW9wIGFuZCByZXR1cm4gdGhlIHR4SGV4LiBTbyB0aGF0IHRoZSBjYWxsZXIgY2FuIGNhbGwgdGhpcyBtZXRob2QgaW4gdGhlIHNhbWUgc2VxdWVuY2UuXG4gICAgICAgKi9cbiAgICAgIHJldHVybiB0eDtcbiAgfVxuXG4gIGlmICh0eC5pbnMubGVuZ3RoICE9PSBwYXJhbXMudHhJbmZvPy51bnNwZW50cz8ubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IEVycm9yKCdsZW5ndGggb2YgdW5zcGVudHMgYXJyYXkgc2hvdWxkIGVxdWFsIHRvIHRoZSBudW1iZXIgb2YgdHJhbnNhY3Rpb24gaW5wdXRzJyk7XG4gIH1cblxuICBpZiAoIXBhcmFtcy5wdWJzIHx8ICFpc1RyaXBsZShwYXJhbXMucHVicykpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoYG11c3QgcHJvdmlkZSB4cHViIGFycmF5YCk7XG4gIH1cblxuICBjb25zdCBrZXljaGFpbnMgPSBwYXJhbXMucHVicy5tYXAoKHB1YikgPT4gYmlwMzIuZnJvbUJhc2U1OChwdWIpKSBhcyBUcmlwbGU8QklQMzJJbnRlcmZhY2U+O1xuICBjb25zdCBjb3NpZ25lclB1YiA9IHBhcmFtcy5jb3NpZ25lclB1YiA/PyBwYXJhbXMucHVic1syXTtcbiAgY29uc3QgY29zaWduZXJLZXljaGFpbiA9IGJpcDMyLmZyb21CYXNlNTgoY29zaWduZXJQdWIpO1xuXG4gIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gIGNvbnN0IHdhbGxldFNpZ25lciA9IG5ldyBiaXRnby5XYWxsZXRVbnNwZW50U2lnbmVyPFJvb3RXYWxsZXRLZXlzPihrZXljaGFpbnMsIHNpZ25lcktleWNoYWluLCBjb3NpZ25lcktleWNoYWluKTtcbiAgcmV0dXJuIHNpZ25BbmRWZXJpZnlXYWxsZXRUcmFuc2FjdGlvbih0eCwgcGFyYW1zLnR4SW5mby51bnNwZW50cywgd2FsbGV0U2lnbmVyLCB7XG4gICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlLFxuICB9KSBhcyB1dHhvbGliLmJpdGdvLlV0eG9UcmFuc2FjdGlvbjxUTnVtYmVyPjtcbn1cbiJdfQ==
@@ -0,0 +1,30 @@
1
+ import * as utxolib from '@bitgo-beta/utxo-lib';
2
+ import { BIP32Interface } from '@bitgo-beta/secp256k1';
3
+ import { Musig2Participant } from './musig2';
4
+ export type PsbtParsedScriptType = 'p2sh' | 'p2wsh' | 'p2shP2wsh' | 'p2shP2pk' | 'taprootKeyPathSpend' | 'taprootScriptPathSpend' | 'p2trLegacy' | 'p2trMusig2ScriptPath' | 'p2trMusig2KeyPath';
5
+ /**
6
+ * Sign all inputs of a psbt and verify signatures after signing.
7
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
8
+ * failed.
9
+ *
10
+ * If it is the last signature, finalize and extract the transaction from the psbt.
11
+ *
12
+ * This function mirrors signAndVerifyWalletTransaction, but is used for signing PSBTs instead of
13
+ * using TransactionBuilder
14
+ *
15
+ * @param psbt
16
+ * @param signerKeychain
17
+ * @param isLastSignature
18
+ */
19
+ export declare function signAndVerifyPsbt(psbt: utxolib.bitgo.UtxoPsbt, signerKeychain: utxolib.BIP32Interface, { isLastSignature,
20
+ /** deprecated */
21
+ allowNonSegwitSigningWithoutPrevTx, }: {
22
+ isLastSignature: boolean;
23
+ allowNonSegwitSigningWithoutPrevTx?: boolean;
24
+ }): utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint>;
25
+ export declare function signPsbtWithMusig2Participant(coin: Musig2Participant<utxolib.bitgo.UtxoPsbt>, tx: utxolib.bitgo.UtxoPsbt, signerKeychain: BIP32Interface | undefined, params: {
26
+ isLastSignature: boolean;
27
+ signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
28
+ walletId: string | undefined;
29
+ }): Promise<utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint>>;
30
+ //# sourceMappingURL=signPsbt.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signPsbt.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/signPsbt.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAKvD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAI7C,MAAM,MAAM,oBAAoB,GAC5B,MAAM,GACN,OAAO,GACP,WAAW,GACX,UAAU,GACV,qBAAqB,GACrB,wBAAwB,GAExB,YAAY,GACZ,sBAAsB,GACtB,mBAAmB,CAAC;AAExB;;;;;;;;;;;;;GAaG;AACH,wBAAgB,iBAAiB,CAC/B,IAAI,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC5B,cAAc,EAAE,OAAO,CAAC,cAAc,EACtC,EACE,eAAe;AACf,iBAAiB;AACjB,kCAAkC,GACnC,EAAE;IAAE,eAAe,EAAE,OAAO,CAAC;IAAC,kCAAkC,CAAC,EAAE,OAAO,CAAA;CAAE,GAC5E,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CA6DhE;AAYD,wBAAsB,6BAA6B,CACjD,IAAI,EAAE,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,EAC/C,EAAE,EAAE,OAAO,CAAC,KAAK,CAAC,QAAQ,EAC1B,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,MAAM,EAAE;IACN,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;CAC9B,GACA,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAsDzE"}
@@ -0,0 +1,134 @@
1
+ import assert from 'assert';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ import { bitgo } from '@bitgo-beta/utxo-lib';
4
+ import debugLib from 'debug';
5
+ import { InputSigningError, TransactionSigningError } from './SigningError';
6
+ const debug = debugLib('bitgo:v2:utxo');
7
+ /**
8
+ * Sign all inputs of a psbt and verify signatures after signing.
9
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them
10
+ * failed.
11
+ *
12
+ * If it is the last signature, finalize and extract the transaction from the psbt.
13
+ *
14
+ * This function mirrors signAndVerifyWalletTransaction, but is used for signing PSBTs instead of
15
+ * using TransactionBuilder
16
+ *
17
+ * @param psbt
18
+ * @param signerKeychain
19
+ * @param isLastSignature
20
+ */
21
+ export function signAndVerifyPsbt(psbt, signerKeychain, { isLastSignature,
22
+ /** deprecated */
23
+ allowNonSegwitSigningWithoutPrevTx, }) {
24
+ const txInputs = psbt.txInputs;
25
+ const outputIds = [];
26
+ const scriptTypes = [];
27
+ const signErrors = psbt.data.inputs
28
+ .map((input, inputIndex) => {
29
+ const outputId = utxolib.bitgo.formatOutputId(utxolib.bitgo.getOutputIdForInput(txInputs[inputIndex]));
30
+ outputIds.push(outputId);
31
+ const { scriptType } = utxolib.bitgo.parsePsbtInput(input);
32
+ scriptTypes.push(scriptType);
33
+ if (scriptType === 'p2shP2pk') {
34
+ debug('Skipping signature for input %d of %d (RP input?)', inputIndex + 1, psbt.data.inputs.length);
35
+ return;
36
+ }
37
+ try {
38
+ psbt.signInputHD(inputIndex, signerKeychain);
39
+ debug('Successfully signed input %d of %d', inputIndex + 1, psbt.data.inputs.length);
40
+ }
41
+ catch (e) {
42
+ return new InputSigningError(inputIndex, scriptType, { id: outputId }, e);
43
+ }
44
+ })
45
+ .filter((e) => e !== undefined);
46
+ const verifyErrors = psbt.data.inputs
47
+ .map((input, inputIndex) => {
48
+ const scriptType = scriptTypes[inputIndex];
49
+ if (scriptType === 'p2shP2pk') {
50
+ debug('Skipping input signature %d of %d (unspent from replay protection address which is platform signed only)', inputIndex + 1, psbt.data.inputs.length);
51
+ return;
52
+ }
53
+ const outputId = outputIds[inputIndex];
54
+ try {
55
+ if (!psbt.validateSignaturesOfInputHD(inputIndex, signerKeychain)) {
56
+ return new InputSigningError(inputIndex, scriptType, { id: outputId }, new Error(`invalid signature`));
57
+ }
58
+ }
59
+ catch (e) {
60
+ debug('Invalid signature');
61
+ return new InputSigningError(inputIndex, scriptType, { id: outputId }, e);
62
+ }
63
+ })
64
+ .filter((e) => e !== undefined);
65
+ if (signErrors.length || verifyErrors.length) {
66
+ throw new TransactionSigningError(signErrors, verifyErrors);
67
+ }
68
+ if (isLastSignature) {
69
+ psbt.finalizeAllInputs();
70
+ return psbt.extractTransaction();
71
+ }
72
+ return psbt;
73
+ }
74
+ /**
75
+ * Key Value: Unsigned tx id => PSBT
76
+ * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
77
+ * Reason: MuSig2 signer secure nonce is cached in the UtxoPsbt object. It will be required during the signing step.
78
+ * For more info, check SignTransactionOptions.signingStep
79
+ *
80
+ * TODO BTC-276: This cache may need to be done with LRU like memory safe caching if memory issues comes up.
81
+ */
82
+ const PSBT_CACHE = new Map();
83
+ export async function signPsbtWithMusig2Participant(coin, tx, signerKeychain, params) {
84
+ if (bitgo.isTransactionWithKeyPathSpendInput(tx)) {
85
+ // We can only be the first signature on a transaction with taproot key path spend inputs because
86
+ // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
87
+ // deserialized from a hex.
88
+ if (params.isLastSignature) {
89
+ throw new Error('Cannot be last signature on a transaction with key path spend inputs');
90
+ }
91
+ switch (params.signingStep) {
92
+ case 'signerNonce':
93
+ assert(signerKeychain);
94
+ tx.setAllInputsMusig2NonceHD(signerKeychain);
95
+ PSBT_CACHE.set(tx.getUnsignedTx().getId(), tx);
96
+ return tx;
97
+ case 'cosignerNonce':
98
+ assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
99
+ return await coin.getMusig2Nonces(tx, params.walletId);
100
+ case 'signerSignature':
101
+ const txId = tx.getUnsignedTx().getId();
102
+ const psbt = PSBT_CACHE.get(txId);
103
+ assert(psbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE.size}).
104
+ This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
105
+ PSBT_CACHE.delete(txId);
106
+ tx = psbt.combine(tx);
107
+ break;
108
+ default:
109
+ // this instance is not an external signer
110
+ assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
111
+ assert(signerKeychain);
112
+ tx.setAllInputsMusig2NonceHD(signerKeychain);
113
+ const response = await coin.getMusig2Nonces(tx, params.walletId);
114
+ tx = tx.combine(response);
115
+ break;
116
+ }
117
+ }
118
+ else {
119
+ switch (params.signingStep) {
120
+ case 'signerNonce':
121
+ case 'cosignerNonce':
122
+ /**
123
+ * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
124
+ * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
125
+ */
126
+ return tx;
127
+ }
128
+ }
129
+ assert(signerKeychain);
130
+ return signAndVerifyPsbt(tx, signerKeychain, {
131
+ isLastSignature: params.isLastSignature,
132
+ });
133
+ }
134
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblBzYnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvdHJhbnNhY3Rpb24vZml4ZWRTY3JpcHQvc2lnblBzYnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxNQUFNLE1BQU0sUUFBUSxDQUFDO0FBRTVCLE9BQU8sS0FBSyxPQUFPLE1BQU0sc0JBQXNCLENBQUM7QUFFaEQsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQzdDLE9BQU8sUUFBUSxNQUFNLE9BQU8sQ0FBQztBQUU3QixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUc1RSxNQUFNLEtBQUssR0FBRyxRQUFRLENBQUMsZUFBZSxDQUFDLENBQUM7QUFjeEM7Ozs7Ozs7Ozs7Ozs7R0FhRztBQUNILE1BQU0sVUFBVSxpQkFBaUIsQ0FDL0IsSUFBNEIsRUFDNUIsY0FBc0MsRUFDdEMsRUFDRSxlQUFlO0FBQ2YsaUJBQWlCO0FBQ2pCLGtDQUFrQyxHQUN5QztJQUU3RSxNQUFNLFFBQVEsR0FBRyxJQUFJLENBQUMsUUFBUSxDQUFDO0lBQy9CLE1BQU0sU0FBUyxHQUFhLEVBQUUsQ0FBQztJQUMvQixNQUFNLFdBQVcsR0FBMkIsRUFBRSxDQUFDO0lBRS9DLE1BQU0sVUFBVSxHQUFnQyxJQUFJLENBQUMsSUFBSSxDQUFDLE1BQU07U0FDN0QsR0FBRyxDQUFDLENBQUMsS0FBSyxFQUFFLFVBQWtCLEVBQUUsRUFBRTtRQUNqQyxNQUFNLFFBQVEsR0FBRyxPQUFPLENBQUMsS0FBSyxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxVQUFVLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDdkcsU0FBUyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUV6QixNQUFNLEVBQUUsVUFBVSxFQUFFLEdBQUcsT0FBTyxDQUFDLEtB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UUFBUSxFQUFFLDZDQUE2QyxDQUFDLENBQUM7Z0JBQ3ZFLE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztnQkFDdkIsRUFBRSxDQUFDLHlCQUF5QixDQUFDLGNBQWMsQ0FBQyxDQUFDO2dCQUM3QyxNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDakUsRUFBRSxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUMsUUFBUSxDQUFDLENBQUM7Z0JBQzFCLE1BQU07UUFDVixDQUFDO0lBQ0gsQ0FBQztTQUFNLENBQUM7UUFDTixRQUFRLE1BQU0sQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUMzQixLQUFLLGFBQWEsQ0FBQztZQUNuQixLQUFLLGVBQWU7Z0JBQ2xCOzs7bUJBR0c7Z0JBQ0gsT0FBTyxFQUFFLENBQUM7UUFDZCxDQUFDO0lBQ0gsQ0FBQztJQUVELE1BQU0sQ0FBQyxjQUFjLENBQUMsQ0FBQztJQUN2QixPQUFPLGlCQUFpQixDQUFDLEVBQUUsRUFBRSxjQUFjLEVBQUU7UUFDM0MsZUFBZSxFQUFFLE1BQU0sQ0FBQyxlQUFlO0tBQ3hDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgQklQMzJJbnRlcmZhY2UgfSBmcm9tICdAYml0Z28tYmV0YS9zZWNwMjU2azEnO1xuaW1wb3J0IHsgYml0Z28gfSBmcm9tICdAYml0Z28tYmV0YS91dHhvLWxpYic7XG5pbXBvcnQgZGVidWdMaWIgZnJvbSAnZGVidWcnO1xuXG5pbXBvcnQgeyBJbnB1dFNpZ25pbmdFcnJvciwgVHJhbnNhY3Rpb25TaWduaW5nRXJyb3IgfSBmcm9tICcuL1NpZ25pbmdFcnJvcic7XG5pbXBvcnQgeyBNdXNpZzJQYXJ0aWNpcGFudCB9IGZyb20gJy4vbXVzaWcyJztcblxuY29uc3QgZGVidWcgPSBkZWJ1Z0xpYignYml0Z286djI6dXR4bycpO1xuXG5leHBvcnQgdHlwZSBQc2J0UGFyc2VkU2NyaXB0VHlwZSA9XG4gIHwgJ3Ayc2gnXG4gIHwgJ3Ayd3NoJ1xuICB8ICdwMnNoUDJ3c2gnXG4gIHwgJ3Ayc2hQMnBrJ1xuICB8ICd0YXByb290S2V5UGF0aFNwZW5kJ1xuICB8ICd0YXByb290U2NyaXB0UGF0aFNwZW5kJ1xuICAvLyB3YXNtLXV0eG8gdHlwZXNcbiAgfCAncDJ0ckxlZ2FjeSdcbiAgfCAncDJ0ck11c2lnMlNjcmlwdFBhdGgnXG4gIHwgJ3AydHJNdXNpZzJLZXlQYXRoJztcblxuLyoqXG4gKiBTaWduIGFsbCBpbnB1dHMgb2YgYSBwc2J0IGFuZCB2ZXJpZnkgc2lnbmF0dXJlcyBhZnRlciBzaWduaW5nLlxuICogQ29sbGVjdHMgYW5kIGxvZ3Mgc2lnbmluZyBlcnJvcnMgYW5kIHZlcmlmaWNhdGlvbiBlcnJvcnMsIHRocm93cyBlcnJvciBpbiB0aGUgZW5kIGlmIGFueSBvZiB0aGVtXG4gKiBmYWlsZWQuXG4gKlxuICogSWYgaXQgaXMgdGhlIGxhc3Qgc2lnbmF0dXJlLCBmaW5hbGl6ZSBhbmQgZXh0cmFjdCB0aGUgdHJhbnNhY3Rpb24gZnJvbSB0aGUgcHNidC5cbiAqXG4gKiBUaGlzIGZ1bmN0aW9uIG1pcnJvcnMgc2lnbkFuZFZlcmlmeVdhbGxldFRyYW5zYWN0aW9uLCBidXQgaXMgdXNlZCBmb3Igc2lnbmluZyBQU0JUcyBpbnN0ZWFkIG9mXG4gKiB1c2luZyBUcmFuc2FjdGlvbkJ1aWxkZXJcbiAqXG4gKiBAcGFyYW0gcHNidFxuICogQHBhcmFtIHNpZ25lcktleWNoYWluXG4gKiBAcGFyYW0gaXNMYXN0U2lnbmF0dXJlXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzaWduQW5kVmVyaWZ5UHNidChcbiAgcHNidDogdXR4b2xpYi5iaXRnby5VdHhvUHNidCxcbiAgc2lnbmVyS2V5Y2hhaW46IHV0eG9saWIuQklQMzJJbnRlcmZhY2UsXG4gIHtcbiAgICBpc0xhc3RTaWduYXR1cmUsXG4gICAgLyoqIGRlcHJlY2F0ZWQgKi9cbiAgICBhbGxvd05vblNlZ3dpdFNpZ25pbmdXaXRob3V0UHJldlR4LFxuICB9OiB7IGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjsgYWxsb3dOb25TZWd3aXRTaWduaW5nV2l0aG91dFByZXZUeD86IGJvb2xlYW4gfVxuKTogdXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludD4ge1xuICBjb25zdCB0eElucHV0cyA9IHBzYnQudHhJbnB1dHM7XG4gIGNvbnN0IG91dHB1dElkczogc3RyaW5nW10gPSBbXTtcbiAgY29uc3Qgc2NyaXB0VHlwZXM6IFBzYnRQYXJzZWRTY3JpcHRUeXBlW10gPSBbXTtcblxuICBjb25zdCBzaWduRXJyb3JzOiBJbnB1dFNpZ25pbmdFcnJvcjxiaWdpbnQ+W10gPSBwc2J0LmRhdGEuaW5wdXRzXG4gICAgLm1hcCgoaW5wdXQsIGlucHV0SW5kZXg6IG51bWJlcikgPT4ge1xuICAgICAgY29uc3Qgb3V0cHV0SWQgPSB1dHhvbGliLmJpdGdvLmZvcm1hdE91dHB1dElkKHV0eG9saWIuYml0Z28uZ2V0T3V0cHV0SWRGb3JJbnB1dCh0eElucHV0c1tpbnB1dEluZGV4XSkpO1xuICAgICAgb3V0cHV0SWRzLnB1c2gob3V0cHV0SWQpO1xuXG4gICAgICBjb25zdCB7IHNjcmlwdFR5cGUgfSA9IHV0eG9saWIuYml0Z28ucGFyc2VQc2J0SW5wdXQoaW5wdXQpO1xuICAgICAgc2NyaXB0VHlwZXMucHVzaChzY3JpcHRUeXBlKTtcblxuICAgICAgaWYgKHNjcmlwdFR5cGUgPT09ICdwMnNoUDJwaycpIHtcbiAgICAgICAgZGVidWcoJ1NraXBwaW5nIHNpZ25hdHVyZSBmb3IgaW5wdXQgJWQgb2YgJWQgKFJQIGlucHV0PyknLCBpbnB1dEluZGV4ICsgMSwgcHNidC5kYXRhLmlucHV0cy5sZW5ndGgpO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIHRyeSB7XG4gICAgICAgIHBzYnQuc2lnbklucHV0SEQoaW5wdXRJbmRleCwgc2lnbmVyS2V5Y2hhaW4pO1xuICAgICAgICBkZWJ1ZygnU3VjY2Vzc2Z1bGx5IHNpZ25lZCBpbnB1dCAlZCBvZiAlZCcsIGlucHV0SW5kZXggKyAxLCBwc2J0LmRhdGEuaW5wdXRzLmxlbmd0aCk7XG4gICAgICB9IGNhdGNoIChlKSB7XG4gICAgICAgIHJldHVybiBuZXcgSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PihpbnB1dEluZGV4LCBzY3JpcHRUeXBlLCB7IGlkOiBvdXRwdXRJZCB9LCBlKTtcbiAgICAgIH1cbiAgICB9KVxuICAgIC5maWx0ZXIoKGUpOiBlIGlzIElucHV0U2lnbmluZ0Vycm9yPGJpZ2ludD4gPT4gZSAhPT0gdW5kZWZpbmVkKTtcblxuICBjb25zdCB2ZXJpZnlFcnJvcnM6IElucHV0U2lnbmluZ0Vycm9yPGJpZ2ludD5bXSA9IHBzYnQuZGF0YS5pbnB1dHNcbiAgICAubWFwKChpbnB1dCwgaW5wdXRJbmRleCkgPT4ge1xuICAgICAgY29uc3Qgc2NyaXB0VHlwZSA9IHNjcmlwdFR5cGVzW2lucHV0SW5kZXhdO1xuICAgICAgaWYgKHNjcmlwdFR5cGUgPT09ICdwMnNoUDJwaycpIHtcbiAgICAgICAgZGVidWcoXG4gICAgICAgICAgJ1NraXBwaW5nIGlucHV0IHNpZ25hdHVyZSAlZCBvZiAlZCAodW5zcGVudCBmcm9tIHJlcGxheSBwcm90ZWN0aW9uIGFkZHJlc3Mgd2hpY2ggaXMgcGxhdGZvcm0gc2lnbmVkIG9ubHkpJyxcbiAgICAgICAgICBpbnB1dEluZGV4ICsgMSxcbiAgICAgICAgICBwc2J0LmRhdGEuaW5wdXRzLmxlbmd0aFxuICAgICAgICApO1xuICAgICAgICByZXR1cm47XG4gICAgICB9XG5cbiAgICAgIGNvbnN0IG91dHB1dElkID0gb3V0cHV0SWRzW2lucHV0SW5kZXhdO1xuICAgICAgdHJ5IHtcbiAgICAgICAgaWYgKCFwc2J0LnZhbGlkYXRlU2lnbmF0dXJlc09mSW5wdXRIRChpbnB1dEluZGV4LCBzaWduZXJLZXljaGFpbikpIHtcbiAgICAgICAgICByZXR1cm4gbmV3IElucHV0U2lnbmluZ0Vycm9yKGlucHV0SW5kZXgsIHNjcmlwdFR5cGUsIHsgaWQ6IG91dHB1dElkIH0sIG5ldyBFcnJvcihgaW52YWxpZCBzaWduYXR1cmVgKSk7XG4gICAgICAgIH1cbiAgICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgICAgZGVidWcoJ0ludmFsaWQgc2lnbmF0dXJlJyk7XG4gICAgICAgIHJldHVybiBuZXcgSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PihpbnB1dEluZGV4LCBzY3JpcHRUeXBlLCB7IGlkOiBvdXRwdXRJZCB9LCBlKTtcbiAgICAgIH1cbiAgICB9KVxuICAgIC5maWx0ZXIoKGUpOiBlIGlzIElucHV0U2lnbmluZ0Vycm9yPGJpZ2ludD4gPT4gZSAhPT0gdW5kZWZpbmVkKTtcblxuICBpZiAoc2lnbkVycm9ycy5sZW5ndGggfHwgdmVyaWZ5RXJyb3JzLmxlbmd0aCkge1xuICAgIHRocm93IG5ldyBUcmFuc2FjdGlvblNpZ25pbmdFcnJvcihzaWduRXJyb3JzLCB2ZXJpZnlFcnJvcnMpO1xuICB9XG5cbiAgaWYgKGlzTGFzdFNpZ25hdHVyZSkge1xuICAgIHBzYnQuZmluYWxpemVBbGxJbnB1dHMoKTtcbiAgICByZXR1cm4gcHNidC5leHRyYWN0VHJhbnNhY3Rpb24oKTtcbiAgfVxuXG4gIHJldHVybiBwc2J0O1xufVxuXG4vKipcbiAqIEtleSBWYWx1ZTogVW5zaWduZWQgdHggaWQgPT4gUFNCVFxuICogSXQgaXMgdXNlZCB0byBjYWNoZSBQU0JUcyB3aXRoIHRhcHJvb3Qga2V5IHBhdGggKE11U2lnMikgaW5wdXRzIGR1cmluZyBleHRlcm5hbCBleHByZXNzIHNpZ25lciBpcyBhY3RpdmF0ZWQuXG4gKiBSZWFzb246IE11U2lnMiBzaWduZXIgc2VjdXJlIG5vbmNlIGlzIGNhY2hlZCBpbiB0aGUgVXR4b1BzYnQgb2JqZWN0LiBJdCB3aWxsIGJlIHJlcXVpcmVkIGR1cmluZyB0aGUgc2lnbmluZyBzdGVwLlxuICogRm9yIG1vcmUgaW5mbywgY2hlY2sgU2lnblRyYW5zYWN0aW9uT3B0aW9ucy5zaWduaW5nU3RlcFxuICpcbiAqIFRPRE8gQlRDLTI3NjogVGhpcyBjYWNoZSBtYXkgbmVlZCB0byBiZSBkb25lIHdpdGggTFJVIGxpa2UgbWVtb3J5IHNhZmUgY2FjaGluZyBpZiBtZW1vcnkgaXNzdWVzIGNvbWVzIHVwLlxuICovXG5jb25zdCBQU0JUX0NBQ0hFID0gbmV3IE1hcDxzdHJpbmcsIHV0eG9saWIuYml0Z28uVXR4b1BzYnQ+KCk7XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBzaWduUHNidFdpdGhNdXNpZzJQYXJ0aWNpcGFudChcbiAgY29pbjogTXVzaWcyUGFydGljaXBhbnQ8dXR4b2xpYi5iaXRnby5VdHhvUHNidD4sXG4gIHR4OiB1dHhvbGliLmJpdGdvLlV0eG9Qc2J0LFxuICBzaWduZXJLZXljaGFpbjogQklQMzJJbnRlcmZhY2UgfCB1bmRlZmluZWQsXG4gIHBhcmFtczoge1xuICAgIGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjtcbiAgICBzaWduaW5nU3RlcDogJ3NpZ25lck5vbmNlJyB8ICdjb3NpZ25lck5vbmNlJyB8ICdzaWduZXJTaWduYXR1cmUnIHwgdW5kZWZpbmVkO1xuICAgIHdhbGxldElkOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH1cbik6IFByb21pc2U8dXR4b2xpYi5iaXRnby5VdHhvUHNidCB8IHV0eG9saWIuYml0Z28uVXR4b1RyYW5zYWN0aW9uPGJpZ2ludD4+IHtcbiAgaWYgKGJpdGdvLmlzVHJhbnNhY3Rpb25XaXRoS2V5UGF0aFNwZW5kSW5wdXQodHgpKSB7XG4gICAgLy8gV2UgY2FuIG9ubHkgYmUgdGhlIGZpcnN0IHNpZ25hdHVyZSBvbiBhIHRyYW5zYWN0aW9uIHdpdGggdGFwcm9vdCBrZXkgcGF0aCBzcGVuZCBpbnB1dHMgYmVjYXVzZVxuICAgIC8vIHdlIHJlcXVpcmUgdGhlIHNlY3JldCBub25jZSBpbiB0aGUgY2FjaGUgb2YgdGhlIGZpcnN0IHNpZ25lciwgd2hpY2ggaXMgaW1wb3NzaWJsZSB0byByZXRyaWV2ZSBpZlxuICAgIC8vIGRlc2VyaWFsaXplZCBmcm9tIGEgaGV4LlxuICAgIGlmIChwYXJhbXMuaXNMYXN0U2lnbmF0dXJlKSB7XG4gICAgICB0aHJvdyBuZXcgRXJyb3IoJ0Nhbm5vdCBiZSBsYXN0IHNpZ25hdHVyZSBvbiBhIHRyYW5zYWN0aW9uIHdpdGgga2V5IHBhdGggc3BlbmQgaW5wdXRzJyk7XG4gICAgfVxuXG4gICAgc3dpdGNoIChwYXJhbXMuc2lnbmluZ1N0ZXApIHtcbiAgICAgIGNhc2UgJ3NpZ25lck5vbmNlJzpcbiAgICAgICAgYXNzZXJ0KHNpZ25lcktleWNoYWluKTtcbiAgICAgICAgdHguc2V0QWxsSW5wdXRzTXVzaWcyTm9uY2VIRChzaWduZXJLZXljaGFpbik7XG4gICAgICAgIFBTQlRfQ0FDSEUuc2V0KHR4LmdldFVuc2lnbmVkVHgoKS5nZXRJZCgpLCB0eCk7XG4gICAgICAgIHJldHVybiB0eDtcbiAgICAgIGNhc2UgJ2Nvc2lnbmVyTm9uY2UnOlxuICAgICAgICBhc3NlcnQocGFyYW1zLndhbGxldElkLCAnd2FsbGV0SWQgaXMgcmVxdWlyZWQgZm9yIE11U2lnMiBiaXRnbyBub25jZScpO1xuICAgICAgICByZXR1cm4gYXdhaXQgY29pbi5nZXRNdXNpZzJOb25jZXModHgsIHBhcmFtcy53YWxsZXRJZCk7XG4gICAgICBjYXNlICdzaWduZXJTaWduYXR1cmUnOlxuICAgICAgICBjb25zdCB0eElkID0gdHguZ2V0VW5zaWduZWRUeCgpLmdldElkKCk7XG4gICAgICAgIGNvbnN0IHBzYnQgPSBQU0JUX0NBQ0hFLmdldCh0eElkKTtcbiAgICAgICAgYXNzZXJ0KFxuICAgICAgICAgIHBzYnQsXG4gICAgICAgICAgYFBzYnQgaXMgbWlzc2luZyBmcm9tIHR4Q2FjaGUgKGNhY2hlIHNpemUgJHtQU0JUX0NBQ0hFLnNpemV9KS5cbiAgICAgICAgICAgIFRoaXMgbWF5IGJlIGR1ZSB0byB0aGUgcmVxdWVzdCBiZWluZyByb3V0ZWQgdG8gYSBkaWZmZXJlbnQgQml0R28tRXhwcmVzcyBpbnN0YW5jZSB0aGF0IGZvciBzaWduaW5nIHN0ZXAgJ3NpZ25lck5vbmNlJy5gXG4gICAgICAgICk7XG4gICAgICAgIFBTQlRfQ0FDSEUuZGVsZXRlKHR4SWQpO1xuICAgICAgICB0eCA9IHBzYnQuY29tYmluZSh0eCk7XG4gICAgICAgIGJyZWFrO1xuICAgICAgZGVmYXVsdDpcbiAgICAgICAgLy8gdGhpcyBpbnN0YW5jZSBpcyBub3QgYW4gZXh0ZXJuYWwgc2lnbmVyXG4gICAgICAgIGFzc2VydChwYXJhbXMud2FsbGV0SWQsICd3YWxsZXRJZCBpcyByZXF1aXJlZCBmb3IgTXVTaWcyIGJpdGdvIG5vbmNlJyk7XG4gICAgICAgIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gICAgICAgIHR4LnNldEFsbElucHV0c011c2lnMk5vbmNlSEQoc2lnbmVyS2V5Y2hhaW4pO1xuICAgICAgICBjb25zdCByZXNwb25zZSA9IGF3YWl0IGNvaW4uZ2V0TXVzaWcyTm9uY2VzKHR4LCBwYXJhbXMud2FsbGV0SWQpO1xuICAgICAgICB0eCA9IHR4LmNvbWJpbmUocmVzcG9uc2UpO1xuICAgICAgICBicmVhaztcbiAgICB9XG4gIH0gZWxzZSB7XG4gICAgc3dpdGNoIChwYXJhbXMuc2lnbmluZ1N0ZXApIHtcbiAgICAgIGNhc2UgJ3NpZ25lck5vbmNlJzpcbiAgICAgIGNhc2UgJ2Nvc2lnbmVyTm9uY2UnOlxuICAgICAgICAvKipcbiAgICAgICAgICogSW4gY2VydGFpbiBjYXNlcywgdGhlIGNhbGxlciBvZiB0aGlzIG1ldGhvZCBtYXkgbm90IGtub3cgd2hldGhlciB0aGUgdHhIZXggY29udGFpbnMgYSBwc2J0IHdpdGggdGFwcm9vdCBrZXkgcGF0aCBzcGVuZCBpbnB1dChzKS5cbiAgICAgICAgICogSW5zdGVhZCBvZiB0aHJvd2luZyBlcnJvciwgbm8tb3AgYW5kIHJldHVybiB0aGUgdHhIZXguIFNvIHRoYXQgdGhlIGNhbGxlciBjYW4gY2FsbCB0aGlzIG1ldGhvZCBpbiB0aGUgc2FtZSBzZXF1ZW5jZS5cbiAgICAgICAgICovXG4gICAgICAgIHJldHVybiB0eDtcbiAgICB9XG4gIH1cblxuICBhc3NlcnQoc2lnbmVyS2V5Y2hhaW4pO1xuICByZXR1cm4gc2lnbkFuZFZlcmlmeVBzYnQodHgsIHNpZ25lcktleWNoYWluLCB7XG4gICAgaXNMYXN0U2lnbmF0dXJlOiBwYXJhbXMuaXNMYXN0U2lnbmF0dXJlLFxuICB9KTtcbn1cbiJdfQ==
@@ -0,0 +1,22 @@
1
+ import { BIP32Interface } from '@bitgo-beta/utxo-lib';
2
+ import { ECPair, fixedScriptWallet } from '@bitgo/wasm-utxo';
3
+ import { Musig2Participant } from './musig2';
4
+ export type ReplayProtectionKeys = {
5
+ publicKeys: (Uint8Array | ECPair)[];
6
+ };
7
+ /**
8
+ * Sign all inputs of a PSBT and verify signatures after signing.
9
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them failed.
10
+ *
11
+ * If it is the last signature, finalize and extract the transaction from the psbt.
12
+ */
13
+ export declare function signAndVerifyPsbtWasm(tx: fixedScriptWallet.BitGoPsbt, signerKeychain: BIP32Interface, rootWalletKeys: fixedScriptWallet.RootWalletKeys, replayProtection: ReplayProtectionKeys, { isLastSignature }: {
14
+ isLastSignature: boolean;
15
+ }): fixedScriptWallet.BitGoPsbt | Buffer;
16
+ export declare function signPsbtWithMusig2ParticipantWasm(coin: Musig2Participant<fixedScriptWallet.BitGoPsbt>, tx: fixedScriptWallet.BitGoPsbt, signerKeychain: BIP32Interface | undefined, rootWalletKeys: fixedScriptWallet.RootWalletKeys, params: {
17
+ replayProtection: ReplayProtectionKeys;
18
+ isLastSignature: boolean;
19
+ signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
20
+ walletId: string | undefined;
21
+ }): Promise<fixedScriptWallet.BitGoPsbt | Buffer>;
22
+ //# sourceMappingURL=signPsbtWasm.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signPsbtWasm.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/signPsbtWasm.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AACtD,OAAO,EAAS,MAAM,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAGpE,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAE7C,MAAM,MAAM,oBAAoB,GAAG;IACjC,UAAU,EAAE,CAAC,UAAU,GAAG,MAAM,CAAC,EAAE,CAAC;CACrC,CAAC;AAmBF;;;;;GAKG;AACH,wBAAgB,qBAAqB,CACnC,EAAE,EAAE,iBAAiB,CAAC,SAAS,EAC/B,cAAc,EAAE,cAAc,EAC9B,cAAc,EAAE,iBAAiB,CAAC,cAAc,EAChD,gBAAgB,EAAE,oBAAoB,EACtC,EAAE,eAAe,EAAE,EAAE;IAAE,eAAe,EAAE,OAAO,CAAA;CAAE,GAChD,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAkDtC;AAOD,wBAAsB,iCAAiC,CACrD,IAAI,EAAE,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,EACpD,EAAE,EAAE,iBAAiB,CAAC,SAAS,EAC/B,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,cAAc,EAAE,iBAAiB,CAAC,cAAc,EAChD,MAAM,EAAE;IACN,gBAAgB,EAAE,oBAAoB,CAAC;IACvC,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;CAC9B,GACA,OAAO,CAAC,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAAC,CA0D/C"}
@@ -0,0 +1,122 @@
1
+ import assert from 'assert';
2
+ import { BIP32 } from '@bitgo/wasm-utxo';
3
+ import { InputSigningError, TransactionSigningError } from './SigningError';
4
+ /**
5
+ * Key Value: Unsigned tx id => PSBT
6
+ * It is used to cache PSBTs with taproot key path (MuSig2) inputs during external express signer is activated.
7
+ * Reason: MuSig2 signer secure nonce is cached in the BitGoPsbt object. It will be required during the signing step.
8
+ * For more info, check SignTransactionOptions.signingStep
9
+ */
10
+ const PSBT_CACHE_WASM = new Map();
11
+ function hasKeyPathSpendInput(tx, rootWalletKeys, replayProtection) {
12
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
13
+ return parsed.inputs.some((input) => input.scriptType === 'p2trMusig2KeyPath');
14
+ }
15
+ /**
16
+ * Sign all inputs of a PSBT and verify signatures after signing.
17
+ * Collects and logs signing errors and verification errors, throws error in the end if any of them failed.
18
+ *
19
+ * If it is the last signature, finalize and extract the transaction from the psbt.
20
+ */
21
+ export function signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, replayProtection, { isLastSignature }) {
22
+ const wasmSigner = toWasmBIP32(signerKeychain);
23
+ const parsed = tx.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
24
+ const signErrors = [];
25
+ const verifyErrors = [];
26
+ // Sign all inputs (skipping replay protection inputs)
27
+ parsed.inputs.forEach((input, inputIndex) => {
28
+ if (input.scriptType === 'p2shP2pk') {
29
+ // Skip replay protection inputs - they are platform signed only
30
+ return;
31
+ }
32
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
33
+ try {
34
+ tx.sign(inputIndex, wasmSigner);
35
+ }
36
+ catch (e) {
37
+ signErrors.push(new InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
38
+ }
39
+ });
40
+ // Verify signatures for all signed inputs
41
+ parsed.inputs.forEach((input, inputIndex) => {
42
+ if (input.scriptType === 'p2shP2pk') {
43
+ return;
44
+ }
45
+ const outputId = `${input.previousOutput.txid}:${input.previousOutput.vout}`;
46
+ try {
47
+ if (!tx.verifySignature(inputIndex, wasmSigner)) {
48
+ verifyErrors.push(new InputSigningError(inputIndex, input.scriptType, { id: outputId }, new Error('invalid signature')));
49
+ }
50
+ }
51
+ catch (e) {
52
+ verifyErrors.push(new InputSigningError(inputIndex, input.scriptType, { id: outputId }, e));
53
+ }
54
+ });
55
+ if (signErrors.length || verifyErrors.length) {
56
+ throw new TransactionSigningError(signErrors, verifyErrors);
57
+ }
58
+ if (isLastSignature) {
59
+ tx.finalizeAllInputs();
60
+ return Buffer.from(tx.extractTransaction());
61
+ }
62
+ return tx;
63
+ }
64
+ function toWasmBIP32(key) {
65
+ // Convert using base58 string to ensure private key is properly transferred
66
+ return BIP32.fromBase58(key.toBase58());
67
+ }
68
+ export async function signPsbtWithMusig2ParticipantWasm(coin, tx, signerKeychain, rootWalletKeys, params) {
69
+ const wasmSigner = signerKeychain ? toWasmBIP32(signerKeychain) : undefined;
70
+ if (hasKeyPathSpendInput(tx, rootWalletKeys, params.replayProtection)) {
71
+ // We can only be the first signature on a transaction with taproot key path spend inputs because
72
+ // we require the secret nonce in the cache of the first signer, which is impossible to retrieve if
73
+ // deserialized from a hex.
74
+ if (params.isLastSignature) {
75
+ throw new Error('Cannot be last signature on a transaction with key path spend inputs');
76
+ }
77
+ switch (params.signingStep) {
78
+ case 'signerNonce':
79
+ assert(wasmSigner);
80
+ tx.generateMusig2Nonces(wasmSigner);
81
+ PSBT_CACHE_WASM.set(tx.unsignedTxid(), tx);
82
+ return tx;
83
+ case 'cosignerNonce':
84
+ assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
85
+ return await coin.getMusig2Nonces(tx, params.walletId);
86
+ case 'signerSignature': {
87
+ const txId = tx.unsignedTxid();
88
+ const cachedPsbt = PSBT_CACHE_WASM.get(txId);
89
+ assert(cachedPsbt, `Psbt is missing from txCache (cache size ${PSBT_CACHE_WASM.size}).
90
+ This may be due to the request being routed to a different BitGo-Express instance that for signing step 'signerNonce'.`);
91
+ PSBT_CACHE_WASM.delete(txId);
92
+ cachedPsbt.combineMusig2Nonces(tx);
93
+ tx = cachedPsbt;
94
+ break;
95
+ }
96
+ default:
97
+ // this instance is not an external signer
98
+ assert(params.walletId, 'walletId is required for MuSig2 bitgo nonce');
99
+ assert(wasmSigner);
100
+ tx.generateMusig2Nonces(wasmSigner);
101
+ const response = await coin.getMusig2Nonces(tx, params.walletId);
102
+ tx.combineMusig2Nonces(response);
103
+ break;
104
+ }
105
+ }
106
+ else {
107
+ switch (params.signingStep) {
108
+ case 'signerNonce':
109
+ case 'cosignerNonce':
110
+ /**
111
+ * In certain cases, the caller of this method may not know whether the txHex contains a psbt with taproot key path spend input(s).
112
+ * Instead of throwing error, no-op and return the txHex. So that the caller can call this method in the same sequence.
113
+ */
114
+ return tx;
115
+ }
116
+ }
117
+ assert(signerKeychain);
118
+ return signAndVerifyPsbtWasm(tx, signerKeychain, rootWalletKeys, params.replayProtection, {
119
+ isLastSignature: params.isLastSignature,
120
+ });
121
+ }
122
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2lnblBzYnRXYXNtLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL3RyYW5zYWN0aW9uL2ZpeGVkU2NyaXB0L3NpZ25Qc2J0V2FzbS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLE1BQU0sTUFBTSxRQUFRLENBQUM7QUFHNUIsT0FBTyxFQUFFLEtBQUssRUFBNkIsTUFBTSxrQkFBa0IsQ0FBQztBQUVwRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQU81RTs7Ozs7R0FLRztBQUNILE1BQU0sZUFBZSxHQUFHLElBQUksR0FBRyxFQUF1QyxDQUFDO0FBRXZFLFNBQVMsb0JBQW9CLENBQzNCLEVBQStCLEVBQy9CLGNBQWdELEVBQ2hELGdCQUFzQztJQUV0QyxNQUFNLE1BQU0sR0FBRyxFQUFFLENBQUMsOEJBQThCLENBQUMsY0FBYyxFQUFFLGdCQUFnQixDQUFDLENBQUM7SUFDbkYsT0FBTyxNQUFNLENBQUMsTUFBTSxDQUFDLElBQUksQ0FBQyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsS0FBSyxDQUFDLFVBQVUsS0FBSyxtQkFBbUIsQ0FBQyxDQUFDO0FBQ2pGLENBQUM7QUFFRDs7Ozs7R0FLRztBQUNILE1BQU0sVUFBVSxxQkFBcUIsQ0FDbkMsRUFBK0IsRUFDL0IsY0FBOEIsRUFDOUIsY0FBZ0QsRUFDaEQsZ0JBQXNDLEVBQ3RDLEVBQUUsZUFBZSxFQUFnQztJQUVqRCxNQUFNLFVBQVUsR0FBRyxXQUFXLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDL0MsTUFBTSxNQUFNLEdBQUcsRUFBRSxDQUFDLDhCQUE4QixDQUFDLGNBQWMsRUFBRSxnQkFBZ0IsQ0FBQyxDQUFDO0lBRW5GLE1BQU0sVUFBVSxHQUFnQyxFQUFFLENBQUM7SUFDbkQsTUFBTSxZQUFZLEdBQWdDLEVBQUUsQ0FBQztJQUVyRCxzREFBc0Q7SUFDdEQsTUFBTSxDQUFDLE1BQU0sQ0FBQyxP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bkIsRUFBRSxDQUFDLG9CQUFvQixDQUFDLFVBQVUsQ0FBQyxDQUFDO2dCQUNwQyxNQUFNLFFBQVEsR0FBRyxNQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsRUFBRSxFQUFFLE1BQU0sQ0FBQyxRQUFRLENBQUMsQ0FBQztnQkFDakUsRUFBRSxDQUFDLG1CQUFtQixDQUFDLFFBQVEsQ0FBQyxDQUFDO2dCQUNqQyxNQUFNO1FBQ1YsQ0FBQztJQUNILENBQUM7U0FBTSxDQUFDO1FBQ04sUUFBUSxNQUFNLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDM0IsS0FBSyxhQUFhLENBQUM7WUFDbkIsS0FBSyxlQUFlO2dCQUNsQjs7O21CQUdHO2dCQUNILE9BQU8sRUFBRSxDQUFDO1FBQ2QsQ0FBQztJQUNILENBQUM7SUFFRCxNQUFNLENBQUMsY0FBYyxDQUFDLENBQUM7SUFDdkIsT0FBTyxxQkFBcUIsQ0FBQyxFQUFFLEVBQUUsY0FBYyxFQUFFLGNBQWMsRUFBRSxNQUFNLENBQUMsZ0JBQWdCLEVBQUU7UUFDeEYsZUFBZSxFQUFFLE1BQU0sQ0FBQyxlQUFlO0tBQ3hDLENBQUMsQ0FBQztBQUNMLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgYXNzZXJ0IGZyb20gJ2Fzc2VydCc7XG5cbmltcG9ydCB7IEJJUDMySW50ZXJmYWNlIH0gZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuaW1wb3J0IHsgQklQMzIsIEVDUGFpciwgZml4ZWRTY3JpcHRXYWxsZXQgfSBmcm9tICdAYml0Z28vd2FzbS11dHhvJztcblxuaW1wb3J0IHsgSW5wdXRTaWduaW5nRXJyb3IsIFRyYW5zYWN0aW9uU2lnbmluZ0Vycm9yIH0gZnJvbSAnLi9TaWduaW5nRXJyb3InO1xuaW1wb3J0IHsgTXVzaWcyUGFydGljaXBhbnQgfSBmcm9tICcuL211c2lnMic7XG5cbmV4cG9ydCB0eXBlIFJlcGxheVByb3RlY3Rpb25LZXlzID0ge1xuICBwdWJsaWNLZXlzOiAoVWludDhBcnJheSB8IEVDUGFpcilbXTtcbn07XG5cbi8qKlxuICogS2V5IFZhbHVlOiBVbnNpZ25lZCB0eCBpZCA9PiBQU0JUXG4gKiBJdCBpcyB1c2VkIHRvIGNhY2hlIFBTQlRzIHdpdGggdGFwcm9vdCBrZXkgcGF0aCAoTXVTaWcyKSBpbnB1dHMgZHVyaW5nIGV4dGVybmFsIGV4cHJlc3Mgc2lnbmVyIGlzIGFjdGl2YXRlZC5cbiAqIFJlYXNvbjogTXVTaWcyIHNpZ25lciBzZWN1cmUgbm9uY2UgaXMgY2FjaGVkIGluIHRoZSBCaXRHb1BzYnQgb2JqZWN0LiBJdCB3aWxsIGJlIHJlcXVpcmVkIGR1cmluZyB0aGUgc2lnbmluZyBzdGVwLlxuICogRm9yIG1vcmUgaW5mbywgY2hlY2sgU2lnblRyYW5zYWN0aW9uT3B0aW9ucy5zaWduaW5nU3RlcFxuICovXG5jb25zdCBQU0JUX0NBQ0hFX1dBU00gPSBuZXcgTWFwPHN0cmluZywgZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PigpO1xuXG5mdW5jdGlvbiBoYXNLZXlQYXRoU3BlbmRJbnB1dChcbiAgdHg6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCxcbiAgcm9vdFdhbGxldEtleXM6IGZpeGVkU2NyaXB0V2FsbGV0LlJvb3RXYWxsZXRLZXlzLFxuICByZXBsYXlQcm90ZWN0aW9uOiBSZXBsYXlQcm90ZWN0aW9uS2V5c1xuKTogYm9vbGVhbiB7XG4gIGNvbnN0IHBhcnNlZCA9IHR4LnBhcnNlVHJhbnNhY3Rpb25XaXRoV2FsbGV0S2V5cyhyb290V2FsbGV0S2V5cywgcmVwbGF5UHJvdGVjdGlvbik7XG4gIHJldHVybiBwYXJzZWQuaW5wdXRzLnNvbWUoKGlucHV0KSA9PiBpbnB1dC5zY3JpcHRUeXBlID09PSAncDJ0ck11c2lnMktleVBhdGgnKTtcbn1cblxuLyoqXG4gKiBTaWduIGFsbCBpbnB1dHMgb2YgYSBQU0JUIGFuZCB2ZXJpZnkgc2lnbmF0dXJlcyBhZnRlciBzaWduaW5nLlxuICogQ29sbGVjdHMgYW5kIGxvZ3Mgc2lnbmluZyBlcnJvcnMgYW5kIHZlcmlmaWNhdGlvbiBlcnJvcnMsIHRocm93cyBlcnJvciBpbiB0aGUgZW5kIGlmIGFueSBvZiB0aGVtIGZhaWxlZC5cbiAqXG4gKiBJZiBpdCBpcyB0aGUgbGFzdCBzaWduYXR1cmUsIGZpbmFsaXplIGFuZCBleHRyYWN0IHRoZSB0cmFuc2FjdGlvbiBmcm9tIHRoZSBwc2J0LlxuICovXG5leHBvcnQgZnVuY3Rpb24gc2lnbkFuZFZlcmlmeVBzYnRXYXNtKFxuICB0eDogZml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0LFxuICBzaWduZXJLZXljaGFpbjogQklQMzJJbnRlcmZhY2UsXG4gIHJvb3RXYWxsZXRLZXlzOiBmaXhlZFNjcmlwdFdhbGxldC5Sb290V2FsbGV0S2V5cyxcbiAgcmVwbGF5UHJvdGVjdGlvbjogUmVwbGF5UHJvdGVjdGlvbktleXMsXG4gIHsgaXNMYXN0U2lnbmF0dXJlIH06IHsgaXNMYXN0U2lnbmF0dXJlOiBib29sZWFuIH1cbik6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCB8IEJ1ZmZlciB7XG4gIGNvbnN0IHdhc21TaWduZXIgPSB0b1dhc21CSVAzMihzaWduZXJLZXljaGFpbik7XG4gIGNvbnN0IHBhcnNlZCA9IHR4LnBhcnNlVHJhbnNhY3Rpb25XaXRoV2FsbGV0S2V5cyhyb290V2FsbGV0S2V5cywgcmVwbGF5UHJvdGVjdGlvbik7XG5cbiAgY29uc3Qgc2lnbkVycm9yczogSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PltdID0gW107XG4gIGNvbnN0IHZlcmlmeUVycm9yczogSW5wdXRTaWduaW5nRXJyb3I8YmlnaW50PltdID0gW107XG5cbiAgLy8gU2lnbiBhbGwgaW5wdXRzIChza2lwcGluZyByZXBsYXkgcHJvdGVjdGlvbiBpbnB1dHMpXG4gIHBhcnNlZC5pbnB1dHMuZm9yRWFjaCgoaW5wdXQsIGlucHV0SW5kZXgpID0+IHtcbiAgICBpZiAoaW5wdXQuc2NyaXB0VHlwZSA9PT0gJ3Ayc2hQMnBrJykge1xuICAgICAgLy8gU2tpcCByZXBsYXkgcHJvdGVjdGlvbiBpbnB1dHMgLSB0aGV5IGFyZSBwbGF0Zm9ybSBzaWduZWQgb25seVxuICAgICAgcmV0dXJuO1xuICAgIH1cblxuICAgIGNvbnN0IG91dHB1dElkID0gYCR7aW5wdXQucHJldmlvdXNPdXRwdXQudHhpZH06JHtpbnB1dC5wcmV2aW91c091dHB1dC52b3V0fWA7XG4gICAgdHJ5IHtcbiAgICAgIHR4LnNpZ24oaW5wdXRJbmRleCwgd2FzbVNpZ25lcik7XG4gICAgfSBjYXRjaCAoZSkge1xuICAgICAgc2lnbkVycm9ycy5wdXNoKG5ldyBJbnB1dFNpZ25pbmdFcnJvcjxiaWdpbnQ+KGlucHV0SW5kZXgsIGlucHV0LnNjcmlwdFR5cGUsIHsgaWQ6IG91dHB1dElkIH0sIGUpKTtcbiAgICB9XG4gIH0pO1xuXG4gIC8vIFZlcmlmeSBzaWduYXR1cmVzIGZvciBhbGwgc2lnbmVkIGlucHV0c1xuICBwYXJzZWQuaW5wdXRzLmZvckVhY2goKGlucHV0LCBpbnB1dEluZGV4KSA9PiB7XG4gICAgaWYgKGlucHV0LnNjcmlwdFR5cGUgPT09ICdwMnNoUDJwaycpIHtcbiAgICAgIHJldHVybjtcbiAgICB9XG5cbiAgICBjb25zdCBvdXRwdXRJZCA9IGAke2lucHV0LnByZXZpb3VzT3V0cHV0LnR4aWR9OiR7aW5wdXQucHJldmlvdXNPdXRwdXQudm91dH1gO1xuICAgIHRyeSB7XG4gICAgICBpZiAoIXR4LnZlcmlmeVNpZ25hdHVyZShpbnB1dEluZGV4LCB3YXNtU2lnbmVyKSkge1xuICAgICAgICB2ZXJpZnlFcnJvcnMucHVzaChcbiAgICAgICAgICBuZXcgSW5wdXRTaWduaW5nRXJyb3IoaW5wdXRJbmRleCwgaW5wdXQuc2NyaXB0VHlwZSwgeyBpZDogb3V0cHV0SWQgfSwgbmV3IEVycm9yKCdpbnZhbGlkIHNpZ25hdHVyZScpKVxuICAgICAgICApO1xuICAgICAgfVxuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHZlcmlmeUVycm9ycy5wdXNoKG5ldyBJbnB1dFNpZ25pbmdFcnJvcjxiaWdpbnQ+KGlucHV0SW5kZXgsIGlucHV0LnNjcmlwdFR5cGUsIHsgaWQ6IG91dHB1dElkIH0sIGUpKTtcbiAgICB9XG4gIH0pO1xuXG4gIGlmIChzaWduRXJyb3JzLmxlbmd0aCB8fCB2ZXJpZnlFcnJvcnMubGVuZ3RoKSB7XG4gICAgdGhyb3cgbmV3IFRyYW5zYWN0aW9uU2lnbmluZ0Vycm9yKHNpZ25FcnJvcnMsIHZlcmlmeUVycm9ycyk7XG4gIH1cblxuICBpZiAoaXNMYXN0U2lnbmF0dXJlKSB7XG4gICAgdHguZmluYWxpemVBbGxJbnB1dHMoKTtcbiAgICByZXR1cm4gQnVmZmVyLmZyb20odHguZXh0cmFjdFRyYW5zYWN0aW9uKCkpO1xuICB9XG5cbiAgcmV0dXJuIHR4O1xufVxuXG5mdW5jdGlvbiB0b1dhc21CSVAzMihrZXk6IEJJUDMySW50ZXJmYWNlKTogQklQMzIge1xuICAvLyBDb252ZXJ0IHVzaW5nIGJhc2U1OCBzdHJpbmcgdG8gZW5zdXJlIHByaXZhdGUga2V5IGlzIHByb3Blcmx5IHRyYW5zZmVycmVkXG4gIHJldHVybiBCSVAzMi5mcm9tQmFzZTU4KGtleS50b0Jhc2U1OCgpKTtcbn1cblxuZXhwb3J0IGFzeW5jIGZ1bmN0aW9uIHNpZ25Qc2J0V2l0aE11c2lnMlBhcnRpY2lwYW50V2FzbShcbiAgY29pbjogTXVzaWcyUGFydGljaXBhbnQ8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0PixcbiAgdHg6IGZpeGVkU2NyaXB0V2FsbGV0LkJpdEdvUHNidCxcbiAgc2lnbmVyS2V5Y2hhaW46IEJJUDMySW50ZXJmYWNlIHwgdW5kZWZpbmVkLFxuICByb290V2FsbGV0S2V5czogZml4ZWRTY3JpcHRXYWxsZXQuUm9vdFdhbGxldEtleXMsXG4gIHBhcmFtczoge1xuICAgIHJlcGxheVByb3RlY3Rpb246IFJlcGxheVByb3RlY3Rpb25LZXlzO1xuICAgIGlzTGFzdFNpZ25hdHVyZTogYm9vbGVhbjtcbiAgICBzaWduaW5nU3RlcDogJ3NpZ25lck5vbmNlJyB8ICdjb3NpZ25lck5vbmNlJyB8ICdzaWduZXJTaWduYXR1cmUnIHwgdW5kZWZpbmVkO1xuICAgIHdhbGxldElkOiBzdHJpbmcgfCB1bmRlZmluZWQ7XG4gIH1cbik6IFByb21pc2U8Zml4ZWRTY3JpcHRXYWxsZXQuQml0R29Qc2J0IHwgQnVmZmVyPiB7XG4gIGNvbnN0IHdhc21TaWduZXIgPSBzaWduZXJLZXljaGFpbiA/IHRvV2FzbUJJUDMyKHNpZ25lcktleWNoYWluKSA6IHVuZGVmaW5lZDtcblxuICBpZiAoaGFzS2V5UGF0aFNwZW5kSW5wdXQodHgsIHJvb3RXYWxsZXRLZXlzLCBwYXJhbXMucmVwbGF5UHJvdGVjdGlvbikpIHtcbiAgICAvLyBXZSBjYW4gb25seSBiZSB0aGUgZmlyc3Qgc2lnbmF0dXJlIG9uIGEgdHJhbnNhY3Rpb24gd2l0aCB0YXByb290IGtleSBwYXRoIHNwZW5kIGlucHV0cyBiZWNhdXNlXG4gICAgLy8gd2UgcmVxdWlyZSB0aGUgc2VjcmV0IG5vbmNlIGluIHRoZSBjYWNoZSBvZiB0aGUgZmlyc3Qgc2lnbmVyLCB3aGljaCBpcyBpbXBvc3NpYmxlIHRvIHJldHJpZXZlIGlmXG4gICAgLy8gZGVzZXJpYWxpemVkIGZyb20gYSBoZXguXG4gICAgaWYgKHBhcmFtcy5pc0xhc3RTaWduYXR1cmUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcignQ2Fubm90IGJlIGxhc3Qgc2lnbmF0dXJlIG9uIGEgdHJhbnNhY3Rpb24gd2l0aCBrZXkgcGF0aCBzcGVuZCBpbnB1dHMnKTtcbiAgICB9XG5cbiAgICBzd2l0Y2ggKHBhcmFtcy5zaWduaW5nU3RlcCkge1xuICAgICAgY2FzZSAnc2lnbmVyTm9uY2UnOlxuICAgICAgICBhc3NlcnQod2FzbVNpZ25lcik7XG4gICAgICAgIHR4LmdlbmVyYXRlTXVzaWcyTm9uY2VzKHdhc21TaWduZXIpO1xuICAgICAgICBQU0JUX0NBQ0hFX1dBU00uc2V0KHR4LnVuc2lnbmVkVHhpZCgpLCB0eCk7XG4gICAgICAgIHJldHVybiB0eDtcbiAgICAgIGNhc2UgJ2Nvc2lnbmVyTm9uY2UnOlxuICAgICAgICBhc3NlcnQocGFyYW1zLndhbGxldElkLCAnd2FsbGV0SWQgaXMgcmVxdWlyZWQgZm9yIE11U2lnMiBiaXRnbyBub25jZScpO1xuICAgICAgICByZXR1cm4gYXdhaXQgY29pbi5nZXRNdXNpZzJOb25jZXModHgsIHBhcmFtcy53YWxsZXRJZCk7XG4gICAgICBjYXNlICdzaWduZXJTaWduYXR1cmUnOiB7XG4gICAgICAgIGNvbnN0IHR4SWQgPSB0eC51bnNpZ25lZFR4aWQoKTtcbiAgICAgICAgY29uc3QgY2FjaGVkUHNidCA9IFBTQlRfQ0FDSEVfV0FTTS5nZXQodHhJZCk7XG4gICAgICAgIGFzc2VydChcbiAgICAgICAgICBjYWNoZWRQc2J0LFxuICAgICAgICAgIGBQc2J0IGlzIG1pc3NpbmcgZnJvbSB0eENhY2hlIChjYWNoZSBzaXplICR7UFNCVF9DQUNIRV9XQVNNLnNpemV9KS5cbiAgICAgICAgICAgIFRoaXMgbWF5IGJlIGR1ZSB0byB0aGUgcmVxdWVzdCBiZWluZyByb3V0ZWQgdG8gYSBkaWZmZXJlbnQgQml0R28tRXhwcmVzcyBpbnN0YW5jZSB0aGF0IGZvciBzaWduaW5nIHN0ZXAgJ3NpZ25lck5vbmNlJy5gXG4gICAgICAgICk7XG4gICAgICAgIFBTQlRfQ0FDSEVfV0FTTS5kZWxldGUodHhJZCk7XG4gICAgICAgIGNhY2hlZFBzYnQuY29tYmluZU11c2lnMk5vbmNlcyh0eCk7XG4gICAgICAgIHR4ID0gY2FjaGVkUHNidDtcbiAgICAgICAgYnJlYWs7XG4gICAgICB9XG4gICAgICBkZWZhdWx0OlxuICAgICAgICAvLyB0aGlzIGluc3RhbmNlIGlzIG5vdCBhbiBleHRlcm5hbCBzaWduZXJcbiAgICAgICAgYXNzZXJ0KHBhcmFtcy53YWxsZXRJZCwgJ3dhbGxldElkIGlzIHJlcXVpcmVkIGZvciBNdVNpZzIgYml0Z28gbm9uY2UnKTtcbiAgICAgICAgYXNzZXJ0KHdhc21TaWduZXIpO1xuICAgICAgICB0eC5nZW5lcmF0ZU11c2lnMk5vbmNlcyh3YXNtU2lnbmVyKTtcbiAgICAgICAgY29uc3QgcmVzcG9uc2UgPSBhd2FpdCBjb2luLmdldE11c2lnMk5vbmNlcyh0eCwgcGFyYW1zLndhbGxldElkKTtcbiAgICAgICAgdHguY29tYmluZU11c2lnMk5vbmNlcyhyZXNwb25zZSk7XG4gICAgICAgIGJyZWFrO1xuICAgIH1cbiAgfSBlbHNlIHtcbiAgICBzd2l0Y2ggKHBhcmFtcy5zaWduaW5nU3RlcCkge1xuICAgICAgY2FzZSAnc2lnbmVyTm9uY2UnOlxuICAgICAgY2FzZSAnY29zaWduZXJOb25jZSc6XG4gICAgICAgIC8qKlxuICAgICAgICAgKiBJbiBjZXJ0YWluIGNhc2VzLCB0aGUgY2FsbGVyIG9mIHRoaXMgbWV0aG9kIG1heSBub3Qga25vdyB3aGV0aGVyIHRoZSB0eEhleCBjb250YWlucyBhIHBzYnQgd2l0aCB0YXByb290IGtleSBwYXRoIHNwZW5kIGlucHV0KHMpLlxuICAgICAgICAgKiBJbnN0ZWFkIG9mIHRocm93aW5nIGVycm9yLCBuby1vcCBhbmQgcmV0dXJuIHRoZSB0eEhleC4gU28gdGhhdCB0aGUgY2FsbGVyIGNhbiBjYWxsIHRoaXMgbWV0aG9kIGluIHRoZSBzYW1lIHNlcXVlbmNlLlxuICAgICAgICAgKi9cbiAgICAgICAgcmV0dXJuIHR4O1xuICAgIH1cbiAgfVxuXG4gIGFzc2VydChzaWduZXJLZXljaGFpbik7XG4gIHJldHVybiBzaWduQW5kVmVyaWZ5UHNidFdhc20odHgsIHNpZ25lcktleWNoYWluLCByb290V2FsbGV0S2V5cywgcGFyYW1zLnJlcGxheVByb3RlY3Rpb24sIHtcbiAgICBpc0xhc3RTaWduYXR1cmU6IHBhcmFtcy5pc0xhc3RTaWduYXR1cmUsXG4gIH0pO1xufVxuIl19
@@ -0,0 +1,17 @@
1
+ import { BIP32Interface } from '@bitgo-beta/secp256k1';
2
+ import * as utxolib from '@bitgo-beta/utxo-lib';
3
+ import { fixedScriptWallet } from '@bitgo/wasm-utxo';
4
+ import { Musig2Participant } from './musig2';
5
+ export declare function signTransaction<T extends utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt>(coin: Musig2Participant<utxolib.bitgo.UtxoPsbt> | Musig2Participant<fixedScriptWallet.BitGoPsbt>, tx: T, signerKeychain: BIP32Interface | undefined, network: utxolib.Network, params: {
6
+ walletId: string | undefined;
7
+ txInfo: {
8
+ unspents?: utxolib.bitgo.Unspent<bigint | number>[];
9
+ } | undefined;
10
+ isLastSignature: boolean;
11
+ signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
12
+ /** deprecated */
13
+ allowNonSegwitSigningWithoutPrevTx: boolean;
14
+ pubs: string[] | undefined;
15
+ cosignerPub: string | undefined;
16
+ }): Promise<utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt | Buffer>;
17
+ //# sourceMappingURL=signTransaction.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"signTransaction.d.ts","sourceRoot":"","sources":["../../../../src/transaction/fixedScript/signTransaction.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,cAAc,EAAE,MAAM,uBAAuB,CAAC;AAEvD,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAChD,OAAO,EAAE,iBAAiB,EAAE,MAAM,kBAAkB,CAAC;AAErD,OAAO,EAAE,iBAAiB,EAAE,MAAM,UAAU,CAAC;AAM7C,wBAAsB,eAAe,CACnC,CAAC,SAAS,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,EAE/G,IAAI,EAAE,iBAAiB,CAAC,OAAO,CAAC,KAAK,CAAC,QAAQ,CAAC,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,SAAS,CAAC,EAChG,EAAE,EAAE,CAAC,EACL,cAAc,EAAE,cAAc,GAAG,SAAS,EAC1C,OAAO,EAAE,OAAO,CAAC,OAAO,EACxB,MAAM,EAAE;IACN,QAAQ,EAAE,MAAM,GAAG,SAAS,CAAC;IAC7B,MAAM,EAAE;QAAE,QAAQ,CAAC,EAAE,OAAO,CAAC,KAAK,CAAC,OAAO,CAAC,MAAM,GAAG,MAAM,CAAC,EAAE,CAAA;KAAE,GAAG,SAAS,CAAC;IAC5E,eAAe,EAAE,OAAO,CAAC;IACzB,WAAW,EAAE,aAAa,GAAG,eAAe,GAAG,iBAAiB,GAAG,SAAS,CAAC;IAC7E,iBAAiB;IACjB,kCAAkC,EAAE,OAAO,CAAC;IAC5C,IAAI,EAAE,MAAM,EAAE,GAAG,SAAS,CAAC;IAC3B,WAAW,EAAE,MAAM,GAAG,SAAS,CAAC;CACjC,GACA,OAAO,CACR,OAAO,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC,KAAK,CAAC,eAAe,CAAC,MAAM,GAAG,MAAM,CAAC,GAAG,iBAAiB,CAAC,SAAS,GAAG,MAAM,CAC/G,CAwCA"}