@bsv/sdk 1.3.13 → 1.3.15

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 (1251) hide show
  1. package/dist/cjs/mod.js +15 -15
  2. package/dist/cjs/mod.js.map +1 -1
  3. package/dist/cjs/package.json +8 -3
  4. package/dist/cjs/src/auth/Peer.js +71 -61
  5. package/dist/cjs/src/auth/Peer.js.map +1 -1
  6. package/dist/cjs/src/auth/SessionManager.js +10 -5
  7. package/dist/cjs/src/auth/SessionManager.js.map +1 -1
  8. package/dist/cjs/src/auth/certificates/Certificate.js +33 -30
  9. package/dist/cjs/src/auth/certificates/Certificate.js.map +1 -1
  10. package/dist/cjs/src/auth/certificates/MasterCertificate.js +36 -36
  11. package/dist/cjs/src/auth/certificates/MasterCertificate.js.map +1 -1
  12. package/dist/cjs/src/auth/certificates/VerifiableCertificate.js +9 -9
  13. package/dist/cjs/src/auth/certificates/VerifiableCertificate.js.map +1 -1
  14. package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js +45 -29
  15. package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
  16. package/dist/cjs/src/auth/certificates/index.js +5 -5
  17. package/dist/cjs/src/auth/certificates/index.js.map +1 -1
  18. package/dist/cjs/src/auth/clients/AuthFetch.js +65 -74
  19. package/dist/cjs/src/auth/clients/AuthFetch.js.map +1 -1
  20. package/dist/cjs/src/auth/clients/index.js +1 -1
  21. package/dist/cjs/src/auth/clients/index.js.map +1 -1
  22. package/dist/cjs/src/auth/index.js +7 -7
  23. package/dist/cjs/src/auth/index.js.map +1 -1
  24. package/dist/cjs/src/auth/transports/SimplifiedFetchTransport.js +54 -62
  25. package/dist/cjs/src/auth/transports/SimplifiedFetchTransport.js.map +1 -1
  26. package/dist/cjs/src/auth/transports/index.js +1 -1
  27. package/dist/cjs/src/auth/transports/index.js.map +1 -1
  28. package/dist/cjs/src/auth/utils/createNonce.js +6 -5
  29. package/dist/cjs/src/auth/utils/createNonce.js.map +1 -1
  30. package/dist/cjs/src/auth/utils/getVerifiableCertificates.js +2 -2
  31. package/dist/cjs/src/auth/utils/getVerifiableCertificates.js.map +1 -1
  32. package/dist/cjs/src/auth/utils/index.js +4 -4
  33. package/dist/cjs/src/auth/utils/index.js.map +1 -1
  34. package/dist/cjs/src/auth/utils/validateCertificates.js +7 -4
  35. package/dist/cjs/src/auth/utils/validateCertificates.js.map +1 -1
  36. package/dist/cjs/src/auth/utils/verifyNonce.js +5 -4
  37. package/dist/cjs/src/auth/utils/verifyNonce.js.map +1 -1
  38. package/dist/cjs/src/compat/BSM.js +16 -26
  39. package/dist/cjs/src/compat/BSM.js.map +1 -1
  40. package/dist/cjs/src/compat/ECIES.js +50 -52
  41. package/dist/cjs/src/compat/ECIES.js.map +1 -1
  42. package/dist/cjs/src/compat/HD.js +36 -46
  43. package/dist/cjs/src/compat/HD.js.map +1 -1
  44. package/dist/cjs/src/compat/Mnemonic.js +30 -39
  45. package/dist/cjs/src/compat/Mnemonic.js.map +1 -1
  46. package/dist/cjs/src/compat/Utxo.js +5 -5
  47. package/dist/cjs/src/compat/Utxo.js.map +1 -1
  48. package/dist/cjs/src/compat/index.js +16 -26
  49. package/dist/cjs/src/compat/index.js.map +1 -1
  50. package/dist/cjs/src/messages/EncryptedMessage.js +14 -14
  51. package/dist/cjs/src/messages/EncryptedMessage.js.map +1 -1
  52. package/dist/cjs/src/messages/SignedMessage.js +21 -20
  53. package/dist/cjs/src/messages/SignedMessage.js.map +1 -1
  54. package/dist/cjs/src/messages/index.js +9 -19
  55. package/dist/cjs/src/messages/index.js.map +1 -1
  56. package/dist/cjs/src/overlay-tools/LookupResolver.js +44 -32
  57. package/dist/cjs/src/overlay-tools/LookupResolver.js.map +1 -1
  58. package/dist/cjs/src/overlay-tools/OverlayAdminTokenTemplate.js +12 -12
  59. package/dist/cjs/src/overlay-tools/OverlayAdminTokenTemplate.js.map +1 -1
  60. package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js +11 -10
  61. package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
  62. package/dist/cjs/src/overlay-tools/index.js +8 -8
  63. package/dist/cjs/src/overlay-tools/index.js.map +1 -1
  64. package/dist/cjs/src/primitives/AESGCM.js +6 -5
  65. package/dist/cjs/src/primitives/AESGCM.js.map +1 -1
  66. package/dist/cjs/src/primitives/BasePoint.js +2 -2
  67. package/dist/cjs/src/primitives/BasePoint.js.map +1 -1
  68. package/dist/cjs/src/primitives/BigNumber.js +5 -4
  69. package/dist/cjs/src/primitives/BigNumber.js.map +1 -1
  70. package/dist/cjs/src/primitives/Curve.js +70 -36
  71. package/dist/cjs/src/primitives/Curve.js.map +1 -1
  72. package/dist/cjs/src/primitives/DRBG.js +6 -6
  73. package/dist/cjs/src/primitives/DRBG.js.map +1 -1
  74. package/dist/cjs/src/primitives/ECDSA.js +71 -55
  75. package/dist/cjs/src/primitives/ECDSA.js.map +1 -1
  76. package/dist/cjs/src/primitives/Hash.js +115 -105
  77. package/dist/cjs/src/primitives/Hash.js.map +1 -1
  78. package/dist/cjs/src/primitives/JacobianPoint.js +25 -15
  79. package/dist/cjs/src/primitives/JacobianPoint.js.map +1 -1
  80. package/dist/cjs/src/primitives/K256.js +2 -2
  81. package/dist/cjs/src/primitives/K256.js.map +1 -1
  82. package/dist/cjs/src/primitives/Mersenne.js +4 -4
  83. package/dist/cjs/src/primitives/Mersenne.js.map +1 -1
  84. package/dist/cjs/src/primitives/MontgomoryMethod.js +5 -5
  85. package/dist/cjs/src/primitives/MontgomoryMethod.js.map +1 -1
  86. package/dist/cjs/src/primitives/Point.js +114 -87
  87. package/dist/cjs/src/primitives/Point.js.map +1 -1
  88. package/dist/cjs/src/primitives/Polynomial.js +14 -14
  89. package/dist/cjs/src/primitives/Polynomial.js.map +1 -1
  90. package/dist/cjs/src/primitives/PrivateKey.js +48 -58
  91. package/dist/cjs/src/primitives/PrivateKey.js.map +1 -1
  92. package/dist/cjs/src/primitives/PublicKey.js +23 -23
  93. package/dist/cjs/src/primitives/PublicKey.js.map +1 -1
  94. package/dist/cjs/src/primitives/Random.js +2 -1
  95. package/dist/cjs/src/primitives/Random.js.map +1 -1
  96. package/dist/cjs/src/primitives/ReductionContext.js +10 -10
  97. package/dist/cjs/src/primitives/ReductionContext.js.map +1 -1
  98. package/dist/cjs/src/primitives/Schnorr.js +8 -8
  99. package/dist/cjs/src/primitives/Schnorr.js.map +1 -1
  100. package/dist/cjs/src/primitives/Signature.js +23 -23
  101. package/dist/cjs/src/primitives/Signature.js.map +1 -1
  102. package/dist/cjs/src/primitives/SymmetricKey.js +13 -13
  103. package/dist/cjs/src/primitives/SymmetricKey.js.map +1 -1
  104. package/dist/cjs/src/primitives/TransactionSignature.js +38 -38
  105. package/dist/cjs/src/primitives/TransactionSignature.js.map +1 -1
  106. package/dist/cjs/src/primitives/index.js +34 -44
  107. package/dist/cjs/src/primitives/index.js.map +1 -1
  108. package/dist/cjs/src/primitives/utils.js +38 -37
  109. package/dist/cjs/src/primitives/utils.js.map +1 -1
  110. package/dist/cjs/src/script/LockingScript.js +2 -2
  111. package/dist/cjs/src/script/LockingScript.js.map +1 -1
  112. package/dist/cjs/src/script/OP.js +3 -3
  113. package/dist/cjs/src/script/OP.js.map +1 -1
  114. package/dist/cjs/src/script/Script.js +47 -47
  115. package/dist/cjs/src/script/Script.js.map +1 -1
  116. package/dist/cjs/src/script/Spend.js +304 -311
  117. package/dist/cjs/src/script/Spend.js.map +1 -1
  118. package/dist/cjs/src/script/UnlockingScript.js +2 -2
  119. package/dist/cjs/src/script/UnlockingScript.js.map +1 -1
  120. package/dist/cjs/src/script/index.js +11 -11
  121. package/dist/cjs/src/script/index.js.map +1 -1
  122. package/dist/cjs/src/script/templates/P2PKH.js +55 -47
  123. package/dist/cjs/src/script/templates/P2PKH.js.map +1 -1
  124. package/dist/cjs/src/script/templates/PushDrop.js +57 -51
  125. package/dist/cjs/src/script/templates/PushDrop.js.map +1 -1
  126. package/dist/cjs/src/script/templates/RPuzzle.js +49 -48
  127. package/dist/cjs/src/script/templates/RPuzzle.js.map +1 -1
  128. package/dist/cjs/src/script/templates/index.js +6 -6
  129. package/dist/cjs/src/script/templates/index.js.map +1 -1
  130. package/dist/cjs/src/totp/index.js +1 -1
  131. package/dist/cjs/src/totp/index.js.map +1 -1
  132. package/dist/cjs/src/totp/totp.js +9 -8
  133. package/dist/cjs/src/totp/totp.js.map +1 -1
  134. package/dist/cjs/src/transaction/Beef.js +78 -67
  135. package/dist/cjs/src/transaction/Beef.js.map +1 -1
  136. package/dist/cjs/src/transaction/BeefParty.js +5 -5
  137. package/dist/cjs/src/transaction/BeefParty.js.map +1 -1
  138. package/dist/cjs/src/transaction/BeefTx.js +39 -33
  139. package/dist/cjs/src/transaction/BeefTx.js.map +1 -1
  140. package/dist/cjs/src/transaction/Broadcaster.js +3 -2
  141. package/dist/cjs/src/transaction/Broadcaster.js.map +1 -1
  142. package/dist/cjs/src/transaction/MerklePath.js +60 -38
  143. package/dist/cjs/src/transaction/MerklePath.js.map +1 -1
  144. package/dist/cjs/src/transaction/Transaction.js +127 -85
  145. package/dist/cjs/src/transaction/Transaction.js.map +1 -1
  146. package/dist/cjs/src/transaction/broadcasters/ARC.js +48 -43
  147. package/dist/cjs/src/transaction/broadcasters/ARC.js.map +1 -1
  148. package/dist/cjs/src/transaction/broadcasters/DefaultBroadcaster.js +4 -3
  149. package/dist/cjs/src/transaction/broadcasters/DefaultBroadcaster.js.map +1 -1
  150. package/dist/cjs/src/transaction/broadcasters/WhatsOnChainBroadcaster.js +15 -15
  151. package/dist/cjs/src/transaction/broadcasters/WhatsOnChainBroadcaster.js.map +1 -1
  152. package/dist/cjs/src/transaction/broadcasters/index.js +6 -6
  153. package/dist/cjs/src/transaction/broadcasters/index.js.map +1 -1
  154. package/dist/cjs/src/transaction/chaintrackers/DefaultChainTracker.js +4 -3
  155. package/dist/cjs/src/transaction/chaintrackers/DefaultChainTracker.js.map +1 -1
  156. package/dist/cjs/src/transaction/chaintrackers/WhatsOnChain.js +11 -11
  157. package/dist/cjs/src/transaction/chaintrackers/WhatsOnChain.js.map +1 -1
  158. package/dist/cjs/src/transaction/chaintrackers/index.js +4 -4
  159. package/dist/cjs/src/transaction/chaintrackers/index.js.map +1 -1
  160. package/dist/cjs/src/transaction/fee-models/SatoshisPerKilobyte.js +3 -3
  161. package/dist/cjs/src/transaction/fee-models/SatoshisPerKilobyte.js.map +1 -1
  162. package/dist/cjs/src/transaction/fee-models/index.js +2 -2
  163. package/dist/cjs/src/transaction/fee-models/index.js.map +1 -1
  164. package/dist/cjs/src/transaction/http/DefaultHttpClient.js +12 -10
  165. package/dist/cjs/src/transaction/http/DefaultHttpClient.js.map +1 -1
  166. package/dist/cjs/src/transaction/http/FetchHttpClient.js +2 -1
  167. package/dist/cjs/src/transaction/http/FetchHttpClient.js.map +1 -1
  168. package/dist/cjs/src/transaction/http/NodejsHttpClient.js +8 -8
  169. package/dist/cjs/src/transaction/http/NodejsHttpClient.js.map +1 -1
  170. package/dist/cjs/src/transaction/http/index.js +6 -6
  171. package/dist/cjs/src/transaction/http/index.js.map +1 -1
  172. package/dist/cjs/src/transaction/index.js +12 -12
  173. package/dist/cjs/src/transaction/index.js.map +1 -1
  174. package/dist/cjs/src/wallet/CachedKeyDeriver.js +34 -11
  175. package/dist/cjs/src/wallet/CachedKeyDeriver.js.map +1 -1
  176. package/dist/cjs/src/wallet/KeyDeriver.js +10 -9
  177. package/dist/cjs/src/wallet/KeyDeriver.js.map +1 -1
  178. package/dist/cjs/src/wallet/ProtoWallet.js +68 -31
  179. package/dist/cjs/src/wallet/ProtoWallet.js.map +1 -1
  180. package/dist/cjs/src/wallet/WalletClient.js +18 -14
  181. package/dist/cjs/src/wallet/WalletClient.js.map +1 -1
  182. package/dist/cjs/src/wallet/WalletError.js +2 -2
  183. package/dist/cjs/src/wallet/WalletError.js.map +1 -1
  184. package/dist/cjs/src/wallet/index.js +12 -12
  185. package/dist/cjs/src/wallet/index.js.map +1 -1
  186. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js +2 -1
  187. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
  188. package/dist/cjs/src/wallet/substrates/HTTPWalletWire.js +11 -11
  189. package/dist/cjs/src/wallet/substrates/HTTPWalletWire.js.map +1 -1
  190. package/dist/cjs/src/wallet/substrates/WalletWireCalls.js.map +1 -1
  191. package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js +239 -238
  192. package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
  193. package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js +311 -300
  194. package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js.map +1 -1
  195. package/dist/cjs/src/wallet/substrates/XDM.js +9 -7
  196. package/dist/cjs/src/wallet/substrates/XDM.js.map +1 -1
  197. package/dist/cjs/src/wallet/substrates/index.js +12 -12
  198. package/dist/cjs/src/wallet/substrates/index.js.map +1 -1
  199. package/dist/cjs/src/wallet/substrates/window.CWI.js +32 -32
  200. package/dist/cjs/src/wallet/substrates/window.CWI.js.map +1 -1
  201. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  202. package/dist/esm/mod.js +15 -31
  203. package/dist/esm/mod.js.map +1 -1
  204. package/dist/esm/src/auth/Peer.js +64 -63
  205. package/dist/esm/src/auth/Peer.js.map +1 -1
  206. package/dist/esm/src/auth/SessionManager.js +11 -10
  207. package/dist/esm/src/auth/SessionManager.js.map +1 -1
  208. package/dist/esm/src/auth/certificates/Certificate.js +32 -34
  209. package/dist/esm/src/auth/certificates/Certificate.js.map +1 -1
  210. package/dist/esm/src/auth/certificates/MasterCertificate.js +36 -43
  211. package/dist/esm/src/auth/certificates/MasterCertificate.js.map +1 -1
  212. package/dist/esm/src/auth/certificates/VerifiableCertificate.js +9 -16
  213. package/dist/esm/src/auth/certificates/VerifiableCertificate.js.map +1 -1
  214. package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js +46 -33
  215. package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
  216. package/dist/esm/src/auth/certificates/index.js +4 -25
  217. package/dist/esm/src/auth/certificates/index.js.map +1 -1
  218. package/dist/esm/src/auth/clients/AuthFetch.js +66 -79
  219. package/dist/esm/src/auth/clients/AuthFetch.js.map +1 -1
  220. package/dist/esm/src/auth/clients/index.js +1 -17
  221. package/dist/esm/src/auth/clients/index.js.map +1 -1
  222. package/dist/esm/src/auth/index.js +7 -23
  223. package/dist/esm/src/auth/index.js.map +1 -1
  224. package/dist/esm/src/auth/transports/SimplifiedFetchTransport.js +55 -67
  225. package/dist/esm/src/auth/transports/SimplifiedFetchTransport.js.map +1 -1
  226. package/dist/esm/src/auth/transports/index.js +1 -17
  227. package/dist/esm/src/auth/transports/index.js.map +1 -1
  228. package/dist/esm/src/auth/types.js +1 -2
  229. package/dist/esm/src/auth/utils/createNonce.js +5 -8
  230. package/dist/esm/src/auth/utils/createNonce.js.map +1 -1
  231. package/dist/esm/src/auth/utils/getVerifiableCertificates.js +3 -7
  232. package/dist/esm/src/auth/utils/getVerifiableCertificates.js.map +1 -1
  233. package/dist/esm/src/auth/utils/index.js +4 -20
  234. package/dist/esm/src/auth/utils/index.js.map +1 -1
  235. package/dist/esm/src/auth/utils/validateCertificates.js +8 -9
  236. package/dist/esm/src/auth/utils/validateCertificates.js.map +1 -1
  237. package/dist/esm/src/auth/utils/verifyNonce.js +4 -7
  238. package/dist/esm/src/auth/utils/verifyNonce.js.map +1 -1
  239. package/dist/esm/src/compat/BSM.js +14 -56
  240. package/dist/esm/src/compat/BSM.js.map +1 -1
  241. package/dist/esm/src/compat/ECIES.js +44 -75
  242. package/dist/esm/src/compat/ECIES.js.map +1 -1
  243. package/dist/esm/src/compat/HD.js +30 -69
  244. package/dist/esm/src/compat/HD.js.map +1 -1
  245. package/dist/esm/src/compat/Mnemonic.js +24 -62
  246. package/dist/esm/src/compat/Mnemonic.js.map +1 -1
  247. package/dist/esm/src/compat/Utxo.js +5 -11
  248. package/dist/esm/src/compat/Utxo.js.map +1 -1
  249. package/dist/esm/src/compat/bip-39-wordlist-en.js +1 -4
  250. package/dist/esm/src/compat/bip-39-wordlist-en.js.map +1 -1
  251. package/dist/esm/src/compat/index.js +5 -48
  252. package/dist/esm/src/compat/index.js.map +1 -1
  253. package/dist/esm/src/messages/EncryptedMessage.js +16 -24
  254. package/dist/esm/src/messages/EncryptedMessage.js.map +1 -1
  255. package/dist/esm/src/messages/SignedMessage.js +23 -30
  256. package/dist/esm/src/messages/SignedMessage.js.map +1 -1
  257. package/dist/esm/src/messages/index.js +2 -38
  258. package/dist/esm/src/messages/index.js.map +1 -1
  259. package/dist/esm/src/overlay-tools/LookupResolver.js +46 -43
  260. package/dist/esm/src/overlay-tools/LookupResolver.js.map +1 -1
  261. package/dist/esm/src/overlay-tools/OverlayAdminTokenTemplate.js +13 -19
  262. package/dist/esm/src/overlay-tools/OverlayAdminTokenTemplate.js.map +1 -1
  263. package/dist/esm/src/overlay-tools/SHIPBroadcaster.js +13 -20
  264. package/dist/esm/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
  265. package/dist/esm/src/overlay-tools/index.js +5 -28
  266. package/dist/esm/src/overlay-tools/index.js.map +1 -1
  267. package/dist/esm/src/primitives/AESGCM.js +27 -39
  268. package/dist/esm/src/primitives/AESGCM.js.map +1 -1
  269. package/dist/esm/src/primitives/BasePoint.js +3 -9
  270. package/dist/esm/src/primitives/BasePoint.js.map +1 -1
  271. package/dist/esm/src/primitives/BigNumber.js +6 -8
  272. package/dist/esm/src/primitives/BigNumber.js.map +1 -1
  273. package/dist/esm/src/primitives/Curve.js +70 -43
  274. package/dist/esm/src/primitives/Curve.js.map +1 -1
  275. package/dist/esm/src/primitives/DRBG.js +7 -10
  276. package/dist/esm/src/primitives/DRBG.js.map +1 -1
  277. package/dist/esm/src/primitives/ECDSA.js +72 -65
  278. package/dist/esm/src/primitives/ECDSA.js.map +1 -1
  279. package/dist/esm/src/primitives/Hash.js +131 -141
  280. package/dist/esm/src/primitives/Hash.js.map +1 -1
  281. package/dist/esm/src/primitives/JacobianPoint.js +24 -21
  282. package/dist/esm/src/primitives/JacobianPoint.js.map +1 -1
  283. package/dist/esm/src/primitives/K256.js +2 -8
  284. package/dist/esm/src/primitives/K256.js.map +1 -1
  285. package/dist/esm/src/primitives/Mersenne.js +5 -11
  286. package/dist/esm/src/primitives/Mersenne.js.map +1 -1
  287. package/dist/esm/src/primitives/MontgomoryMethod.js +5 -11
  288. package/dist/esm/src/primitives/MontgomoryMethod.js.map +1 -1
  289. package/dist/esm/src/primitives/Point.js +104 -93
  290. package/dist/esm/src/primitives/Point.js.map +1 -1
  291. package/dist/esm/src/primitives/Polynomial.js +16 -24
  292. package/dist/esm/src/primitives/Polynomial.js.map +1 -1
  293. package/dist/esm/src/primitives/PrivateKey.js +42 -83
  294. package/dist/esm/src/primitives/PrivateKey.js.map +1 -1
  295. package/dist/esm/src/primitives/PublicKey.js +23 -29
  296. package/dist/esm/src/primitives/PublicKey.js.map +1 -1
  297. package/dist/esm/src/primitives/Random.js +4 -5
  298. package/dist/esm/src/primitives/Random.js.map +1 -1
  299. package/dist/esm/src/primitives/ReductionContext.js +11 -17
  300. package/dist/esm/src/primitives/ReductionContext.js.map +1 -1
  301. package/dist/esm/src/primitives/Schnorr.js +9 -15
  302. package/dist/esm/src/primitives/Schnorr.js.map +1 -1
  303. package/dist/esm/src/primitives/Signature.js +24 -30
  304. package/dist/esm/src/primitives/Signature.js.map +1 -1
  305. package/dist/esm/src/primitives/SymmetricKey.js +13 -19
  306. package/dist/esm/src/primitives/SymmetricKey.js.map +1 -1
  307. package/dist/esm/src/primitives/TransactionSignature.js +29 -60
  308. package/dist/esm/src/primitives/TransactionSignature.js.map +1 -1
  309. package/dist/esm/src/primitives/index.js +14 -66
  310. package/dist/esm/src/primitives/index.js.map +1 -1
  311. package/dist/esm/src/primitives/utils.js +55 -74
  312. package/dist/esm/src/primitives/utils.js.map +1 -1
  313. package/dist/esm/src/script/LockingScript.js +2 -8
  314. package/dist/esm/src/script/LockingScript.js.map +1 -1
  315. package/dist/esm/src/script/OP.js +4 -6
  316. package/dist/esm/src/script/OP.js.map +1 -1
  317. package/dist/esm/src/script/Script.js +48 -54
  318. package/dist/esm/src/script/Script.js.map +1 -1
  319. package/dist/esm/src/script/ScriptChunk.js +1 -2
  320. package/dist/esm/src/script/ScriptTemplate.js +1 -2
  321. package/dist/esm/src/script/Spend.js +297 -334
  322. package/dist/esm/src/script/Spend.js.map +1 -1
  323. package/dist/esm/src/script/UnlockingScript.js +2 -8
  324. package/dist/esm/src/script/UnlockingScript.js.map +1 -1
  325. package/dist/esm/src/script/index.js +6 -31
  326. package/dist/esm/src/script/index.js.map +1 -1
  327. package/dist/esm/src/script/templates/P2PKH.js +53 -51
  328. package/dist/esm/src/script/templates/P2PKH.js.map +1 -1
  329. package/dist/esm/src/script/templates/PushDrop.js +54 -52
  330. package/dist/esm/src/script/templates/PushDrop.js.map +1 -1
  331. package/dist/esm/src/script/templates/RPuzzle.js +51 -55
  332. package/dist/esm/src/script/templates/RPuzzle.js.map +1 -1
  333. package/dist/esm/src/script/templates/index.js +3 -12
  334. package/dist/esm/src/script/templates/index.js.map +1 -1
  335. package/dist/esm/src/totp/index.js +1 -17
  336. package/dist/esm/src/totp/index.js.map +1 -1
  337. package/dist/esm/src/totp/totp.js +10 -16
  338. package/dist/esm/src/totp/totp.js.map +1 -1
  339. package/dist/esm/src/transaction/Beef.js +89 -86
  340. package/dist/esm/src/transaction/Beef.js.map +1 -1
  341. package/dist/esm/src/transaction/BeefParty.js +6 -10
  342. package/dist/esm/src/transaction/BeefParty.js.map +1 -1
  343. package/dist/esm/src/transaction/BeefTx.js +40 -40
  344. package/dist/esm/src/transaction/BeefTx.js.map +1 -1
  345. package/dist/esm/src/transaction/Broadcaster.js +2 -6
  346. package/dist/esm/src/transaction/Broadcaster.js.map +1 -1
  347. package/dist/esm/src/transaction/ChainTracker.js +1 -2
  348. package/dist/esm/src/transaction/FeeModel.js +1 -2
  349. package/dist/esm/src/transaction/MerklePath.js +58 -41
  350. package/dist/esm/src/transaction/MerklePath.js.map +1 -1
  351. package/dist/esm/src/transaction/Transaction.js +121 -92
  352. package/dist/esm/src/transaction/Transaction.js.map +1 -1
  353. package/dist/esm/src/transaction/TransactionInput.js +1 -2
  354. package/dist/esm/src/transaction/TransactionOutput.js +1 -2
  355. package/dist/esm/src/transaction/broadcasters/ARC.js +49 -50
  356. package/dist/esm/src/transaction/broadcasters/ARC.js.map +1 -1
  357. package/dist/esm/src/transaction/broadcasters/DefaultBroadcaster.js +3 -9
  358. package/dist/esm/src/transaction/broadcasters/DefaultBroadcaster.js.map +1 -1
  359. package/dist/esm/src/transaction/broadcasters/WhatsOnChainBroadcaster.js +16 -19
  360. package/dist/esm/src/transaction/broadcasters/WhatsOnChainBroadcaster.js.map +1 -1
  361. package/dist/esm/src/transaction/broadcasters/index.js +3 -12
  362. package/dist/esm/src/transaction/broadcasters/index.js.map +1 -1
  363. package/dist/esm/src/transaction/chaintrackers/DefaultChainTracker.js +3 -9
  364. package/dist/esm/src/transaction/chaintrackers/DefaultChainTracker.js.map +1 -1
  365. package/dist/esm/src/transaction/chaintrackers/WhatsOnChain.js +12 -15
  366. package/dist/esm/src/transaction/chaintrackers/WhatsOnChain.js.map +1 -1
  367. package/dist/esm/src/transaction/chaintrackers/index.js +2 -10
  368. package/dist/esm/src/transaction/chaintrackers/index.js.map +1 -1
  369. package/dist/esm/src/transaction/fee-models/SatoshisPerKilobyte.js +4 -7
  370. package/dist/esm/src/transaction/fee-models/SatoshisPerKilobyte.js.map +1 -1
  371. package/dist/esm/src/transaction/fee-models/index.js +1 -8
  372. package/dist/esm/src/transaction/fee-models/index.js.map +1 -1
  373. package/dist/esm/src/transaction/http/DefaultHttpClient.js +11 -13
  374. package/dist/esm/src/transaction/http/DefaultHttpClient.js.map +1 -1
  375. package/dist/esm/src/transaction/http/FetchHttpClient.js +2 -6
  376. package/dist/esm/src/transaction/http/FetchHttpClient.js.map +1 -1
  377. package/dist/esm/src/transaction/http/HttpClient.js +1 -2
  378. package/dist/esm/src/transaction/http/NodejsHttpClient.js +9 -13
  379. package/dist/esm/src/transaction/http/NodejsHttpClient.js.map +1 -1
  380. package/dist/esm/src/transaction/http/index.js +3 -9
  381. package/dist/esm/src/transaction/http/index.js.map +1 -1
  382. package/dist/esm/src/transaction/index.js +6 -32
  383. package/dist/esm/src/transaction/index.js.map +1 -1
  384. package/dist/esm/src/wallet/CachedKeyDeriver.js +35 -15
  385. package/dist/esm/src/wallet/CachedKeyDeriver.js.map +1 -1
  386. package/dist/esm/src/wallet/KeyDeriver.js +11 -15
  387. package/dist/esm/src/wallet/KeyDeriver.js.map +1 -1
  388. package/dist/esm/src/wallet/ProtoWallet.js +66 -37
  389. package/dist/esm/src/wallet/ProtoWallet.js.map +1 -1
  390. package/dist/esm/src/wallet/Wallet.interfaces.js +2 -5
  391. package/dist/esm/src/wallet/Wallet.interfaces.js.map +1 -1
  392. package/dist/esm/src/wallet/WalletClient.js +19 -21
  393. package/dist/esm/src/wallet/WalletClient.js.map +1 -1
  394. package/dist/esm/src/wallet/WalletError.js +4 -8
  395. package/dist/esm/src/wallet/WalletError.js.map +1 -1
  396. package/dist/esm/src/wallet/index.js +8 -32
  397. package/dist/esm/src/wallet/index.js.map +1 -1
  398. package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js +3 -6
  399. package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
  400. package/dist/esm/src/wallet/substrates/HTTPWalletWire.js +12 -18
  401. package/dist/esm/src/wallet/substrates/HTTPWalletWire.js.map +1 -1
  402. package/dist/esm/src/wallet/substrates/WalletWire.js +1 -2
  403. package/dist/esm/src/wallet/substrates/WalletWireCalls.js +1 -3
  404. package/dist/esm/src/wallet/substrates/WalletWireCalls.js.map +1 -1
  405. package/dist/esm/src/wallet/substrates/WalletWireProcessor.js +240 -245
  406. package/dist/esm/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
  407. package/dist/esm/src/wallet/substrates/WalletWireTransceiver.js +305 -307
  408. package/dist/esm/src/wallet/substrates/WalletWireTransceiver.js.map +1 -1
  409. package/dist/esm/src/wallet/substrates/XDM.js +10 -11
  410. package/dist/esm/src/wallet/substrates/XDM.js.map +1 -1
  411. package/dist/esm/src/wallet/substrates/index.js +7 -32
  412. package/dist/esm/src/wallet/substrates/index.js.map +1 -1
  413. package/dist/esm/src/wallet/substrates/window.CWI.js +33 -36
  414. package/dist/esm/src/wallet/substrates/window.CWI.js.map +1 -1
  415. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  416. package/dist/types/mod.d.ts +15 -15
  417. package/dist/types/mod.d.ts.map +1 -1
  418. package/dist/types/src/auth/Peer.d.ts +4 -4
  419. package/dist/types/src/auth/Peer.d.ts.map +1 -1
  420. package/dist/types/src/auth/SessionManager.d.ts +1 -1
  421. package/dist/types/src/auth/SessionManager.d.ts.map +1 -1
  422. package/dist/types/src/auth/certificates/Certificate.d.ts +6 -6
  423. package/dist/types/src/auth/certificates/Certificate.d.ts.map +1 -1
  424. package/dist/types/src/auth/certificates/MasterCertificate.d.ts +6 -6
  425. package/dist/types/src/auth/certificates/MasterCertificate.d.ts.map +1 -1
  426. package/dist/types/src/auth/certificates/VerifiableCertificate.d.ts +2 -2
  427. package/dist/types/src/auth/certificates/VerifiableCertificate.d.ts.map +1 -1
  428. package/dist/types/src/auth/certificates/__tests/CompletedProtoWallet.d.ts +23 -22
  429. package/dist/types/src/auth/certificates/__tests/CompletedProtoWallet.d.ts.map +1 -1
  430. package/dist/types/src/auth/certificates/index.d.ts +4 -4
  431. package/dist/types/src/auth/certificates/index.d.ts.map +1 -1
  432. package/dist/types/src/auth/clients/AuthFetch.d.ts +9 -9
  433. package/dist/types/src/auth/clients/AuthFetch.d.ts.map +1 -1
  434. package/dist/types/src/auth/clients/index.d.ts +1 -1
  435. package/dist/types/src/auth/clients/index.d.ts.map +1 -1
  436. package/dist/types/src/auth/index.d.ts +7 -7
  437. package/dist/types/src/auth/index.d.ts.map +1 -1
  438. package/dist/types/src/auth/transports/SimplifiedFetchTransport.d.ts +1 -1
  439. package/dist/types/src/auth/transports/SimplifiedFetchTransport.d.ts.map +1 -1
  440. package/dist/types/src/auth/transports/index.d.ts +1 -1
  441. package/dist/types/src/auth/transports/index.d.ts.map +1 -1
  442. package/dist/types/src/auth/types.d.ts +1 -1
  443. package/dist/types/src/auth/types.d.ts.map +1 -1
  444. package/dist/types/src/auth/utils/createNonce.d.ts +1 -1
  445. package/dist/types/src/auth/utils/createNonce.d.ts.map +1 -1
  446. package/dist/types/src/auth/utils/getVerifiableCertificates.d.ts +3 -3
  447. package/dist/types/src/auth/utils/getVerifiableCertificates.d.ts.map +1 -1
  448. package/dist/types/src/auth/utils/index.d.ts +4 -4
  449. package/dist/types/src/auth/utils/index.d.ts.map +1 -1
  450. package/dist/types/src/auth/utils/validateCertificates.d.ts +2 -2
  451. package/dist/types/src/auth/utils/validateCertificates.d.ts.map +1 -1
  452. package/dist/types/src/auth/utils/verifyNonce.d.ts +1 -1
  453. package/dist/types/src/auth/utils/verifyNonce.d.ts.map +1 -1
  454. package/dist/types/src/compat/BSM.d.ts +4 -4
  455. package/dist/types/src/compat/BSM.d.ts.map +1 -1
  456. package/dist/types/src/compat/ECIES.d.ts +2 -2
  457. package/dist/types/src/compat/ECIES.d.ts.map +1 -1
  458. package/dist/types/src/compat/HD.d.ts +2 -2
  459. package/dist/types/src/compat/HD.d.ts.map +1 -1
  460. package/dist/types/src/compat/Mnemonic.d.ts.map +1 -1
  461. package/dist/types/src/compat/Utxo.d.ts +3 -3
  462. package/dist/types/src/compat/Utxo.d.ts.map +1 -1
  463. package/dist/types/src/compat/index.d.ts +5 -5
  464. package/dist/types/src/compat/index.d.ts.map +1 -1
  465. package/dist/types/src/messages/EncryptedMessage.d.ts +2 -2
  466. package/dist/types/src/messages/EncryptedMessage.d.ts.map +1 -1
  467. package/dist/types/src/messages/SignedMessage.d.ts +2 -2
  468. package/dist/types/src/messages/SignedMessage.d.ts.map +1 -1
  469. package/dist/types/src/messages/index.d.ts +2 -2
  470. package/dist/types/src/messages/index.d.ts.map +1 -1
  471. package/dist/types/src/overlay-tools/LookupResolver.d.ts.map +1 -1
  472. package/dist/types/src/overlay-tools/OverlayAdminTokenTemplate.d.ts +4 -4
  473. package/dist/types/src/overlay-tools/OverlayAdminTokenTemplate.d.ts.map +1 -1
  474. package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts +2 -2
  475. package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts.map +1 -1
  476. package/dist/types/src/overlay-tools/index.d.ts +5 -5
  477. package/dist/types/src/overlay-tools/index.d.ts.map +1 -1
  478. package/dist/types/src/primitives/AESGCM.d.ts.map +1 -1
  479. package/dist/types/src/primitives/BasePoint.d.ts +9 -9
  480. package/dist/types/src/primitives/BasePoint.d.ts.map +1 -1
  481. package/dist/types/src/primitives/BigNumber.d.ts +1 -1
  482. package/dist/types/src/primitives/BigNumber.d.ts.map +1 -1
  483. package/dist/types/src/primitives/Curve.d.ts +17 -10
  484. package/dist/types/src/primitives/Curve.d.ts.map +1 -1
  485. package/dist/types/src/primitives/DRBG.d.ts +1 -1
  486. package/dist/types/src/primitives/DRBG.d.ts.map +1 -1
  487. package/dist/types/src/primitives/ECDSA.d.ts +4 -4
  488. package/dist/types/src/primitives/ECDSA.d.ts.map +1 -1
  489. package/dist/types/src/primitives/Hash.d.ts +11 -11
  490. package/dist/types/src/primitives/Hash.d.ts.map +1 -1
  491. package/dist/types/src/primitives/JacobianPoint.d.ts +3 -3
  492. package/dist/types/src/primitives/JacobianPoint.d.ts.map +1 -1
  493. package/dist/types/src/primitives/K256.d.ts +2 -2
  494. package/dist/types/src/primitives/K256.d.ts.map +1 -1
  495. package/dist/types/src/primitives/Mersenne.d.ts +1 -1
  496. package/dist/types/src/primitives/Mersenne.d.ts.map +1 -1
  497. package/dist/types/src/primitives/MontgomoryMethod.d.ts +2 -2
  498. package/dist/types/src/primitives/MontgomoryMethod.d.ts.map +1 -1
  499. package/dist/types/src/primitives/Point.d.ts +3 -3
  500. package/dist/types/src/primitives/Point.d.ts.map +1 -1
  501. package/dist/types/src/primitives/Polynomial.d.ts +2 -2
  502. package/dist/types/src/primitives/Polynomial.d.ts.map +1 -1
  503. package/dist/types/src/primitives/PrivateKey.d.ts +7 -7
  504. package/dist/types/src/primitives/PrivateKey.d.ts.map +1 -1
  505. package/dist/types/src/primitives/PublicKey.d.ts +4 -4
  506. package/dist/types/src/primitives/PublicKey.d.ts.map +1 -1
  507. package/dist/types/src/primitives/Random.d.ts.map +1 -1
  508. package/dist/types/src/primitives/ReductionContext.d.ts +2 -2
  509. package/dist/types/src/primitives/ReductionContext.d.ts.map +1 -1
  510. package/dist/types/src/primitives/Schnorr.d.ts +3 -3
  511. package/dist/types/src/primitives/Schnorr.d.ts.map +1 -1
  512. package/dist/types/src/primitives/Signature.d.ts +3 -3
  513. package/dist/types/src/primitives/Signature.d.ts.map +1 -1
  514. package/dist/types/src/primitives/SymmetricKey.d.ts +1 -1
  515. package/dist/types/src/primitives/SymmetricKey.d.ts.map +1 -1
  516. package/dist/types/src/primitives/TransactionSignature.d.ts +5 -5
  517. package/dist/types/src/primitives/TransactionSignature.d.ts.map +1 -1
  518. package/dist/types/src/primitives/index.d.ts +14 -14
  519. package/dist/types/src/primitives/index.d.ts.map +1 -1
  520. package/dist/types/src/primitives/utils.d.ts +4 -7
  521. package/dist/types/src/primitives/utils.d.ts.map +1 -1
  522. package/dist/types/src/script/LockingScript.d.ts +1 -1
  523. package/dist/types/src/script/LockingScript.d.ts.map +1 -1
  524. package/dist/types/src/script/Script.d.ts +2 -2
  525. package/dist/types/src/script/Script.d.ts.map +1 -1
  526. package/dist/types/src/script/ScriptTemplate.d.ts +5 -5
  527. package/dist/types/src/script/ScriptTemplate.d.ts.map +1 -1
  528. package/dist/types/src/script/Spend.d.ts +4 -4
  529. package/dist/types/src/script/Spend.d.ts.map +1 -1
  530. package/dist/types/src/script/UnlockingScript.d.ts +1 -1
  531. package/dist/types/src/script/UnlockingScript.d.ts.map +1 -1
  532. package/dist/types/src/script/index.d.ts +7 -7
  533. package/dist/types/src/script/index.d.ts.map +1 -1
  534. package/dist/types/src/script/templates/P2PKH.d.ts +7 -7
  535. package/dist/types/src/script/templates/P2PKH.d.ts.map +1 -1
  536. package/dist/types/src/script/templates/PushDrop.d.ts +6 -7
  537. package/dist/types/src/script/templates/PushDrop.d.ts.map +1 -1
  538. package/dist/types/src/script/templates/RPuzzle.d.ts +9 -9
  539. package/dist/types/src/script/templates/RPuzzle.d.ts.map +1 -1
  540. package/dist/types/src/script/templates/index.d.ts +3 -3
  541. package/dist/types/src/script/templates/index.d.ts.map +1 -1
  542. package/dist/types/src/totp/index.d.ts +1 -1
  543. package/dist/types/src/totp/index.d.ts.map +1 -1
  544. package/dist/types/src/totp/totp.d.ts.map +1 -1
  545. package/dist/types/src/transaction/Beef.d.ts +10 -10
  546. package/dist/types/src/transaction/Beef.d.ts.map +1 -1
  547. package/dist/types/src/transaction/BeefParty.d.ts +1 -1
  548. package/dist/types/src/transaction/BeefParty.d.ts.map +1 -1
  549. package/dist/types/src/transaction/BeefTx.d.ts +4 -4
  550. package/dist/types/src/transaction/BeefTx.d.ts.map +1 -1
  551. package/dist/types/src/transaction/Broadcaster.d.ts +1 -1
  552. package/dist/types/src/transaction/Broadcaster.d.ts.map +1 -1
  553. package/dist/types/src/transaction/FeeModel.d.ts +1 -1
  554. package/dist/types/src/transaction/FeeModel.d.ts.map +1 -1
  555. package/dist/types/src/transaction/MerklePath.d.ts +2 -2
  556. package/dist/types/src/transaction/MerklePath.d.ts.map +1 -1
  557. package/dist/types/src/transaction/Transaction.d.ts +7 -7
  558. package/dist/types/src/transaction/Transaction.d.ts.map +1 -1
  559. package/dist/types/src/transaction/TransactionInput.d.ts +2 -2
  560. package/dist/types/src/transaction/TransactionInput.d.ts.map +1 -1
  561. package/dist/types/src/transaction/TransactionOutput.d.ts +1 -1
  562. package/dist/types/src/transaction/TransactionOutput.d.ts.map +1 -1
  563. package/dist/types/src/transaction/broadcasters/ARC.d.ts +4 -4
  564. package/dist/types/src/transaction/broadcasters/ARC.d.ts.map +1 -1
  565. package/dist/types/src/transaction/broadcasters/DefaultBroadcaster.d.ts +2 -2
  566. package/dist/types/src/transaction/broadcasters/DefaultBroadcaster.d.ts.map +1 -1
  567. package/dist/types/src/transaction/broadcasters/WhatsOnChainBroadcaster.d.ts +4 -4
  568. package/dist/types/src/transaction/broadcasters/WhatsOnChainBroadcaster.d.ts.map +1 -1
  569. package/dist/types/src/transaction/broadcasters/index.d.ts +4 -4
  570. package/dist/types/src/transaction/broadcasters/index.d.ts.map +1 -1
  571. package/dist/types/src/transaction/chaintrackers/DefaultChainTracker.d.ts +1 -1
  572. package/dist/types/src/transaction/chaintrackers/DefaultChainTracker.d.ts.map +1 -1
  573. package/dist/types/src/transaction/chaintrackers/WhatsOnChain.d.ts +3 -3
  574. package/dist/types/src/transaction/chaintrackers/WhatsOnChain.d.ts.map +1 -1
  575. package/dist/types/src/transaction/chaintrackers/index.d.ts +3 -3
  576. package/dist/types/src/transaction/chaintrackers/index.d.ts.map +1 -1
  577. package/dist/types/src/transaction/fee-models/SatoshisPerKilobyte.d.ts +2 -2
  578. package/dist/types/src/transaction/fee-models/SatoshisPerKilobyte.d.ts.map +1 -1
  579. package/dist/types/src/transaction/fee-models/index.d.ts +1 -1
  580. package/dist/types/src/transaction/fee-models/index.d.ts.map +1 -1
  581. package/dist/types/src/transaction/http/DefaultHttpClient.d.ts +1 -1
  582. package/dist/types/src/transaction/http/DefaultHttpClient.d.ts.map +1 -1
  583. package/dist/types/src/transaction/http/FetchHttpClient.d.ts +1 -1
  584. package/dist/types/src/transaction/http/FetchHttpClient.d.ts.map +1 -1
  585. package/dist/types/src/transaction/http/HttpClient.d.ts.map +1 -1
  586. package/dist/types/src/transaction/http/NodejsHttpClient.d.ts +1 -1
  587. package/dist/types/src/transaction/http/NodejsHttpClient.d.ts.map +1 -1
  588. package/dist/types/src/transaction/http/index.d.ts +6 -6
  589. package/dist/types/src/transaction/http/index.d.ts.map +1 -1
  590. package/dist/types/src/transaction/index.d.ts +10 -10
  591. package/dist/types/src/transaction/index.d.ts.map +1 -1
  592. package/dist/types/src/wallet/CachedKeyDeriver.d.ts +3 -3
  593. package/dist/types/src/wallet/CachedKeyDeriver.d.ts.map +1 -1
  594. package/dist/types/src/wallet/KeyDeriver.d.ts +2 -2
  595. package/dist/types/src/wallet/KeyDeriver.d.ts.map +1 -1
  596. package/dist/types/src/wallet/ProtoWallet.d.ts +12 -12
  597. package/dist/types/src/wallet/ProtoWallet.d.ts.map +1 -1
  598. package/dist/types/src/wallet/Wallet.interfaces.d.ts +7 -8
  599. package/dist/types/src/wallet/Wallet.interfaces.d.ts.map +1 -1
  600. package/dist/types/src/wallet/WalletClient.d.ts +6 -6
  601. package/dist/types/src/wallet/WalletClient.d.ts.map +1 -1
  602. package/dist/types/src/wallet/index.d.ts +8 -8
  603. package/dist/types/src/wallet/index.d.ts.map +1 -1
  604. package/dist/types/src/wallet/substrates/HTTPWalletJSON.d.ts +7 -7
  605. package/dist/types/src/wallet/substrates/HTTPWalletJSON.d.ts.map +1 -1
  606. package/dist/types/src/wallet/substrates/HTTPWalletWire.d.ts +1 -1
  607. package/dist/types/src/wallet/substrates/HTTPWalletWire.d.ts.map +1 -1
  608. package/dist/types/src/wallet/substrates/WalletWire.d.ts.map +1 -1
  609. package/dist/types/src/wallet/substrates/WalletWireCalls.d.ts.map +1 -1
  610. package/dist/types/src/wallet/substrates/WalletWireProcessor.d.ts +2 -2
  611. package/dist/types/src/wallet/substrates/WalletWireProcessor.d.ts.map +1 -1
  612. package/dist/types/src/wallet/substrates/WalletWireTransceiver.d.ts +10 -10
  613. package/dist/types/src/wallet/substrates/WalletWireTransceiver.d.ts.map +1 -1
  614. package/dist/types/src/wallet/substrates/XDM.d.ts +2 -2
  615. package/dist/types/src/wallet/substrates/XDM.d.ts.map +1 -1
  616. package/dist/types/src/wallet/substrates/index.d.ts +7 -7
  617. package/dist/types/src/wallet/substrates/index.d.ts.map +1 -1
  618. package/dist/types/src/wallet/substrates/window.CWI.d.ts +25 -25
  619. package/dist/types/src/wallet/substrates/window.CWI.d.ts.map +1 -1
  620. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  621. package/dist/umd/bundle.js +1 -1
  622. package/docs/auth.md +44 -38
  623. package/docs/primitives.md +97 -73
  624. package/docs/script.md +4 -4
  625. package/docs/swagger/dist/swagger-initializer.js +7 -7
  626. package/docs/swagger/dist/swagger-ui-bundle.js +1 -1
  627. package/docs/swagger/dist/swagger-ui-es-bundle-core.js +2 -2
  628. package/docs/swagger/dist/swagger-ui-es-bundle.js +1 -1
  629. package/docs/swagger/dist/swagger-ui-standalone-preset.js +1 -1
  630. package/docs/swagger/dist/swagger-ui.js +2 -2
  631. package/docs/transaction.md +27 -27
  632. package/docs/wallet-substrates.md +13 -13
  633. package/docs/wallet.md +80 -82
  634. package/mod.ts +15 -15
  635. package/package.json +8 -3
  636. package/src/auth/Peer.ts +75 -70
  637. package/src/auth/SessionManager.ts +11 -6
  638. package/src/auth/__tests/Peer.test.ts +141 -114
  639. package/src/auth/__tests/SessionManager.test.ts +67 -19
  640. package/src/auth/__tests/build.test.ts +11 -0
  641. package/src/auth/certificates/Certificate.ts +15 -12
  642. package/src/auth/certificates/MasterCertificate.ts +24 -33
  643. package/src/auth/certificates/VerifiableCertificate.ts +6 -4
  644. package/src/auth/certificates/__tests/Certificate.test.ts +140 -139
  645. package/src/auth/certificates/__tests/CompletedProtoWallet.ts +88 -74
  646. package/src/auth/certificates/__tests/MasterCertificate.test.ts +7 -15
  647. package/src/auth/certificates/__tests/VerifiableCertificate.test.ts +1 -6
  648. package/src/auth/certificates/index.ts +4 -4
  649. package/src/auth/clients/AuthFetch.ts +232 -316
  650. package/src/auth/clients/index.ts +1 -1
  651. package/src/auth/index.ts +7 -7
  652. package/src/auth/transports/SimplifiedFetchTransport.ts +126 -166
  653. package/src/auth/transports/index.ts +1 -1
  654. package/src/auth/types.ts +1 -1
  655. package/src/auth/utils/__tests/cryptononce.test.ts +7 -5
  656. package/src/auth/utils/__tests/getVerifiableCertificates.test.ts +12 -12
  657. package/src/auth/utils/__tests/validateCertificates.test.ts +113 -103
  658. package/src/auth/utils/createNonce.ts +1 -1
  659. package/src/auth/utils/getVerifiableCertificates.ts +4 -4
  660. package/src/auth/utils/index.ts +4 -4
  661. package/src/auth/utils/validateCertificates.ts +9 -5
  662. package/src/auth/utils/verifyNonce.ts +1 -1
  663. package/src/compat/BSM.ts +7 -7
  664. package/src/compat/ECIES.ts +38 -30
  665. package/src/compat/HD.ts +12 -13
  666. package/src/compat/Mnemonic.ts +16 -14
  667. package/src/compat/Utxo.ts +4 -4
  668. package/src/compat/__tests/BSM.test.ts +5 -6
  669. package/src/compat/__tests/HD.test.ts +6 -4
  670. package/src/compat/__tests/Mnemonic.test.ts +144 -145
  671. package/src/compat/__tests/Mnemonic.vectors.ts +110 -55
  672. package/src/compat/index.ts +5 -5
  673. package/src/messages/EncryptedMessage.ts +5 -5
  674. package/src/messages/SignedMessage.ts +7 -6
  675. package/src/messages/__tests/EncryptedMessage.test.ts +39 -39
  676. package/src/messages/__tests/SignedMessage.test.ts +49 -49
  677. package/src/messages/index.ts +2 -2
  678. package/src/overlay-tools/LookupResolver.ts +52 -32
  679. package/src/overlay-tools/OverlayAdminTokenTemplate.ts +9 -5
  680. package/src/overlay-tools/SHIPBroadcaster.ts +8 -7
  681. package/src/overlay-tools/index.ts +5 -5
  682. package/src/primitives/AESGCM.ts +2 -0
  683. package/src/primitives/BasePoint.ts +5 -5
  684. package/src/primitives/BigNumber.ts +8 -6
  685. package/src/primitives/Curve.ts +79 -27
  686. package/src/primitives/DRBG.ts +3 -3
  687. package/src/primitives/ECDSA.ts +62 -42
  688. package/src/primitives/Hash.ts +215 -163
  689. package/src/primitives/JacobianPoint.ts +19 -5
  690. package/src/primitives/K256.ts +2 -2
  691. package/src/primitives/Mersenne.ts +1 -1
  692. package/src/primitives/MontgomoryMethod.ts +2 -2
  693. package/src/primitives/Point.ts +98 -76
  694. package/src/primitives/Polynomial.ts +6 -6
  695. package/src/primitives/PrivateKey.ts +24 -24
  696. package/src/primitives/PublicKey.ts +8 -8
  697. package/src/primitives/Random.ts +7 -3
  698. package/src/primitives/ReductionContext.ts +3 -3
  699. package/src/primitives/Schnorr.ts +5 -5
  700. package/src/primitives/Signature.ts +14 -12
  701. package/src/primitives/SymmetricKey.ts +5 -5
  702. package/src/primitives/TransactionSignature.ts +26 -13
  703. package/src/primitives/__tests/AESGCM.test.ts +403 -403
  704. package/src/primitives/__tests/BRC42.private.vectors.ts +30 -15
  705. package/src/primitives/__tests/BRC42.public.vectors.ts +30 -15
  706. package/src/primitives/__tests/BigNumber.arithmatic.test.ts +563 -563
  707. package/src/primitives/__tests/BigNumber.binary.test.ts +211 -211
  708. package/src/primitives/__tests/BigNumber.constructor.test.ts +8 -4
  709. package/src/primitives/__tests/BigNumber.dhGroup.test.ts +15 -15
  710. package/src/primitives/__tests/BigNumber.fixtures.ts +16 -8
  711. package/src/primitives/__tests/BigNumber.serializers.test.ts +169 -169
  712. package/src/primitives/__tests/BigNumber.utils.test.ts +328 -328
  713. package/src/primitives/__tests/Curve.unit.test.ts +152 -145
  714. package/src/primitives/__tests/DRBG.test.ts +13 -13
  715. package/src/primitives/__tests/DRBG.vectors.ts +45 -75
  716. package/src/primitives/__tests/ECDSA.test.ts +51 -51
  717. package/src/primitives/__tests/HMAC.test.ts +46 -46
  718. package/src/primitives/__tests/Hash.test.ts +83 -83
  719. package/src/primitives/__tests/PBKDF2.vectors.ts +130 -117
  720. package/src/primitives/__tests/PrivateKey.split.test.ts +6 -4
  721. package/src/primitives/__tests/PrivateKey.test.ts +53 -55
  722. package/src/primitives/__tests/PublicKey.test.ts +59 -57
  723. package/src/primitives/__tests/Random.test.ts +10 -10
  724. package/src/primitives/__tests/ReductionContext.test.ts +222 -222
  725. package/src/primitives/__tests/Schnorr.test.ts +150 -148
  726. package/src/primitives/__tests/SymmetricKey.test.ts +44 -44
  727. package/src/primitives/__tests/SymmetricKey.vectors.ts +16 -8
  728. package/src/primitives/__tests/bug-31.test.ts +23 -29
  729. package/src/primitives/__tests/utils.test.ts +1 -1
  730. package/src/primitives/index.ts +14 -14
  731. package/src/primitives/utils.ts +25 -26
  732. package/src/script/LockingScript.ts +1 -1
  733. package/src/script/Script.ts +13 -11
  734. package/src/script/ScriptTemplate.ts +5 -5
  735. package/src/script/Spend.ts +27 -25
  736. package/src/script/UnlockingScript.ts +1 -1
  737. package/src/script/__tests/Script.test.ts +7 -3
  738. package/src/script/__tests/Spend.test.ts +23 -18
  739. package/src/script/__tests/SpendComplex.test.ts +27 -31
  740. package/src/script/__tests/script.invalid.vectors.ts +428 -1796
  741. package/src/script/__tests/script.valid.vectors.ts +1064 -1064
  742. package/src/script/index.ts +7 -7
  743. package/src/script/templates/P2PKH.ts +72 -61
  744. package/src/script/templates/PushDrop.ts +101 -95
  745. package/src/script/templates/RPuzzle.ts +65 -62
  746. package/src/script/templates/__tests/PushDrop.test.ts +2 -3
  747. package/src/script/templates/index.ts +3 -3
  748. package/src/totp/__tests/totp.test.ts +12 -11
  749. package/src/totp/index.ts +1 -1
  750. package/src/totp/totp.ts +5 -4
  751. package/src/transaction/Beef.ts +84 -59
  752. package/src/transaction/BeefParty.ts +9 -7
  753. package/src/transaction/BeefTx.ts +32 -26
  754. package/src/transaction/Broadcaster.ts +1 -1
  755. package/src/transaction/FeeModel.ts +1 -2
  756. package/src/transaction/MerklePath.ts +58 -37
  757. package/src/transaction/Transaction.ts +127 -103
  758. package/src/transaction/TransactionInput.ts +2 -2
  759. package/src/transaction/TransactionOutput.ts +1 -2
  760. package/src/transaction/__tests/Beef.test.ts +109 -68
  761. package/src/transaction/__tests/MerklePath.test.ts +132 -131
  762. package/src/transaction/__tests/Transaction.benchmarks.test.ts +10 -13
  763. package/src/transaction/__tests/Transaction.test.ts +20 -31
  764. package/src/transaction/__tests/bigtx.vectors.ts +2 -1
  765. package/src/transaction/__tests/bump.invalid.vectors.ts +24 -6
  766. package/src/transaction/__tests/bump.valid.vectors.ts +6 -2
  767. package/src/transaction/__tests/tx.invalid.vectors.ts +881 -185
  768. package/src/transaction/__tests/tx.valid.vectors.ts +1210 -257
  769. package/src/transaction/broadcasters/ARC.ts +117 -112
  770. package/src/transaction/broadcasters/DefaultBroadcaster.ts +4 -4
  771. package/src/transaction/broadcasters/WhatsOnChainBroadcaster.ts +32 -32
  772. package/src/transaction/broadcasters/__tests/ARC.test.ts +63 -27
  773. package/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.ts +9 -8
  774. package/src/transaction/broadcasters/index.ts +4 -4
  775. package/src/transaction/chaintrackers/DefaultChainTracker.ts +3 -3
  776. package/src/transaction/chaintrackers/WhatsOnChain.ts +39 -38
  777. package/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.ts +99 -99
  778. package/src/transaction/chaintrackers/index.ts +3 -3
  779. package/src/transaction/fee-models/SatoshisPerKilobyte.ts +30 -31
  780. package/src/transaction/fee-models/index.ts +1 -1
  781. package/src/transaction/http/DefaultHttpClient.ts +14 -13
  782. package/src/transaction/http/FetchHttpClient.ts +3 -3
  783. package/src/transaction/http/HttpClient.ts +20 -20
  784. package/src/transaction/http/NodejsHttpClient.ts +27 -27
  785. package/src/transaction/http/index.ts +7 -7
  786. package/src/transaction/index.ts +10 -10
  787. package/src/wallet/CachedKeyDeriver.ts +39 -16
  788. package/src/wallet/KeyDeriver.ts +4 -4
  789. package/src/wallet/ProtoWallet.ts +77 -44
  790. package/src/wallet/Wallet.interfaces.ts +10 -8
  791. package/src/wallet/WalletClient.ts +21 -24
  792. package/src/wallet/WalletError.ts +2 -2
  793. package/src/wallet/__tests/CachedKeyDeriver.test.ts +15 -12
  794. package/src/wallet/__tests/KeyDeriver.test.ts +115 -115
  795. package/src/wallet/__tests/ProtoWallet.test.ts +320 -313
  796. package/src/wallet/index.ts +8 -8
  797. package/src/wallet/substrates/HTTPWalletJSON.ts +54 -40
  798. package/src/wallet/substrates/HTTPWalletWire.ts +27 -27
  799. package/src/wallet/substrates/WalletWire.ts +1 -1
  800. package/src/wallet/substrates/WalletWireCalls.ts +2 -2
  801. package/src/wallet/substrates/WalletWireProcessor.ts +966 -967
  802. package/src/wallet/substrates/WalletWireTransceiver.ts +1012 -1007
  803. package/src/wallet/substrates/XDM.ts +18 -19
  804. package/src/wallet/substrates/__tests/WalletWire.integration.test.ts +6 -4
  805. package/src/wallet/substrates/__tests/XDM.test.ts +343 -341
  806. package/src/wallet/substrates/index.ts +7 -7
  807. package/src/wallet/substrates/window.CWI.ts +330 -330
  808. package/dist/cjs/src/auth/__tests/Peer.test.js +0 -446
  809. package/dist/cjs/src/auth/__tests/Peer.test.js.map +0 -1
  810. package/dist/cjs/src/auth/__tests/SessionManager.test.js +0 -69
  811. package/dist/cjs/src/auth/__tests/SessionManager.test.js.map +0 -1
  812. package/dist/cjs/src/auth/certificates/__tests/Certificate.test.js +0 -182
  813. package/dist/cjs/src/auth/certificates/__tests/Certificate.test.js.map +0 -1
  814. package/dist/cjs/src/auth/certificates/__tests/MasterCertificate.test.js +0 -184
  815. package/dist/cjs/src/auth/certificates/__tests/MasterCertificate.test.js.map +0 -1
  816. package/dist/cjs/src/auth/certificates/__tests/VerifiableCertificate.test.js +0 -75
  817. package/dist/cjs/src/auth/certificates/__tests/VerifiableCertificate.test.js.map +0 -1
  818. package/dist/cjs/src/auth/utils/__tests/cryptononce.test.js +0 -101
  819. package/dist/cjs/src/auth/utils/__tests/cryptononce.test.js.map +0 -1
  820. package/dist/cjs/src/auth/utils/__tests/getVerifiableCertificates.test.js +0 -106
  821. package/dist/cjs/src/auth/utils/__tests/getVerifiableCertificates.test.js.map +0 -1
  822. package/dist/cjs/src/auth/utils/__tests/validateCertificates.test.js +0 -111
  823. package/dist/cjs/src/auth/utils/__tests/validateCertificates.test.js.map +0 -1
  824. package/dist/cjs/src/compat/__tests/BSM.test.js +0 -69
  825. package/dist/cjs/src/compat/__tests/BSM.test.js.map +0 -1
  826. package/dist/cjs/src/compat/__tests/ECIES.test.js +0 -115
  827. package/dist/cjs/src/compat/__tests/ECIES.test.js.map +0 -1
  828. package/dist/cjs/src/compat/__tests/HD.test.js +0 -336
  829. package/dist/cjs/src/compat/__tests/HD.test.js.map +0 -1
  830. package/dist/cjs/src/compat/__tests/Mnemonic.test.js +0 -150
  831. package/dist/cjs/src/compat/__tests/Mnemonic.test.js.map +0 -1
  832. package/dist/cjs/src/compat/__tests/Mnemonic.vectors.js +0 -175
  833. package/dist/cjs/src/compat/__tests/Mnemonic.vectors.js.map +0 -1
  834. package/dist/cjs/src/messages/__tests/EncryptedMessage.test.js +0 -57
  835. package/dist/cjs/src/messages/__tests/EncryptedMessage.test.js.map +0 -1
  836. package/dist/cjs/src/messages/__tests/SignedMessage.test.js +0 -52
  837. package/dist/cjs/src/messages/__tests/SignedMessage.test.js.map +0 -1
  838. package/dist/cjs/src/overlay-tools/__tests/LookupResolver.test.js +0 -1471
  839. package/dist/cjs/src/overlay-tools/__tests/LookupResolver.test.js.map +0 -1
  840. package/dist/cjs/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js +0 -78
  841. package/dist/cjs/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js.map +0 -1
  842. package/dist/cjs/src/overlay-tools/__tests/SHIPBroadcaster.test.js +0 -933
  843. package/dist/cjs/src/overlay-tools/__tests/SHIPBroadcaster.test.js.map +0 -1
  844. package/dist/cjs/src/primitives/__tests/AESGCM.test.js +0 -248
  845. package/dist/cjs/src/primitives/__tests/AESGCM.test.js.map +0 -1
  846. package/dist/cjs/src/primitives/__tests/BRC42.private.vectors.js +0 -36
  847. package/dist/cjs/src/primitives/__tests/BRC42.private.vectors.js.map +0 -1
  848. package/dist/cjs/src/primitives/__tests/BRC42.public.vectors.js +0 -36
  849. package/dist/cjs/src/primitives/__tests/BRC42.public.vectors.js.map +0 -1
  850. package/dist/cjs/src/primitives/__tests/BigNumber.arithmatic.test.js +0 -501
  851. package/dist/cjs/src/primitives/__tests/BigNumber.arithmatic.test.js.map +0 -1
  852. package/dist/cjs/src/primitives/__tests/BigNumber.binary.test.js +0 -185
  853. package/dist/cjs/src/primitives/__tests/BigNumber.binary.test.js.map +0 -1
  854. package/dist/cjs/src/primitives/__tests/BigNumber.constructor.test.js +0 -149
  855. package/dist/cjs/src/primitives/__tests/BigNumber.constructor.test.js.map +0 -1
  856. package/dist/cjs/src/primitives/__tests/BigNumber.dhGroup.test.js +0 -23
  857. package/dist/cjs/src/primitives/__tests/BigNumber.dhGroup.test.js.map +0 -1
  858. package/dist/cjs/src/primitives/__tests/BigNumber.fixtures.js +0 -268
  859. package/dist/cjs/src/primitives/__tests/BigNumber.fixtures.js.map +0 -1
  860. package/dist/cjs/src/primitives/__tests/BigNumber.serializers.test.js +0 -147
  861. package/dist/cjs/src/primitives/__tests/BigNumber.serializers.test.js.map +0 -1
  862. package/dist/cjs/src/primitives/__tests/BigNumber.utils.test.js +0 -322
  863. package/dist/cjs/src/primitives/__tests/BigNumber.utils.test.js.map +0 -1
  864. package/dist/cjs/src/primitives/__tests/Curve.unit.test.js +0 -145
  865. package/dist/cjs/src/primitives/__tests/Curve.unit.test.js.map +0 -1
  866. package/dist/cjs/src/primitives/__tests/DRBG.test.js +0 -22
  867. package/dist/cjs/src/primitives/__tests/DRBG.test.js.map +0 -1
  868. package/dist/cjs/src/primitives/__tests/DRBG.vectors.js +0 -170
  869. package/dist/cjs/src/primitives/__tests/DRBG.vectors.js.map +0 -1
  870. package/dist/cjs/src/primitives/__tests/ECDH.test.js +0 -34
  871. package/dist/cjs/src/primitives/__tests/ECDH.test.js.map +0 -1
  872. package/dist/cjs/src/primitives/__tests/ECDSA.test.js +0 -89
  873. package/dist/cjs/src/primitives/__tests/ECDSA.test.js.map +0 -1
  874. package/dist/cjs/src/primitives/__tests/HMAC.test.js +0 -60
  875. package/dist/cjs/src/primitives/__tests/HMAC.test.js.map +0 -1
  876. package/dist/cjs/src/primitives/__tests/Hash.test.js +0 -159
  877. package/dist/cjs/src/primitives/__tests/Hash.test.js.map +0 -1
  878. package/dist/cjs/src/primitives/__tests/PBKDF2.vectors.js +0 -122
  879. package/dist/cjs/src/primitives/__tests/PBKDF2.vectors.js.map +0 -1
  880. package/dist/cjs/src/primitives/__tests/PrivateKey.split.test.js +0 -105
  881. package/dist/cjs/src/primitives/__tests/PrivateKey.split.test.js.map +0 -1
  882. package/dist/cjs/src/primitives/__tests/PrivateKey.test.js +0 -90
  883. package/dist/cjs/src/primitives/__tests/PrivateKey.test.js.map +0 -1
  884. package/dist/cjs/src/primitives/__tests/PublicKey.test.js +0 -83
  885. package/dist/cjs/src/primitives/__tests/PublicKey.test.js.map +0 -1
  886. package/dist/cjs/src/primitives/__tests/Random.test.js +0 -19
  887. package/dist/cjs/src/primitives/__tests/Random.test.js.map +0 -1
  888. package/dist/cjs/src/primitives/__tests/Reader.test.js +0 -282
  889. package/dist/cjs/src/primitives/__tests/Reader.test.js.map +0 -1
  890. package/dist/cjs/src/primitives/__tests/ReductionContext.test.js +0 -224
  891. package/dist/cjs/src/primitives/__tests/ReductionContext.test.js.map +0 -1
  892. package/dist/cjs/src/primitives/__tests/Schnorr.test.js +0 -213
  893. package/dist/cjs/src/primitives/__tests/Schnorr.test.js.map +0 -1
  894. package/dist/cjs/src/primitives/__tests/SymmetricKey.test.js +0 -51
  895. package/dist/cjs/src/primitives/__tests/SymmetricKey.test.js.map +0 -1
  896. package/dist/cjs/src/primitives/__tests/SymmetricKey.vectors.js +0 -43
  897. package/dist/cjs/src/primitives/__tests/SymmetricKey.vectors.js.map +0 -1
  898. package/dist/cjs/src/primitives/__tests/Writer.test.js +0 -176
  899. package/dist/cjs/src/primitives/__tests/Writer.test.js.map +0 -1
  900. package/dist/cjs/src/primitives/__tests/bug-31.test.js +0 -32
  901. package/dist/cjs/src/primitives/__tests/bug-31.test.js.map +0 -1
  902. package/dist/cjs/src/primitives/__tests/sighash.vectors.js +0 -3506
  903. package/dist/cjs/src/primitives/__tests/sighash.vectors.js.map +0 -1
  904. package/dist/cjs/src/primitives/__tests/utils.test.js +0 -110
  905. package/dist/cjs/src/primitives/__tests/utils.test.js.map +0 -1
  906. package/dist/cjs/src/script/__tests/Script.test.js +0 -347
  907. package/dist/cjs/src/script/__tests/Script.test.js.map +0 -1
  908. package/dist/cjs/src/script/__tests/Spend.test.js +0 -282
  909. package/dist/cjs/src/script/__tests/Spend.test.js.map +0 -1
  910. package/dist/cjs/src/script/__tests/SpendComplex.test.js +0 -52
  911. package/dist/cjs/src/script/__tests/SpendComplex.test.js.map +0 -1
  912. package/dist/cjs/src/script/__tests/script.invalid.vectors.js +0 -2370
  913. package/dist/cjs/src/script/__tests/script.invalid.vectors.js.map +0 -1
  914. package/dist/cjs/src/script/__tests/script.valid.vectors.js +0 -1181
  915. package/dist/cjs/src/script/__tests/script.valid.vectors.js.map +0 -1
  916. package/dist/cjs/src/script/__tests/spend.valid.vectors.js +0 -2298
  917. package/dist/cjs/src/script/__tests/spend.valid.vectors.js.map +0 -1
  918. package/dist/cjs/src/script/templates/__tests/PushDrop.test.js +0 -161
  919. package/dist/cjs/src/script/templates/__tests/PushDrop.test.js.map +0 -1
  920. package/dist/cjs/src/totp/__tests/totp.test.js +0 -67
  921. package/dist/cjs/src/totp/__tests/totp.test.js.map +0 -1
  922. package/dist/cjs/src/transaction/__tests/Beef.test.js +0 -393
  923. package/dist/cjs/src/transaction/__tests/Beef.test.js.map +0 -1
  924. package/dist/cjs/src/transaction/__tests/MerklePath.test.js +0 -209
  925. package/dist/cjs/src/transaction/__tests/MerklePath.test.js.map +0 -1
  926. package/dist/cjs/src/transaction/__tests/Transaction.benchmarks.test.js +0 -219
  927. package/dist/cjs/src/transaction/__tests/Transaction.benchmarks.test.js.map +0 -1
  928. package/dist/cjs/src/transaction/__tests/Transaction.test.js +0 -1073
  929. package/dist/cjs/src/transaction/__tests/Transaction.test.js.map +0 -1
  930. package/dist/cjs/src/transaction/__tests/bigtx.vectors.js +0 -7
  931. package/dist/cjs/src/transaction/__tests/bigtx.vectors.js.map +0 -1
  932. package/dist/cjs/src/transaction/__tests/bump.invalid.vectors.js +0 -11
  933. package/dist/cjs/src/transaction/__tests/bump.invalid.vectors.js.map +0 -1
  934. package/dist/cjs/src/transaction/__tests/bump.valid.vectors.js +0 -7
  935. package/dist/cjs/src/transaction/__tests/bump.valid.vectors.js.map +0 -1
  936. package/dist/cjs/src/transaction/__tests/tx.invalid.vectors.js +0 -230
  937. package/dist/cjs/src/transaction/__tests/tx.invalid.vectors.js.map +0 -1
  938. package/dist/cjs/src/transaction/__tests/tx.valid.vectors.js +0 -296
  939. package/dist/cjs/src/transaction/__tests/tx.valid.vectors.js.map +0 -1
  940. package/dist/cjs/src/transaction/broadcasters/__tests/ARC.test.js +0 -246
  941. package/dist/cjs/src/transaction/broadcasters/__tests/ARC.test.js.map +0 -1
  942. package/dist/cjs/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js +0 -148
  943. package/dist/cjs/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js.map +0 -1
  944. package/dist/cjs/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js +0 -155
  945. package/dist/cjs/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js.map +0 -1
  946. package/dist/cjs/src/wallet/__tests/CachedKeyDeriver.test.js +0 -269
  947. package/dist/cjs/src/wallet/__tests/CachedKeyDeriver.test.js.map +0 -1
  948. package/dist/cjs/src/wallet/__tests/KeyDeriver.test.js +0 -114
  949. package/dist/cjs/src/wallet/__tests/KeyDeriver.test.js.map +0 -1
  950. package/dist/cjs/src/wallet/__tests/ProtoWallet.test.js +0 -475
  951. package/dist/cjs/src/wallet/__tests/ProtoWallet.test.js.map +0 -1
  952. package/dist/cjs/src/wallet/substrates/__tests/WalletWire.integration.test.js +0 -1962
  953. package/dist/cjs/src/wallet/substrates/__tests/WalletWire.integration.test.js.map +0 -1
  954. package/dist/cjs/src/wallet/substrates/__tests/XDM.test.js +0 -579
  955. package/dist/cjs/src/wallet/substrates/__tests/XDM.test.js.map +0 -1
  956. package/dist/esm/src/auth/__tests/Peer.test.js +0 -448
  957. package/dist/esm/src/auth/__tests/Peer.test.js.map +0 -1
  958. package/dist/esm/src/auth/__tests/SessionManager.test.js +0 -69
  959. package/dist/esm/src/auth/__tests/SessionManager.test.js.map +0 -1
  960. package/dist/esm/src/auth/certificates/__tests/Certificate.test.js +0 -182
  961. package/dist/esm/src/auth/certificates/__tests/Certificate.test.js.map +0 -1
  962. package/dist/esm/src/auth/certificates/__tests/MasterCertificate.test.js +0 -184
  963. package/dist/esm/src/auth/certificates/__tests/MasterCertificate.test.js.map +0 -1
  964. package/dist/esm/src/auth/certificates/__tests/VerifiableCertificate.test.js +0 -75
  965. package/dist/esm/src/auth/certificates/__tests/VerifiableCertificate.test.js.map +0 -1
  966. package/dist/esm/src/auth/utils/__tests/cryptononce.test.js +0 -101
  967. package/dist/esm/src/auth/utils/__tests/cryptononce.test.js.map +0 -1
  968. package/dist/esm/src/auth/utils/__tests/getVerifiableCertificates.test.js +0 -106
  969. package/dist/esm/src/auth/utils/__tests/getVerifiableCertificates.test.js.map +0 -1
  970. package/dist/esm/src/auth/utils/__tests/validateCertificates.test.js +0 -111
  971. package/dist/esm/src/auth/utils/__tests/validateCertificates.test.js.map +0 -1
  972. package/dist/esm/src/compat/__tests/BSM.test.js +0 -69
  973. package/dist/esm/src/compat/__tests/BSM.test.js.map +0 -1
  974. package/dist/esm/src/compat/__tests/ECIES.test.js +0 -115
  975. package/dist/esm/src/compat/__tests/ECIES.test.js.map +0 -1
  976. package/dist/esm/src/compat/__tests/HD.test.js +0 -336
  977. package/dist/esm/src/compat/__tests/HD.test.js.map +0 -1
  978. package/dist/esm/src/compat/__tests/Mnemonic.test.js +0 -150
  979. package/dist/esm/src/compat/__tests/Mnemonic.test.js.map +0 -1
  980. package/dist/esm/src/compat/__tests/Mnemonic.vectors.js +0 -175
  981. package/dist/esm/src/compat/__tests/Mnemonic.vectors.js.map +0 -1
  982. package/dist/esm/src/messages/__tests/EncryptedMessage.test.js +0 -57
  983. package/dist/esm/src/messages/__tests/EncryptedMessage.test.js.map +0 -1
  984. package/dist/esm/src/messages/__tests/SignedMessage.test.js +0 -52
  985. package/dist/esm/src/messages/__tests/SignedMessage.test.js.map +0 -1
  986. package/dist/esm/src/overlay-tools/__tests/LookupResolver.test.js +0 -1471
  987. package/dist/esm/src/overlay-tools/__tests/LookupResolver.test.js.map +0 -1
  988. package/dist/esm/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js +0 -78
  989. package/dist/esm/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js.map +0 -1
  990. package/dist/esm/src/overlay-tools/__tests/SHIPBroadcaster.test.js +0 -933
  991. package/dist/esm/src/overlay-tools/__tests/SHIPBroadcaster.test.js.map +0 -1
  992. package/dist/esm/src/primitives/__tests/AESGCM.test.js +0 -248
  993. package/dist/esm/src/primitives/__tests/AESGCM.test.js.map +0 -1
  994. package/dist/esm/src/primitives/__tests/BRC42.private.vectors.js +0 -36
  995. package/dist/esm/src/primitives/__tests/BRC42.private.vectors.js.map +0 -1
  996. package/dist/esm/src/primitives/__tests/BRC42.public.vectors.js +0 -36
  997. package/dist/esm/src/primitives/__tests/BRC42.public.vectors.js.map +0 -1
  998. package/dist/esm/src/primitives/__tests/BigNumber.arithmatic.test.js +0 -501
  999. package/dist/esm/src/primitives/__tests/BigNumber.arithmatic.test.js.map +0 -1
  1000. package/dist/esm/src/primitives/__tests/BigNumber.binary.test.js +0 -185
  1001. package/dist/esm/src/primitives/__tests/BigNumber.binary.test.js.map +0 -1
  1002. package/dist/esm/src/primitives/__tests/BigNumber.constructor.test.js +0 -149
  1003. package/dist/esm/src/primitives/__tests/BigNumber.constructor.test.js.map +0 -1
  1004. package/dist/esm/src/primitives/__tests/BigNumber.dhGroup.test.js +0 -23
  1005. package/dist/esm/src/primitives/__tests/BigNumber.dhGroup.test.js.map +0 -1
  1006. package/dist/esm/src/primitives/__tests/BigNumber.fixtures.js +0 -268
  1007. package/dist/esm/src/primitives/__tests/BigNumber.fixtures.js.map +0 -1
  1008. package/dist/esm/src/primitives/__tests/BigNumber.serializers.test.js +0 -147
  1009. package/dist/esm/src/primitives/__tests/BigNumber.serializers.test.js.map +0 -1
  1010. package/dist/esm/src/primitives/__tests/BigNumber.utils.test.js +0 -322
  1011. package/dist/esm/src/primitives/__tests/BigNumber.utils.test.js.map +0 -1
  1012. package/dist/esm/src/primitives/__tests/Curve.unit.test.js +0 -145
  1013. package/dist/esm/src/primitives/__tests/Curve.unit.test.js.map +0 -1
  1014. package/dist/esm/src/primitives/__tests/DRBG.test.js +0 -22
  1015. package/dist/esm/src/primitives/__tests/DRBG.test.js.map +0 -1
  1016. package/dist/esm/src/primitives/__tests/DRBG.vectors.js +0 -170
  1017. package/dist/esm/src/primitives/__tests/DRBG.vectors.js.map +0 -1
  1018. package/dist/esm/src/primitives/__tests/ECDH.test.js +0 -34
  1019. package/dist/esm/src/primitives/__tests/ECDH.test.js.map +0 -1
  1020. package/dist/esm/src/primitives/__tests/ECDSA.test.js +0 -89
  1021. package/dist/esm/src/primitives/__tests/ECDSA.test.js.map +0 -1
  1022. package/dist/esm/src/primitives/__tests/HMAC.test.js +0 -60
  1023. package/dist/esm/src/primitives/__tests/HMAC.test.js.map +0 -1
  1024. package/dist/esm/src/primitives/__tests/Hash.test.js +0 -159
  1025. package/dist/esm/src/primitives/__tests/Hash.test.js.map +0 -1
  1026. package/dist/esm/src/primitives/__tests/PBKDF2.vectors.js +0 -122
  1027. package/dist/esm/src/primitives/__tests/PBKDF2.vectors.js.map +0 -1
  1028. package/dist/esm/src/primitives/__tests/PrivateKey.split.test.js +0 -105
  1029. package/dist/esm/src/primitives/__tests/PrivateKey.split.test.js.map +0 -1
  1030. package/dist/esm/src/primitives/__tests/PrivateKey.test.js +0 -90
  1031. package/dist/esm/src/primitives/__tests/PrivateKey.test.js.map +0 -1
  1032. package/dist/esm/src/primitives/__tests/PublicKey.test.js +0 -83
  1033. package/dist/esm/src/primitives/__tests/PublicKey.test.js.map +0 -1
  1034. package/dist/esm/src/primitives/__tests/Random.test.js +0 -19
  1035. package/dist/esm/src/primitives/__tests/Random.test.js.map +0 -1
  1036. package/dist/esm/src/primitives/__tests/Reader.test.js +0 -282
  1037. package/dist/esm/src/primitives/__tests/Reader.test.js.map +0 -1
  1038. package/dist/esm/src/primitives/__tests/ReductionContext.test.js +0 -223
  1039. package/dist/esm/src/primitives/__tests/ReductionContext.test.js.map +0 -1
  1040. package/dist/esm/src/primitives/__tests/Schnorr.test.js +0 -213
  1041. package/dist/esm/src/primitives/__tests/Schnorr.test.js.map +0 -1
  1042. package/dist/esm/src/primitives/__tests/SymmetricKey.test.js +0 -51
  1043. package/dist/esm/src/primitives/__tests/SymmetricKey.test.js.map +0 -1
  1044. package/dist/esm/src/primitives/__tests/SymmetricKey.vectors.js +0 -43
  1045. package/dist/esm/src/primitives/__tests/SymmetricKey.vectors.js.map +0 -1
  1046. package/dist/esm/src/primitives/__tests/Writer.test.js +0 -176
  1047. package/dist/esm/src/primitives/__tests/Writer.test.js.map +0 -1
  1048. package/dist/esm/src/primitives/__tests/bug-31.test.js +0 -32
  1049. package/dist/esm/src/primitives/__tests/bug-31.test.js.map +0 -1
  1050. package/dist/esm/src/primitives/__tests/sighash.vectors.js +0 -3506
  1051. package/dist/esm/src/primitives/__tests/sighash.vectors.js.map +0 -1
  1052. package/dist/esm/src/primitives/__tests/utils.test.js +0 -110
  1053. package/dist/esm/src/primitives/__tests/utils.test.js.map +0 -1
  1054. package/dist/esm/src/script/__tests/Script.test.js +0 -347
  1055. package/dist/esm/src/script/__tests/Script.test.js.map +0 -1
  1056. package/dist/esm/src/script/__tests/Spend.test.js +0 -282
  1057. package/dist/esm/src/script/__tests/Spend.test.js.map +0 -1
  1058. package/dist/esm/src/script/__tests/SpendComplex.test.js +0 -51
  1059. package/dist/esm/src/script/__tests/SpendComplex.test.js.map +0 -1
  1060. package/dist/esm/src/script/__tests/script.invalid.vectors.js +0 -2370
  1061. package/dist/esm/src/script/__tests/script.invalid.vectors.js.map +0 -1
  1062. package/dist/esm/src/script/__tests/script.valid.vectors.js +0 -1181
  1063. package/dist/esm/src/script/__tests/script.valid.vectors.js.map +0 -1
  1064. package/dist/esm/src/script/__tests/spend.valid.vectors.js +0 -2298
  1065. package/dist/esm/src/script/__tests/spend.valid.vectors.js.map +0 -1
  1066. package/dist/esm/src/script/templates/__tests/PushDrop.test.js +0 -161
  1067. package/dist/esm/src/script/templates/__tests/PushDrop.test.js.map +0 -1
  1068. package/dist/esm/src/totp/__tests/totp.test.js +0 -67
  1069. package/dist/esm/src/totp/__tests/totp.test.js.map +0 -1
  1070. package/dist/esm/src/transaction/__tests/Beef.test.js +0 -393
  1071. package/dist/esm/src/transaction/__tests/Beef.test.js.map +0 -1
  1072. package/dist/esm/src/transaction/__tests/MerklePath.test.js +0 -209
  1073. package/dist/esm/src/transaction/__tests/MerklePath.test.js.map +0 -1
  1074. package/dist/esm/src/transaction/__tests/Transaction.benchmarks.test.js +0 -219
  1075. package/dist/esm/src/transaction/__tests/Transaction.benchmarks.test.js.map +0 -1
  1076. package/dist/esm/src/transaction/__tests/Transaction.test.js +0 -1072
  1077. package/dist/esm/src/transaction/__tests/Transaction.test.js.map +0 -1
  1078. package/dist/esm/src/transaction/__tests/bigtx.vectors.js +0 -7
  1079. package/dist/esm/src/transaction/__tests/bigtx.vectors.js.map +0 -1
  1080. package/dist/esm/src/transaction/__tests/bump.invalid.vectors.js +0 -11
  1081. package/dist/esm/src/transaction/__tests/bump.invalid.vectors.js.map +0 -1
  1082. package/dist/esm/src/transaction/__tests/bump.valid.vectors.js +0 -7
  1083. package/dist/esm/src/transaction/__tests/bump.valid.vectors.js.map +0 -1
  1084. package/dist/esm/src/transaction/__tests/tx.invalid.vectors.js +0 -230
  1085. package/dist/esm/src/transaction/__tests/tx.invalid.vectors.js.map +0 -1
  1086. package/dist/esm/src/transaction/__tests/tx.valid.vectors.js +0 -296
  1087. package/dist/esm/src/transaction/__tests/tx.valid.vectors.js.map +0 -1
  1088. package/dist/esm/src/transaction/broadcasters/__tests/ARC.test.js +0 -246
  1089. package/dist/esm/src/transaction/broadcasters/__tests/ARC.test.js.map +0 -1
  1090. package/dist/esm/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js +0 -148
  1091. package/dist/esm/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js.map +0 -1
  1092. package/dist/esm/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js +0 -155
  1093. package/dist/esm/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js.map +0 -1
  1094. package/dist/esm/src/wallet/__tests/CachedKeyDeriver.test.js +0 -269
  1095. package/dist/esm/src/wallet/__tests/CachedKeyDeriver.test.js.map +0 -1
  1096. package/dist/esm/src/wallet/__tests/KeyDeriver.test.js +0 -113
  1097. package/dist/esm/src/wallet/__tests/KeyDeriver.test.js.map +0 -1
  1098. package/dist/esm/src/wallet/__tests/ProtoWallet.test.js +0 -475
  1099. package/dist/esm/src/wallet/__tests/ProtoWallet.test.js.map +0 -1
  1100. package/dist/esm/src/wallet/substrates/__tests/WalletWire.integration.test.js +0 -1962
  1101. package/dist/esm/src/wallet/substrates/__tests/WalletWire.integration.test.js.map +0 -1
  1102. package/dist/esm/src/wallet/substrates/__tests/XDM.test.js +0 -579
  1103. package/dist/esm/src/wallet/substrates/__tests/XDM.test.js.map +0 -1
  1104. package/dist/types/src/auth/__tests/Peer.test.d.ts +0 -2
  1105. package/dist/types/src/auth/__tests/Peer.test.d.ts.map +0 -1
  1106. package/dist/types/src/auth/__tests/SessionManager.test.d.ts +0 -2
  1107. package/dist/types/src/auth/__tests/SessionManager.test.d.ts.map +0 -1
  1108. package/dist/types/src/auth/certificates/__tests/Certificate.test.d.ts +0 -2
  1109. package/dist/types/src/auth/certificates/__tests/Certificate.test.d.ts.map +0 -1
  1110. package/dist/types/src/auth/certificates/__tests/MasterCertificate.test.d.ts +0 -2
  1111. package/dist/types/src/auth/certificates/__tests/MasterCertificate.test.d.ts.map +0 -1
  1112. package/dist/types/src/auth/certificates/__tests/VerifiableCertificate.test.d.ts +0 -2
  1113. package/dist/types/src/auth/certificates/__tests/VerifiableCertificate.test.d.ts.map +0 -1
  1114. package/dist/types/src/auth/utils/__tests/cryptononce.test.d.ts +0 -2
  1115. package/dist/types/src/auth/utils/__tests/cryptononce.test.d.ts.map +0 -1
  1116. package/dist/types/src/auth/utils/__tests/getVerifiableCertificates.test.d.ts +0 -2
  1117. package/dist/types/src/auth/utils/__tests/getVerifiableCertificates.test.d.ts.map +0 -1
  1118. package/dist/types/src/auth/utils/__tests/validateCertificates.test.d.ts +0 -2
  1119. package/dist/types/src/auth/utils/__tests/validateCertificates.test.d.ts.map +0 -1
  1120. package/dist/types/src/compat/__tests/BSM.test.d.ts +0 -2
  1121. package/dist/types/src/compat/__tests/BSM.test.d.ts.map +0 -1
  1122. package/dist/types/src/compat/__tests/ECIES.test.d.ts +0 -2
  1123. package/dist/types/src/compat/__tests/ECIES.test.d.ts.map +0 -1
  1124. package/dist/types/src/compat/__tests/HD.test.d.ts +0 -2
  1125. package/dist/types/src/compat/__tests/HD.test.d.ts.map +0 -1
  1126. package/dist/types/src/compat/__tests/Mnemonic.test.d.ts +0 -2
  1127. package/dist/types/src/compat/__tests/Mnemonic.test.d.ts.map +0 -1
  1128. package/dist/types/src/compat/__tests/Mnemonic.vectors.d.ts +0 -11
  1129. package/dist/types/src/compat/__tests/Mnemonic.vectors.d.ts.map +0 -1
  1130. package/dist/types/src/messages/__tests/EncryptedMessage.test.d.ts +0 -2
  1131. package/dist/types/src/messages/__tests/EncryptedMessage.test.d.ts.map +0 -1
  1132. package/dist/types/src/messages/__tests/SignedMessage.test.d.ts +0 -2
  1133. package/dist/types/src/messages/__tests/SignedMessage.test.d.ts.map +0 -1
  1134. package/dist/types/src/overlay-tools/__tests/LookupResolver.test.d.ts +0 -2
  1135. package/dist/types/src/overlay-tools/__tests/LookupResolver.test.d.ts.map +0 -1
  1136. package/dist/types/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.d.ts +0 -2
  1137. package/dist/types/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.d.ts.map +0 -1
  1138. package/dist/types/src/overlay-tools/__tests/SHIPBroadcaster.test.d.ts +0 -2
  1139. package/dist/types/src/overlay-tools/__tests/SHIPBroadcaster.test.d.ts.map +0 -1
  1140. package/dist/types/src/primitives/__tests/AESGCM.test.d.ts +0 -2
  1141. package/dist/types/src/primitives/__tests/AESGCM.test.d.ts.map +0 -1
  1142. package/dist/types/src/primitives/__tests/BRC42.private.vectors.d.ts +0 -8
  1143. package/dist/types/src/primitives/__tests/BRC42.private.vectors.d.ts.map +0 -1
  1144. package/dist/types/src/primitives/__tests/BRC42.public.vectors.d.ts +0 -8
  1145. package/dist/types/src/primitives/__tests/BRC42.public.vectors.d.ts.map +0 -1
  1146. package/dist/types/src/primitives/__tests/BigNumber.arithmatic.test.d.ts +0 -2
  1147. package/dist/types/src/primitives/__tests/BigNumber.arithmatic.test.d.ts.map +0 -1
  1148. package/dist/types/src/primitives/__tests/BigNumber.binary.test.d.ts +0 -2
  1149. package/dist/types/src/primitives/__tests/BigNumber.binary.test.d.ts.map +0 -1
  1150. package/dist/types/src/primitives/__tests/BigNumber.constructor.test.d.ts +0 -2
  1151. package/dist/types/src/primitives/__tests/BigNumber.constructor.test.d.ts.map +0 -1
  1152. package/dist/types/src/primitives/__tests/BigNumber.dhGroup.test.d.ts +0 -2
  1153. package/dist/types/src/primitives/__tests/BigNumber.dhGroup.test.d.ts.map +0 -1
  1154. package/dist/types/src/primitives/__tests/BigNumber.fixtures.d.ts +0 -15
  1155. package/dist/types/src/primitives/__tests/BigNumber.fixtures.d.ts.map +0 -1
  1156. package/dist/types/src/primitives/__tests/BigNumber.serializers.test.d.ts +0 -2
  1157. package/dist/types/src/primitives/__tests/BigNumber.serializers.test.d.ts.map +0 -1
  1158. package/dist/types/src/primitives/__tests/BigNumber.utils.test.d.ts +0 -2
  1159. package/dist/types/src/primitives/__tests/BigNumber.utils.test.d.ts.map +0 -1
  1160. package/dist/types/src/primitives/__tests/Curve.unit.test.d.ts +0 -2
  1161. package/dist/types/src/primitives/__tests/Curve.unit.test.d.ts.map +0 -1
  1162. package/dist/types/src/primitives/__tests/DRBG.test.d.ts +0 -2
  1163. package/dist/types/src/primitives/__tests/DRBG.test.d.ts.map +0 -1
  1164. package/dist/types/src/primitives/__tests/DRBG.vectors.d.ts +0 -10
  1165. package/dist/types/src/primitives/__tests/DRBG.vectors.d.ts.map +0 -1
  1166. package/dist/types/src/primitives/__tests/ECDH.test.d.ts +0 -2
  1167. package/dist/types/src/primitives/__tests/ECDH.test.d.ts.map +0 -1
  1168. package/dist/types/src/primitives/__tests/ECDSA.test.d.ts +0 -2
  1169. package/dist/types/src/primitives/__tests/ECDSA.test.d.ts.map +0 -1
  1170. package/dist/types/src/primitives/__tests/HMAC.test.d.ts +0 -2
  1171. package/dist/types/src/primitives/__tests/HMAC.test.d.ts.map +0 -1
  1172. package/dist/types/src/primitives/__tests/Hash.test.d.ts +0 -2
  1173. package/dist/types/src/primitives/__tests/Hash.test.d.ts.map +0 -1
  1174. package/dist/types/src/primitives/__tests/PBKDF2.vectors.d.ts +0 -68
  1175. package/dist/types/src/primitives/__tests/PBKDF2.vectors.d.ts.map +0 -1
  1176. package/dist/types/src/primitives/__tests/PrivateKey.split.test.d.ts +0 -2
  1177. package/dist/types/src/primitives/__tests/PrivateKey.split.test.d.ts.map +0 -1
  1178. package/dist/types/src/primitives/__tests/PrivateKey.test.d.ts +0 -2
  1179. package/dist/types/src/primitives/__tests/PrivateKey.test.d.ts.map +0 -1
  1180. package/dist/types/src/primitives/__tests/PublicKey.test.d.ts +0 -2
  1181. package/dist/types/src/primitives/__tests/PublicKey.test.d.ts.map +0 -1
  1182. package/dist/types/src/primitives/__tests/Random.test.d.ts +0 -2
  1183. package/dist/types/src/primitives/__tests/Random.test.d.ts.map +0 -1
  1184. package/dist/types/src/primitives/__tests/Reader.test.d.ts +0 -2
  1185. package/dist/types/src/primitives/__tests/Reader.test.d.ts.map +0 -1
  1186. package/dist/types/src/primitives/__tests/ReductionContext.test.d.ts +0 -2
  1187. package/dist/types/src/primitives/__tests/ReductionContext.test.d.ts.map +0 -1
  1188. package/dist/types/src/primitives/__tests/Schnorr.test.d.ts +0 -2
  1189. package/dist/types/src/primitives/__tests/Schnorr.test.d.ts.map +0 -1
  1190. package/dist/types/src/primitives/__tests/SymmetricKey.test.d.ts +0 -2
  1191. package/dist/types/src/primitives/__tests/SymmetricKey.test.d.ts.map +0 -1
  1192. package/dist/types/src/primitives/__tests/SymmetricKey.vectors.d.ts +0 -20
  1193. package/dist/types/src/primitives/__tests/SymmetricKey.vectors.d.ts.map +0 -1
  1194. package/dist/types/src/primitives/__tests/Writer.test.d.ts +0 -2
  1195. package/dist/types/src/primitives/__tests/Writer.test.d.ts.map +0 -1
  1196. package/dist/types/src/primitives/__tests/bug-31.test.d.ts +0 -2
  1197. package/dist/types/src/primitives/__tests/bug-31.test.d.ts.map +0 -1
  1198. package/dist/types/src/primitives/__tests/sighash.vectors.d.ts +0 -3
  1199. package/dist/types/src/primitives/__tests/sighash.vectors.d.ts.map +0 -1
  1200. package/dist/types/src/primitives/__tests/utils.test.d.ts +0 -2
  1201. package/dist/types/src/primitives/__tests/utils.test.d.ts.map +0 -1
  1202. package/dist/types/src/script/__tests/Script.test.d.ts +0 -2
  1203. package/dist/types/src/script/__tests/Script.test.d.ts.map +0 -1
  1204. package/dist/types/src/script/__tests/Spend.test.d.ts +0 -2
  1205. package/dist/types/src/script/__tests/Spend.test.d.ts.map +0 -1
  1206. package/dist/types/src/script/__tests/SpendComplex.test.d.ts +0 -2
  1207. package/dist/types/src/script/__tests/SpendComplex.test.d.ts.map +0 -1
  1208. package/dist/types/src/script/__tests/script.invalid.vectors.d.ts +0 -3
  1209. package/dist/types/src/script/__tests/script.invalid.vectors.d.ts.map +0 -1
  1210. package/dist/types/src/script/__tests/script.valid.vectors.d.ts +0 -3
  1211. package/dist/types/src/script/__tests/script.valid.vectors.d.ts.map +0 -1
  1212. package/dist/types/src/script/__tests/spend.valid.vectors.d.ts +0 -3
  1213. package/dist/types/src/script/__tests/spend.valid.vectors.d.ts.map +0 -1
  1214. package/dist/types/src/script/templates/__tests/PushDrop.test.d.ts +0 -2
  1215. package/dist/types/src/script/templates/__tests/PushDrop.test.d.ts.map +0 -1
  1216. package/dist/types/src/totp/__tests/totp.test.d.ts +0 -2
  1217. package/dist/types/src/totp/__tests/totp.test.d.ts.map +0 -1
  1218. package/dist/types/src/transaction/__tests/Beef.test.d.ts +0 -2
  1219. package/dist/types/src/transaction/__tests/Beef.test.d.ts.map +0 -1
  1220. package/dist/types/src/transaction/__tests/MerklePath.test.d.ts +0 -2
  1221. package/dist/types/src/transaction/__tests/MerklePath.test.d.ts.map +0 -1
  1222. package/dist/types/src/transaction/__tests/Transaction.benchmarks.test.d.ts +0 -2
  1223. package/dist/types/src/transaction/__tests/Transaction.benchmarks.test.d.ts.map +0 -1
  1224. package/dist/types/src/transaction/__tests/Transaction.test.d.ts +0 -2
  1225. package/dist/types/src/transaction/__tests/Transaction.test.d.ts.map +0 -1
  1226. package/dist/types/src/transaction/__tests/bigtx.vectors.d.ts +0 -6
  1227. package/dist/types/src/transaction/__tests/bigtx.vectors.d.ts.map +0 -1
  1228. package/dist/types/src/transaction/__tests/bump.invalid.vectors.d.ts +0 -6
  1229. package/dist/types/src/transaction/__tests/bump.invalid.vectors.d.ts.map +0 -1
  1230. package/dist/types/src/transaction/__tests/bump.valid.vectors.d.ts +0 -5
  1231. package/dist/types/src/transaction/__tests/bump.valid.vectors.d.ts.map +0 -1
  1232. package/dist/types/src/transaction/__tests/tx.invalid.vectors.d.ts +0 -3
  1233. package/dist/types/src/transaction/__tests/tx.invalid.vectors.d.ts.map +0 -1
  1234. package/dist/types/src/transaction/__tests/tx.valid.vectors.d.ts +0 -3
  1235. package/dist/types/src/transaction/__tests/tx.valid.vectors.d.ts.map +0 -1
  1236. package/dist/types/src/transaction/broadcasters/__tests/ARC.test.d.ts +0 -2
  1237. package/dist/types/src/transaction/broadcasters/__tests/ARC.test.d.ts.map +0 -1
  1238. package/dist/types/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.d.ts +0 -2
  1239. package/dist/types/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.d.ts.map +0 -1
  1240. package/dist/types/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.d.ts +0 -2
  1241. package/dist/types/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.d.ts.map +0 -1
  1242. package/dist/types/src/wallet/__tests/CachedKeyDeriver.test.d.ts +0 -2
  1243. package/dist/types/src/wallet/__tests/CachedKeyDeriver.test.d.ts.map +0 -1
  1244. package/dist/types/src/wallet/__tests/KeyDeriver.test.d.ts +0 -2
  1245. package/dist/types/src/wallet/__tests/KeyDeriver.test.d.ts.map +0 -1
  1246. package/dist/types/src/wallet/__tests/ProtoWallet.test.d.ts +0 -2
  1247. package/dist/types/src/wallet/__tests/ProtoWallet.test.d.ts.map +0 -1
  1248. package/dist/types/src/wallet/substrates/__tests/WalletWire.integration.test.d.ts +0 -2
  1249. package/dist/types/src/wallet/substrates/__tests/WalletWire.integration.test.d.ts.map +0 -1
  1250. package/dist/types/src/wallet/substrates/__tests/XDM.test.d.ts +0 -5
  1251. package/dist/types/src/wallet/substrates/__tests/XDM.test.d.ts.map +0 -1
