@btc-vision/bitcoin 6.5.5 → 7.0.0-alpha.0
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/AUDIT/README.md +9 -0
- package/HOW_TO_WRITE_GOOD_CODE.md +2436 -0
- package/SECURITY.md +27 -0
- package/benchmark/psbt-2000-inputs.bench.ts +178 -0
- package/benchmark/signing.bench.ts +147 -0
- package/browser/address.d.ts +56 -9
- package/browser/address.d.ts.map +1 -0
- package/browser/bech32utils.d.ts +9 -1
- package/browser/bech32utils.d.ts.map +1 -0
- package/browser/bip66.d.ts +11 -6
- package/browser/bip66.d.ts.map +1 -0
- package/browser/block.d.ts +117 -11
- package/browser/block.d.ts.map +1 -0
- package/browser/branded.d.ts +20 -0
- package/browser/branded.d.ts.map +1 -0
- package/browser/crypto/crypto.d.ts +1 -0
- package/browser/crypto/crypto.d.ts.map +1 -0
- package/browser/crypto.d.ts +46 -7
- package/browser/crypto.d.ts.map +1 -0
- package/browser/ecc/context.d.ts +129 -0
- package/browser/ecc/context.d.ts.map +1 -0
- package/browser/ecc/index.d.ts +11 -0
- package/browser/ecc/index.d.ts.map +1 -0
- package/browser/ecc/types.d.ts +128 -0
- package/browser/ecc/types.d.ts.map +1 -0
- package/browser/ecpair.d.ts +99 -0
- package/browser/errors.d.ts +124 -0
- package/browser/errors.d.ts.map +1 -0
- package/browser/index.d.ts +32 -5
- package/browser/index.d.ts.map +1 -0
- package/browser/index.js +12482 -101
- package/browser/io/BinaryReader.d.ts +276 -0
- package/browser/io/BinaryReader.d.ts.map +1 -0
- package/browser/io/BinaryWriter.d.ts +391 -0
- package/browser/io/BinaryWriter.d.ts.map +1 -0
- package/browser/io/MemoryPool.d.ts +220 -0
- package/browser/io/MemoryPool.d.ts.map +1 -0
- package/browser/io/base64.d.ts +13 -0
- package/browser/io/base64.d.ts.map +1 -0
- package/browser/io/hex.d.ts +67 -0
- package/browser/io/hex.d.ts.map +1 -0
- package/browser/io/index.d.ts +17 -0
- package/browser/io/index.d.ts.map +1 -0
- package/browser/io/utils.d.ts +199 -0
- package/browser/io/utils.d.ts.map +1 -0
- package/browser/merkle.d.ts +10 -1
- package/browser/merkle.d.ts.map +1 -0
- package/browser/networks.d.ts +70 -9
- package/browser/networks.d.ts.map +1 -0
- package/browser/opcodes.d.ts +1 -0
- package/browser/opcodes.d.ts.map +1 -0
- package/browser/payments/bip341.d.ts +35 -9
- package/browser/payments/bip341.d.ts.map +1 -0
- package/browser/payments/embed.d.ts +112 -1
- package/browser/payments/embed.d.ts.map +1 -0
- package/browser/payments/index.d.ts +17 -10
- package/browser/payments/index.d.ts.map +1 -0
- package/browser/payments/p2ms.d.ts +150 -0
- package/browser/payments/p2ms.d.ts.map +1 -0
- package/browser/payments/p2op.d.ts +150 -24
- package/browser/payments/p2op.d.ts.map +1 -0
- package/browser/payments/p2pk.d.ts +154 -1
- package/browser/payments/p2pk.d.ts.map +1 -0
- package/browser/payments/p2pkh.d.ts +176 -1
- package/browser/payments/p2pkh.d.ts.map +1 -0
- package/browser/payments/p2sh.d.ts +150 -1
- package/browser/payments/p2sh.d.ts.map +1 -0
- package/browser/payments/p2tr.d.ts +185 -1
- package/browser/payments/p2tr.d.ts.map +1 -0
- package/browser/payments/p2wpkh.d.ts +161 -1
- package/browser/payments/p2wpkh.d.ts.map +1 -0
- package/browser/payments/p2wsh.d.ts +146 -1
- package/browser/payments/p2wsh.d.ts.map +1 -0
- package/browser/payments/types.d.ts +94 -64
- package/browser/payments/types.d.ts.map +1 -0
- package/browser/psbt/bip371.d.ts +34 -8
- package/browser/psbt/bip371.d.ts.map +1 -0
- package/browser/psbt/psbtutils.d.ts +56 -16
- package/browser/psbt/psbtutils.d.ts.map +1 -0
- package/browser/psbt/types.d.ts +245 -0
- package/browser/psbt/types.d.ts.map +1 -0
- package/browser/psbt/utils.d.ts +64 -0
- package/browser/psbt/utils.d.ts.map +1 -0
- package/browser/psbt/validation.d.ts +84 -0
- package/browser/psbt/validation.d.ts.map +1 -0
- package/browser/psbt.d.ts +82 -118
- package/browser/psbt.d.ts.map +1 -0
- package/browser/pubkey.d.ts +27 -6
- package/browser/pubkey.d.ts.map +1 -0
- package/browser/push_data.d.ts +24 -2
- package/browser/push_data.d.ts.map +1 -0
- package/browser/script.d.ts +33 -8
- package/browser/script.d.ts.map +1 -0
- package/browser/script_number.d.ts +17 -0
- package/browser/script_number.d.ts.map +1 -0
- package/browser/script_signature.d.ts +23 -5
- package/browser/script_signature.d.ts.map +1 -0
- package/browser/transaction.d.ts +160 -18
- package/browser/transaction.d.ts.map +1 -0
- package/browser/types.d.ts +36 -38
- package/browser/types.d.ts.map +1 -0
- package/browser/workers/WorkerSigningPool.d.ts +143 -0
- package/browser/workers/WorkerSigningPool.d.ts.map +1 -0
- package/browser/workers/WorkerSigningPool.node.d.ts +116 -0
- package/browser/workers/WorkerSigningPool.node.d.ts.map +1 -0
- package/browser/workers/ecc-bundle.d.ts +25 -0
- package/browser/workers/ecc-bundle.d.ts.map +1 -0
- package/browser/workers/index.d.ts +91 -0
- package/browser/workers/index.d.ts.map +1 -0
- package/browser/workers/psbt-parallel.d.ts +88 -0
- package/browser/workers/psbt-parallel.d.ts.map +1 -0
- package/browser/workers/signing-worker.d.ts +37 -0
- package/browser/workers/signing-worker.d.ts.map +1 -0
- package/browser/workers/types.d.ts +365 -0
- package/browser/workers/types.d.ts.map +1 -0
- package/build/address.d.ts +57 -10
- package/build/address.d.ts.map +1 -0
- package/build/address.js +80 -24
- package/build/address.js.map +1 -0
- package/build/bech32utils.d.ts +9 -1
- package/build/bech32utils.d.ts.map +1 -0
- package/build/bech32utils.js +10 -2
- package/build/bech32utils.js.map +1 -0
- package/build/bip66.d.ts +11 -6
- package/build/bip66.d.ts.map +1 -0
- package/build/bip66.js +32 -3
- package/build/bip66.js.map +1 -0
- package/build/block.d.ts +117 -11
- package/build/block.d.ts.map +1 -0
- package/build/block.js +204 -72
- package/build/block.js.map +1 -0
- package/build/branded.d.ts +20 -0
- package/build/branded.d.ts.map +1 -0
- package/build/branded.js +7 -0
- package/build/branded.js.map +1 -0
- package/build/crypto/crypto.d.ts +1 -0
- package/build/crypto/crypto.d.ts.map +1 -0
- package/build/crypto/crypto.js +1 -0
- package/build/crypto/crypto.js.map +1 -0
- package/build/crypto.d.ts +46 -7
- package/build/crypto.d.ts.map +1 -0
- package/build/crypto.js +65 -20
- package/build/crypto.js.map +1 -0
- package/build/ecc/context.d.ts +135 -0
- package/build/ecc/context.d.ts.map +1 -0
- package/build/ecc/context.js +232 -0
- package/build/ecc/context.js.map +1 -0
- package/build/ecc/index.d.ts +11 -0
- package/build/ecc/index.d.ts.map +1 -0
- package/build/ecc/index.js +11 -0
- package/build/ecc/index.js.map +1 -0
- package/build/ecc/types.d.ts +134 -0
- package/build/ecc/types.d.ts.map +1 -0
- package/build/ecc/types.js +8 -0
- package/build/ecc/types.js.map +1 -0
- package/build/errors.d.ts +124 -0
- package/build/errors.d.ts.map +1 -0
- package/build/errors.js +155 -0
- package/build/errors.js.map +1 -0
- package/build/index.d.ts +32 -5
- package/build/index.d.ts.map +1 -0
- package/build/index.js +26 -3
- package/build/index.js.map +1 -0
- package/build/io/BinaryReader.d.ts +276 -0
- package/build/io/BinaryReader.d.ts.map +1 -0
- package/build/io/BinaryReader.js +425 -0
- package/build/io/BinaryReader.js.map +1 -0
- package/build/io/BinaryWriter.d.ts +391 -0
- package/build/io/BinaryWriter.d.ts.map +1 -0
- package/build/io/BinaryWriter.js +611 -0
- package/build/io/BinaryWriter.js.map +1 -0
- package/build/io/MemoryPool.d.ts +220 -0
- package/build/io/MemoryPool.d.ts.map +1 -0
- package/build/io/MemoryPool.js +309 -0
- package/build/io/MemoryPool.js.map +1 -0
- package/build/io/base64.d.ts +13 -0
- package/build/io/base64.d.ts.map +1 -0
- package/build/io/base64.js +20 -0
- package/build/io/base64.js.map +1 -0
- package/build/io/hex.d.ts +67 -0
- package/build/io/hex.d.ts.map +1 -0
- package/build/io/hex.js +138 -0
- package/build/io/hex.js.map +1 -0
- package/build/io/index.d.ts +17 -0
- package/build/io/index.d.ts.map +1 -0
- package/build/io/index.js +23 -0
- package/build/io/index.js.map +1 -0
- package/build/io/utils.d.ts +199 -0
- package/build/io/utils.d.ts.map +1 -0
- package/build/io/utils.js +271 -0
- package/build/io/utils.js.map +1 -0
- package/build/merkle.d.ts +10 -1
- package/build/merkle.d.ts.map +1 -0
- package/build/merkle.js +12 -1
- package/build/merkle.js.map +1 -0
- package/build/networks.d.ts +70 -9
- package/build/networks.d.ts.map +1 -0
- package/build/networks.js +90 -4
- package/build/networks.js.map +1 -0
- package/build/opcodes.d.ts +1 -0
- package/build/opcodes.d.ts.map +1 -0
- package/build/opcodes.js +1 -0
- package/build/opcodes.js.map +1 -0
- package/build/payments/bip341.d.ts +36 -9
- package/build/payments/bip341.d.ts.map +1 -0
- package/build/payments/bip341.js +35 -15
- package/build/payments/bip341.js.map +1 -0
- package/build/payments/embed.d.ts +120 -1
- package/build/payments/embed.d.ts.map +1 -0
- package/build/payments/embed.js +215 -34
- package/build/payments/embed.js.map +1 -0
- package/build/payments/index.d.ts +17 -10
- package/build/payments/index.d.ts.map +1 -0
- package/build/payments/index.js +20 -10
- package/build/payments/index.js.map +1 -0
- package/build/payments/p2ms.d.ts +159 -1
- package/build/payments/p2ms.d.ts.map +1 -0
- package/build/payments/p2ms.js +427 -108
- package/build/payments/p2ms.js.map +1 -0
- package/build/payments/p2op.d.ts +158 -24
- package/build/payments/p2op.d.ts.map +1 -0
- package/build/payments/p2op.js +379 -93
- package/build/payments/p2op.js.map +1 -0
- package/build/payments/p2pk.d.ts +162 -1
- package/build/payments/p2pk.d.ts.map +1 -0
- package/build/payments/p2pk.js +327 -58
- package/build/payments/p2pk.js.map +1 -0
- package/build/payments/p2pkh.d.ts +185 -1
- package/build/payments/p2pkh.d.ts.map +1 -0
- package/build/payments/p2pkh.js +467 -114
- package/build/payments/p2pkh.js.map +1 -0
- package/build/payments/p2sh.d.ts +159 -1
- package/build/payments/p2sh.d.ts.map +1 -0
- package/build/payments/p2sh.js +500 -152
- package/build/payments/p2sh.js.map +1 -0
- package/build/payments/p2tr.d.ts +193 -1
- package/build/payments/p2tr.d.ts.map +1 -0
- package/build/payments/p2tr.js +592 -174
- package/build/payments/p2tr.js.map +1 -0
- package/build/payments/p2wpkh.d.ts +170 -1
- package/build/payments/p2wpkh.d.ts.map +1 -0
- package/build/payments/p2wpkh.js +429 -104
- package/build/payments/p2wpkh.js.map +1 -0
- package/build/payments/p2wsh.d.ts +155 -1
- package/build/payments/p2wsh.d.ts.map +1 -0
- package/build/payments/p2wsh.js +466 -144
- package/build/payments/p2wsh.js.map +1 -0
- package/build/payments/types.d.ts +98 -64
- package/build/payments/types.d.ts.map +1 -0
- package/build/payments/types.js +17 -13
- package/build/payments/types.js.map +1 -0
- package/build/psbt/bip371.d.ts +35 -9
- package/build/psbt/bip371.d.ts.map +1 -0
- package/build/psbt/bip371.js +113 -28
- package/build/psbt/bip371.js.map +1 -0
- package/build/psbt/psbtutils.d.ts +56 -16
- package/build/psbt/psbtutils.d.ts.map +1 -0
- package/build/psbt/psbtutils.js +71 -16
- package/build/psbt/psbtutils.js.map +1 -0
- package/build/psbt/types.d.ts +249 -0
- package/build/psbt/types.d.ts.map +1 -0
- package/build/psbt/types.js +6 -0
- package/build/psbt/types.js.map +1 -0
- package/build/psbt/utils.d.ts +68 -0
- package/build/psbt/utils.d.ts.map +1 -0
- package/build/psbt/utils.js +171 -0
- package/build/psbt/utils.js.map +1 -0
- package/build/psbt/validation.d.ts +88 -0
- package/build/psbt/validation.d.ts.map +1 -0
- package/build/psbt/validation.js +149 -0
- package/build/psbt/validation.js.map +1 -0
- package/build/psbt.d.ts +84 -120
- package/build/psbt.d.ts.map +1 -0
- package/build/psbt.js +411 -412
- package/build/psbt.js.map +1 -0
- package/build/pubkey.d.ts +27 -6
- package/build/pubkey.d.ts.map +1 -0
- package/build/pubkey.js +37 -13
- package/build/pubkey.js.map +1 -0
- package/build/push_data.d.ts +24 -2
- package/build/push_data.d.ts.map +1 -0
- package/build/push_data.js +44 -12
- package/build/push_data.js.map +1 -0
- package/build/script.d.ts +33 -8
- package/build/script.d.ts.map +1 -0
- package/build/script.js +100 -36
- package/build/script.js.map +1 -0
- package/build/script_number.d.ts +17 -0
- package/build/script_number.d.ts.map +1 -0
- package/build/script_number.js +19 -0
- package/build/script_number.js.map +1 -0
- package/build/script_signature.d.ts +23 -5
- package/build/script_signature.d.ts.map +1 -0
- package/build/script_signature.js +48 -15
- package/build/script_signature.js.map +1 -0
- package/build/transaction.d.ts +160 -18
- package/build/transaction.d.ts.map +1 -0
- package/build/transaction.js +443 -176
- package/build/transaction.js.map +1 -0
- package/build/tsconfig.build.tsbuildinfo +1 -0
- package/build/types.d.ts +36 -38
- package/build/types.d.ts.map +1 -0
- package/build/types.js +175 -57
- package/build/types.js.map +1 -0
- package/build/workers/WorkerSigningPool.d.ts +174 -0
- package/build/workers/WorkerSigningPool.d.ts.map +1 -0
- package/build/workers/WorkerSigningPool.js +553 -0
- package/build/workers/WorkerSigningPool.js.map +1 -0
- package/build/workers/WorkerSigningPool.node.d.ts +124 -0
- package/build/workers/WorkerSigningPool.node.d.ts.map +1 -0
- package/build/workers/WorkerSigningPool.node.js +753 -0
- package/build/workers/WorkerSigningPool.node.js.map +1 -0
- package/build/workers/ecc-bundle.d.ts +25 -0
- package/build/workers/ecc-bundle.d.ts.map +1 -0
- package/build/workers/ecc-bundle.js +25 -0
- package/build/workers/ecc-bundle.js.map +1 -0
- package/build/workers/index.d.ts +91 -0
- package/build/workers/index.d.ts.map +1 -0
- package/build/workers/index.js +114 -0
- package/build/workers/index.js.map +1 -0
- package/build/workers/psbt-parallel.d.ts +117 -0
- package/build/workers/psbt-parallel.d.ts.map +1 -0
- package/build/workers/psbt-parallel.js +233 -0
- package/build/workers/psbt-parallel.js.map +1 -0
- package/build/workers/signing-worker.d.ts +37 -0
- package/build/workers/signing-worker.d.ts.map +1 -0
- package/build/workers/signing-worker.js +350 -0
- package/build/workers/signing-worker.js.map +1 -0
- package/build/workers/types.d.ts +365 -0
- package/build/workers/types.d.ts.map +1 -0
- package/build/workers/types.js +60 -0
- package/build/workers/types.js.map +1 -0
- package/package.json +83 -25
- package/scripts/bundle-ecc.ts +111 -0
- package/src/address.ts +81 -44
- package/src/bech32utils.ts +3 -3
- package/src/bip66.ts +34 -24
- package/src/block.ts +196 -84
- package/src/branded.ts +18 -0
- package/src/crypto.ts +64 -26
- package/src/ecc/context.ts +277 -0
- package/src/ecc/index.ts +14 -0
- package/src/ecc/types.ts +154 -0
- package/src/ecpair.d.ts +99 -0
- package/src/errors.ts +163 -0
- package/src/index.ts +113 -9
- package/src/io/BinaryReader.ts +461 -0
- package/src/io/BinaryWriter.ts +696 -0
- package/src/io/MemoryPool.ts +343 -0
- package/src/io/base64.ts +20 -0
- package/src/io/hex.ts +155 -0
- package/src/io/index.ts +41 -0
- package/src/io/utils.ts +283 -0
- package/src/merkle.ts +14 -9
- package/src/networks.ts +9 -9
- package/src/payments/bip341.ts +34 -33
- package/src/payments/embed.ts +244 -41
- package/src/payments/index.ts +12 -10
- package/src/payments/p2ms.ts +490 -118
- package/src/payments/p2op.ts +431 -133
- package/src/payments/p2pk.ts +370 -72
- package/src/payments/p2pkh.ts +524 -130
- package/src/payments/p2sh.ts +572 -172
- package/src/payments/p2tr.ts +686 -194
- package/src/payments/p2wpkh.ts +484 -107
- package/src/payments/p2wsh.ts +526 -164
- package/src/payments/types.ts +80 -66
- package/src/psbt/bip371.ts +68 -51
- package/src/psbt/psbtutils.ts +39 -40
- package/src/psbt/types.ts +331 -0
- package/src/psbt/utils.ts +188 -0
- package/src/psbt/validation.ts +192 -0
- package/src/psbt.ts +566 -809
- package/src/pubkey.ts +24 -25
- package/src/push_data.ts +18 -16
- package/src/script.ts +82 -64
- package/src/script_number.ts +6 -6
- package/src/script_signature.ts +33 -36
- package/src/transaction.ts +458 -238
- package/src/types.ts +231 -100
- package/src/workers/WorkerSigningPool.node.ts +887 -0
- package/src/workers/WorkerSigningPool.ts +670 -0
- package/src/workers/ecc-bundle.ts +26 -0
- package/src/workers/index.ts +165 -0
- package/src/workers/psbt-parallel.ts +332 -0
- package/src/workers/signing-worker.ts +353 -0
- package/src/workers/types.ts +413 -0
- package/test/address.spec.ts +9 -6
- package/test/bitcoin.core.spec.ts +16 -17
- package/test/block.spec.ts +8 -7
- package/test/bufferutils.spec.ts +228 -214
- package/test/crypto.spec.ts +19 -11
- package/test/fixtures/p2pk.json +0 -8
- package/test/fixtures/p2pkh.json +1 -1
- package/test/fixtures/p2sh.json +1 -1
- package/test/fixtures/script.json +1 -1
- package/test/fixtures/transaction.json +2 -2
- package/test/integration/_regtest.ts +25 -0
- package/test/integration/addresses.spec.ts +4 -3
- package/test/integration/bip32.spec.ts +2 -1
- package/test/integration/blocks.spec.ts +1 -1
- package/test/integration/cltv.spec.ts +18 -16
- package/test/integration/csv.spec.ts +37 -64
- package/test/integration/payments.spec.ts +5 -3
- package/test/integration/taproot.spec.ts +76 -83
- package/test/integration/transactions.spec.ts +38 -35
- package/test/payments.spec.ts +35 -13
- package/test/payments.utils.ts +17 -16
- package/test/psbt.spec.ts +111 -100
- package/test/script.spec.ts +11 -10
- package/test/script_signature.spec.ts +9 -11
- package/test/taproot-cache.spec.ts +694 -0
- package/test/transaction.spec.ts +32 -40
- package/test/types.spec.ts +74 -29
- package/test/workers-pool.spec.ts +963 -0
- package/test/workers-signing.spec.ts +635 -0
- package/test/workers.spec.ts +1390 -0
- package/tsconfig.base.json +34 -18
- package/tsconfig.browser.json +15 -0
- package/tsconfig.build.json +5 -0
- package/tsconfig.json +5 -14
- package/vite.config.browser.ts +3 -42
- package/vitest.config.integration.ts +11 -0
- package/browser/bufferutils.d.ts +0 -34
- package/browser/chunks/crypto-BhCpKpek.js +0 -2033
- package/browser/chunks/payments-yjA0Evsv.js +0 -1089
- package/browser/chunks/psbt-URK2hBFc.js +0 -4039
- package/browser/chunks/script-DyPItFEl.js +0 -318
- package/browser/chunks/transaction-C_UbhMGn.js +0 -432
- package/browser/chunks/utils-DNZi-T5W.js +0 -761
- package/browser/ecc_lib.d.ts +0 -3
- package/browser/hooks/AdvancedSignatureManager.d.ts +0 -16
- package/browser/hooks/HookedSigner.d.ts +0 -4
- package/browser/hooks/SignatureManager.d.ts +0 -13
- package/browser/payments/lazy.d.ts +0 -2
- package/browser/typeforce.d.ts +0 -38
- package/build/bufferutils.d.ts +0 -34
- package/build/bufferutils.js +0 -141
- package/build/ecc_lib.d.ts +0 -3
- package/build/ecc_lib.js +0 -61
- package/build/hooks/AdvancedSignatureManager.d.ts +0 -16
- package/build/hooks/AdvancedSignatureManager.js +0 -52
- package/build/hooks/HookedSigner.d.ts +0 -4
- package/build/hooks/HookedSigner.js +0 -64
- package/build/hooks/SignatureManager.d.ts +0 -13
- package/build/hooks/SignatureManager.js +0 -45
- package/build/payments/lazy.d.ts +0 -2
- package/build/payments/lazy.js +0 -28
- package/build/tsconfig.tsbuildinfo +0 -1
- package/src/bufferutils.ts +0 -188
- package/src/ecc_lib.ts +0 -94
- package/src/hooks/AdvancedSignatureManager.ts +0 -104
- package/src/hooks/HookedSigner.ts +0 -108
- package/src/hooks/SignatureManager.ts +0 -84
- package/src/payments/lazy.ts +0 -28
- package/src/typeforce.d.ts +0 -38
- package/tsconfig.webpack.json +0 -18
package/test/transaction.spec.ts
CHANGED
|
@@ -2,6 +2,7 @@ import assert from 'assert';
|
|
|
2
2
|
import { beforeEach, describe, it } from 'vitest';
|
|
3
3
|
import { Transaction } from '../src/index.js';
|
|
4
4
|
import * as bscript from '../src/script.js';
|
|
5
|
+
import type { Bytes32, Script, Satoshi } from '../src/types.js';
|
|
5
6
|
import fixtures from './fixtures/transaction.json' with { type: 'json' };
|
|
6
7
|
|
|
7
8
|
describe('Transaction', () => {
|
|
@@ -11,11 +12,11 @@ describe('Transaction', () => {
|
|
|
11
12
|
tx.locktime = raw.locktime;
|
|
12
13
|
|
|
13
14
|
raw.ins.forEach((txIn: any, i: number) => {
|
|
14
|
-
const txHash = Buffer.from(txIn.hash, 'hex');
|
|
15
|
+
const txHash = Buffer.from(txIn.hash, 'hex') as unknown as Bytes32;
|
|
15
16
|
let scriptSig;
|
|
16
17
|
|
|
17
18
|
if (txIn.data) {
|
|
18
|
-
scriptSig = Buffer.from(txIn.data, 'hex');
|
|
19
|
+
scriptSig = Buffer.from(txIn.data, 'hex') as unknown as Script;
|
|
19
20
|
} else if (txIn.script) {
|
|
20
21
|
scriptSig = bscript.fromASM(txIn.script);
|
|
21
22
|
}
|
|
@@ -32,15 +33,15 @@ describe('Transaction', () => {
|
|
|
32
33
|
});
|
|
33
34
|
|
|
34
35
|
raw.outs.forEach((txOut: any) => {
|
|
35
|
-
let script:
|
|
36
|
+
let script: Script;
|
|
36
37
|
|
|
37
38
|
if (txOut.data) {
|
|
38
|
-
script = Buffer.from(txOut.data, 'hex');
|
|
39
|
+
script = Buffer.from(txOut.data, 'hex') as unknown as Script;
|
|
39
40
|
} else if (txOut.script) {
|
|
40
41
|
script = bscript.fromASM(txOut.script);
|
|
41
42
|
}
|
|
42
43
|
|
|
43
|
-
tx.addOutput(script!, txOut.value);
|
|
44
|
+
tx.addOutput(script!, BigInt(txOut.value) as Satoshi);
|
|
44
45
|
});
|
|
45
46
|
|
|
46
47
|
return tx;
|
|
@@ -112,11 +113,11 @@ describe('Transaction', () => {
|
|
|
112
113
|
|
|
113
114
|
assert.strictEqual(a.length, byteLength);
|
|
114
115
|
assert.strictEqual(b.length, byteLength);
|
|
115
|
-
assert.strictEqual(a.toString('hex'), f.hex);
|
|
116
|
-
assert.strictEqual(b.toString('hex'), f.hex);
|
|
116
|
+
assert.strictEqual(Buffer.from(a).toString('hex'), f.hex);
|
|
117
|
+
assert.strictEqual(Buffer.from(b).toString('hex'), f.hex);
|
|
117
118
|
assert.deepStrictEqual(a, b);
|
|
118
|
-
assert.deepStrictEqual(a, target.slice(0, byteLength));
|
|
119
|
-
assert.deepStrictEqual(b, target.slice(byteLength));
|
|
119
|
+
assert.deepStrictEqual(Buffer.from(a), target.slice(0, byteLength));
|
|
120
|
+
assert.deepStrictEqual(Buffer.from(b), target.slice(byteLength));
|
|
120
121
|
});
|
|
121
122
|
});
|
|
122
123
|
|
|
@@ -150,12 +151,12 @@ describe('Transaction', () => {
|
|
|
150
151
|
});
|
|
151
152
|
|
|
152
153
|
describe('addInput', () => {
|
|
153
|
-
let prevTxHash:
|
|
154
|
+
let prevTxHash: Bytes32;
|
|
154
155
|
beforeEach(() => {
|
|
155
156
|
prevTxHash = Buffer.from(
|
|
156
157
|
'ffffffff00ffff000000000000000000000000000000000000000000101010ff',
|
|
157
158
|
'hex',
|
|
158
|
-
);
|
|
159
|
+
) as unknown as Bytes32;
|
|
159
160
|
});
|
|
160
161
|
|
|
161
162
|
it('returns an index', () => {
|
|
@@ -176,7 +177,7 @@ describe('Transaction', () => {
|
|
|
176
177
|
fixtures.invalid.addInput.forEach((f) => {
|
|
177
178
|
it('throws on ' + f.exception, () => {
|
|
178
179
|
const tx = new Transaction();
|
|
179
|
-
const hash = Buffer.from(f.hash, 'hex');
|
|
180
|
+
const hash = Buffer.from(f.hash, 'hex') as unknown as Bytes32;
|
|
180
181
|
|
|
181
182
|
assert.throws(() => {
|
|
182
183
|
tx.addInput(hash, f.index);
|
|
@@ -188,8 +189,8 @@ describe('Transaction', () => {
|
|
|
188
189
|
describe('addOutput', () => {
|
|
189
190
|
it('returns an index', () => {
|
|
190
191
|
const tx = new Transaction();
|
|
191
|
-
assert.strictEqual(tx.addOutput(Buffer.alloc(0),
|
|
192
|
-
assert.strictEqual(tx.addOutput(Buffer.alloc(0),
|
|
192
|
+
assert.strictEqual(tx.addOutput(Buffer.alloc(0) as unknown as Script, 0n as Satoshi), 0);
|
|
193
|
+
assert.strictEqual(tx.addOutput(Buffer.alloc(0) as unknown as Script, 0n as Satoshi), 1);
|
|
193
194
|
});
|
|
194
195
|
});
|
|
195
196
|
|
|
@@ -218,7 +219,7 @@ describe('Transaction', () => {
|
|
|
218
219
|
it('should return the id for ' + f.id + '(' + f.description + ')', () => {
|
|
219
220
|
const tx = Transaction.fromHex(f.whex || f.hex);
|
|
220
221
|
|
|
221
|
-
assert.strictEqual(tx.getHash().toString('hex'), f.hash);
|
|
222
|
+
assert.strictEqual(Buffer.from(tx.getHash()).toString('hex'), f.hash);
|
|
222
223
|
assert.strictEqual(tx.getId(), f.id);
|
|
223
224
|
});
|
|
224
225
|
}
|
|
@@ -247,25 +248,18 @@ describe('Transaction', () => {
|
|
|
247
248
|
Buffer.from(
|
|
248
249
|
'0000000000000000000000000000000000000000000000000000000000000000',
|
|
249
250
|
'hex',
|
|
250
|
-
),
|
|
251
|
+
) as unknown as Bytes32,
|
|
251
252
|
0,
|
|
252
253
|
);
|
|
253
|
-
tx.addOutput(randScript,
|
|
254
|
-
|
|
255
|
-
const original = (tx as any).__toBuffer;
|
|
256
|
-
(tx as any).__toBuffer = function (this: Transaction, a: any, b: any, c: any): any {
|
|
257
|
-
if (c !== false) throw new Error('hashForSignature MUST pass false');
|
|
254
|
+
tx.addOutput(randScript as unknown as Script, 5000000000n as Satoshi);
|
|
258
255
|
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
assert.throws(() => {
|
|
263
|
-
(tx as any).__toBuffer(undefined, undefined, true);
|
|
264
|
-
}, /hashForSignature MUST pass false/);
|
|
256
|
+
// Note: __toBuffer has been converted to #toBuffer (true private field)
|
|
257
|
+
// which cannot be accessed from tests. The behavior is tested through
|
|
258
|
+
// the expected hash output in the fixtures below.
|
|
265
259
|
|
|
266
|
-
//
|
|
260
|
+
// Test that hashForSignature works correctly
|
|
267
261
|
assert.doesNotThrow(() => {
|
|
268
|
-
tx.hashForSignature(0, randScript, 1);
|
|
262
|
+
tx.hashForSignature(0, randScript as unknown as Script, 1);
|
|
269
263
|
});
|
|
270
264
|
});
|
|
271
265
|
|
|
@@ -280,7 +274,7 @@ describe('Transaction', () => {
|
|
|
280
274
|
const script = bscript.fromASM(f.script);
|
|
281
275
|
|
|
282
276
|
assert.strictEqual(
|
|
283
|
-
tx.hashForSignature(f.inIndex, script, f.type).toString('hex'),
|
|
277
|
+
Buffer.from(tx.hashForSignature(f.inIndex, script, f.type)).toString('hex'),
|
|
284
278
|
f.hash,
|
|
285
279
|
);
|
|
286
280
|
},
|
|
@@ -299,10 +293,8 @@ describe('Transaction', () => {
|
|
|
299
293
|
const tx = Transaction.fromHex(f.txHex);
|
|
300
294
|
const script = bscript.fromASM(f.script);
|
|
301
295
|
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
f.hash,
|
|
305
|
-
);
|
|
296
|
+
const hash = tx.hashForWitnessV0(f.inIndex, script, BigInt(f.value) as Satoshi, f.type);
|
|
297
|
+
assert.strictEqual(Buffer.from(hash).toString('hex'), f.hash);
|
|
306
298
|
},
|
|
307
299
|
);
|
|
308
300
|
});
|
|
@@ -311,27 +303,27 @@ describe('Transaction', () => {
|
|
|
311
303
|
describe('taprootSigning', () => {
|
|
312
304
|
fixtures.taprootSigning.forEach((f) => {
|
|
313
305
|
const tx = Transaction.fromHex(f.txHex);
|
|
314
|
-
const prevOutScripts = f.utxos.map(({ scriptHex }) => Buffer.from(scriptHex, 'hex'));
|
|
315
|
-
const values = f.utxos.map(({ value }) => value);
|
|
306
|
+
const prevOutScripts = f.utxos.map(({ scriptHex }) => Buffer.from(scriptHex, 'hex')) as unknown as Script[];
|
|
307
|
+
const values = f.utxos.map(({ value }) => BigInt(value)) as Satoshi[];
|
|
316
308
|
|
|
317
309
|
f.cases.forEach((c) => {
|
|
318
|
-
let hash:
|
|
310
|
+
let hash: Uint8Array;
|
|
319
311
|
|
|
320
312
|
it(`should hash to ${c.hash} for ${f.description}:${c.vin}`, () => {
|
|
321
313
|
const hashType = Buffer.from(c.typeHex, 'hex').readUInt8(0);
|
|
322
314
|
|
|
323
315
|
hash = tx.hashForWitnessV1(c.vin, prevOutScripts, values, hashType);
|
|
324
|
-
assert.strictEqual(hash.toString('hex'), c.hash);
|
|
316
|
+
assert.strictEqual(Buffer.from(hash).toString('hex'), c.hash);
|
|
325
317
|
});
|
|
326
318
|
});
|
|
327
319
|
});
|
|
328
320
|
});
|
|
329
321
|
|
|
330
322
|
describe('setWitness', () => {
|
|
331
|
-
it('only accepts a witness stack (Array of
|
|
323
|
+
it('only accepts a witness stack (Array of Uint8Arrays)', () => {
|
|
332
324
|
assert.throws(() => {
|
|
333
325
|
(new Transaction().setWitness as any)(0, 'foobar');
|
|
334
|
-
}, /Expected
|
|
326
|
+
}, /Expected array of Uint8Array for witness/);
|
|
335
327
|
});
|
|
336
328
|
});
|
|
337
329
|
});
|
package/test/types.spec.ts
CHANGED
|
@@ -2,52 +2,97 @@ import assert from 'assert';
|
|
|
2
2
|
import { describe, it } from 'vitest';
|
|
3
3
|
import * as types from '../src/types.js';
|
|
4
4
|
|
|
5
|
-
// @ts-ignore
|
|
6
|
-
import typeforce from 'typeforce';
|
|
7
|
-
|
|
8
5
|
describe('types', () => {
|
|
9
|
-
describe('Buffer
|
|
10
|
-
const buffer20byte =
|
|
11
|
-
const buffer32byte =
|
|
6
|
+
describe('Buffer validation', () => {
|
|
7
|
+
const buffer20byte = new Uint8Array(20);
|
|
8
|
+
const buffer32byte = new Uint8Array(32);
|
|
12
9
|
|
|
13
|
-
it('
|
|
14
|
-
assert(types.
|
|
15
|
-
assert(types.Hash256bit(buffer32byte));
|
|
10
|
+
it('isBytes20 returns true for 20-byte buffer', () => {
|
|
11
|
+
assert(types.isBytes20(buffer20byte));
|
|
16
12
|
});
|
|
17
13
|
|
|
18
|
-
it('
|
|
19
|
-
assert.
|
|
20
|
-
|
|
21
|
-
});
|
|
14
|
+
it('isBytes32 returns true for 32-byte buffer', () => {
|
|
15
|
+
assert(types.isBytes32(buffer32byte));
|
|
16
|
+
});
|
|
22
17
|
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
18
|
+
it('isBytes20 returns false for wrong size', () => {
|
|
19
|
+
assert.strictEqual(types.isBytes20(buffer32byte), false);
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
it('isBytes32 returns false for wrong size', () => {
|
|
23
|
+
assert.strictEqual(types.isBytes32(buffer20byte), false);
|
|
26
24
|
});
|
|
27
25
|
|
|
28
|
-
it('throws for invalid size', () => {
|
|
26
|
+
it('toBytes20 throws for invalid size', () => {
|
|
29
27
|
assert.throws(() => {
|
|
30
|
-
types.
|
|
31
|
-
}, /Expected
|
|
28
|
+
types.toBytes20(buffer32byte);
|
|
29
|
+
}, /Expected 20-byte Uint8Array/);
|
|
30
|
+
});
|
|
32
31
|
|
|
32
|
+
it('toBytes32 throws for invalid size', () => {
|
|
33
33
|
assert.throws(() => {
|
|
34
|
-
types.
|
|
35
|
-
}, /Expected
|
|
34
|
+
types.toBytes32(buffer20byte);
|
|
35
|
+
}, /Expected 32-byte Uint8Array/);
|
|
36
36
|
});
|
|
37
37
|
});
|
|
38
38
|
|
|
39
39
|
describe('Satoshi', () => {
|
|
40
40
|
[
|
|
41
|
-
{ value: -
|
|
42
|
-
{ value:
|
|
43
|
-
{ value:
|
|
44
|
-
{ value:
|
|
45
|
-
{ value:
|
|
46
|
-
{ value:
|
|
41
|
+
{ value: -1n, result: false },
|
|
42
|
+
{ value: 0n, result: true },
|
|
43
|
+
{ value: 1n, result: true },
|
|
44
|
+
{ value: 20999999n * 100000000n, result: true },
|
|
45
|
+
{ value: 21000000n * 100000000n, result: true },
|
|
46
|
+
{ value: 21000001n * 100000000n, result: false },
|
|
47
47
|
].forEach((f) => {
|
|
48
|
-
it('returns ' + f.result + ' for
|
|
49
|
-
assert.strictEqual(types.
|
|
48
|
+
it('returns ' + f.result + ' for value ' + f.value, () => {
|
|
49
|
+
assert.strictEqual(types.isSatoshi(f.value), f.result);
|
|
50
50
|
});
|
|
51
51
|
});
|
|
52
52
|
});
|
|
53
|
+
|
|
54
|
+
describe('Type guards', () => {
|
|
55
|
+
it('isUInt8 validates correctly', () => {
|
|
56
|
+
assert.strictEqual(types.isUInt8(0), true);
|
|
57
|
+
assert.strictEqual(types.isUInt8(255), true);
|
|
58
|
+
assert.strictEqual(types.isUInt8(256), false);
|
|
59
|
+
assert.strictEqual(types.isUInt8(-1), false);
|
|
60
|
+
assert.strictEqual(types.isUInt8(1.5), false);
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('isUInt32 validates correctly', () => {
|
|
64
|
+
assert.strictEqual(types.isUInt32(0), true);
|
|
65
|
+
assert.strictEqual(types.isUInt32(0xffffffff), true);
|
|
66
|
+
assert.strictEqual(types.isUInt32(0x100000000), false);
|
|
67
|
+
assert.strictEqual(types.isUInt32(-1), false);
|
|
68
|
+
});
|
|
69
|
+
|
|
70
|
+
it('isHex validates correctly', () => {
|
|
71
|
+
assert.strictEqual(types.isHex('abcd'), true);
|
|
72
|
+
assert.strictEqual(types.isHex('ABCD'), true);
|
|
73
|
+
assert.strictEqual(types.isHex('1234'), true);
|
|
74
|
+
assert.strictEqual(types.isHex('abc'), false); // odd length
|
|
75
|
+
assert.strictEqual(types.isHex('ghij'), false); // invalid chars
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
it('isUint8Array validates correctly', () => {
|
|
79
|
+
assert.strictEqual(types.isUint8Array(new Uint8Array(10)), true);
|
|
80
|
+
assert.strictEqual(types.isUint8Array(Buffer.alloc(10)), true);
|
|
81
|
+
assert.strictEqual(types.isUint8Array([1, 2, 3]), false);
|
|
82
|
+
assert.strictEqual(types.isUint8Array('hello'), false);
|
|
83
|
+
});
|
|
84
|
+
|
|
85
|
+
it('isPoint validates public keys', () => {
|
|
86
|
+
// Compressed pubkey (33 bytes, prefix 0x02 or 0x03)
|
|
87
|
+
const compressedKey = new Uint8Array(33);
|
|
88
|
+
compressedKey[0] = 0x02;
|
|
89
|
+
compressedKey[1] = 0x01; // non-zero x coordinate
|
|
90
|
+
|
|
91
|
+
// Invalid: all zeros
|
|
92
|
+
const zeroKey = new Uint8Array(33);
|
|
93
|
+
zeroKey[0] = 0x02;
|
|
94
|
+
|
|
95
|
+
assert.strictEqual(types.isPoint(zeroKey), false);
|
|
96
|
+
});
|
|
97
|
+
});
|
|
53
98
|
});
|