@bsv/sdk 1.6.7 → 1.6.9

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 (611) hide show
  1. package/dist/cjs/package.json +4 -4
  2. package/dist/cjs/src/auth/__tests/Peer.test.js +446 -0
  3. package/dist/cjs/src/auth/__tests/Peer.test.js.map +1 -0
  4. package/dist/cjs/src/auth/__tests/SessionManager.test.js +69 -0
  5. package/dist/cjs/src/auth/__tests/SessionManager.test.js.map +1 -0
  6. package/dist/cjs/src/auth/certificates/__tests/Certificate.test.js +182 -0
  7. package/dist/cjs/src/auth/certificates/__tests/Certificate.test.js.map +1 -0
  8. package/dist/cjs/src/auth/certificates/__tests/MasterCertificate.test.js +184 -0
  9. package/dist/cjs/src/auth/certificates/__tests/MasterCertificate.test.js.map +1 -0
  10. package/dist/cjs/src/auth/certificates/__tests/VerifiableCertificate.test.js +75 -0
  11. package/dist/cjs/src/auth/certificates/__tests/VerifiableCertificate.test.js.map +1 -0
  12. package/dist/cjs/src/auth/utils/__tests/cryptononce.test.js +101 -0
  13. package/dist/cjs/src/auth/utils/__tests/cryptononce.test.js.map +1 -0
  14. package/dist/cjs/src/auth/utils/__tests/getVerifiableCertificates.test.js +106 -0
  15. package/dist/cjs/src/auth/utils/__tests/getVerifiableCertificates.test.js.map +1 -0
  16. package/dist/cjs/src/auth/utils/__tests/validateCertificates.test.js +111 -0
  17. package/dist/cjs/src/auth/utils/__tests/validateCertificates.test.js.map +1 -0
  18. package/dist/cjs/src/auth/utils/certificateHelpers.js +51 -0
  19. package/dist/cjs/src/auth/utils/certificateHelpers.js.map +1 -0
  20. package/dist/cjs/src/compat/__tests/BSM.test.js +69 -0
  21. package/dist/cjs/src/compat/__tests/BSM.test.js.map +1 -0
  22. package/dist/cjs/src/compat/__tests/ECIES.test.js +115 -0
  23. package/dist/cjs/src/compat/__tests/ECIES.test.js.map +1 -0
  24. package/dist/cjs/src/compat/__tests/HD.test.js +336 -0
  25. package/dist/cjs/src/compat/__tests/HD.test.js.map +1 -0
  26. package/dist/cjs/src/compat/__tests/Mnemonic.test.js +150 -0
  27. package/dist/cjs/src/compat/__tests/Mnemonic.test.js.map +1 -0
  28. package/dist/cjs/src/compat/__tests/Mnemonic.vectors.js +175 -0
  29. package/dist/cjs/src/compat/__tests/Mnemonic.vectors.js.map +1 -0
  30. package/dist/cjs/src/messages/__tests/EncryptedMessage.test.js +57 -0
  31. package/dist/cjs/src/messages/__tests/EncryptedMessage.test.js.map +1 -0
  32. package/dist/cjs/src/messages/__tests/SignedMessage.test.js +52 -0
  33. package/dist/cjs/src/messages/__tests/SignedMessage.test.js.map +1 -0
  34. package/dist/cjs/src/overlay-tools/__tests/LookupResolver.test.js +1471 -0
  35. package/dist/cjs/src/overlay-tools/__tests/LookupResolver.test.js.map +1 -0
  36. package/dist/cjs/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js +78 -0
  37. package/dist/cjs/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js.map +1 -0
  38. package/dist/cjs/src/overlay-tools/__tests/SHIPBroadcaster.test.js +933 -0
  39. package/dist/cjs/src/overlay-tools/__tests/SHIPBroadcaster.test.js.map +1 -0
  40. package/dist/cjs/src/primitives/__tests/AESGCM.test.js +248 -0
  41. package/dist/cjs/src/primitives/__tests/AESGCM.test.js.map +1 -0
  42. package/dist/cjs/src/primitives/__tests/BRC42.private.vectors.js +36 -0
  43. package/dist/cjs/src/primitives/__tests/BRC42.private.vectors.js.map +1 -0
  44. package/dist/cjs/src/primitives/__tests/BRC42.public.vectors.js +36 -0
  45. package/dist/cjs/src/primitives/__tests/BRC42.public.vectors.js.map +1 -0
  46. package/dist/cjs/src/primitives/__tests/BigNumber.arithmatic.test.js +501 -0
  47. package/dist/cjs/src/primitives/__tests/BigNumber.arithmatic.test.js.map +1 -0
  48. package/dist/cjs/src/primitives/__tests/BigNumber.binary.test.js +185 -0
  49. package/dist/cjs/src/primitives/__tests/BigNumber.binary.test.js.map +1 -0
  50. package/dist/cjs/src/primitives/__tests/BigNumber.constructor.test.js +149 -0
  51. package/dist/cjs/src/primitives/__tests/BigNumber.constructor.test.js.map +1 -0
  52. package/dist/cjs/src/primitives/__tests/BigNumber.dhGroup.test.js +23 -0
  53. package/dist/cjs/src/primitives/__tests/BigNumber.dhGroup.test.js.map +1 -0
  54. package/dist/cjs/src/primitives/__tests/BigNumber.fixtures.js +268 -0
  55. package/dist/cjs/src/primitives/__tests/BigNumber.fixtures.js.map +1 -0
  56. package/dist/cjs/src/primitives/__tests/BigNumber.serializers.test.js +147 -0
  57. package/dist/cjs/src/primitives/__tests/BigNumber.serializers.test.js.map +1 -0
  58. package/dist/cjs/src/primitives/__tests/BigNumber.utils.test.js +322 -0
  59. package/dist/cjs/src/primitives/__tests/BigNumber.utils.test.js.map +1 -0
  60. package/dist/cjs/src/primitives/__tests/Curve.unit.test.js +145 -0
  61. package/dist/cjs/src/primitives/__tests/Curve.unit.test.js.map +1 -0
  62. package/dist/cjs/src/primitives/__tests/DRBG.test.js +22 -0
  63. package/dist/cjs/src/primitives/__tests/DRBG.test.js.map +1 -0
  64. package/dist/cjs/src/primitives/__tests/DRBG.vectors.js +170 -0
  65. package/dist/cjs/src/primitives/__tests/DRBG.vectors.js.map +1 -0
  66. package/dist/cjs/src/primitives/__tests/ECDH.test.js +34 -0
  67. package/dist/cjs/src/primitives/__tests/ECDH.test.js.map +1 -0
  68. package/dist/cjs/src/primitives/__tests/ECDSA.test.js +89 -0
  69. package/dist/cjs/src/primitives/__tests/ECDSA.test.js.map +1 -0
  70. package/dist/cjs/src/primitives/__tests/HMAC.test.js +60 -0
  71. package/dist/cjs/src/primitives/__tests/HMAC.test.js.map +1 -0
  72. package/dist/cjs/src/primitives/__tests/Hash.test.js +159 -0
  73. package/dist/cjs/src/primitives/__tests/Hash.test.js.map +1 -0
  74. package/dist/cjs/src/primitives/__tests/PBKDF2.vectors.js +122 -0
  75. package/dist/cjs/src/primitives/__tests/PBKDF2.vectors.js.map +1 -0
  76. package/dist/cjs/src/primitives/__tests/PrivateKey.split.test.js +105 -0
  77. package/dist/cjs/src/primitives/__tests/PrivateKey.split.test.js.map +1 -0
  78. package/dist/cjs/src/primitives/__tests/PrivateKey.test.js +90 -0
  79. package/dist/cjs/src/primitives/__tests/PrivateKey.test.js.map +1 -0
  80. package/dist/cjs/src/primitives/__tests/PublicKey.test.js +83 -0
  81. package/dist/cjs/src/primitives/__tests/PublicKey.test.js.map +1 -0
  82. package/dist/cjs/src/primitives/__tests/Random.test.js +19 -0
  83. package/dist/cjs/src/primitives/__tests/Random.test.js.map +1 -0
  84. package/dist/cjs/src/primitives/__tests/Reader.test.js +282 -0
  85. package/dist/cjs/src/primitives/__tests/Reader.test.js.map +1 -0
  86. package/dist/cjs/src/primitives/__tests/ReductionContext.test.js +224 -0
  87. package/dist/cjs/src/primitives/__tests/ReductionContext.test.js.map +1 -0
  88. package/dist/cjs/src/primitives/__tests/Schnorr.test.js +213 -0
  89. package/dist/cjs/src/primitives/__tests/Schnorr.test.js.map +1 -0
  90. package/dist/cjs/src/primitives/__tests/SymmetricKey.test.js +51 -0
  91. package/dist/cjs/src/primitives/__tests/SymmetricKey.test.js.map +1 -0
  92. package/dist/cjs/src/primitives/__tests/SymmetricKey.vectors.js +43 -0
  93. package/dist/cjs/src/primitives/__tests/SymmetricKey.vectors.js.map +1 -0
  94. package/dist/cjs/src/primitives/__tests/Writer.test.js +176 -0
  95. package/dist/cjs/src/primitives/__tests/Writer.test.js.map +1 -0
  96. package/dist/cjs/src/primitives/__tests/bug-31.test.js +32 -0
  97. package/dist/cjs/src/primitives/__tests/bug-31.test.js.map +1 -0
  98. package/dist/cjs/src/primitives/__tests/sighash.vectors.js +3506 -0
  99. package/dist/cjs/src/primitives/__tests/sighash.vectors.js.map +1 -0
  100. package/dist/cjs/src/primitives/__tests/utils.test.js +110 -0
  101. package/dist/cjs/src/primitives/__tests/utils.test.js.map +1 -0
  102. package/dist/cjs/src/primitives/utils.js +18 -2
  103. package/dist/cjs/src/primitives/utils.js.map +1 -1
  104. package/dist/cjs/src/script/__tests/Script.test.js +347 -0
  105. package/dist/cjs/src/script/__tests/Script.test.js.map +1 -0
  106. package/dist/cjs/src/script/__tests/Spend.test.js +282 -0
  107. package/dist/cjs/src/script/__tests/Spend.test.js.map +1 -0
  108. package/dist/cjs/src/script/__tests/SpendComplex.test.js +52 -0
  109. package/dist/cjs/src/script/__tests/SpendComplex.test.js.map +1 -0
  110. package/dist/cjs/src/script/__tests/script.invalid.vectors.js +2370 -0
  111. package/dist/cjs/src/script/__tests/script.invalid.vectors.js.map +1 -0
  112. package/dist/cjs/src/script/__tests/script.valid.vectors.js +1181 -0
  113. package/dist/cjs/src/script/__tests/script.valid.vectors.js.map +1 -0
  114. package/dist/cjs/src/script/__tests/spend.valid.vectors.js +2298 -0
  115. package/dist/cjs/src/script/__tests/spend.valid.vectors.js.map +1 -0
  116. package/dist/cjs/src/script/templates/__tests/PushDrop.test.js +161 -0
  117. package/dist/cjs/src/script/templates/__tests/PushDrop.test.js.map +1 -0
  118. package/dist/cjs/src/totp/__tests/totp.test.js +67 -0
  119. package/dist/cjs/src/totp/__tests/totp.test.js.map +1 -0
  120. package/dist/cjs/src/transaction/__tests/Beef.test.js +393 -0
  121. package/dist/cjs/src/transaction/__tests/Beef.test.js.map +1 -0
  122. package/dist/cjs/src/transaction/__tests/MerklePath.test.js +209 -0
  123. package/dist/cjs/src/transaction/__tests/MerklePath.test.js.map +1 -0
  124. package/dist/cjs/src/transaction/__tests/Transaction.benchmarks.test.js +219 -0
  125. package/dist/cjs/src/transaction/__tests/Transaction.benchmarks.test.js.map +1 -0
  126. package/dist/cjs/src/transaction/__tests/Transaction.test.js +1073 -0
  127. package/dist/cjs/src/transaction/__tests/Transaction.test.js.map +1 -0
  128. package/dist/cjs/src/transaction/__tests/bigtx.vectors.js +7 -0
  129. package/dist/cjs/src/transaction/__tests/bigtx.vectors.js.map +1 -0
  130. package/dist/cjs/src/transaction/__tests/bump.invalid.vectors.js +11 -0
  131. package/dist/cjs/src/transaction/__tests/bump.invalid.vectors.js.map +1 -0
  132. package/dist/cjs/src/transaction/__tests/bump.valid.vectors.js +7 -0
  133. package/dist/cjs/src/transaction/__tests/bump.valid.vectors.js.map +1 -0
  134. package/dist/cjs/src/transaction/__tests/tx.invalid.vectors.js +230 -0
  135. package/dist/cjs/src/transaction/__tests/tx.invalid.vectors.js.map +1 -0
  136. package/dist/cjs/src/transaction/__tests/tx.valid.vectors.js +296 -0
  137. package/dist/cjs/src/transaction/__tests/tx.valid.vectors.js.map +1 -0
  138. package/dist/cjs/src/transaction/broadcasters/__tests/ARC.test.js +246 -0
  139. package/dist/cjs/src/transaction/broadcasters/__tests/ARC.test.js.map +1 -0
  140. package/dist/cjs/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js +148 -0
  141. package/dist/cjs/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js.map +1 -0
  142. package/dist/cjs/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js +155 -0
  143. package/dist/cjs/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js.map +1 -0
  144. package/dist/cjs/src/wallet/ScriptTemplateSABPPP.js +39 -0
  145. package/dist/cjs/src/wallet/ScriptTemplateSABPPP.js.map +1 -0
  146. package/dist/cjs/src/wallet/WalletSigner.js +260 -0
  147. package/dist/cjs/src/wallet/WalletSigner.js.map +1 -0
  148. package/dist/cjs/src/wallet/__tests/CachedKeyDeriver.test.js +269 -0
  149. package/dist/cjs/src/wallet/__tests/CachedKeyDeriver.test.js.map +1 -0
  150. package/dist/cjs/src/wallet/__tests/KeyDeriver.test.js +114 -0
  151. package/dist/cjs/src/wallet/__tests/KeyDeriver.test.js.map +1 -0
  152. package/dist/cjs/src/wallet/__tests/ProtoWallet.test.js +475 -0
  153. package/dist/cjs/src/wallet/__tests/ProtoWallet.test.js.map +1 -0
  154. package/dist/cjs/src/wallet/createActionSdk.js +230 -0
  155. package/dist/cjs/src/wallet/createActionSdk.js.map +1 -0
  156. package/dist/cjs/src/wallet/sdk/CachedKeyDeriver.js +174 -0
  157. package/dist/cjs/src/wallet/sdk/CachedKeyDeriver.js.map +1 -0
  158. package/dist/cjs/src/wallet/sdk/CertOps.js +181 -0
  159. package/dist/cjs/src/wallet/sdk/CertOps.js.map +1 -0
  160. package/dist/cjs/src/wallet/sdk/Certificate.js +162 -0
  161. package/dist/cjs/src/wallet/sdk/Certificate.js.map +1 -0
  162. package/dist/cjs/src/wallet/sdk/KeyDeriver.js +176 -0
  163. package/dist/cjs/src/wallet/sdk/KeyDeriver.js.map +1 -0
  164. package/dist/cjs/src/wallet/sdk/ProtoWallet.js +75 -0
  165. package/dist/cjs/src/wallet/sdk/ProtoWallet.js.map +1 -0
  166. package/dist/cjs/src/wallet/sdk/StorageSyncReader.js +3 -0
  167. package/dist/cjs/src/wallet/sdk/StorageSyncReader.js.map +1 -0
  168. package/dist/cjs/src/wallet/sdk/WERR_errors.js +107 -0
  169. package/dist/cjs/src/wallet/sdk/WERR_errors.js.map +1 -0
  170. package/dist/cjs/src/wallet/sdk/Wallet.interfaces.js +3 -0
  171. package/dist/cjs/src/wallet/sdk/Wallet.interfaces.js.map +1 -0
  172. package/dist/cjs/src/wallet/sdk/WalletCrypto.js +171 -0
  173. package/dist/cjs/src/wallet/sdk/WalletCrypto.js.map +1 -0
  174. package/dist/cjs/src/wallet/sdk/WalletError.js +103 -0
  175. package/dist/cjs/src/wallet/sdk/WalletError.js.map +1 -0
  176. package/dist/cjs/src/wallet/sdk/WalletServices.interfaces.js +3 -0
  177. package/dist/cjs/src/wallet/sdk/WalletServices.interfaces.js.map +1 -0
  178. package/dist/cjs/src/wallet/sdk/WalletSigner.interfaces.js +3 -0
  179. package/dist/cjs/src/wallet/sdk/WalletSigner.interfaces.js.map +1 -0
  180. package/dist/cjs/src/wallet/sdk/WalletStorage.interfaces.js +3 -0
  181. package/dist/cjs/src/wallet/sdk/WalletStorage.interfaces.js.map +1 -0
  182. package/dist/cjs/src/wallet/sdk/index.js +31 -0
  183. package/dist/cjs/src/wallet/sdk/index.js.map +1 -0
  184. package/dist/cjs/src/wallet/sdk/types.js +11 -0
  185. package/dist/cjs/src/wallet/sdk/types.js.map +1 -0
  186. package/dist/cjs/src/wallet/sdk/validationHelpers.js +601 -0
  187. package/dist/cjs/src/wallet/sdk/validationHelpers.js.map +1 -0
  188. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js +11 -3
  189. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
  190. package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js +1 -1
  191. package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
  192. package/dist/cjs/src/wallet/substrates/__tests/WalletWire.integration.test.js +1962 -0
  193. package/dist/cjs/src/wallet/substrates/__tests/WalletWire.integration.test.js.map +1 -0
  194. package/dist/cjs/src/wallet/substrates/__tests/XDM.test.js +579 -0
  195. package/dist/cjs/src/wallet/substrates/__tests/XDM.test.js.map +1 -0
  196. package/dist/cjs/src/wallet/substrates/utils/toOriginHeader.js +21 -0
  197. package/dist/cjs/src/wallet/substrates/utils/toOriginHeader.js.map +1 -0
  198. package/dist/cjs/src/wallet/utilityHelpers.js +305 -0
  199. package/dist/cjs/src/wallet/utilityHelpers.js.map +1 -0
  200. package/dist/cjs/src/wallet/validationHelpers.js +601 -0
  201. package/dist/cjs/src/wallet/validationHelpers.js.map +1 -0
  202. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  203. package/dist/esm/src/auth/__tests/Peer.test.js +448 -0
  204. package/dist/esm/src/auth/__tests/Peer.test.js.map +1 -0
  205. package/dist/esm/src/auth/__tests/SessionManager.test.js +69 -0
  206. package/dist/esm/src/auth/__tests/SessionManager.test.js.map +1 -0
  207. package/dist/esm/src/auth/certificates/__tests/Certificate.test.js +182 -0
  208. package/dist/esm/src/auth/certificates/__tests/Certificate.test.js.map +1 -0
  209. package/dist/esm/src/auth/certificates/__tests/MasterCertificate.test.js +184 -0
  210. package/dist/esm/src/auth/certificates/__tests/MasterCertificate.test.js.map +1 -0
  211. package/dist/esm/src/auth/certificates/__tests/VerifiableCertificate.test.js +75 -0
  212. package/dist/esm/src/auth/certificates/__tests/VerifiableCertificate.test.js.map +1 -0
  213. package/dist/esm/src/auth/utils/__tests/cryptononce.test.js +101 -0
  214. package/dist/esm/src/auth/utils/__tests/cryptononce.test.js.map +1 -0
  215. package/dist/esm/src/auth/utils/__tests/getVerifiableCertificates.test.js +106 -0
  216. package/dist/esm/src/auth/utils/__tests/getVerifiableCertificates.test.js.map +1 -0
  217. package/dist/esm/src/auth/utils/__tests/validateCertificates.test.js +111 -0
  218. package/dist/esm/src/auth/utils/__tests/validateCertificates.test.js.map +1 -0
  219. package/dist/esm/src/auth/utils/certificateHelpers.js +47 -0
  220. package/dist/esm/src/auth/utils/certificateHelpers.js.map +1 -0
  221. package/dist/esm/src/compat/__tests/BSM.test.js +69 -0
  222. package/dist/esm/src/compat/__tests/BSM.test.js.map +1 -0
  223. package/dist/esm/src/compat/__tests/ECIES.test.js +115 -0
  224. package/dist/esm/src/compat/__tests/ECIES.test.js.map +1 -0
  225. package/dist/esm/src/compat/__tests/HD.test.js +336 -0
  226. package/dist/esm/src/compat/__tests/HD.test.js.map +1 -0
  227. package/dist/esm/src/compat/__tests/Mnemonic.test.js +150 -0
  228. package/dist/esm/src/compat/__tests/Mnemonic.test.js.map +1 -0
  229. package/dist/esm/src/compat/__tests/Mnemonic.vectors.js +175 -0
  230. package/dist/esm/src/compat/__tests/Mnemonic.vectors.js.map +1 -0
  231. package/dist/esm/src/messages/__tests/EncryptedMessage.test.js +57 -0
  232. package/dist/esm/src/messages/__tests/EncryptedMessage.test.js.map +1 -0
  233. package/dist/esm/src/messages/__tests/SignedMessage.test.js +52 -0
  234. package/dist/esm/src/messages/__tests/SignedMessage.test.js.map +1 -0
  235. package/dist/esm/src/overlay-tools/__tests/LookupResolver.test.js +1471 -0
  236. package/dist/esm/src/overlay-tools/__tests/LookupResolver.test.js.map +1 -0
  237. package/dist/esm/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js +78 -0
  238. package/dist/esm/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.js.map +1 -0
  239. package/dist/esm/src/overlay-tools/__tests/SHIPBroadcaster.test.js +933 -0
  240. package/dist/esm/src/overlay-tools/__tests/SHIPBroadcaster.test.js.map +1 -0
  241. package/dist/esm/src/primitives/__tests/AESGCM.test.js +248 -0
  242. package/dist/esm/src/primitives/__tests/AESGCM.test.js.map +1 -0
  243. package/dist/esm/src/primitives/__tests/BRC42.private.vectors.js +36 -0
  244. package/dist/esm/src/primitives/__tests/BRC42.private.vectors.js.map +1 -0
  245. package/dist/esm/src/primitives/__tests/BRC42.public.vectors.js +36 -0
  246. package/dist/esm/src/primitives/__tests/BRC42.public.vectors.js.map +1 -0
  247. package/dist/esm/src/primitives/__tests/BigNumber.arithmatic.test.js +501 -0
  248. package/dist/esm/src/primitives/__tests/BigNumber.arithmatic.test.js.map +1 -0
  249. package/dist/esm/src/primitives/__tests/BigNumber.binary.test.js +185 -0
  250. package/dist/esm/src/primitives/__tests/BigNumber.binary.test.js.map +1 -0
  251. package/dist/esm/src/primitives/__tests/BigNumber.constructor.test.js +149 -0
  252. package/dist/esm/src/primitives/__tests/BigNumber.constructor.test.js.map +1 -0
  253. package/dist/esm/src/primitives/__tests/BigNumber.dhGroup.test.js +23 -0
  254. package/dist/esm/src/primitives/__tests/BigNumber.dhGroup.test.js.map +1 -0
  255. package/dist/esm/src/primitives/__tests/BigNumber.fixtures.js +268 -0
  256. package/dist/esm/src/primitives/__tests/BigNumber.fixtures.js.map +1 -0
  257. package/dist/esm/src/primitives/__tests/BigNumber.serializers.test.js +147 -0
  258. package/dist/esm/src/primitives/__tests/BigNumber.serializers.test.js.map +1 -0
  259. package/dist/esm/src/primitives/__tests/BigNumber.utils.test.js +322 -0
  260. package/dist/esm/src/primitives/__tests/BigNumber.utils.test.js.map +1 -0
  261. package/dist/esm/src/primitives/__tests/Curve.unit.test.js +145 -0
  262. package/dist/esm/src/primitives/__tests/Curve.unit.test.js.map +1 -0
  263. package/dist/esm/src/primitives/__tests/DRBG.test.js +22 -0
  264. package/dist/esm/src/primitives/__tests/DRBG.test.js.map +1 -0
  265. package/dist/esm/src/primitives/__tests/DRBG.vectors.js +170 -0
  266. package/dist/esm/src/primitives/__tests/DRBG.vectors.js.map +1 -0
  267. package/dist/esm/src/primitives/__tests/ECDH.test.js +34 -0
  268. package/dist/esm/src/primitives/__tests/ECDH.test.js.map +1 -0
  269. package/dist/esm/src/primitives/__tests/ECDSA.test.js +89 -0
  270. package/dist/esm/src/primitives/__tests/ECDSA.test.js.map +1 -0
  271. package/dist/esm/src/primitives/__tests/HMAC.test.js +60 -0
  272. package/dist/esm/src/primitives/__tests/HMAC.test.js.map +1 -0
  273. package/dist/esm/src/primitives/__tests/Hash.test.js +159 -0
  274. package/dist/esm/src/primitives/__tests/Hash.test.js.map +1 -0
  275. package/dist/esm/src/primitives/__tests/PBKDF2.vectors.js +122 -0
  276. package/dist/esm/src/primitives/__tests/PBKDF2.vectors.js.map +1 -0
  277. package/dist/esm/src/primitives/__tests/PrivateKey.split.test.js +105 -0
  278. package/dist/esm/src/primitives/__tests/PrivateKey.split.test.js.map +1 -0
  279. package/dist/esm/src/primitives/__tests/PrivateKey.test.js +90 -0
  280. package/dist/esm/src/primitives/__tests/PrivateKey.test.js.map +1 -0
  281. package/dist/esm/src/primitives/__tests/PublicKey.test.js +83 -0
  282. package/dist/esm/src/primitives/__tests/PublicKey.test.js.map +1 -0
  283. package/dist/esm/src/primitives/__tests/Random.test.js +19 -0
  284. package/dist/esm/src/primitives/__tests/Random.test.js.map +1 -0
  285. package/dist/esm/src/primitives/__tests/Reader.test.js +282 -0
  286. package/dist/esm/src/primitives/__tests/Reader.test.js.map +1 -0
  287. package/dist/esm/src/primitives/__tests/ReductionContext.test.js +223 -0
  288. package/dist/esm/src/primitives/__tests/ReductionContext.test.js.map +1 -0
  289. package/dist/esm/src/primitives/__tests/Schnorr.test.js +213 -0
  290. package/dist/esm/src/primitives/__tests/Schnorr.test.js.map +1 -0
  291. package/dist/esm/src/primitives/__tests/SymmetricKey.test.js +51 -0
  292. package/dist/esm/src/primitives/__tests/SymmetricKey.test.js.map +1 -0
  293. package/dist/esm/src/primitives/__tests/SymmetricKey.vectors.js +43 -0
  294. package/dist/esm/src/primitives/__tests/SymmetricKey.vectors.js.map +1 -0
  295. package/dist/esm/src/primitives/__tests/Writer.test.js +176 -0
  296. package/dist/esm/src/primitives/__tests/Writer.test.js.map +1 -0
  297. package/dist/esm/src/primitives/__tests/bug-31.test.js +32 -0
  298. package/dist/esm/src/primitives/__tests/bug-31.test.js.map +1 -0
  299. package/dist/esm/src/primitives/__tests/sighash.vectors.js +3506 -0
  300. package/dist/esm/src/primitives/__tests/sighash.vectors.js.map +1 -0
  301. package/dist/esm/src/primitives/__tests/utils.test.js +110 -0
  302. package/dist/esm/src/primitives/__tests/utils.test.js.map +1 -0
  303. package/dist/esm/src/primitives/utils.js +18 -2
  304. package/dist/esm/src/primitives/utils.js.map +1 -1
  305. package/dist/esm/src/script/__tests/Script.test.js +347 -0
  306. package/dist/esm/src/script/__tests/Script.test.js.map +1 -0
  307. package/dist/esm/src/script/__tests/Spend.test.js +282 -0
  308. package/dist/esm/src/script/__tests/Spend.test.js.map +1 -0
  309. package/dist/esm/src/script/__tests/SpendComplex.test.js +51 -0
  310. package/dist/esm/src/script/__tests/SpendComplex.test.js.map +1 -0
  311. package/dist/esm/src/script/__tests/script.invalid.vectors.js +2370 -0
  312. package/dist/esm/src/script/__tests/script.invalid.vectors.js.map +1 -0
  313. package/dist/esm/src/script/__tests/script.valid.vectors.js +1181 -0
  314. package/dist/esm/src/script/__tests/script.valid.vectors.js.map +1 -0
  315. package/dist/esm/src/script/__tests/spend.valid.vectors.js +2298 -0
  316. package/dist/esm/src/script/__tests/spend.valid.vectors.js.map +1 -0
  317. package/dist/esm/src/script/templates/__tests/PushDrop.test.js +161 -0
  318. package/dist/esm/src/script/templates/__tests/PushDrop.test.js.map +1 -0
  319. package/dist/esm/src/totp/__tests/totp.test.js +67 -0
  320. package/dist/esm/src/totp/__tests/totp.test.js.map +1 -0
  321. package/dist/esm/src/transaction/__tests/Beef.test.js +393 -0
  322. package/dist/esm/src/transaction/__tests/Beef.test.js.map +1 -0
  323. package/dist/esm/src/transaction/__tests/MerklePath.test.js +209 -0
  324. package/dist/esm/src/transaction/__tests/MerklePath.test.js.map +1 -0
  325. package/dist/esm/src/transaction/__tests/Transaction.benchmarks.test.js +219 -0
  326. package/dist/esm/src/transaction/__tests/Transaction.benchmarks.test.js.map +1 -0
  327. package/dist/esm/src/transaction/__tests/Transaction.test.js +1072 -0
  328. package/dist/esm/src/transaction/__tests/Transaction.test.js.map +1 -0
  329. package/dist/esm/src/transaction/__tests/bigtx.vectors.js +7 -0
  330. package/dist/esm/src/transaction/__tests/bigtx.vectors.js.map +1 -0
  331. package/dist/esm/src/transaction/__tests/bump.invalid.vectors.js +11 -0
  332. package/dist/esm/src/transaction/__tests/bump.invalid.vectors.js.map +1 -0
  333. package/dist/esm/src/transaction/__tests/bump.valid.vectors.js +7 -0
  334. package/dist/esm/src/transaction/__tests/bump.valid.vectors.js.map +1 -0
  335. package/dist/esm/src/transaction/__tests/tx.invalid.vectors.js +230 -0
  336. package/dist/esm/src/transaction/__tests/tx.invalid.vectors.js.map +1 -0
  337. package/dist/esm/src/transaction/__tests/tx.valid.vectors.js +296 -0
  338. package/dist/esm/src/transaction/__tests/tx.valid.vectors.js.map +1 -0
  339. package/dist/esm/src/transaction/broadcasters/__tests/ARC.test.js +246 -0
  340. package/dist/esm/src/transaction/broadcasters/__tests/ARC.test.js.map +1 -0
  341. package/dist/esm/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js +148 -0
  342. package/dist/esm/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.js.map +1 -0
  343. package/dist/esm/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js +155 -0
  344. package/dist/esm/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.js.map +1 -0
  345. package/dist/esm/src/wallet/ScriptTemplateSABPPP.js +37 -0
  346. package/dist/esm/src/wallet/ScriptTemplateSABPPP.js.map +1 -0
  347. package/dist/esm/src/wallet/WalletSigner.js +263 -0
  348. package/dist/esm/src/wallet/WalletSigner.js.map +1 -0
  349. package/dist/esm/src/wallet/__tests/CachedKeyDeriver.test.js +269 -0
  350. package/dist/esm/src/wallet/__tests/CachedKeyDeriver.test.js.map +1 -0
  351. package/dist/esm/src/wallet/__tests/KeyDeriver.test.js +113 -0
  352. package/dist/esm/src/wallet/__tests/KeyDeriver.test.js.map +1 -0
  353. package/dist/esm/src/wallet/__tests/ProtoWallet.test.js +475 -0
  354. package/dist/esm/src/wallet/__tests/ProtoWallet.test.js.map +1 -0
  355. package/dist/esm/src/wallet/createActionSdk.js +223 -0
  356. package/dist/esm/src/wallet/createActionSdk.js.map +1 -0
  357. package/dist/esm/src/wallet/sdk/CachedKeyDeriver.js +174 -0
  358. package/dist/esm/src/wallet/sdk/CachedKeyDeriver.js.map +1 -0
  359. package/dist/esm/src/wallet/sdk/CertOps.js +181 -0
  360. package/dist/esm/src/wallet/sdk/CertOps.js.map +1 -0
  361. package/dist/esm/src/wallet/sdk/Certificate.js +186 -0
  362. package/dist/esm/src/wallet/sdk/Certificate.js.map +1 -0
  363. package/dist/esm/src/wallet/sdk/KeyDeriver.js +174 -0
  364. package/dist/esm/src/wallet/sdk/KeyDeriver.js.map +1 -0
  365. package/dist/esm/src/wallet/sdk/ProtoWallet.js +71 -0
  366. package/dist/esm/src/wallet/sdk/ProtoWallet.js.map +1 -0
  367. package/dist/esm/src/wallet/sdk/StorageSyncReader.js +2 -0
  368. package/dist/esm/src/wallet/sdk/StorageSyncReader.js.map +1 -0
  369. package/dist/esm/src/wallet/sdk/WERR_errors.js +99 -0
  370. package/dist/esm/src/wallet/sdk/WERR_errors.js.map +1 -0
  371. package/dist/esm/src/wallet/sdk/Wallet.interfaces.js +2 -0
  372. package/dist/esm/src/wallet/sdk/Wallet.interfaces.js.map +1 -0
  373. package/dist/esm/src/wallet/sdk/WalletCrypto.js +168 -0
  374. package/dist/esm/src/wallet/sdk/WalletCrypto.js.map +1 -0
  375. package/dist/esm/src/wallet/sdk/WalletError.js +100 -0
  376. package/dist/esm/src/wallet/sdk/WalletError.js.map +1 -0
  377. package/dist/esm/src/wallet/sdk/WalletServices.interfaces.js +2 -0
  378. package/dist/esm/src/wallet/sdk/WalletServices.interfaces.js.map +1 -0
  379. package/dist/esm/src/wallet/sdk/WalletSigner.interfaces.js +2 -0
  380. package/dist/esm/src/wallet/sdk/WalletSigner.interfaces.js.map +1 -0
  381. package/dist/esm/src/wallet/sdk/WalletStorage.interfaces.js +2 -0
  382. package/dist/esm/src/wallet/sdk/WalletStorage.interfaces.js.map +1 -0
  383. package/dist/esm/src/wallet/sdk/index.js +15 -0
  384. package/dist/esm/src/wallet/sdk/index.js.map +1 -0
  385. package/dist/esm/src/wallet/sdk/types.js +8 -0
  386. package/dist/esm/src/wallet/sdk/types.js.map +1 -0
  387. package/dist/esm/src/wallet/sdk/validationHelpers.js +566 -0
  388. package/dist/esm/src/wallet/sdk/validationHelpers.js.map +1 -0
  389. package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js +9 -1
  390. package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
  391. package/dist/esm/src/wallet/substrates/WalletWireProcessor.js +1 -1
  392. package/dist/esm/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
  393. package/dist/esm/src/wallet/substrates/__tests/WalletWire.integration.test.js +1962 -0
  394. package/dist/esm/src/wallet/substrates/__tests/WalletWire.integration.test.js.map +1 -0
  395. package/dist/esm/src/wallet/substrates/__tests/XDM.test.js +579 -0
  396. package/dist/esm/src/wallet/substrates/__tests/XDM.test.js.map +1 -0
  397. package/dist/esm/src/wallet/substrates/utils/toOriginHeader.js +17 -0
  398. package/dist/esm/src/wallet/substrates/utils/toOriginHeader.js.map +1 -0
  399. package/dist/esm/src/wallet/utilityHelpers.js +275 -0
  400. package/dist/esm/src/wallet/utilityHelpers.js.map +1 -0
  401. package/dist/esm/src/wallet/validationHelpers.js +566 -0
  402. package/dist/esm/src/wallet/validationHelpers.js.map +1 -0
  403. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  404. package/dist/types/src/auth/__tests/Peer.test.d.ts +2 -0
  405. package/dist/types/src/auth/__tests/Peer.test.d.ts.map +1 -0
  406. package/dist/types/src/auth/__tests/SessionManager.test.d.ts +2 -0
  407. package/dist/types/src/auth/__tests/SessionManager.test.d.ts.map +1 -0
  408. package/dist/types/src/auth/certificates/__tests/Certificate.test.d.ts +2 -0
  409. package/dist/types/src/auth/certificates/__tests/Certificate.test.d.ts.map +1 -0
  410. package/dist/types/src/auth/certificates/__tests/MasterCertificate.test.d.ts +2 -0
  411. package/dist/types/src/auth/certificates/__tests/MasterCertificate.test.d.ts.map +1 -0
  412. package/dist/types/src/auth/certificates/__tests/VerifiableCertificate.test.d.ts +2 -0
  413. package/dist/types/src/auth/certificates/__tests/VerifiableCertificate.test.d.ts.map +1 -0
  414. package/dist/types/src/auth/utils/__tests/cryptononce.test.d.ts +2 -0
  415. package/dist/types/src/auth/utils/__tests/cryptononce.test.d.ts.map +1 -0
  416. package/dist/types/src/auth/utils/__tests/getVerifiableCertificates.test.d.ts +2 -0
  417. package/dist/types/src/auth/utils/__tests/getVerifiableCertificates.test.d.ts.map +1 -0
  418. package/dist/types/src/auth/utils/__tests/validateCertificates.test.d.ts +2 -0
  419. package/dist/types/src/auth/utils/__tests/validateCertificates.test.d.ts.map +1 -0
  420. package/dist/types/src/auth/utils/certificateHelpers.d.ts +26 -0
  421. package/dist/types/src/auth/utils/certificateHelpers.d.ts.map +1 -0
  422. package/dist/types/src/compat/__tests/BSM.test.d.ts +2 -0
  423. package/dist/types/src/compat/__tests/BSM.test.d.ts.map +1 -0
  424. package/dist/types/src/compat/__tests/ECIES.test.d.ts +2 -0
  425. package/dist/types/src/compat/__tests/ECIES.test.d.ts.map +1 -0
  426. package/dist/types/src/compat/__tests/HD.test.d.ts +2 -0
  427. package/dist/types/src/compat/__tests/HD.test.d.ts.map +1 -0
  428. package/dist/types/src/compat/__tests/Mnemonic.test.d.ts +2 -0
  429. package/dist/types/src/compat/__tests/Mnemonic.test.d.ts.map +1 -0
  430. package/dist/types/src/compat/__tests/Mnemonic.vectors.d.ts +11 -0
  431. package/dist/types/src/compat/__tests/Mnemonic.vectors.d.ts.map +1 -0
  432. package/dist/types/src/messages/__tests/EncryptedMessage.test.d.ts +2 -0
  433. package/dist/types/src/messages/__tests/EncryptedMessage.test.d.ts.map +1 -0
  434. package/dist/types/src/messages/__tests/SignedMessage.test.d.ts +2 -0
  435. package/dist/types/src/messages/__tests/SignedMessage.test.d.ts.map +1 -0
  436. package/dist/types/src/overlay-tools/__tests/LookupResolver.test.d.ts +2 -0
  437. package/dist/types/src/overlay-tools/__tests/LookupResolver.test.d.ts.map +1 -0
  438. package/dist/types/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.d.ts +2 -0
  439. package/dist/types/src/overlay-tools/__tests/OverlayAdminTokenTemplate.test.d.ts.map +1 -0
  440. package/dist/types/src/overlay-tools/__tests/SHIPBroadcaster.test.d.ts +2 -0
  441. package/dist/types/src/overlay-tools/__tests/SHIPBroadcaster.test.d.ts.map +1 -0
  442. package/dist/types/src/primitives/__tests/AESGCM.test.d.ts +2 -0
  443. package/dist/types/src/primitives/__tests/AESGCM.test.d.ts.map +1 -0
  444. package/dist/types/src/primitives/__tests/BRC42.private.vectors.d.ts +8 -0
  445. package/dist/types/src/primitives/__tests/BRC42.private.vectors.d.ts.map +1 -0
  446. package/dist/types/src/primitives/__tests/BRC42.public.vectors.d.ts +8 -0
  447. package/dist/types/src/primitives/__tests/BRC42.public.vectors.d.ts.map +1 -0
  448. package/dist/types/src/primitives/__tests/BigNumber.arithmatic.test.d.ts +2 -0
  449. package/dist/types/src/primitives/__tests/BigNumber.arithmatic.test.d.ts.map +1 -0
  450. package/dist/types/src/primitives/__tests/BigNumber.binary.test.d.ts +2 -0
  451. package/dist/types/src/primitives/__tests/BigNumber.binary.test.d.ts.map +1 -0
  452. package/dist/types/src/primitives/__tests/BigNumber.constructor.test.d.ts +2 -0
  453. package/dist/types/src/primitives/__tests/BigNumber.constructor.test.d.ts.map +1 -0
  454. package/dist/types/src/primitives/__tests/BigNumber.dhGroup.test.d.ts +2 -0
  455. package/dist/types/src/primitives/__tests/BigNumber.dhGroup.test.d.ts.map +1 -0
  456. package/dist/types/src/primitives/__tests/BigNumber.fixtures.d.ts +15 -0
  457. package/dist/types/src/primitives/__tests/BigNumber.fixtures.d.ts.map +1 -0
  458. package/dist/types/src/primitives/__tests/BigNumber.serializers.test.d.ts +2 -0
  459. package/dist/types/src/primitives/__tests/BigNumber.serializers.test.d.ts.map +1 -0
  460. package/dist/types/src/primitives/__tests/BigNumber.utils.test.d.ts +2 -0
  461. package/dist/types/src/primitives/__tests/BigNumber.utils.test.d.ts.map +1 -0
  462. package/dist/types/src/primitives/__tests/Curve.unit.test.d.ts +2 -0
  463. package/dist/types/src/primitives/__tests/Curve.unit.test.d.ts.map +1 -0
  464. package/dist/types/src/primitives/__tests/DRBG.test.d.ts +2 -0
  465. package/dist/types/src/primitives/__tests/DRBG.test.d.ts.map +1 -0
  466. package/dist/types/src/primitives/__tests/DRBG.vectors.d.ts +10 -0
  467. package/dist/types/src/primitives/__tests/DRBG.vectors.d.ts.map +1 -0
  468. package/dist/types/src/primitives/__tests/ECDH.test.d.ts +2 -0
  469. package/dist/types/src/primitives/__tests/ECDH.test.d.ts.map +1 -0
  470. package/dist/types/src/primitives/__tests/ECDSA.test.d.ts +2 -0
  471. package/dist/types/src/primitives/__tests/ECDSA.test.d.ts.map +1 -0
  472. package/dist/types/src/primitives/__tests/HMAC.test.d.ts +2 -0
  473. package/dist/types/src/primitives/__tests/HMAC.test.d.ts.map +1 -0
  474. package/dist/types/src/primitives/__tests/Hash.test.d.ts +2 -0
  475. package/dist/types/src/primitives/__tests/Hash.test.d.ts.map +1 -0
  476. package/dist/types/src/primitives/__tests/PBKDF2.vectors.d.ts +68 -0
  477. package/dist/types/src/primitives/__tests/PBKDF2.vectors.d.ts.map +1 -0
  478. package/dist/types/src/primitives/__tests/PrivateKey.split.test.d.ts +2 -0
  479. package/dist/types/src/primitives/__tests/PrivateKey.split.test.d.ts.map +1 -0
  480. package/dist/types/src/primitives/__tests/PrivateKey.test.d.ts +2 -0
  481. package/dist/types/src/primitives/__tests/PrivateKey.test.d.ts.map +1 -0
  482. package/dist/types/src/primitives/__tests/PublicKey.test.d.ts +2 -0
  483. package/dist/types/src/primitives/__tests/PublicKey.test.d.ts.map +1 -0
  484. package/dist/types/src/primitives/__tests/Random.test.d.ts +2 -0
  485. package/dist/types/src/primitives/__tests/Random.test.d.ts.map +1 -0
  486. package/dist/types/src/primitives/__tests/Reader.test.d.ts +2 -0
  487. package/dist/types/src/primitives/__tests/Reader.test.d.ts.map +1 -0
  488. package/dist/types/src/primitives/__tests/ReductionContext.test.d.ts +2 -0
  489. package/dist/types/src/primitives/__tests/ReductionContext.test.d.ts.map +1 -0
  490. package/dist/types/src/primitives/__tests/Schnorr.test.d.ts +2 -0
  491. package/dist/types/src/primitives/__tests/Schnorr.test.d.ts.map +1 -0
  492. package/dist/types/src/primitives/__tests/SymmetricKey.test.d.ts +2 -0
  493. package/dist/types/src/primitives/__tests/SymmetricKey.test.d.ts.map +1 -0
  494. package/dist/types/src/primitives/__tests/SymmetricKey.vectors.d.ts +20 -0
  495. package/dist/types/src/primitives/__tests/SymmetricKey.vectors.d.ts.map +1 -0
  496. package/dist/types/src/primitives/__tests/Writer.test.d.ts +2 -0
  497. package/dist/types/src/primitives/__tests/Writer.test.d.ts.map +1 -0
  498. package/dist/types/src/primitives/__tests/bug-31.test.d.ts +2 -0
  499. package/dist/types/src/primitives/__tests/bug-31.test.d.ts.map +1 -0
  500. package/dist/types/src/primitives/__tests/sighash.vectors.d.ts +3 -0
  501. package/dist/types/src/primitives/__tests/sighash.vectors.d.ts.map +1 -0
  502. package/dist/types/src/primitives/__tests/utils.test.d.ts +2 -0
  503. package/dist/types/src/primitives/__tests/utils.test.d.ts.map +1 -0
  504. package/dist/types/src/primitives/utils.d.ts +2 -1
  505. package/dist/types/src/primitives/utils.d.ts.map +1 -1
  506. package/dist/types/src/script/__tests/Script.test.d.ts +2 -0
  507. package/dist/types/src/script/__tests/Script.test.d.ts.map +1 -0
  508. package/dist/types/src/script/__tests/Spend.test.d.ts +2 -0
  509. package/dist/types/src/script/__tests/Spend.test.d.ts.map +1 -0
  510. package/dist/types/src/script/__tests/SpendComplex.test.d.ts +2 -0
  511. package/dist/types/src/script/__tests/SpendComplex.test.d.ts.map +1 -0
  512. package/dist/types/src/script/__tests/script.invalid.vectors.d.ts +3 -0
  513. package/dist/types/src/script/__tests/script.invalid.vectors.d.ts.map +1 -0
  514. package/dist/types/src/script/__tests/script.valid.vectors.d.ts +3 -0
  515. package/dist/types/src/script/__tests/script.valid.vectors.d.ts.map +1 -0
  516. package/dist/types/src/script/__tests/spend.valid.vectors.d.ts +3 -0
  517. package/dist/types/src/script/__tests/spend.valid.vectors.d.ts.map +1 -0
  518. package/dist/types/src/script/templates/__tests/PushDrop.test.d.ts +2 -0
  519. package/dist/types/src/script/templates/__tests/PushDrop.test.d.ts.map +1 -0
  520. package/dist/types/src/totp/__tests/totp.test.d.ts +2 -0
  521. package/dist/types/src/totp/__tests/totp.test.d.ts.map +1 -0
  522. package/dist/types/src/transaction/__tests/Beef.test.d.ts +2 -0
  523. package/dist/types/src/transaction/__tests/Beef.test.d.ts.map +1 -0
  524. package/dist/types/src/transaction/__tests/MerklePath.test.d.ts +2 -0
  525. package/dist/types/src/transaction/__tests/MerklePath.test.d.ts.map +1 -0
  526. package/dist/types/src/transaction/__tests/Transaction.benchmarks.test.d.ts +2 -0
  527. package/dist/types/src/transaction/__tests/Transaction.benchmarks.test.d.ts.map +1 -0
  528. package/dist/types/src/transaction/__tests/Transaction.test.d.ts +2 -0
  529. package/dist/types/src/transaction/__tests/Transaction.test.d.ts.map +1 -0
  530. package/dist/types/src/transaction/__tests/bigtx.vectors.d.ts +6 -0
  531. package/dist/types/src/transaction/__tests/bigtx.vectors.d.ts.map +1 -0
  532. package/dist/types/src/transaction/__tests/bump.invalid.vectors.d.ts +6 -0
  533. package/dist/types/src/transaction/__tests/bump.invalid.vectors.d.ts.map +1 -0
  534. package/dist/types/src/transaction/__tests/bump.valid.vectors.d.ts +5 -0
  535. package/dist/types/src/transaction/__tests/bump.valid.vectors.d.ts.map +1 -0
  536. package/dist/types/src/transaction/__tests/tx.invalid.vectors.d.ts +3 -0
  537. package/dist/types/src/transaction/__tests/tx.invalid.vectors.d.ts.map +1 -0
  538. package/dist/types/src/transaction/__tests/tx.valid.vectors.d.ts +3 -0
  539. package/dist/types/src/transaction/__tests/tx.valid.vectors.d.ts.map +1 -0
  540. package/dist/types/src/transaction/broadcasters/__tests/ARC.test.d.ts +2 -0
  541. package/dist/types/src/transaction/broadcasters/__tests/ARC.test.d.ts.map +1 -0
  542. package/dist/types/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.d.ts +2 -0
  543. package/dist/types/src/transaction/broadcasters/__tests/WhatsOnChainBroadcaster.test.d.ts.map +1 -0
  544. package/dist/types/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.d.ts +2 -0
  545. package/dist/types/src/transaction/chaintrackers/__tests/WhatsOnChainChainTracker.test.d.ts.map +1 -0
  546. package/dist/types/src/wallet/ScriptTemplateSABPPP.d.ts +25 -0
  547. package/dist/types/src/wallet/ScriptTemplateSABPPP.d.ts.map +1 -0
  548. package/dist/types/src/wallet/WalletSigner.d.ts +110 -0
  549. package/dist/types/src/wallet/WalletSigner.d.ts.map +1 -0
  550. package/dist/types/src/wallet/__tests/CachedKeyDeriver.test.d.ts +2 -0
  551. package/dist/types/src/wallet/__tests/CachedKeyDeriver.test.d.ts.map +1 -0
  552. package/dist/types/src/wallet/__tests/KeyDeriver.test.d.ts +2 -0
  553. package/dist/types/src/wallet/__tests/KeyDeriver.test.d.ts.map +1 -0
  554. package/dist/types/src/wallet/__tests/ProtoWallet.test.d.ts +2 -0
  555. package/dist/types/src/wallet/__tests/ProtoWallet.test.d.ts.map +1 -0
  556. package/dist/types/src/wallet/createActionSdk.d.ts +8 -0
  557. package/dist/types/src/wallet/createActionSdk.d.ts.map +1 -0
  558. package/dist/types/src/wallet/sdk/CachedKeyDeriver.d.ts +94 -0
  559. package/dist/types/src/wallet/sdk/CachedKeyDeriver.d.ts.map +1 -0
  560. package/dist/types/src/wallet/sdk/CertOps.d.ts +63 -0
  561. package/dist/types/src/wallet/sdk/CertOps.d.ts.map +1 -0
  562. package/dist/types/src/wallet/sdk/Certificate.d.ts +77 -0
  563. package/dist/types/src/wallet/sdk/Certificate.d.ts.map +1 -0
  564. package/dist/types/src/wallet/sdk/KeyDeriver.d.ts +128 -0
  565. package/dist/types/src/wallet/sdk/KeyDeriver.d.ts.map +1 -0
  566. package/dist/types/src/wallet/sdk/ProtoWallet.d.ts +30 -0
  567. package/dist/types/src/wallet/sdk/ProtoWallet.d.ts.map +1 -0
  568. package/dist/types/src/wallet/sdk/StorageSyncReader.d.ts +102 -0
  569. package/dist/types/src/wallet/sdk/StorageSyncReader.d.ts.map +1 -0
  570. package/dist/types/src/wallet/sdk/WERR_errors.d.ts +84 -0
  571. package/dist/types/src/wallet/sdk/WERR_errors.d.ts.map +1 -0
  572. package/dist/types/src/wallet/sdk/Wallet.interfaces.d.ts +1036 -0
  573. package/dist/types/src/wallet/sdk/Wallet.interfaces.d.ts.map +1 -0
  574. package/dist/types/src/wallet/sdk/WalletCrypto.d.ts +31 -0
  575. package/dist/types/src/wallet/sdk/WalletCrypto.d.ts.map +1 -0
  576. package/dist/types/src/wallet/sdk/WalletError.d.ts +46 -0
  577. package/dist/types/src/wallet/sdk/WalletError.d.ts.map +1 -0
  578. package/dist/types/src/wallet/sdk/WalletServices.interfaces.d.ts +293 -0
  579. package/dist/types/src/wallet/sdk/WalletServices.interfaces.d.ts.map +1 -0
  580. package/dist/types/src/wallet/sdk/WalletSigner.interfaces.d.ts +48 -0
  581. package/dist/types/src/wallet/sdk/WalletSigner.interfaces.d.ts.map +1 -0
  582. package/dist/types/src/wallet/sdk/WalletStorage.interfaces.d.ts +296 -0
  583. package/dist/types/src/wallet/sdk/WalletStorage.interfaces.d.ts.map +1 -0
  584. package/dist/types/src/wallet/sdk/index.d.ts +15 -0
  585. package/dist/types/src/wallet/sdk/index.d.ts.map +1 -0
  586. package/dist/types/src/wallet/sdk/types.d.ts +56 -0
  587. package/dist/types/src/wallet/sdk/types.d.ts.map +1 -0
  588. package/dist/types/src/wallet/sdk/validationHelpers.d.ts +301 -0
  589. package/dist/types/src/wallet/sdk/validationHelpers.d.ts.map +1 -0
  590. package/dist/types/src/wallet/substrates/HTTPWalletJSON.d.ts.map +1 -1
  591. package/dist/types/src/wallet/substrates/__tests/WalletWire.integration.test.d.ts +2 -0
  592. package/dist/types/src/wallet/substrates/__tests/WalletWire.integration.test.d.ts.map +1 -0
  593. package/dist/types/src/wallet/substrates/__tests/XDM.test.d.ts +5 -0
  594. package/dist/types/src/wallet/substrates/__tests/XDM.test.d.ts.map +1 -0
  595. package/dist/types/src/wallet/substrates/utils/toOriginHeader.d.ts +2 -0
  596. package/dist/types/src/wallet/substrates/utils/toOriginHeader.d.ts.map +1 -0
  597. package/dist/types/src/wallet/utilityHelpers.d.ts +142 -0
  598. package/dist/types/src/wallet/utilityHelpers.d.ts.map +1 -0
  599. package/dist/types/src/wallet/validationHelpers.d.ts +301 -0
  600. package/dist/types/src/wallet/validationHelpers.d.ts.map +1 -0
  601. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  602. package/dist/umd/bundle.js +1 -1
  603. package/docs/primitives.md +2 -1
  604. package/docs/wallet.md +9 -0
  605. package/package.json +4 -4
  606. package/src/primitives/utils.ts +20 -2
  607. package/src/transaction/__tests/Transaction.test.ts +1 -1
  608. package/src/wallet/substrates/HTTPWalletJSON.ts +11 -1
  609. package/src/wallet/substrates/WalletWireProcessor.ts +1 -1
  610. package/src/wallet/substrates/__tests/toOriginHeader.test.ts +34 -0
  611. package/src/wallet/substrates/utils/toOriginHeader.ts +15 -0
