@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,249 @@
|
|
|
1
|
+
import * as bscript from '../script.js';
|
|
2
|
+
import { isP2TR, isP2WPKH, pubkeyInScript } from './psbtutils.js';
|
|
3
|
+
import { getMeaningfulScript, isPubkeyLike, isSigLike, scriptWitnessToWitnessStack, } from './utils.js';
|
|
4
|
+
import { isFinalized } from './validation.js';
|
|
5
|
+
import { isUnknownSegwitVersion } from '../address.js';
|
|
6
|
+
/**
|
|
7
|
+
* Internal PSBT cache for computed values.
|
|
8
|
+
* Wraps all cache management previously handled by a plain interface + scattered helper functions.
|
|
9
|
+
*/
|
|
10
|
+
export class PsbtCache {
|
|
11
|
+
nonWitnessUtxoTxCache;
|
|
12
|
+
nonWitnessUtxoBufCache;
|
|
13
|
+
txInCache;
|
|
14
|
+
tx;
|
|
15
|
+
unsafeSignNonSegwit;
|
|
16
|
+
hasSignatures;
|
|
17
|
+
fee;
|
|
18
|
+
feeRate;
|
|
19
|
+
extractedTx;
|
|
20
|
+
prevOuts;
|
|
21
|
+
signingScripts;
|
|
22
|
+
values;
|
|
23
|
+
taprootHashCache;
|
|
24
|
+
constructor(tx) {
|
|
25
|
+
this.nonWitnessUtxoTxCache = [];
|
|
26
|
+
this.nonWitnessUtxoBufCache = [];
|
|
27
|
+
this.txInCache = {};
|
|
28
|
+
this.tx = tx;
|
|
29
|
+
this.unsafeSignNonSegwit = false;
|
|
30
|
+
this.hasSignatures = false;
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Invalidates cached computed values.
|
|
34
|
+
* @param scope - 'full' clears everything (for input changes), 'outputs' clears fee/extract/taproot caches
|
|
35
|
+
*/
|
|
36
|
+
invalidate(scope) {
|
|
37
|
+
this.fee = undefined;
|
|
38
|
+
this.feeRate = undefined;
|
|
39
|
+
this.extractedTx = undefined;
|
|
40
|
+
this.taprootHashCache = undefined;
|
|
41
|
+
if (scope === 'full') {
|
|
42
|
+
this.prevOuts = undefined;
|
|
43
|
+
this.signingScripts = undefined;
|
|
44
|
+
this.values = undefined;
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
addNonWitnessTxCache(input, inputIndex, txFromBuffer) {
|
|
48
|
+
if (!input.nonWitnessUtxo)
|
|
49
|
+
throw new Error('nonWitnessUtxo is required');
|
|
50
|
+
if (input === null || input === Object.prototype) {
|
|
51
|
+
throw new Error('Invalid input object');
|
|
52
|
+
}
|
|
53
|
+
const nonWitnessUtxoBuf = input.nonWitnessUtxo;
|
|
54
|
+
this.nonWitnessUtxoBufCache[inputIndex] = nonWitnessUtxoBuf;
|
|
55
|
+
this.nonWitnessUtxoTxCache[inputIndex] = txFromBuffer(nonWitnessUtxoBuf);
|
|
56
|
+
}
|
|
57
|
+
getNonWitnessUtxoTx(input, inputIndex, txFromBuffer) {
|
|
58
|
+
const cached = this.nonWitnessUtxoTxCache[inputIndex];
|
|
59
|
+
if (!cached) {
|
|
60
|
+
this.addNonWitnessTxCache(input, inputIndex, txFromBuffer);
|
|
61
|
+
}
|
|
62
|
+
return this.nonWitnessUtxoTxCache[inputIndex];
|
|
63
|
+
}
|
|
64
|
+
getScriptFromUtxo(inputIndex, input, txFromBuffer) {
|
|
65
|
+
const { script } = this.getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer);
|
|
66
|
+
return script;
|
|
67
|
+
}
|
|
68
|
+
getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer) {
|
|
69
|
+
if (input.witnessUtxo !== undefined) {
|
|
70
|
+
return {
|
|
71
|
+
script: input.witnessUtxo.script,
|
|
72
|
+
value: input.witnessUtxo.value,
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
else if (input.nonWitnessUtxo !== undefined) {
|
|
76
|
+
const nonWitnessUtxoTx = this.getNonWitnessUtxoTx(input, inputIndex, txFromBuffer);
|
|
77
|
+
const o = nonWitnessUtxoTx.outs[this.tx.ins[inputIndex].index];
|
|
78
|
+
return { script: o.script, value: o.value };
|
|
79
|
+
}
|
|
80
|
+
else {
|
|
81
|
+
throw new Error("Can't find pubkey in input without Utxo data");
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
computeFee(inputs, disableOutputChecks = false, txFromBuffer) {
|
|
85
|
+
if (!inputs.every(isFinalized))
|
|
86
|
+
throw new Error('PSBT must be finalized to calculate fee');
|
|
87
|
+
if (this.fee !== undefined)
|
|
88
|
+
return this.fee;
|
|
89
|
+
let tx;
|
|
90
|
+
let mustFinalize = true;
|
|
91
|
+
if (this.extractedTx) {
|
|
92
|
+
tx = this.extractedTx;
|
|
93
|
+
mustFinalize = false;
|
|
94
|
+
}
|
|
95
|
+
else {
|
|
96
|
+
tx = this.tx.clone();
|
|
97
|
+
}
|
|
98
|
+
const { fee } = this.finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer);
|
|
99
|
+
return fee;
|
|
100
|
+
}
|
|
101
|
+
computeFeeRate(inputs, disableOutputChecks = false, txFromBuffer) {
|
|
102
|
+
if (!inputs.every(isFinalized))
|
|
103
|
+
throw new Error('PSBT must be finalized to calculate fee rate');
|
|
104
|
+
if (this.feeRate !== undefined)
|
|
105
|
+
return this.feeRate;
|
|
106
|
+
let tx;
|
|
107
|
+
let mustFinalize = true;
|
|
108
|
+
if (this.extractedTx) {
|
|
109
|
+
tx = this.extractedTx;
|
|
110
|
+
mustFinalize = false;
|
|
111
|
+
}
|
|
112
|
+
else {
|
|
113
|
+
tx = this.tx.clone();
|
|
114
|
+
}
|
|
115
|
+
const { feeRate } = this.finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer);
|
|
116
|
+
return feeRate;
|
|
117
|
+
}
|
|
118
|
+
checkFees(opts) {
|
|
119
|
+
const feeRate = this.feeRate;
|
|
120
|
+
if (!this.extractedTx)
|
|
121
|
+
throw new Error('Transaction not extracted');
|
|
122
|
+
if (feeRate === undefined)
|
|
123
|
+
throw new Error('Fee rate not computed');
|
|
124
|
+
const vsize = this.extractedTx.virtualSize();
|
|
125
|
+
const satoshis = feeRate * vsize;
|
|
126
|
+
if (feeRate >= opts.maximumFeeRate) {
|
|
127
|
+
throw new Error(`Warning: You are paying around ${(satoshis / 1e8).toFixed(8)} in ` +
|
|
128
|
+
`fees, which is ${feeRate} satoshi per byte for a transaction ` +
|
|
129
|
+
`with a VSize of ${vsize} bytes (segwit counted as 0.25 byte per ` +
|
|
130
|
+
`byte). Use setMaximumFeeRate method to raise your threshold, or ` +
|
|
131
|
+
`pass true to the first arg of extractTransaction.`);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
pubkeyInInput(pubkey, input, inputIndex, txFromBuffer) {
|
|
135
|
+
const script = this.getScriptFromUtxo(inputIndex, input, txFromBuffer);
|
|
136
|
+
const { meaningfulScript } = getMeaningfulScript(script, inputIndex, 'input', input.redeemScript, input.witnessScript);
|
|
137
|
+
return pubkeyInScript(pubkey, meaningfulScript);
|
|
138
|
+
}
|
|
139
|
+
pubkeyInOutput(pubkey, output, outputIndex) {
|
|
140
|
+
const script = this.tx.outs[outputIndex].script;
|
|
141
|
+
const { meaningfulScript } = getMeaningfulScript(script, outputIndex, 'output', output.redeemScript, output.witnessScript);
|
|
142
|
+
return pubkeyInScript(pubkey, meaningfulScript);
|
|
143
|
+
}
|
|
144
|
+
redeemFromFinalScriptSig(finalScript) {
|
|
145
|
+
if (!finalScript)
|
|
146
|
+
return;
|
|
147
|
+
const decomp = bscript.decompile(finalScript);
|
|
148
|
+
if (!decomp)
|
|
149
|
+
return;
|
|
150
|
+
const lastItem = decomp[decomp.length - 1];
|
|
151
|
+
if (!(lastItem instanceof Uint8Array) || isPubkeyLike(lastItem) || isSigLike(lastItem))
|
|
152
|
+
return;
|
|
153
|
+
const sDecomp = bscript.decompile(lastItem);
|
|
154
|
+
if (!sDecomp)
|
|
155
|
+
return;
|
|
156
|
+
return lastItem;
|
|
157
|
+
}
|
|
158
|
+
redeemFromFinalWitnessScript(finalScript) {
|
|
159
|
+
if (!finalScript)
|
|
160
|
+
return;
|
|
161
|
+
const decomp = scriptWitnessToWitnessStack(finalScript);
|
|
162
|
+
const lastItem = decomp[decomp.length - 1];
|
|
163
|
+
if (isPubkeyLike(lastItem))
|
|
164
|
+
return;
|
|
165
|
+
const sDecomp = bscript.decompile(lastItem);
|
|
166
|
+
if (!sDecomp)
|
|
167
|
+
return;
|
|
168
|
+
return lastItem;
|
|
169
|
+
}
|
|
170
|
+
/**
|
|
171
|
+
* Finalize transaction inputs and compute fee amounts.
|
|
172
|
+
* Returns computed values instead of mutating cache parameters directly.
|
|
173
|
+
*/
|
|
174
|
+
finalizeAndComputeAmounts(inputs, tx, mustFinalize, disableOutputChecks, txFromBuffer) {
|
|
175
|
+
let inputAmount = 0n;
|
|
176
|
+
inputs.forEach((input, idx) => {
|
|
177
|
+
if (mustFinalize && input.finalScriptSig)
|
|
178
|
+
tx.ins[idx].script = input.finalScriptSig;
|
|
179
|
+
if (mustFinalize && input.finalScriptWitness) {
|
|
180
|
+
tx.ins[idx].witness = scriptWitnessToWitnessStack(input.finalScriptWitness);
|
|
181
|
+
}
|
|
182
|
+
if (input.witnessUtxo) {
|
|
183
|
+
inputAmount += input.witnessUtxo.value;
|
|
184
|
+
}
|
|
185
|
+
else if (input.nonWitnessUtxo) {
|
|
186
|
+
if (!txFromBuffer)
|
|
187
|
+
throw new Error('txFromBuffer is required for nonWitnessUtxo inputs');
|
|
188
|
+
const nwTx = this.getNonWitnessUtxoTx(input, idx, txFromBuffer);
|
|
189
|
+
const vout = tx.ins[idx].index;
|
|
190
|
+
const out = nwTx.outs[vout];
|
|
191
|
+
inputAmount += out.value;
|
|
192
|
+
}
|
|
193
|
+
});
|
|
194
|
+
const outputAmount = tx.outs.reduce((total, o) => total + o.value, 0n);
|
|
195
|
+
const feeValue = inputAmount - outputAmount;
|
|
196
|
+
if (!disableOutputChecks) {
|
|
197
|
+
if (feeValue < 0n) {
|
|
198
|
+
throw new Error(`Outputs are spending more than Inputs ${inputAmount} < ${outputAmount}`);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
const bytes = tx.virtualSize();
|
|
202
|
+
const fee = Number(feeValue);
|
|
203
|
+
const feeRate = Math.floor(fee / bytes);
|
|
204
|
+
this.fee = fee;
|
|
205
|
+
this.extractedTx = tx;
|
|
206
|
+
this.feeRate = feeRate;
|
|
207
|
+
return { fee, feeRate };
|
|
208
|
+
}
|
|
209
|
+
getScriptFromInput(inputIndex, input, txFromBuffer) {
|
|
210
|
+
const res = {
|
|
211
|
+
script: null,
|
|
212
|
+
isSegwit: false,
|
|
213
|
+
isP2SH: false,
|
|
214
|
+
isP2WSH: false,
|
|
215
|
+
};
|
|
216
|
+
res.isP2SH = !!input.redeemScript;
|
|
217
|
+
res.isP2WSH = !!input.witnessScript;
|
|
218
|
+
if (input.witnessScript) {
|
|
219
|
+
res.script = input.witnessScript;
|
|
220
|
+
}
|
|
221
|
+
else if (input.redeemScript) {
|
|
222
|
+
res.script = input.redeemScript;
|
|
223
|
+
}
|
|
224
|
+
else {
|
|
225
|
+
if (input.nonWitnessUtxo) {
|
|
226
|
+
const nonWitnessUtxoTx = this.getNonWitnessUtxoTx(input, inputIndex, txFromBuffer);
|
|
227
|
+
const prevoutIndex = this.tx.ins[inputIndex].index;
|
|
228
|
+
res.script = nonWitnessUtxoTx.outs[prevoutIndex].script;
|
|
229
|
+
}
|
|
230
|
+
else if (input.witnessUtxo) {
|
|
231
|
+
res.script = input.witnessUtxo.script;
|
|
232
|
+
}
|
|
233
|
+
}
|
|
234
|
+
if (input.witnessScript || (res.script && isP2WPKH(res.script))) {
|
|
235
|
+
res.isSegwit = true;
|
|
236
|
+
}
|
|
237
|
+
else {
|
|
238
|
+
if (res.script && isUnknownSegwitVersion(res.script)) {
|
|
239
|
+
res.isSegwit = true;
|
|
240
|
+
}
|
|
241
|
+
}
|
|
242
|
+
return res;
|
|
243
|
+
}
|
|
244
|
+
getPrevoutTaprootKey(inputIndex, input, txFromBuffer) {
|
|
245
|
+
const { script } = this.getScriptAndAmountFromUtxo(inputIndex, input, txFromBuffer);
|
|
246
|
+
return isP2TR(script) ? script.subarray(2, 34) : null;
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
//# sourceMappingURL=PsbtCache.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtCache.js","sourceRoot":"","sources":["../../src/psbt/PsbtCache.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
import type { PartialSig, PsbtInput } from 'bip174';
|
|
2
|
+
import type { Transaction } from '../transaction.js';
|
|
3
|
+
import type { Script } from '../types.js';
|
|
4
|
+
import type { PsbtCache } from './PsbtCache.js';
|
|
5
|
+
import type { GetScriptReturn } from './types.js';
|
|
6
|
+
export interface FinalScriptsResult {
|
|
7
|
+
readonly finalScriptSig: Script | undefined;
|
|
8
|
+
readonly finalScriptWitness: Uint8Array | undefined;
|
|
9
|
+
}
|
|
10
|
+
/**
|
|
11
|
+
* Class wrapping all finalization logic for PSBT.
|
|
12
|
+
*/
|
|
13
|
+
export declare class PsbtFinalizer {
|
|
14
|
+
#private;
|
|
15
|
+
constructor(cache: PsbtCache, txFromBuffer: (buf: Uint8Array) => Transaction);
|
|
16
|
+
getFinalScripts(inputIndex: number, input: PsbtInput, script: Script, isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, canRunChecks?: boolean, solution?: Uint8Array[]): FinalScriptsResult;
|
|
17
|
+
getScriptFromInput(inputIndex: number, input: PsbtInput): GetScriptReturn;
|
|
18
|
+
}
|
|
19
|
+
export declare function getFinalScripts(inputIndex: number, input: PsbtInput, script: Script, isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, canRunChecks?: boolean, solution?: Uint8Array[]): FinalScriptsResult;
|
|
20
|
+
export declare function prepareFinalScripts(script: Uint8Array, scriptType: string, partialSig: PartialSig[], isSegwit: boolean, isP2SH: boolean, isP2WSH: boolean, solution?: Uint8Array[]): FinalScriptsResult;
|
|
21
|
+
//# sourceMappingURL=PsbtFinalizer.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtFinalizer.d.ts","sourceRoot":"","sources":["../../src/psbt/PsbtFinalizer.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAMpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AACrD,OAAO,KAAK,EAAa,MAAM,EAAa,MAAM,aAAa,CAAC;AAChE,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAElD,MAAM,WAAW,kBAAkB;IAC/B,QAAQ,CAAC,cAAc,EAAE,MAAM,GAAG,SAAS,CAAC;IAC5C,QAAQ,CAAC,kBAAkB,EAAE,UAAU,GAAG,SAAS,CAAC;CACvD;AAED;;GAEG;AACH,qBAAa,aAAa;;gBAIH,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,EAAE,UAAU,KAAK,WAAW;IAK5E,eAAe,CAClB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,YAAY,GAAE,OAAc,EAC5B,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB;IAkBd,kBAAkB,CAAC,UAAU,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,GAAG,eAAe;CAGnF;AAED,wBAAgB,eAAe,CAC3B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,MAAM,EACd,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,YAAY,GAAE,OAAc,EAC5B,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB,CAgBpB;AAED,wBAAgB,mBAAmB,CAC/B,MAAM,EAAE,UAAU,EAClB,UAAU,EAAE,MAAM,EAClB,UAAU,EAAE,UAAU,EAAE,EACxB,QAAQ,EAAE,OAAO,EACjB,MAAM,EAAE,OAAO,EACf,OAAO,EAAE,OAAO,EAChB,QAAQ,CAAC,EAAE,UAAU,EAAE,GACxB,kBAAkB,CAiCpB"}
|
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
import { equals } from '../io/index.js';
|
|
2
|
+
import * as payments from '../payments/index.js';
|
|
3
|
+
import { witnessStackToScriptWitness } from './psbtutils.js';
|
|
4
|
+
import { classifyScript, compressPubkey } from './utils.js';
|
|
5
|
+
/**
|
|
6
|
+
* Class wrapping all finalization logic for PSBT.
|
|
7
|
+
*/
|
|
8
|
+
export class PsbtFinalizer {
|
|
9
|
+
#cache;
|
|
10
|
+
#txFromBuffer;
|
|
11
|
+
constructor(cache, txFromBuffer) {
|
|
12
|
+
this.#cache = cache;
|
|
13
|
+
this.#txFromBuffer = txFromBuffer;
|
|
14
|
+
}
|
|
15
|
+
getFinalScripts(inputIndex, input, script, isSegwit, isP2SH, isP2WSH, canRunChecks = true, solution) {
|
|
16
|
+
const scriptType = classifyScript(script);
|
|
17
|
+
if (!canFinalize(input, script, scriptType) && canRunChecks) {
|
|
18
|
+
throw new Error(`Can not finalize input #${inputIndex}`);
|
|
19
|
+
}
|
|
20
|
+
if (!input.partialSig)
|
|
21
|
+
throw new Error('Input missing partial signatures');
|
|
22
|
+
return prepareFinalScripts(script, scriptType, input.partialSig, isSegwit, isP2SH, isP2WSH, solution);
|
|
23
|
+
}
|
|
24
|
+
getScriptFromInput(inputIndex, input) {
|
|
25
|
+
return this.#cache.getScriptFromInput(inputIndex, input, this.#txFromBuffer);
|
|
26
|
+
}
|
|
27
|
+
}
|
|
28
|
+
export function getFinalScripts(inputIndex, input, script, isSegwit, isP2SH, isP2WSH, canRunChecks = true, solution) {
|
|
29
|
+
const scriptType = classifyScript(script);
|
|
30
|
+
if (!canFinalize(input, script, scriptType) && canRunChecks) {
|
|
31
|
+
throw new Error(`Can not finalize input #${inputIndex}`);
|
|
32
|
+
}
|
|
33
|
+
if (!input.partialSig)
|
|
34
|
+
throw new Error('Input missing partial signatures');
|
|
35
|
+
return prepareFinalScripts(script, scriptType, input.partialSig, isSegwit, isP2SH, isP2WSH, solution);
|
|
36
|
+
}
|
|
37
|
+
export function prepareFinalScripts(script, scriptType, partialSig, isSegwit, isP2SH, isP2WSH, solution) {
|
|
38
|
+
let finalScriptSig;
|
|
39
|
+
let finalScriptWitness;
|
|
40
|
+
const payment = getPayment(script, scriptType, partialSig);
|
|
41
|
+
const p2wsh = !isP2WSH ? null : payments.p2wsh({ redeem: payment });
|
|
42
|
+
const p2sh = !isP2SH ? null : payments.p2sh({ redeem: p2wsh || payment });
|
|
43
|
+
if (isSegwit) {
|
|
44
|
+
if (p2wsh && p2wsh.witness) {
|
|
45
|
+
finalScriptWitness = witnessStackToScriptWitness(p2wsh.witness);
|
|
46
|
+
}
|
|
47
|
+
else if (payment && payment.witness) {
|
|
48
|
+
finalScriptWitness = witnessStackToScriptWitness(payment.witness);
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
finalScriptWitness = witnessStackToScriptWitness(solution ?? [new Uint8Array([0x00])]);
|
|
52
|
+
}
|
|
53
|
+
if (p2sh) {
|
|
54
|
+
finalScriptSig = p2sh?.input;
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
if (p2sh) {
|
|
59
|
+
finalScriptSig = p2sh?.input;
|
|
60
|
+
}
|
|
61
|
+
else {
|
|
62
|
+
if (!payment) {
|
|
63
|
+
finalScriptSig = (Array.isArray(solution) && solution[0] ? solution[0] : new Uint8Array([0x01]));
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
finalScriptSig = payment.input;
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
}
|
|
70
|
+
return { finalScriptSig, finalScriptWitness };
|
|
71
|
+
}
|
|
72
|
+
function canFinalize(input, script, scriptType) {
|
|
73
|
+
switch (scriptType) {
|
|
74
|
+
case 'pubkey':
|
|
75
|
+
case 'pubkeyhash':
|
|
76
|
+
case 'witnesspubkeyhash':
|
|
77
|
+
return hasSigs(1, input.partialSig);
|
|
78
|
+
case 'multisig': {
|
|
79
|
+
const p2ms = payments.p2ms({
|
|
80
|
+
output: script,
|
|
81
|
+
});
|
|
82
|
+
if (p2ms.m === undefined)
|
|
83
|
+
throw new Error('Cannot determine m for multisig');
|
|
84
|
+
return hasSigs(p2ms.m, input.partialSig, p2ms.pubkeys);
|
|
85
|
+
}
|
|
86
|
+
case 'nonstandard':
|
|
87
|
+
return true;
|
|
88
|
+
default:
|
|
89
|
+
return false;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
function hasSigs(neededSigs, partialSig, pubkeys) {
|
|
93
|
+
if (!partialSig)
|
|
94
|
+
return false;
|
|
95
|
+
let sigs;
|
|
96
|
+
if (pubkeys) {
|
|
97
|
+
sigs = pubkeys
|
|
98
|
+
.map((pkey) => {
|
|
99
|
+
const pubkey = compressPubkey(pkey);
|
|
100
|
+
return partialSig.find((pSig) => equals(pSig.pubkey, pubkey));
|
|
101
|
+
})
|
|
102
|
+
.filter((v) => !!v);
|
|
103
|
+
}
|
|
104
|
+
else {
|
|
105
|
+
sigs = partialSig;
|
|
106
|
+
}
|
|
107
|
+
if (sigs.length > neededSigs)
|
|
108
|
+
throw new Error('Too many signatures');
|
|
109
|
+
return sigs.length === neededSigs;
|
|
110
|
+
}
|
|
111
|
+
function getPayment(script, scriptType, partialSig) {
|
|
112
|
+
const scriptBranded = script;
|
|
113
|
+
switch (scriptType) {
|
|
114
|
+
case 'multisig': {
|
|
115
|
+
const sigs = getSortedSigs(script, partialSig);
|
|
116
|
+
return payments.p2ms({
|
|
117
|
+
output: scriptBranded,
|
|
118
|
+
signatures: sigs,
|
|
119
|
+
});
|
|
120
|
+
}
|
|
121
|
+
case 'pubkey':
|
|
122
|
+
return payments.p2pk({
|
|
123
|
+
output: scriptBranded,
|
|
124
|
+
signature: partialSig[0].signature,
|
|
125
|
+
});
|
|
126
|
+
case 'pubkeyhash':
|
|
127
|
+
return payments.p2pkh({
|
|
128
|
+
output: scriptBranded,
|
|
129
|
+
pubkey: partialSig[0].pubkey,
|
|
130
|
+
signature: partialSig[0].signature,
|
|
131
|
+
});
|
|
132
|
+
case 'witnesspubkeyhash':
|
|
133
|
+
return payments.p2wpkh({
|
|
134
|
+
output: scriptBranded,
|
|
135
|
+
pubkey: partialSig[0].pubkey,
|
|
136
|
+
signature: partialSig[0].signature,
|
|
137
|
+
});
|
|
138
|
+
default:
|
|
139
|
+
throw new Error(`Unknown script type: ${scriptType}`);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
function getSortedSigs(script, partialSig) {
|
|
143
|
+
const p2ms = payments.p2ms({ output: script });
|
|
144
|
+
if (!p2ms.pubkeys)
|
|
145
|
+
throw new Error('Cannot extract pubkeys from multisig script');
|
|
146
|
+
const result = [];
|
|
147
|
+
for (const pk of p2ms.pubkeys) {
|
|
148
|
+
const matched = partialSig.filter((ps) => {
|
|
149
|
+
return equals(ps.pubkey, pk);
|
|
150
|
+
})[0];
|
|
151
|
+
if (matched) {
|
|
152
|
+
result.push(new Uint8Array(matched.signature));
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
return result;
|
|
156
|
+
}
|
|
157
|
+
//# sourceMappingURL=PsbtFinalizer.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtFinalizer.js","sourceRoot":"","sources":["../../src/psbt/PsbtFinalizer.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,32 @@
|
|
|
1
|
+
import type { Bip32Derivation, PsbtInput } from 'bip174';
|
|
2
|
+
import { Transaction } from '../transaction.js';
|
|
3
|
+
import type { Bytes32, MessageHash, PublicKey, Script } from '../types.js';
|
|
4
|
+
import type { PsbtCache } from './PsbtCache.js';
|
|
5
|
+
import type { HDSigner, HDSignerAsync } from './types.js';
|
|
6
|
+
export interface HashForSig {
|
|
7
|
+
readonly pubkey: PublicKey;
|
|
8
|
+
readonly hash: MessageHash;
|
|
9
|
+
readonly leafHash?: Bytes32;
|
|
10
|
+
}
|
|
11
|
+
/**
|
|
12
|
+
* Class wrapping all signing-related logic for PSBT.
|
|
13
|
+
*/
|
|
14
|
+
export declare class PsbtSigner {
|
|
15
|
+
#private;
|
|
16
|
+
constructor(cache: PsbtCache, txFromBuffer: (buf: Uint8Array) => Transaction);
|
|
17
|
+
getHashAndSighashType(inputs: PsbtInput[], inputIndex: number, pubkey: Uint8Array, sighashTypes: number[]): {
|
|
18
|
+
hash: MessageHash;
|
|
19
|
+
sighashType: number;
|
|
20
|
+
};
|
|
21
|
+
getHashForSig(inputIndex: number, input: PsbtInput, forValidate: boolean, sighashTypes?: number[]): {
|
|
22
|
+
script: Script;
|
|
23
|
+
hash: MessageHash;
|
|
24
|
+
sighashType: number;
|
|
25
|
+
};
|
|
26
|
+
getTaprootHashesForSig(inputIndex: number, input: PsbtInput, inputs: PsbtInput[], pubkey: Uint8Array, tapLeafHashToSign?: Uint8Array, allowedSighashTypes?: number[]): HashForSig[];
|
|
27
|
+
getAllTaprootHashesForSig(inputIndex: number, input: PsbtInput, inputs: PsbtInput[]): HashForSig[];
|
|
28
|
+
trimTaprootSig(signature: Uint8Array): Uint8Array;
|
|
29
|
+
getSignersFromHD<T extends HDSigner | HDSignerAsync>(inputIndex: number, inputs: PsbtInput[], hdKeyPair: T): T[];
|
|
30
|
+
bip32DerivationIsMine(root: HDSigner): (d: Bip32Derivation) => boolean;
|
|
31
|
+
}
|
|
32
|
+
//# sourceMappingURL=PsbtSigner.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"PsbtSigner.d.ts","sourceRoot":"","sources":["../../src/psbt/PsbtSigner.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,SAAS,EAAE,MAAM,QAAQ,CAAC;AAUzD,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAChD,OAAO,KAAK,EAAW,OAAO,EAAE,WAAW,EAAE,SAAS,EAAW,MAAM,EAAE,MAAM,aAAa,CAAC;AAC7F,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAChD,OAAO,KAAK,EAAE,QAAQ,EAAE,aAAa,EAAE,MAAM,YAAY,CAAC;AAE1D,MAAM,WAAW,UAAU;IACvB,QAAQ,CAAC,MAAM,EAAE,SAAS,CAAC;IAC3B,QAAQ,CAAC,IAAI,EAAE,WAAW,CAAC;IAC3B,QAAQ,CAAC,QAAQ,CAAC,EAAE,OAAO,CAAC;CAC/B;AAED;;GAEG;AACH,qBAAa,UAAU;;gBAIA,KAAK,EAAE,SAAS,EAAE,YAAY,EAAE,CAAC,GAAG,EAAE,UAAU,KAAK,WAAW;IAK5E,qBAAqB,CACxB,MAAM,EAAE,SAAS,EAAE,EACnB,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,UAAU,EAClB,YAAY,EAAE,MAAM,EAAE,GACvB;QAAE,IAAI,EAAE,WAAW,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;IAatC,aAAa,CAChB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,WAAW,EAAE,OAAO,EACpB,YAAY,CAAC,EAAE,MAAM,EAAE,GACxB;QAAE,MAAM,EAAE,MAAM,CAAC;QAAC,IAAI,EAAE,WAAW,CAAC;QAAC,WAAW,EAAE,MAAM,CAAA;KAAE;IAiFtD,sBAAsB,CACzB,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,EAAE,EACnB,MAAM,EAAE,UAAU,EAClB,iBAAiB,CAAC,EAAE,UAAU,EAC9B,mBAAmB,CAAC,EAAE,MAAM,EAAE,GAC/B,UAAU,EAAE;IAuER,yBAAyB,CAC5B,UAAU,EAAE,MAAM,EAClB,KAAK,EAAE,SAAS,EAChB,MAAM,EAAE,SAAS,EAAE,GACpB,UAAU,EAAE;IAqBR,cAAc,CAAC,SAAS,EAAE,UAAU,GAAG,UAAU;IAIjD,gBAAgB,CAAC,CAAC,SAAS,QAAQ,GAAG,aAAa,EACtD,UAAU,EAAE,MAAM,EAClB,MAAM,EAAE,SAAS,EAAE,EACnB,SAAS,EAAE,CAAC,GACb,CAAC,EAAE;IA6BC,qBAAqB,CAAC,IAAI,EAAE,QAAQ,GAAG,CAAC,CAAC,EAAE,eAAe,KAAK,OAAO;CAchF"}
|