@bsv/sdk 2.1.0 → 2.1.2
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.
- package/README.md +7 -7
- package/dist/cjs/package.json +1 -1
- package/dist/cjs/src/auth/Peer.js +8 -13
- package/dist/cjs/src/auth/Peer.js.map +1 -1
- package/dist/cjs/src/auth/SessionManager.js +4 -7
- package/dist/cjs/src/auth/SessionManager.js.map +1 -1
- package/dist/cjs/src/auth/certificates/MasterCertificate.js +1 -1
- package/dist/cjs/src/auth/certificates/MasterCertificate.js.map +1 -1
- package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js +1 -1
- package/dist/cjs/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
- package/dist/cjs/src/auth/clients/AuthFetch.js +32 -32
- package/dist/cjs/src/auth/clients/AuthFetch.js.map +1 -1
- package/dist/cjs/src/auth/transports/SimplifiedFetchTransport.js +4 -4
- package/dist/cjs/src/auth/transports/SimplifiedFetchTransport.js.map +1 -1
- package/dist/cjs/src/compat/ECIES.js +29 -34
- package/dist/cjs/src/compat/ECIES.js.map +1 -1
- package/dist/cjs/src/compat/HD.js +9 -4
- package/dist/cjs/src/compat/HD.js.map +1 -1
- package/dist/cjs/src/compat/Mnemonic.js +12 -12
- package/dist/cjs/src/compat/Mnemonic.js.map +1 -1
- package/dist/cjs/src/identity/ContactsManager.js +212 -234
- package/dist/cjs/src/identity/ContactsManager.js.map +1 -1
- package/dist/cjs/src/identity/IdentityClient.js +199 -63
- package/dist/cjs/src/identity/IdentityClient.js.map +1 -1
- package/dist/cjs/src/kvstore/GlobalKVStore.js +30 -31
- package/dist/cjs/src/kvstore/GlobalKVStore.js.map +1 -1
- package/dist/cjs/src/kvstore/LocalKVStore.js +9 -9
- package/dist/cjs/src/kvstore/LocalKVStore.js.map +1 -1
- package/dist/cjs/src/kvstore/kvStoreInterpreter.js +2 -2
- package/dist/cjs/src/kvstore/kvStoreInterpreter.js.map +1 -1
- package/dist/cjs/src/messages/SignedMessage.js +1 -1
- package/dist/cjs/src/messages/SignedMessage.js.map +1 -1
- package/dist/cjs/src/overlay-tools/Historian.js +1 -1
- package/dist/cjs/src/overlay-tools/Historian.js.map +1 -1
- package/dist/cjs/src/overlay-tools/LookupResolver.js +213 -93
- package/dist/cjs/src/overlay-tools/LookupResolver.js.map +1 -1
- package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js +75 -146
- package/dist/cjs/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
- package/dist/cjs/src/primitives/AESGCM.js +2 -2
- package/dist/cjs/src/primitives/AESGCM.js.map +1 -1
- package/dist/cjs/src/primitives/BigNumber.js +164 -148
- package/dist/cjs/src/primitives/BigNumber.js.map +1 -1
- package/dist/cjs/src/primitives/Curve.js +17 -15
- package/dist/cjs/src/primitives/Curve.js.map +1 -1
- package/dist/cjs/src/primitives/ECDSA.js +12 -7
- package/dist/cjs/src/primitives/ECDSA.js.map +1 -1
- package/dist/cjs/src/primitives/Hash.js +312 -105
- package/dist/cjs/src/primitives/Hash.js.map +1 -1
- package/dist/cjs/src/primitives/JacobianPoint.js +8 -8
- package/dist/cjs/src/primitives/JacobianPoint.js.map +1 -1
- package/dist/cjs/src/primitives/K256.js +3 -3
- package/dist/cjs/src/primitives/K256.js.map +1 -1
- package/dist/cjs/src/primitives/Point.js +36 -40
- package/dist/cjs/src/primitives/Point.js.map +1 -1
- package/dist/cjs/src/primitives/PrivateKey.js +4 -4
- package/dist/cjs/src/primitives/PrivateKey.js.map +1 -1
- package/dist/cjs/src/primitives/PublicKey.js +4 -4
- package/dist/cjs/src/primitives/PublicKey.js.map +1 -1
- package/dist/cjs/src/primitives/Random.js +10 -14
- package/dist/cjs/src/primitives/Random.js.map +1 -1
- package/dist/cjs/src/primitives/ReaderUint8Array.js +6 -6
- package/dist/cjs/src/primitives/ReaderUint8Array.js.map +1 -1
- package/dist/cjs/src/primitives/Schnorr.js +2 -2
- package/dist/cjs/src/primitives/Schnorr.js.map +1 -1
- package/dist/cjs/src/primitives/Secp256r1.js +2 -1
- package/dist/cjs/src/primitives/Secp256r1.js.map +1 -1
- package/dist/cjs/src/primitives/Signature.js +8 -8
- package/dist/cjs/src/primitives/Signature.js.map +1 -1
- package/dist/cjs/src/primitives/SymmetricKey.js +123 -1
- package/dist/cjs/src/primitives/SymmetricKey.js.map +1 -1
- package/dist/cjs/src/primitives/TransactionSignature.js +20 -21
- package/dist/cjs/src/primitives/TransactionSignature.js.map +1 -1
- package/dist/cjs/src/primitives/utils.js +39 -46
- package/dist/cjs/src/primitives/utils.js.map +1 -1
- package/dist/cjs/src/registry/RegistryClient.js +31 -23
- package/dist/cjs/src/registry/RegistryClient.js.map +1 -1
- package/dist/cjs/src/remittance/RemittanceManager.js +19 -18
- package/dist/cjs/src/remittance/RemittanceManager.js.map +1 -1
- package/dist/cjs/src/remittance/modules/BasicBRC29.js.map +1 -1
- package/dist/cjs/src/script/Script.js +93 -170
- package/dist/cjs/src/script/Script.js.map +1 -1
- package/dist/cjs/src/script/ScriptEvaluationError.js +2 -2
- package/dist/cjs/src/script/ScriptEvaluationError.js.map +1 -1
- package/dist/cjs/src/script/Spend.js +14 -12
- package/dist/cjs/src/script/Spend.js.map +1 -1
- package/dist/cjs/src/script/templates/PushDrop.js +22 -18
- package/dist/cjs/src/script/templates/PushDrop.js.map +1 -1
- package/dist/cjs/src/script/templates/RPuzzle.js +2 -4
- package/dist/cjs/src/script/templates/RPuzzle.js.map +1 -1
- package/dist/cjs/src/storage/StorageDownloader.js +42 -9
- package/dist/cjs/src/storage/StorageDownloader.js.map +1 -1
- package/dist/cjs/src/totp/totp.js +1 -1
- package/dist/cjs/src/totp/totp.js.map +1 -1
- package/dist/cjs/src/transaction/Beef.js +239 -192
- package/dist/cjs/src/transaction/Beef.js.map +1 -1
- package/dist/cjs/src/transaction/BeefConstants.js +19 -0
- package/dist/cjs/src/transaction/BeefConstants.js.map +1 -0
- package/dist/cjs/src/transaction/BeefTx.js +12 -12
- package/dist/cjs/src/transaction/BeefTx.js.map +1 -1
- package/dist/cjs/src/transaction/MerklePath.js +4 -4
- package/dist/cjs/src/transaction/MerklePath.js.map +1 -1
- package/dist/cjs/src/transaction/Transaction.js +49 -52
- package/dist/cjs/src/transaction/Transaction.js.map +1 -1
- package/dist/cjs/src/transaction/fee-models/SatoshisPerKilobyte.js +1 -1
- package/dist/cjs/src/transaction/fee-models/SatoshisPerKilobyte.js.map +1 -1
- package/dist/cjs/src/transaction/http/BinaryFetchClient.js +9 -9
- package/dist/cjs/src/transaction/http/BinaryFetchClient.js.map +1 -1
- package/dist/cjs/src/transaction/http/DefaultHttpClient.js +9 -9
- package/dist/cjs/src/transaction/http/DefaultHttpClient.js.map +1 -1
- package/dist/cjs/src/wallet/CachedKeyDeriver.js +1 -1
- package/dist/cjs/src/wallet/CachedKeyDeriver.js.map +1 -1
- package/dist/cjs/src/wallet/WalletClient.js.map +1 -1
- package/dist/cjs/src/wallet/WalletError.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js +5 -4
- package/dist/cjs/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/ReactNativeWebView.js +9 -9
- package/dist/cjs/src/wallet/substrates/ReactNativeWebView.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js +92 -92
- package/dist/cjs/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js +387 -711
- package/dist/cjs/src/wallet/substrates/WalletWireTransceiver.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/XDM.js +4 -4
- package/dist/cjs/src/wallet/substrates/XDM.js.map +1 -1
- package/dist/cjs/src/wallet/substrates/window.CWI.js +2 -2
- package/dist/cjs/src/wallet/substrates/window.CWI.js.map +1 -1
- package/dist/cjs/src/wallet/validationHelpers.js +9 -9
- package/dist/cjs/src/wallet/validationHelpers.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/src/auth/Peer.js +25 -13
- package/dist/esm/src/auth/Peer.js.map +1 -1
- package/dist/esm/src/auth/SessionManager.js +4 -7
- package/dist/esm/src/auth/SessionManager.js.map +1 -1
- package/dist/esm/src/auth/certificates/MasterCertificate.js +1 -1
- package/dist/esm/src/auth/certificates/MasterCertificate.js.map +1 -1
- package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js +1 -1
- package/dist/esm/src/auth/certificates/__tests/CompletedProtoWallet.js.map +1 -1
- package/dist/esm/src/auth/clients/AuthFetch.js +32 -32
- package/dist/esm/src/auth/clients/AuthFetch.js.map +1 -1
- package/dist/esm/src/auth/transports/SimplifiedFetchTransport.js +4 -4
- package/dist/esm/src/auth/transports/SimplifiedFetchTransport.js.map +1 -1
- package/dist/esm/src/compat/ECIES.js +29 -34
- package/dist/esm/src/compat/ECIES.js.map +1 -1
- package/dist/esm/src/compat/HD.js +9 -4
- package/dist/esm/src/compat/HD.js.map +1 -1
- package/dist/esm/src/compat/Mnemonic.js +12 -12
- package/dist/esm/src/compat/Mnemonic.js.map +1 -1
- package/dist/esm/src/identity/ContactsManager.js +212 -234
- package/dist/esm/src/identity/ContactsManager.js.map +1 -1
- package/dist/esm/src/identity/IdentityClient.js +199 -63
- package/dist/esm/src/identity/IdentityClient.js.map +1 -1
- package/dist/esm/src/kvstore/GlobalKVStore.js +30 -31
- package/dist/esm/src/kvstore/GlobalKVStore.js.map +1 -1
- package/dist/esm/src/kvstore/LocalKVStore.js +9 -9
- package/dist/esm/src/kvstore/LocalKVStore.js.map +1 -1
- package/dist/esm/src/kvstore/kvStoreInterpreter.js +2 -2
- package/dist/esm/src/kvstore/kvStoreInterpreter.js.map +1 -1
- package/dist/esm/src/messages/SignedMessage.js +1 -1
- package/dist/esm/src/messages/SignedMessage.js.map +1 -1
- package/dist/esm/src/overlay-tools/Historian.js +1 -1
- package/dist/esm/src/overlay-tools/Historian.js.map +1 -1
- package/dist/esm/src/overlay-tools/LookupResolver.js +213 -93
- package/dist/esm/src/overlay-tools/LookupResolver.js.map +1 -1
- package/dist/esm/src/overlay-tools/SHIPBroadcaster.js +74 -146
- package/dist/esm/src/overlay-tools/SHIPBroadcaster.js.map +1 -1
- package/dist/esm/src/primitives/AESGCM.js +2 -2
- package/dist/esm/src/primitives/AESGCM.js.map +1 -1
- package/dist/esm/src/primitives/BigNumber.js +167 -154
- package/dist/esm/src/primitives/BigNumber.js.map +1 -1
- package/dist/esm/src/primitives/Curve.js +17 -15
- package/dist/esm/src/primitives/Curve.js.map +1 -1
- package/dist/esm/src/primitives/ECDSA.js +12 -7
- package/dist/esm/src/primitives/ECDSA.js.map +1 -1
- package/dist/esm/src/primitives/Hash.js +316 -105
- package/dist/esm/src/primitives/Hash.js.map +1 -1
- package/dist/esm/src/primitives/JacobianPoint.js +8 -8
- package/dist/esm/src/primitives/JacobianPoint.js.map +1 -1
- package/dist/esm/src/primitives/K256.js +3 -3
- package/dist/esm/src/primitives/K256.js.map +1 -1
- package/dist/esm/src/primitives/Point.js +36 -40
- package/dist/esm/src/primitives/Point.js.map +1 -1
- package/dist/esm/src/primitives/PrivateKey.js +4 -4
- package/dist/esm/src/primitives/PrivateKey.js.map +1 -1
- package/dist/esm/src/primitives/PublicKey.js +4 -4
- package/dist/esm/src/primitives/PublicKey.js.map +1 -1
- package/dist/esm/src/primitives/Random.js +10 -14
- package/dist/esm/src/primitives/Random.js.map +1 -1
- package/dist/esm/src/primitives/ReaderUint8Array.js +6 -6
- package/dist/esm/src/primitives/ReaderUint8Array.js.map +1 -1
- package/dist/esm/src/primitives/Schnorr.js +1 -1
- package/dist/esm/src/primitives/Schnorr.js.map +1 -1
- package/dist/esm/src/primitives/Secp256r1.js +2 -1
- package/dist/esm/src/primitives/Secp256r1.js.map +1 -1
- package/dist/esm/src/primitives/Signature.js +8 -8
- package/dist/esm/src/primitives/Signature.js.map +1 -1
- package/dist/esm/src/primitives/SymmetricKey.js +123 -1
- package/dist/esm/src/primitives/SymmetricKey.js.map +1 -1
- package/dist/esm/src/primitives/TransactionSignature.js +20 -21
- package/dist/esm/src/primitives/TransactionSignature.js.map +1 -1
- package/dist/esm/src/primitives/utils.js +39 -48
- package/dist/esm/src/primitives/utils.js.map +1 -1
- package/dist/esm/src/registry/RegistryClient.js +31 -23
- package/dist/esm/src/registry/RegistryClient.js.map +1 -1
- package/dist/esm/src/remittance/RemittanceManager.js +19 -18
- package/dist/esm/src/remittance/RemittanceManager.js.map +1 -1
- package/dist/esm/src/remittance/modules/BasicBRC29.js.map +1 -1
- package/dist/esm/src/script/Script.js +93 -170
- package/dist/esm/src/script/Script.js.map +1 -1
- package/dist/esm/src/script/ScriptEvaluationError.js +2 -2
- package/dist/esm/src/script/ScriptEvaluationError.js.map +1 -1
- package/dist/esm/src/script/Spend.js +14 -12
- package/dist/esm/src/script/Spend.js.map +1 -1
- package/dist/esm/src/script/templates/PushDrop.js +4 -3
- package/dist/esm/src/script/templates/PushDrop.js.map +1 -1
- package/dist/esm/src/script/templates/RPuzzle.js +2 -4
- package/dist/esm/src/script/templates/RPuzzle.js.map +1 -1
- package/dist/esm/src/storage/StorageDownloader.js +1 -1
- package/dist/esm/src/storage/StorageDownloader.js.map +1 -1
- package/dist/esm/src/totp/totp.js +1 -1
- package/dist/esm/src/totp/totp.js.map +1 -1
- package/dist/esm/src/transaction/Beef.js +229 -186
- package/dist/esm/src/transaction/Beef.js.map +1 -1
- package/dist/esm/src/transaction/BeefConstants.js +16 -0
- package/dist/esm/src/transaction/BeefConstants.js.map +1 -0
- package/dist/esm/src/transaction/BeefTx.js +3 -3
- package/dist/esm/src/transaction/BeefTx.js.map +1 -1
- package/dist/esm/src/transaction/MerklePath.js +4 -4
- package/dist/esm/src/transaction/MerklePath.js.map +1 -1
- package/dist/esm/src/transaction/Transaction.js +49 -52
- package/dist/esm/src/transaction/Transaction.js.map +1 -1
- package/dist/esm/src/transaction/fee-models/SatoshisPerKilobyte.js +1 -1
- package/dist/esm/src/transaction/fee-models/SatoshisPerKilobyte.js.map +1 -1
- package/dist/esm/src/transaction/http/BinaryFetchClient.js +9 -9
- package/dist/esm/src/transaction/http/BinaryFetchClient.js.map +1 -1
- package/dist/esm/src/transaction/http/DefaultHttpClient.js +9 -9
- package/dist/esm/src/transaction/http/DefaultHttpClient.js.map +1 -1
- package/dist/esm/src/wallet/CachedKeyDeriver.js +1 -1
- package/dist/esm/src/wallet/CachedKeyDeriver.js.map +1 -1
- package/dist/esm/src/wallet/WalletClient.js.map +1 -1
- package/dist/esm/src/wallet/WalletError.js.map +1 -1
- package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js +5 -4
- package/dist/esm/src/wallet/substrates/HTTPWalletJSON.js.map +1 -1
- package/dist/esm/src/wallet/substrates/ReactNativeWebView.js +9 -9
- package/dist/esm/src/wallet/substrates/ReactNativeWebView.js.map +1 -1
- package/dist/esm/src/wallet/substrates/WalletWireProcessor.js +92 -92
- package/dist/esm/src/wallet/substrates/WalletWireProcessor.js.map +1 -1
- package/dist/esm/src/wallet/substrates/WalletWireTransceiver.js +387 -711
- package/dist/esm/src/wallet/substrates/WalletWireTransceiver.js.map +1 -1
- package/dist/esm/src/wallet/substrates/XDM.js +4 -4
- package/dist/esm/src/wallet/substrates/XDM.js.map +1 -1
- package/dist/esm/src/wallet/substrates/window.CWI.js +2 -2
- package/dist/esm/src/wallet/substrates/window.CWI.js.map +1 -1
- package/dist/esm/src/wallet/validationHelpers.js +9 -9
- package/dist/esm/src/wallet/validationHelpers.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/dist/types/src/auth/Peer.d.ts +13 -0
- package/dist/types/src/auth/Peer.d.ts.map +1 -1
- package/dist/types/src/auth/SessionManager.d.ts.map +1 -1
- package/dist/types/src/auth/clients/AuthFetch.d.ts.map +1 -1
- package/dist/types/src/compat/ECIES.d.ts.map +1 -1
- package/dist/types/src/compat/HD.d.ts.map +1 -1
- package/dist/types/src/identity/ContactsManager.d.ts +31 -2
- package/dist/types/src/identity/ContactsManager.d.ts.map +1 -1
- package/dist/types/src/identity/IdentityClient.d.ts +75 -10
- package/dist/types/src/identity/IdentityClient.d.ts.map +1 -1
- package/dist/types/src/kvstore/GlobalKVStore.d.ts.map +1 -1
- package/dist/types/src/overlay-tools/LookupResolver.d.ts +73 -2
- package/dist/types/src/overlay-tools/LookupResolver.d.ts.map +1 -1
- package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts +18 -3
- package/dist/types/src/overlay-tools/SHIPBroadcaster.d.ts.map +1 -1
- package/dist/types/src/primitives/BigNumber.d.ts +13 -3
- package/dist/types/src/primitives/BigNumber.d.ts.map +1 -1
- package/dist/types/src/primitives/Curve.d.ts.map +1 -1
- package/dist/types/src/primitives/ECDSA.d.ts.map +1 -1
- package/dist/types/src/primitives/Hash.d.ts +22 -17
- package/dist/types/src/primitives/Hash.d.ts.map +1 -1
- package/dist/types/src/primitives/JacobianPoint.d.ts +3 -1
- package/dist/types/src/primitives/JacobianPoint.d.ts.map +1 -1
- package/dist/types/src/primitives/Point.d.ts.map +1 -1
- package/dist/types/src/primitives/Random.d.ts +2 -2
- package/dist/types/src/primitives/Random.d.ts.map +1 -1
- package/dist/types/src/primitives/ReaderUint8Array.d.ts.map +1 -1
- package/dist/types/src/primitives/Schnorr.d.ts +2 -1
- package/dist/types/src/primitives/Schnorr.d.ts.map +1 -1
- package/dist/types/src/primitives/Secp256r1.d.ts.map +1 -1
- package/dist/types/src/primitives/SymmetricKey.d.ts.map +1 -1
- package/dist/types/src/primitives/utils.d.ts +2 -4
- package/dist/types/src/primitives/utils.d.ts.map +1 -1
- package/dist/types/src/registry/RegistryClient.d.ts.map +1 -1
- package/dist/types/src/remittance/RemittanceManager.d.ts.map +1 -1
- package/dist/types/src/remittance/modules/BasicBRC29.d.ts.map +1 -1
- package/dist/types/src/script/Script.d.ts +15 -8
- package/dist/types/src/script/Script.d.ts.map +1 -1
- package/dist/types/src/script/Spend.d.ts.map +1 -1
- package/dist/types/src/script/templates/PushDrop.d.ts +3 -1
- package/dist/types/src/script/templates/PushDrop.d.ts.map +1 -1
- package/dist/types/src/script/templates/RPuzzle.d.ts.map +1 -1
- package/dist/types/src/transaction/Beef.d.ts +46 -8
- package/dist/types/src/transaction/Beef.d.ts.map +1 -1
- package/dist/types/src/transaction/BeefConstants.d.ts +15 -0
- package/dist/types/src/transaction/BeefConstants.d.ts.map +1 -0
- package/dist/types/src/transaction/Transaction.d.ts.map +1 -1
- package/dist/types/src/wallet/CachedKeyDeriver.d.ts.map +1 -1
- package/dist/types/src/wallet/KeyDeriver.d.ts +1 -1
- package/dist/types/src/wallet/KeyDeriver.d.ts.map +1 -1
- package/dist/types/src/wallet/Wallet.interfaces.d.ts +18 -3
- package/dist/types/src/wallet/Wallet.interfaces.d.ts.map +1 -1
- package/dist/types/src/wallet/WalletClient.d.ts +8 -8
- package/dist/types/src/wallet/WalletClient.d.ts.map +1 -1
- package/dist/types/src/wallet/substrates/HTTPWalletJSON.d.ts +7 -7
- package/dist/types/src/wallet/substrates/HTTPWalletJSON.d.ts.map +1 -1
- package/dist/types/src/wallet/substrates/WalletWireTransceiver.d.ts +36 -7
- package/dist/types/src/wallet/substrates/WalletWireTransceiver.d.ts.map +1 -1
- package/dist/types/src/wallet/substrates/window.CWI.d.ts +9 -9
- package/dist/types/src/wallet/substrates/window.CWI.d.ts.map +1 -1
- package/dist/types/tsconfig.types.tsbuildinfo +1 -1
- package/dist/umd/bundle.js +3 -3
- package/package.json +1 -1
- package/src/auth/Peer.ts +26 -13
- package/src/auth/SessionManager.ts +4 -7
- package/src/auth/certificates/MasterCertificate.ts +1 -1
- package/src/auth/certificates/__tests/CompletedProtoWallet.ts +1 -1
- package/src/auth/clients/AuthFetch.ts +41 -41
- package/src/auth/transports/SimplifiedFetchTransport.ts +4 -4
- package/src/compat/ECIES.ts +29 -34
- package/src/compat/HD.ts +10 -5
- package/src/compat/Mnemonic.ts +11 -11
- package/src/compat/__tests/HD.test.ts +19 -0
- package/src/identity/ContactsManager.ts +236 -258
- package/src/identity/IdentityClient.ts +244 -71
- package/src/identity/__tests/IdentityClient.additional.test.ts +150 -1
- package/src/identity/__tests/IdentityClient.test.ts +27 -3
- package/src/kvstore/GlobalKVStore.ts +31 -32
- package/src/kvstore/LocalKVStore.ts +8 -8
- package/src/kvstore/kvStoreInterpreter.ts +2 -2
- package/src/messages/SignedMessage.ts +1 -1
- package/src/overlay-tools/Historian.ts +1 -1
- package/src/overlay-tools/LookupResolver.ts +264 -90
- package/src/overlay-tools/SHIPBroadcaster.ts +92 -168
- package/src/primitives/AESGCM.ts +2 -2
- package/src/primitives/BigNumber.ts +122 -113
- package/src/primitives/Curve.ts +16 -15
- package/src/primitives/ECDSA.ts +10 -8
- package/src/primitives/Hash.ts +381 -146
- package/src/primitives/JacobianPoint.ts +13 -11
- package/src/primitives/K256.ts +3 -3
- package/src/primitives/Point.ts +35 -38
- package/src/primitives/PrivateKey.ts +3 -3
- package/src/primitives/PublicKey.ts +3 -3
- package/src/primitives/Random.ts +11 -14
- package/src/primitives/ReaderUint8Array.ts +7 -7
- package/src/primitives/Schnorr.ts +2 -1
- package/src/primitives/Secp256r1.ts +2 -1
- package/src/primitives/Signature.ts +8 -8
- package/src/primitives/SymmetricKey.ts +145 -1
- package/src/primitives/TransactionSignature.ts +16 -16
- package/src/primitives/__tests/Hash.additional.test.ts +65 -0
- package/src/primitives/__tests/Hash.test.ts +6 -1
- package/src/primitives/utils.ts +37 -47
- package/src/registry/RegistryClient.ts +25 -25
- package/src/remittance/RemittanceManager.ts +17 -18
- package/src/remittance/modules/BasicBRC29.ts +2 -5
- package/src/script/Script.ts +114 -170
- package/src/script/ScriptEvaluationError.ts +2 -2
- package/src/script/Spend.ts +14 -15
- package/src/script/templates/PushDrop.ts +5 -3
- package/src/script/templates/RPuzzle.ts +2 -4
- package/src/storage/StorageDownloader.ts +1 -1
- package/src/totp/totp.ts +1 -1
- package/src/transaction/Beef.ts +241 -203
- package/src/transaction/BeefConstants.ts +16 -0
- package/src/transaction/BeefTx.ts +3 -3
- package/src/transaction/MerklePath.ts +4 -4
- package/src/transaction/Transaction.ts +48 -51
- package/src/transaction/fee-models/SatoshisPerKilobyte.ts +1 -1
- package/src/transaction/http/BinaryFetchClient.ts +8 -8
- package/src/transaction/http/DefaultHttpClient.ts +8 -8
- package/src/wallet/CachedKeyDeriver.ts +8 -6
- package/src/wallet/KeyDeriver.ts +1 -1
- package/src/wallet/Wallet.interfaces.ts +18 -5
- package/src/wallet/WalletClient.ts +9 -9
- package/src/wallet/WalletError.ts +1 -1
- package/src/wallet/__tests/WalletClient.substrate.test.ts +10 -6
- package/src/wallet/substrates/HTTPWalletJSON.ts +22 -21
- package/src/wallet/substrates/ReactNativeWebView.ts +9 -9
- package/src/wallet/substrates/WalletWireProcessor.ts +83 -83
- package/src/wallet/substrates/WalletWireTransceiver.ts +528 -938
- package/src/wallet/substrates/XDM.ts +4 -4
- package/src/wallet/substrates/__tests/HTTPWalletJSON.test.ts +38 -25
- package/src/wallet/substrates/__tests/ReactNativeWebView.test.ts +174 -0
- package/src/wallet/substrates/__tests/window.CWI.test.ts +256 -0
- package/src/wallet/substrates/window.CWI.ts +11 -11
- package/src/wallet/validationHelpers.ts +9 -9
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Signature.js","sourceRoot":"","sources":["../../../../src/primitives/Signature.ts"],"names":[],"mappings":";;;;;AAAA,kEAAsC;AACtC,kEAAsC;AACtC,yCAAmC;AACnC,uCAAkC;AAClC,yCAAqD;AACrD,0DAA8B;AAC9B,0DAA8B;AAE9B;;;;;;;;;GASG;AACH,MAAqB,SAAS;IAW5B;;;;;;;;;;;;;OAaG;IACH,MAAM,CAAC,OAAO,CAAE,IAAuB,EAAE,GAAsB;QAC7D,MAAM,SAAS,GAAG,CAAC,GAAG,EAAE,CAAC,EAAU,EAAE;YACnC,MAAM,OAAO,GAAG,GAAG,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAA;YAC9B,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC3B,OAAO,OAAO,CAAA;YAChB,CAAC;iBAAM,CAAC;gBACN,MAAM,IAAI,KAAK,CAAC,2BAA2B,CAAC,CAAA;YAC9C,CAAC;QACH,CAAC,CAAA;QAED,MAAM,QAAQ;YAEZ;gBACE,IAAI,CAAC,KAAK,GAAG,CAAC,CAAA;YAChB,CAAC;SACF;QACD,IAAI,GAAG,IAAA,kBAAO,EAAC,IAAI,EAAE,GAAG,CAAC,CAAA;QAEzB,MAAM,CAAC,GAAG,IAAI,QAAQ,EAAE,CAAA;QACxB,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CAAC,oCAAoC,CAAC,CAAA;QACvD,CAAC;QACD,MAAM,GAAG,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;QAC9B,IAAI,GAAG,GAAG,CAAC,CAAC,KAAK,KAAK,IAAI,CAAC,MAAM,EAAE,CAAC;YAClC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAC1C,CAAC;QACD,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAC1C,CAAC;QACD,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;QAC/B,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,CAAC,KAAK,CAAC,CAAA;QAC3C,CAAC,CAAC,KAAK,IAAI,IAAI,CAAA;QACf,IAAI,IAAI,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,KAAK,IAAI,EAAE,CAAC;YAC7B,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAA;QAC1C,CAAC;QACD,MAAM,IAAI,GAAG,SAAS,CAAC,IAAI,EAAE,CAAC,CAAC,CAAA;QAC/B,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI,GAAG,CAAC,CAAC,KAAK,EAAE,CAAC;YACnC,MAAM,IAAI,KAAK,CAAC,mCAAmC,CAAC,CAAA;QACtD,CAAC;QACD,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,EAAE,IAAI,GAAG,CAAC,CAAC,KAAK,CAAC,CAAA;QAC3C,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;YACf,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;gBACxB,
|
|
1
|
+
{"version":3,"file":"Signature.js","sourceRoot":"","sources":["../../../../src/primitives/Signature.ts"],"names":[],"mappings":"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"}
|
|
@@ -7,6 +7,105 @@ const BigNumber_js_1 = __importDefault(require("./BigNumber.js"));
|
|
|
7
7
|
const AESGCM_js_1 = require("./AESGCM.js");
|
|
8
8
|
const Random_js_1 = __importDefault(require("./Random.js"));
|
|
9
9
|
const utils_js_1 = require("./utils.js");
|
|
10
|
+
// ---------------------------------------------------------------------------
|
|
11
|
+
// Native AES-GCM fast-path via node:crypto / react-native-quick-crypto
|
|
12
|
+
//
|
|
13
|
+
// Resolved once at module load using the same pattern as Hash.ts. When
|
|
14
|
+
// `node:crypto` (or a compatible shim) is available and exposes
|
|
15
|
+
// `createCipheriv` / `createDecipheriv`, encrypt and decrypt will use it
|
|
16
|
+
// instead of the pure-TS implementation. The pure-TS path remains the
|
|
17
|
+
// unconditional fallback — any error in the native path causes silent
|
|
18
|
+
// re-execution through the pure-TS implementation.
|
|
19
|
+
// ---------------------------------------------------------------------------
|
|
20
|
+
const NODE_CRYPTO_SYM = (() => {
|
|
21
|
+
const processLike = typeof globalThis === 'undefined' ? undefined : globalThis.process;
|
|
22
|
+
const getBuiltinModule = processLike?.getBuiltinModule;
|
|
23
|
+
if (typeof getBuiltinModule === 'function') {
|
|
24
|
+
try {
|
|
25
|
+
const crypto = getBuiltinModule.call(processLike, 'node:crypto');
|
|
26
|
+
if (crypto != null)
|
|
27
|
+
return crypto;
|
|
28
|
+
}
|
|
29
|
+
catch {
|
|
30
|
+
// continue to CommonJS fallback
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
try {
|
|
34
|
+
if (typeof require === 'function') {
|
|
35
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
|
36
|
+
return require('node:crypto');
|
|
37
|
+
}
|
|
38
|
+
}
|
|
39
|
+
catch {
|
|
40
|
+
// node:crypto is unavailable in this runtime
|
|
41
|
+
}
|
|
42
|
+
return undefined;
|
|
43
|
+
})();
|
|
44
|
+
/** True when the runtime provides a usable createCipheriv for aes-256-gcm. */
|
|
45
|
+
const NATIVE_AES_GCM_AVAILABLE = (() => {
|
|
46
|
+
if (NODE_CRYPTO_SYM == null)
|
|
47
|
+
return false;
|
|
48
|
+
return (typeof NODE_CRYPTO_SYM.createCipheriv === 'function' &&
|
|
49
|
+
typeof NODE_CRYPTO_SYM.createDecipheriv === 'function');
|
|
50
|
+
})();
|
|
51
|
+
/**
|
|
52
|
+
* Encrypt `plaintext` with AES-256-GCM via node:crypto.
|
|
53
|
+
* Returns `iv (32 bytes) || ciphertext || authTag (16 bytes)` — identical
|
|
54
|
+
* layout to the pure-TS AESGCM path used by SymmetricKey.encrypt.
|
|
55
|
+
*
|
|
56
|
+
* Returns `null` on any failure so the caller can fall back to pure-TS.
|
|
57
|
+
*/
|
|
58
|
+
function nativeEncrypt(plaintext, iv, key) {
|
|
59
|
+
try {
|
|
60
|
+
const cipher = NODE_CRYPTO_SYM.createCipheriv('aes-256-gcm', Buffer.from(key.buffer, key.byteOffset, key.byteLength), Buffer.from(iv.buffer, iv.byteOffset, iv.byteLength));
|
|
61
|
+
const encrypted = Buffer.concat([
|
|
62
|
+
cipher.update(Buffer.from(plaintext.buffer, plaintext.byteOffset, plaintext.byteLength)),
|
|
63
|
+
cipher.final()
|
|
64
|
+
]);
|
|
65
|
+
const authTag = cipher.getAuthTag(); // always 16 bytes for GCM
|
|
66
|
+
const out = new Uint8Array(iv.length + encrypted.length + authTag.length);
|
|
67
|
+
let offset = 0;
|
|
68
|
+
out.set(iv, offset);
|
|
69
|
+
offset += iv.length;
|
|
70
|
+
out.set(encrypted, offset);
|
|
71
|
+
offset += encrypted.length;
|
|
72
|
+
out.set(authTag, offset);
|
|
73
|
+
return out;
|
|
74
|
+
}
|
|
75
|
+
catch {
|
|
76
|
+
return null;
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
/**
|
|
80
|
+
* Decrypt an `iv || ciphertext || authTag` bundle produced by nativeEncrypt
|
|
81
|
+
* (or by the pure-TS SymmetricKey.encrypt path) using node:crypto.
|
|
82
|
+
*
|
|
83
|
+
* Returns the plaintext on success, `null` on authentication failure, or
|
|
84
|
+
* `undefined` to signal a non-auth error so the caller can fall back.
|
|
85
|
+
*/
|
|
86
|
+
function nativeDecrypt(msgBytes, ivLength, tagLength, key) {
|
|
87
|
+
try {
|
|
88
|
+
const iv = msgBytes.slice(0, ivLength);
|
|
89
|
+
const tagStart = msgBytes.length - tagLength;
|
|
90
|
+
const ciphertext = msgBytes.slice(ivLength, tagStart);
|
|
91
|
+
const messageTag = msgBytes.slice(tagStart);
|
|
92
|
+
const decipher = NODE_CRYPTO_SYM.createDecipheriv('aes-256-gcm', Buffer.from(key.buffer, key.byteOffset, key.byteLength), Buffer.from(iv.buffer, iv.byteOffset, iv.byteLength));
|
|
93
|
+
decipher.setAuthTag(Buffer.from(messageTag.buffer, messageTag.byteOffset, messageTag.byteLength));
|
|
94
|
+
// Decryption authenticates on final(); throws if tag is wrong.
|
|
95
|
+
const decrypted = Buffer.concat([
|
|
96
|
+
decipher.update(Buffer.from(ciphertext.buffer, ciphertext.byteOffset, ciphertext.byteLength)),
|
|
97
|
+
decipher.final()
|
|
98
|
+
]);
|
|
99
|
+
return new Uint8Array(decrypted.buffer, decrypted.byteOffset, decrypted.byteLength);
|
|
100
|
+
}
|
|
101
|
+
catch {
|
|
102
|
+
// Node throws "Unsupported state or unable to authenticate data" on auth
|
|
103
|
+
// failure. Treat any error as auth failure so SymmetricKey.decrypt re-throws
|
|
104
|
+
// its own descriptive message — pure-TS fallback would return null in the
|
|
105
|
+
// same scenario.
|
|
106
|
+
return null;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
10
109
|
/**
|
|
11
110
|
* `SymmetricKey` is a class that extends the `BigNumber` class and implements symmetric encryption and decryption methods.
|
|
12
111
|
* Symmetric-Key encryption is a form of encryption where the same key is used to encrypt and decrypt the message.
|
|
@@ -47,6 +146,15 @@ class SymmetricKey extends BigNumber_js_1.default {
|
|
|
47
146
|
const iv = new Uint8Array((0, Random_js_1.default)(32));
|
|
48
147
|
const msgBytes = new Uint8Array((0, utils_js_1.toArray)(msg, enc));
|
|
49
148
|
const keyBytes = new Uint8Array(this.toArray('be', 32));
|
|
149
|
+
// Fast path: native AES-256-GCM via node:crypto / react-native-quick-crypto.
|
|
150
|
+
// Falls back to pure-TS on any failure.
|
|
151
|
+
if (NATIVE_AES_GCM_AVAILABLE) {
|
|
152
|
+
const nativeResult = nativeEncrypt(msgBytes, iv, keyBytes);
|
|
153
|
+
if (nativeResult !== null) {
|
|
154
|
+
return (0, utils_js_1.encode)(Array.from(nativeResult), enc);
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
// Pure-TS fallback.
|
|
50
158
|
const { result, authenticationTag } = (0, AESGCM_js_1.AESGCM)(msgBytes, iv, keyBytes);
|
|
51
159
|
const totalLength = iv.length + result.length + authenticationTag.length;
|
|
52
160
|
const combined = new Uint8Array(totalLength);
|
|
@@ -81,11 +189,25 @@ class SymmetricKey extends BigNumber_js_1.default {
|
|
|
81
189
|
if (msgBytes.length < ivLength + tagLength) {
|
|
82
190
|
throw new Error('Ciphertext too short');
|
|
83
191
|
}
|
|
192
|
+
const keyBytes = new Uint8Array(this.toArray('be', 32));
|
|
193
|
+
// Fast path: native AES-256-GCM via node:crypto / react-native-quick-crypto.
|
|
194
|
+
// Falls back to pure-TS on null/undefined return.
|
|
195
|
+
if (NATIVE_AES_GCM_AVAILABLE) {
|
|
196
|
+
const nativeResult = nativeDecrypt(msgBytes, ivLength, tagLength, keyBytes);
|
|
197
|
+
if (nativeResult !== undefined) {
|
|
198
|
+
// nativeResult is Uint8Array on success or null on auth/decryption failure.
|
|
199
|
+
if (nativeResult === null) {
|
|
200
|
+
throw new Error('Decryption failed!');
|
|
201
|
+
}
|
|
202
|
+
return (0, utils_js_1.encode)(Array.from(nativeResult), enc);
|
|
203
|
+
}
|
|
204
|
+
// undefined means unexpected setup error — fall through to pure-TS.
|
|
205
|
+
}
|
|
206
|
+
// Pure-TS fallback.
|
|
84
207
|
const iv = msgBytes.slice(0, ivLength);
|
|
85
208
|
const tagStart = msgBytes.length - tagLength;
|
|
86
209
|
const ciphertext = msgBytes.slice(ivLength, tagStart);
|
|
87
210
|
const messageTag = msgBytes.slice(tagStart);
|
|
88
|
-
const keyBytes = new Uint8Array(this.toArray('be', 32));
|
|
89
211
|
const result = (0, AESGCM_js_1.AESGCMDecrypt)(ciphertext, iv, messageTag, keyBytes);
|
|
90
212
|
if (result === null) {
|
|
91
213
|
throw new Error('Decryption failed!');
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"SymmetricKey.js","sourceRoot":"","sources":["../../../../src/primitives/SymmetricKey.ts"],"names":[],"mappings":";;;;;AAAA,kEAAsC;AACtC,2CAAmD;AACnD,4DAAgC;AAChC,yCAA4C;AAE5C;;;;;;;GAOG;AACH,MAAqB,YAAa,SAAQ,sBAAS;IACjD;;;;;;;;;OASG;IACH,MAAM,CAAC,UAAU;QACf,OAAO,IAAI,YAAY,CAAC,IAAA,mBAAM,EAAC,EAAE,CAAC,CAAC,CAAA;IACrC,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,OAAO,CAAE,GAAsB,EAAE,GAAW;QAC1C,MAAM,EAAE,GAAG,IAAI,UAAU,CAAC,IAAA,mBAAM,EAAC,EAAE,CAAC,CAAC,CAAA;QACrC,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAA,kBAAO,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAClD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAA;QAEvD,MAAM,EAAE,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAA,kBAAM,EAC1C,QAAQ,EACR,EAAE,EACF,QAAQ,CACT,CAAA;QAED,MAAM,WAAW,GAAG,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,iBAAiB,CAAC,MAAM,CAAA;QACxE,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAA;QAC5C,IAAI,MAAM,GAAG,CAAC,CAAA;QAEd,QAAQ,CAAC,GAAG,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;QACxB,MAAM,IAAI,EAAE,CAAC,MAAM,CAAA;QACnB,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QAC5B,MAAM,IAAI,MAAM,CAAC,MAAM,CAAA;QACvB,QAAQ,CAAC,GAAG,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAA;QAEvC,OAAO,IAAA,iBAAM,EAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAA;IAC1C,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACH,OAAO,CAAE,GAAsB,EAAE,GAAoB;QACnD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAA,kBAAO,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAElD,MAAM,QAAQ,GAAG,EAAE,CAAA;QACnB,MAAM,SAAS,GAAG,EAAE,CAAA;QAEpB,IAAI,QAAQ,CAAC,MAAM,GAAG,QAAQ,GAAG,SAAS,EAAE,CAAC;YAC3C,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;QACzC,CAAC;QAED,MAAM,
|
|
1
|
+
{"version":3,"file":"SymmetricKey.js","sourceRoot":"","sources":["../../../../src/primitives/SymmetricKey.ts"],"names":[],"mappings":";;;;;AAAA,kEAAsC;AACtC,2CAAmD;AACnD,4DAAgC;AAChC,yCAA4C;AAE5C,8EAA8E;AAC9E,uEAAuE;AACvE,EAAE;AACF,wEAAwE;AACxE,gEAAgE;AAChE,yEAAyE;AACzE,uEAAuE;AACvE,sEAAsE;AACtE,mDAAmD;AACnD,8EAA8E;AAC9E,MAAM,eAAe,GAAG,CAAC,GAAG,EAAE;IAC5B,MAAM,WAAW,GACf,OAAO,UAAU,KAAK,WAAW,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAE,UAAkB,CAAC,OAAO,CAAA;IAC7E,MAAM,gBAAgB,GAAG,WAAW,EAAE,gBAAgB,CAAA;IACtD,IAAI,OAAO,gBAAgB,KAAK,UAAU,EAAE,CAAC;QAC3C,IAAI,CAAC;YACH,MAAM,MAAM,GAAG,gBAAgB,CAAC,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,CAAA;YAChE,IAAI,MAAM,IAAI,IAAI;gBAAE,OAAO,MAAM,CAAA;QACnC,CAAC;QAAC,MAAM,CAAC;YACP,gCAAgC;QAClC,CAAC;IACH,CAAC;IACD,IAAI,CAAC;QACH,IAAI,OAAO,OAAO,KAAK,UAAU,EAAE,CAAC;YAClC,8DAA8D;YAC9D,OAAO,OAAO,CAAC,aAAa,CAAC,CAAA;QAC/B,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,6CAA6C;IAC/C,CAAC;IACD,OAAO,SAAS,CAAA;AAClB,CAAC,CAAC,EAAE,CAAA;AAEJ,8EAA8E;AAC9E,MAAM,wBAAwB,GAAY,CAAC,GAAG,EAAE;IAC9C,IAAI,eAAe,IAAI,IAAI;QAAE,OAAO,KAAK,CAAA;IACzC,OAAO,CACL,OAAO,eAAe,CAAC,cAAc,KAAK,UAAU;QACpD,OAAO,eAAe,CAAC,gBAAgB,KAAK,UAAU,CACvD,CAAA;AACH,CAAC,CAAC,EAAE,CAAA;AAEJ;;;;;;GAMG;AACH,SAAS,aAAa,CACpB,SAAqB,EACrB,EAAc,EACd,GAAe;IAEf,IAAI,CAAC;QACH,MAAM,MAAM,GAAG,eAAe,CAAC,cAAc,CAC3C,aAAa,EACb,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,EACvD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,CACrD,CAAA;QACD,MAAM,SAAS,GAAW,MAAM,CAAC,MAAM,CAAC;YACtC,MAAM,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,UAAU,CAAC,CAAC;YACxF,MAAM,CAAC,KAAK,EAAE;SACf,CAAC,CAAA;QACF,MAAM,OAAO,GAAW,MAAM,CAAC,UAAU,EAAE,CAAA,CAAC,0BAA0B;QAEtE,MAAM,GAAG,GAAG,IAAI,UAAU,CAAC,EAAE,CAAC,MAAM,GAAG,SAAS,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAAA;QACzE,IAAI,MAAM,GAAG,CAAC,CAAA;QACd,GAAG,CAAC,GAAG,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;QAAC,MAAM,IAAI,EAAE,CAAC,MAAM,CAAA;QACxC,GAAG,CAAC,GAAG,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAAC,MAAM,IAAI,SAAS,CAAC,MAAM,CAAA;QACtD,GAAG,CAAC,GAAG,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;QACxB,OAAO,GAAG,CAAA;IACZ,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAA;IACb,CAAC;AACH,CAAC;AAED;;;;;;GAMG;AACH,SAAS,aAAa,CACpB,QAAoB,EACpB,QAAgB,EAChB,SAAiB,EACjB,GAAe;IAEf,IAAI,CAAC;QACH,MAAM,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;QACtC,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAA;QAC5C,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;QACrD,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAE3C,MAAM,QAAQ,GAAG,eAAe,CAAC,gBAAgB,CAC/C,aAAa,EACb,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,UAAU,EAAE,GAAG,CAAC,UAAU,CAAC,EACvD,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,MAAM,EAAE,EAAE,CAAC,UAAU,EAAE,EAAE,CAAC,UAAU,CAAC,CACrD,CAAA;QACD,QAAQ,CAAC,UAAU,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC,CAAA;QAEjG,+DAA+D;QAC/D,MAAM,SAAS,GAAW,MAAM,CAAC,MAAM,CAAC;YACtC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;YAC7F,QAAQ,CAAC,KAAK,EAAE;SACjB,CAAC,CAAA;QACF,OAAO,IAAI,UAAU,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,UAAU,EAAE,SAAS,CAAC,UAAU,CAAC,CAAA;IACrF,CAAC;IAAC,MAAM,CAAC;QACP,yEAAyE;QACzE,6EAA6E;QAC7E,0EAA0E;QAC1E,iBAAiB;QACjB,OAAO,IAAI,CAAA;IACb,CAAC;AACH,CAAC;AAED;;;;;;;GAOG;AACH,MAAqB,YAAa,SAAQ,sBAAS;IACjD;;;;;;;;;OASG;IACH,MAAM,CAAC,UAAU;QACf,OAAO,IAAI,YAAY,CAAC,IAAA,mBAAM,EAAC,EAAE,CAAC,CAAC,CAAA;IACrC,CAAC;IAED;;;;;;;;;;;;;OAaG;IACH,OAAO,CAAE,GAAsB,EAAE,GAAW;QAC1C,MAAM,EAAE,GAAG,IAAI,UAAU,CAAC,IAAA,mBAAM,EAAC,EAAE,CAAC,CAAC,CAAA;QACrC,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAA,kBAAO,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAClD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAA;QAEvD,6EAA6E;QAC7E,wCAAwC;QACxC,IAAI,wBAAwB,EAAE,CAAC;YAC7B,MAAM,YAAY,GAAG,aAAa,CAAC,QAAQ,EAAE,EAAE,EAAE,QAAQ,CAAC,CAAA;YAC1D,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;gBAC1B,OAAO,IAAA,iBAAM,EAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,GAAG,CAAC,CAAA;YAC9C,CAAC;QACH,CAAC;QAED,oBAAoB;QACpB,MAAM,EAAE,MAAM,EAAE,iBAAiB,EAAE,GAAG,IAAA,kBAAM,EAC1C,QAAQ,EACR,EAAE,EACF,QAAQ,CACT,CAAA;QAED,MAAM,WAAW,GAAG,EAAE,CAAC,MAAM,GAAG,MAAM,CAAC,MAAM,GAAG,iBAAiB,CAAC,MAAM,CAAA;QACxE,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,WAAW,CAAC,CAAA;QAC5C,IAAI,MAAM,GAAG,CAAC,CAAA;QAEd,QAAQ,CAAC,GAAG,CAAC,EAAE,EAAE,MAAM,CAAC,CAAA;QACxB,MAAM,IAAI,EAAE,CAAC,MAAM,CAAA;QACnB,QAAQ,CAAC,GAAG,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QAC5B,MAAM,IAAI,MAAM,CAAC,MAAM,CAAA;QACvB,QAAQ,CAAC,GAAG,CAAC,iBAAiB,EAAE,MAAM,CAAC,CAAA;QAEvC,OAAO,IAAA,iBAAM,EAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,CAAA;IAC1C,CAAC;IAED;;;;;;;;;;;;;;;OAeG;IACH,OAAO,CAAE,GAAsB,EAAE,GAAoB;QACnD,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAA,kBAAO,EAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAA;QAElD,MAAM,QAAQ,GAAG,EAAE,CAAA;QACnB,MAAM,SAAS,GAAG,EAAE,CAAA;QAEpB,IAAI,QAAQ,CAAC,MAAM,GAAG,QAAQ,GAAG,SAAS,EAAE,CAAC;YAC3C,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAA;QACzC,CAAC;QAED,MAAM,QAAQ,GAAG,IAAI,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,CAAA;QAEvD,6EAA6E;QAC7E,kDAAkD;QAClD,IAAI,wBAAwB,EAAE,CAAC;YAC7B,MAAM,YAAY,GAAG,aAAa,CAAC,QAAQ,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,CAAC,CAAA;YAC3E,IAAI,YAAY,KAAK,SAAS,EAAE,CAAC;gBAC/B,4EAA4E;gBAC5E,IAAI,YAAY,KAAK,IAAI,EAAE,CAAC;oBAC1B,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;gBACvC,CAAC;gBACD,OAAO,IAAA,iBAAM,EAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,GAAG,CAAC,CAAA;YAC9C,CAAC;YACD,oEAAoE;QACtE,CAAC;QAED,oBAAoB;QACpB,MAAM,EAAE,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;QACtC,MAAM,QAAQ,GAAG,QAAQ,CAAC,MAAM,GAAG,SAAS,CAAA;QAC5C,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,EAAE,QAAQ,CAAC,CAAA;QACrD,MAAM,UAAU,GAAG,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAA;QAE3C,MAAM,MAAM,GAAG,IAAA,yBAAa,EAC1B,UAAU,EACV,EAAE,EACF,UAAU,EACV,QAAQ,CACT,CAAA;QACD,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;YACpB,MAAM,IAAI,KAAK,CAAC,oBAAoB,CAAC,CAAA;QACvC,CAAC;QACD,OAAO,IAAA,iBAAM,EAAC,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE,GAAG,CAAC,CAAA;IACxC,CAAC;CACF;AA1HD,+BA0HC"}
|
|
@@ -143,7 +143,7 @@ class TransactionSignature extends Signature_js_1.default {
|
|
|
143
143
|
const getPrevoutHash = () => {
|
|
144
144
|
const writer = new utils_js_1.Writer();
|
|
145
145
|
for (const input of inputs) {
|
|
146
|
-
if (
|
|
146
|
+
if (input.sourceTXID === undefined) {
|
|
147
147
|
if (input.sourceTransaction == null) {
|
|
148
148
|
throw new Error('Missing sourceTransaction for input');
|
|
149
149
|
}
|
|
@@ -170,7 +170,7 @@ class TransactionSignature extends Signature_js_1.default {
|
|
|
170
170
|
};
|
|
171
171
|
function getOutputsHash(outputIndex) {
|
|
172
172
|
const writer = new utils_js_1.Writer();
|
|
173
|
-
if (
|
|
173
|
+
if (outputIndex === undefined) {
|
|
174
174
|
for (const output of params.outputs) {
|
|
175
175
|
const satoshis = output.satoshis ?? 0; // Default to 0 if undefined
|
|
176
176
|
writer.writeUInt64LE(satoshis);
|
|
@@ -198,53 +198,52 @@ class TransactionSignature extends Signature_js_1.default {
|
|
|
198
198
|
let hashSequence = new Array(32).fill(0);
|
|
199
199
|
let hashOutputs = new Array(32).fill(0);
|
|
200
200
|
if ((params.scope & TransactionSignature.SIGHASH_ANYONECANPAY) === 0) {
|
|
201
|
-
if (cache?.hashPrevouts
|
|
202
|
-
hashPrevouts = cache.hashPrevouts;
|
|
203
|
-
}
|
|
204
|
-
else {
|
|
201
|
+
if (cache?.hashPrevouts == null) {
|
|
205
202
|
hashPrevouts = getPrevoutHash();
|
|
206
203
|
if (cache != null)
|
|
207
204
|
cache.hashPrevouts = hashPrevouts;
|
|
208
205
|
}
|
|
206
|
+
else {
|
|
207
|
+
hashPrevouts = cache.hashPrevouts;
|
|
208
|
+
}
|
|
209
209
|
}
|
|
210
210
|
if ((params.scope & TransactionSignature.SIGHASH_ANYONECANPAY) === 0 &&
|
|
211
211
|
(params.scope & 31) !== TransactionSignature.SIGHASH_SINGLE &&
|
|
212
212
|
(params.scope & 31) !== TransactionSignature.SIGHASH_NONE) {
|
|
213
|
-
if (cache?.hashSequence
|
|
214
|
-
hashSequence = cache.hashSequence;
|
|
215
|
-
}
|
|
216
|
-
else {
|
|
213
|
+
if (cache?.hashSequence == null) {
|
|
217
214
|
hashSequence = getSequenceHash();
|
|
218
215
|
if (cache != null)
|
|
219
216
|
cache.hashSequence = hashSequence;
|
|
220
217
|
}
|
|
218
|
+
else {
|
|
219
|
+
hashSequence = cache.hashSequence;
|
|
220
|
+
}
|
|
221
221
|
}
|
|
222
222
|
if ((params.scope & 31) !== TransactionSignature.SIGHASH_SINGLE &&
|
|
223
223
|
(params.scope & 31) !== TransactionSignature.SIGHASH_NONE) {
|
|
224
|
-
if (cache?.hashOutputsAll
|
|
225
|
-
hashOutputs = cache.hashOutputsAll;
|
|
226
|
-
}
|
|
227
|
-
else {
|
|
224
|
+
if (cache?.hashOutputsAll == null) {
|
|
228
225
|
hashOutputs = getOutputsHash();
|
|
229
226
|
if (cache != null)
|
|
230
227
|
cache.hashOutputsAll = hashOutputs;
|
|
231
228
|
}
|
|
229
|
+
else {
|
|
230
|
+
hashOutputs = cache.hashOutputsAll;
|
|
231
|
+
}
|
|
232
232
|
}
|
|
233
233
|
else if ((params.scope & 31) === TransactionSignature.SIGHASH_SINGLE &&
|
|
234
234
|
params.inputIndex < params.outputs.length) {
|
|
235
235
|
const key = params.inputIndex;
|
|
236
236
|
const cachedSingle = cache?.hashOutputsSingle?.get(key);
|
|
237
|
-
if (cachedSingle
|
|
238
|
-
hashOutputs = cachedSingle;
|
|
239
|
-
}
|
|
240
|
-
else {
|
|
237
|
+
if (cachedSingle == null) {
|
|
241
238
|
hashOutputs = getOutputsHash(key);
|
|
242
239
|
if (cache != null) {
|
|
243
|
-
|
|
244
|
-
cache.hashOutputsSingle = new Map();
|
|
240
|
+
cache.hashOutputsSingle ?? (cache.hashOutputsSingle = new Map());
|
|
245
241
|
cache.hashOutputsSingle.set(key, hashOutputs);
|
|
246
242
|
}
|
|
247
243
|
}
|
|
244
|
+
else {
|
|
245
|
+
hashOutputs = cachedSingle;
|
|
246
|
+
}
|
|
248
247
|
}
|
|
249
248
|
const writer = new utils_js_1.Writer();
|
|
250
249
|
// Version
|
|
@@ -311,7 +310,7 @@ class TransactionSignature extends Signature_js_1.default {
|
|
|
311
310
|
const scope = 1;
|
|
312
311
|
return new TransactionSignature(r, s, scope);
|
|
313
312
|
}
|
|
314
|
-
const scope = buf
|
|
313
|
+
const scope = buf.at(-1);
|
|
315
314
|
const derbuf = buf.slice(0, buf.length - 1);
|
|
316
315
|
const tempSig = Signature_js_1.default.fromDER(derbuf);
|
|
317
316
|
return new TransactionSignature(tempSig.r, tempSig.s, scope);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"TransactionSignature.js","sourceRoot":"","sources":["../../../../src/primitives/TransactionSignature.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"TransactionSignature.js","sourceRoot":"","sources":["../../../../src/primitives/TransactionSignature.ts"],"names":[],"mappings":"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"}
|
|
@@ -11,11 +11,11 @@ exports.constantTimeEquals = constantTimeEquals;
|
|
|
11
11
|
const BigNumber_js_1 = __importDefault(require("./BigNumber.js"));
|
|
12
12
|
const Hash_js_1 = require("./Hash.js");
|
|
13
13
|
const hex_js_1 = require("./hex.js");
|
|
14
|
-
|
|
14
|
+
var WriterUint8Array_js_1 = require("./WriterUint8Array.js");
|
|
15
15
|
Object.defineProperty(exports, "WriterUint8Array", { enumerable: true, get: function () { return WriterUint8Array_js_1.WriterUint8Array; } });
|
|
16
|
-
|
|
16
|
+
var ReaderUint8Array_js_1 = require("./ReaderUint8Array.js");
|
|
17
17
|
Object.defineProperty(exports, "ReaderUint8Array", { enumerable: true, get: function () { return ReaderUint8Array_js_1.ReaderUint8Array; } });
|
|
18
|
-
const BufferCtor = typeof globalThis
|
|
18
|
+
const BufferCtor = typeof globalThis === 'undefined' ? undefined : globalThis.Buffer;
|
|
19
19
|
const CAN_USE_BUFFER = BufferCtor != null && typeof BufferCtor.from === 'function';
|
|
20
20
|
/**
|
|
21
21
|
* Prepends a '0' to an odd character length word to ensure it has an even number of characters.
|
|
@@ -83,7 +83,7 @@ const toArray = (msg, enc) => {
|
|
|
83
83
|
if (msg === undefined)
|
|
84
84
|
return [];
|
|
85
85
|
if (typeof msg !== 'string') {
|
|
86
|
-
return Array.from(msg, (item) => item
|
|
86
|
+
return Array.from(msg, (item) => Math.trunc(item));
|
|
87
87
|
}
|
|
88
88
|
switch (enc) {
|
|
89
89
|
case 'hex':
|
|
@@ -112,8 +112,8 @@ const hexToArray = (msg) => {
|
|
|
112
112
|
const out = new Array(normalized.length / 2);
|
|
113
113
|
let o = 0;
|
|
114
114
|
for (let i = 0; i < normalized.length; i += 2) {
|
|
115
|
-
const hi = HEX_CHAR_TO_VALUE[normalized.
|
|
116
|
-
const lo = HEX_CHAR_TO_VALUE[normalized.
|
|
115
|
+
const hi = HEX_CHAR_TO_VALUE[normalized.codePointAt(i)];
|
|
116
|
+
const lo = HEX_CHAR_TO_VALUE[normalized.codePointAt(i + 1)];
|
|
117
117
|
out[o++] = (hi << 4) | lo;
|
|
118
118
|
}
|
|
119
119
|
return out;
|
|
@@ -123,8 +123,8 @@ function base64ToArray(msg) {
|
|
|
123
123
|
throw new TypeError('msg must be a string');
|
|
124
124
|
}
|
|
125
125
|
// cleanse string
|
|
126
|
-
let s = msg.trim().
|
|
127
|
-
s = s.
|
|
126
|
+
let s = msg.trim().replaceAll(/[\r\n\t\f\v ]+/g, '');
|
|
127
|
+
s = s.replaceAll('-', '+').replaceAll('_', '/');
|
|
128
128
|
// ensure padding is correct
|
|
129
129
|
const padIndex = s.indexOf('=');
|
|
130
130
|
if (padIndex !== -1) {
|
|
@@ -137,15 +137,11 @@ function base64ToArray(msg) {
|
|
|
137
137
|
}
|
|
138
138
|
s = s.slice(0, padIndex);
|
|
139
139
|
}
|
|
140
|
-
// if (s.length % 4 === 1)
|
|
141
|
-
// {
|
|
142
|
-
// throw new Error("Invalid base64 length")
|
|
143
|
-
// }
|
|
144
140
|
const result = [];
|
|
145
141
|
let bitBuffer = 0;
|
|
146
142
|
let bitCount = 0;
|
|
147
143
|
for (let i = 0; i < s.length; i++) {
|
|
148
|
-
const c = s.
|
|
144
|
+
const c = s.codePointAt(i);
|
|
149
145
|
// using ascii map values rather than indexOf
|
|
150
146
|
let v = -1;
|
|
151
147
|
if (c >= 65 && c <= 90) {
|
|
@@ -260,7 +256,7 @@ const fromBase58 = (str) => {
|
|
|
260
256
|
throw new Error(`Invalid base58 character “${match.join('')}”`);
|
|
261
257
|
}
|
|
262
258
|
const lz = str.match(/^1+/gmu);
|
|
263
|
-
const psz =
|
|
259
|
+
const psz = lz === null ? 0 : lz[0].length;
|
|
264
260
|
const size = ((str.length - psz) * (Math.log(58) / Math.log(256)) + 1) >>> 0;
|
|
265
261
|
const uint8 = new Uint8Array([
|
|
266
262
|
...new Uint8Array(psz),
|
|
@@ -289,31 +285,31 @@ exports.fromBase58 = fromBase58;
|
|
|
289
285
|
* @returns The base58 string representation
|
|
290
286
|
*/
|
|
291
287
|
const toBase58 = (bin) => {
|
|
292
|
-
const base58Map = Array(256).fill(-1);
|
|
288
|
+
const base58Map = new Array(256).fill(-1);
|
|
293
289
|
for (let i = 0; i < base58chars.length; ++i) {
|
|
294
|
-
base58Map[base58chars.
|
|
290
|
+
base58Map[base58chars.codePointAt(i)] = i;
|
|
295
291
|
}
|
|
296
292
|
const result = [];
|
|
297
293
|
for (const byte of bin) {
|
|
298
294
|
let carry = byte;
|
|
299
295
|
for (let j = 0; j < result.length; ++j) {
|
|
300
296
|
const x = (base58Map[result[j]] << 8) + carry;
|
|
301
|
-
result[j] = base58chars.
|
|
302
|
-
carry = (x / 58)
|
|
297
|
+
result[j] = base58chars.codePointAt(x % 58);
|
|
298
|
+
carry = Math.trunc(x / 58);
|
|
303
299
|
}
|
|
304
300
|
while (carry !== 0) {
|
|
305
|
-
result.push(base58chars.
|
|
306
|
-
carry = (carry / 58)
|
|
301
|
+
result.push(base58chars.codePointAt(carry % 58));
|
|
302
|
+
carry = Math.trunc(carry / 58);
|
|
307
303
|
}
|
|
308
304
|
}
|
|
309
305
|
for (const byte of bin) {
|
|
310
|
-
if (byte
|
|
311
|
-
|
|
306
|
+
if (byte === 0)
|
|
307
|
+
result.push('1'.codePointAt(0));
|
|
312
308
|
else
|
|
313
|
-
|
|
309
|
+
break;
|
|
314
310
|
}
|
|
315
311
|
result.reverse();
|
|
316
|
-
return String.
|
|
312
|
+
return String.fromCodePoint(...result);
|
|
317
313
|
};
|
|
318
314
|
exports.toBase58 = toBase58;
|
|
319
315
|
/**
|
|
@@ -354,7 +350,7 @@ const fromBase58Check = (str, enc, prefixLength = 1) => {
|
|
|
354
350
|
exports.fromBase58Check = fromBase58Check;
|
|
355
351
|
class Writer {
|
|
356
352
|
constructor(bufs) {
|
|
357
|
-
this.bufs = bufs
|
|
353
|
+
this.bufs = bufs ?? [];
|
|
358
354
|
this.length = 0;
|
|
359
355
|
for (const b of this.bufs)
|
|
360
356
|
this.length += b.length;
|
|
@@ -377,14 +373,14 @@ class Writer {
|
|
|
377
373
|
let offset = 0;
|
|
378
374
|
for (const buf of this.bufs) {
|
|
379
375
|
if (buf instanceof Uint8Array) {
|
|
380
|
-
for (
|
|
381
|
-
ret[offset++] =
|
|
376
|
+
for (const byte of buf) {
|
|
377
|
+
ret[offset++] = byte;
|
|
382
378
|
}
|
|
383
379
|
}
|
|
384
380
|
else {
|
|
385
381
|
const arr = buf;
|
|
386
|
-
for (
|
|
387
|
-
ret[offset++] =
|
|
382
|
+
for (const item of arr) {
|
|
383
|
+
ret[offset++] = item;
|
|
388
384
|
}
|
|
389
385
|
}
|
|
390
386
|
}
|
|
@@ -412,10 +408,7 @@ class Writer {
|
|
|
412
408
|
return this;
|
|
413
409
|
}
|
|
414
410
|
writeInt8(n) {
|
|
415
|
-
|
|
416
|
-
buf[0] = n & 0xff;
|
|
417
|
-
this.write(buf);
|
|
418
|
-
return this;
|
|
411
|
+
return this.writeUInt8(n);
|
|
419
412
|
}
|
|
420
413
|
writeUInt16BE(n) {
|
|
421
414
|
const buf = [
|
|
@@ -605,7 +598,7 @@ class Reader {
|
|
|
605
598
|
const val = this.bin[this.pos];
|
|
606
599
|
this.pos += 1;
|
|
607
600
|
// If the sign bit is set, convert to negative value
|
|
608
|
-
return (val & 0x80)
|
|
601
|
+
return (val & 0x80) === 0 ? val : val - 0x100;
|
|
609
602
|
}
|
|
610
603
|
readUInt16BE() {
|
|
611
604
|
const val = (this.bin[this.pos] << 8) | this.bin[this.pos + 1];
|
|
@@ -615,7 +608,7 @@ class Reader {
|
|
|
615
608
|
readInt16BE() {
|
|
616
609
|
const val = this.readUInt16BE();
|
|
617
610
|
// If the sign bit is set, convert to negative value
|
|
618
|
-
return (val & 0x8000)
|
|
611
|
+
return (val & 0x8000) === 0 ? val : val - 0x10000;
|
|
619
612
|
}
|
|
620
613
|
readUInt16LE() {
|
|
621
614
|
const val = this.bin[this.pos] | (this.bin[this.pos + 1] << 8);
|
|
@@ -625,7 +618,7 @@ class Reader {
|
|
|
625
618
|
readInt16LE() {
|
|
626
619
|
const val = this.readUInt16LE();
|
|
627
620
|
// If the sign bit is set, convert to negative value
|
|
628
|
-
const x = (val & 0x8000)
|
|
621
|
+
const x = (val & 0x8000) === 0 ? val : val - 0x10000;
|
|
629
622
|
return x;
|
|
630
623
|
}
|
|
631
624
|
readUInt32BE() {
|
|
@@ -639,7 +632,7 @@ class Reader {
|
|
|
639
632
|
readInt32BE() {
|
|
640
633
|
const val = this.readUInt32BE();
|
|
641
634
|
// If the sign bit is set, convert to negative value
|
|
642
|
-
return (val & 0x80000000)
|
|
635
|
+
return (val & 0x80000000) === 0 ? val : val - 0x100000000;
|
|
643
636
|
}
|
|
644
637
|
readUInt32LE() {
|
|
645
638
|
const val = (this.bin[this.pos] |
|
|
@@ -653,7 +646,7 @@ class Reader {
|
|
|
653
646
|
readInt32LE() {
|
|
654
647
|
const val = this.readUInt32LE();
|
|
655
648
|
// Explicitly check if the sign bit is set and then convert to a negative value
|
|
656
|
-
return (val & 0x80000000)
|
|
649
|
+
return (val & 0x80000000) === 0 ? val : val - 0x100000000;
|
|
657
650
|
}
|
|
658
651
|
readUInt64BEBn() {
|
|
659
652
|
const bin = this.bin.slice(this.pos, this.pos + 8);
|
|
@@ -727,7 +720,7 @@ const minimallyEncode = (buf) => {
|
|
|
727
720
|
return buf;
|
|
728
721
|
}
|
|
729
722
|
// If the last byte is not 0x00 or 0x80, we are minimally encoded.
|
|
730
|
-
const last = buf
|
|
723
|
+
const last = buf.at(-1);
|
|
731
724
|
if ((last & 0x7f) !== 0) {
|
|
732
725
|
return buf;
|
|
733
726
|
}
|
|
@@ -737,24 +730,24 @@ const minimallyEncode = (buf) => {
|
|
|
737
730
|
return [];
|
|
738
731
|
}
|
|
739
732
|
// If the next byte has it sign bit set, then we are minimaly encoded.
|
|
740
|
-
if ((buf
|
|
733
|
+
if ((buf.at(-2) & 0x80) !== 0) {
|
|
741
734
|
return buf;
|
|
742
735
|
}
|
|
743
736
|
// We are not minimally encoded, we need to figure out how much to trim.
|
|
744
737
|
for (let i = buf.length - 1; i > 0; i--) {
|
|
745
738
|
// We found a non zero byte, time to encode.
|
|
746
739
|
if (buf[i - 1] !== 0) {
|
|
747
|
-
if ((buf[i - 1] & 0x80)
|
|
740
|
+
if ((buf[i - 1] & 0x80) === 0) {
|
|
741
|
+
// the sign bit is clear, we can use it.
|
|
742
|
+
buf[i - 1] |= last;
|
|
743
|
+
return buf.slice(0, i);
|
|
744
|
+
}
|
|
745
|
+
else {
|
|
748
746
|
// We found a byte with it sign bit set so we need one more
|
|
749
747
|
// byte.
|
|
750
748
|
buf[i] = last;
|
|
751
749
|
return buf.slice(0, i + 1);
|
|
752
750
|
}
|
|
753
|
-
else {
|
|
754
|
-
// the sign bit is clear, we can use it.
|
|
755
|
-
buf[i - 1] |= last;
|
|
756
|
-
return buf.slice(0, i);
|
|
757
|
-
}
|
|
758
751
|
}
|
|
759
752
|
}
|
|
760
753
|
// If we found the whole thing is zeros, then we have a zero.
|