@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/src/payments/embed.ts
CHANGED
|
@@ -1,60 +1,263 @@
|
|
|
1
|
-
|
|
1
|
+
/**
|
|
2
|
+
* OP_RETURN Embed payment class.
|
|
3
|
+
*
|
|
4
|
+
* Embed payments use OP_RETURN to store arbitrary data in the blockchain.
|
|
5
|
+
* These outputs are provably unspendable.
|
|
6
|
+
*
|
|
7
|
+
* @packageDocumentation
|
|
8
|
+
*/
|
|
9
|
+
|
|
10
|
+
import { bitcoin as BITCOIN_NETWORK, type Network } from '../networks.js';
|
|
2
11
|
import * as bscript from '../script.js';
|
|
3
|
-
import { stacksEqual,
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
12
|
+
import { stacksEqual, type Stack } from '../types.js';
|
|
13
|
+
import type { Script } from '../types.js';
|
|
14
|
+
import { PaymentType, type EmbedPayment, type PaymentOpts } from './types.js';
|
|
6
15
|
|
|
7
16
|
const OPS = bscript.opcodes;
|
|
8
17
|
|
|
9
|
-
// output: OP_RETURN ...
|
|
10
18
|
/**
|
|
11
|
-
*
|
|
12
|
-
*
|
|
13
|
-
*
|
|
14
|
-
*
|
|
15
|
-
*
|
|
19
|
+
* OP_RETURN Embed payment class.
|
|
20
|
+
*
|
|
21
|
+
* Creates outputs of the form: `OP_RETURN {data1} {data2} ...`
|
|
22
|
+
* These outputs are provably unspendable and used for data storage.
|
|
23
|
+
*
|
|
24
|
+
* @example
|
|
25
|
+
* ```typescript
|
|
26
|
+
* import { Embed } from '@btc-vision/bitcoin';
|
|
27
|
+
*
|
|
28
|
+
* // Create from data
|
|
29
|
+
* const payment = Embed.fromData([Buffer.from('Hello, Bitcoin!')]);
|
|
30
|
+
* console.log(payment.output); // scriptPubKey with OP_RETURN
|
|
31
|
+
*
|
|
32
|
+
* // Decode an existing output
|
|
33
|
+
* const decoded = Embed.fromOutput(scriptPubKey);
|
|
34
|
+
* console.log(decoded.data); // array of data chunks
|
|
35
|
+
* ```
|
|
16
36
|
*/
|
|
17
|
-
export
|
|
18
|
-
|
|
19
|
-
|
|
37
|
+
export class Embed {
|
|
38
|
+
// Static public fields
|
|
39
|
+
static readonly NAME = PaymentType.Embed;
|
|
20
40
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
41
|
+
// Private instance fields
|
|
42
|
+
readonly #network: Network;
|
|
43
|
+
readonly #opts: Required<PaymentOpts>;
|
|
44
|
+
|
|
45
|
+
// Input data (provided by user)
|
|
46
|
+
#inputData?: Uint8Array[] | undefined;
|
|
47
|
+
#inputOutput?: Uint8Array | undefined;
|
|
48
|
+
|
|
49
|
+
// Cached computed values
|
|
50
|
+
#data?: Uint8Array[] | undefined;
|
|
51
|
+
#output?: Uint8Array | undefined;
|
|
52
|
+
|
|
53
|
+
// Cache flags
|
|
54
|
+
#dataComputed = false;
|
|
55
|
+
#outputComputed = false;
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Creates a new Embed payment instance.
|
|
59
|
+
*
|
|
60
|
+
* @param params - Payment parameters
|
|
61
|
+
* @param params.data - Array of data chunks to embed
|
|
62
|
+
* @param params.output - The scriptPubKey
|
|
63
|
+
* @param params.network - Network parameters (defaults to mainnet)
|
|
64
|
+
* @param opts - Payment options
|
|
65
|
+
* @param opts.validate - Whether to validate inputs (default: true)
|
|
66
|
+
*
|
|
67
|
+
* @throws {TypeError} If validation is enabled and data is invalid
|
|
68
|
+
*/
|
|
69
|
+
constructor(
|
|
70
|
+
params: {
|
|
71
|
+
data?: Uint8Array[] | undefined;
|
|
72
|
+
output?: Uint8Array | undefined;
|
|
73
|
+
network?: Network | undefined;
|
|
26
74
|
},
|
|
27
|
-
|
|
28
|
-
)
|
|
75
|
+
opts?: PaymentOpts,
|
|
76
|
+
) {
|
|
77
|
+
this.#network = params.network ?? BITCOIN_NETWORK;
|
|
78
|
+
this.#opts = {
|
|
79
|
+
validate: opts?.validate ?? true,
|
|
80
|
+
allowIncomplete: opts?.allowIncomplete ?? false,
|
|
81
|
+
};
|
|
82
|
+
|
|
83
|
+
// Store input data
|
|
84
|
+
this.#inputData = params.data;
|
|
85
|
+
this.#inputOutput = params.output;
|
|
86
|
+
|
|
87
|
+
// Validate if requested
|
|
88
|
+
if (this.#opts.validate) {
|
|
89
|
+
this.#validate();
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
// Public getters
|
|
29
94
|
|
|
30
|
-
|
|
31
|
-
|
|
95
|
+
/**
|
|
96
|
+
* Payment type discriminant.
|
|
97
|
+
*/
|
|
98
|
+
get name(): typeof PaymentType.Embed {
|
|
99
|
+
return PaymentType.Embed;
|
|
100
|
+
}
|
|
101
|
+
|
|
102
|
+
/**
|
|
103
|
+
* Network parameters.
|
|
104
|
+
*/
|
|
105
|
+
get network(): Network {
|
|
106
|
+
return this.#network;
|
|
107
|
+
}
|
|
32
108
|
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
109
|
+
/**
|
|
110
|
+
* The embedded data chunks.
|
|
111
|
+
*/
|
|
112
|
+
get data(): Uint8Array[] {
|
|
113
|
+
if (!this.#dataComputed) {
|
|
114
|
+
this.#data = this.#computeData();
|
|
115
|
+
this.#dataComputed = true;
|
|
116
|
+
}
|
|
117
|
+
return this.#data ?? [];
|
|
118
|
+
}
|
|
37
119
|
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
120
|
+
/**
|
|
121
|
+
* The scriptPubKey: `OP_RETURN {data...}`
|
|
122
|
+
*/
|
|
123
|
+
get output(): Script | undefined {
|
|
124
|
+
if (!this.#outputComputed) {
|
|
125
|
+
this.#output = this.#computeOutput();
|
|
126
|
+
this.#outputComputed = true;
|
|
43
127
|
}
|
|
128
|
+
return this.#output as Script | undefined;
|
|
129
|
+
}
|
|
44
130
|
|
|
45
|
-
|
|
46
|
-
});
|
|
131
|
+
// Static factory methods
|
|
47
132
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
133
|
+
/**
|
|
134
|
+
* Creates an Embed payment from data chunks.
|
|
135
|
+
*
|
|
136
|
+
* @param data - Array of data chunks to embed
|
|
137
|
+
* @param network - Network parameters (defaults to mainnet)
|
|
138
|
+
* @returns A new Embed payment instance
|
|
139
|
+
*
|
|
140
|
+
* @example
|
|
141
|
+
* ```typescript
|
|
142
|
+
* const payment = Embed.fromData([
|
|
143
|
+
* new TextEncoder().encode('Hello'),
|
|
144
|
+
* new TextEncoder().encode('Bitcoin')
|
|
145
|
+
* ]);
|
|
146
|
+
* ```
|
|
147
|
+
*/
|
|
148
|
+
static fromData(data: Uint8Array[], network?: Network): Embed {
|
|
149
|
+
return new Embed({ data, network });
|
|
150
|
+
}
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Creates an Embed payment from a scriptPubKey.
|
|
154
|
+
*
|
|
155
|
+
* @param output - The scriptPubKey
|
|
156
|
+
* @param network - Network parameters (defaults to mainnet)
|
|
157
|
+
* @returns A new Embed payment instance
|
|
158
|
+
*/
|
|
159
|
+
static fromOutput(output: Uint8Array, network?: Network): Embed {
|
|
160
|
+
return new Embed({ output, network });
|
|
161
|
+
}
|
|
54
162
|
|
|
55
|
-
|
|
163
|
+
// Private computation methods
|
|
164
|
+
|
|
165
|
+
#computeData(): Uint8Array[] | undefined {
|
|
166
|
+
if (this.#inputData) {
|
|
167
|
+
return this.#inputData;
|
|
168
|
+
}
|
|
169
|
+
if (this.#inputOutput) {
|
|
170
|
+
const script = bscript.decompile(this.#inputOutput);
|
|
171
|
+
if (script === null || script === undefined) {
|
|
172
|
+
return undefined;
|
|
173
|
+
}
|
|
174
|
+
return script.slice(1) as Uint8Array[];
|
|
175
|
+
}
|
|
176
|
+
return undefined;
|
|
177
|
+
}
|
|
178
|
+
|
|
179
|
+
#computeOutput(): Uint8Array | undefined {
|
|
180
|
+
if (this.#inputOutput) {
|
|
181
|
+
return this.#inputOutput;
|
|
182
|
+
}
|
|
183
|
+
if (!this.#inputData) {
|
|
184
|
+
return undefined;
|
|
56
185
|
}
|
|
186
|
+
return bscript.compile(([OPS.OP_RETURN] as Stack).concat(this.#inputData)) as Script;
|
|
57
187
|
}
|
|
58
188
|
|
|
59
|
-
|
|
189
|
+
// Validation
|
|
190
|
+
|
|
191
|
+
#validate(): void {
|
|
192
|
+
if (this.#inputOutput) {
|
|
193
|
+
const chunks = bscript.decompile(this.#inputOutput);
|
|
194
|
+
if (!chunks) {
|
|
195
|
+
throw new TypeError('Output is invalid');
|
|
196
|
+
}
|
|
197
|
+
if (chunks[0] !== OPS.OP_RETURN) {
|
|
198
|
+
throw new TypeError('Output is invalid');
|
|
199
|
+
}
|
|
200
|
+
if (!chunks.slice(1).every((c) => c instanceof Uint8Array)) {
|
|
201
|
+
throw new TypeError('Output is invalid');
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
if (this.#inputData && !stacksEqual(this.#inputData, this.data)) {
|
|
205
|
+
throw new TypeError('Data mismatch');
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
|
|
210
|
+
/**
|
|
211
|
+
* Converts to a plain EmbedPayment object for backwards compatibility.
|
|
212
|
+
*
|
|
213
|
+
* @returns An EmbedPayment object
|
|
214
|
+
*/
|
|
215
|
+
toPayment(): EmbedPayment {
|
|
216
|
+
return {
|
|
217
|
+
name: this.name,
|
|
218
|
+
network: this.network,
|
|
219
|
+
data: this.data,
|
|
220
|
+
output: this.output,
|
|
221
|
+
};
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Creates an OP_RETURN Embed payment object.
|
|
227
|
+
*
|
|
228
|
+
* This is the legacy factory function for backwards compatibility.
|
|
229
|
+
* For new code, prefer using the Embed class directly.
|
|
230
|
+
*
|
|
231
|
+
* @param a - The payment object containing the necessary data
|
|
232
|
+
* @param opts - Optional payment options
|
|
233
|
+
* @returns The Embed payment object
|
|
234
|
+
* @throws {TypeError} If the required data is not provided or if the data is invalid
|
|
235
|
+
*
|
|
236
|
+
* @example
|
|
237
|
+
* ```typescript
|
|
238
|
+
* import { p2data } from '@btc-vision/bitcoin';
|
|
239
|
+
*
|
|
240
|
+
* // Create from data
|
|
241
|
+
* const payment = p2data({ data: [Buffer.from('Hello')] });
|
|
242
|
+
*
|
|
243
|
+
* // Decode from output
|
|
244
|
+
* const decoded = p2data({ output: scriptPubKey });
|
|
245
|
+
* ```
|
|
246
|
+
*/
|
|
247
|
+
export function p2data(a: Omit<EmbedPayment, 'name'>, opts?: PaymentOpts): EmbedPayment {
|
|
248
|
+
if (!a.data && !a.output) {
|
|
249
|
+
throw new TypeError('Not enough data');
|
|
250
|
+
}
|
|
251
|
+
|
|
252
|
+
const instance = new Embed(
|
|
253
|
+
{
|
|
254
|
+
data: a.data,
|
|
255
|
+
output: a.output,
|
|
256
|
+
network: a.network,
|
|
257
|
+
},
|
|
258
|
+
opts,
|
|
259
|
+
);
|
|
260
|
+
|
|
261
|
+
// Return a merged object for backwards compatibility
|
|
262
|
+
return Object.assign(instance.toPayment(), a);
|
|
60
263
|
}
|
package/src/payments/index.ts
CHANGED
|
@@ -6,6 +6,7 @@
|
|
|
6
6
|
* @packageDocumentation
|
|
7
7
|
*/
|
|
8
8
|
|
|
9
|
+
// Type exports
|
|
9
10
|
export {
|
|
10
11
|
PaymentType,
|
|
11
12
|
type BasePayment,
|
|
@@ -25,17 +26,18 @@ export {
|
|
|
25
26
|
type PaymentOpts,
|
|
26
27
|
} from './types.js';
|
|
27
28
|
|
|
28
|
-
|
|
29
|
-
export {
|
|
30
|
-
export {
|
|
31
|
-
export {
|
|
32
|
-
export {
|
|
33
|
-
export {
|
|
34
|
-
export {
|
|
35
|
-
export {
|
|
36
|
-
export {
|
|
37
|
-
export { p2op } from './p2op.js';
|
|
29
|
+
// Class exports (new pattern)
|
|
30
|
+
export { P2PK, p2pk } from './p2pk.js';
|
|
31
|
+
export { P2PKH, p2pkh } from './p2pkh.js';
|
|
32
|
+
export { P2WPKH, p2wpkh } from './p2wpkh.js';
|
|
33
|
+
export { Embed, p2data } from './embed.js';
|
|
34
|
+
export { P2MS, p2ms } from './p2ms.js';
|
|
35
|
+
export { P2SH, p2sh } from './p2sh.js';
|
|
36
|
+
export { P2WSH, p2wsh } from './p2wsh.js';
|
|
37
|
+
export { P2TR, p2tr } from './p2tr.js';
|
|
38
|
+
export { P2OP, p2op } from './p2op.js';
|
|
38
39
|
|
|
40
|
+
// BIP341 Taproot utilities
|
|
39
41
|
export {
|
|
40
42
|
findScriptPath,
|
|
41
43
|
LEAF_VERSION_TAPSCRIPT,
|