@@ -0,0 +1,260 @@
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 KeyDeriver_js_1 = __importDefault(require("./KeyDeriver.js"));
7
+ const index_js_1 = require("../primitives/index.js");
8
+ const WalletError_js_1 = require("./WalletError.js");
9
+ const ProtoWallet_js_1 = __importDefault(require("./ProtoWallet.js"));
10
+ const mod_js_1 = require("mod.js");
11
+ const createActionSdk_js_1 = require("./createActionSdk.js");
12
+ const validationHelpers_js_1 = require("./validationHelpers.js");
13
+ // type Network = 'mainnet' | 'testnet';
14
+ /**
15
+ * A WalletSigner is a structure that fulfills the Wallet interface, capable of performing all foundational cryptographic operations. It can derive keys, create signatures, facilitate encryption and HMAC operations, and reveal key linkages. However, ProtoWallet does not create transactions, manage outputs, interact with the blockchain, enable the management of identity certificates, or store any data.
16
+ */
17
+ class WalletSigner {
18
+ constructor(rootKey, storageProviders, network = 'mainnet', syncAfterWrite = false, KeyDeriverClass = KeyDeriver_js_1.default) {
19
+ this.privilegedError = 'ProtoWallet is a single-keyring wallet, operating without context about whether its configured keyring is privileged.';
20
+ this.keyDeriver = new KeyDeriverClass(rootKey);
21
+ this.activeStorageProvider = storageProviders[0];
22
+ this.auxiliaryStorageProviders = storageProviders.splice(1);
23
+ this.network = network;
24
+ this.proto = new ProtoWallet_js_1.default(rootKey, KeyDeriverClass);
25
+ this.syncAfterWrite = syncAfterWrite;
26
+ // Construct signer BEEF parties
27
+ this.storageParty = this.activeStorageProvider.storageIdentityKey;
28
+ this.userParty = this.getClientChangeKeyPair().publicKey;
29
+ this.beef = new mod_js_1.BeefParty([this.storageParty, this.userParty]);
30
+ }
31
+ async syncPrimaryStorageToAuxiliary() {
32
+ for (const aux of this.auxiliaryStorageProviders) {
33
+ try {
34
+ await aux.syncWith(this.activeStorageProvider);
35
+ }
36
+ catch (e) {
37
+ continue;
38
+ }
39
+ }
40
+ }
41
+ async createAction(args) {
42
+ const vargs = (0, validationHelpers_js_1.validateCreateActionArgs)(args);
43
+ vargs.options.knownTxids = this.getKnownTxids(vargs.options.knownTxids);
44
+ const r = await (0, createActionSdk_js_1.createActionSdk)(this, vargs);
45
+ if (r.signableTransaction) {
46
+ const st = r.signableTransaction;
47
+ const ab = mod_js_1.Beef.fromBinary(st.tx);
48
+ if (!ab.atomicTxid)
49
+ throw new WalletError_js_1.WalletError('Missing atomicTxid in signableTransaction result');
50
+ if (ab.txs.length < 1 || ab.txs[ab.txs.length - 1].txid !== ab.atomicTxid)
51
+ throw new WalletError_js_1.WalletError('atomicTxid does not match txid of last AtomicBEEF transaction');
52
+ // Remove the new, partially constructed transaction from beef as it will never be a valid transaction.
53
+ ab.txs.slice(ab.txs.length - 1);
54
+ this.beef.mergeBeefFromParty(this.storageParty, ab);
55
+ }
56
+ else if (r.tx) {
57
+ this.beef.mergeBeefFromParty(this.storageParty, r.tx);
58
+ }
59
+ if (this.syncAfterWrite) {
60
+ await this.syncPrimaryStorageToAuxiliary();
61
+ }
62
+ return r;
63
+ }
64
+ async signAction(args) {
65
+ throw new Error('todo');
66
+ }
67
+ async abortAction(args) {
68
+ throw new Error('todo');
69
+ }
70
+ async listActions(args) {
71
+ return this.activeStorageProvider.listActions(args);
72
+ }
73
+ internalizeAction(args) {
74
+ return this.activeStorageProvider.internalizeAction(args);
75
+ }
76
+ listOutputs(args) {
77
+ return this.activeStorageProvider.listOutputs(args);
78
+ }
79
+ async relinquishOutput(args) {
80
+ await this.activeStorageProvider.relinquishOutput(args);
81
+ if (this.syncAfterWrite) {
82
+ await this.syncPrimaryStorageToAuxiliary();
83
+ }
84
+ return { relinquished: true };
85
+ }
86
+ async getPublicKey(args) {
87
+ return this.proto.getPublicKey(args);
88
+ }
89
+ async revealCounterpartyKeyLinkage(args) {
90
+ return this.proto.revealCounterpartyKeyLinkage(args);
91
+ }
92
+ async revealSpecificKeyLinkage(args) {
93
+ return this.proto.revealSpecificKeyLinkage(args);
94
+ }
95
+ async encrypt(args) {
96
+ return this.proto.encrypt(args);
97
+ }
98
+ async decrypt(args) {
99
+ return this.proto.decrypt(args);
100
+ }
101
+ async createHmac(args) {
102
+ return this.proto.createHmac(args);
103
+ }
104
+ async verifyHmac(args) {
105
+ return this.proto.verifyHmac(args);
106
+ }
107
+ async createSignature(args) {
108
+ return this.proto.createSignature(args);
109
+ }
110
+ async verifySignature(args) {
111
+ return this.proto.verifySignature(args);
112
+ }
113
+ async acquireCertificate(args) {
114
+ if (args.privileged) {
115
+ throw new WalletError_js_1.WalletError(this.privilegedError);
116
+ }
117
+ const { publicKey: ourIdentityKey } = await this.proto.getPublicKey({ identityKey: true });
118
+ if (args.acquisitionProtocol === 'direct') {
119
+ let actualKeyringRevealer;
120
+ if (!args.keyringRevealer || args.keyringRevealer === 'certifier') {
121
+ actualKeyringRevealer = args.certifier;
122
+ }
123
+ else {
124
+ actualKeyringRevealer = args.keyringRevealer;
125
+ }
126
+ // Validate that all fields are provided in the keyring
127
+ if (Object.keys(args.fields).length !== Object.keys(args.keyringForSubject).length) {
128
+ throw new WalletError_js_1.WalletError('Keyring for subject does not include all fields');
129
+ }
130
+ if (Object.keys(args.fields).some(field => (!args.keyringForSubject[field]))) {
131
+ throw new WalletError_js_1.WalletError('Keyring for subject does not include all fields');
132
+ }
133
+ // Decrypt the keyring and build the correct "self" master keyring
134
+ const masterKeyringForSelf = {};
135
+ for (const fieldName of Object.keys(args.fields)) {
136
+ const keyID = `${args.serialNumber} ${fieldName}`;
137
+ const encryptedMasterFieldKey = args.keyringForSubject[fieldName];
138
+ // Decrypt the master field key
139
+ const { plaintext: masterFieldKey } = await this.proto.decrypt({
140
+ ciphertext: index_js_1.Utils.toArray(encryptedMasterFieldKey, 'base64'),
141
+ protocolID: [2, 'certificate field encryption'],
142
+ keyID,
143
+ counterparty: actualKeyringRevealer
144
+ });
145
+ // Verify that derived key actually decrypts requested field
146
+ try {
147
+ new mod_js_1.SymmetricKey(masterFieldKey).decrypt(index_js_1.Utils.toArray(args.fields[fieldName], 'base64'));
148
+ }
149
+ catch (_) {
150
+ throw new WalletError_js_1.WalletError(`Decryption of the "${fieldName}" field with its revelation key failed.`);
151
+ }
152
+ // Encrypt masterFieldKey for self
153
+ const { ciphertext: encryptedFieldRevelationKey } = await this.proto.encrypt({
154
+ plaintext: masterFieldKey,
155
+ protocolID: [2, 'certificate field encryption'],
156
+ keyID: `${args.serialNumber} ${fieldName}`,
157
+ counterparty: 'self'
158
+ });
159
+ // Add encryptedFieldRevelationKey to fieldRevelationKeyring
160
+ masterKeyringForSelf[fieldName] = index_js_1.Utils.toBase64(encryptedFieldRevelationKey);
161
+ }
162
+ const cert = {
163
+ type: args.type,
164
+ serialNumber: args.serialNumber,
165
+ subject: ourIdentityKey,
166
+ certifier: args.certifier,
167
+ fields: args.fields,
168
+ revocationOutpoint: args.revocationOutpoint,
169
+ signature: args.signature
170
+ };
171
+ await this.activeStorageProvider.storeCertificateAndMasterKeyring(cert, masterKeyringForSelf);
172
+ if (this.syncAfterWrite) {
173
+ await this.syncPrimaryStorageToAuxiliary();
174
+ }
175
+ return cert;
176
+ }
177
+ else if (args.acquisitionProtocol === 'issuance') {
178
+ // TODO: Pull code from CWI Core
179
+ // Put this code into a private method for talking to a certifier
180
+ // Get the certificate and store it with `await this.activeStorageProvider.storeCertificateAndMasterKeyring(cert, masterKeyringForSelf)`
181
+ // Get certificate from backend
182
+ // Validate that we can actually decrypt the master keyring
183
+ // Store certificate and master keyring
184
+ // store
185
+ if (this.syncAfterWrite) {
186
+ await this.syncPrimaryStorageToAuxiliary();
187
+ }
188
+ }
189
+ else {
190
+ throw new WalletError_js_1.WalletError(`Unknown certificate acquisition protocol: ${args.acquisitionProtocol}`);
191
+ }
192
+ }
193
+ async listCertificates(args) {
194
+ return await this.activeStorageProvider.listCertificates(args);
195
+ }
196
+ async proveCertificate(args) {
197
+ if (args.privileged) {
198
+ throw new WalletError_js_1.WalletError(this.privilegedError);
199
+ }
200
+ const masterKeyring = await this.activeStorageProvider.findMasterKeyringForCertificate(args.certificate.type, args.certificate.serialNumber);
201
+ const masterCertificate = new mod_js_1.MasterCertificate(args.certificate.type, args.certificate.serialNumber, args.certificate.subject, args.certificate.certifier, args.certificate.revocationOutpoint, args.certificate.fields, masterKeyring, args.certificate.signature);
202
+ const keyringForVerifier = await masterCertificate.createKeyringForVerifier(this.proto, args.verifier, args.fieldsToReveal);
203
+ return {
204
+ keyringForVerifier
205
+ };
206
+ }
207
+ async relinquishCertificate(args) {
208
+ await this.activeStorageProvider.relinquishCertificate(args);
209
+ if (this.syncAfterWrite) {
210
+ await this.syncPrimaryStorageToAuxiliary();
211
+ }
212
+ return { relinquished: true };
213
+ }
214
+ async discoverByIdentityKey(args) {
215
+ // SOW E
216
+ throw new Error('todo');
217
+ }
218
+ async discoverByAttributes(args) {
219
+ // SOW E
220
+ throw new Error('todo');
221
+ }
222
+ async isAuthenticated(args) {
223
+ return { authenticated: true };
224
+ }
225
+ async waitForAuthentication(args) {
226
+ return { authenticated: true };
227
+ }
228
+ async getHeight(args) {
229
+ const height = await this.activeStorageProvider.getHeight();
230
+ return { height };
231
+ }
232
+ async getHeaderForHeight(args) {
233
+ return this.activeStorageProvider.getHeaderForHeight(args);
234
+ }
235
+ async getNetwork(args) {
236
+ return { network: this.network };
237
+ }
238
+ async getVersion(args) {
239
+ return { version: 'signer-1.0.0' };
240
+ }
241
+ // Helper methods
242
+ getKnownTxids(newKnownTxids) {
243
+ if (newKnownTxids) {
244
+ for (const txid of newKnownTxids)
245
+ this.beef.mergeTxidOnly(txid);
246
+ }
247
+ const r = this.beef.sortTxs();
248
+ const knownTxids = r.valid.concat(r.txidOnly);
249
+ return knownTxids;
250
+ }
251
+ getClientChangeKeyPair() {
252
+ const kp = {
253
+ privateKey: this.keyDeriver.rootKey.toString(),
254
+ publicKey: this.keyDeriver.rootKey.toPublicKey().toString()
255
+ };
256
+ return kp;
257
+ }
258
+ }
259
+ exports.default = WalletSigner;
260
+ //# sourceMappingURL=WalletSigner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WalletSigner.js","sourceRoot":"","sources":["../../../../src/wallet/WalletSigner.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,269 @@
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 index_1 = require("../../primitives/index");
7
+ const CachedKeyDeriver_1 = __importDefault(require("../../wallet/CachedKeyDeriver"));
8
+ const KeyDeriver_1 = __importDefault(require("../../wallet/KeyDeriver"));
9
+ describe('CachedKeyDeriver', () => {
10
+ let mockKeyDeriver;
11
+ let cachedKeyDeriver;
12
+ const rootKey = new index_1.PrivateKey(1);
13
+ beforeEach(() => {
14
+ // Reset the mocks and create a new CachedKeyDeriver instance before each test
15
+ jest.clearAllMocks();
16
+ mockKeyDeriver = new KeyDeriver_1.default(rootKey);
17
+ // Mock the methods of KeyDeriver
18
+ mockKeyDeriver.derivePublicKey = jest.fn();
19
+ mockKeyDeriver.derivePrivateKey = jest.fn();
20
+ mockKeyDeriver.deriveSymmetricKey = jest.fn();
21
+ mockKeyDeriver.revealCounterpartySecret = jest.fn();
22
+ mockKeyDeriver.revealSpecificSecret = jest.fn();
23
+ // Replace the internal keyDeriver instance with the mocked one
24
+ cachedKeyDeriver = new CachedKeyDeriver_1.default(rootKey);
25
+ cachedKeyDeriver.keyDeriver = mockKeyDeriver;
26
+ });
27
+ describe('derivePublicKey', () => {
28
+ it('should call derivePublicKey on KeyDeriver and cache the result', () => {
29
+ const protocolID = [0, 'testprotocol'];
30
+ const keyID = 'key1';
31
+ const counterparty = 'self';
32
+ const publicKey = new index_1.PublicKey(0);
33
+ mockKeyDeriver.derivePublicKey.mockReturnValue(publicKey);
34
+ // First call - should invoke the underlying method
35
+ const result1 = cachedKeyDeriver.derivePublicKey(protocolID, keyID, counterparty);
36
+ expect(mockKeyDeriver.derivePublicKey).toHaveBeenCalledTimes(1);
37
+ expect(result1).toBe(publicKey);
38
+ // Second call with the same parameters - should retrieve from cache
39
+ const result2 = cachedKeyDeriver.derivePublicKey(protocolID, keyID, counterparty);
40
+ expect(mockKeyDeriver.derivePublicKey).toHaveBeenCalledTimes(1); // No additional calls
41
+ expect(result2).toBe(publicKey);
42
+ });
43
+ it('should handle different parameters correctly', () => {
44
+ const protocolID1 = [0, 'protocol1'];
45
+ const protocolID2 = [1, 'protocol2'];
46
+ const keyID1 = 'key1';
47
+ const keyID2 = 'key2';
48
+ const counterparty1 = 'self';
49
+ const counterparty2 = 'anyone';
50
+ const publicKey1 = new index_1.PublicKey(0);
51
+ const publicKey2 = new index_1.PublicKey(0);
52
+ mockKeyDeriver.derivePublicKey
53
+ .mockReturnValueOnce(publicKey1)
54
+ .mockReturnValueOnce(publicKey2);
55
+ // Different parameters - should not hit cache
56
+ const result1 = cachedKeyDeriver.derivePublicKey(protocolID1, keyID1, counterparty1);
57
+ const result2 = cachedKeyDeriver.derivePublicKey(protocolID2, keyID2, counterparty2);
58
+ expect(mockKeyDeriver.derivePublicKey).toHaveBeenCalledTimes(2);
59
+ expect(result1).toBe(publicKey1);
60
+ expect(result2).toBe(publicKey2);
61
+ });
62
+ });
63
+ describe('derivePrivateKey', () => {
64
+ it('should call derivePrivateKey on KeyDeriver and cache the result', () => {
65
+ const protocolID = [1, 'testprotocol'];
66
+ const keyID = 'key1';
67
+ const counterparty = 'anyone';
68
+ const privateKey = new index_1.PrivateKey();
69
+ mockKeyDeriver.derivePrivateKey.mockReturnValue(privateKey);
70
+ // First call - should invoke the underlying method
71
+ const result1 = cachedKeyDeriver.derivePrivateKey(protocolID, keyID, counterparty);
72
+ expect(mockKeyDeriver.derivePrivateKey).toHaveBeenCalledTimes(1);
73
+ expect(result1).toBe(privateKey);
74
+ // Second call with the same parameters - should retrieve from cache
75
+ const result2 = cachedKeyDeriver.derivePrivateKey(protocolID, keyID, counterparty);
76
+ expect(mockKeyDeriver.derivePrivateKey).toHaveBeenCalledTimes(1);
77
+ expect(result2).toBe(privateKey);
78
+ });
79
+ it('should differentiate cache entries based on parameters', () => {
80
+ const protocolID = [1, 'testprotocol'];
81
+ const keyID = 'key1';
82
+ const counterparty = 'anyone';
83
+ const privateKey1 = new index_1.PrivateKey();
84
+ const privateKey2 = new index_1.PrivateKey();
85
+ mockKeyDeriver.derivePrivateKey
86
+ .mockReturnValueOnce(privateKey1)
87
+ .mockReturnValueOnce(privateKey2);
88
+ // First call
89
+ const result1 = cachedKeyDeriver.derivePrivateKey(protocolID, keyID, counterparty);
90
+ expect(result1).toBe(privateKey1);
91
+ // Second call with different keyID
92
+ const result2 = cachedKeyDeriver.derivePrivateKey(protocolID, 'key2', counterparty);
93
+ expect(result2).toBe(privateKey2);
94
+ expect(mockKeyDeriver.derivePrivateKey).toHaveBeenCalledTimes(2);
95
+ });
96
+ });
97
+ describe('deriveSymmetricKey', () => {
98
+ it('should call deriveSymmetricKey on KeyDeriver and cache the result', () => {
99
+ const protocolID = [2, 'testprotocol'];
100
+ const keyID = 'key1';
101
+ const counterparty = new index_1.PublicKey(0);
102
+ const symmetricKey = new index_1.SymmetricKey(0);
103
+ mockKeyDeriver.deriveSymmetricKey.mockReturnValue(symmetricKey);
104
+ // First call
105
+ const result1 = cachedKeyDeriver.deriveSymmetricKey(protocolID, keyID, counterparty);
106
+ expect(mockKeyDeriver.deriveSymmetricKey).toHaveBeenCalledTimes(1);
107
+ expect(result1).toBe(symmetricKey);
108
+ // Second call with same parameters
109
+ const result2 = cachedKeyDeriver.deriveSymmetricKey(protocolID, keyID, counterparty);
110
+ expect(mockKeyDeriver.deriveSymmetricKey).toHaveBeenCalledTimes(1);
111
+ expect(result2).toBe(symmetricKey);
112
+ });
113
+ it('should throw an error when KeyDeriver throws an error', () => {
114
+ const protocolID = [2, 'testprotocol'];
115
+ const keyID = 'key1';
116
+ const counterparty = 'anyone';
117
+ mockKeyDeriver.deriveSymmetricKey.mockImplementation(() => {
118
+ throw new Error('Test error');
119
+ });
120
+ expect(() => {
121
+ cachedKeyDeriver.deriveSymmetricKey(protocolID, keyID, counterparty);
122
+ }).toThrow('Test error');
123
+ });
124
+ });
125
+ describe('revealCounterpartySecret', () => {
126
+ it('should call revealCounterpartySecret on KeyDeriver and cache the result', () => {
127
+ const counterparty = new index_1.PublicKey(0);
128
+ const secret = [1, 2, 3];
129
+ mockKeyDeriver.revealCounterpartySecret.mockReturnValue(secret);
130
+ // First call
131
+ const result1 = cachedKeyDeriver.revealCounterpartySecret(counterparty);
132
+ expect(mockKeyDeriver.revealCounterpartySecret).toHaveBeenCalledTimes(1);
133
+ expect(result1).toBe(secret);
134
+ // Second call with same parameters
135
+ const result2 = cachedKeyDeriver.revealCounterpartySecret(counterparty);
136
+ expect(mockKeyDeriver.revealCounterpartySecret).toHaveBeenCalledTimes(1);
137
+ expect(result2).toBe(secret);
138
+ });
139
+ });
140
+ describe('revealSpecificSecret', () => {
141
+ it('should call revealSpecificSecret on KeyDeriver and cache the result', () => {
142
+ const counterparty = 'self';
143
+ const protocolID = [0, 'testprotocol'];
144
+ const keyID = 'key1';
145
+ const secret = [4, 5, 6];
146
+ mockKeyDeriver.revealSpecificSecret.mockReturnValue(secret);
147
+ // First call
148
+ const result1 = cachedKeyDeriver.revealSpecificSecret(counterparty, protocolID, keyID);
149
+ expect(mockKeyDeriver.revealSpecificSecret).toHaveBeenCalledTimes(1);
150
+ expect(result1).toBe(secret);
151
+ // Second call with same parameters
152
+ const result2 = cachedKeyDeriver.revealSpecificSecret(counterparty, protocolID, keyID);
153
+ expect(mockKeyDeriver.revealSpecificSecret).toHaveBeenCalledTimes(1);
154
+ expect(result2).toBe(secret);
155
+ });
156
+ it('should handle different parameters correctly', () => {
157
+ const counterparty = 'self';
158
+ const protocolID1 = [0, 'protocol1'];
159
+ const protocolID2 = [1, 'protocol2'];
160
+ const keyID1 = 'key1';
161
+ const keyID2 = 'key2';
162
+ const secret1 = [4, 5, 6];
163
+ const secret2 = [7, 8, 9];
164
+ mockKeyDeriver.revealSpecificSecret
165
+ .mockReturnValueOnce(secret1)
166
+ .mockReturnValueOnce(secret2);
167
+ // First call
168
+ const result1 = cachedKeyDeriver.revealSpecificSecret(counterparty, protocolID1, keyID1);
169
+ expect(result1).toBe(secret1);
170
+ // Second call with different parameters
171
+ const result2 = cachedKeyDeriver.revealSpecificSecret(counterparty, protocolID2, keyID2);
172
+ expect(result2).toBe(secret2);
173
+ expect(mockKeyDeriver.revealSpecificSecret).toHaveBeenCalledTimes(2);
174
+ });
175
+ });
176
+ describe('Cache management', () => {
177
+ it('should not exceed the max cache size and evict least recently used items', () => {
178
+ const maxCacheSize = 5;
179
+ // Create a new CachedKeyDeriver with a small cache size
180
+ cachedKeyDeriver = new CachedKeyDeriver_1.default(rootKey, { maxCacheSize });
181
+ cachedKeyDeriver.keyDeriver = mockKeyDeriver;
182
+ const protocolID = [0, 'testprotocol'];
183
+ const counterparty = 'self';
184
+ // Mock return values
185
+ const mockResults = [1, 2, 3, 4, 5, 6].map(n => new index_1.PublicKey(0));
186
+ mockKeyDeriver.derivePublicKey
187
+ .mockReturnValueOnce(mockResults[0])
188
+ .mockReturnValueOnce(mockResults[1])
189
+ .mockReturnValueOnce(mockResults[2])
190
+ .mockReturnValueOnce(mockResults[3])
191
+ .mockReturnValueOnce(mockResults[4])
192
+ .mockReturnValueOnce(mockResults[5]);
193
+ // Add entries to fill the cache
194
+ for (let i = 0; i < maxCacheSize; i++) {
195
+ cachedKeyDeriver.derivePublicKey(protocolID, `key${i}`, counterparty);
196
+ }
197
+ // Cache should be full now
198
+ expect(cachedKeyDeriver.cache.size).toBe(maxCacheSize);
199
+ // Access one of the earlier keys to make it recently used
200
+ cachedKeyDeriver.derivePublicKey(protocolID, 'key0', counterparty);
201
+ // Add one more entry to exceed the cache size
202
+ cachedKeyDeriver.derivePublicKey(protocolID, 'key5', counterparty);
203
+ // Cache size should still be maxCacheSize
204
+ expect(cachedKeyDeriver.cache.size).toBe(maxCacheSize);
205
+ // The least recently used item (key1) should have been evicted
206
+ // The cache should contain keys: key0, key2, key3, key4, key5
207
+ expect(Array.from(cachedKeyDeriver.cache.keys())).toEqual([
208
+ expect.stringContaining('key2'),
209
+ expect.stringContaining('key3'),
210
+ expect.stringContaining('key4'),
211
+ expect.stringContaining('key0'),
212
+ expect.stringContaining('key5')
213
+ ]);
214
+ });
215
+ it('should update the recentness of cache entries on access', () => {
216
+ const maxCacheSize = 3;
217
+ cachedKeyDeriver = new CachedKeyDeriver_1.default(rootKey, { maxCacheSize });
218
+ cachedKeyDeriver.keyDeriver = mockKeyDeriver;
219
+ const protocolID = [0, 'testprotocol'];
220
+ const counterparty = 'self';
221
+ const keys = ['key1', 'key2', 'key3'];
222
+ const publicKeys = keys.map(() => new index_1.PublicKey(0));
223
+ mockKeyDeriver.derivePublicKey
224
+ .mockReturnValueOnce(publicKeys[0])
225
+ .mockReturnValueOnce(publicKeys[1])
226
+ .mockReturnValueOnce(publicKeys[2]);
227
+ // Fill the cache
228
+ keys.forEach(keyID => {
229
+ cachedKeyDeriver.derivePublicKey(protocolID, keyID, counterparty);
230
+ });
231
+ // Access 'key1' to make it most recently used
232
+ cachedKeyDeriver.derivePublicKey(protocolID, 'key1', counterparty);
233
+ // Add a new key to trigger eviction
234
+ const newKeyID = 'key4';
235
+ const newPublicKey = new index_1.PublicKey(0);
236
+ mockKeyDeriver.derivePublicKey.mockReturnValueOnce(newPublicKey);
237
+ cachedKeyDeriver.derivePublicKey(protocolID, newKeyID, counterparty);
238
+ // 'key2' should be evicted as it is the least recently used
239
+ expect(Array.from(cachedKeyDeriver.cache.keys())).toEqual([
240
+ expect.stringContaining('key3'),
241
+ expect.stringContaining('key1'),
242
+ expect.stringContaining('key4')
243
+ ]);
244
+ });
245
+ });
246
+ describe('Performance considerations', () => {
247
+ it('should improve performance by caching expensive operations', () => {
248
+ const protocolID = [0, 'testprotocol'];
249
+ const keyID = 'key1';
250
+ const counterparty = 'self';
251
+ const publicKey = new index_1.PublicKey(0);
252
+ // Simulate an expensive operation
253
+ mockKeyDeriver.derivePublicKey.mockImplementation(() => {
254
+ const start = Date.now();
255
+ while (Date.now() - start < 50) { } // Busy wait for 50ms
256
+ return publicKey;
257
+ });
258
+ const startTime = Date.now();
259
+ cachedKeyDeriver.derivePublicKey(protocolID, keyID, counterparty);
260
+ const firstCallDuration = Date.now() - startTime;
261
+ const startTime2 = Date.now();
262
+ cachedKeyDeriver.derivePublicKey(protocolID, keyID, counterparty);
263
+ const secondCallDuration = Date.now() - startTime2;
264
+ expect(firstCallDuration).toBeGreaterThanOrEqual(50);
265
+ expect(secondCallDuration).toBeLessThan(10); // Should be much faster due to caching
266
+ });
267
+ });
268
+ });
269
+ //# sourceMappingURL=CachedKeyDeriver.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CachedKeyDeriver.test.js","sourceRoot":"","sources":["../../../../../src/wallet/__tests/CachedKeyDeriver.test.ts"],"names":[],"mappings":"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"}