-
Notifications
You must be signed in to change notification settings - Fork 302
Expand file tree
/
Copy pathsignTransaction.ts
More file actions
75 lines (70 loc) · 2.74 KB
/
signTransaction.ts
File metadata and controls
75 lines (70 loc) · 2.74 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
import assert from 'assert';
import { isTriple } from '@bitgo/sdk-core';
import _ from 'lodash';
import { BIP32Interface } from '@bitgo/secp256k1';
import { bitgo } from '@bitgo/utxo-lib';
import * as utxolib from '@bitgo/utxo-lib';
import { fixedScriptWallet } from '@bitgo/wasm-utxo';
import { Musig2Participant } from './musig2';
import { signLegacyTransaction } from './signLegacyTransaction';
import { signPsbtWithMusig2Participant } from './signPsbt';
import { signPsbtWithMusig2ParticipantWasm } from './signPsbtWasm';
import { getReplayProtectionPubkeys } from './replayProtection';
export async function signTransaction<
T extends utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt
>(
coin: Musig2Participant<utxolib.bitgo.UtxoPsbt> | Musig2Participant<fixedScriptWallet.BitGoPsbt>,
tx: T,
signerKeychain: BIP32Interface | undefined,
network: utxolib.Network,
params: {
walletId: string | undefined;
txInfo: { unspents?: utxolib.bitgo.Unspent<bigint | number>[] } | undefined;
isLastSignature: boolean;
signingStep: 'signerNonce' | 'cosignerNonce' | 'signerSignature' | undefined;
/** deprecated */
allowNonSegwitSigningWithoutPrevTx: boolean;
pubs: string[] | undefined;
cosignerPub: string | undefined;
}
): Promise<
utxolib.bitgo.UtxoPsbt | utxolib.bitgo.UtxoTransaction<bigint | number> | fixedScriptWallet.BitGoPsbt | Buffer
> {
let isLastSignature = false;
if (_.isBoolean(params.isLastSignature)) {
// if build is called instead of buildIncomplete, no signature placeholders are left in the sig script
isLastSignature = params.isLastSignature;
}
if (tx instanceof bitgo.UtxoPsbt) {
return signPsbtWithMusig2Participant(coin as Musig2Participant<utxolib.bitgo.UtxoPsbt>, tx, signerKeychain, {
isLastSignature,
signingStep: params.signingStep,
walletId: params.walletId,
});
} else if (tx instanceof fixedScriptWallet.BitGoPsbt) {
assert(params.pubs, 'pubs are required for fixed script signing');
assert(isTriple(params.pubs), 'pubs must be a triple');
const rootWalletKeys = fixedScriptWallet.RootWalletKeys.fromXpubs(params.pubs);
return signPsbtWithMusig2ParticipantWasm(
coin as Musig2Participant<fixedScriptWallet.BitGoPsbt>,
tx,
signerKeychain,
rootWalletKeys,
{
replayProtection: {
publicKeys: getReplayProtectionPubkeys(network),
},
isLastSignature,
signingStep: params.signingStep,
walletId: params.walletId,
}
);
}
return signLegacyTransaction(tx, signerKeychain, {
isLastSignature,
signingStep: params.signingStep,
txInfo: params.txInfo,
pubs: params.pubs,
cosignerPub: params.cosignerPub,
});
}