@btc-vision/bitcoin 7.0.0-alpha.0 → 7.0.0-alpha.10
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 +455 -155
- package/browser/address.d.ts +6 -2
- package/browser/address.d.ts.map +1 -1
- package/browser/block.d.ts.map +1 -1
- package/browser/branded.d.ts +3 -14
- package/browser/branded.d.ts.map +1 -1
- package/browser/chunks/psbt-parallel-BBFlkmiv.js +10717 -0
- package/browser/crypto.d.ts +1 -1
- package/browser/ecc/context.d.ts +25 -24
- package/browser/ecc/context.d.ts.map +1 -1
- package/browser/ecc/index.d.ts +1 -1
- package/browser/ecc/index.d.ts.map +1 -1
- package/browser/ecc/types.d.ts +10 -123
- package/browser/ecc/types.d.ts.map +1 -1
- package/browser/env.d.ts +13 -0
- package/browser/env.d.ts.map +1 -0
- package/browser/index.d.ts +7 -7
- package/browser/index.d.ts.map +1 -1
- package/browser/index.js +2497 -11686
- package/browser/io/BinaryReader.d.ts +15 -15
- package/browser/io/BinaryReader.d.ts.map +1 -1
- package/browser/io/BinaryWriter.d.ts +17 -17
- package/browser/io/BinaryWriter.d.ts.map +1 -1
- package/browser/io/hex.d.ts.map +1 -1
- package/browser/io/index.d.ts +0 -1
- package/browser/io/index.d.ts.map +1 -1
- package/browser/opcodes.d.ts +11 -0
- package/browser/opcodes.d.ts.map +1 -1
- package/browser/payments/bip341.d.ts +1 -1
- package/browser/payments/bip341.d.ts.map +1 -1
- package/browser/payments/embed.d.ts +1 -1
- package/browser/payments/embed.d.ts.map +1 -1
- package/browser/payments/p2ms.d.ts.map +1 -1
- package/browser/payments/p2op.d.ts +1 -1
- package/browser/payments/p2op.d.ts.map +1 -1
- package/browser/payments/p2pk.d.ts +1 -1
- package/browser/payments/p2pk.d.ts.map +1 -1
- package/browser/payments/p2pkh.d.ts +1 -1
- package/browser/payments/p2pkh.d.ts.map +1 -1
- package/browser/payments/p2sh.d.ts.map +1 -1
- package/browser/payments/p2tr.d.ts +2 -2
- package/browser/payments/p2tr.d.ts.map +1 -1
- package/browser/payments/p2wpkh.d.ts +1 -1
- package/browser/payments/p2wpkh.d.ts.map +1 -1
- package/browser/payments/p2wsh.d.ts.map +1 -1
- package/browser/payments/types.d.ts +1 -1
- package/browser/payments/types.d.ts.map +1 -1
- package/browser/psbt/PsbtCache.d.ts +54 -0
- package/browser/psbt/PsbtCache.d.ts.map +1 -0
- package/browser/psbt/PsbtFinalizer.d.ts +21 -0
- package/browser/psbt/PsbtFinalizer.d.ts.map +1 -0
- package/browser/psbt/PsbtSigner.d.ts +32 -0
- package/browser/psbt/PsbtSigner.d.ts.map +1 -0
- package/browser/psbt/PsbtTransaction.d.ts +25 -0
- package/browser/psbt/PsbtTransaction.d.ts.map +1 -0
- package/browser/psbt/bip371.d.ts.map +1 -1
- package/browser/psbt/types.d.ts +5 -71
- package/browser/psbt/types.d.ts.map +1 -1
- package/browser/psbt/validation.d.ts +1 -1
- package/browser/psbt/validation.d.ts.map +1 -1
- package/browser/psbt.d.ts +26 -40
- package/browser/psbt.d.ts.map +1 -1
- package/browser/script.d.ts.map +1 -1
- package/browser/transaction.d.ts +4 -4
- package/browser/transaction.d.ts.map +1 -1
- package/browser/types.d.ts +5 -3
- package/browser/types.d.ts.map +1 -1
- package/browser/workers/WorkerSigningPool.d.ts +24 -17
- package/browser/workers/WorkerSigningPool.d.ts.map +1 -1
- package/browser/workers/WorkerSigningPool.node.d.ts +19 -12
- package/browser/workers/WorkerSigningPool.node.d.ts.map +1 -1
- package/browser/workers/WorkerSigningPool.sequential.d.ts +67 -0
- package/browser/workers/WorkerSigningPool.sequential.d.ts.map +1 -0
- package/browser/workers/WorkerSigningPool.worklet.d.ts +64 -0
- package/browser/workers/WorkerSigningPool.worklet.d.ts.map +1 -0
- package/browser/workers/index.browser.d.ts +16 -0
- package/browser/workers/index.browser.d.ts.map +1 -0
- package/browser/workers/index.d.ts +4 -64
- package/browser/workers/index.d.ts.map +1 -1
- package/browser/workers/index.js +28 -0
- package/browser/workers/index.node.d.ts +17 -0
- package/browser/workers/index.node.d.ts.map +1 -0
- package/browser/workers/index.react-native.d.ts +28 -0
- package/browser/workers/index.react-native.d.ts.map +1 -0
- package/browser/workers/index.shared.d.ts +15 -0
- package/browser/workers/index.shared.d.ts.map +1 -0
- package/browser/workers/psbt-parallel.d.ts +2 -3
- package/browser/workers/psbt-parallel.d.ts.map +1 -1
- package/browser/workers/types.d.ts +17 -0
- package/browser/workers/types.d.ts.map +1 -1
- package/build/address.d.ts +6 -2
- package/build/address.d.ts.map +1 -1
- package/build/address.js +32 -19
- package/build/address.js.map +1 -1
- package/build/bech32utils.js.map +1 -1
- package/build/block.d.ts.map +1 -1
- package/build/block.js +2 -4
- package/build/block.js.map +1 -1
- package/build/branded.d.ts +3 -14
- package/build/branded.d.ts.map +1 -1
- package/build/branded.js +0 -5
- package/build/branded.js.map +1 -1
- package/build/crypto.d.ts +1 -1
- package/build/ecc/context.d.ts +25 -24
- package/build/ecc/context.d.ts.map +1 -1
- package/build/ecc/context.js +29 -101
- package/build/ecc/context.js.map +1 -1
- package/build/ecc/index.d.ts +1 -1
- package/build/ecc/index.d.ts.map +1 -1
- package/build/ecc/types.d.ts +7 -126
- package/build/ecc/types.d.ts.map +1 -1
- package/build/ecc/types.js +4 -1
- package/build/ecc/types.js.map +1 -1
- package/build/env.d.ts +13 -0
- package/build/env.d.ts.map +1 -0
- package/build/env.js +198 -0
- package/build/env.js.map +1 -0
- package/build/index.d.ts +8 -7
- package/build/index.d.ts.map +1 -1
- package/build/index.js +9 -7
- package/build/index.js.map +1 -1
- package/build/io/BinaryReader.d.ts +15 -15
- package/build/io/BinaryReader.d.ts.map +1 -1
- package/build/io/BinaryReader.js +17 -17
- package/build/io/BinaryReader.js.map +1 -1
- package/build/io/BinaryWriter.d.ts +17 -17
- package/build/io/BinaryWriter.d.ts.map +1 -1
- package/build/io/BinaryWriter.js +39 -39
- package/build/io/BinaryWriter.js.map +1 -1
- package/build/io/hex.d.ts.map +1 -1
- package/build/io/hex.js +2 -1
- package/build/io/hex.js.map +1 -1
- package/build/io/index.d.ts +0 -1
- package/build/io/index.d.ts.map +1 -1
- package/build/io/index.js +0 -2
- package/build/io/index.js.map +1 -1
- package/build/opcodes.d.ts +11 -0
- package/build/opcodes.d.ts.map +1 -1
- package/build/opcodes.js +19 -4
- package/build/opcodes.js.map +1 -1
- package/build/payments/bip341.d.ts +1 -2
- package/build/payments/bip341.d.ts.map +1 -1
- package/build/payments/bip341.js +1 -2
- package/build/payments/bip341.js.map +1 -1
- package/build/payments/embed.d.ts +1 -1
- package/build/payments/embed.d.ts.map +1 -1
- package/build/payments/embed.js +14 -14
- package/build/payments/embed.js.map +1 -1
- package/build/payments/p2ms.d.ts.map +1 -1
- package/build/payments/p2ms.js +21 -21
- package/build/payments/p2ms.js.map +1 -1
- package/build/payments/p2op.d.ts +1 -1
- package/build/payments/p2op.d.ts.map +1 -1
- package/build/payments/p2op.js +18 -18
- package/build/payments/p2op.js.map +1 -1
- package/build/payments/p2pk.d.ts +1 -1
- package/build/payments/p2pk.d.ts.map +1 -1
- package/build/payments/p2pk.js +17 -17
- package/build/payments/p2pk.js.map +1 -1
- package/build/payments/p2pkh.d.ts +1 -1
- package/build/payments/p2pkh.d.ts.map +1 -1
- package/build/payments/p2pkh.js +20 -20
- package/build/payments/p2pkh.js.map +1 -1
- package/build/payments/p2sh.d.ts.map +1 -1
- package/build/payments/p2sh.js +22 -20
- package/build/payments/p2sh.js.map +1 -1
- package/build/payments/p2tr.d.ts +2 -2
- package/build/payments/p2tr.d.ts.map +1 -1
- package/build/payments/p2tr.js +25 -26
- package/build/payments/p2tr.js.map +1 -1
- package/build/payments/p2wpkh.d.ts +1 -1
- package/build/payments/p2wpkh.d.ts.map +1 -1
- package/build/payments/p2wpkh.js +20 -20
- package/build/payments/p2wpkh.js.map +1 -1
- package/build/payments/p2wsh.d.ts.map +1 -1
- package/build/payments/p2wsh.js +22 -22
- package/build/payments/p2wsh.js.map +1 -1
- package/build/payments/types.d.ts +1 -1
- package/build/payments/types.d.ts.map +1 -1
- package/build/psbt/PsbtCache.d.ts +54 -0
- package/build/psbt/PsbtCache.d.ts.map +1 -0
- package/build/psbt/PsbtCache.js +249 -0
- package/build/psbt/PsbtCache.js.map +1 -0
- package/build/psbt/PsbtFinalizer.d.ts +21 -0
- package/build/psbt/PsbtFinalizer.d.ts.map +1 -0
- package/build/psbt/PsbtFinalizer.js +157 -0
- package/build/psbt/PsbtFinalizer.js.map +1 -0
- package/build/psbt/PsbtSigner.d.ts +32 -0
- package/build/psbt/PsbtSigner.d.ts.map +1 -0
- package/build/psbt/PsbtSigner.js +192 -0
- package/build/psbt/PsbtSigner.js.map +1 -0
- package/build/psbt/PsbtTransaction.d.ts +25 -0
- package/build/psbt/PsbtTransaction.d.ts.map +1 -0
- package/build/psbt/PsbtTransaction.js +61 -0
- package/build/psbt/PsbtTransaction.js.map +1 -0
- package/build/psbt/bip371.d.ts.map +1 -1
- package/build/psbt/bip371.js +6 -2
- package/build/psbt/bip371.js.map +1 -1
- package/build/psbt/psbtutils.js +1 -1
- package/build/psbt/psbtutils.js.map +1 -1
- package/build/psbt/types.d.ts +5 -71
- package/build/psbt/types.d.ts.map +1 -1
- package/build/psbt/validation.d.ts +1 -1
- package/build/psbt/validation.d.ts.map +1 -1
- package/build/psbt/validation.js +1 -1
- package/build/psbt/validation.js.map +1 -1
- package/build/psbt.d.ts +26 -40
- package/build/psbt.d.ts.map +1 -1
- package/build/psbt.js +180 -808
- package/build/psbt.js.map +1 -1
- package/build/script.d.ts.map +1 -1
- package/build/script.js +4 -4
- package/build/script.js.map +1 -1
- package/build/transaction.d.ts +4 -4
- package/build/transaction.d.ts.map +1 -1
- package/build/transaction.js +6 -5
- package/build/transaction.js.map +1 -1
- package/build/tsconfig.build.tsbuildinfo +1 -1
- package/build/types.d.ts +5 -3
- package/build/types.d.ts.map +1 -1
- package/build/types.js +14 -25
- package/build/types.js.map +1 -1
- package/build/workers/WorkerSigningPool.d.ts +24 -17
- package/build/workers/WorkerSigningPool.d.ts.map +1 -1
- package/build/workers/WorkerSigningPool.js +36 -25
- package/build/workers/WorkerSigningPool.js.map +1 -1
- package/build/workers/WorkerSigningPool.node.d.ts +19 -12
- package/build/workers/WorkerSigningPool.node.d.ts.map +1 -1
- package/build/workers/WorkerSigningPool.node.js +60 -28
- package/build/workers/WorkerSigningPool.node.js.map +1 -1
- package/build/workers/WorkerSigningPool.sequential.d.ts +76 -0
- package/build/workers/WorkerSigningPool.sequential.d.ts.map +1 -0
- package/build/workers/WorkerSigningPool.sequential.js +160 -0
- package/build/workers/WorkerSigningPool.sequential.js.map +1 -0
- package/build/workers/WorkerSigningPool.worklet.d.ts +79 -0
- package/build/workers/WorkerSigningPool.worklet.d.ts.map +1 -0
- package/build/workers/WorkerSigningPool.worklet.js +390 -0
- package/build/workers/WorkerSigningPool.worklet.js.map +1 -0
- package/build/workers/index.browser.d.ts +24 -0
- package/build/workers/index.browser.d.ts.map +1 -0
- package/build/workers/index.browser.js +30 -0
- package/build/workers/index.browser.js.map +1 -0
- package/build/workers/index.d.ts +6 -18
- package/build/workers/index.d.ts.map +1 -1
- package/build/workers/index.js +12 -14
- package/build/workers/index.js.map +1 -1
- package/build/workers/index.node.d.ts +38 -0
- package/build/workers/index.node.d.ts.map +1 -0
- package/build/workers/index.node.js +45 -0
- package/build/workers/index.node.js.map +1 -0
- package/build/workers/index.react-native.d.ts +28 -0
- package/build/workers/index.react-native.d.ts.map +1 -0
- package/build/workers/index.react-native.js +67 -0
- package/build/workers/index.react-native.js.map +1 -0
- package/build/workers/index.shared.d.ts +15 -0
- package/build/workers/index.shared.d.ts.map +1 -0
- package/build/workers/index.shared.js +20 -0
- package/build/workers/index.shared.js.map +1 -0
- package/build/workers/psbt-parallel.d.ts +2 -3
- package/build/workers/psbt-parallel.d.ts.map +1 -1
- package/build/workers/psbt-parallel.js +4 -4
- package/build/workers/psbt-parallel.js.map +1 -1
- package/build/workers/types.d.ts +17 -0
- package/build/workers/types.d.ts.map +1 -1
- package/build/workers/types.js.map +1 -1
- package/package.json +48 -9
- package/src/address.ts +53 -21
- package/src/bech32utils.ts +3 -3
- package/src/block.ts +17 -10
- package/src/branded.ts +15 -13
- package/src/crypto.ts +1 -1
- package/src/ecc/context.ts +36 -136
- package/src/ecc/index.ts +2 -2
- package/src/ecc/types.ts +7 -145
- package/src/env.ts +239 -0
- package/src/index.ts +57 -22
- package/src/io/BinaryReader.ts +18 -18
- package/src/io/BinaryWriter.ts +43 -43
- package/src/io/hex.ts +2 -1
- package/src/io/index.ts +0 -3
- package/src/opcodes.ts +21 -4
- package/src/payments/bip341.ts +5 -7
- package/src/payments/embed.ts +19 -19
- package/src/payments/p2ms.ts +34 -27
- package/src/payments/p2op.ts +22 -22
- package/src/payments/p2pk.ts +22 -22
- package/src/payments/p2pkh.ts +28 -28
- package/src/payments/p2sh.ts +33 -30
- package/src/payments/p2tr.ts +40 -40
- package/src/payments/p2wpkh.ts +30 -30
- package/src/payments/p2wsh.ts +29 -29
- package/src/payments/types.ts +1 -1
- package/src/psbt/PsbtCache.ts +325 -0
- package/src/psbt/PsbtFinalizer.ts +213 -0
- package/src/psbt/PsbtSigner.ts +302 -0
- package/src/psbt/PsbtTransaction.ts +82 -0
- package/src/psbt/bip371.ts +7 -3
- package/src/psbt/psbtutils.ts +1 -1
- package/src/psbt/types.ts +5 -94
- package/src/psbt/validation.ts +5 -12
- package/src/psbt.ts +376 -1201
- package/src/script.ts +6 -9
- package/src/transaction.ts +19 -15
- package/src/types.ts +33 -45
- package/src/workers/WorkerSigningPool.node.ts +72 -36
- package/src/workers/WorkerSigningPool.sequential.ts +191 -0
- package/src/workers/WorkerSigningPool.ts +48 -39
- package/src/workers/WorkerSigningPool.worklet.ts +522 -0
- package/src/workers/index.browser.ts +34 -0
- package/src/workers/index.node.ts +50 -0
- package/src/workers/index.react-native.ts +110 -0
- package/src/workers/index.shared.ts +58 -0
- package/src/workers/index.ts +14 -65
- package/src/workers/psbt-parallel.ts +8 -13
- package/src/workers/types.ts +26 -1
- package/test/address.spec.ts +2 -2
- package/test/bitcoin.core.spec.ts +5 -2
- package/test/browser/payments.spec.ts +151 -0
- package/test/browser/psbt.spec.ts +1510 -0
- package/test/browser/script.spec.ts +223 -0
- package/test/browser/setup.ts +13 -0
- package/test/browser/workers-signing.spec.ts +537 -0
- package/test/crypto.spec.ts +2 -2
- package/test/env.spec.ts +418 -0
- package/test/fixtures/core/base58_encode_decode.json +12 -48
- package/test/fixtures/core/base58_keys_invalid.json +50 -150
- package/test/fixtures/core/sighash.json +1 -3
- package/test/fixtures/core/tx_valid.json +133 -501
- package/test/fixtures/embed.json +3 -11
- package/test/fixtures/p2ms.json +21 -91
- package/test/fixtures/p2pk.json +5 -24
- package/test/fixtures/p2pkh.json +7 -36
- package/test/fixtures/p2sh.json +8 -54
- package/test/fixtures/p2tr.json +2 -6
- package/test/fixtures/p2wpkh.json +7 -36
- package/test/fixtures/p2wsh.json +14 -59
- package/test/fixtures/psbt.json +2 -6
- package/test/fixtures/script.json +12 -48
- package/test/integration/addresses.spec.ts +11 -5
- package/test/integration/bip32.spec.ts +1 -1
- package/test/integration/cltv.spec.ts +10 -6
- package/test/integration/csv.spec.ts +10 -9
- package/test/integration/payments.spec.ts +8 -4
- package/test/integration/taproot.spec.ts +26 -6
- package/test/integration/transactions.spec.ts +22 -8
- package/test/payments.spec.ts +1 -1
- package/test/payments.utils.ts +1 -1
- package/test/psbt.spec.ts +250 -64
- package/test/script_signature.spec.ts +1 -1
- package/test/transaction.spec.ts +18 -5
- package/test/tsconfig.json +6 -20
- package/test/workers-pool.spec.ts +65 -23
- package/test/workers-sequential.spec.ts +669 -0
- package/test/workers-signing.spec.ts +7 -3
- package/test/workers-worklet.spec.ts +500 -0
- package/test/workers.spec.ts +6 -7
- package/typedoc.json +39 -0
- package/vite.config.browser.ts +31 -6
- package/vitest.config.browser.ts +68 -0
- package/browser/ecpair.d.ts +0 -99
- package/browser/io/MemoryPool.d.ts +0 -220
- package/browser/io/MemoryPool.d.ts.map +0 -1
- package/build/io/MemoryPool.d.ts +0 -220
- package/build/io/MemoryPool.d.ts.map +0 -1
- package/build/io/MemoryPool.js +0 -309
- package/build/io/MemoryPool.js.map +0 -1
- package/src/ecpair.d.ts +0 -99
- package/src/io/MemoryPool.ts +0 -343
- package/test/taproot-cache.spec.ts +0 -694
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { checkForInput } from 'bip174';
|
|
2
|
+
import { equals, toHex } from '../io/index.js';
|
|
3
|
+
import * as payments from '../payments/index.js';
|
|
4
|
+
import { tapleafHash } from '../payments/bip341.js';
|
|
5
|
+
import { toXOnly } from '../pubkey.js';
|
|
6
|
+
import { isP2WPKH, pubkeyInScript } from './psbtutils.js';
|
|
7
|
+
import { getMeaningfulScript, sighashTypeToString } from './utils.js';
|
|
8
|
+
import { checkScriptForPubkey } from './validation.js';
|
|
9
|
+
import { Transaction } from '../transaction.js';
|
|
10
|
+
/**
|
|
11
|
+
* Class wrapping all signing-related logic for PSBT.
|
|
12
|
+
*/
|
|
13
|
+
export class PsbtSigner {
|
|
14
|
+
#cache;
|
|
15
|
+
#txFromBuffer;
|
|
16
|
+
constructor(cache, txFromBuffer) {
|
|
17
|
+
this.#cache = cache;
|
|
18
|
+
this.#txFromBuffer = txFromBuffer;
|
|
19
|
+
}
|
|
20
|
+
getHashAndSighashType(inputs, inputIndex, pubkey, sighashTypes) {
|
|
21
|
+
const input = checkForInput(inputs, inputIndex);
|
|
22
|
+
const { hash, sighashType, script } = this.getHashForSig(inputIndex, input, false, sighashTypes);
|
|
23
|
+
checkScriptForPubkey(pubkey, script, 'sign');
|
|
24
|
+
return { hash, sighashType };
|
|
25
|
+
}
|
|
26
|
+
getHashForSig(inputIndex, input, forValidate, sighashTypes) {
|
|
27
|
+
const unsignedTx = this.#cache.tx;
|
|
28
|
+
const sighashType = input.sighashType || Transaction.SIGHASH_ALL;
|
|
29
|
+
checkSighashTypeAllowed(sighashType, sighashTypes);
|
|
30
|
+
let hash;
|
|
31
|
+
let prevout;
|
|
32
|
+
if (input.nonWitnessUtxo) {
|
|
33
|
+
const nonWitnessUtxoTx = this.#cache.getNonWitnessUtxoTx(input, inputIndex, this.#txFromBuffer);
|
|
34
|
+
const prevoutHash = unsignedTx.ins[inputIndex].hash;
|
|
35
|
+
const utxoHash = nonWitnessUtxoTx.getHash();
|
|
36
|
+
if (!equals(prevoutHash, utxoHash)) {
|
|
37
|
+
throw new Error(`Non-witness UTXO hash for input #${inputIndex} doesn't match the hash specified in the prevout`);
|
|
38
|
+
}
|
|
39
|
+
const prevoutIndex = unsignedTx.ins[inputIndex].index;
|
|
40
|
+
prevout = nonWitnessUtxoTx.outs[prevoutIndex];
|
|
41
|
+
}
|
|
42
|
+
else if (input.witnessUtxo) {
|
|
43
|
+
prevout = {
|
|
44
|
+
script: input.witnessUtxo.script,
|
|
45
|
+
value: input.witnessUtxo.value,
|
|
46
|
+
};
|
|
47
|
+
}
|
|
48
|
+
else {
|
|
49
|
+
throw new Error('Need a Utxo input item for signing');
|
|
50
|
+
}
|
|
51
|
+
const { meaningfulScript, type } = getMeaningfulScript(prevout.script, inputIndex, 'input', input.redeemScript, input.witnessScript);
|
|
52
|
+
const script = meaningfulScript;
|
|
53
|
+
if (['p2sh-p2wsh', 'p2wsh'].includes(type)) {
|
|
54
|
+
hash = unsignedTx.hashForWitnessV0(inputIndex, script, prevout.value, sighashType);
|
|
55
|
+
}
|
|
56
|
+
else if (isP2WPKH(meaningfulScript)) {
|
|
57
|
+
const p2pkhPayment = payments.p2pkh({
|
|
58
|
+
hash: meaningfulScript.subarray(2),
|
|
59
|
+
});
|
|
60
|
+
if (!p2pkhPayment.output)
|
|
61
|
+
throw new Error('Unable to create signing script');
|
|
62
|
+
hash = unsignedTx.hashForWitnessV0(inputIndex, p2pkhPayment.output, prevout.value, sighashType);
|
|
63
|
+
}
|
|
64
|
+
else {
|
|
65
|
+
// non-segwit
|
|
66
|
+
if (input.nonWitnessUtxo === undefined && !this.#cache.unsafeSignNonSegwit)
|
|
67
|
+
throw new Error(`Input #${inputIndex} has witnessUtxo but non-segwit script: ` +
|
|
68
|
+
toHex(meaningfulScript));
|
|
69
|
+
if (!forValidate && this.#cache.unsafeSignNonSegwit)
|
|
70
|
+
console.warn('Warning: Signing non-segwit inputs without the full parent transaction ' +
|
|
71
|
+
'means there is a chance that a miner could feed you incorrect information ' +
|
|
72
|
+
"to trick you into paying large fees. This behavior is the same as Psbt's predecessor " +
|
|
73
|
+
'(TransactionBuilder - now removed) when signing non-segwit scripts. You are not ' +
|
|
74
|
+
'able to export this Psbt with toBuffer|toBase64|toHex since it is not ' +
|
|
75
|
+
'BIP174 compliant.\n*********************\nPROCEED WITH CAUTION!\n' +
|
|
76
|
+
'*********************');
|
|
77
|
+
hash = unsignedTx.hashForSignature(inputIndex, script, sighashType);
|
|
78
|
+
}
|
|
79
|
+
return { script, sighashType, hash };
|
|
80
|
+
}
|
|
81
|
+
getTaprootHashesForSig(inputIndex, input, inputs, pubkey, tapLeafHashToSign, allowedSighashTypes) {
|
|
82
|
+
const unsignedTx = this.#cache.tx;
|
|
83
|
+
const sighashType = input.sighashType || Transaction.SIGHASH_DEFAULT;
|
|
84
|
+
checkSighashTypeAllowed(sighashType, allowedSighashTypes);
|
|
85
|
+
if (!this.#cache.prevOuts) {
|
|
86
|
+
const prevOuts = inputs.map((i, index) => this.#cache.getScriptAndAmountFromUtxo(index, i, this.#txFromBuffer));
|
|
87
|
+
this.#cache.prevOuts = prevOuts;
|
|
88
|
+
this.#cache.signingScripts = prevOuts.map((o) => o.script);
|
|
89
|
+
this.#cache.values = prevOuts.map((o) => o.value);
|
|
90
|
+
}
|
|
91
|
+
const signingScripts = this.#cache.signingScripts;
|
|
92
|
+
const values = this.#cache.values;
|
|
93
|
+
if (!this.#cache.taprootHashCache) {
|
|
94
|
+
this.#cache.taprootHashCache = unsignedTx.getTaprootHashCache(signingScripts, values);
|
|
95
|
+
}
|
|
96
|
+
const taprootCache = this.#cache.taprootHashCache;
|
|
97
|
+
const hashes = [];
|
|
98
|
+
if (input.tapInternalKey && !tapLeafHashToSign) {
|
|
99
|
+
const outputKey = this.#cache.getPrevoutTaprootKey(inputIndex, input, this.#txFromBuffer) ||
|
|
100
|
+
new Uint8Array(0);
|
|
101
|
+
if (equals(toXOnly(pubkey), outputKey)) {
|
|
102
|
+
const tapKeyHash = unsignedTx.hashForWitnessV1(inputIndex, signingScripts, values, sighashType, undefined, undefined, taprootCache);
|
|
103
|
+
hashes.push({ pubkey: pubkey, hash: tapKeyHash });
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
const tapLeafHashes = (input.tapLeafScript || [])
|
|
107
|
+
.filter((tapLeaf) => pubkeyInScript(pubkey, tapLeaf.script))
|
|
108
|
+
.map((tapLeaf) => {
|
|
109
|
+
const hash = tapleafHash({
|
|
110
|
+
output: tapLeaf.script,
|
|
111
|
+
version: tapLeaf.leafVersion,
|
|
112
|
+
});
|
|
113
|
+
return Object.assign({ hash }, tapLeaf);
|
|
114
|
+
})
|
|
115
|
+
.filter((tapLeaf) => !tapLeafHashToSign || equals(tapLeafHashToSign, tapLeaf.hash))
|
|
116
|
+
.map((tapLeaf) => {
|
|
117
|
+
const tapScriptHash = unsignedTx.hashForWitnessV1(inputIndex, signingScripts, values, sighashType, tapLeaf.hash, undefined, taprootCache);
|
|
118
|
+
return {
|
|
119
|
+
pubkey: pubkey,
|
|
120
|
+
hash: tapScriptHash,
|
|
121
|
+
leafHash: tapLeaf.hash,
|
|
122
|
+
};
|
|
123
|
+
});
|
|
124
|
+
return hashes.concat(tapLeafHashes);
|
|
125
|
+
}
|
|
126
|
+
getAllTaprootHashesForSig(inputIndex, input, inputs) {
|
|
127
|
+
const allPublicKeys = [];
|
|
128
|
+
if (input.tapInternalKey) {
|
|
129
|
+
const key = this.#cache.getPrevoutTaprootKey(inputIndex, input, this.#txFromBuffer);
|
|
130
|
+
if (key) {
|
|
131
|
+
allPublicKeys.push(key);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
if (input.tapScriptSig) {
|
|
135
|
+
const tapScriptPubkeys = input.tapScriptSig.map((tss) => tss.pubkey);
|
|
136
|
+
allPublicKeys.push(...tapScriptPubkeys);
|
|
137
|
+
}
|
|
138
|
+
const allHashes = allPublicKeys.map((pubicKey) => this.getTaprootHashesForSig(inputIndex, input, inputs, pubicKey));
|
|
139
|
+
return allHashes.flat();
|
|
140
|
+
}
|
|
141
|
+
trimTaprootSig(signature) {
|
|
142
|
+
return signature.length === 64 ? signature : signature.subarray(0, 64);
|
|
143
|
+
}
|
|
144
|
+
getSignersFromHD(inputIndex, inputs, hdKeyPair) {
|
|
145
|
+
const input = checkForInput(inputs, inputIndex);
|
|
146
|
+
if (!input.bip32Derivation || input.bip32Derivation.length === 0) {
|
|
147
|
+
throw new Error('Need bip32Derivation to sign with HD');
|
|
148
|
+
}
|
|
149
|
+
const myDerivations = input.bip32Derivation
|
|
150
|
+
.map((bipDv) => {
|
|
151
|
+
if (equals(bipDv.masterFingerprint, hdKeyPair.fingerprint)) {
|
|
152
|
+
return bipDv;
|
|
153
|
+
}
|
|
154
|
+
else {
|
|
155
|
+
return;
|
|
156
|
+
}
|
|
157
|
+
})
|
|
158
|
+
.filter((v) => !!v);
|
|
159
|
+
if (myDerivations.length === 0) {
|
|
160
|
+
throw new Error('Need one bip32Derivation masterFingerprint to match the HDSigner fingerprint');
|
|
161
|
+
}
|
|
162
|
+
return myDerivations.map((bipDv) => {
|
|
163
|
+
const node = hdKeyPair.derivePath(bipDv.path);
|
|
164
|
+
if (!equals(bipDv.pubkey, node.publicKey)) {
|
|
165
|
+
throw new Error('pubkey did not match bip32Derivation');
|
|
166
|
+
}
|
|
167
|
+
return node;
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
bip32DerivationIsMine(root) {
|
|
171
|
+
return (d) => {
|
|
172
|
+
const fingerprint = root.fingerprint instanceof Uint8Array
|
|
173
|
+
? root.fingerprint
|
|
174
|
+
: new Uint8Array(root.fingerprint);
|
|
175
|
+
if (!equals(d.masterFingerprint, fingerprint))
|
|
176
|
+
return false;
|
|
177
|
+
const derivedPubkey = root.derivePath(d.path).publicKey;
|
|
178
|
+
const pubkey = derivedPubkey instanceof Uint8Array ? derivedPubkey : new Uint8Array(derivedPubkey);
|
|
179
|
+
if (!equals(pubkey, d.pubkey))
|
|
180
|
+
return false;
|
|
181
|
+
return true;
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
function checkSighashTypeAllowed(sighashType, sighashTypes) {
|
|
186
|
+
if (sighashTypes && !sighashTypes.includes(sighashType)) {
|
|
187
|
+
const str = sighashTypeToString(sighashType);
|
|
188
|
+
throw new Error(`Sighash type is not allowed. Retry the sign method passing the ` +
|
|
189
|
+
`sighashTypes array of whitelisted types. Sighash type: ${str}`);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
//# sourceMappingURL=PsbtSigner.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtSigner.js","sourceRoot":"","sources":["../../src/psbt/PsbtSigner.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import type { Transaction as ITransaction, TransactionFromBuffer } from 'bip174';
|
|
2
|
+
import { Transaction } from '../transaction.js';
|
|
3
|
+
import type { TransactionInput, TransactionOutput } from './types.js';
|
|
4
|
+
/**
|
|
5
|
+
* This class implements the Transaction interface from bip174 library.
|
|
6
|
+
* It contains a bitcoinjs-lib Transaction object.
|
|
7
|
+
*/
|
|
8
|
+
export declare class PsbtTransaction implements ITransaction {
|
|
9
|
+
tx: Transaction;
|
|
10
|
+
constructor(buffer?: Uint8Array);
|
|
11
|
+
getInputOutputCounts(): {
|
|
12
|
+
inputCount: number;
|
|
13
|
+
outputCount: number;
|
|
14
|
+
};
|
|
15
|
+
addInput(input: TransactionInput): void;
|
|
16
|
+
addOutput(output: TransactionOutput): void;
|
|
17
|
+
toBuffer(): Uint8Array;
|
|
18
|
+
}
|
|
19
|
+
/**
|
|
20
|
+
* This function is needed to pass to the bip174 base class's fromBuffer.
|
|
21
|
+
* It takes the "transaction buffer" portion of the psbt buffer and returns a
|
|
22
|
+
* Transaction (From the bip174 library) interface.
|
|
23
|
+
*/
|
|
24
|
+
export declare const transactionFromBuffer: TransactionFromBuffer;
|
|
25
|
+
//# sourceMappingURL=PsbtTransaction.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtTransaction.d.ts","sourceRoot":"","sources":["../../src/psbt/PsbtTransaction.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,WAAW,IAAI,YAAY,EAAE,qBAAqB,EAAE,MAAM,QAAQ,CAAC;AAEjF,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAGhD,OAAO,KAAK,EAAE,gBAAgB,EAAE,iBAAiB,EAAE,MAAM,YAAY,CAAC;AAWtE;;;GAGG;AACH,qBAAa,eAAgB,YAAW,YAAY;IACzC,EAAE,EAAE,WAAW,CAAC;gBAEJ,MAAM,GAAE,UAAwB;IAS5C,oBAAoB,IAAI;QAC3B,UAAU,EAAE,MAAM,CAAC;QACnB,WAAW,EAAE,MAAM,CAAC;KACvB;IAOM,QAAQ,CAAC,KAAK,EAAE,gBAAgB,GAAG,IAAI;IAgBvC,SAAS,CAAC,MAAM,EAAE,iBAAiB,GAAG,IAAI;IAY1C,QAAQ,IAAI,UAAU;CAGhC;AAED;;;;GAIG;AACH,eAAO,MAAM,qBAAqB,EAAE,qBACL,CAAC"}
|
|
@@ -0,0 +1,61 @@
|
|
|
1
|
+
import { fromHex, reverse } from '../io/index.js';
|
|
2
|
+
import { Transaction } from '../transaction.js';
|
|
3
|
+
import { checkTxEmpty } from './validation.js';
|
|
4
|
+
/**
|
|
5
|
+
* Empty version-2 transaction with zero inputs and zero outputs.
|
|
6
|
+
* Used as the default buffer when constructing a new PsbtTransaction.
|
|
7
|
+
*
|
|
8
|
+
* Layout: [version(4LE)] [inputCount(varint)] [outputCount(varint)] [locktime(4LE)]
|
|
9
|
+
* [02 00 00 00] [00] [00] [00 00 00 00]
|
|
10
|
+
*/
|
|
11
|
+
const EMPTY_TX_V2 = new Uint8Array([2, 0, 0, 0, 0, 0, 0, 0, 0, 0]);
|
|
12
|
+
/**
|
|
13
|
+
* This class implements the Transaction interface from bip174 library.
|
|
14
|
+
* It contains a bitcoinjs-lib Transaction object.
|
|
15
|
+
*/
|
|
16
|
+
export class PsbtTransaction {
|
|
17
|
+
tx;
|
|
18
|
+
constructor(buffer = EMPTY_TX_V2) {
|
|
19
|
+
this.tx = Transaction.fromBuffer(buffer);
|
|
20
|
+
checkTxEmpty(this.tx);
|
|
21
|
+
Object.defineProperty(this, 'tx', {
|
|
22
|
+
enumerable: false,
|
|
23
|
+
writable: true,
|
|
24
|
+
});
|
|
25
|
+
}
|
|
26
|
+
getInputOutputCounts() {
|
|
27
|
+
return {
|
|
28
|
+
inputCount: this.tx.ins.length,
|
|
29
|
+
outputCount: this.tx.outs.length,
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
addInput(input) {
|
|
33
|
+
if (input.hash === undefined ||
|
|
34
|
+
input.index === undefined ||
|
|
35
|
+
(!(input.hash instanceof Uint8Array) && typeof input.hash !== 'string') ||
|
|
36
|
+
typeof input.index !== 'number') {
|
|
37
|
+
throw new Error('Error adding input.');
|
|
38
|
+
}
|
|
39
|
+
const hash = (typeof input.hash === 'string' ? reverse(fromHex(input.hash)) : input.hash);
|
|
40
|
+
this.tx.addInput(hash, input.index, input.sequence);
|
|
41
|
+
}
|
|
42
|
+
addOutput(output) {
|
|
43
|
+
if (output.script === undefined ||
|
|
44
|
+
output.value === undefined ||
|
|
45
|
+
!(output.script instanceof Uint8Array) ||
|
|
46
|
+
typeof output.value !== 'bigint') {
|
|
47
|
+
throw new Error('Error adding output.');
|
|
48
|
+
}
|
|
49
|
+
this.tx.addOutput(output.script, output.value);
|
|
50
|
+
}
|
|
51
|
+
toBuffer() {
|
|
52
|
+
return this.tx.toBuffer();
|
|
53
|
+
}
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* This function is needed to pass to the bip174 base class's fromBuffer.
|
|
57
|
+
* It takes the "transaction buffer" portion of the psbt buffer and returns a
|
|
58
|
+
* Transaction (From the bip174 library) interface.
|
|
59
|
+
*/
|
|
60
|
+
export const transactionFromBuffer = (buffer) => new PsbtTransaction(buffer);
|
|
61
|
+
//# sourceMappingURL=PsbtTransaction.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtTransaction.js","sourceRoot":"","sources":["../../src/psbt/PsbtTransaction.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,OAAO,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAClD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAEhD,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAG/C;;;;;;GAMG;AACH,MAAM,WAAW,GAAG,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC;AAEnE;;;GAGG;AACH,MAAM,OAAO,eAAe;IACjB,EAAE,CAAc;IAEvB,YAAmB,SAAqB,WAAW;QAC/C,IAAI,CAAC,EAAE,GAAG,WAAW,CAAC,UAAU,CAAC,MAAM,CAAC,CAAC;QACzC,YAAY,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QACtB,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,IAAI,EAAE;YAC9B,UAAU,EAAE,KAAK;YACjB,QAAQ,EAAE,IAAI;SACjB,CAAC,CAAC;IACP,CAAC;IAEM,oBAAoB;QAIvB,OAAO;YACH,UAAU,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM;YAC9B,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,MAAM;SACnC,CAAC;IACN,CAAC;IAEM,QAAQ,CAAC,KAAuB;QACnC,IACI,KAAK,CAAC,IAAI,KAAK,SAAS;YACxB,KAAK,CAAC,KAAK,KAAK,SAAS;YACzB,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,YAAY,UAAU,CAAC,IAAI,OAAO,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC;YACvE,OAAO,KAAK,CAAC,KAAK,KAAK,QAAQ,EACjC,CAAC;YACC,MAAM,IAAI,KAAK,CAAC,qBAAqB,CAAC,CAAC;QAC3C,CAAC;QACD,MAAM,IAAI,GAAG,CACT,OAAO,KAAK,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,IAAI,CAClE,CAAC;QAEb,IAAI,CAAC,EAAE,CAAC,QAAQ,CAAC,IAAI,EAAE,KAAK,CAAC,KAAK,EAAE,KAAK,CAAC,QAAQ,CAAC,CAAC;IACxD,CAAC;IAEM,SAAS,CAAC,MAAyB;QACtC,IACI,MAAM,CAAC,MAAM,KAAK,SAAS;YAC3B,MAAM,CAAC,KAAK,KAAK,SAAS;YAC1B,CAAC,CAAC,MAAM,CAAC,MAAM,YAAY,UAAU,CAAC;YACtC,OAAO,MAAM,CAAC,KAAK,KAAK,QAAQ,EAClC,CAAC;YACC,MAAM,IAAI,KAAK,CAAC,sBAAsB,CAAC,CAAC;QAC5C,CAAC;QACD,IAAI,CAAC,EAAE,CAAC,SAAS,CAAC,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC;IACnD,CAAC;IAEM,QAAQ;QACX,OAAO,IAAI,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC;IAC9B,CAAC;CACJ;AAED;;;;GAIG;AACH,MAAM,CAAC,MAAM,qBAAqB,GAA0B,CAAC,MAAkB,EAAgB,EAAE,CAC7F,IAAI,eAAe,CAAC,MAAM,CAAC,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bip371.d.ts","sourceRoot":"","sources":["../../src/psbt/bip371.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,SAAS,EACT,UAAU,EAEV,OAAO,EAIV,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"bip371.d.ts","sourceRoot":"","sources":["../../src/psbt/bip371.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACR,SAAS,EACT,UAAU,EAEV,OAAO,EAIV,MAAM,QAAQ,CAAC;AAUhB,OAAO,KAAK,EAAoB,OAAO,EAAkB,MAAM,aAAa,CAAC;AAU7E,UAAU,oBAAqB,SAAQ,UAAU;IAC7C,MAAM,CAAC,EAAE,UAAU,CAAC;CACvB;AAED;;;;;;;;GAQG;AACH,wBAAgB,kBAAkB,CAC9B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,qBAAqB,CAAC,EAAE,UAAU,GACnC;IACC,kBAAkB,EAAE,UAAU,GAAG,SAAS,CAAC;CAC9C,CAYA;AAED,wBAAgB,yBAAyB,CAAC,GAAG,EAAE,UAAU,EAAE,WAAW,CAAC,EAAE,MAAM,GAAG,UAAU,CAI3F;AAED,wBAAgB,cAAc,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAWxD;AAED,wBAAgB,eAAe,CAAC,MAAM,EAAE,UAAU,EAAE,MAAM,CAAC,EAAE,UAAU,GAAG,OAAO,CAUhF;AAED,wBAAgB,uBAAuB,CACnC,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,SAAS,EACvB,MAAM,EAAE,MAAM,GACf,IAAI,CAGN;AAED,wBAAgB,wBAAwB,CACpC,UAAU,EAAE,oBAAoB,EAChC,aAAa,EAAE,UAAU,EACzB,MAAM,EAAE,MAAM,GACf,IAAI,CAGN;AA6BD,wBAAgB,mBAAmB,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,UAAU,CAoBpF;AAED;;;;;;;GAOG;AACH,wBAAgB,aAAa,CAAC,IAAI,EAAE,OAAO,GAAG,OAAO,EAAE,CAItD;AAED;;;;;;;GAOG;AACH,wBAAgB,eAAe,CAAC,MAAM,GAAE,OAAO,EAAO,GAAG,OAAO,CAQ/D;AAED,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,GAAG,OAAO,CAGlF;AA2BD,wBAAgB,uBAAuB,CAAC,kBAAkB,CAAC,EAAE,UAAU,GAAG,UAAU,GAAG,SAAS,CAM/F"}
|
package/build/psbt/bip371.js
CHANGED
|
@@ -77,8 +77,12 @@ function getTaprootScripPubkey(tapInternalKey, tapTree) {
|
|
|
77
77
|
}
|
|
78
78
|
export function tweakInternalPubKey(inputIndex, input) {
|
|
79
79
|
const tapInternalKey = input.tapInternalKey;
|
|
80
|
-
const tapInternalKeyBuf = tapInternalKey
|
|
81
|
-
|
|
80
|
+
const tapInternalKeyBuf = tapInternalKey
|
|
81
|
+
? new Uint8Array(tapInternalKey)
|
|
82
|
+
: undefined;
|
|
83
|
+
const tapMerkleRootBuf = input.tapMerkleRoot
|
|
84
|
+
? new Uint8Array(input.tapMerkleRoot)
|
|
85
|
+
: undefined;
|
|
82
86
|
const outputKey = tapInternalKeyBuf && tweakKey(tapInternalKeyBuf, tapMerkleRootBuf);
|
|
83
87
|
if (!outputKey)
|
|
84
88
|
throw new Error(`Cannot tweak tap internal key for input #${inputIndex}. Public key: ${tapInternalKeyBuf &&
|
package/build/psbt/bip371.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bip371.js","sourceRoot":"","sources":["../../src/psbt/bip371.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"bip371.js","sourceRoot":"","sources":["../../src/psbt/bip371.ts"],"names":[],"mappings":"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"}
|
package/build/psbt/psbtutils.js
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"psbtutils.js","sourceRoot":"","sources":["../../src/psbt/psbtutils.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"psbtutils.js","sourceRoot":"","sources":["../../src/psbt/psbtutils.ts"],"names":[],"mappings":"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"}
|
package/build/psbt/types.d.ts
CHANGED
|
@@ -4,8 +4,8 @@
|
|
|
4
4
|
*/
|
|
5
5
|
import type { Psbt as PsbtBase, PsbtGlobal, PsbtInput, PsbtOutput } from 'bip174';
|
|
6
6
|
import type { Network } from '../networks.js';
|
|
7
|
-
import type {
|
|
8
|
-
import type { Bytes32, PublicKey, Satoshi, Script
|
|
7
|
+
import type { TaprootHashCache, Transaction } from '../transaction.js';
|
|
8
|
+
import type { Bytes32, MessageHash, PublicKey, Satoshi, Script } from '../types.js';
|
|
9
9
|
/**
|
|
10
10
|
* Transaction input interface for PSBT.
|
|
11
11
|
*/
|
|
@@ -37,7 +37,7 @@ export interface PsbtTxOutput extends TransactionOutput {
|
|
|
37
37
|
* Signature validation function type.
|
|
38
38
|
* msghash is 32 byte hash of preimage, signature is 64 byte compact signature (r,s 32 bytes each)
|
|
39
39
|
*/
|
|
40
|
-
export type ValidateSigFunction = (pubkey: PublicKey, msghash:
|
|
40
|
+
export type ValidateSigFunction = (pubkey: PublicKey, msghash: MessageHash, signature: Uint8Array) => boolean;
|
|
41
41
|
/**
|
|
42
42
|
* Extended PsbtBase interface with typed inputs and globalMap.
|
|
43
43
|
*/
|
|
@@ -84,72 +84,7 @@ export interface PsbtOutputExtendedScript extends PsbtOutput {
|
|
|
84
84
|
readonly script: Script;
|
|
85
85
|
readonly value: Satoshi;
|
|
86
86
|
}
|
|
87
|
-
|
|
88
|
-
* Base interface for HD signers.
|
|
89
|
-
*/
|
|
90
|
-
interface HDSignerBase {
|
|
91
|
-
/**
|
|
92
|
-
* DER format compressed publicKey Uint8Array
|
|
93
|
-
*/
|
|
94
|
-
readonly publicKey: PublicKey;
|
|
95
|
-
/**
|
|
96
|
-
* The first 4 bytes of the sha256-ripemd160 of the publicKey
|
|
97
|
-
*/
|
|
98
|
-
readonly fingerprint: Uint8Array;
|
|
99
|
-
}
|
|
100
|
-
/**
|
|
101
|
-
* HD signer interface for synchronous signing.
|
|
102
|
-
*/
|
|
103
|
-
export interface HDSigner extends HDSignerBase {
|
|
104
|
-
/**
|
|
105
|
-
* The path string must match /^m(\/\d+'?)+$/
|
|
106
|
-
* ex. m/44'/0'/0'/1/23 levels with ' must be hard derivations
|
|
107
|
-
*/
|
|
108
|
-
derivePath(path: string): HDSigner;
|
|
109
|
-
/**
|
|
110
|
-
* Input hash (the "message digest") for the signature algorithm
|
|
111
|
-
* Return a 64 byte signature (32 byte r and 32 byte s in that order)
|
|
112
|
-
*/
|
|
113
|
-
sign(hash: Bytes32): Uint8Array;
|
|
114
|
-
}
|
|
115
|
-
/**
|
|
116
|
-
* HD signer interface for asynchronous signing.
|
|
117
|
-
*/
|
|
118
|
-
export interface HDSignerAsync extends HDSignerBase {
|
|
119
|
-
derivePath(path: string): HDSignerAsync;
|
|
120
|
-
sign(hash: Bytes32): Promise<Uint8Array>;
|
|
121
|
-
}
|
|
122
|
-
/**
|
|
123
|
-
* Alternative signer interface with lowR support.
|
|
124
|
-
*/
|
|
125
|
-
export interface SignerAlternative {
|
|
126
|
-
readonly publicKey: PublicKey;
|
|
127
|
-
readonly lowR: boolean;
|
|
128
|
-
sign(hash: Bytes32, lowR?: boolean): Signature;
|
|
129
|
-
verify(hash: Bytes32, signature: Signature): boolean;
|
|
130
|
-
signSchnorr(hash: Bytes32): SchnorrSignature;
|
|
131
|
-
verifySchnorr(hash: Bytes32, signature: SchnorrSignature): boolean;
|
|
132
|
-
}
|
|
133
|
-
/**
|
|
134
|
-
* Basic signer interface for synchronous signing.
|
|
135
|
-
*/
|
|
136
|
-
export interface Signer {
|
|
137
|
-
readonly publicKey: PublicKey;
|
|
138
|
-
readonly network?: Network | undefined;
|
|
139
|
-
sign(hash: Bytes32, lowR?: boolean): Signature;
|
|
140
|
-
signSchnorr?(hash: Bytes32): SchnorrSignature;
|
|
141
|
-
getPublicKey?(): PublicKey;
|
|
142
|
-
}
|
|
143
|
-
/**
|
|
144
|
-
* Basic signer interface for asynchronous signing.
|
|
145
|
-
*/
|
|
146
|
-
export interface SignerAsync {
|
|
147
|
-
readonly publicKey: PublicKey;
|
|
148
|
-
readonly network?: Network | undefined;
|
|
149
|
-
sign(hash: Bytes32, lowR?: boolean): Promise<Signature>;
|
|
150
|
-
signSchnorr?(hash: Bytes32): Promise<SchnorrSignature>;
|
|
151
|
-
getPublicKey?(): PublicKey;
|
|
152
|
-
}
|
|
87
|
+
export type { Signer, SignerAsync, HDSigner, HDSignerAsync } from '@btc-vision/ecpair';
|
|
153
88
|
/**
|
|
154
89
|
* Minimal key pair interface for checking Taproot hashes.
|
|
155
90
|
* Only requires publicKey and optional signSchnorr presence check.
|
|
@@ -162,7 +97,7 @@ export interface TaprootHashCheckSigner {
|
|
|
162
97
|
/**
|
|
163
98
|
* Internal PSBT cache for computed values.
|
|
164
99
|
*/
|
|
165
|
-
export interface
|
|
100
|
+
export interface PsbtCacheInterface {
|
|
166
101
|
nonWitnessUtxoTxCache: Transaction[];
|
|
167
102
|
nonWitnessUtxoBufCache: Uint8Array[];
|
|
168
103
|
txInCache: TxInCacheMap;
|
|
@@ -245,5 +180,4 @@ export type FinalScriptsFunc = (inputIndex: number, input: PsbtInput, script: Sc
|
|
|
245
180
|
export type FinalTaprootScriptsFunc = (inputIndex: number, input: PsbtInput, tapLeafHashToFinalize?: Bytes32) => {
|
|
246
181
|
finalScriptWitness: Uint8Array | undefined;
|
|
247
182
|
};
|
|
248
|
-
export {};
|
|
249
183
|
//# sourceMappingURL=types.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/psbt/types.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,IAAI,IAAI,QAAQ,EAAE,UAAU,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,QAAQ,CAAC;AAClF,OAAO,KAAK,EAAE,OAAO,EAAE,MAAM,gBAAgB,CAAC;AAC9C,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../src/psbt/types.ts"],"names":[],"mappings":"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"}
|
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
import type { PsbtInput } from 'bip174';
|
|
6
6
|
import type { Payment, PaymentOpts } from '../payments/index.js';
|
|
7
7
|
import type { Transaction } from '../transaction.js';
|
|
8
|
-
import type { PsbtCache } from './types.js';
|
|
8
|
+
import type { PsbtCacheInterface as PsbtCache } from './types.js';
|
|
9
9
|
import type { PublicKey, Script } from '../types.js';
|
|
10
10
|
/**
|
|
11
11
|
* Validates that a number is a valid 32-bit unsigned integer.
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/psbt/validation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;
|
|
1
|
+
{"version":3,"file":"validation.d.ts","sourceRoot":"","sources":["../../src/psbt/validation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAExC,OAAO,KAAK,EAAe,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAK9E,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAE,kBAAkB,IAAI,SAAS,EAAE,MAAM,YAAY,CAAC;AAClE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,aAAa,CAAC;AAErD;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,GAAG,EAAE,MAAM,GAAG,IAAI,CAI5C;AAED;;;;GAIG;AACH,wBAAgB,UAAU,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAIjD;AAED;;;;GAIG;AACH,wBAAgB,WAAW,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAErD;AAED;;;;GAIG;AACH,wBAAgB,YAAY,CAAC,EAAE,EAAE,WAAW,GAAG,IAAI,CAWlD;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAC7B,KAAK,EAAE,SAAS,EAChB,KAAK,EAAE;IAAE,IAAI,EAAE,UAAU,CAAC;IAAC,KAAK,EAAE,MAAM,CAAA;CAAE,GAC3C,IAAI,CAKN;AAED;;;;;GAKG;AACH,wBAAgB,iBAAiB,CAAC,EAAE,EAAE,WAAW,EAAE,KAAK,EAAE,SAAS,GAAG,IAAI,CAIzE;AAED;;;;;;GAMG;AACH,wBAAgB,wBAAwB,CACpC,MAAM,EAAE,SAAS,EAAE,EACnB,MAAM,EAAE,MAAM,EACd,kBAAkB,CAAC,EAAE,OAAO,GAC7B,IAAI,CAaN;AAED;;;;GAIG;AACH,wBAAgB,wBAAwB,CAAC,KAAK,EAAE,SAAS,GAAG,IAAI,CAS/D;AAED;;;;;;GAMG;AACH,wBAAgB,oBAAoB,CAAC,MAAM,EAAE,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI,CAI5F;AAED;;;;;GAKG;AACH,wBAAgB,oBAAoB,CAChC,OAAO,EAAE,CAAC,CAAC,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,CAAC,EAAE,IAAI,CAAC,EAAE,WAAW,KAAK,OAAO,EAClE,iBAAiB,EAAE,MAAM,GAC1B,CAAC,GAAG,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,EAAE,MAAM,EAAE,OAAO,GAAG,QAAQ,KAAK,IAAI,CAiB/F;AAED;;GAEG;AACH,eAAO,MAAM,iBAAiB,QAtBrB,MAAM,gBAAgB,MAAM,gBAAgB,MAAM,UAAU,OAAO,GAAG,QAAQ,KAAK,IAsBP,CAAC;AAEtF;;GAEG;AACH,eAAO,MAAM,kBAAkB,QA3BtB,MAAM,gBAAgB,MAAM,gBAAgB,MAAM,UAAU,OAAO,GAAG,QAAQ,KAAK,IA2BJ,CAAC"}
|
package/build/psbt/validation.js
CHANGED
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
* PSBT validation utilities
|
|
3
3
|
* @packageDocumentation
|
|
4
4
|
*/
|
|
5
|
-
import {
|
|
5
|
+
import { equals, reverse, toHex } from '../io/index.js';
|
|
6
6
|
import * as payments from '../payments/index.js';
|
|
7
7
|
import { checkTaprootInputForSigs, isTaprootInput } from './bip371.js';
|
|
8
8
|
import { checkInputForSig, pubkeyInScript } from './psbtutils.js';
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/psbt/validation.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAGH,OAAO,EAAE,
|
|
1
|
+
{"version":3,"file":"validation.js","sourceRoot":"","sources":["../../src/psbt/validation.ts"],"names":[],"mappings":"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"}
|