@bsv/sdk 1.6.15 → 1.6.17

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 (138) hide show
  1. package/dist/cjs/package.json +1 -1
  2. package/dist/cjs/src/auth/Peer.js +16 -25
  3. package/dist/cjs/src/auth/Peer.js.map +1 -1
  4. package/dist/cjs/src/auth/SessionManager.js +2 -4
  5. package/dist/cjs/src/auth/SessionManager.js.map +1 -1
  6. package/dist/cjs/src/auth/certificates/Certificate.js +2 -4
  7. package/dist/cjs/src/auth/certificates/Certificate.js.map +1 -1
  8. package/dist/cjs/src/auth/certificates/MasterCertificate.js +1 -1
  9. package/dist/cjs/src/auth/certificates/MasterCertificate.js.map +1 -1
  10. package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js +1 -1
  11. package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
  12. package/dist/cjs/src/auth/clients/AuthFetch.js +2 -4
  13. package/dist/cjs/src/auth/clients/AuthFetch.js.map +1 -1
  14. package/dist/cjs/src/compat/ECIES.js +1 -1
  15. package/dist/cjs/src/compat/ECIES.js.map +1 -1
  16. package/dist/cjs/src/compat/Mnemonic.js +2 -2
  17. package/dist/cjs/src/compat/Mnemonic.js.map +1 -1
  18. package/dist/cjs/src/identity/IdentityClient.js +1 -1
  19. package/dist/cjs/src/identity/IdentityClient.js.map +1 -1
  20. package/dist/cjs/src/kvstore/LocalKVStore.js +1 -2
  21. package/dist/cjs/src/kvstore/LocalKVStore.js.map +1 -1
  22. package/dist/cjs/src/overlay-tools/LookupResolver.js +6 -8
  23. package/dist/cjs/src/overlay-tools/LookupResolver.js.map +1 -1
  24. package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js +9 -10
  25. package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
  26. package/dist/cjs/src/primitives/AESGCM.js +1 -2
  27. package/dist/cjs/src/primitives/AESGCM.js.map +1 -1
  28. package/dist/cjs/src/primitives/BigNumber.js +2 -3
  29. package/dist/cjs/src/primitives/BigNumber.js.map +1 -1
  30. package/dist/cjs/src/primitives/Curve.js +2 -3
  31. package/dist/cjs/src/primitives/Curve.js.map +1 -1
  32. package/dist/cjs/src/primitives/ECDSA.js +174 -396
  33. package/dist/cjs/src/primitives/ECDSA.js.map +1 -1
  34. package/dist/cjs/src/primitives/JacobianPoint.js +1 -2
  35. package/dist/cjs/src/primitives/JacobianPoint.js.map +1 -1
  36. package/dist/cjs/src/primitives/Point.js +279 -126
  37. package/dist/cjs/src/primitives/Point.js.map +1 -1
  38. package/dist/cjs/src/primitives/Polynomial.js +1 -1
  39. package/dist/cjs/src/primitives/Polynomial.js.map +1 -1
  40. package/dist/cjs/src/primitives/PrivateKey.js +19 -2
  41. package/dist/cjs/src/primitives/PrivateKey.js.map +1 -1
  42. package/dist/cjs/src/primitives/PublicKey.js +19 -2
  43. package/dist/cjs/src/primitives/PublicKey.js.map +1 -1
  44. package/dist/cjs/src/primitives/Random.js +1 -2
  45. package/dist/cjs/src/primitives/Random.js.map +1 -1
  46. package/dist/cjs/src/primitives/TransactionSignature.js +5 -7
  47. package/dist/cjs/src/primitives/TransactionSignature.js.map +1 -1
  48. package/dist/cjs/src/primitives/utils.js +1 -2
  49. package/dist/cjs/src/primitives/utils.js.map +1 -1
  50. package/dist/cjs/src/registry/RegistryClient.js +2 -4
  51. package/dist/cjs/src/registry/RegistryClient.js.map +1 -1
  52. package/dist/cjs/src/script/Spend.js +1 -2
  53. package/dist/cjs/src/script/Spend.js.map +1 -1
  54. package/dist/cjs/src/script/templates/P2PKH.js +4 -4
  55. package/dist/cjs/src/script/templates/P2PKH.js.map +1 -1
  56. package/dist/cjs/src/script/templates/PushDrop.js +7 -8
  57. package/dist/cjs/src/script/templates/PushDrop.js.map +1 -1
  58. package/dist/cjs/src/script/templates/RPuzzle.js +7 -6
  59. package/dist/cjs/src/script/templates/RPuzzle.js.map +1 -1
  60. package/dist/cjs/src/storage/StorageDownloader.js +1 -1
  61. package/dist/cjs/src/storage/StorageDownloader.js.map +1 -1
  62. package/dist/cjs/src/storage/StorageUploader.js +6 -9
  63. package/dist/cjs/src/storage/StorageUploader.js.map +1 -1
  64. package/dist/cjs/src/transaction/Beef.js +2 -3
  65. package/dist/cjs/src/transaction/Beef.js.map +1 -1
  66. package/dist/cjs/src/transaction/MerklePath.js +9 -12
  67. package/dist/cjs/src/transaction/MerklePath.js.map +1 -1
  68. package/dist/cjs/src/transaction/Transaction.js +15 -22
  69. package/dist/cjs/src/transaction/Transaction.js.map +1 -1
  70. package/dist/cjs/src/transaction/broadcasters/ARC.js +3 -3
  71. package/dist/cjs/src/transaction/broadcasters/ARC.js.map +1 -1
  72. package/dist/cjs/src/transaction/broadcasters/Teranode.js +2 -3
  73. package/dist/cjs/src/transaction/broadcasters/Teranode.js.map +1 -1
  74. package/dist/cjs/src/transaction/broadcasters/WhatsOnChainBroadcaster.js +2 -3
  75. package/dist/cjs/src/transaction/broadcasters/WhatsOnChainBroadcaster.js.map +1 -1
  76. package/dist/cjs/src/transaction/chaintrackers/BlockHeadersService.js +2 -2
  77. package/dist/cjs/src/transaction/chaintrackers/BlockHeadersService.js.map +1 -1
  78. package/dist/cjs/src/transaction/chaintrackers/WhatsOnChain.js +2 -2
  79. package/dist/cjs/src/transaction/chaintrackers/WhatsOnChain.js.map +1 -1
  80. package/dist/cjs/src/transaction/http/FetchHttpClient.js +1 -2
  81. package/dist/cjs/src/transaction/http/FetchHttpClient.js.map +1 -1
  82. package/dist/cjs/src/wallet/CachedKeyDeriver.js +13 -2
  83. package/dist/cjs/src/wallet/CachedKeyDeriver.js.map +1 -1
  84. package/dist/cjs/src/wallet/KeyDeriver.js +12 -8
  85. package/dist/cjs/src/wallet/KeyDeriver.js.map +1 -1
  86. package/dist/cjs/src/wallet/ProtoWallet.js +26 -27
  87. package/dist/cjs/src/wallet/ProtoWallet.js.map +1 -1
  88. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js +2 -3
  89. package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
  90. package/dist/cjs/src/wallet/substrates/HTTPWalletWire.js +1 -1
  91. package/dist/cjs/src/wallet/substrates/HTTPWalletWire.js.map +1 -1
  92. package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js +12 -19
  93. package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js.map +1 -1
  94. package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
  95. package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js +2 -2
  96. package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
  97. package/dist/esm/src/primitives/ECDSA.js +174 -395
  98. package/dist/esm/src/primitives/ECDSA.js.map +1 -1
  99. package/dist/esm/src/primitives/Point.js +254 -91
  100. package/dist/esm/src/primitives/Point.js.map +1 -1
  101. package/dist/esm/src/primitives/PrivateKey.js +19 -2
  102. package/dist/esm/src/primitives/PrivateKey.js.map +1 -1
  103. package/dist/esm/src/primitives/PublicKey.js +19 -2
  104. package/dist/esm/src/primitives/PublicKey.js.map +1 -1
  105. package/dist/esm/src/wallet/CachedKeyDeriver.js +20 -1
  106. package/dist/esm/src/wallet/CachedKeyDeriver.js.map +1 -1
  107. package/dist/esm/src/wallet/KeyDeriver.js +14 -6
  108. package/dist/esm/src/wallet/KeyDeriver.js.map +1 -1
  109. package/dist/esm/src/wallet/ProtoWallet.js +2 -2
  110. package/dist/esm/src/wallet/ProtoWallet.js.map +1 -1
  111. package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
  112. package/dist/types/src/auth/certificates/__tests/CompletedProtoWallet.d.ts.map +1 -1
  113. package/dist/types/src/primitives/ECDSA.d.ts.map +1 -1
  114. package/dist/types/src/primitives/Point.d.ts.map +1 -1
  115. package/dist/types/src/primitives/PrivateKey.d.ts +3 -1
  116. package/dist/types/src/primitives/PrivateKey.d.ts.map +1 -1
  117. package/dist/types/src/primitives/PublicKey.d.ts +3 -1
  118. package/dist/types/src/primitives/PublicKey.d.ts.map +1 -1
  119. package/dist/types/src/wallet/CachedKeyDeriver.d.ts +10 -2
  120. package/dist/types/src/wallet/CachedKeyDeriver.d.ts.map +1 -1
  121. package/dist/types/src/wallet/KeyDeriver.d.ts +5 -2
  122. package/dist/types/src/wallet/KeyDeriver.d.ts.map +1 -1
  123. package/dist/types/src/wallet/ProtoWallet.d.ts.map +1 -1
  124. package/dist/types/tsconfig.types.tsbuildinfo +1 -1
  125. package/dist/umd/bundle.js +1 -1
  126. package/docs/reference/primitives.md +179 -383
  127. package/docs/reference/wallet.md +25 -6
  128. package/package.json +1 -1
  129. package/src/auth/certificates/__tests/CompletedProtoWallet.ts +3 -2
  130. package/src/primitives/ECDSA.ts +218 -488
  131. package/src/primitives/Point.ts +291 -94
  132. package/src/primitives/PrivateKey.ts +22 -2
  133. package/src/primitives/PublicKey.ts +22 -2
  134. package/src/transaction/__tests/Transaction.test.ts +1 -1
  135. package/src/wallet/CachedKeyDeriver.ts +32 -8
  136. package/src/wallet/KeyDeriver.ts +24 -7
  137. package/src/wallet/ProtoWallet.ts +3 -2
  138. package/src/wallet/__tests/ProtoWallet.test.ts +46 -1
