utxo-lib 1.0.1
Sign up to get free protection for your applications and to get access to all the features.
- package/LICENSE +21 -0
- package/README.md +59 -0
- package/dist/src/address.d.ts +11 -0
- package/dist/src/address.d.ts.map +1 -0
- package/dist/src/address.js +37 -0
- package/dist/src/addressFormat.d.ts +53 -0
- package/dist/src/addressFormat.d.ts.map +1 -0
- package/dist/src/addressFormat.js +110 -0
- package/dist/src/bitgo/Musig2.d.ts +51 -0
- package/dist/src/bitgo/Musig2.d.ts.map +1 -0
- package/dist/src/bitgo/Musig2.js +175 -0
- package/dist/src/bitgo/Unspent.d.ts +95 -0
- package/dist/src/bitgo/Unspent.d.ts.map +1 -0
- package/dist/src/bitgo/Unspent.js +138 -0
- package/dist/src/bitgo/UtxoPsbt.d.ts +132 -0
- package/dist/src/bitgo/UtxoPsbt.d.ts.map +1 -0
- package/dist/src/bitgo/UtxoPsbt.js +469 -0
- package/dist/src/bitgo/UtxoTransaction.d.ts +22 -0
- package/dist/src/bitgo/UtxoTransaction.d.ts.map +1 -0
- package/dist/src/bitgo/UtxoTransaction.js +97 -0
- package/dist/src/bitgo/UtxoTransactionBuilder.d.ts +26 -0
- package/dist/src/bitgo/UtxoTransactionBuilder.d.ts.map +1 -0
- package/dist/src/bitgo/UtxoTransactionBuilder.js +67 -0
- package/dist/src/bitgo/bbc/DashPsbt.d.ts +12 -0
- package/dist/src/bitgo/bbc/DashPsbt.d.ts.map +1 -0
- package/dist/src/bitgo/bbc/DashPsbt.js +27 -0
- package/dist/src/bitgo/bbc/DashTransaction.d.ts +39 -0
- package/dist/src/bitgo/bbc/DashTransaction.d.ts.map +1 -0
- package/dist/src/bitgo/bbc/DashTransaction.js +109 -0
- package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts +14 -0
- package/dist/src/bitgo/bbc/DashTransactionBuilder.d.ts.map +1 -0
- package/dist/src/bitgo/bbc/DashTransactionBuilder.js +28 -0
- package/dist/src/bitgo/bbc/index.d.ts +4 -0
- package/dist/src/bitgo/bbc/index.d.ts.map +1 -0
- package/dist/src/bitgo/bbc/index.js +16 -0
- package/dist/src/bitgo/bitcoincash/address.d.ts +35 -0
- package/dist/src/bitgo/bitcoincash/address.d.ts.map +1 -0
- package/dist/src/bitgo/bitcoincash/address.js +151 -0
- package/dist/src/bitgo/bitcoincash/index.d.ts +2 -0
- package/dist/src/bitgo/bitcoincash/index.d.ts.map +1 -0
- package/dist/src/bitgo/bitcoincash/index.js +14 -0
- package/dist/src/bitgo/dash/DashPsbt.d.ts +12 -0
- package/dist/src/bitgo/dash/DashPsbt.d.ts.map +1 -0
- package/dist/src/bitgo/dash/DashPsbt.js +27 -0
- package/dist/src/bitgo/dash/DashTransaction.d.ts +39 -0
- package/dist/src/bitgo/dash/DashTransaction.d.ts.map +1 -0
- package/dist/src/bitgo/dash/DashTransaction.js +109 -0
- package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts +14 -0
- package/dist/src/bitgo/dash/DashTransactionBuilder.d.ts.map +1 -0
- package/dist/src/bitgo/dash/DashTransactionBuilder.js +28 -0
- package/dist/src/bitgo/dash/index.d.ts +4 -0
- package/dist/src/bitgo/dash/index.d.ts.map +1 -0
- package/dist/src/bitgo/dash/index.js +16 -0
- package/dist/src/bitgo/index.d.ts +17 -0
- package/dist/src/bitgo/index.d.ts.map +1 -0
- package/dist/src/bitgo/index.js +30 -0
- package/dist/src/bitgo/keyutil.d.ts +17 -0
- package/dist/src/bitgo/keyutil.d.ts.map +1 -0
- package/dist/src/bitgo/keyutil.js +37 -0
- package/dist/src/bitgo/nonStandardHalfSigned.d.ts +7 -0
- package/dist/src/bitgo/nonStandardHalfSigned.d.ts.map +1 -0
- package/dist/src/bitgo/nonStandardHalfSigned.js +56 -0
- package/dist/src/bitgo/outputScripts.d.ts +84 -0
- package/dist/src/bitgo/outputScripts.d.ts.map +1 -0
- package/dist/src/bitgo/outputScripts.js +297 -0
- package/dist/src/bitgo/parseInput.d.ts +92 -0
- package/dist/src/bitgo/parseInput.d.ts.map +1 -0
- package/dist/src/bitgo/parseInput.js +344 -0
- package/dist/src/bitgo/psbt/fromHalfSigned.d.ts +24 -0
- package/dist/src/bitgo/psbt/fromHalfSigned.d.ts.map +1 -0
- package/dist/src/bitgo/psbt/fromHalfSigned.js +91 -0
- package/dist/src/bitgo/psbt/scriptTypes.d.ts +6 -0
- package/dist/src/bitgo/psbt/scriptTypes.d.ts.map +1 -0
- package/dist/src/bitgo/psbt/scriptTypes.js +23 -0
- package/dist/src/bitgo/signature.d.ts +84 -0
- package/dist/src/bitgo/signature.d.ts.map +1 -0
- package/dist/src/bitgo/signature.js +222 -0
- package/dist/src/bitgo/tnumber.d.ts +9 -0
- package/dist/src/bitgo/tnumber.d.ts.map +1 -0
- package/dist/src/bitgo/tnumber.js +31 -0
- package/dist/src/bitgo/transaction.d.ts +29 -0
- package/dist/src/bitgo/transaction.d.ts.map +1 -0
- package/dist/src/bitgo/transaction.js +247 -0
- package/dist/src/bitgo/types.d.ts +5 -0
- package/dist/src/bitgo/types.d.ts.map +1 -0
- package/dist/src/bitgo/types.js +12 -0
- package/dist/src/bitgo/wallet/Psbt.d.ts +47 -0
- package/dist/src/bitgo/wallet/Psbt.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/Psbt.js +232 -0
- package/dist/src/bitgo/wallet/Unspent.d.ts +47 -0
- package/dist/src/bitgo/wallet/Unspent.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/Unspent.js +154 -0
- package/dist/src/bitgo/wallet/WalletKeys.d.ts +72 -0
- package/dist/src/bitgo/wallet/WalletKeys.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/WalletKeys.js +104 -0
- package/dist/src/bitgo/wallet/WalletOutput.d.ts +18 -0
- package/dist/src/bitgo/wallet/WalletOutput.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/WalletOutput.js +69 -0
- package/dist/src/bitgo/wallet/WalletScripts.d.ts +7 -0
- package/dist/src/bitgo/wallet/WalletScripts.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/WalletScripts.js +15 -0
- package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts +19 -0
- package/dist/src/bitgo/wallet/WalletUnspentSigner.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/WalletUnspentSigner.js +47 -0
- package/dist/src/bitgo/wallet/chains.d.ts +57 -0
- package/dist/src/bitgo/wallet/chains.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/chains.js +106 -0
- package/dist/src/bitgo/wallet/index.d.ts +8 -0
- package/dist/src/bitgo/wallet/index.d.ts.map +1 -0
- package/dist/src/bitgo/wallet/index.js +20 -0
- package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts +26 -0
- package/dist/src/bitgo/zcash/ZcashBufferutils.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/ZcashBufferutils.js +157 -0
- package/dist/src/bitgo/zcash/ZcashPsbt.d.ts +36 -0
- package/dist/src/bitgo/zcash/ZcashPsbt.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/ZcashPsbt.js +146 -0
- package/dist/src/bitgo/zcash/ZcashTransaction.d.ts +61 -0
- package/dist/src/bitgo/zcash/ZcashTransaction.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/ZcashTransaction.js +341 -0
- package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts +21 -0
- package/dist/src/bitgo/zcash/ZcashTransactionBuilder.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/ZcashTransactionBuilder.js +105 -0
- package/dist/src/bitgo/zcash/address.d.ts +8 -0
- package/dist/src/bitgo/zcash/address.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/address.js +57 -0
- package/dist/src/bitgo/zcash/hashZip0244.d.ts +27 -0
- package/dist/src/bitgo/zcash/hashZip0244.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/hashZip0244.js +184 -0
- package/dist/src/bitgo/zcash/index.d.ts +4 -0
- package/dist/src/bitgo/zcash/index.d.ts.map +1 -0
- package/dist/src/bitgo/zcash/index.js +16 -0
- package/dist/src/classify.d.ts +19 -0
- package/dist/src/classify.d.ts.map +1 -0
- package/dist/src/classify.js +89 -0
- package/dist/src/index.d.ts +13 -0
- package/dist/src/index.d.ts.map +1 -0
- package/dist/src/index.js +36 -0
- package/dist/src/networks.d.ts +119 -0
- package/dist/src/networks.d.ts.map +1 -0
- package/dist/src/networks.js +477 -0
- package/dist/src/noble_ecc.d.ts +28 -0
- package/dist/src/noble_ecc.d.ts.map +1 -0
- package/dist/src/noble_ecc.js +168 -0
- package/dist/src/payments/index.d.ts +4 -0
- package/dist/src/payments/index.d.ts.map +1 -0
- package/dist/src/payments/index.js +8 -0
- package/dist/src/payments/p2tr.d.ts +3 -0
- package/dist/src/payments/p2tr.d.ts.map +1 -0
- package/dist/src/payments/p2tr.js +348 -0
- package/dist/src/payments/p2tr_ns.d.ts +3 -0
- package/dist/src/payments/p2tr_ns.d.ts.map +1 -0
- package/dist/src/payments/p2tr_ns.js +134 -0
- package/dist/src/taproot.d.ts +141 -0
- package/dist/src/taproot.d.ts.map +1 -0
- package/dist/src/taproot.js +384 -0
- package/dist/src/templates/multisig/index.d.ts +4 -0
- package/dist/src/templates/multisig/index.d.ts.map +1 -0
- package/dist/src/templates/multisig/index.js +8 -0
- package/dist/src/templates/multisig/input.d.ts +7 -0
- package/dist/src/templates/multisig/input.d.ts.map +1 -0
- package/dist/src/templates/multisig/input.js +25 -0
- package/dist/src/templates/multisig/output.d.ts +7 -0
- package/dist/src/templates/multisig/output.d.ts.map +1 -0
- package/dist/src/templates/multisig/output.js +38 -0
- package/dist/src/templates/nulldata.d.ts +10 -0
- package/dist/src/templates/nulldata.d.ts.map +1 -0
- package/dist/src/templates/nulldata.js +17 -0
- package/dist/src/templates/pubkey/index.d.ts +4 -0
- package/dist/src/templates/pubkey/index.d.ts.map +1 -0
- package/dist/src/templates/pubkey/index.js +8 -0
- package/dist/src/templates/pubkey/input.d.ts +7 -0
- package/dist/src/templates/pubkey/input.d.ts.map +1 -0
- package/dist/src/templates/pubkey/input.js +14 -0
- package/dist/src/templates/pubkey/output.d.ts +7 -0
- package/dist/src/templates/pubkey/output.d.ts.map +1 -0
- package/dist/src/templates/pubkey/output.js +15 -0
- package/dist/src/templates/pubkeyhash/index.d.ts +4 -0
- package/dist/src/templates/pubkeyhash/index.d.ts.map +1 -0
- package/dist/src/templates/pubkeyhash/index.js +8 -0
- package/dist/src/templates/pubkeyhash/input.d.ts +7 -0
- package/dist/src/templates/pubkeyhash/input.d.ts.map +1 -0
- package/dist/src/templates/pubkeyhash/input.js +16 -0
- package/dist/src/templates/pubkeyhash/output.d.ts +6 -0
- package/dist/src/templates/pubkeyhash/output.d.ts.map +1 -0
- package/dist/src/templates/pubkeyhash/output.js +20 -0
- package/dist/src/templates/scripthash/index.d.ts +4 -0
- package/dist/src/templates/scripthash/index.d.ts.map +1 -0
- package/dist/src/templates/scripthash/index.js +8 -0
- package/dist/src/templates/scripthash/input.d.ts +6 -0
- package/dist/src/templates/scripthash/input.d.ts.map +1 -0
- package/dist/src/templates/scripthash/input.js +43 -0
- package/dist/src/templates/scripthash/output.d.ts +6 -0
- package/dist/src/templates/scripthash/output.d.ts.map +1 -0
- package/dist/src/templates/scripthash/output.js +15 -0
- package/dist/src/templates/taproot/index.d.ts +4 -0
- package/dist/src/templates/taproot/index.d.ts.map +1 -0
- package/dist/src/templates/taproot/index.js +8 -0
- package/dist/src/templates/taproot/input.d.ts +6 -0
- package/dist/src/templates/taproot/input.d.ts.map +1 -0
- package/dist/src/templates/taproot/input.js +23 -0
- package/dist/src/templates/taproot/output.d.ts +6 -0
- package/dist/src/templates/taproot/output.d.ts.map +1 -0
- package/dist/src/templates/taproot/output.js +15 -0
- package/dist/src/templates/taprootnofn/index.d.ts +4 -0
- package/dist/src/templates/taprootnofn/index.d.ts.map +1 -0
- package/dist/src/templates/taprootnofn/index.js +8 -0
- package/dist/src/templates/taprootnofn/input.d.ts +7 -0
- package/dist/src/templates/taprootnofn/input.d.ts.map +1 -0
- package/dist/src/templates/taprootnofn/input.js +24 -0
- package/dist/src/templates/taprootnofn/output.d.ts +7 -0
- package/dist/src/templates/taprootnofn/output.d.ts.map +1 -0
- package/dist/src/templates/taprootnofn/output.js +28 -0
- package/dist/src/templates/witnesscommitment/index.d.ts +3 -0
- package/dist/src/templates/witnesscommitment/index.d.ts.map +1 -0
- package/dist/src/templates/witnesscommitment/index.js +6 -0
- package/dist/src/templates/witnesscommitment/output.d.ts +8 -0
- package/dist/src/templates/witnesscommitment/output.d.ts.map +1 -0
- package/dist/src/templates/witnesscommitment/output.js +31 -0
- package/dist/src/templates/witnesspubkeyhash/index.d.ts +4 -0
- package/dist/src/templates/witnesspubkeyhash/index.d.ts.map +1 -0
- package/dist/src/templates/witnesspubkeyhash/index.js +8 -0
- package/dist/src/templates/witnesspubkeyhash/input.d.ts +7 -0
- package/dist/src/templates/witnesspubkeyhash/input.d.ts.map +1 -0
- package/dist/src/templates/witnesspubkeyhash/input.js +19 -0
- package/dist/src/templates/witnesspubkeyhash/output.d.ts +6 -0
- package/dist/src/templates/witnesspubkeyhash/output.d.ts.map +1 -0
- package/dist/src/templates/witnesspubkeyhash/output.js +15 -0
- package/dist/src/templates/witnessscripthash/index.d.ts +4 -0
- package/dist/src/templates/witnessscripthash/index.d.ts.map +1 -0
- package/dist/src/templates/witnessscripthash/index.js +8 -0
- package/dist/src/templates/witnessscripthash/input.d.ts +6 -0
- package/dist/src/templates/witnessscripthash/input.d.ts.map +1 -0
- package/dist/src/templates/witnessscripthash/input.js +35 -0
- package/dist/src/templates/witnessscripthash/output.d.ts +6 -0
- package/dist/src/templates/witnessscripthash/output.d.ts.map +1 -0
- package/dist/src/templates/witnessscripthash/output.js +15 -0
- package/dist/src/testutil/index.d.ts +3 -0
- package/dist/src/testutil/index.d.ts.map +1 -0
- package/dist/src/testutil/index.js +15 -0
- package/dist/src/testutil/keys.d.ts +10 -0
- package/dist/src/testutil/keys.d.ts.map +1 -0
- package/dist/src/testutil/keys.js +40 -0
- package/dist/src/testutil/mock.d.ts +21 -0
- package/dist/src/testutil/mock.d.ts.map +1 -0
- package/dist/src/testutil/mock.js +86 -0
- package/dist/src/transaction_builder.d.ts +47 -0
- package/dist/src/transaction_builder.d.ts.map +1 -0
- package/dist/src/transaction_builder.js +1084 -0
- package/package.json +87 -0
@@ -0,0 +1,168 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.musig = exports.bip32 = exports.ECPair = exports.ecc = void 0;
|
4
|
+
const createHash = require("create-hash");
|
5
|
+
const createHmac = require("create-hmac");
|
6
|
+
const ecpair_1 = require("ecpair");
|
7
|
+
const necc = require("@noble/secp256k1");
|
8
|
+
const bip32_1 = require("bip32");
|
9
|
+
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
10
|
+
// @ts-ignore base_crypto is exported as a subPath export, ignoring since compiler complains about importing like this
|
11
|
+
const baseCrypto = require("@brandonblack/musig/base_crypto");
|
12
|
+
const musig_1 = require("@brandonblack/musig");
|
13
|
+
necc.utils.sha256Sync = (...messages) => {
|
14
|
+
const sha256 = createHash('sha256');
|
15
|
+
for (const message of messages)
|
16
|
+
sha256.update(message);
|
17
|
+
return sha256.digest();
|
18
|
+
};
|
19
|
+
necc.utils.hmacSha256Sync = (key, ...messages) => {
|
20
|
+
const hash = createHmac('sha256', Buffer.from(key));
|
21
|
+
messages.forEach((m) => hash.update(m));
|
22
|
+
return Uint8Array.from(hash.digest());
|
23
|
+
};
|
24
|
+
const defaultTrue = (param) => param !== false;
|
25
|
+
function throwToNull(fn) {
|
26
|
+
try {
|
27
|
+
return fn();
|
28
|
+
}
|
29
|
+
catch (e) {
|
30
|
+
return null;
|
31
|
+
}
|
32
|
+
}
|
33
|
+
function isPoint(p, xOnly) {
|
34
|
+
if ((p.length === 32) !== xOnly)
|
35
|
+
return false;
|
36
|
+
try {
|
37
|
+
return !!necc.Point.fromHex(p);
|
38
|
+
}
|
39
|
+
catch (e) {
|
40
|
+
return false;
|
41
|
+
}
|
42
|
+
}
|
43
|
+
function toBigInt(b) {
|
44
|
+
return Buffer.from(b).readBigUint64BE();
|
45
|
+
}
|
46
|
+
const ecc = {
|
47
|
+
isPoint: (p) => isPoint(p, false),
|
48
|
+
isPrivate: (d) => necc.utils.isValidPrivateKey(d),
|
49
|
+
isXOnlyPoint: (p) => isPoint(p, true),
|
50
|
+
xOnlyPointAddTweak: (p, tweak) => throwToNull(() => {
|
51
|
+
const P = necc.utils.pointAddScalar(p, tweak, true);
|
52
|
+
const parity = P[0] % 2 === 1 ? 1 : 0;
|
53
|
+
return { parity, xOnlyPubkey: P.slice(1) };
|
54
|
+
}),
|
55
|
+
pointFromScalar: (sk, compressed) => throwToNull(() => necc.getPublicKey(sk, defaultTrue(compressed))),
|
56
|
+
pointCompress: (p, compressed) => {
|
57
|
+
return necc.Point.fromHex(p).toRawBytes(defaultTrue(compressed));
|
58
|
+
},
|
59
|
+
pointMultiply: (a, tweak, compressed) => throwToNull(() => necc.utils.pointMultiply(a, tweak, defaultTrue(compressed))),
|
60
|
+
pointAdd: (a, b, compressed) => throwToNull(() => {
|
61
|
+
const A = necc.Point.fromHex(a);
|
62
|
+
const B = necc.Point.fromHex(b);
|
63
|
+
return A.add(B).toRawBytes(defaultTrue(compressed));
|
64
|
+
}),
|
65
|
+
pointAddScalar: (p, tweak, compressed) => throwToNull(() => necc.utils.pointAddScalar(p, tweak, defaultTrue(compressed))),
|
66
|
+
privateAdd: (d, tweak) => throwToNull(() => {
|
67
|
+
const res = necc.utils.privateAdd(d, tweak);
|
68
|
+
// tiny-secp256k1 returns null rather than allowing a 0 private key to be returned
|
69
|
+
// ECPair.testEcc() requires that behavior.
|
70
|
+
if (res === null || res === void 0 ? void 0 : res.every((i) => i === 0))
|
71
|
+
return null;
|
72
|
+
return res;
|
73
|
+
}),
|
74
|
+
privateNegate: (d) => necc.utils.privateNegate(d),
|
75
|
+
sign: (h, d, e) => {
|
76
|
+
return necc.signSync(h, d, { der: false, extraEntropy: e });
|
77
|
+
},
|
78
|
+
signSchnorr: (h, d, e = Buffer.alloc(32, 0x00)) => {
|
79
|
+
return necc.schnorr.signSync(h, d, e);
|
80
|
+
},
|
81
|
+
verify: (h, Q, signature, strict) => {
|
82
|
+
return necc.verify(signature, h, Q, { strict });
|
83
|
+
},
|
84
|
+
verifySchnorr: (h, Q, signature) => {
|
85
|
+
return necc.schnorr.verifySync(signature, h, Q);
|
86
|
+
},
|
87
|
+
};
|
88
|
+
exports.ecc = ecc;
|
89
|
+
const crypto = {
|
90
|
+
...baseCrypto,
|
91
|
+
pointMultiplyUnsafe(p, a, compress) {
|
92
|
+
try {
|
93
|
+
const product = necc.Point.fromHex(p).multiplyAndAddUnsafe(necc.Point.ZERO, toBigInt(a), BigInt(1));
|
94
|
+
if (!product)
|
95
|
+
return null;
|
96
|
+
return product.toRawBytes(compress);
|
97
|
+
}
|
98
|
+
catch {
|
99
|
+
return null;
|
100
|
+
}
|
101
|
+
},
|
102
|
+
pointMultiplyAndAddUnsafe(p1, a, p2, compress) {
|
103
|
+
try {
|
104
|
+
const p2p = necc.Point.fromHex(p2);
|
105
|
+
const p = necc.Point.fromHex(p1).multiplyAndAddUnsafe(p2p, toBigInt(a), BigInt(1));
|
106
|
+
if (!p)
|
107
|
+
return null;
|
108
|
+
return p.toRawBytes(compress);
|
109
|
+
}
|
110
|
+
catch {
|
111
|
+
return null;
|
112
|
+
}
|
113
|
+
},
|
114
|
+
pointAdd(a, b, compress) {
|
115
|
+
try {
|
116
|
+
return necc.Point.fromHex(a).add(necc.Point.fromHex(b)).toRawBytes(compress);
|
117
|
+
}
|
118
|
+
catch {
|
119
|
+
return null;
|
120
|
+
}
|
121
|
+
},
|
122
|
+
pointAddTweak(p, tweak, compress) {
|
123
|
+
try {
|
124
|
+
const P = necc.Point.fromHex(p);
|
125
|
+
const t = baseCrypto.readSecret(tweak);
|
126
|
+
const Q = necc.Point.BASE.multiplyAndAddUnsafe(P, t, BigInt(1));
|
127
|
+
if (!Q)
|
128
|
+
throw new Error('Tweaked point at infinity');
|
129
|
+
return Q.toRawBytes(compress);
|
130
|
+
}
|
131
|
+
catch {
|
132
|
+
return null;
|
133
|
+
}
|
134
|
+
},
|
135
|
+
pointCompress(p, compress = true) {
|
136
|
+
return necc.Point.fromHex(p).toRawBytes(compress);
|
137
|
+
},
|
138
|
+
liftX(p) {
|
139
|
+
try {
|
140
|
+
return necc.Point.fromHex(p).toRawBytes(false);
|
141
|
+
}
|
142
|
+
catch {
|
143
|
+
return null;
|
144
|
+
}
|
145
|
+
},
|
146
|
+
getPublicKey(s, compress) {
|
147
|
+
try {
|
148
|
+
return necc.getPublicKey(s, compress);
|
149
|
+
}
|
150
|
+
catch {
|
151
|
+
return null;
|
152
|
+
}
|
153
|
+
},
|
154
|
+
taggedHash: necc.utils.taggedHashSync,
|
155
|
+
sha256(...messages) {
|
156
|
+
const sha256 = createHash('sha256');
|
157
|
+
for (const message of messages)
|
158
|
+
sha256.update(message);
|
159
|
+
return sha256.digest();
|
160
|
+
},
|
161
|
+
};
|
162
|
+
const ECPair = ecpair_1.ECPairFactory(ecc);
|
163
|
+
exports.ECPair = ECPair;
|
164
|
+
const bip32 = bip32_1.BIP32Factory(ecc);
|
165
|
+
exports.bip32 = bip32;
|
166
|
+
const musig = musig_1.MuSigFactory(crypto);
|
167
|
+
exports.musig = musig;
|
168
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"noble_ecc.js","sourceRoot":"","sources":["../../src/noble_ecc.ts"],"names":[],"mappings":"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","sourcesContent":["import * as createHash from 'create-hash';\nimport * as createHmac from 'create-hmac';\nimport { ECPairAPI, ECPairFactory, ECPairInterface } from 'ecpair';\nimport * as necc from '@noble/secp256k1';\nimport { BIP32API, BIP32Factory, BIP32Interface } from 'bip32';\n// eslint-disable-next-line @typescript-eslint/ban-ts-comment\n// @ts-ignore base_crypto is exported as a subPath export, ignoring since compiler complains about importing like this\nimport * as baseCrypto from '@brandonblack/musig/base_crypto';\nimport { MuSig, MuSigFactory } from '@brandonblack/musig';\n\nnecc.utils.sha256Sync = (...messages: Uint8Array[]): Uint8Array => {\n  const sha256 = createHash('sha256');\n  for (const message of messages) sha256.update(message);\n  return sha256.digest();\n};\n\nnecc.utils.hmacSha256Sync = (key: Uint8Array, ...messages: Uint8Array[]): Uint8Array => {\n  const hash = createHmac('sha256', Buffer.from(key));\n  messages.forEach((m) => hash.update(m));\n  return Uint8Array.from(hash.digest());\n};\n\nconst defaultTrue = (param?: boolean): boolean => param !== false;\n\nfunction throwToNull<Type>(fn: () => Type): Type | null {\n  try {\n    return fn();\n  } catch (e) {\n    return null;\n  }\n}\n\nfunction isPoint(p: Uint8Array, xOnly: boolean): boolean {\n  if ((p.length === 32) !== xOnly) return false;\n  try {\n    return !!necc.Point.fromHex(p);\n  } catch (e) {\n    return false;\n  }\n}\n\nfunction toBigInt(b: Uint8Array | Buffer): bigint {\n  return Buffer.from(b).readBigUint64BE();\n}\n\nconst ecc = {\n  isPoint: (p: Uint8Array): boolean => isPoint(p, false),\n  isPrivate: (d: Uint8Array): boolean => necc.utils.isValidPrivateKey(d),\n  isXOnlyPoint: (p: Uint8Array): boolean => isPoint(p, true),\n\n  xOnlyPointAddTweak: (p: Uint8Array, tweak: Uint8Array): { parity: 0 | 1; xOnlyPubkey: Uint8Array } | null =>\n    throwToNull(() => {\n      const P = necc.utils.pointAddScalar(p, tweak, true);\n      const parity = P[0] % 2 === 1 ? 1 : 0;\n      return { parity, xOnlyPubkey: P.slice(1) };\n    }),\n\n  pointFromScalar: (sk: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.getPublicKey(sk, defaultTrue(compressed))),\n\n  pointCompress: (p: Uint8Array, compressed?: boolean): Uint8Array => {\n    return necc.Point.fromHex(p).toRawBytes(defaultTrue(compressed));\n  },\n\n  pointMultiply: (a: Uint8Array, tweak: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.utils.pointMultiply(a, tweak, defaultTrue(compressed))),\n\n  pointAdd: (a: Uint8Array, b: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => {\n      const A = necc.Point.fromHex(a);\n      const B = necc.Point.fromHex(b);\n      return A.add(B).toRawBytes(defaultTrue(compressed));\n    }),\n\n  pointAddScalar: (p: Uint8Array, tweak: Uint8Array, compressed?: boolean): Uint8Array | null =>\n    throwToNull(() => necc.utils.pointAddScalar(p, tweak, defaultTrue(compressed))),\n\n  privateAdd: (d: Uint8Array, tweak: Uint8Array): Uint8Array | null =>\n    throwToNull(() => {\n      const res = necc.utils.privateAdd(d, tweak);\n      // tiny-secp256k1 returns null rather than allowing a 0 private key to be returned\n      // ECPair.testEcc() requires that behavior.\n      if (res?.every((i) => i === 0)) return null;\n      return res;\n    }),\n\n  privateNegate: (d: Uint8Array): Uint8Array => necc.utils.privateNegate(d),\n\n  sign: (h: Uint8Array, d: Uint8Array, e?: Uint8Array): Uint8Array => {\n    return necc.signSync(h, d, { der: false, extraEntropy: e });\n  },\n\n  signSchnorr: (h: Uint8Array, d: Uint8Array, e: Uint8Array = Buffer.alloc(32, 0x00)): Uint8Array => {\n    return necc.schnorr.signSync(h, d, e);\n  },\n\n  verify: (h: Uint8Array, Q: Uint8Array, signature: Uint8Array, strict?: boolean): boolean => {\n    return necc.verify(signature, h, Q, { strict });\n  },\n\n  verifySchnorr: (h: Uint8Array, Q: Uint8Array, signature: Uint8Array): boolean => {\n    return necc.schnorr.verifySync(signature, h, Q);\n  },\n};\n\nconst crypto = {\n  ...baseCrypto,\n  pointMultiplyUnsafe(p: Uint8Array, a: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const product = necc.Point.fromHex(p).multiplyAndAddUnsafe(necc.Point.ZERO, toBigInt(a), BigInt(1));\n      if (!product) return null;\n      return product.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointMultiplyAndAddUnsafe(p1: Uint8Array, a: Uint8Array, p2: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const p2p = necc.Point.fromHex(p2);\n      const p = necc.Point.fromHex(p1).multiplyAndAddUnsafe(p2p, toBigInt(a), BigInt(1));\n      if (!p) return null;\n      return p.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointAdd(a: Uint8Array, b: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      return necc.Point.fromHex(a).add(necc.Point.fromHex(b)).toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointAddTweak(p: Uint8Array, tweak: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      const P = necc.Point.fromHex(p);\n      const t = baseCrypto.readSecret(tweak);\n      const Q = necc.Point.BASE.multiplyAndAddUnsafe(P, t, BigInt(1));\n      if (!Q) throw new Error('Tweaked point at infinity');\n      return Q.toRawBytes(compress);\n    } catch {\n      return null;\n    }\n  },\n  pointCompress(p: Uint8Array, compress = true): Uint8Array {\n    return necc.Point.fromHex(p).toRawBytes(compress);\n  },\n  liftX(p: Uint8Array): Uint8Array | null {\n    try {\n      return necc.Point.fromHex(p).toRawBytes(false);\n    } catch {\n      return null;\n    }\n  },\n  getPublicKey(s: Uint8Array, compress: boolean): Uint8Array | null {\n    try {\n      return necc.getPublicKey(s, compress);\n    } catch {\n      return null;\n    }\n  },\n  taggedHash: necc.utils.taggedHashSync,\n  sha256(...messages: Uint8Array[]): Uint8Array {\n    const sha256 = createHash('sha256');\n    for (const message of messages) sha256.update(message);\n    return sha256.digest();\n  },\n};\n\nconst ECPair: ECPairAPI = ECPairFactory(ecc);\nconst bip32: BIP32API = BIP32Factory(ecc);\nconst musig: MuSig = MuSigFactory(crypto);\n\nexport { ecc, ECPair, ECPairAPI, ECPairInterface, bip32, BIP32API, BIP32Interface, musig, MuSig };\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/payments/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACpC,OAAO,EAAE,IAAI,EAAE,MAAM,QAAQ,CAAC;AAE9B,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC"}
|
@@ -0,0 +1,8 @@
|
|
1
|
+
"use strict";
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
3
|
+
exports.p2tr = exports.p2tr_ns = void 0;
|
4
|
+
const p2tr_ns_1 = require("./p2tr_ns");
|
5
|
+
Object.defineProperty(exports, "p2tr_ns", { enumerable: true, get: function () { return p2tr_ns_1.p2tr_ns; } });
|
6
|
+
const p2tr_1 = require("./p2tr");
|
7
|
+
Object.defineProperty(exports, "p2tr", { enumerable: true, get: function () { return p2tr_1.p2tr; } });
|
8
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvcGF5bWVudHMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7O0FBQUEsdUNBQW9DO0FBRzNCLHdGQUhBLGlCQUFPLE9BR0E7QUFGaEIsaUNBQThCO0FBRVoscUZBRlQsV0FBSSxPQUVTIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgcDJ0cl9ucyB9IGZyb20gJy4vcDJ0cl9ucyc7XG5pbXBvcnQgeyBwMnRyIH0gZnJvbSAnLi9wMnRyJztcblxuZXhwb3J0IHsgcDJ0cl9ucywgcDJ0ciB9O1xuIl19
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"p2tr.d.ts","sourceRoot":"","sources":["../../../src/payments/p2tr.ts"],"names":[],"mappings":"AAIA,OAAO,EAAqB,OAAO,EAAE,WAAW,EAAQ,MAAM,eAAe,CAAC;AAgC9E,wBAAgB,IAAI,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,WAAW,GAAG,OAAO,CAwU5D"}
|
@@ -0,0 +1,348 @@
|
|
1
|
+
"use strict";
|
2
|
+
// SegWit version 1 P2TR output type for Taproot defined in
|
3
|
+
// https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki
|
4
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
5
|
+
exports.p2tr = void 0;
|
6
|
+
const networks_1 = require("../networks");
|
7
|
+
const bitcoinjs_lib_1 = require("bitcoinjs-lib");
|
8
|
+
const taproot = require("../taproot");
|
9
|
+
const noble_ecc_1 = require("../noble_ecc");
|
10
|
+
const necc = require("@noble/secp256k1");
|
11
|
+
const typef = require('typeforce');
|
12
|
+
const OPS = bitcoinjs_lib_1.script.OPS;
|
13
|
+
const { bech32m } = require('bech32');
|
14
|
+
const BITCOIN_NETWORK = networks_1.networks.bitcoin;
|
15
|
+
/**
|
16
|
+
* A secp256k1 x coordinate with unknown discrete logarithm used for eliminating
|
17
|
+
* keypath spends, equal to SHA256(uncompressedDER(SECP256K1_GENERATOR_POINT)).
|
18
|
+
*/
|
19
|
+
const H = Buffer.from('50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0', 'hex');
|
20
|
+
const EMPTY_BUFFER = Buffer.alloc(0);
|
21
|
+
function isPlainPubkey(pubKey) {
|
22
|
+
if (pubKey.length !== 33)
|
23
|
+
return false;
|
24
|
+
try {
|
25
|
+
return !!necc.Point.fromHex(pubKey);
|
26
|
+
}
|
27
|
+
catch (e) {
|
28
|
+
return false;
|
29
|
+
}
|
30
|
+
}
|
31
|
+
function isPlainPubkeys(pubkeys) {
|
32
|
+
return pubkeys.every(isPlainPubkey);
|
33
|
+
}
|
34
|
+
// output: OP_1 {witnessProgram}
|
35
|
+
function p2tr(a, opts) {
|
36
|
+
var _a, _b, _c, _d;
|
37
|
+
if (!a.address && !a.pubkey && !a.pubkeys && !(a.redeems && a.redeems.length) && !a.output && !a.witness) {
|
38
|
+
throw new TypeError('Not enough data');
|
39
|
+
}
|
40
|
+
opts = Object.assign({ validate: true }, opts || {});
|
41
|
+
if (!opts.eccLib)
|
42
|
+
throw new Error('ECC Library is required for p2tr.');
|
43
|
+
const ecc = opts.eccLib;
|
44
|
+
typef({
|
45
|
+
network: typef.maybe(typef.Object),
|
46
|
+
address: typef.maybe(typef.String),
|
47
|
+
// the output script should be a fixed 34 bytes.
|
48
|
+
// 1 byte for OP_1 indicating segwit version 1, one byte for 0x20 to push
|
49
|
+
// the next 32 bytes, followed by the 32 byte witness program
|
50
|
+
output: typef.maybe(typef.BufferN(34)),
|
51
|
+
// a single pubkey
|
52
|
+
pubkey: typef.maybe(ecc.isXOnlyPoint),
|
53
|
+
// the pub key(s) used for keypath signing.
|
54
|
+
// aggregated with MuSig2* if > 1
|
55
|
+
pubkeys: typef.maybe(typef.anyOf(typef.arrayOf(ecc.isXOnlyPoint), typef.arrayOf(isPlainPubkey))),
|
56
|
+
redeems: typef.maybe(typef.arrayOf({
|
57
|
+
network: typef.maybe(typef.Object),
|
58
|
+
output: typef.maybe(typef.Buffer),
|
59
|
+
weight: typef.maybe(typef.Number),
|
60
|
+
depth: typef.maybe(typef.Number),
|
61
|
+
witness: typef.maybe(typef.arrayOf(typef.Buffer)),
|
62
|
+
})),
|
63
|
+
redeemIndex: typef.maybe(typef.Number),
|
64
|
+
signature: typef.maybe(bitcoinjs_lib_1.script.isCanonicalSchnorrSignature),
|
65
|
+
controlBlock: typef.maybe(typef.Buffer),
|
66
|
+
annex: typef.maybe(typef.Buffer),
|
67
|
+
}, a);
|
68
|
+
const _address = bitcoinjs_lib_1.lazy.value(() => {
|
69
|
+
if (!a.address)
|
70
|
+
return undefined;
|
71
|
+
const result = bech32m.decode(a.address);
|
72
|
+
const version = result.words.shift();
|
73
|
+
const data = bech32m.fromWords(result.words);
|
74
|
+
return {
|
75
|
+
version,
|
76
|
+
prefix: result.prefix,
|
77
|
+
data: Buffer.from(data),
|
78
|
+
};
|
79
|
+
});
|
80
|
+
const _outputPubkey = bitcoinjs_lib_1.lazy.value(() => {
|
81
|
+
// we remove the first two bytes (OP_1 0x20) from the output script to
|
82
|
+
// extract the 32 byte taproot pubkey (aka witness program)
|
83
|
+
return a.output && a.output.slice(2);
|
84
|
+
});
|
85
|
+
const network = a.network || BITCOIN_NETWORK;
|
86
|
+
const o = { network };
|
87
|
+
const _taprootPaths = bitcoinjs_lib_1.lazy.value(() => {
|
88
|
+
if (!a.redeems)
|
89
|
+
return;
|
90
|
+
if (o.tapTree) {
|
91
|
+
return taproot.getDepthFirstTaptree(o.tapTree);
|
92
|
+
}
|
93
|
+
const outputs = a.redeems.map(({ output }) => output);
|
94
|
+
if (!outputs.every((output) => output))
|
95
|
+
return;
|
96
|
+
return taproot.getHuffmanTaptree(outputs, a.redeems.map(({ weight }) => weight));
|
97
|
+
});
|
98
|
+
const _parsedWitness = bitcoinjs_lib_1.lazy.value(() => {
|
99
|
+
if (!a.witness)
|
100
|
+
return;
|
101
|
+
return taproot.parseTaprootWitness(a.witness);
|
102
|
+
});
|
103
|
+
const _parsedControlBlock = bitcoinjs_lib_1.lazy.value(() => {
|
104
|
+
// Can't use o.controlBlock, because it could be circular
|
105
|
+
if (a.controlBlock)
|
106
|
+
return taproot.parseControlBlock(ecc, a.controlBlock);
|
107
|
+
const parsedWitness = _parsedWitness();
|
108
|
+
if (parsedWitness && parsedWitness.spendType === 'Script') {
|
109
|
+
return taproot.parseControlBlock(ecc, parsedWitness.controlBlock);
|
110
|
+
}
|
111
|
+
});
|
112
|
+
bitcoinjs_lib_1.lazy.prop(o, 'internalPubkey', () => {
|
113
|
+
var _a;
|
114
|
+
if (a.pubkey) {
|
115
|
+
// single pubkey
|
116
|
+
return a.pubkey;
|
117
|
+
}
|
118
|
+
else if (a.pubkeys && a.pubkeys.length === 1) {
|
119
|
+
return a.pubkeys[0];
|
120
|
+
}
|
121
|
+
else if (a.pubkeys && a.pubkeys.length > 1) {
|
122
|
+
// multiple pubkeys
|
123
|
+
if (isPlainPubkeys(a.pubkeys)) {
|
124
|
+
return Buffer.from(noble_ecc_1.musig.getXOnlyPubkey(noble_ecc_1.musig.keyAgg(noble_ecc_1.musig.keySort(a.pubkeys))));
|
125
|
+
}
|
126
|
+
return Buffer.from(taproot.aggregateMuSigPubkeys(ecc, a.pubkeys));
|
127
|
+
}
|
128
|
+
else if (_parsedControlBlock()) {
|
129
|
+
return (_a = _parsedControlBlock()) === null || _a === void 0 ? void 0 : _a.internalPubkey;
|
130
|
+
}
|
131
|
+
else {
|
132
|
+
// If there is no key path spending condition, we use an internal key with unknown secret key.
|
133
|
+
// TODO: In order to avoid leaking the information that key path spending is not possible it
|
134
|
+
// is recommended to pick a fresh integer r in the range 0...n-1 uniformly at random and use
|
135
|
+
// H + rG as internal key. It is possible to prove that this internal key does not have a
|
136
|
+
// known discrete logarithm with respect to G by revealing r to a verifier who can then
|
137
|
+
// reconstruct how the internal key was created.
|
138
|
+
return H;
|
139
|
+
}
|
140
|
+
});
|
141
|
+
const _taprootPubkey = bitcoinjs_lib_1.lazy.value(() => {
|
142
|
+
var _a;
|
143
|
+
const parsedControlBlock = _parsedControlBlock();
|
144
|
+
const parsedWitness = _parsedWitness();
|
145
|
+
// Refuse to create an unspendable key
|
146
|
+
if (!a.pubkey && !(a.pubkeys && a.pubkeys.length) && !a.redeems && !parsedControlBlock) {
|
147
|
+
return;
|
148
|
+
}
|
149
|
+
let taptreeRoot;
|
150
|
+
// Prefer to get the root via the control block because not all redeems may
|
151
|
+
// be available
|
152
|
+
if (parsedControlBlock) {
|
153
|
+
let tapscript;
|
154
|
+
if (parsedWitness && parsedWitness.spendType === 'Script') {
|
155
|
+
tapscript = parsedWitness.tapscript;
|
156
|
+
}
|
157
|
+
else if (o.redeem && o.redeem.output) {
|
158
|
+
tapscript = o.redeem.output;
|
159
|
+
}
|
160
|
+
if (tapscript)
|
161
|
+
taptreeRoot = taproot.getTaptreeRoot(ecc, parsedControlBlock, tapscript);
|
162
|
+
}
|
163
|
+
if (!taptreeRoot && _taprootPaths())
|
164
|
+
taptreeRoot = (_a = _taprootPaths()) === null || _a === void 0 ? void 0 : _a.root;
|
165
|
+
return taproot.tapTweakPubkey(ecc, o === null || o === void 0 ? void 0 : o.internalPubkey, taptreeRoot);
|
166
|
+
});
|
167
|
+
bitcoinjs_lib_1.lazy.prop(o, 'tapTree', () => {
|
168
|
+
if (!a.redeems)
|
169
|
+
return;
|
170
|
+
if (a.redeems.find(({ depth }) => depth === undefined)) {
|
171
|
+
console.warn('Deprecation Warning: Weight-based tap tree construction will be removed in the future. ' +
|
172
|
+
'Please use depth-first coding as specified in BIP-0371.');
|
173
|
+
return;
|
174
|
+
}
|
175
|
+
if (!a.redeems.every(({ output }) => output))
|
176
|
+
return;
|
177
|
+
return {
|
178
|
+
leaves: a.redeems.map(({ output, depth }) => {
|
179
|
+
return {
|
180
|
+
script: output,
|
181
|
+
leafVersion: taproot.INITIAL_TAPSCRIPT_VERSION,
|
182
|
+
depth,
|
183
|
+
};
|
184
|
+
}),
|
185
|
+
};
|
186
|
+
});
|
187
|
+
bitcoinjs_lib_1.lazy.prop(o, 'address', () => {
|
188
|
+
var _a;
|
189
|
+
const pubkey = _outputPubkey() || (_taprootPubkey() && ((_a = _taprootPubkey()) === null || _a === void 0 ? void 0 : _a.xOnlyPubkey));
|
190
|
+
// only encode the 32 byte witness program as bech32m
|
191
|
+
const words = bech32m.toWords(pubkey);
|
192
|
+
words.unshift(0x01);
|
193
|
+
return bech32m.encode(network.bech32, words);
|
194
|
+
});
|
195
|
+
bitcoinjs_lib_1.lazy.prop(o, 'controlBlock', () => {
|
196
|
+
const parsedWitness = _parsedWitness();
|
197
|
+
if (parsedWitness && parsedWitness.spendType === 'Script') {
|
198
|
+
return parsedWitness.controlBlock;
|
199
|
+
}
|
200
|
+
const taprootPubkey = _taprootPubkey();
|
201
|
+
const taprootPaths = _taprootPaths();
|
202
|
+
if (!taprootPaths || !taprootPubkey || a.redeemIndex === undefined)
|
203
|
+
return;
|
204
|
+
return taproot.getControlBlock(taprootPubkey.parity, o.internalPubkey, taprootPaths.paths[a.redeemIndex]);
|
205
|
+
});
|
206
|
+
bitcoinjs_lib_1.lazy.prop(o, 'signature', () => {
|
207
|
+
const parsedWitness = _parsedWitness();
|
208
|
+
if (parsedWitness && parsedWitness.spendType === 'Key') {
|
209
|
+
return parsedWitness.signature;
|
210
|
+
}
|
211
|
+
});
|
212
|
+
bitcoinjs_lib_1.lazy.prop(o, 'annex', () => {
|
213
|
+
if (!_parsedWitness())
|
214
|
+
return;
|
215
|
+
return _parsedWitness().annex;
|
216
|
+
});
|
217
|
+
bitcoinjs_lib_1.lazy.prop(o, 'output', () => {
|
218
|
+
if (a.address) {
|
219
|
+
const { data } = _address();
|
220
|
+
return bitcoinjs_lib_1.script.compile([OPS.OP_1, data]);
|
221
|
+
}
|
222
|
+
const taprootPubkey = _taprootPubkey();
|
223
|
+
if (!taprootPubkey)
|
224
|
+
return;
|
225
|
+
// OP_1 indicates segwit version 1
|
226
|
+
return bitcoinjs_lib_1.script.compile([OPS.OP_1, Buffer.from(taprootPubkey.xOnlyPubkey)]);
|
227
|
+
});
|
228
|
+
bitcoinjs_lib_1.lazy.prop(o, 'witness', () => {
|
229
|
+
if (!a.redeems) {
|
230
|
+
if (a.signature)
|
231
|
+
return [a.signature]; // Keypath spend
|
232
|
+
return;
|
233
|
+
}
|
234
|
+
else if (!o.redeem) {
|
235
|
+
return; // No chosen redeem script, can't make witness
|
236
|
+
}
|
237
|
+
else if (!o.controlBlock) {
|
238
|
+
return;
|
239
|
+
}
|
240
|
+
let redeemWitness;
|
241
|
+
// some callers may provide witness elements in the input script
|
242
|
+
if (o.redeem.input && o.redeem.input.length > 0 && o.redeem.output && o.redeem.output.length > 0) {
|
243
|
+
// transform redeem input to witness stack
|
244
|
+
redeemWitness = bitcoinjs_lib_1.script.toStack(bitcoinjs_lib_1.script.decompile(o.redeem.input));
|
245
|
+
// assigns a new object to o.redeem
|
246
|
+
o.redeems[a.redeemIndex] = Object.assign({ witness: redeemWitness }, o.redeem);
|
247
|
+
o.redeem.input = EMPTY_BUFFER;
|
248
|
+
}
|
249
|
+
else if (o.redeem.output && o.redeem.output.length > 0 && o.redeem.witness && o.redeem.witness.length > 0) {
|
250
|
+
redeemWitness = o.redeem.witness;
|
251
|
+
}
|
252
|
+
else {
|
253
|
+
return;
|
254
|
+
}
|
255
|
+
const witness = [...redeemWitness, o.redeem.output, o.controlBlock];
|
256
|
+
if (a.annex) {
|
257
|
+
witness.push(a.annex);
|
258
|
+
}
|
259
|
+
return witness;
|
260
|
+
});
|
261
|
+
bitcoinjs_lib_1.lazy.prop(o, 'name', () => {
|
262
|
+
const nameParts = ['p2tr'];
|
263
|
+
return nameParts.join('-');
|
264
|
+
});
|
265
|
+
bitcoinjs_lib_1.lazy.prop(o, 'redeem', () => {
|
266
|
+
if (a.redeems) {
|
267
|
+
if (a.redeemIndex === undefined)
|
268
|
+
return;
|
269
|
+
return a.redeems[a.redeemIndex];
|
270
|
+
}
|
271
|
+
const parsedWitness = _parsedWitness();
|
272
|
+
if (parsedWitness && parsedWitness.spendType === 'Script') {
|
273
|
+
return {
|
274
|
+
witness: parsedWitness.scriptSig,
|
275
|
+
output: parsedWitness.tapscript,
|
276
|
+
};
|
277
|
+
}
|
278
|
+
});
|
279
|
+
// extended validation
|
280
|
+
if (opts.validate) {
|
281
|
+
const taprootPubkey = _taprootPubkey();
|
282
|
+
if (a.output) {
|
283
|
+
if (a.output[0] !== OPS.OP_1 || a.output[1] !== 0x20) {
|
284
|
+
throw new TypeError('Output is invalid');
|
285
|
+
}
|
286
|
+
// if we're passed both an output script and an address, ensure they match
|
287
|
+
if (a.address && _outputPubkey && !((_a = _outputPubkey()) === null || _a === void 0 ? void 0 : _a.equals((_b = _address()) === null || _b === void 0 ? void 0 : _b.data))) {
|
288
|
+
throw new TypeError('mismatch between address & output');
|
289
|
+
}
|
290
|
+
if (taprootPubkey && _outputPubkey && !((_c = _outputPubkey()) === null || _c === void 0 ? void 0 : _c.equals(taprootPubkey.xOnlyPubkey))) {
|
291
|
+
throw new TypeError('mismatch between output and taproot pubkey');
|
292
|
+
}
|
293
|
+
}
|
294
|
+
if (a.address) {
|
295
|
+
if (taprootPubkey && !((_d = _address()) === null || _d === void 0 ? void 0 : _d.data.equals(taprootPubkey.xOnlyPubkey))) {
|
296
|
+
throw new TypeError('mismatch between address and taproot pubkey');
|
297
|
+
}
|
298
|
+
}
|
299
|
+
const parsedControlBlock = _parsedControlBlock();
|
300
|
+
if (parsedControlBlock) {
|
301
|
+
if (!parsedControlBlock.internalPubkey.equals(o === null || o === void 0 ? void 0 : o.internalPubkey)) {
|
302
|
+
throw new TypeError('Internal pubkey mismatch');
|
303
|
+
}
|
304
|
+
if (taprootPubkey && parsedControlBlock.parity !== taprootPubkey.parity) {
|
305
|
+
throw new TypeError('Parity mismatch');
|
306
|
+
}
|
307
|
+
}
|
308
|
+
if (a.redeems) {
|
309
|
+
if (!a.redeems.length)
|
310
|
+
throw new TypeError('Empty redeems');
|
311
|
+
if (a.redeemIndex !== undefined && (a.redeemIndex < 0 || a.redeemIndex >= a.redeems.length)) {
|
312
|
+
throw new TypeError('invalid redeem index');
|
313
|
+
}
|
314
|
+
a.redeems.forEach((redeem) => {
|
315
|
+
if (redeem.network && redeem.network !== network) {
|
316
|
+
throw new TypeError('Network mismatch');
|
317
|
+
}
|
318
|
+
});
|
319
|
+
}
|
320
|
+
const chosenRedeem = a.redeems && a.redeemIndex !== undefined && a.redeems[a.redeemIndex];
|
321
|
+
const parsedWitness = _parsedWitness();
|
322
|
+
if (parsedWitness && parsedWitness.spendType === 'Key') {
|
323
|
+
if (a.controlBlock) {
|
324
|
+
throw new TypeError('unexpected control block for key path');
|
325
|
+
}
|
326
|
+
if (a.signature && !a.signature.equals(parsedWitness.signature)) {
|
327
|
+
throw new TypeError('mismatch between witness & signature');
|
328
|
+
}
|
329
|
+
}
|
330
|
+
if (parsedWitness && parsedWitness.spendType === 'Script') {
|
331
|
+
if (a.signature) {
|
332
|
+
throw new TypeError('unexpected signature with script path witness');
|
333
|
+
}
|
334
|
+
if (a.controlBlock && !a.controlBlock.equals(parsedWitness.controlBlock)) {
|
335
|
+
throw new TypeError('control block mismatch');
|
336
|
+
}
|
337
|
+
if (a.annex && parsedWitness.annex && !a.annex.equals(parsedWitness.annex)) {
|
338
|
+
throw new TypeError('annex mismatch');
|
339
|
+
}
|
340
|
+
if (chosenRedeem && chosenRedeem.output && !chosenRedeem.output.equals(parsedWitness.tapscript)) {
|
341
|
+
throw new TypeError('tapscript mismatch');
|
342
|
+
}
|
343
|
+
}
|
344
|
+
}
|
345
|
+
return Object.assign(o, a);
|
346
|
+
}
|
347
|
+
exports.p2tr = p2tr;
|
348
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"p2tr.js","sourceRoot":"","sources":["../../../src/payments/p2tr.ts"],"names":[],"mappings":"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","sourcesContent":["// SegWit version 1 P2TR output type for Taproot defined in\n// https://github.com/bitcoin/bips/blob/master/bip-0341.mediawiki\n\nimport { networks } from '../networks';\nimport { script as bscript, Payment, PaymentOpts, lazy } from 'bitcoinjs-lib';\nimport * as taproot from '../taproot';\nimport { musig } from '../noble_ecc';\nimport * as necc from '@noble/secp256k1';\nconst typef = require('typeforce');\nconst OPS = bscript.OPS;\n\nconst { bech32m } = require('bech32');\n\nconst BITCOIN_NETWORK = networks.bitcoin;\n\n/**\n * A secp256k1 x coordinate with unknown discrete logarithm used for eliminating\n * keypath spends, equal to SHA256(uncompressedDER(SECP256K1_GENERATOR_POINT)).\n */\nconst H = Buffer.from('50929b74c1a04954b78b4b6035e97a5e078a5a0f28ec96d547bfee9ace803ac0', 'hex');\nconst EMPTY_BUFFER = Buffer.alloc(0);\n\nfunction isPlainPubkey(pubKey: Uint8Array): boolean {\n  if (pubKey.length !== 33) return false;\n  try {\n    return !!necc.Point.fromHex(pubKey);\n  } catch (e) {\n    return false;\n  }\n}\n\nfunction isPlainPubkeys(pubkeys: Buffer[]) {\n  return pubkeys.every(isPlainPubkey);\n}\n\n// output: OP_1 {witnessProgram}\nexport function p2tr(a: Payment, opts?: PaymentOpts): Payment {\n  if (!a.address && !a.pubkey && !a.pubkeys && !(a.redeems && a.redeems.length) && !a.output && !a.witness) {\n    throw new TypeError('Not enough data');\n  }\n  opts = Object.assign({ validate: true }, opts || {});\n\n  if (!opts.eccLib) throw new Error('ECC Library is required for p2tr.');\n  const ecc = opts.eccLib;\n\n  typef(\n    {\n      network: typef.maybe(typef.Object),\n\n      address: typef.maybe(typef.String),\n      // the output script should be a fixed 34 bytes.\n      // 1 byte for OP_1 indicating segwit version 1, one byte for 0x20 to push\n      // the next 32 bytes, followed by the 32 byte witness program\n      output: typef.maybe(typef.BufferN(34)),\n      // a single pubkey\n      pubkey: typef.maybe(ecc.isXOnlyPoint),\n      // the pub key(s) used for keypath signing.\n      // aggregated with MuSig2* if > 1\n      pubkeys: typef.maybe(typef.anyOf(typef.arrayOf(ecc.isXOnlyPoint), typef.arrayOf(isPlainPubkey))),\n\n      redeems: typef.maybe(\n        typef.arrayOf({\n          network: typef.maybe(typef.Object),\n          output: typef.maybe(typef.Buffer),\n          weight: typef.maybe(typef.Number),\n          depth: typef.maybe(typef.Number),\n          witness: typef.maybe(typef.arrayOf(typef.Buffer)),\n        })\n      ),\n      redeemIndex: typef.maybe(typef.Number), // Selects the redeem to spend\n\n      signature: typef.maybe(bscript.isCanonicalSchnorrSignature),\n      controlBlock: typef.maybe(typef.Buffer),\n      annex: typef.maybe(typef.Buffer),\n    },\n    a\n  );\n\n  const _address = lazy.value(() => {\n    if (!a.address) return undefined;\n\n    const result = bech32m.decode(a.address);\n    const version = result.words.shift();\n    const data = bech32m.fromWords(result.words);\n    return {\n      version,\n      prefix: result.prefix,\n      data: Buffer.from(data),\n    };\n  });\n  const _outputPubkey = lazy.value(() => {\n    // we remove the first two bytes (OP_1 0x20) from the output script to\n    // extract the 32 byte taproot pubkey (aka witness program)\n    return a.output && a.output.slice(2);\n  });\n\n  const network = a.network || BITCOIN_NETWORK;\n\n  const o: Payment = { network };\n\n  const _taprootPaths = lazy.value(() => {\n    if (!a.redeems) return;\n    if (o.tapTree) {\n      return taproot.getDepthFirstTaptree(o.tapTree);\n    }\n    const outputs: Array<Buffer | undefined> = a.redeems.map(({ output }) => output);\n    if (!outputs.every((output) => output)) return;\n    return taproot.getHuffmanTaptree(\n      outputs as Buffer[],\n      a.redeems.map(({ weight }) => weight)\n    );\n  });\n  const _parsedWitness = lazy.value(() => {\n    if (!a.witness) return;\n    return taproot.parseTaprootWitness(a.witness);\n  });\n  const _parsedControlBlock = lazy.value(() => {\n    // Can't use o.controlBlock, because it could be circular\n    if (a.controlBlock) return taproot.parseControlBlock(ecc, a.controlBlock);\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return taproot.parseControlBlock(ecc, parsedWitness.controlBlock);\n    }\n  });\n\n  lazy.prop(o, 'internalPubkey', () => {\n    if (a.pubkey) {\n      // single pubkey\n      return a.pubkey;\n    } else if (a.pubkeys && a.pubkeys.length === 1) {\n      return a.pubkeys[0];\n    } else if (a.pubkeys && a.pubkeys.length > 1) {\n      // multiple pubkeys\n      if (isPlainPubkeys(a.pubkeys)) {\n        return Buffer.from(musig.getXOnlyPubkey(musig.keyAgg(musig.keySort(a.pubkeys))));\n      }\n\n      return Buffer.from(taproot.aggregateMuSigPubkeys(ecc, a.pubkeys));\n    } else if (_parsedControlBlock()) {\n      return _parsedControlBlock()?.internalPubkey;\n    } else {\n      // If there is no key path spending condition, we use an internal key with unknown secret key.\n      // TODO: In order to avoid leaking the information that key path spending is not possible it\n      // is recommended to pick a fresh integer r in the range 0...n-1 uniformly at random and use\n      // H + rG as internal key. It is possible to prove that this internal key does not have a\n      // known discrete logarithm with respect to G by revealing r to a verifier who can then\n      // reconstruct how the internal key was created.\n      return H;\n    }\n  });\n\n  const _taprootPubkey = lazy.value(() => {\n    const parsedControlBlock = _parsedControlBlock();\n    const parsedWitness = _parsedWitness();\n    // Refuse to create an unspendable key\n    if (!a.pubkey && !(a.pubkeys && a.pubkeys.length) && !a.redeems && !parsedControlBlock) {\n      return;\n    }\n    let taptreeRoot;\n    // Prefer to get the root via the control block because not all redeems may\n    // be available\n    if (parsedControlBlock) {\n      let tapscript;\n      if (parsedWitness && parsedWitness.spendType === 'Script') {\n        tapscript = parsedWitness.tapscript;\n      } else if (o.redeem && o.redeem.output) {\n        tapscript = o.redeem.output;\n      }\n      if (tapscript) taptreeRoot = taproot.getTaptreeRoot(ecc, parsedControlBlock, tapscript);\n    }\n    if (!taptreeRoot && _taprootPaths()) taptreeRoot = _taprootPaths()?.root;\n\n    return taproot.tapTweakPubkey(ecc, o?.internalPubkey as Uint8Array, taptreeRoot);\n  });\n\n  lazy.prop(o, 'tapTree', () => {\n    if (!a.redeems) return;\n    if (a.redeems.find(({ depth }) => depth === undefined)) {\n      console.warn(\n        'Deprecation Warning: Weight-based tap tree construction will be removed in the future. ' +\n          'Please use depth-first coding as specified in BIP-0371.'\n      );\n      return;\n    }\n    if (!a.redeems.every(({ output }) => output)) return;\n    return {\n      leaves: a.redeems.map(({ output, depth }) => {\n        return {\n          script: output,\n          leafVersion: taproot.INITIAL_TAPSCRIPT_VERSION,\n          depth,\n        };\n      }),\n    };\n  });\n  lazy.prop(o, 'address', () => {\n    const pubkey = _outputPubkey() || (_taprootPubkey() && _taprootPubkey()?.xOnlyPubkey);\n    // only encode the 32 byte witness program as bech32m\n    const words = bech32m.toWords(pubkey);\n    words.unshift(0x01);\n    return bech32m.encode(network.bech32, words);\n  });\n  lazy.prop(o, 'controlBlock', () => {\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return parsedWitness.controlBlock;\n    }\n    const taprootPubkey = _taprootPubkey();\n    const taprootPaths = _taprootPaths();\n    if (!taprootPaths || !taprootPubkey || a.redeemIndex === undefined) return;\n    return taproot.getControlBlock(taprootPubkey.parity, o.internalPubkey!, taprootPaths.paths[a.redeemIndex]);\n  });\n  lazy.prop(o, 'signature', () => {\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Key') {\n      return parsedWitness.signature;\n    }\n  });\n  lazy.prop(o, 'annex', () => {\n    if (!_parsedWitness()) return;\n    return _parsedWitness()!.annex;\n  });\n  lazy.prop(o, 'output', () => {\n    if (a.address) {\n      const { data } = _address()!;\n      return bscript.compile([OPS.OP_1, data]);\n    }\n\n    const taprootPubkey = _taprootPubkey();\n    if (!taprootPubkey) return;\n\n    // OP_1 indicates segwit version 1\n    return bscript.compile([OPS.OP_1, Buffer.from(taprootPubkey.xOnlyPubkey)]);\n  });\n  lazy.prop(o, 'witness', () => {\n    if (!a.redeems) {\n      if (a.signature) return [a.signature]; // Keypath spend\n      return;\n    } else if (!o.redeem) {\n      return; // No chosen redeem script, can't make witness\n    } else if (!o.controlBlock) {\n      return;\n    }\n\n    let redeemWitness;\n    // some callers may provide witness elements in the input script\n    if (o.redeem.input && o.redeem.input.length > 0 && o.redeem.output && o.redeem.output.length > 0) {\n      // transform redeem input to witness stack\n      redeemWitness = bscript.toStack(bscript.decompile(o.redeem.input)!);\n\n      // assigns a new object to o.redeem\n      o.redeems![a.redeemIndex!] = Object.assign({ witness: redeemWitness }, o.redeem);\n      o.redeem.input = EMPTY_BUFFER;\n    } else if (o.redeem.output && o.redeem.output.length > 0 && o.redeem.witness && o.redeem.witness.length > 0) {\n      redeemWitness = o.redeem.witness;\n    } else {\n      return;\n    }\n\n    const witness = [...redeemWitness, o.redeem.output, o.controlBlock];\n\n    if (a.annex) {\n      witness.push(a.annex);\n    }\n\n    return witness;\n  });\n  lazy.prop(o, 'name', () => {\n    const nameParts = ['p2tr'];\n    return nameParts.join('-');\n  });\n  lazy.prop(o, 'redeem', () => {\n    if (a.redeems) {\n      if (a.redeemIndex === undefined) return;\n      return a.redeems[a.redeemIndex];\n    }\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      return {\n        witness: parsedWitness.scriptSig,\n        output: parsedWitness.tapscript,\n      };\n    }\n  });\n\n  // extended validation\n  if (opts.validate) {\n    const taprootPubkey = _taprootPubkey();\n\n    if (a.output) {\n      if (a.output[0] !== OPS.OP_1 || a.output[1] !== 0x20) {\n        throw new TypeError('Output is invalid');\n      }\n\n      // if we're passed both an output script and an address, ensure they match\n      if (a.address && _outputPubkey && !_outputPubkey()?.equals(_address()?.data as Buffer)) {\n        throw new TypeError('mismatch between address & output');\n      }\n\n      if (taprootPubkey && _outputPubkey && !_outputPubkey()?.equals(taprootPubkey.xOnlyPubkey)) {\n        throw new TypeError('mismatch between output and taproot pubkey');\n      }\n    }\n\n    if (a.address) {\n      if (taprootPubkey && !_address()?.data.equals(taprootPubkey.xOnlyPubkey)) {\n        throw new TypeError('mismatch between address and taproot pubkey');\n      }\n    }\n\n    const parsedControlBlock = _parsedControlBlock();\n    if (parsedControlBlock) {\n      if (!parsedControlBlock.internalPubkey.equals(o?.internalPubkey as Uint8Array)) {\n        throw new TypeError('Internal pubkey mismatch');\n      }\n      if (taprootPubkey && parsedControlBlock.parity !== taprootPubkey.parity) {\n        throw new TypeError('Parity mismatch');\n      }\n    }\n\n    if (a.redeems) {\n      if (!a.redeems.length) throw new TypeError('Empty redeems');\n      if (a.redeemIndex !== undefined && (a.redeemIndex < 0 || a.redeemIndex >= a.redeems.length)) {\n        throw new TypeError('invalid redeem index');\n      }\n      a.redeems.forEach((redeem) => {\n        if (redeem.network && redeem.network !== network) {\n          throw new TypeError('Network mismatch');\n        }\n      });\n    }\n\n    const chosenRedeem = a.redeems && a.redeemIndex !== undefined && a.redeems[a.redeemIndex];\n\n    const parsedWitness = _parsedWitness();\n    if (parsedWitness && parsedWitness.spendType === 'Key') {\n      if (a.controlBlock) {\n        throw new TypeError('unexpected control block for key path');\n      }\n\n      if (a.signature && !a.signature.equals(parsedWitness.signature)) {\n        throw new TypeError('mismatch between witness & signature');\n      }\n    }\n    if (parsedWitness && parsedWitness.spendType === 'Script') {\n      if (a.signature) {\n        throw new TypeError('unexpected signature with script path witness');\n      }\n\n      if (a.controlBlock && !a.controlBlock.equals(parsedWitness.controlBlock)) {\n        throw new TypeError('control block mismatch');\n      }\n\n      if (a.annex && parsedWitness.annex && !a.annex.equals(parsedWitness.annex)) {\n        throw new TypeError('annex mismatch');\n      }\n\n      if (chosenRedeem && chosenRedeem.output && !chosenRedeem.output.equals(parsedWitness.tapscript)) {\n        throw new TypeError('tapscript mismatch');\n      }\n    }\n  }\n\n  return Object.assign(o, a);\n}\n"]}
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"p2tr_ns.d.ts","sourceRoot":"","sources":["../../../src/payments/p2tr_ns.ts"],"names":[],"mappings":"AACA,OAAO,EAAqB,OAAO,EAAE,WAAW,EAAe,MAAM,eAAe,CAAC;AAiBrF,wBAAgB,OAAO,CAAC,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,EAAE,WAAW,GAAG,OAAO,CAgI/D"}
|