@vultisig/core-mpc 0.9.0 → 1.0.0
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/CHANGELOG.md +28 -0
- package/dist/chains/cosmos/qbtc/QBTCHelper.d.ts +25 -0
- package/dist/chains/cosmos/qbtc/QBTCHelper.d.ts.map +1 -0
- package/dist/chains/cosmos/qbtc/QBTCHelper.js +158 -0
- package/dist/chains/cosmos/qbtc/QBTCHelper.js.map +1 -0
- package/dist/dkls/dkls.d.ts +6 -3
- package/dist/dkls/dkls.d.ts.map +1 -1
- package/dist/dkls/dkls.js +102 -57
- package/dist/dkls/dkls.js.map +1 -1
- package/dist/fast/api/batchReshareWithServer.d.ts +19 -0
- package/dist/fast/api/batchReshareWithServer.d.ts.map +1 -0
- package/dist/fast/api/batchReshareWithServer.js +7 -0
- package/dist/fast/api/batchReshareWithServer.js.map +1 -0
- package/dist/fast/api/createVaultWithServer.d.ts +14 -0
- package/dist/fast/api/createVaultWithServer.d.ts.map +1 -0
- package/dist/fast/api/createVaultWithServer.js +7 -0
- package/dist/fast/api/createVaultWithServer.js.map +1 -0
- package/dist/fast/api/keyImportWithServer.d.ts +3 -2
- package/dist/fast/api/keyImportWithServer.d.ts.map +1 -1
- package/dist/fast/api/keyImportWithServer.js +2 -2
- package/dist/fast/api/keyImportWithServer.js.map +1 -1
- package/dist/fast/api/reshareWithServer.d.ts +3 -1
- package/dist/fast/api/reshareWithServer.d.ts.map +1 -1
- package/dist/fast/api/reshareWithServer.js +2 -2
- package/dist/fast/api/reshareWithServer.js.map +1 -1
- package/dist/fast/api/sequentialKeyImportWithServer.d.ts +15 -0
- package/dist/fast/api/sequentialKeyImportWithServer.d.ts.map +1 -0
- package/dist/fast/api/sequentialKeyImportWithServer.js +7 -0
- package/dist/fast/api/sequentialKeyImportWithServer.js.map +1 -0
- package/dist/fast/api/setupVaultWithServer.d.ts +2 -1
- package/dist/fast/api/setupVaultWithServer.d.ts.map +1 -1
- package/dist/fast/api/setupVaultWithServer.js +1 -1
- package/dist/fast/api/setupVaultWithServer.js.map +1 -1
- package/dist/keygen/KeygenStep.d.ts +1 -1
- package/dist/keygen/KeygenStep.d.ts.map +1 -1
- package/dist/keygen/KeygenStep.js +7 -1
- package/dist/keygen/KeygenStep.js.map +1 -1
- package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts +1 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts.map +1 -1
- package/dist/keysign/chainSpecific/KeysignChainSpecific.js +1 -0
- package/dist/keysign/chainSpecific/KeysignChainSpecific.js.map +1 -1
- package/dist/keysign/chainSpecific/index.d.ts.map +1 -1
- package/dist/keysign/chainSpecific/index.js +2 -0
- package/dist/keysign/chainSpecific/index.js.map +1 -1
- package/dist/keysign/chainSpecific/resolvers/qbtc.d.ts +3 -0
- package/dist/keysign/chainSpecific/resolvers/qbtc.d.ts.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/qbtc.js +25 -0
- package/dist/keysign/chainSpecific/resolvers/qbtc.js.map +1 -0
- package/dist/keysign/chainSpecific/resolvers/solana/index.js +1 -1
- package/dist/keysign/chainSpecific/resolvers/solana/index.js.map +1 -1
- package/dist/keysign/cosigner.js +1 -1
- package/dist/keysign/cosigner.js.map +1 -1
- package/dist/keysign/fee/index.d.ts.map +1 -1
- package/dist/keysign/fee/index.js +2 -0
- package/dist/keysign/fee/index.js.map +1 -1
- package/dist/keysign/fee/resolvers/qbtc.d.ts +3 -0
- package/dist/keysign/fee/resolvers/qbtc.d.ts.map +1 -0
- package/dist/keysign/fee/resolvers/qbtc.js +6 -0
- package/dist/keysign/fee/resolvers/qbtc.js.map +1 -0
- package/dist/keysign/index.d.ts.map +1 -1
- package/dist/keysign/index.js +28 -19
- package/dist/keysign/index.js.map +1 -1
- package/dist/keysign/preSigningOutput/index.d.ts +1 -0
- package/dist/keysign/preSigningOutput/index.d.ts.map +1 -1
- package/dist/keysign/preSigningOutput/index.js +1 -0
- package/dist/keysign/preSigningOutput/index.js.map +1 -1
- package/dist/keysign/send/build.d.ts +4 -2
- package/dist/keysign/send/build.d.ts.map +1 -1
- package/dist/keysign/send/build.js +19 -10
- package/dist/keysign/send/build.js.map +1 -1
- package/dist/keysign/send/getSendFeeEstimate.d.ts.map +1 -1
- package/dist/keysign/send/getSendFeeEstimate.js +9 -1
- package/dist/keysign/send/getSendFeeEstimate.js.map +1 -1
- package/dist/keysign/setupMessage/make.d.ts.map +1 -1
- package/dist/keysign/setupMessage/make.js +12 -2
- package/dist/keysign/setupMessage/make.js.map +1 -1
- package/dist/keysign/signingInputs/core.d.ts +1 -0
- package/dist/keysign/signingInputs/core.d.ts.map +1 -1
- package/dist/keysign/signingInputs/core.js +1 -0
- package/dist/keysign/signingInputs/core.js.map +1 -1
- package/dist/keysign/signingInputs/index.d.ts.map +1 -1
- package/dist/keysign/signingInputs/index.js +3 -1
- package/dist/keysign/signingInputs/index.js.map +1 -1
- package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.d.ts +3 -0
- package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.js +17 -0
- package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/evm/index.js +1 -1
- package/dist/keysign/signingInputs/resolvers/evm/index.js.map +1 -1
- package/dist/keysign/signingInputs/resolvers/qbtc.d.ts +5 -0
- package/dist/keysign/signingInputs/resolvers/qbtc.d.ts.map +1 -0
- package/dist/keysign/signingInputs/resolvers/qbtc.js +4 -0
- package/dist/keysign/signingInputs/resolvers/qbtc.js.map +1 -0
- package/dist/keysign/signingInputs/resolvers/ton/index.d.ts.map +1 -1
- package/dist/keysign/signingInputs/resolvers/ton/index.js +25 -13
- package/dist/keysign/signingInputs/resolvers/ton/index.js.map +1 -1
- package/dist/keysign/signingInputs/resolvers/ton/jetton.d.ts.map +1 -1
- package/dist/keysign/signingInputs/resolvers/ton/jetton.js +2 -1
- package/dist/keysign/signingInputs/resolvers/ton/jetton.js.map +1 -1
- package/dist/keysign/signingInputs/resolvers/ton/native.d.ts +9 -0
- package/dist/keysign/signingInputs/resolvers/ton/native.d.ts.map +1 -1
- package/dist/keysign/signingInputs/resolvers/ton/native.js +31 -3
- package/dist/keysign/signingInputs/resolvers/ton/native.js.map +1 -1
- package/dist/keysign/swap/build.js +1 -1
- package/dist/keysign/swap/build.js.map +1 -1
- package/dist/keysign/utxo/getKeysignUtxoInfo.d.ts.map +1 -1
- package/dist/keysign/utxo/getKeysignUtxoInfo.js +11 -2
- package/dist/keysign/utxo/getKeysignUtxoInfo.js.map +1 -1
- package/dist/lib/initialize.d.ts.map +1 -1
- package/dist/lib/initialize.js +2 -0
- package/dist/lib/initialize.js.map +1 -1
- package/dist/lib/keyshare.d.ts +2 -1
- package/dist/lib/keyshare.d.ts.map +1 -1
- package/dist/lib/keyshare.js +2 -0
- package/dist/lib/keyshare.js.map +1 -1
- package/dist/lib/signSession.d.ts +3 -2
- package/dist/lib/signSession.d.ts.map +1 -1
- package/dist/lib/signSession.js +4 -1
- package/dist/lib/signSession.js.map +1 -1
- package/dist/mldsa/mldsaKeygen.d.ts +4 -0
- package/dist/mldsa/mldsaKeygen.d.ts.map +1 -1
- package/dist/mldsa/mldsaKeygen.js +9 -5
- package/dist/mldsa/mldsaKeygen.js.map +1 -1
- package/dist/mpcLib.d.ts +3 -3
- package/dist/mpcLib.d.ts.map +1 -1
- package/dist/schnorr/schnorrKeygen.d.ts +5 -3
- package/dist/schnorr/schnorrKeygen.d.ts.map +1 -1
- package/dist/schnorr/schnorrKeygen.js +72 -40
- package/dist/schnorr/schnorrKeygen.js.map +1 -1
- package/dist/security/blockaid/tx/simulation/input/index.d.ts +4 -0
- package/dist/security/blockaid/tx/simulation/input/index.d.ts.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/index.js +26 -0
- package/dist/security/blockaid/tx/simulation/input/index.js.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolver.d.ts +18 -0
- package/dist/security/blockaid/tx/simulation/input/resolver.d.ts.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolver.js +2 -0
- package/dist/security/blockaid/tx/simulation/input/resolver.js.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/evm.d.ts +4 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/evm.d.ts.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/evm.js +67 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/evm.js.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/solana.d.ts +4 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/solana.d.ts.map +1 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/solana.js +31 -0
- package/dist/security/blockaid/tx/simulation/input/resolvers/solana.js.map +1 -0
- package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.d.ts +9 -0
- package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.d.ts.map +1 -0
- package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.js +50 -0
- package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/index.d.ts +4 -0
- package/dist/security/blockaid/tx/validation/input/index.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/index.js +30 -0
- package/dist/security/blockaid/tx/validation/input/index.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolver.d.ts +16 -0
- package/dist/security/blockaid/tx/validation/input/resolver.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolver.js +2 -0
- package/dist/security/blockaid/tx/validation/input/resolver.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/evm.d.ts +4 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/evm.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/evm.js +58 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/evm.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/solana.d.ts +4 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/solana.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/solana.js +20 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/solana.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/sui.d.ts +4 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/sui.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/sui.js +20 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/sui.js.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/utxo.d.ts +4 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/utxo.d.ts.map +1 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/utxo.js +19 -0
- package/dist/security/blockaid/tx/validation/input/resolvers/utxo.js.map +1 -0
- package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.d.ts +16 -0
- package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.d.ts.map +1 -0
- package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.js +31 -0
- package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.js.map +1 -0
- package/dist/swap/utils/getSwapTrackingUrl.d.ts +10 -0
- package/dist/swap/utils/getSwapTrackingUrl.d.ts.map +1 -0
- package/dist/swap/utils/getSwapTrackingUrl.js +29 -0
- package/dist/swap/utils/getSwapTrackingUrl.js.map +1 -0
- package/dist/tx/compile/compileTx.d.ts +14 -0
- package/dist/tx/compile/compileTx.d.ts.map +1 -0
- package/dist/tx/compile/compileTx.js +85 -0
- package/dist/tx/compile/compileTx.js.map +1 -0
- package/dist/tx/preSigningHashes/index.d.ts +10 -0
- package/dist/tx/preSigningHashes/index.d.ts.map +1 -0
- package/dist/tx/preSigningHashes/index.js +41 -0
- package/dist/tx/preSigningHashes/index.js.map +1 -0
- package/dist/tx/signature/generateSignature.d.ts +11 -0
- package/dist/tx/signature/generateSignature.d.ts.map +1 -0
- package/dist/tx/signature/generateSignature.js +20 -0
- package/dist/tx/signature/generateSignature.js.map +1 -0
- package/dist/types/utils/libType.d.ts +1 -2
- package/dist/types/utils/libType.d.ts.map +1 -1
- package/dist/types/utils/libType.js +2 -6
- package/dist/types/utils/libType.js.map +1 -1
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts +7 -1
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts.map +1 -1
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.js +1 -1
- package/dist/types/vultisig/keysign/v1/keysign_message_pb.js.map +1 -1
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts +36 -0
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts.map +1 -1
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js +12 -2
- package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js.map +1 -1
- package/dist/vault/Vault.d.ts +4 -2
- package/dist/vault/Vault.d.ts.map +1 -1
- package/dist/vault/Vault.js.map +1 -1
- package/package.json +929 -8
|
@@ -24,6 +24,7 @@ export class Schnorr {
|
|
|
24
24
|
sequenceNo = 0;
|
|
25
25
|
cache = {};
|
|
26
26
|
setupMessage = new Uint8Array();
|
|
27
|
+
pendingKeyImportSession = null;
|
|
27
28
|
localUI;
|
|
28
29
|
publicKey;
|
|
29
30
|
chainCode;
|
|
@@ -44,7 +45,7 @@ export class Schnorr {
|
|
|
44
45
|
this.chainCode = options?.chainCode;
|
|
45
46
|
this.timeoutMs = options?.timeoutMs ?? 60000; // Default to 1 minute (60000ms)
|
|
46
47
|
}
|
|
47
|
-
async processOutbound(session) {
|
|
48
|
+
async processOutbound(session, messageId) {
|
|
48
49
|
try {
|
|
49
50
|
const message = session.outputMessage();
|
|
50
51
|
if (message === undefined) {
|
|
@@ -54,7 +55,7 @@ export class Schnorr {
|
|
|
54
55
|
}
|
|
55
56
|
else {
|
|
56
57
|
await sleep(100); // backoff for 100ms
|
|
57
|
-
return await this.processOutbound(session);
|
|
58
|
+
return await this.processOutbound(session, messageId);
|
|
58
59
|
}
|
|
59
60
|
}
|
|
60
61
|
console.log('outbound message:', message);
|
|
@@ -72,29 +73,31 @@ export class Schnorr {
|
|
|
72
73
|
hash: getMessageHash(base64Encode(message.body)),
|
|
73
74
|
sequence_no: this.sequenceNo,
|
|
74
75
|
},
|
|
76
|
+
messageId,
|
|
75
77
|
});
|
|
76
78
|
this.sequenceNo++;
|
|
77
79
|
});
|
|
78
80
|
await sleep(100);
|
|
79
|
-
return await this.processOutbound(session);
|
|
81
|
+
return await this.processOutbound(session, messageId);
|
|
80
82
|
}
|
|
81
83
|
catch (error) {
|
|
82
84
|
console.error('processOutbound error:', error);
|
|
83
85
|
await sleep(100);
|
|
84
|
-
return await this.processOutbound(session);
|
|
86
|
+
return await this.processOutbound(session, messageId);
|
|
85
87
|
}
|
|
86
88
|
}
|
|
87
|
-
async processInbound(session, start) {
|
|
89
|
+
async processInbound(session, start, messageId) {
|
|
88
90
|
try {
|
|
89
91
|
const parsedMessages = await getMpcRelayMessages({
|
|
90
92
|
serverUrl: this.serverURL,
|
|
91
93
|
localPartyId: this.localPartyId,
|
|
92
94
|
sessionId: this.sessionId,
|
|
95
|
+
messageId,
|
|
93
96
|
});
|
|
94
97
|
if (parsedMessages.length === 0) {
|
|
95
98
|
// no message to download, backoff for 100ms
|
|
96
99
|
await sleep(100);
|
|
97
|
-
return await this.processInbound(session, start);
|
|
100
|
+
return await this.processInbound(session, start, messageId);
|
|
98
101
|
}
|
|
99
102
|
for (const msg of parsedMessages) {
|
|
100
103
|
const cacheKey = `${msg.session_id}-${msg.from}-${msg.hash}`;
|
|
@@ -116,6 +119,7 @@ export class Schnorr {
|
|
|
116
119
|
localPartyId: this.localPartyId,
|
|
117
120
|
sessionId: this.sessionId,
|
|
118
121
|
messageHash: msg.hash,
|
|
122
|
+
messageId,
|
|
119
123
|
});
|
|
120
124
|
}
|
|
121
125
|
const end = Date.now();
|
|
@@ -126,15 +130,15 @@ export class Schnorr {
|
|
|
126
130
|
return false;
|
|
127
131
|
}
|
|
128
132
|
await sleep(100);
|
|
129
|
-
return await this.processInbound(session, start);
|
|
133
|
+
return await this.processInbound(session, start, messageId);
|
|
130
134
|
}
|
|
131
135
|
catch (error) {
|
|
132
136
|
console.error('processInbound error:', error);
|
|
133
137
|
await sleep(100);
|
|
134
|
-
return await this.processInbound(session, start);
|
|
138
|
+
return await this.processInbound(session, start, messageId);
|
|
135
139
|
}
|
|
136
140
|
}
|
|
137
|
-
async startKeygen(attempt) {
|
|
141
|
+
async startKeygen(attempt, messageId) {
|
|
138
142
|
if (this.setupMessage === undefined || this.setupMessage.length === 0) {
|
|
139
143
|
throw new Error('setup message is empty');
|
|
140
144
|
}
|
|
@@ -154,8 +158,8 @@ export class Schnorr {
|
|
|
154
158
|
throw new Error('invalid keygen type');
|
|
155
159
|
}
|
|
156
160
|
const start = Date.now();
|
|
157
|
-
const outbound = this.processOutbound(session);
|
|
158
|
-
const inbound = this.processInbound(session, start);
|
|
161
|
+
const outbound = this.processOutbound(session, messageId);
|
|
162
|
+
const inbound = this.processInbound(session, start, messageId);
|
|
159
163
|
const [, inboundResult] = await Promise.all([outbound, inbound]);
|
|
160
164
|
if (inboundResult) {
|
|
161
165
|
const keyShare = session.finish();
|
|
@@ -175,11 +179,11 @@ export class Schnorr {
|
|
|
175
179
|
throw error;
|
|
176
180
|
}
|
|
177
181
|
}
|
|
178
|
-
async startKeygenWithRetry() {
|
|
182
|
+
async startKeygenWithRetry(messageId) {
|
|
179
183
|
await initializeMpcLib('eddsa');
|
|
180
184
|
for (let i = 0; i < 3; i++) {
|
|
181
185
|
try {
|
|
182
|
-
const result = await this.startKeygen(i);
|
|
186
|
+
const result = await this.startKeygen(i, messageId);
|
|
183
187
|
return result;
|
|
184
188
|
}
|
|
185
189
|
catch (error) {
|
|
@@ -188,7 +192,7 @@ export class Schnorr {
|
|
|
188
192
|
}
|
|
189
193
|
throw new Error('Schnorr keygen failed');
|
|
190
194
|
}
|
|
191
|
-
async startReshare(rawSchnorrKeyshare, attempt) {
|
|
195
|
+
async startReshare(rawSchnorrKeyshare, attempt, messageId) {
|
|
192
196
|
console.log('startReshare schnorr, attempt:', attempt);
|
|
193
197
|
this.isKeygenComplete = false;
|
|
194
198
|
let localKeyshare = null;
|
|
@@ -196,6 +200,7 @@ export class Schnorr {
|
|
|
196
200
|
localKeyshare = Keyshare.fromBytes(Buffer.from(rawSchnorrKeyshare, 'base64'));
|
|
197
201
|
}
|
|
198
202
|
try {
|
|
203
|
+
const setupMessageId = messageId ?? 'eddsa';
|
|
199
204
|
let setupMessage = new Uint8Array();
|
|
200
205
|
if (this.isInitiateDevice && attempt === 0) {
|
|
201
206
|
if (localKeyshare === null) {
|
|
@@ -218,7 +223,7 @@ export class Schnorr {
|
|
|
218
223
|
serverUrl: this.serverURL,
|
|
219
224
|
message: encryptedSetupMsg,
|
|
220
225
|
sessionId: this.sessionId,
|
|
221
|
-
messageId:
|
|
226
|
+
messageId: setupMessageId,
|
|
222
227
|
});
|
|
223
228
|
console.log('uploaded setup message successfully');
|
|
224
229
|
}
|
|
@@ -226,15 +231,15 @@ export class Schnorr {
|
|
|
226
231
|
const encodedEncryptedSetupMsg = await waitForSetupMessage({
|
|
227
232
|
serverUrl: this.serverURL,
|
|
228
233
|
sessionId: this.sessionId,
|
|
229
|
-
messageId:
|
|
234
|
+
messageId: setupMessageId,
|
|
230
235
|
});
|
|
231
236
|
setupMessage = fromMpcServerMessage(encodedEncryptedSetupMsg, this.hexEncryptionKey);
|
|
232
237
|
}
|
|
233
238
|
const session = new QcSession(setupMessage, this.localPartyId, localKeyshare);
|
|
234
239
|
try {
|
|
235
240
|
const start = Date.now();
|
|
236
|
-
const outbound = this.processOutbound(session);
|
|
237
|
-
const inbound = this.processInbound(session, start);
|
|
241
|
+
const outbound = this.processOutbound(session, messageId);
|
|
242
|
+
const inbound = this.processInbound(session, start, messageId);
|
|
238
243
|
const [, inboundResult] = await Promise.all([outbound, inbound]);
|
|
239
244
|
if (inboundResult) {
|
|
240
245
|
const finalKeyShare = session.finish();
|
|
@@ -257,11 +262,11 @@ export class Schnorr {
|
|
|
257
262
|
throw error;
|
|
258
263
|
}
|
|
259
264
|
}
|
|
260
|
-
async startReshareWithRetry(keyshare) {
|
|
265
|
+
async startReshareWithRetry(keyshare, messageId) {
|
|
261
266
|
await initializeMpcLib('eddsa');
|
|
262
267
|
for (let i = 0; i < 3; i++) {
|
|
263
268
|
try {
|
|
264
|
-
const result = await this.startReshare(keyshare, i);
|
|
269
|
+
const result = await this.startReshare(keyshare, i, messageId);
|
|
265
270
|
if (result !== undefined) {
|
|
266
271
|
return result;
|
|
267
272
|
}
|
|
@@ -272,32 +277,58 @@ export class Schnorr {
|
|
|
272
277
|
}
|
|
273
278
|
throw new Error('schnorr reshare failed');
|
|
274
279
|
}
|
|
275
|
-
async
|
|
280
|
+
async prepareKeyImportSetup(hexPrivateKey, hexChainCode, messageId) {
|
|
281
|
+
if (!this.isInitiateDevice) {
|
|
282
|
+
return;
|
|
283
|
+
}
|
|
284
|
+
const privateKey = Buffer.from(hexPrivateKey, 'hex');
|
|
285
|
+
const chainCode = Buffer.from(hexChainCode, 'hex');
|
|
286
|
+
this.pendingKeyImportSession = new KeyImportInitiator(Uint8Array.from(privateKey), Uint8Array.from(chainCode), getKeygenThreshold(this.keygenCommittee.length), this.keygenCommittee);
|
|
287
|
+
this.setupMessage = this.pendingKeyImportSession.setup;
|
|
288
|
+
const encryptedSetupMsg = toMpcServerMessage(this.setupMessage, this.hexEncryptionKey);
|
|
289
|
+
const effectiveSetupId = messageId ?? 'eddsa_key_import';
|
|
290
|
+
await uploadMpcSetupMessage({
|
|
291
|
+
serverUrl: this.serverURL,
|
|
292
|
+
message: encryptedSetupMsg,
|
|
293
|
+
sessionId: this.sessionId,
|
|
294
|
+
messageId: effectiveSetupId,
|
|
295
|
+
});
|
|
296
|
+
console.log('uploaded setup message successfully');
|
|
297
|
+
}
|
|
298
|
+
async startKeyImport(hexPrivateKey, hexChainCode, attempt, setupMessageId, protocolMessageId) {
|
|
276
299
|
console.log('startKeyImport schnorr, attempt:', attempt);
|
|
277
300
|
this.isKeygenComplete = false;
|
|
278
301
|
try {
|
|
279
302
|
let session = null;
|
|
303
|
+
const effectiveSetupId = setupMessageId ?? 'eddsa_key_import';
|
|
280
304
|
if (this.isInitiateDevice) {
|
|
281
|
-
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
305
|
+
if (attempt === 0 && this.pendingKeyImportSession) {
|
|
306
|
+
const pendingSession = this.pendingKeyImportSession;
|
|
307
|
+
session = pendingSession;
|
|
308
|
+
this.setupMessage = pendingSession.setup;
|
|
309
|
+
this.pendingKeyImportSession = null;
|
|
310
|
+
}
|
|
311
|
+
else {
|
|
312
|
+
const privateKey = Buffer.from(hexPrivateKey, 'hex');
|
|
313
|
+
const chainCode = Buffer.from(hexChainCode, 'hex');
|
|
314
|
+
const initiatorSession = new KeyImportInitiator(Uint8Array.from(privateKey), Uint8Array.from(chainCode), getKeygenThreshold(this.keygenCommittee.length), this.keygenCommittee);
|
|
315
|
+
this.setupMessage = initiatorSession.setup;
|
|
316
|
+
session = initiatorSession;
|
|
317
|
+
const encryptedSetupMsg = toMpcServerMessage(this.setupMessage, this.hexEncryptionKey);
|
|
318
|
+
await uploadMpcSetupMessage({
|
|
319
|
+
serverUrl: this.serverURL,
|
|
320
|
+
message: encryptedSetupMsg,
|
|
321
|
+
sessionId: this.sessionId,
|
|
322
|
+
messageId: effectiveSetupId,
|
|
323
|
+
});
|
|
324
|
+
console.log('uploaded setup message successfully');
|
|
325
|
+
}
|
|
295
326
|
}
|
|
296
327
|
else {
|
|
297
328
|
const encodedEncryptedSetupMsg = await waitForSetupMessage({
|
|
298
329
|
serverUrl: this.serverURL,
|
|
299
330
|
sessionId: this.sessionId,
|
|
300
|
-
messageId:
|
|
331
|
+
messageId: effectiveSetupId,
|
|
301
332
|
});
|
|
302
333
|
this.setupMessage = fromMpcServerMessage(encodedEncryptedSetupMsg, this.hexEncryptionKey);
|
|
303
334
|
}
|
|
@@ -312,9 +343,10 @@ export class Schnorr {
|
|
|
312
343
|
if (session === null) {
|
|
313
344
|
throw new Error('Schnorr key import session is null');
|
|
314
345
|
}
|
|
346
|
+
const exchangeMessageId = protocolMessageId;
|
|
315
347
|
const start = Date.now();
|
|
316
|
-
const outbound = this.processOutbound(session);
|
|
317
|
-
const inbound = this.processInbound(session, start);
|
|
348
|
+
const outbound = this.processOutbound(session, exchangeMessageId);
|
|
349
|
+
const inbound = this.processInbound(session, start, exchangeMessageId);
|
|
318
350
|
const [, inboundResult] = await Promise.all([outbound, inbound]);
|
|
319
351
|
if (inboundResult) {
|
|
320
352
|
const keyShare = session.finish();
|
|
@@ -334,11 +366,11 @@ export class Schnorr {
|
|
|
334
366
|
throw error;
|
|
335
367
|
}
|
|
336
368
|
}
|
|
337
|
-
async startKeyImportWithRetry(hexPrivateKey, hexChainCode,
|
|
369
|
+
async startKeyImportWithRetry(hexPrivateKey, hexChainCode, setupMessageId, protocolMessageId) {
|
|
338
370
|
await initializeMpcLib('eddsa');
|
|
339
371
|
for (let i = 0; i < 3; i++) {
|
|
340
372
|
try {
|
|
341
|
-
const result = await this.startKeyImport(hexPrivateKey, hexChainCode, i,
|
|
373
|
+
const result = await this.startKeyImport(hexPrivateKey, hexChainCode, i, setupMessageId, protocolMessageId);
|
|
342
374
|
if (result !== undefined) {
|
|
343
375
|
return result;
|
|
344
376
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schnorrKeygen.js","sourceRoot":"","sources":["../../../../../packages/core/mpc/schnorr/schnorrKeygen.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"schnorrKeygen.js","sourceRoot":"","sources":["../../../../../packages/core/mpc/schnorr/schnorrKeygen.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { BlockaidTxSimulationInput } from '@vultisig/core-chain/security/blockaid/tx/simulation/resolver';
|
|
2
|
+
import { BlockaidTxSimulationInputResolverInput } from './resolver.js';
|
|
3
|
+
export declare const getBlockaidTxSimulationInput: (input: Omit<BlockaidTxSimulationInputResolverInput, "chain">) => BlockaidTxSimulationInput | null;
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,yBAAyB,EAAE,MAAM,+DAA+D,CAAA;AAIzG,OAAO,EAEL,sCAAsC,EACvC,MAAM,YAAY,CAAA;AAYnB,eAAO,MAAM,4BAA4B,GACvC,OAAO,IAAI,CAAC,sCAAsC,EAAE,OAAO,CAAC,KAC3D,yBAAyB,GAAG,IAkB9B,CAAA"}
|
|
@@ -0,0 +1,26 @@
|
|
|
1
|
+
import { getChainKind } from '@vultisig/core-chain/ChainKind';
|
|
2
|
+
import { blockaidSimulationSupportedChains, } from '@vultisig/core-chain/security/blockaid/simulationChains';
|
|
3
|
+
import { getKeysignChain } from '@vultisig/core-mpc/keysign/utils/getKeysignChain';
|
|
4
|
+
import { isOneOf } from '@vultisig/lib-utils/array/isOneOf';
|
|
5
|
+
import { getEvmBlockaidTxSimulationInput } from './resolvers/evm.js';
|
|
6
|
+
import { getSolanaBlockaidTxSimulationInput } from './resolvers/solana.js';
|
|
7
|
+
const resolvers = {
|
|
8
|
+
solana: getSolanaBlockaidTxSimulationInput,
|
|
9
|
+
evm: getEvmBlockaidTxSimulationInput,
|
|
10
|
+
};
|
|
11
|
+
export const getBlockaidTxSimulationInput = (input) => {
|
|
12
|
+
const chain = getKeysignChain(input.payload);
|
|
13
|
+
if (!isOneOf(chain, blockaidSimulationSupportedChains)) {
|
|
14
|
+
return null;
|
|
15
|
+
}
|
|
16
|
+
const chainKind = getChainKind(chain);
|
|
17
|
+
const data = resolvers[chainKind]({
|
|
18
|
+
...input,
|
|
19
|
+
chain,
|
|
20
|
+
});
|
|
21
|
+
if (!data) {
|
|
22
|
+
return null;
|
|
23
|
+
}
|
|
24
|
+
return { chain, data };
|
|
25
|
+
};
|
|
26
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAA;AAC7D,OAAO,EAEL,iCAAiC,GAClC,MAAM,yDAAyD,CAAA;AAEhE,OAAO,EAAE,eAAe,EAAE,MAAM,kDAAkD,CAAA;AAClF,OAAO,EAAE,OAAO,EAAE,MAAM,mCAAmC,CAAA;AAM3D,OAAO,EAAE,+BAA+B,EAAE,MAAM,iBAAiB,CAAA;AACjE,OAAO,EAAE,kCAAkC,EAAE,MAAM,oBAAoB,CAAA;AAEvE,MAAM,SAAS,GAGX;IACF,MAAM,EAAE,kCAAkC;IAC1C,GAAG,EAAE,+BAA+B;CACrC,CAAA;AAED,MAAM,CAAC,MAAM,4BAA4B,GAAG,CAC1C,KAA4D,EAC1B,EAAE;IACpC,MAAM,KAAK,GAAG,eAAe,CAAC,KAAK,CAAC,OAAO,CAAC,CAAA;IAC5C,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,iCAAiC,CAAC,EAAE,CAAC;QACvD,OAAO,IAAI,CAAA;IACb,CAAC;IAED,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,CAAA;IAErC,MAAM,IAAI,GAAG,SAAS,CAAC,SAAS,CAAC,CAAC;QAChC,GAAG,KAAK;QACR,KAAK;KACN,CAAC,CAAA;IAEF,IAAI,CAAC,IAAI,EAAE,CAAC;QACV,OAAO,IAAI,CAAA;IACb,CAAC;IAED,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,CAAA;AACxB,CAAC,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import { KeysignPayload } from '@vultisig/core-mpc/types/vultisig/keysign/v1/keysign_message_pb';
|
|
2
|
+
import { Resolver } from '@vultisig/lib-utils/types/Resolver';
|
|
3
|
+
import { WalletCore } from '@trustwallet/wallet-core';
|
|
4
|
+
import { BlockaidSimulationSupportedChain } from '@vultisig/core-chain/security/blockaid/simulationChains';
|
|
5
|
+
import { BlockaidTxSimulationInput } from '@vultisig/core-chain/security/blockaid/tx/simulation/resolver';
|
|
6
|
+
export type BlockaidTxSimulationInputResolverInput<T extends BlockaidSimulationSupportedChain = BlockaidSimulationSupportedChain> = {
|
|
7
|
+
payload: KeysignPayload;
|
|
8
|
+
walletCore: WalletCore;
|
|
9
|
+
chain: T;
|
|
10
|
+
raw?: string[];
|
|
11
|
+
};
|
|
12
|
+
export type BlockaidTxSimulationInputResolver<T extends BlockaidSimulationSupportedChain = BlockaidSimulationSupportedChain> = Resolver<{
|
|
13
|
+
payload: KeysignPayload;
|
|
14
|
+
walletCore: WalletCore;
|
|
15
|
+
chain: T;
|
|
16
|
+
raw?: string[];
|
|
17
|
+
}, BlockaidTxSimulationInput['data'] | null>;
|
|
18
|
+
//# sourceMappingURL=resolver.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.d.ts","sourceRoot":"","sources":["../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolver.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,cAAc,EAAE,MAAM,iEAAiE,CAAA;AAChG,OAAO,EAAE,QAAQ,EAAE,MAAM,oCAAoC,CAAA;AAC7D,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAErD,OAAO,EAAE,gCAAgC,EAAE,MAAM,yDAAyD,CAAA;AAC1G,OAAO,EAAE,yBAAyB,EAAE,MAAM,+DAA+D,CAAA;AAEzG,MAAM,MAAM,sCAAsC,CAChD,CAAC,SAAS,gCAAgC,GAAG,gCAAgC,IAC3E;IACF,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,EAAE,UAAU,CAAA;IACtB,KAAK,EAAE,CAAC,CAAA;IACR,GAAG,CAAC,EAAE,MAAM,EAAE,CAAA;CACf,CAAA;AAED,MAAM,MAAM,iCAAiC,CAC3C,CAAC,SAAS,gCAAgC,GAAG,gCAAgC,IAC3E,QAAQ,CACV;IACE,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,EAAE,UAAU,CAAA;IACtB,KAAK,EAAE,CAAC,CAAA;IACR,GAAG,CAAC,EAAE,MAAM,EAAE,CAAA;CACf,EACD,yBAAyB,CAAC,MAAM,CAAC,GAAG,IAAI,CACzC,CAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"resolver.js","sourceRoot":"","sources":["../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolver.ts"],"names":[],"mappings":""}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { BlockaidSupportedEvmChain } from '@vultisig/core-chain/security/blockaid/evmChains';
|
|
2
|
+
import { BlockaidTxSimulationInputResolver } from '../resolver.js';
|
|
3
|
+
export declare const getEvmBlockaidTxSimulationInput: BlockaidTxSimulationInputResolver<BlockaidSupportedEvmChain>;
|
|
4
|
+
//# sourceMappingURL=evm.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evm.d.ts","sourceRoot":"","sources":["../../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolvers/evm.ts"],"names":[],"mappings":"AACA,OAAO,EAEL,yBAAyB,EAC1B,MAAM,kDAAkD,CAAA;AASzD,OAAO,EAAE,iCAAiC,EAAE,MAAM,aAAa,CAAA;AAE/D,eAAO,MAAM,+BAA+B,EAAE,iCAAiC,CAC7E,yBAAyB,CA4E1B,CAAA"}
|
|
@@ -0,0 +1,67 @@
|
|
|
1
|
+
import { productRootDomain } from '@vultisig/core-config';
|
|
2
|
+
import { blockaidEvmChain, } from '@vultisig/core-chain/security/blockaid/evmChains';
|
|
3
|
+
import { getKeysignSwapPayload } from '@vultisig/core-mpc/keysign/swap/getKeysignSwapPayload';
|
|
4
|
+
import { getKeysignCoin } from '@vultisig/core-mpc/keysign/utils/getKeysignCoin';
|
|
5
|
+
import { bigIntToHex } from '@vultisig/lib-utils/bigint/bigIntToHex';
|
|
6
|
+
import { matchRecordUnion } from '@vultisig/lib-utils/matchRecordUnion';
|
|
7
|
+
import { encodeFunctionData, erc20Abi } from 'viem';
|
|
8
|
+
export const getEvmBlockaidTxSimulationInput = ({ payload, chain }) => {
|
|
9
|
+
const coin = getKeysignCoin(payload);
|
|
10
|
+
const toEvmBlockaidTxScanInput = ({ to, value, data, }) => {
|
|
11
|
+
const params = {
|
|
12
|
+
from: coin.address,
|
|
13
|
+
to,
|
|
14
|
+
value,
|
|
15
|
+
data,
|
|
16
|
+
};
|
|
17
|
+
return {
|
|
18
|
+
data: {
|
|
19
|
+
method: 'eth_sendTransaction',
|
|
20
|
+
params: [params],
|
|
21
|
+
},
|
|
22
|
+
chain: blockaidEvmChain[chain],
|
|
23
|
+
metadata: {
|
|
24
|
+
domain: productRootDomain,
|
|
25
|
+
},
|
|
26
|
+
options: ['simulation'],
|
|
27
|
+
};
|
|
28
|
+
};
|
|
29
|
+
const swapPayload = getKeysignSwapPayload(payload);
|
|
30
|
+
if (swapPayload) {
|
|
31
|
+
return matchRecordUnion(swapPayload, {
|
|
32
|
+
native: () => null,
|
|
33
|
+
general: generalSwapPayload => {
|
|
34
|
+
const { quote } = generalSwapPayload;
|
|
35
|
+
if (!quote?.tx) {
|
|
36
|
+
return null;
|
|
37
|
+
}
|
|
38
|
+
return toEvmBlockaidTxScanInput({
|
|
39
|
+
to: quote.tx.to,
|
|
40
|
+
value: quote.tx.value.startsWith('0x')
|
|
41
|
+
? quote.tx.value
|
|
42
|
+
: `0x${bigIntToHex(BigInt(quote.tx.value))}`,
|
|
43
|
+
data: quote.tx.data,
|
|
44
|
+
});
|
|
45
|
+
},
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
const amount = BigInt(payload.toAmount);
|
|
49
|
+
const receiver = payload.toAddress;
|
|
50
|
+
if (!coin.id) {
|
|
51
|
+
return toEvmBlockaidTxScanInput({
|
|
52
|
+
to: receiver,
|
|
53
|
+
value: `0x${bigIntToHex(amount)}`,
|
|
54
|
+
data: payload.memo || '0x',
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
return toEvmBlockaidTxScanInput({
|
|
58
|
+
to: coin.id,
|
|
59
|
+
value: `0x${bigIntToHex(amount)}`,
|
|
60
|
+
data: encodeFunctionData({
|
|
61
|
+
abi: erc20Abi,
|
|
62
|
+
functionName: 'transfer',
|
|
63
|
+
args: [receiver, amount],
|
|
64
|
+
}),
|
|
65
|
+
});
|
|
66
|
+
};
|
|
67
|
+
//# sourceMappingURL=evm.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"evm.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolvers/evm.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { OtherChain } from '@vultisig/core-chain/Chain';
|
|
2
|
+
import { BlockaidTxSimulationInputResolver } from '../resolver.js';
|
|
3
|
+
export declare const getSolanaBlockaidTxSimulationInput: BlockaidTxSimulationInputResolver<OtherChain.Solana>;
|
|
4
|
+
//# sourceMappingURL=solana.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solana.d.ts","sourceRoot":"","sources":["../../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolvers/solana.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,MAAM,4BAA4B,CAAA;AAKvD,OAAO,EAAE,iCAAiC,EAAE,MAAM,aAAa,CAAA;AAE/D,eAAO,MAAM,kCAAkC,EAAE,iCAAiC,CAChF,UAAU,CAAC,MAAM,CA4BlB,CAAA"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { decodeSigningOutput } from '@vultisig/core-chain/tw/signingOutput';
|
|
2
|
+
import { assertField } from '@vultisig/lib-utils/record/assertField';
|
|
3
|
+
import { getCompiledTxsForBlockaidInput } from '../../../utils/getCompiledTxsForBlockaidInput.js';
|
|
4
|
+
export const getSolanaBlockaidTxSimulationInput = ({ payload, walletCore, chain, raw }) => {
|
|
5
|
+
const coin = assertField(payload, 'coin');
|
|
6
|
+
if (raw && raw.length > 0) {
|
|
7
|
+
return {
|
|
8
|
+
chain: 'mainnet',
|
|
9
|
+
options: ['simulation'],
|
|
10
|
+
account_address: coin.address,
|
|
11
|
+
encoding: 'base58',
|
|
12
|
+
transactions: raw,
|
|
13
|
+
method: 'signAndSendTransaction',
|
|
14
|
+
metadata: {},
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
const transactions = getCompiledTxsForBlockaidInput({
|
|
18
|
+
payload,
|
|
19
|
+
walletCore,
|
|
20
|
+
}).map(tx => decodeSigningOutput(chain, tx).encoded);
|
|
21
|
+
return {
|
|
22
|
+
chain: 'mainnet',
|
|
23
|
+
options: ['simulation'],
|
|
24
|
+
account_address: coin.address,
|
|
25
|
+
encoding: 'base58',
|
|
26
|
+
transactions,
|
|
27
|
+
method: 'signAndSendTransaction',
|
|
28
|
+
metadata: {},
|
|
29
|
+
};
|
|
30
|
+
};
|
|
31
|
+
//# sourceMappingURL=solana.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"solana.js","sourceRoot":"","sources":["../../../../../../../../../../packages/core/mpc/security/blockaid/tx/simulation/input/resolvers/solana.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,mBAAmB,EAAE,MAAM,uCAAuC,CAAA;AAC3E,OAAO,EAAE,WAAW,EAAE,MAAM,wCAAwC,CAAA;AAEpE,OAAO,EAAE,8BAA8B,EAAE,MAAM,+CAA+C,CAAA;AAG9F,MAAM,CAAC,MAAM,kCAAkC,GAE3C,CAAC,EAAE,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,GAAG,EAAE,EAAE,EAAE;IAC1C,MAAM,IAAI,GAAG,WAAW,CAAC,OAAO,EAAE,MAAM,CAAC,CAAA;IACzC,IAAI,GAAG,IAAI,GAAG,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;QAC1B,OAAO;YACL,KAAK,EAAE,SAAS;YAChB,OAAO,EAAE,CAAC,YAAY,CAAC;YACvB,eAAe,EAAE,IAAI,CAAC,OAAO;YAC7B,QAAQ,EAAE,QAAQ;YAClB,YAAY,EAAE,GAAG;YACjB,MAAM,EAAE,wBAAwB;YAChC,QAAQ,EAAE,EAAE;SACb,CAAA;IACH,CAAC;IACD,MAAM,YAAY,GAAG,8BAA8B,CAAC;QAClD,OAAO;QACP,UAAU;KACX,CAAC,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,mBAAmB,CAAC,KAAK,EAAE,EAAE,CAAC,CAAC,OAAO,CAAC,CAAA;IAEpD,OAAO;QACL,KAAK,EAAE,SAAS;QAChB,OAAO,EAAE,CAAC,YAAY,CAAC;QACvB,eAAe,EAAE,IAAI,CAAC,OAAO;QAC7B,QAAQ,EAAE,QAAQ;QAClB,YAAY;QACZ,MAAM,EAAE,wBAAwB;QAChC,QAAQ,EAAE,EAAE;KACb,CAAA;AACH,CAAC,CAAA"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { WalletCore } from '@trustwallet/wallet-core';
|
|
2
|
+
import { KeysignPayload } from '../../../../types/vultisig/keysign/v1/keysign_message_pb.js';
|
|
3
|
+
type Input = {
|
|
4
|
+
payload: KeysignPayload;
|
|
5
|
+
walletCore: WalletCore;
|
|
6
|
+
};
|
|
7
|
+
export declare const getCompiledTxsForBlockaidInput: ({ payload, walletCore, }: Input) => Uint8Array<ArrayBufferLike>[];
|
|
8
|
+
export {};
|
|
9
|
+
//# sourceMappingURL=getCompiledTxsForBlockaidInput.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getCompiledTxsForBlockaidInput.d.ts","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAA;AAKrD,OAAO,EAAE,cAAc,EAAE,MAAM,0DAA0D,CAAA;AAGzF,KAAK,KAAK,GAAG;IACX,OAAO,EAAE,cAAc,CAAA;IACvB,UAAU,EAAE,UAAU,CAAA;CACvB,CAAA;AAED,eAAO,MAAM,8BAA8B,GAAI,0BAG5C,KAAK,kCAyDP,CAAA"}
|
|
@@ -0,0 +1,50 @@
|
|
|
1
|
+
import { getChainKind } from '@vultisig/core-chain/ChainKind';
|
|
2
|
+
import { getCoinType } from '@vultisig/core-chain/coin/coinType';
|
|
3
|
+
import { signatureFormats } from '@vultisig/core-chain/signing/SignatureFormat';
|
|
4
|
+
import { getTwPublicKeyType } from '@vultisig/core-chain/publicKey/tw/getTwPublicKeyType';
|
|
5
|
+
import { match } from '@vultisig/lib-utils/match';
|
|
6
|
+
import { getEncodedSigningInputs } from '../../../../keysign/signingInputs.js';
|
|
7
|
+
import { getKeysignTwPublicKey } from '../../../../keysign/tw/getKeysignTwPublicKey.js';
|
|
8
|
+
import { getKeysignChain } from '../../../../keysign/utils/getKeysignChain.js';
|
|
9
|
+
import { getPreSigningHashes } from '../../../../tx/preSigningHashes.js';
|
|
10
|
+
export const getCompiledTxsForBlockaidInput = ({ payload, walletCore, }) => {
|
|
11
|
+
const chain = getKeysignChain(payload);
|
|
12
|
+
const chainKind = getChainKind(chain);
|
|
13
|
+
const publicKeyData = getKeysignTwPublicKey(payload);
|
|
14
|
+
const publicKey = walletCore.PublicKey.createWithData(publicKeyData, getTwPublicKeyType({ walletCore, chain }));
|
|
15
|
+
const coinType = getCoinType({
|
|
16
|
+
chain,
|
|
17
|
+
walletCore,
|
|
18
|
+
});
|
|
19
|
+
const inputs = getEncodedSigningInputs({
|
|
20
|
+
keysignPayload: payload,
|
|
21
|
+
walletCore,
|
|
22
|
+
publicKey,
|
|
23
|
+
});
|
|
24
|
+
return inputs.map(txInputData => {
|
|
25
|
+
const preHashes = getPreSigningHashes({
|
|
26
|
+
walletCore,
|
|
27
|
+
txInputData,
|
|
28
|
+
chain,
|
|
29
|
+
});
|
|
30
|
+
const signatures = walletCore.DataVector.create();
|
|
31
|
+
const publicKeys = walletCore.DataVector.create();
|
|
32
|
+
preHashes.forEach(msg => match(signatureFormats[chainKind], {
|
|
33
|
+
raw: () => {
|
|
34
|
+
signatures.add(Buffer.alloc(64, 0));
|
|
35
|
+
publicKeys.add(publicKey.data());
|
|
36
|
+
},
|
|
37
|
+
rawWithRecoveryId: () => {
|
|
38
|
+
signatures.add(Buffer.alloc(65, 0));
|
|
39
|
+
publicKeys.add(publicKey.data());
|
|
40
|
+
},
|
|
41
|
+
der: () => {
|
|
42
|
+
const privateKey = walletCore.PrivateKey.create();
|
|
43
|
+
signatures.add(Buffer.from(privateKey.signAsDER(msg)));
|
|
44
|
+
publicKeys.add(privateKey.getPublicKeySecp256k1(true).data());
|
|
45
|
+
},
|
|
46
|
+
}));
|
|
47
|
+
return walletCore.TransactionCompiler.compileWithSignatures(coinType, txInputData, signatures, publicKeys);
|
|
48
|
+
});
|
|
49
|
+
};
|
|
50
|
+
//# sourceMappingURL=getCompiledTxsForBlockaidInput.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"getCompiledTxsForBlockaidInput.js","sourceRoot":"","sources":["../../../../../../../../packages/core/mpc/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,gCAAgC,CAAA;AAC7D,OAAO,EAAE,WAAW,EAAE,MAAM,oCAAoC,CAAA;AAChE,OAAO,EAAE,gBAAgB,EAAE,MAAM,8CAA8C,CAAA;AAC/E,OAAO,EAAE,kBAAkB,EAAE,MAAM,sDAAsD,CAAA;AACzF,OAAO,EAAE,KAAK,EAAE,MAAM,2BAA2B,CAAA;AAGjD,OAAO,EAAE,uBAAuB,EAAE,MAAM,mCAAmC,CAAA;AAC3E,OAAO,EAAE,qBAAqB,EAAE,MAAM,8CAA8C,CAAA;AACpF,OAAO,EAAE,eAAe,EAAE,MAAM,2CAA2C,CAAA;AAE3E,OAAO,EAAE,mBAAmB,EAAE,MAAM,iCAAiC,CAAA;AAOrE,MAAM,CAAC,MAAM,8BAA8B,GAAG,CAAC,EAC7C,OAAO,EACP,UAAU,GACJ,EAAE,EAAE;IACV,MAAM,KAAK,GAAG,eAAe,CAAC,OAAO,CAAC,CAAA;IACtC,MAAM,SAAS,GAAG,YAAY,CAAC,KAAK,CAAC,CAAA;IAErC,MAAM,aAAa,GAAG,qBAAqB,CAAC,OAAO,CAAC,CAAA;IACpD,MAAM,SAAS,GAAG,UAAU,CAAC,SAAS,CAAC,cAAc,CACnD,aAAa,EACb,kBAAkB,CAAC,EAAE,UAAU,EAAE,KAAK,EAAE,CAAC,CAC1C,CAAA;IAED,MAAM,QAAQ,GAAG,WAAW,CAAC;QAC3B,KAAK;QACL,UAAU;KACX,CAAC,CAAA;IAEF,MAAM,MAAM,GAAG,uBAAuB,CAAC;QACrC,cAAc,EAAE,OAAO;QACvB,UAAU;QACV,SAAS;KACV,CAAC,CAAA;IAEF,OAAO,MAAM,CAAC,GAAG,CAAC,WAAW,CAAC,EAAE;QAC9B,MAAM,SAAS,GAAG,mBAAmB,CAAC;YACpC,UAAU;YACV,WAAW;YACX,KAAK;SACN,CAAC,CAAA;QAEF,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,CAAA;QACjD,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,CAAA;QAEjD,SAAS,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE,CACtB,KAAK,CAAC,gBAAgB,CAAC,SAAS,CAAC,EAAE;YACjC,GAAG,EAAE,GAAG,EAAE;gBACR,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAA;gBACnC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAA;YAClC,CAAC;YACD,iBAAiB,EAAE,GAAG,EAAE;gBACtB,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAA;gBACnC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC,CAAA;YAClC,CAAC;YACD,GAAG,EAAE,GAAG,EAAE;gBACR,MAAM,UAAU,GAAG,UAAU,CAAC,UAAU,CAAC,MAAM,EAAE,CAAA;gBAEjD,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;gBACtD,UAAU,CAAC,GAAG,CAAC,UAAU,CAAC,qBAAqB,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,CAAC,CAAA;YAC/D,CAAC;SACF,CAAC,CACH,CAAA;QAED,OAAO,UAAU,CAAC,mBAAmB,CAAC,qBAAqB,CACzD,QAAQ,EACR,WAAW,EACX,UAAU,EACV,UAAU,CACX,CAAA;IACH,CAAC,CAAC,CAAA;AACJ,CAAC,CAAA"}
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
import { BlockaidTxValidationInput } from '@vultisig/core-chain/security/blockaid/tx/validation/resolver';
|
|
2
|
+
import { BlockaidTxValidationInputResolverInput } from './resolver.js';
|
|
3
|
+
export declare const getBlockaidTxValidationInput: (input: Omit<BlockaidTxValidationInputResolverInput, "chain">) => BlockaidTxValidationInput | null;
|
|
4
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../../../../../packages/core/mpc/security/blockaid/tx/validation/input/index.ts"],"names":[],"mappings":"AAKA,OAAO,EAAE,yBAAyB,EAAE,MAAM,+DAA+D,CAAA;AAIzG,OAAO,EAEL,sCAAsC,EACvC,MAAM,YAAY,CAAA;AAgBnB,eAAO,MAAM,4BAA4B,GACvC,OAAO,IAAI,CAAC,sCAAsC,EAAE,OAAO,CAAC,KAC3D,yBAAyB,GAAG,IAkB9B,CAAA"}
|