@@ -1,5 +1,6 @@
1
1
  import ProtoWallet from '../../wallet/ProtoWallet'
2
- import { Utils, PrivateKey, Hash } from '../../primitives/index'
2
+ import { Utils, PrivateKey, Hash, Random } from '../../primitives/index'
3
+ import { createNonce, verifyNonce } from '../../auth/utils'
3
4
 
4
5
  const sampleData = [3, 1, 4, 1, 5, 9]
5
6
 
@@ -425,6 +426,50 @@ describe('ProtoWallet', () => {
425
426
  expect(plaintext).toEqual(explicitSelfPlaintext)
426
427
  expect(plaintext).toEqual(sampleData)
427
428
  })
429
+ it('Efficiently executes hot code paths', async () => {
430
+ const alicePriv = PrivateKey.fromRandom()
431
+ const alice = new ProtoWallet(alicePriv)
432
+
433
+ const bobPriv = PrivateKey.fromRandom()
434
+ const bob = new ProtoWallet(bobPriv)
435
+
436
+ const ad1 = Random(200)
437
+ const bd1 = Random(100)
438
+
439
+ const an1 = await createNonce((alice as any), bobPriv.toPublicKey().toString())
440
+ const { signature: as1 } = await alice.createSignature({
441
+ data: ad1,
442
+ protocolID: [0, 'tests'],
443
+ keyID: '1',
444
+ counterparty: bobPriv.toPublicKey().toString()
445
+ })
446
+
447
+ await verifyNonce(an1, (bob as any), alicePriv.toPublicKey().toString())
448
+ await bob.verifySignature({
449
+ signature: as1,
450
+ data: ad1,
451
+ protocolID: [0, 'tests'],
452
+ keyID: '1',
453
+ counterparty: alicePriv.toPublicKey().toString()
454
+ })
455
+
456
+ const bn1 = await createNonce((bob as any), alicePriv.toPublicKey().toString())
457
+ const { signature: bs1 } = await bob.createSignature({
458
+ data: bd1,
459
+ protocolID: [0, 'tests'],
460
+ keyID: '1',
461
+ counterparty: alicePriv.toPublicKey().toString()
462
+ })
463
+
464
+ await verifyNonce(bn1, (alice as any), bobPriv.toPublicKey().toString())
465
+ await alice.verifySignature({
466
+ signature: bs1,
467
+ data: bd1,
468
+ protocolID: [0, 'tests'],
469
+ keyID: '1',
470
+ counterparty: bobPriv.toPublicKey().toString()
471
+ })
472
+ })
428
473
  describe('ProtoWallet Key Linkage Revelation', () => {
429
474
  it('Validates the revealCounterpartyKeyLinkage function', async () => {
430
475
  // Initialize keys