@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.
Files changed (209) hide show
  1. package/CHANGELOG.md +28 -0
  2. package/dist/chains/cosmos/qbtc/QBTCHelper.d.ts +25 -0
  3. package/dist/chains/cosmos/qbtc/QBTCHelper.d.ts.map +1 -0
  4. package/dist/chains/cosmos/qbtc/QBTCHelper.js +158 -0
  5. package/dist/chains/cosmos/qbtc/QBTCHelper.js.map +1 -0
  6. package/dist/dkls/dkls.d.ts +6 -3
  7. package/dist/dkls/dkls.d.ts.map +1 -1
  8. package/dist/dkls/dkls.js +102 -57
  9. package/dist/dkls/dkls.js.map +1 -1
  10. package/dist/fast/api/batchReshareWithServer.d.ts +19 -0
  11. package/dist/fast/api/batchReshareWithServer.d.ts.map +1 -0
  12. package/dist/fast/api/batchReshareWithServer.js +7 -0
  13. package/dist/fast/api/batchReshareWithServer.js.map +1 -0
  14. package/dist/fast/api/createVaultWithServer.d.ts +14 -0
  15. package/dist/fast/api/createVaultWithServer.d.ts.map +1 -0
  16. package/dist/fast/api/createVaultWithServer.js +7 -0
  17. package/dist/fast/api/createVaultWithServer.js.map +1 -0
  18. package/dist/fast/api/keyImportWithServer.d.ts +3 -2
  19. package/dist/fast/api/keyImportWithServer.d.ts.map +1 -1
  20. package/dist/fast/api/keyImportWithServer.js +2 -2
  21. package/dist/fast/api/keyImportWithServer.js.map +1 -1
  22. package/dist/fast/api/reshareWithServer.d.ts +3 -1
  23. package/dist/fast/api/reshareWithServer.d.ts.map +1 -1
  24. package/dist/fast/api/reshareWithServer.js +2 -2
  25. package/dist/fast/api/reshareWithServer.js.map +1 -1
  26. package/dist/fast/api/sequentialKeyImportWithServer.d.ts +15 -0
  27. package/dist/fast/api/sequentialKeyImportWithServer.d.ts.map +1 -0
  28. package/dist/fast/api/sequentialKeyImportWithServer.js +7 -0
  29. package/dist/fast/api/sequentialKeyImportWithServer.js.map +1 -0
  30. package/dist/fast/api/setupVaultWithServer.d.ts +2 -1
  31. package/dist/fast/api/setupVaultWithServer.d.ts.map +1 -1
  32. package/dist/fast/api/setupVaultWithServer.js +1 -1
  33. package/dist/fast/api/setupVaultWithServer.js.map +1 -1
  34. package/dist/keygen/KeygenStep.d.ts +1 -1
  35. package/dist/keygen/KeygenStep.d.ts.map +1 -1
  36. package/dist/keygen/KeygenStep.js +7 -1
  37. package/dist/keygen/KeygenStep.js.map +1 -1
  38. package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts +1 -0
  39. package/dist/keysign/chainSpecific/KeysignChainSpecific.d.ts.map +1 -1
  40. package/dist/keysign/chainSpecific/KeysignChainSpecific.js +1 -0
  41. package/dist/keysign/chainSpecific/KeysignChainSpecific.js.map +1 -1
  42. package/dist/keysign/chainSpecific/index.d.ts.map +1 -1
  43. package/dist/keysign/chainSpecific/index.js +2 -0
  44. package/dist/keysign/chainSpecific/index.js.map +1 -1
  45. package/dist/keysign/chainSpecific/resolvers/qbtc.d.ts +3 -0
  46. package/dist/keysign/chainSpecific/resolvers/qbtc.d.ts.map +1 -0
  47. package/dist/keysign/chainSpecific/resolvers/qbtc.js +25 -0
  48. package/dist/keysign/chainSpecific/resolvers/qbtc.js.map +1 -0
  49. package/dist/keysign/chainSpecific/resolvers/solana/index.js +1 -1
  50. package/dist/keysign/chainSpecific/resolvers/solana/index.js.map +1 -1
  51. package/dist/keysign/cosigner.js +1 -1
  52. package/dist/keysign/cosigner.js.map +1 -1
  53. package/dist/keysign/fee/index.d.ts.map +1 -1
  54. package/dist/keysign/fee/index.js +2 -0
  55. package/dist/keysign/fee/index.js.map +1 -1
  56. package/dist/keysign/fee/resolvers/qbtc.d.ts +3 -0
  57. package/dist/keysign/fee/resolvers/qbtc.d.ts.map +1 -0
  58. package/dist/keysign/fee/resolvers/qbtc.js +6 -0
  59. package/dist/keysign/fee/resolvers/qbtc.js.map +1 -0
  60. package/dist/keysign/index.d.ts.map +1 -1
  61. package/dist/keysign/index.js +28 -19
  62. package/dist/keysign/index.js.map +1 -1
  63. package/dist/keysign/preSigningOutput/index.d.ts +1 -0
  64. package/dist/keysign/preSigningOutput/index.d.ts.map +1 -1
  65. package/dist/keysign/preSigningOutput/index.js +1 -0
  66. package/dist/keysign/preSigningOutput/index.js.map +1 -1
  67. package/dist/keysign/send/build.d.ts +4 -2
  68. package/dist/keysign/send/build.d.ts.map +1 -1
  69. package/dist/keysign/send/build.js +19 -10
  70. package/dist/keysign/send/build.js.map +1 -1
  71. package/dist/keysign/send/getSendFeeEstimate.d.ts.map +1 -1
  72. package/dist/keysign/send/getSendFeeEstimate.js +9 -1
  73. package/dist/keysign/send/getSendFeeEstimate.js.map +1 -1
  74. package/dist/keysign/setupMessage/make.d.ts.map +1 -1
  75. package/dist/keysign/setupMessage/make.js +12 -2
  76. package/dist/keysign/setupMessage/make.js.map +1 -1
  77. package/dist/keysign/signingInputs/core.d.ts +1 -0
  78. package/dist/keysign/signingInputs/core.d.ts.map +1 -1
  79. package/dist/keysign/signingInputs/core.js +1 -0
  80. package/dist/keysign/signingInputs/core.js.map +1 -1
  81. package/dist/keysign/signingInputs/index.d.ts.map +1 -1
  82. package/dist/keysign/signingInputs/index.js +3 -1
  83. package/dist/keysign/signingInputs/index.js.map +1 -1
  84. package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.d.ts +3 -0
  85. package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.d.ts.map +1 -0
  86. package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.js +17 -0
  87. package/dist/keysign/signingInputs/resolvers/evm/incrementKeysignPayloadNonce.js.map +1 -0
  88. package/dist/keysign/signingInputs/resolvers/evm/index.js +1 -1
  89. package/dist/keysign/signingInputs/resolvers/evm/index.js.map +1 -1
  90. package/dist/keysign/signingInputs/resolvers/qbtc.d.ts +5 -0
  91. package/dist/keysign/signingInputs/resolvers/qbtc.d.ts.map +1 -0
  92. package/dist/keysign/signingInputs/resolvers/qbtc.js +4 -0
  93. package/dist/keysign/signingInputs/resolvers/qbtc.js.map +1 -0
  94. package/dist/keysign/signingInputs/resolvers/ton/index.d.ts.map +1 -1
  95. package/dist/keysign/signingInputs/resolvers/ton/index.js +25 -13
  96. package/dist/keysign/signingInputs/resolvers/ton/index.js.map +1 -1
  97. package/dist/keysign/signingInputs/resolvers/ton/jetton.d.ts.map +1 -1
  98. package/dist/keysign/signingInputs/resolvers/ton/jetton.js +2 -1
  99. package/dist/keysign/signingInputs/resolvers/ton/jetton.js.map +1 -1
  100. package/dist/keysign/signingInputs/resolvers/ton/native.d.ts +9 -0
  101. package/dist/keysign/signingInputs/resolvers/ton/native.d.ts.map +1 -1
  102. package/dist/keysign/signingInputs/resolvers/ton/native.js +31 -3
  103. package/dist/keysign/signingInputs/resolvers/ton/native.js.map +1 -1
  104. package/dist/keysign/swap/build.js +1 -1
  105. package/dist/keysign/swap/build.js.map +1 -1
  106. package/dist/keysign/utxo/getKeysignUtxoInfo.d.ts.map +1 -1
  107. package/dist/keysign/utxo/getKeysignUtxoInfo.js +11 -2
  108. package/dist/keysign/utxo/getKeysignUtxoInfo.js.map +1 -1
  109. package/dist/lib/initialize.d.ts.map +1 -1
  110. package/dist/lib/initialize.js +2 -0
  111. package/dist/lib/initialize.js.map +1 -1
  112. package/dist/lib/keyshare.d.ts +2 -1
  113. package/dist/lib/keyshare.d.ts.map +1 -1
  114. package/dist/lib/keyshare.js +2 -0
  115. package/dist/lib/keyshare.js.map +1 -1
  116. package/dist/lib/signSession.d.ts +3 -2
  117. package/dist/lib/signSession.d.ts.map +1 -1
  118. package/dist/lib/signSession.js +4 -1
  119. package/dist/lib/signSession.js.map +1 -1
  120. package/dist/mldsa/mldsaKeygen.d.ts +4 -0
  121. package/dist/mldsa/mldsaKeygen.d.ts.map +1 -1
  122. package/dist/mldsa/mldsaKeygen.js +9 -5
  123. package/dist/mldsa/mldsaKeygen.js.map +1 -1
  124. package/dist/mpcLib.d.ts +3 -3
  125. package/dist/mpcLib.d.ts.map +1 -1
  126. package/dist/schnorr/schnorrKeygen.d.ts +5 -3
  127. package/dist/schnorr/schnorrKeygen.d.ts.map +1 -1
  128. package/dist/schnorr/schnorrKeygen.js +72 -40
  129. package/dist/schnorr/schnorrKeygen.js.map +1 -1
  130. package/dist/security/blockaid/tx/simulation/input/index.d.ts +4 -0
  131. package/dist/security/blockaid/tx/simulation/input/index.d.ts.map +1 -0
  132. package/dist/security/blockaid/tx/simulation/input/index.js +26 -0
  133. package/dist/security/blockaid/tx/simulation/input/index.js.map +1 -0
  134. package/dist/security/blockaid/tx/simulation/input/resolver.d.ts +18 -0
  135. package/dist/security/blockaid/tx/simulation/input/resolver.d.ts.map +1 -0
  136. package/dist/security/blockaid/tx/simulation/input/resolver.js +2 -0
  137. package/dist/security/blockaid/tx/simulation/input/resolver.js.map +1 -0
  138. package/dist/security/blockaid/tx/simulation/input/resolvers/evm.d.ts +4 -0
  139. package/dist/security/blockaid/tx/simulation/input/resolvers/evm.d.ts.map +1 -0
  140. package/dist/security/blockaid/tx/simulation/input/resolvers/evm.js +67 -0
  141. package/dist/security/blockaid/tx/simulation/input/resolvers/evm.js.map +1 -0
  142. package/dist/security/blockaid/tx/simulation/input/resolvers/solana.d.ts +4 -0
  143. package/dist/security/blockaid/tx/simulation/input/resolvers/solana.d.ts.map +1 -0
  144. package/dist/security/blockaid/tx/simulation/input/resolvers/solana.js +31 -0
  145. package/dist/security/blockaid/tx/simulation/input/resolvers/solana.js.map +1 -0
  146. package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.d.ts +9 -0
  147. package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.d.ts.map +1 -0
  148. package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.js +50 -0
  149. package/dist/security/blockaid/tx/utils/getCompiledTxsForBlockaidInput.js.map +1 -0
  150. package/dist/security/blockaid/tx/validation/input/index.d.ts +4 -0
  151. package/dist/security/blockaid/tx/validation/input/index.d.ts.map +1 -0
  152. package/dist/security/blockaid/tx/validation/input/index.js +30 -0
  153. package/dist/security/blockaid/tx/validation/input/index.js.map +1 -0
  154. package/dist/security/blockaid/tx/validation/input/resolver.d.ts +16 -0
  155. package/dist/security/blockaid/tx/validation/input/resolver.d.ts.map +1 -0
  156. package/dist/security/blockaid/tx/validation/input/resolver.js +2 -0
  157. package/dist/security/blockaid/tx/validation/input/resolver.js.map +1 -0
  158. package/dist/security/blockaid/tx/validation/input/resolvers/evm.d.ts +4 -0
  159. package/dist/security/blockaid/tx/validation/input/resolvers/evm.d.ts.map +1 -0
  160. package/dist/security/blockaid/tx/validation/input/resolvers/evm.js +58 -0
  161. package/dist/security/blockaid/tx/validation/input/resolvers/evm.js.map +1 -0
  162. package/dist/security/blockaid/tx/validation/input/resolvers/solana.d.ts +4 -0
  163. package/dist/security/blockaid/tx/validation/input/resolvers/solana.d.ts.map +1 -0
  164. package/dist/security/blockaid/tx/validation/input/resolvers/solana.js +20 -0
  165. package/dist/security/blockaid/tx/validation/input/resolvers/solana.js.map +1 -0
  166. package/dist/security/blockaid/tx/validation/input/resolvers/sui.d.ts +4 -0
  167. package/dist/security/blockaid/tx/validation/input/resolvers/sui.d.ts.map +1 -0
  168. package/dist/security/blockaid/tx/validation/input/resolvers/sui.js +20 -0
  169. package/dist/security/blockaid/tx/validation/input/resolvers/sui.js.map +1 -0
  170. package/dist/security/blockaid/tx/validation/input/resolvers/utxo.d.ts +4 -0
  171. package/dist/security/blockaid/tx/validation/input/resolvers/utxo.d.ts.map +1 -0
  172. package/dist/security/blockaid/tx/validation/input/resolvers/utxo.js +19 -0
  173. package/dist/security/blockaid/tx/validation/input/resolvers/utxo.js.map +1 -0
  174. package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.d.ts +16 -0
  175. package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.d.ts.map +1 -0
  176. package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.js +31 -0
  177. package/dist/swap/native/utils/nativeSwapQuoteToSwapPayload.js.map +1 -0
  178. package/dist/swap/utils/getSwapTrackingUrl.d.ts +10 -0
  179. package/dist/swap/utils/getSwapTrackingUrl.d.ts.map +1 -0
  180. package/dist/swap/utils/getSwapTrackingUrl.js +29 -0
  181. package/dist/swap/utils/getSwapTrackingUrl.js.map +1 -0
  182. package/dist/tx/compile/compileTx.d.ts +14 -0
  183. package/dist/tx/compile/compileTx.d.ts.map +1 -0
  184. package/dist/tx/compile/compileTx.js +85 -0
  185. package/dist/tx/compile/compileTx.js.map +1 -0
  186. package/dist/tx/preSigningHashes/index.d.ts +10 -0
  187. package/dist/tx/preSigningHashes/index.d.ts.map +1 -0
  188. package/dist/tx/preSigningHashes/index.js +41 -0
  189. package/dist/tx/preSigningHashes/index.js.map +1 -0
  190. package/dist/tx/signature/generateSignature.d.ts +11 -0
  191. package/dist/tx/signature/generateSignature.d.ts.map +1 -0
  192. package/dist/tx/signature/generateSignature.js +20 -0
  193. package/dist/tx/signature/generateSignature.js.map +1 -0
  194. package/dist/types/utils/libType.d.ts +1 -2
  195. package/dist/types/utils/libType.d.ts.map +1 -1
  196. package/dist/types/utils/libType.js +2 -6
  197. package/dist/types/utils/libType.js.map +1 -1
  198. package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts +7 -1
  199. package/dist/types/vultisig/keysign/v1/keysign_message_pb.d.ts.map +1 -1
  200. package/dist/types/vultisig/keysign/v1/keysign_message_pb.js +1 -1
  201. package/dist/types/vultisig/keysign/v1/keysign_message_pb.js.map +1 -1
  202. package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts +36 -0
  203. package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.d.ts.map +1 -1
  204. package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js +12 -2
  205. package/dist/types/vultisig/keysign/v1/wasm_execute_contract_payload_pb.js.map +1 -1
  206. package/dist/vault/Vault.d.ts +4 -2
  207. package/dist/vault/Vault.d.ts.map +1 -1
  208. package/dist/vault/Vault.js.map +1 -1
  209. 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: 'eddsa',
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: 'eddsa',
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 startKeyImport(hexPrivateKey, hexChainCode, attempt, additionalHeader) {
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
- const privateKey = Buffer.from(hexPrivateKey, 'hex');
282
- const chainCode = Buffer.from(hexChainCode, 'hex');
283
- const initiatorSession = new KeyImportInitiator(Uint8Array.from(privateKey), Uint8Array.from(chainCode), getKeygenThreshold(this.keygenCommittee.length), this.keygenCommittee);
284
- this.setupMessage = initiatorSession.setup;
285
- session = initiatorSession;
286
- // upload setup message to server
287
- const encryptedSetupMsg = toMpcServerMessage(this.setupMessage, this.hexEncryptionKey);
288
- await uploadMpcSetupMessage({
289
- serverUrl: this.serverURL,
290
- message: encryptedSetupMsg,
291
- sessionId: this.sessionId,
292
- messageId: additionalHeader ?? 'eddsa_key_import',
293
- });
294
- console.log('uploaded setup message successfully');
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: additionalHeader ?? 'eddsa_key_import',
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, additionalHeader) {
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, additionalHeader);
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,2 @@
1
+ export {};
2
+ //# sourceMappingURL=resolver.js.map
@@ -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"}