@bitgo-beta/abstract-utxo 1.6.1-alpha.425 → 1.6.1-alpha.427
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/dist/cjs/src/abstractUtxoCoin.d.ts +22 -5
- package/dist/cjs/src/abstractUtxoCoin.d.ts.map +1 -1
- package/dist/cjs/src/abstractUtxoCoin.js +53 -26
- package/dist/cjs/src/index.d.ts +2 -2
- package/dist/cjs/src/index.d.ts.map +1 -1
- package/dist/cjs/src/index.js +3 -3
- package/dist/cjs/src/recovery/backupKeyRecovery.js +4 -4
- package/dist/cjs/src/recovery/crossChainRecovery.d.ts +10 -0
- package/dist/cjs/src/recovery/crossChainRecovery.d.ts.map +1 -1
- package/dist/cjs/src/recovery/crossChainRecovery.js +48 -4
- package/dist/cjs/src/transaction/decode.d.ts +11 -0
- package/dist/cjs/src/transaction/decode.d.ts.map +1 -0
- package/dist/cjs/src/transaction/decode.js +81 -0
- package/dist/cjs/src/transaction/descriptor/verifyTransaction.d.ts.map +1 -1
- package/dist/cjs/src/transaction/descriptor/verifyTransaction.js +3 -2
- package/dist/cjs/src/transaction/explainTransaction.js +3 -3
- package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts +24 -0
- package/dist/cjs/src/transaction/fixedScript/SigningError.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/SigningError.js +26 -0
- package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts +1 -1
- package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -1
- package/dist/cjs/src/transaction/fixedScript/explainPsbtWasm.js +1 -1
- package/dist/cjs/src/transaction/fixedScript/explainTransaction.d.ts.map +1 -1
- package/dist/cjs/src/transaction/fixedScript/explainTransaction.js +2 -2
- package/dist/cjs/src/transaction/fixedScript/index.d.ts +3 -0
- package/dist/cjs/src/transaction/fixedScript/index.d.ts.map +1 -1
- package/dist/cjs/src/transaction/fixedScript/index.js +18 -1
- package/dist/cjs/src/transaction/fixedScript/musig2.d.ts +4 -0
- package/dist/cjs/src/transaction/fixedScript/musig2.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/musig2.js +3 -0
- package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts +7 -0
- package/dist/cjs/src/transaction/fixedScript/replayProtection.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/replayProtection.js +78 -0
- package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
- package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/signLegacyTransaction.js +152 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts +30 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbt.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbt.js +174 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
- package/dist/cjs/src/transaction/fixedScript/signPsbtWasm.js +129 -0
- package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts +5 -6
- package/dist/cjs/src/transaction/fixedScript/signTransaction.d.ts.map +1 -1
- package/dist/cjs/src/transaction/fixedScript/signTransaction.js +28 -79
- package/dist/cjs/src/transaction/fixedScript/verifyTransaction.d.ts.map +1 -1
- package/dist/cjs/src/transaction/fixedScript/verifyTransaction.js +3 -2
- package/dist/cjs/src/transaction/signTransaction.d.ts.map +1 -1
- package/dist/cjs/src/transaction/signTransaction.js +5 -2
- package/dist/cjs/src/transaction/types.d.ts +5 -0
- package/dist/cjs/src/transaction/types.d.ts.map +1 -1
- package/dist/cjs/src/transaction/types.js +5 -1
- package/dist/cjs/test/unit/recovery/crossChainRecovery.js +24 -1
- package/dist/cjs/test/unit/transaction/fixedScript/explainPsbt.js +3 -3
- package/dist/cjs/test/unit/transaction/fixedScript/parsePsbt.js +2 -2
- package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts +2 -0
- package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.d.ts.map +1 -0
- package/dist/cjs/test/unit/transaction/fixedScript/replayProtection.js +59 -0
- package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts +2 -0
- package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.d.ts.map +1 -0
- package/dist/cjs/test/unit/transaction/fixedScript/signPsbt.js +157 -0
- package/dist/cjs/test/unit/transaction/fixedScript/util.d.ts.map +1 -1
- package/dist/cjs/test/unit/transaction/fixedScript/util.js +2 -1
- package/dist/cjs/test/unit/transaction.js +65 -42
- package/dist/cjs/tsconfig.tsbuildinfo +1 -1
- package/dist/esm/abstractUtxoCoin.d.ts +22 -5
- package/dist/esm/abstractUtxoCoin.d.ts.map +1 -1
- package/dist/esm/abstractUtxoCoin.js +54 -27
- package/dist/esm/index.d.ts +2 -2
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +3 -3
- package/dist/esm/recovery/backupKeyRecovery.js +2 -2
- package/dist/esm/recovery/crossChainRecovery.d.ts +10 -0
- package/dist/esm/recovery/crossChainRecovery.d.ts.map +1 -1
- package/dist/esm/recovery/crossChainRecovery.js +46 -3
- package/dist/esm/transaction/decode.d.ts +11 -0
- package/dist/esm/transaction/decode.d.ts.map +1 -0
- package/dist/esm/transaction/decode.js +43 -0
- package/dist/esm/transaction/descriptor/verifyTransaction.d.ts.map +1 -1
- package/dist/esm/transaction/descriptor/verifyTransaction.js +3 -2
- package/dist/esm/transaction/explainTransaction.js +3 -3
- package/dist/esm/transaction/fixedScript/SigningError.d.ts +24 -0
- package/dist/esm/transaction/fixedScript/SigningError.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/SigningError.js +21 -0
- package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts +1 -1
- package/dist/esm/transaction/fixedScript/explainPsbtWasm.d.ts.map +1 -1
- package/dist/esm/transaction/fixedScript/explainPsbtWasm.js +1 -1
- package/dist/esm/transaction/fixedScript/explainTransaction.d.ts.map +1 -1
- package/dist/esm/transaction/fixedScript/explainTransaction.js +2 -2
- package/dist/esm/transaction/fixedScript/index.d.ts +3 -0
- package/dist/esm/transaction/fixedScript/index.d.ts.map +1 -1
- package/dist/esm/transaction/fixedScript/index.js +4 -1
- package/dist/esm/transaction/fixedScript/musig2.d.ts +4 -0
- package/dist/esm/transaction/fixedScript/musig2.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/musig2.js +2 -0
- package/dist/esm/transaction/fixedScript/replayProtection.d.ts +7 -0
- package/dist/esm/transaction/fixedScript/replayProtection.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/replayProtection.js +39 -0
- package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts +30 -0
- package/dist/esm/transaction/fixedScript/signLegacyTransaction.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/signLegacyTransaction.js +112 -0
- package/dist/esm/transaction/fixedScript/signPsbt.d.ts +30 -0
- package/dist/esm/transaction/fixedScript/signPsbt.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/signPsbt.js +134 -0
- package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts +22 -0
- package/dist/esm/transaction/fixedScript/signPsbtWasm.d.ts.map +1 -0
- package/dist/esm/transaction/fixedScript/signPsbtWasm.js +122 -0
- package/dist/esm/transaction/fixedScript/signTransaction.d.ts +5 -6
- package/dist/esm/transaction/fixedScript/signTransaction.d.ts.map +1 -1
- package/dist/esm/transaction/fixedScript/signTransaction.js +28 -79
- package/dist/esm/transaction/fixedScript/verifyTransaction.d.ts.map +1 -1
- package/dist/esm/transaction/fixedScript/verifyTransaction.js +3 -2
- package/dist/esm/transaction/signTransaction.d.ts.map +1 -1
- package/dist/esm/transaction/signTransaction.js +5 -2
- package/dist/esm/transaction/types.d.ts +5 -0
- package/dist/esm/transaction/types.d.ts.map +1 -1
- package/dist/esm/transaction/types.js +4 -2
- package/package.json +13 -13
- package/dist/cjs/src/replayProtection.d.ts +0 -5
- package/dist/cjs/src/replayProtection.d.ts.map +0 -1
- package/dist/cjs/src/replayProtection.js +0 -58
- package/dist/cjs/src/sign.d.ts +0 -54
- package/dist/cjs/src/sign.d.ts.map +0 -1
- package/dist/cjs/src/sign.js +0 -205
- package/dist/esm/replayProtection.d.ts +0 -5
- package/dist/esm/replayProtection.d.ts.map +0 -1
- package/dist/esm/replayProtection.js +0 -20
- package/dist/esm/sign.d.ts +0 -54
- package/dist/esm/sign.d.ts.map +0 -1
- package/dist/esm/sign.js +0 -162
|
@@ -0,0 +1,157 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
3
|
+
if (k2 === undefined) k2 = k;
|
|
4
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
5
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
6
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
7
|
+
}
|
|
8
|
+
Object.defineProperty(o, k2, desc);
|
|
9
|
+
}) : (function(o, m, k, k2) {
|
|
10
|
+
if (k2 === undefined) k2 = k;
|
|
11
|
+
o[k2] = m[k];
|
|
12
|
+
}));
|
|
13
|
+
var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
|
|
14
|
+
Object.defineProperty(o, "default", { enumerable: true, value: v });
|
|
15
|
+
}) : function(o, v) {
|
|
16
|
+
o["default"] = v;
|
|
17
|
+
});
|
|
18
|
+
var __importStar = (this && this.__importStar) || (function () {
|
|
19
|
+
var ownKeys = function(o) {
|
|
20
|
+
ownKeys = Object.getOwnPropertyNames || function (o) {
|
|
21
|
+
var ar = [];
|
|
22
|
+
for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
|
|
23
|
+
return ar;
|
|
24
|
+
};
|
|
25
|
+
return ownKeys(o);
|
|
26
|
+
};
|
|
27
|
+
return function (mod) {
|
|
28
|
+
if (mod && mod.__esModule) return mod;
|
|
29
|
+
var result = {};
|
|
30
|
+
if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
|
|
31
|
+
__setModuleDefault(result, mod);
|
|
32
|
+
return result;
|
|
33
|
+
};
|
|
34
|
+
})();
|
|
35
|
+
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
36
|
+
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
37
|
+
};
|
|
38
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
+
const strict_1 = __importDefault(require("node:assert/strict"));
|
|
40
|
+
const utxolib = __importStar(require("@bitgo-beta/utxo-lib"));
|
|
41
|
+
const wasm_utxo_1 = require("@bitgo/wasm-utxo");
|
|
42
|
+
const decode_1 = require("../../../../src/transaction/decode");
|
|
43
|
+
const signPsbt_1 = require("../../../../src/transaction/fixedScript/signPsbt");
|
|
44
|
+
const signPsbtWasm_1 = require("../../../../src/transaction/fixedScript/signPsbtWasm");
|
|
45
|
+
const util_1 = require("./util");
|
|
46
|
+
function getMockCoinUtxolib(keys) {
|
|
47
|
+
return {
|
|
48
|
+
async getMusig2Nonces(psbt, walletId) {
|
|
49
|
+
psbt.setAllInputsMusig2NonceHD(keys.bitgo, { deterministic: true });
|
|
50
|
+
return psbt;
|
|
51
|
+
},
|
|
52
|
+
};
|
|
53
|
+
}
|
|
54
|
+
function getMockCoinWasm(keys, network) {
|
|
55
|
+
// Convert utxolib RootWalletKeys to wasm BIP32 using base58 string
|
|
56
|
+
// This ensures the private key is properly transferred
|
|
57
|
+
const bitgoXprv = keys.bitgo.toBase58();
|
|
58
|
+
const bitgoKey = wasm_utxo_1.BIP32.fromBase58(bitgoXprv);
|
|
59
|
+
const networkName = utxolib.getNetworkName(network);
|
|
60
|
+
(0, strict_1.default)(networkName, 'network name is required');
|
|
61
|
+
return {
|
|
62
|
+
async getMusig2Nonces(psbt, walletId) {
|
|
63
|
+
// Generate nonces using the bitgo key
|
|
64
|
+
psbt.generateMusig2Nonces(bitgoKey);
|
|
65
|
+
// Serialize and deserialize to simulate remote response
|
|
66
|
+
// This creates a new object so we don't get "recursive use of an object" error
|
|
67
|
+
return wasm_utxo_1.fixedScriptWallet.BitGoPsbt.fromBytes(psbt.serialize(), networkName);
|
|
68
|
+
},
|
|
69
|
+
};
|
|
70
|
+
}
|
|
71
|
+
function assertSignedUtxolib(psbt, userKey) {
|
|
72
|
+
// Verify that all wallet inputs have been signed by user key
|
|
73
|
+
psbt.data.inputs.forEach((input, inputIndex) => {
|
|
74
|
+
const { scriptType } = utxolib.bitgo.parsePsbtInput(input);
|
|
75
|
+
// Skip replay protection inputs (p2shP2pk)
|
|
76
|
+
if (scriptType === 'p2shP2pk') {
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
// Verify user signature is present
|
|
80
|
+
const isValid = psbt.validateSignaturesOfInputHD(inputIndex, userKey);
|
|
81
|
+
(0, strict_1.default)(isValid, `input ${inputIndex} should have valid user signature`);
|
|
82
|
+
});
|
|
83
|
+
}
|
|
84
|
+
function assertSignedWasm(psbt, userKey, rootWalletKeys, replayProtection) {
|
|
85
|
+
const wasmUserKey = wasm_utxo_1.BIP32.from(userKey);
|
|
86
|
+
const parsed = psbt.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);
|
|
87
|
+
// Verify that all wallet inputs have been signed by user key
|
|
88
|
+
parsed.inputs.forEach((input, inputIndex) => {
|
|
89
|
+
// Skip replay protection inputs (p2shP2pk)
|
|
90
|
+
if (input.scriptType === 'p2shP2pk') {
|
|
91
|
+
return;
|
|
92
|
+
}
|
|
93
|
+
// Verify user signature is present
|
|
94
|
+
const isValid = psbt.verifySignature(inputIndex, wasmUserKey);
|
|
95
|
+
(0, strict_1.default)(isValid, `input ${inputIndex} should have valid user signature (scriptType=${input.scriptType})`);
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
function toWasmWalletKeys(keys) {
|
|
99
|
+
return {
|
|
100
|
+
triple: [keys.user, keys.backup, keys.bitgo],
|
|
101
|
+
derivationPrefixes: keys.derivationPrefixes,
|
|
102
|
+
};
|
|
103
|
+
}
|
|
104
|
+
function getReplayProtectionKeys(keys) {
|
|
105
|
+
// Replay protection inputs use the underived user public key
|
|
106
|
+
return {
|
|
107
|
+
publicKeys: [keys.user.publicKey],
|
|
108
|
+
};
|
|
109
|
+
}
|
|
110
|
+
function describeSignPsbtWithMusig2Participant(acidTest, { decodeWith }) {
|
|
111
|
+
describe(`${acidTest.name} ${decodeWith}`, function () {
|
|
112
|
+
it('should sign unsigned psbt to halfsigned', async function () {
|
|
113
|
+
// Create unsigned PSBT
|
|
114
|
+
const psbt = (0, decode_1.decodePsbtWith)(acidTest.createPsbt().toBuffer(), acidTest.network, decodeWith);
|
|
115
|
+
let result;
|
|
116
|
+
if (decodeWith === 'utxolib') {
|
|
117
|
+
(0, strict_1.default)(psbt instanceof utxolib.bitgo.UtxoPsbt, 'psbt should be a UtxoPsbt');
|
|
118
|
+
result = await (0, signPsbt_1.signPsbtWithMusig2Participant)(getMockCoinUtxolib(acidTest.rootWalletKeys), psbt, acidTest.rootWalletKeys.user, {
|
|
119
|
+
isLastSignature: false,
|
|
120
|
+
signingStep: undefined,
|
|
121
|
+
walletId: 'test-wallet-id',
|
|
122
|
+
});
|
|
123
|
+
// Result should be a PSBT (not finalized)
|
|
124
|
+
(0, strict_1.default)(result instanceof utxolib.bitgo.UtxoPsbt, 'should return UtxoPsbt when not last signature');
|
|
125
|
+
assertSignedUtxolib(result, acidTest.rootWalletKeys.user);
|
|
126
|
+
}
|
|
127
|
+
else {
|
|
128
|
+
(0, strict_1.default)(psbt instanceof wasm_utxo_1.fixedScriptWallet.BitGoPsbt, 'psbt should be a BitGoPsbt');
|
|
129
|
+
const wasmWalletKeys = toWasmWalletKeys(acidTest.rootWalletKeys);
|
|
130
|
+
const replayProtection = getReplayProtectionKeys(acidTest.rootWalletKeys);
|
|
131
|
+
result = await (0, signPsbtWasm_1.signPsbtWithMusig2ParticipantWasm)(getMockCoinWasm(acidTest.rootWalletKeys, acidTest.network), psbt, acidTest.rootWalletKeys.user, wasm_utxo_1.fixedScriptWallet.RootWalletKeys.from(acidTest.rootWalletKeys), {
|
|
132
|
+
replayProtection,
|
|
133
|
+
isLastSignature: false,
|
|
134
|
+
signingStep: undefined,
|
|
135
|
+
walletId: 'test-wallet-id',
|
|
136
|
+
});
|
|
137
|
+
// Result should be a PSBT (not finalized)
|
|
138
|
+
(0, strict_1.default)(result instanceof wasm_utxo_1.fixedScriptWallet.BitGoPsbt, 'should return BitGoPsbt when not last signature');
|
|
139
|
+
assertSignedWasm(result, acidTest.rootWalletKeys.user, wasmWalletKeys, replayProtection);
|
|
140
|
+
}
|
|
141
|
+
});
|
|
142
|
+
});
|
|
143
|
+
}
|
|
144
|
+
describe('signPsbtWithMusig2Participant', function () {
|
|
145
|
+
// Create test suite with includeP2trMusig2ScriptPath set to false
|
|
146
|
+
// p2trMusig2 script path inputs are signed by user and backup keys,
|
|
147
|
+
// which is not the typical signing pattern and makes testing more complex
|
|
148
|
+
utxolib.testutil.AcidTest.suite({ includeP2trMusig2ScriptPath: false })
|
|
149
|
+
.filter((test) => test.signStage === 'unsigned')
|
|
150
|
+
.forEach((test) => {
|
|
151
|
+
describeSignPsbtWithMusig2Participant(test, { decodeWith: 'utxolib' });
|
|
152
|
+
if ((0, util_1.hasWasmUtxoSupport)(test.network)) {
|
|
153
|
+
describeSignPsbtWithMusig2Participant(test, { decodeWith: 'wasm-utxo' });
|
|
154
|
+
}
|
|
155
|
+
});
|
|
156
|
+
});
|
|
157
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"signPsbt.js","sourceRoot":"","sources":["../../../../../../test/unit/transaction/fixedScript/signPsbt.ts"],"names":[],"mappings":"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","sourcesContent":["import assert from 'node:assert/strict';\n\nimport * as utxolib from '@bitgo-beta/utxo-lib';\nimport { BIP32, fixedScriptWallet } from '@bitgo/wasm-utxo';\n\nimport { decodePsbtWith } from '../../../../src/transaction/decode';\nimport { Musig2Participant } from '../../../../src/transaction/fixedScript/musig2';\nimport { signPsbtWithMusig2Participant } from '../../../../src/transaction/fixedScript/signPsbt';\nimport {\n  ReplayProtectionKeys,\n  signPsbtWithMusig2ParticipantWasm,\n} from '../../../../src/transaction/fixedScript/signPsbtWasm';\nimport { SdkBackend } from '../../../../src/transaction/types';\n\nimport { hasWasmUtxoSupport } from './util';\n\nfunction getMockCoinUtxolib(keys: utxolib.bitgo.RootWalletKeys): Musig2Participant<utxolib.bitgo.UtxoPsbt> {\n  return {\n    async getMusig2Nonces(psbt: utxolib.bitgo.UtxoPsbt, walletId: string): Promise<utxolib.bitgo.UtxoPsbt> {\n      psbt.setAllInputsMusig2NonceHD(keys.bitgo, { deterministic: true });\n      return psbt;\n    },\n  };\n}\n\nfunction getMockCoinWasm(\n  keys: utxolib.bitgo.RootWalletKeys,\n  network: utxolib.Network\n): Musig2Participant<fixedScriptWallet.BitGoPsbt> {\n  // Convert utxolib RootWalletKeys to wasm BIP32 using base58 string\n  // This ensures the private key is properly transferred\n  const bitgoXprv = keys.bitgo.toBase58();\n  const bitgoKey = BIP32.fromBase58(bitgoXprv);\n  const networkName = utxolib.getNetworkName(network);\n  assert(networkName, 'network name is required');\n  return {\n    async getMusig2Nonces(psbt: fixedScriptWallet.BitGoPsbt, walletId: string): Promise<fixedScriptWallet.BitGoPsbt> {\n      // Generate nonces using the bitgo key\n      psbt.generateMusig2Nonces(bitgoKey);\n      // Serialize and deserialize to simulate remote response\n      // This creates a new object so we don't get \"recursive use of an object\" error\n      return fixedScriptWallet.BitGoPsbt.fromBytes(psbt.serialize(), networkName);\n    },\n  };\n}\n\nfunction assertSignedUtxolib(psbt: utxolib.bitgo.UtxoPsbt, userKey: utxolib.BIP32Interface): void {\n  // Verify that all wallet inputs have been signed by user key\n  psbt.data.inputs.forEach((input, inputIndex) => {\n    const { scriptType } = utxolib.bitgo.parsePsbtInput(input);\n\n    // Skip replay protection inputs (p2shP2pk)\n    if (scriptType === 'p2shP2pk') {\n      return;\n    }\n\n    // Verify user signature is present\n    const isValid = psbt.validateSignaturesOfInputHD(inputIndex, userKey);\n    assert(isValid, `input ${inputIndex} should have valid user signature`);\n  });\n}\n\nfunction assertSignedWasm(\n  psbt: fixedScriptWallet.BitGoPsbt,\n  userKey: utxolib.BIP32Interface,\n  rootWalletKeys: fixedScriptWallet.IWalletKeys,\n  replayProtection: ReplayProtectionKeys\n): void {\n  const wasmUserKey = BIP32.from(userKey);\n  const parsed = psbt.parseTransactionWithWalletKeys(rootWalletKeys, replayProtection);\n\n  // Verify that all wallet inputs have been signed by user key\n  parsed.inputs.forEach((input, inputIndex) => {\n    // Skip replay protection inputs (p2shP2pk)\n    if (input.scriptType === 'p2shP2pk') {\n      return;\n    }\n\n    // Verify user signature is present\n    const isValid = psbt.verifySignature(inputIndex, wasmUserKey);\n    assert(isValid, `input ${inputIndex} should have valid user signature (scriptType=${input.scriptType})`);\n  });\n}\n\nfunction toWasmWalletKeys(keys: utxolib.bitgo.RootWalletKeys): fixedScriptWallet.IWalletKeys {\n  return {\n    triple: [keys.user, keys.backup, keys.bitgo],\n    derivationPrefixes: keys.derivationPrefixes,\n  };\n}\n\nfunction getReplayProtectionKeys(keys: utxolib.bitgo.RootWalletKeys): ReplayProtectionKeys {\n  // Replay protection inputs use the underived user public key\n  return {\n    publicKeys: [keys.user.publicKey],\n  };\n}\n\nfunction describeSignPsbtWithMusig2Participant(\n  acidTest: utxolib.testutil.AcidTest,\n  { decodeWith }: { decodeWith: SdkBackend }\n) {\n  describe(`${acidTest.name} ${decodeWith}`, function () {\n    it('should sign unsigned psbt to halfsigned', async function () {\n      // Create unsigned PSBT\n      const psbt = decodePsbtWith(acidTest.createPsbt().toBuffer(), acidTest.network, decodeWith);\n\n      let result;\n      if (decodeWith === 'utxolib') {\n        assert(psbt instanceof utxolib.bitgo.UtxoPsbt, 'psbt should be a UtxoPsbt');\n        result = await signPsbtWithMusig2Participant(\n          getMockCoinUtxolib(acidTest.rootWalletKeys),\n          psbt,\n          acidTest.rootWalletKeys.user,\n          {\n            isLastSignature: false,\n            signingStep: undefined,\n            walletId: 'test-wallet-id',\n          }\n        );\n        // Result should be a PSBT (not finalized)\n        assert(result instanceof utxolib.bitgo.UtxoPsbt, 'should return UtxoPsbt when not last signature');\n\n        assertSignedUtxolib(result, acidTest.rootWalletKeys.user);\n      } else {\n        assert(psbt instanceof fixedScriptWallet.BitGoPsbt, 'psbt should be a BitGoPsbt');\n        const wasmWalletKeys = toWasmWalletKeys(acidTest.rootWalletKeys);\n        const replayProtection = getReplayProtectionKeys(acidTest.rootWalletKeys);\n        result = await signPsbtWithMusig2ParticipantWasm(\n          getMockCoinWasm(acidTest.rootWalletKeys, acidTest.network),\n          psbt,\n          acidTest.rootWalletKeys.user,\n          fixedScriptWallet.RootWalletKeys.from(acidTest.rootWalletKeys),\n          {\n            replayProtection,\n            isLastSignature: false,\n            signingStep: undefined,\n            walletId: 'test-wallet-id',\n          }\n        );\n        // Result should be a PSBT (not finalized)\n        assert(result instanceof fixedScriptWallet.BitGoPsbt, 'should return BitGoPsbt when not last signature');\n\n        assertSignedWasm(result, acidTest.rootWalletKeys.user, wasmWalletKeys, replayProtection);\n      }\n    });\n  });\n}\n\ndescribe('signPsbtWithMusig2Participant', function () {\n  // Create test suite with includeP2trMusig2ScriptPath set to false\n  // p2trMusig2 script path inputs are signed by user and backup keys,\n  // which is not the typical signing pattern and makes testing more complex\n  utxolib.testutil.AcidTest.suite({ includeP2trMusig2ScriptPath: false })\n    .filter((test) => test.signStage === 'unsigned')\n    .forEach((test) => {\n      describeSignPsbtWithMusig2Participant(test, { decodeWith: 'utxolib' });\n      if (hasWasmUtxoSupport(test.network)) {\n        describeSignPsbtWithMusig2Participant(test, { decodeWith: 'wasm-utxo' });\n      }\n    });\n});\n"]}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../../../test/unit/transaction/fixedScript/util.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,OAAO,
|
|
1
|
+
{"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../../../../../../test/unit/transaction/fixedScript/util.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,OAAO,MAAM,sBAAsB,CAAC;AAEhD,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,OAAO,CAAC,OAAO,GAAG,OAAO,CAQpE"}
|
|
@@ -39,8 +39,9 @@ function hasWasmUtxoSupport(network) {
|
|
|
39
39
|
return ![
|
|
40
40
|
utxolib.networks.bitcoincash,
|
|
41
41
|
utxolib.networks.bitcoingold,
|
|
42
|
+
utxolib.networks.bitcoinsv,
|
|
42
43
|
utxolib.networks.ecash,
|
|
43
44
|
utxolib.networks.zcash,
|
|
44
45
|
].includes(utxolib.getMainnet(network));
|
|
45
46
|
}
|
|
46
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
47
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Rlc3QvdW5pdC90cmFuc2FjdGlvbi9maXhlZFNjcmlwdC91dGlsLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBRUEsZ0RBUUM7QUFWRCw4REFBZ0Q7QUFFaEQsU0FBZ0Isa0JBQWtCLENBQUMsT0FBd0I7SUFDekQsT0FBTyxDQUFDO1FBQ04sT0FBTyxDQUFDLFFBQVEsQ0FBQyxXQUFXO1FBQzVCLE9BQU8sQ0FBQyxRQUFRLENBQUMsV0FBVztRQUM1QixPQUFPLENBQUMsUUFBUSxDQUFDLFNBQVM7UUFDMUIsT0FBTyxDQUFDLFFBQVEsQ0FBQyxLQUFLO1FBQ3RCLE9BQU8sQ0FBQyxRQUFRLENBQUMsS0FBSztLQUN2QixDQUFDLFFBQVEsQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUM7QUFDMUMsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCAqIGFzIHV0eG9saWIgZnJvbSAnQGJpdGdvLWJldGEvdXR4by1saWInO1xuXG5leHBvcnQgZnVuY3Rpb24gaGFzV2FzbVV0eG9TdXBwb3J0KG5ldHdvcms6IHV0eG9saWIuTmV0d29yayk6IGJvb2xlYW4ge1xuICByZXR1cm4gIVtcbiAgICB1dHhvbGliLm5ldHdvcmtzLmJpdGNvaW5jYXNoLFxuICAgIHV0eG9saWIubmV0d29ya3MuYml0Y29pbmdvbGQsXG4gICAgdXR4b2xpYi5uZXR3b3Jrcy5iaXRjb2luc3YsXG4gICAgdXR4b2xpYi5uZXR3b3Jrcy5lY2FzaCxcbiAgICB1dHhvbGliLm5ldHdvcmtzLnpjYXNoLFxuICBdLmluY2x1ZGVzKHV0eG9saWIuZ2V0TWFpbm5ldChuZXR3b3JrKSk7XG59XG4iXX0=
|