@@ -1,933 +0,0 @@
1
- "use strict";
2
- var __importDefault = (this && this.__importDefault) || function (mod) {
3
- return (mod && mod.__esModule) ? mod : { "default": mod };
4
- };
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const SHIPBroadcaster_1 = __importDefault(require("../../overlay-tools/SHIPBroadcaster"));
7
- const index_1 = require("../../primitives/index");
8
- const index_2 = require("../../transaction/index");
9
- const OverlayAdminTokenTemplate_1 = __importDefault(require("../../overlay-tools/OverlayAdminTokenTemplate"));
10
- const CompletedProtoWallet_1 = require("../../auth/certificates/__tests/CompletedProtoWallet");
11
- const mockFacilitator = {
12
- send: jest.fn()
13
- };
14
- const mockResolver = {
15
- query: jest.fn()
16
- };
17
- describe('SHIPCast', () => {
18
- beforeEach(() => {
19
- mockFacilitator.send.mockReset();
20
- mockResolver.query.mockReset();
21
- });
22
- it('Handles constructor errors', () => {
23
- expect(() => new SHIPBroadcaster_1.default([])).toThrow(new Error('At least one topic is required for broadcast.'));
24
- expect(() => new SHIPBroadcaster_1.default(['badprefix_foo'])).toThrow(new Error('Every topic must start with "tm_".'));
25
- });
26
- it('should broadcast to a single SHIP host found via resolver', async () => {
27
- const shipHostKey = new index_1.PrivateKey(42);
28
- const shipWallet = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey);
29
- const shipLib = new OverlayAdminTokenTemplate_1.default(shipWallet);
30
- const shipScript = await shipLib.lock('SHIP', 'https://shiphost.com', 'tm_foo');
31
- const shipTx = new index_2.Transaction(1, [], [
32
- {
33
- lockingScript: shipScript,
34
- satoshis: 1
35
- }
36
- ], 0);
37
- // Resolver returns one host interested in 'tm_foo' topic
38
- mockResolver.query.mockReturnValueOnce({
39
- type: 'output-list',
40
- outputs: [
41
- {
42
- beef: shipTx.toBEEF(),
43
- outputIndex: 0
44
- }
45
- ]
46
- });
47
- // Host responds successfully
48
- mockFacilitator.send.mockReturnValueOnce({
49
- tm_foo: {
50
- outputsToAdmit: [0],
51
- coinsToRetain: []
52
- }
53
- });
54
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
55
- facilitator: mockFacilitator,
56
- resolver: mockResolver
57
- });
58
- const testTx = new index_2.Transaction(1, [], [], 0);
59
- const response = await b.broadcast(testTx);
60
- expect(response).toEqual({
61
- status: 'success',
62
- txid: testTx.id('hex'),
63
- message: 'Sent to 1 Overlay Services host.'
64
- });
65
- expect(mockResolver.query).toHaveBeenCalledWith({
66
- service: 'ls_ship',
67
- query: {
68
- topics: ['tm_foo']
69
- }
70
- }, 1000);
71
- expect(mockFacilitator.send).toHaveBeenCalledWith('https://shiphost.com', {
72
- beef: testTx.toBEEF(),
73
- topics: ['tm_foo']
74
- });
75
- });
76
- it('should be resilient to malformed or corrupted SHIP data, to the extent possible', async () => {
77
- const shipHostKey = new index_1.PrivateKey(42);
78
- const shipWallet = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey);
79
- const shipLib = new OverlayAdminTokenTemplate_1.default(shipWallet);
80
- // First SHIP is for wrong topic
81
- const shipScript = await shipLib.lock('SHIP', 'https://shiphost.com', 'tm_wrong');
82
- const shipTx = new index_2.Transaction(1, [], [
83
- {
84
- lockingScript: shipScript,
85
- satoshis: 1
86
- }
87
- ], 0);
88
- const shipHostKey2 = new index_1.PrivateKey(43);
89
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
90
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
91
- // Second SHIP is for correct topic
92
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_foo');
93
- const shipTx2 = new index_2.Transaction(1, [], [
94
- {
95
- lockingScript: shipScript2,
96
- satoshis: 1
97
- }
98
- ], 0);
99
- // Resolver returns two hosts, both the correct and the corrupted ones.
100
- mockResolver.query.mockReturnValueOnce({
101
- type: 'output-list',
102
- outputs: [
103
- {
104
- beef: shipTx.toBEEF(),
105
- outputIndex: 0
106
- },
107
- {
108
- beef: shipTx2.toBEEF(),
109
- outputIndex: 0
110
- }
111
- ]
112
- });
113
- // Host responds successfully
114
- mockFacilitator.send.mockReturnValue({
115
- tm_foo: {
116
- outputsToAdmit: [0],
117
- coinsToRetain: []
118
- }
119
- });
120
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
121
- facilitator: mockFacilitator,
122
- resolver: mockResolver
123
- });
124
- const testTx = new index_2.Transaction(1, [], [], 0);
125
- let response = await b.broadcast(testTx);
126
- expect(response).toEqual({
127
- status: 'success',
128
- txid: testTx.id('hex'),
129
- // One SHIP advertisement should be used, but the second one was invalid
130
- message: 'Sent to 1 Overlay Services host.'
131
- });
132
- // Transaction should have been sent to the second host, but the first one was invalid
133
- expect(mockFacilitator.send).toHaveBeenCalledWith('https://shiphost2.com', {
134
- beef: testTx.toBEEF(),
135
- topics: ['tm_foo']
136
- });
137
- mockFacilitator.send.mockClear();
138
- // Resolver returns the wrong type of data
139
- mockResolver.query.mockReturnValueOnce({
140
- type: 'invalid',
141
- bogus: true,
142
- outputs: {
143
- different: 'structure'
144
- }
145
- });
146
- await expect(async () => await b.broadcast(testTx)).rejects.toThrow('SHIP answer is not an output list.');
147
- expect(mockFacilitator.send).not.toHaveBeenCalled();
148
- // Resolver returns the wrong output structure
149
- mockResolver.query.mockReturnValueOnce({
150
- type: 'output-list',
151
- outputs: {
152
- different: 'structure'
153
- }
154
- });
155
- await expect(async () => await b.broadcast(testTx)).rejects.toThrow('answer.outputs is not iterable');
156
- expect(mockFacilitator.send).not.toHaveBeenCalled();
157
- // Resolver returns corrupted BEEF alongside good data
158
- mockResolver.query.mockReturnValueOnce({
159
- type: 'output-list',
160
- outputs: [
161
- {
162
- beef: shipTx.toBEEF(), // Wrong topic
163
- outputIndex: 0
164
- },
165
- {
166
- beef: [0], // corrupted "rotten" BEEF
167
- outputIndex: 4
168
- },
169
- {
170
- beef: shipTx2.toBEEF(),
171
- outputIndex: 1 // Wrong output index
172
- },
173
- {
174
- beef: shipTx2.toBEEF(),
175
- outputIndex: 0 // correct
176
- }
177
- ]
178
- });
179
- response = await b.broadcast(testTx);
180
- expect(response).toEqual({
181
- status: 'success',
182
- txid: testTx.id('hex'),
183
- // One SHIP advertisement should be used, but the second one was invalid
184
- message: 'Sent to 1 Overlay Services host.'
185
- });
186
- // Transaction should have been sent to the second host, but the first one was invalid
187
- expect(mockFacilitator.send).toHaveBeenCalledWith('https://shiphost2.com', {
188
- beef: testTx.toBEEF(),
189
- topics: ['tm_foo']
190
- });
191
- });
192
- it('should fail when transaction cannot be serialized to BEEF', async () => {
193
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
194
- facilitator: mockFacilitator,
195
- resolver: mockResolver
196
- });
197
- const testTx = {
198
- toBEEF: () => {
199
- throw new Error('Cannot serialize to BEEF');
200
- }
201
- };
202
- await expect(b.broadcast(testTx)).rejects.toThrow('Transactions sent via SHIP to Overlay Services must be serializable to BEEF format.');
203
- });
204
- it('should fail when no hosts are interested in the topics', async () => {
205
- // Resolver returns empty output list
206
- mockResolver.query.mockReturnValueOnce({
207
- type: 'output-list',
208
- outputs: []
209
- });
210
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
211
- facilitator: mockFacilitator,
212
- resolver: mockResolver
213
- });
214
- const testTx = new index_2.Transaction(1, [], [], 0);
215
- const result = await b.broadcast(testTx);
216
- expect(result).toEqual({
217
- status: 'error',
218
- code: 'ERR_NO_HOSTS_INTERESTED',
219
- description: 'No hosts are interested in receiving this transaction.'
220
- });
221
- expect(mockResolver.query).toHaveBeenCalledWith({
222
- service: 'ls_ship',
223
- query: {
224
- topics: ['tm_foo']
225
- }
226
- }, 1000);
227
- expect(mockFacilitator.send).not.toHaveBeenCalled();
228
- });
229
- it('should fail when all hosts reject the transaction', async () => {
230
- const shipHostKey = new index_1.PrivateKey(42);
231
- const shipWallet = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey);
232
- const shipLib = new OverlayAdminTokenTemplate_1.default(shipWallet);
233
- const shipScript = await shipLib.lock('SHIP', 'https://shiphost.com', 'tm_foo');
234
- const shipTx = new index_2.Transaction(1, [], [
235
- {
236
- lockingScript: shipScript,
237
- satoshis: 1
238
- }
239
- ], 0);
240
- // Resolver returns one host
241
- mockResolver.query.mockReturnValueOnce({
242
- type: 'output-list',
243
- outputs: [
244
- {
245
- beef: shipTx.toBEEF(),
246
- outputIndex: 0
247
- }
248
- ]
249
- });
250
- // Host fails
251
- mockFacilitator.send.mockImplementationOnce(() => {
252
- throw new Error('Host failed');
253
- });
254
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
255
- facilitator: mockFacilitator,
256
- resolver: mockResolver
257
- });
258
- const testTx = new index_2.Transaction(1, [], [], 0);
259
- const result = await b.broadcast(testTx);
260
- expect(result).toEqual({
261
- status: 'error',
262
- code: 'ERR_ALL_HOSTS_REJECTED',
263
- description: 'All SHIP hosts have rejected the transaction.'
264
- });
265
- expect(mockFacilitator.send).toHaveBeenCalled();
266
- });
267
- it('should fail when required specific hosts are not among interested hosts', async () => {
268
- const shipHostKey = new index_1.PrivateKey(42);
269
- const shipWallet = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey);
270
- const shipLib = new OverlayAdminTokenTemplate_1.default(shipWallet);
271
- const shipScript = await shipLib.lock('SHIP', 'https://shiphost.com', 'tm_foo');
272
- const shipTx = new index_2.Transaction(1, [], [
273
- {
274
- lockingScript: shipScript,
275
- satoshis: 1
276
- }
277
- ], 0);
278
- // Resolver returns one host
279
- mockResolver.query.mockReturnValueOnce({
280
- type: 'output-list',
281
- outputs: [
282
- {
283
- beef: shipTx.toBEEF(),
284
- outputIndex: 0
285
- }
286
- ]
287
- });
288
- // First host acknowledges 'tm_foo', but it's not the right host.
289
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
290
- const steak = {};
291
- for (const topic of topics) {
292
- steak[topic] = {
293
- outputsToAdmit: topic === 'tm_foo' ? [0] : [],
294
- coinsToRetain: []
295
- };
296
- }
297
- return steak;
298
- });
299
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
300
- facilitator: mockFacilitator,
301
- resolver: mockResolver,
302
- requireAcknowledgmentFromSpecificHostsForTopics: {
303
- 'https://anotherhost.com': ['tm_foo']
304
- },
305
- requireAcknowledgmentFromAllHostsForTopics: [],
306
- requireAcknowledgmentFromAnyHostForTopics: []
307
- });
308
- const testTx = new index_2.Transaction(1, [], [], 0);
309
- const response = await b.broadcast(testTx);
310
- expect(response).toEqual({
311
- status: 'error',
312
- code: 'ERR_REQUIRE_ACK_FROM_SPECIFIC_HOSTS_FAILED',
313
- description: 'Specific hosts did not acknowledge the required topics.'
314
- });
315
- });
316
- it('should succeed when all hosts acknowledge all topics (default behavior)', async () => {
317
- const shipHostKey1 = new index_1.PrivateKey(42);
318
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
319
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
320
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
321
- const shipScript1b = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_bar');
322
- const shipTx1 = new index_2.Transaction(1, [], [
323
- {
324
- lockingScript: shipScript1,
325
- satoshis: 1
326
- },
327
- {
328
- lockingScript: shipScript1b,
329
- satoshis: 1
330
- }
331
- ], 0);
332
- const shipHostKey2 = new index_1.PrivateKey(43);
333
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
334
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
335
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_bar');
336
- const shipScript2b = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_foo');
337
- const shipTx2 = new index_2.Transaction(1, [], [
338
- {
339
- lockingScript: shipScript2,
340
- satoshis: 1
341
- },
342
- {
343
- lockingScript: shipScript2b,
344
- satoshis: 1
345
- }
346
- ], 0);
347
- // Resolver returns two hosts
348
- mockResolver.query.mockReturnValueOnce({
349
- type: 'output-list',
350
- outputs: [
351
- { beef: shipTx1.toBEEF(), outputIndex: 0 },
352
- { beef: shipTx1.toBEEF(), outputIndex: 1 },
353
- { beef: shipTx2.toBEEF(), outputIndex: 0 },
354
- { beef: shipTx2.toBEEF(), outputIndex: 1 }
355
- ]
356
- });
357
- // Both hosts acknowledge all topics
358
- mockFacilitator.send.mockImplementation(async (host, { topics }) => {
359
- const steak = {};
360
- for (const topic of topics) {
361
- steak[topic] = {
362
- outputsToAdmit: [0],
363
- coinsToRetain: []
364
- };
365
- }
366
- return steak;
367
- });
368
- const b = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
369
- facilitator: mockFacilitator,
370
- resolver: mockResolver
371
- });
372
- const testTx = new index_2.Transaction(1, [], [], 0);
373
- const response = await b.broadcast(testTx);
374
- expect(response).toEqual({
375
- status: 'success',
376
- txid: testTx.id('hex'),
377
- message: 'Sent to 2 Overlay Services hosts.'
378
- });
379
- expect(mockResolver.query).toHaveBeenCalledWith({
380
- service: 'ls_ship',
381
- query: {
382
- topics: ['tm_foo', 'tm_bar']
383
- }
384
- }, 1000);
385
- expect(mockFacilitator.send).toHaveBeenCalledTimes(2);
386
- });
387
- it('should fail if at least one host does not acknowledge every topic (default behavior)', async () => {
388
- const shipHostKey1 = new index_1.PrivateKey(42);
389
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
390
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
391
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
392
- const shipTx1 = new index_2.Transaction(1, [], [
393
- {
394
- lockingScript: shipScript1,
395
- satoshis: 1
396
- }
397
- ], 0);
398
- const shipHostKey2 = new index_1.PrivateKey(43);
399
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
400
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
401
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_bar');
402
- const shipTx2 = new index_2.Transaction(1, [], [
403
- {
404
- lockingScript: shipScript2,
405
- satoshis: 1
406
- }
407
- ], 0);
408
- // Resolver returns two hosts
409
- mockResolver.query.mockReturnValueOnce({
410
- type: 'output-list',
411
- outputs: [
412
- { beef: shipTx1.toBEEF(), outputIndex: 0 },
413
- { beef: shipTx2.toBEEF(), outputIndex: 0 }
414
- ]
415
- });
416
- // First host acknowledges 'tm_foo'
417
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
418
- const steak = {};
419
- for (const topic of topics) {
420
- steak[topic] = {
421
- outputsToAdmit: [],
422
- coinsToRetain: []
423
- };
424
- }
425
- return steak;
426
- });
427
- // Second host does not acknowledge any topics
428
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
429
- const steak = {};
430
- for (const topic of topics) {
431
- steak[topic] = {
432
- outputsToAdmit: [],
433
- coinsToRetain: []
434
- };
435
- }
436
- return steak;
437
- });
438
- const b = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
439
- facilitator: mockFacilitator,
440
- resolver: mockResolver
441
- });
442
- const testTx = new index_2.Transaction(1, [], [], 0);
443
- const response = await b.broadcast(testTx);
444
- expect(response).toEqual({
445
- status: 'error',
446
- code: 'ERR_REQUIRE_ACK_FROM_ANY_HOST_FAILED',
447
- description: 'No host acknowledged the required topics.'
448
- });
449
- });
450
- it('should succeed when at least one host acknowledges required topics with requireAcknowledgmentFromAnyHostForTopics set to "any"', async () => {
451
- const shipHostKey1 = new index_1.PrivateKey(42);
452
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
453
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
454
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
455
- const shipTx1 = new index_2.Transaction(1, [], [
456
- {
457
- lockingScript: shipScript1,
458
- satoshis: 1
459
- }
460
- ], 0);
461
- const shipHostKey2 = new index_1.PrivateKey(43);
462
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
463
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
464
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_bar');
465
- const shipTx2 = new index_2.Transaction(1, [], [
466
- {
467
- lockingScript: shipScript2,
468
- satoshis: 1
469
- }
470
- ], 0);
471
- // Resolver returns two hosts
472
- mockResolver.query.mockReturnValueOnce({
473
- type: 'output-list',
474
- outputs: [
475
- { beef: shipTx1.toBEEF(), outputIndex: 0 },
476
- { beef: shipTx2.toBEEF(), outputIndex: 0 }
477
- ]
478
- });
479
- // First host acknowledges no topics
480
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
481
- const steak = {};
482
- for (const topic of topics) {
483
- steak[topic] = {
484
- outputsToAdmit: [],
485
- coinsToRetain: []
486
- };
487
- }
488
- return steak;
489
- });
490
- // Second host acknowledges 'tm_bar'
491
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
492
- const steak = {};
493
- for (const topic of topics) {
494
- steak[topic] = {
495
- outputsToAdmit: topic === 'tm_bar' ? [0] : [],
496
- coinsToRetain: []
497
- };
498
- }
499
- return steak;
500
- });
501
- const b = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
502
- facilitator: mockFacilitator,
503
- resolver: mockResolver,
504
- requireAcknowledgmentFromAnyHostForTopics: 'any',
505
- requireAcknowledgmentFromAllHostsForTopics: []
506
- });
507
- const testTx = new index_2.Transaction(1, [], [], 0);
508
- const response = await b.broadcast(testTx);
509
- expect(response).toEqual({
510
- status: 'success',
511
- txid: testTx.id('hex'),
512
- message: 'Sent to 2 Overlay Services hosts.'
513
- });
514
- });
515
- it('should fail when no hosts acknowledge required topics with requireAcknowledgmentFromAnyHostForTopics set to "any"', async () => {
516
- const shipHostKey1 = new index_1.PrivateKey(42);
517
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
518
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
519
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
520
- const shipTx1 = new index_2.Transaction(1, [], [
521
- {
522
- lockingScript: shipScript1,
523
- satoshis: 1
524
- }
525
- ], 0);
526
- // Resolver returns one host
527
- mockResolver.query.mockReturnValueOnce({
528
- type: 'output-list',
529
- outputs: [{ beef: shipTx1.toBEEF(), outputIndex: 0 }]
530
- });
531
- // Host acknowledges no topics
532
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
533
- const steak = {};
534
- for (const topic of topics) {
535
- steak[topic] = {
536
- outputsToAdmit: [],
537
- coinsToRetain: []
538
- };
539
- }
540
- return steak;
541
- });
542
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
543
- facilitator: mockFacilitator,
544
- resolver: mockResolver,
545
- requireAcknowledgmentFromAnyHostForTopics: 'any',
546
- requireAcknowledgmentFromAllHostsForTopics: []
547
- });
548
- const testTx = new index_2.Transaction(1, [], [], 0);
549
- const response = await b.broadcast(testTx);
550
- expect(response).toEqual({
551
- status: 'error',
552
- code: 'ERR_REQUIRE_ACK_FROM_ANY_HOST_FAILED',
553
- description: 'No host acknowledged the required topics.'
554
- });
555
- });
556
- it('should succeed when specific hosts acknowledge required topics', async () => {
557
- const shipHostKey1 = new index_1.PrivateKey(42);
558
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
559
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
560
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
561
- const shipTx1 = new index_2.Transaction(1, [], [
562
- {
563
- lockingScript: shipScript1,
564
- satoshis: 1
565
- }
566
- ], 0);
567
- const shipHostKey2 = new index_1.PrivateKey(43);
568
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
569
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
570
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_bar');
571
- const shipTx2 = new index_2.Transaction(1, [], [
572
- {
573
- lockingScript: shipScript2,
574
- satoshis: 1
575
- }
576
- ], 0);
577
- // Resolver returns two hosts
578
- mockResolver.query.mockReturnValueOnce({
579
- type: 'output-list',
580
- outputs: [
581
- { beef: shipTx1.toBEEF(), outputIndex: 0 },
582
- { beef: shipTx2.toBEEF(), outputIndex: 0 }
583
- ]
584
- });
585
- // First host acknowledges 'tm_foo'
586
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
587
- const steak = {};
588
- for (const topic of topics) {
589
- steak[topic] = {
590
- outputsToAdmit: topic === 'tm_foo' ? [0] : [],
591
- coinsToRetain: []
592
- };
593
- }
594
- return steak;
595
- });
596
- // Second host does not acknowledge 'tm_bar'
597
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
598
- const steak = {};
599
- for (const topic of topics) {
600
- steak[topic] = {
601
- outputsToAdmit: [],
602
- coinsToRetain: []
603
- };
604
- }
605
- return steak;
606
- });
607
- const b = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
608
- facilitator: mockFacilitator,
609
- resolver: mockResolver,
610
- requireAcknowledgmentFromSpecificHostsForTopics: {
611
- 'https://shiphost1.com': ['tm_foo']
612
- },
613
- requireAcknowledgmentFromAllHostsForTopics: [],
614
- requireAcknowledgmentFromAnyHostForTopics: []
615
- });
616
- const testTx = new index_2.Transaction(1, [], [], 0);
617
- const response = await b.broadcast(testTx);
618
- expect(response).toEqual({
619
- status: 'success',
620
- txid: testTx.id('hex'),
621
- message: 'Sent to 2 Overlay Services hosts.'
622
- });
623
- });
624
- it('should succeed when interested hosts only remove coins in a transaction broadcast', async () => {
625
- const shipHostKey1 = new index_1.PrivateKey(42);
626
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
627
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
628
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
629
- const shipTx1 = new index_2.Transaction(1, [], [
630
- {
631
- lockingScript: shipScript1,
632
- satoshis: 1
633
- }
634
- ], 0);
635
- const shipHostKey2 = new index_1.PrivateKey(43);
636
- const shipWallet2 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey2);
637
- const shipLib2 = new OverlayAdminTokenTemplate_1.default(shipWallet2);
638
- const shipScript2 = await shipLib2.lock('SHIP', 'https://shiphost2.com', 'tm_bar');
639
- const shipTx2 = new index_2.Transaction(1, [], [
640
- {
641
- lockingScript: shipScript2,
642
- satoshis: 1
643
- }
644
- ], 0);
645
- // Resolver returns two hosts
646
- mockResolver.query.mockReturnValueOnce({
647
- type: 'output-list',
648
- outputs: [
649
- { beef: shipTx1.toBEEF(), outputIndex: 0 },
650
- { beef: shipTx2.toBEEF(), outputIndex: 0 }
651
- ]
652
- });
653
- // First host acknowledges 'tm_foo' with coinsRemoved
654
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
655
- const steak = {};
656
- for (const topic of topics) {
657
- steak[topic] = {
658
- outputsToAdmit: [],
659
- coinsToRetain: [],
660
- coinsRemoved: topic === 'tm_foo' ? [0] : []
661
- };
662
- }
663
- return steak;
664
- });
665
- // Second host does not acknowledge 'tm_bar'
666
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
667
- const steak = {};
668
- for (const topic of topics) {
669
- steak[topic] = {
670
- outputsToAdmit: [],
671
- coinsToRetain: [],
672
- coinsRemoved: []
673
- };
674
- }
675
- return steak;
676
- });
677
- const b = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
678
- facilitator: mockFacilitator,
679
- resolver: mockResolver,
680
- requireAcknowledgmentFromSpecificHostsForTopics: {
681
- 'https://shiphost1.com': ['tm_foo']
682
- },
683
- requireAcknowledgmentFromAllHostsForTopics: [],
684
- requireAcknowledgmentFromAnyHostForTopics: []
685
- });
686
- const testTx = new index_2.Transaction(1, [], [], 0);
687
- const response = await b.broadcast(testTx);
688
- expect(response).toEqual({
689
- status: 'success',
690
- txid: testTx.id('hex'),
691
- message: 'Sent to 2 Overlay Services hosts.'
692
- });
693
- // Verify the resolver was queried correctly
694
- expect(mockResolver.query).toHaveBeenCalledWith({
695
- service: 'ls_ship',
696
- query: {
697
- topics: ['tm_foo', 'tm_bar']
698
- }
699
- }, 1000);
700
- });
701
- it('should fail when specific hosts do not acknowledge required topics', async () => {
702
- const shipHostKey1 = new index_1.PrivateKey(42);
703
- const shipWallet1 = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey1);
704
- const shipLib1 = new OverlayAdminTokenTemplate_1.default(shipWallet1);
705
- const shipScript1 = await shipLib1.lock('SHIP', 'https://shiphost1.com', 'tm_foo');
706
- const shipTx1 = new index_2.Transaction(1, [], [
707
- {
708
- lockingScript: shipScript1,
709
- satoshis: 1
710
- }
711
- ], 0);
712
- // Resolver returns one host
713
- mockResolver.query.mockReturnValueOnce({
714
- type: 'output-list',
715
- outputs: [{ beef: shipTx1.toBEEF(), outputIndex: 0 }]
716
- });
717
- // Host does not acknowledge 'tm_foo'
718
- mockFacilitator.send.mockImplementationOnce(async (host, { beef, topics }) => {
719
- const steak = {};
720
- for (const topic of topics) {
721
- steak[topic] = {
722
- outputsToAdmit: [],
723
- coinsToRetain: []
724
- };
725
- }
726
- return steak;
727
- });
728
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
729
- facilitator: mockFacilitator,
730
- resolver: mockResolver,
731
- requireAcknowledgmentFromSpecificHostsForTopics: {
732
- 'https://shiphost1.com': ['tm_foo']
733
- },
734
- requireAcknowledgmentFromAllHostsForTopics: [],
735
- requireAcknowledgmentFromAnyHostForTopics: []
736
- });
737
- const testTx = new index_2.Transaction(1, [], [], 0);
738
- const response = await b.broadcast(testTx);
739
- expect(response).toEqual({
740
- status: 'error',
741
- code: 'ERR_REQUIRE_ACK_FROM_SPECIFIC_HOSTS_FAILED',
742
- description: 'Specific hosts did not acknowledge the required topics.'
743
- });
744
- });
745
- it('should handle invalid acknowledgments from hosts gracefully', async () => {
746
- const shipHostKey = new index_1.PrivateKey(42);
747
- const shipWallet = new CompletedProtoWallet_1.CompletedProtoWallet(shipHostKey);
748
- const shipLib = new OverlayAdminTokenTemplate_1.default(shipWallet);
749
- const shipScript = await shipLib.lock('SHIP', 'https://shiphost.com', 'tm_foo');
750
- const shipTx = new index_2.Transaction(1, [], [
751
- {
752
- lockingScript: shipScript,
753
- satoshis: 1
754
- }
755
- ], 0);
756
- // Resolver returns one host
757
- mockResolver.query.mockReturnValueOnce({
758
- type: 'output-list',
759
- outputs: [
760
- {
761
- beef: shipTx.toBEEF(),
762
- outputIndex: 0
763
- }
764
- ]
765
- });
766
- // Host returns invalid acknowledgment
767
- mockFacilitator.send.mockReturnValueOnce(null);
768
- const b = new SHIPBroadcaster_1.default(['tm_foo'], {
769
- facilitator: mockFacilitator,
770
- resolver: mockResolver
771
- });
772
- const testTx = new index_2.Transaction(1, [], [], 0);
773
- const response = await b.broadcast(testTx);
774
- // Since the host responded (successfully in terms of HTTP), but with invalid data, we should consider it a failure
775
- expect(response).toEqual({
776
- status: 'error',
777
- code: 'ERR_ALL_HOSTS_REJECTED',
778
- description: 'All SHIP hosts have rejected the transaction.'
779
- });
780
- });
781
- describe('SHIPCast private methods', () => {
782
- let shipCast;
783
- beforeEach(() => {
784
- shipCast = new SHIPBroadcaster_1.default(['tm_foo', 'tm_bar'], {
785
- facilitator: mockFacilitator,
786
- resolver: mockResolver
787
- });
788
- });
789
- describe('checkAcknowledgmentFromAllHosts', () => {
790
- it('should return true when all hosts acknowledge all required topics', () => {
791
- const hostAcknowledgments = {
792
- 'https://host1.com': new Set(['tm_foo', 'tm_bar']),
793
- 'https://host2.com': new Set(['tm_foo', 'tm_bar'])
794
- };
795
- const result = shipCast.checkAcknowledgmentFromAllHosts(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'all');
796
- expect(result).toBe(true);
797
- });
798
- it('should return false when any host does not acknowledge all required topics', () => {
799
- const hostAcknowledgments = {
800
- 'https://host1.com': new Set(['tm_foo']),
801
- 'https://host2.com': new Set(['tm_foo', 'tm_bar'])
802
- };
803
- const result = shipCast.checkAcknowledgmentFromAllHosts(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'all');
804
- expect(result).toBe(false);
805
- });
806
- it('should return true when all hosts acknowledge any of the required topics', () => {
807
- const hostAcknowledgments = {
808
- 'https://host1.com': new Set(['tm_foo']),
809
- 'https://host2.com': new Set(['tm_bar'])
810
- };
811
- const result = shipCast.checkAcknowledgmentFromAllHosts(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'any');
812
- expect(result).toBe(true);
813
- });
814
- it('should return false when any host does not acknowledge any of the required topics', () => {
815
- const hostAcknowledgments = {
816
- 'https://host1.com': new Set(),
817
- 'https://host2.com': new Set(['tm_bar'])
818
- };
819
- const result = shipCast.checkAcknowledgmentFromAllHosts(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'any');
820
- expect(result).toBe(false);
821
- });
822
- });
823
- describe('checkAcknowledgmentFromAnyHost', () => {
824
- it('should return true when at least one host acknowledges all required topics', () => {
825
- const hostAcknowledgments = {
826
- 'https://host1.com': new Set(['tm_foo', 'tm_bar']),
827
- 'https://host2.com': new Set(['tm_foo'])
828
- };
829
- const result = shipCast.checkAcknowledgmentFromAnyHost(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'all');
830
- expect(result).toBe(true);
831
- });
832
- it('should return false when no host acknowledges all required topics', () => {
833
- const hostAcknowledgments = {
834
- 'https://host1.com': new Set(['tm_foo']),
835
- 'https://host2.com': new Set(['tm_bar'])
836
- };
837
- const result = shipCast.checkAcknowledgmentFromAnyHost(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'all');
838
- expect(result).toBe(false);
839
- });
840
- it('should return true when at least one host acknowledges any of the required topics', () => {
841
- const hostAcknowledgments = {
842
- 'https://host1.com': new Set(['tm_foo']),
843
- 'https://host2.com': new Set()
844
- };
845
- const result = shipCast.checkAcknowledgmentFromAnyHost(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'any');
846
- expect(result).toBe(true);
847
- });
848
- it('should return false when no host acknowledges any of the required topics', () => {
849
- const hostAcknowledgments = {
850
- 'https://host1.com': new Set(),
851
- 'https://host2.com': new Set()
852
- };
853
- const result = shipCast.checkAcknowledgmentFromAnyHost(hostAcknowledgments, ['tm_foo', 'tm_bar'], 'any');
854
- expect(result).toBe(false);
855
- });
856
- });
857
- describe('checkAcknowledgmentFromSpecificHosts', () => {
858
- it('should return true when specific hosts acknowledge all required topics', () => {
859
- const hostAcknowledgments = {
860
- 'https://host1.com': new Set(['tm_foo', 'tm_bar']),
861
- 'https://host2.com': new Set(['tm_foo'])
862
- };
863
- const requirements = {
864
- 'https://host1.com': ['tm_foo', 'tm_bar']
865
- };
866
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
867
- expect(result).toBe(true);
868
- });
869
- it('should return false when specific hosts do not acknowledge all required topics', () => {
870
- const hostAcknowledgments = {
871
- 'https://host1.com': new Set(['tm_foo']),
872
- 'https://host2.com': new Set(['tm_bar'])
873
- };
874
- const requirements = {
875
- 'https://host1.com': ['tm_foo', 'tm_bar']
876
- };
877
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
878
- expect(result).toBe(false);
879
- });
880
- it('should return true when specific hosts acknowledge any of the required topics', () => {
881
- const hostAcknowledgments = {
882
- 'https://host1.com': new Set(['tm_foo']),
883
- 'https://host2.com': new Set(['tm_bar'])
884
- };
885
- const requirements = {
886
- 'https://host1.com': 'any'
887
- };
888
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
889
- expect(result).toBe(true);
890
- });
891
- it('should return false when specific hosts do not acknowledge any of the required topics', () => {
892
- const hostAcknowledgments = {
893
- 'https://host1.com': new Set(),
894
- 'https://host2.com': new Set(['tm_bar'])
895
- };
896
- const requirements = {
897
- 'https://host1.com': 'any'
898
- };
899
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
900
- expect(result).toBe(false);
901
- });
902
- it('should handle multiple hosts with different requirements', () => {
903
- const hostAcknowledgments = {
904
- 'https://host1.com': new Set(['tm_foo']),
905
- 'https://host2.com': new Set(['tm_bar']),
906
- 'https://host3.com': new Set(['tm_foo', 'tm_bar'])
907
- };
908
- const requirements = {
909
- 'https://host1.com': ['tm_foo'],
910
- 'https://host2.com': 'any',
911
- 'https://host3.com': 'all'
912
- };
913
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
914
- expect(result).toBe(true);
915
- });
916
- it('should return false if any specific host fails to meet its requirement', () => {
917
- const hostAcknowledgments = {
918
- 'https://host1.com': new Set(['tm_foo']),
919
- 'https://host2.com': new Set(),
920
- 'https://host3.com': new Set(['tm_foo'])
921
- };
922
- const requirements = {
923
- 'https://host1.com': ['tm_foo'],
924
- 'https://host2.com': 'any',
925
- 'https://host3.com': ['tm_foo', 'tm_bar']
926
- };
927
- const result = shipCast.checkAcknowledgmentFromSpecificHosts(hostAcknowledgments, requirements);
928
- expect(result).toBe(false);
929
- });
930
- });
931
- });
932
- });
933
- //# sourceMappingURL=SHIPBroadcaster.test.js.map