@talken/talkenkit 2.5.2 → 2.5.4

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 (71) hide show
  1. package/dist/{AbcCredentialManager-5W3B7GI4.js → AbcCredentialManager-JV4ZBMKF.js} +1 -1
  2. package/dist/TalkenApiSingleton-TECFDCT4.js +9 -0
  3. package/dist/{abcWallet-HRNBHY5Q.js → abcWallet-QJ5BKEXW.js} +3 -2
  4. package/dist/{chunk-PN6K4CMZ.js → chunk-DNEDHHS4.js} +23 -1
  5. package/dist/chunk-R6ZE7JAZ.js +15 -0
  6. package/dist/{chunk-VCQZZ6SN.js → chunk-YORGXWYS.js} +218 -80
  7. package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthFlow.d.ts +6 -32
  8. package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthSections.d.ts +0 -9
  9. package/dist/components/ConnectOptions/AbcWaasAuth/hooks/useAbcWaasAuth.d.ts +3 -12
  10. package/dist/components/ConnectOptions/AbcWaasAuth/types.d.ts +1 -8
  11. package/dist/components/ConnectOptions/PinAuth/PinAuthFlow.d.ts +6 -4
  12. package/dist/components/ProfileDetails/ProfileDetails.d.ts +5 -5
  13. package/dist/hooks/useMultiChainBalances.d.ts +9 -0
  14. package/dist/index.js +1420 -1466
  15. package/dist/klipWallet-TBZJ5GGT.js +7 -0
  16. package/dist/wallets/walletConnectors/abcWallet/AbcCredentialManager.js +2 -2
  17. package/dist/wallets/walletConnectors/abcWallet/AbcEvmAutoConnector.js +2 -2
  18. package/dist/wallets/walletConnectors/abcWallet/abcAccessKeyProvider.d.ts +4 -0
  19. package/dist/wallets/walletConnectors/abcWallet/abcAccessKeyProvider.js +3 -3
  20. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +3 -3
  21. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +3 -3
  22. package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +7 -7
  23. package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +4 -4
  24. package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +7 -7
  25. package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +44 -45
  26. package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +3 -3
  27. package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +8 -8
  28. package/dist/wallets/walletConnectors/abcWallet/api/ConfigApi.js +2 -2
  29. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +44 -0
  30. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +3 -3
  31. package/dist/wallets/walletConnectors/abcWallet/api/TokenApi.js +2 -2
  32. package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +3 -3
  33. package/dist/wallets/walletConnectors/abcWallet/api/index.js +6 -6
  34. package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +3 -0
  35. package/dist/wallets/walletConnectors/abcWallet/constants.js +5 -3
  36. package/dist/wallets/walletConnectors/abcWallet/index.js +31 -31
  37. package/dist/wallets/walletConnectors/abcWallet/sessionUtils.js +2 -2
  38. package/dist/wallets/walletConnectors/abcWallet/types.d.ts +4 -0
  39. package/dist/wallets/walletConnectors/abcWallet/utils.js +2 -2
  40. package/dist/wallets/walletConnectors/abcWallet/walletGeneration.js +3 -3
  41. package/dist/wallets/walletConnectors/{chunk-QKK3OPQA.js → chunk-36BJXEBA.js} +1 -1
  42. package/dist/wallets/walletConnectors/{chunk-FKI5AZVH.js → chunk-3K3KYVRN.js} +1 -1
  43. package/dist/wallets/walletConnectors/{chunk-URS2KVYK.js → chunk-5DK36WJ2.js} +1 -1
  44. package/dist/wallets/walletConnectors/{chunk-ASYCOXE6.js → chunk-5ERWBR7D.js} +132 -28
  45. package/dist/wallets/walletConnectors/{chunk-RX2VOIUB.js → chunk-6KRX73ED.js} +25 -3
  46. package/dist/wallets/walletConnectors/{chunk-H2AZTZMM.js → chunk-6L5G54IX.js} +1 -1
  47. package/dist/wallets/walletConnectors/{chunk-RGYZNNB6.js → chunk-C4ADBB6M.js} +1 -1
  48. package/dist/wallets/walletConnectors/{chunk-4JZPP3S7.js → chunk-E6ZG77AF.js} +27 -1
  49. package/dist/wallets/walletConnectors/{chunk-PF65YS3T.js → chunk-EBTKWCIS.js} +3 -2
  50. package/dist/wallets/walletConnectors/{chunk-25ZDAJ3L.js → chunk-EZS3GXZN.js} +1 -1
  51. package/dist/wallets/walletConnectors/{chunk-WKP53WWR.js → chunk-G6SV7RAS.js} +8 -7
  52. package/dist/wallets/walletConnectors/chunk-HKMJ67FD.js +37 -0
  53. package/dist/wallets/walletConnectors/{chunk-L6FCF3FH.js → chunk-L3HWFGTN.js} +2 -2
  54. package/dist/wallets/walletConnectors/{chunk-LIGH2LEU.js → chunk-PVPSVCVQ.js} +1 -1
  55. package/dist/wallets/walletConnectors/{chunk-2A5XTST5.js → chunk-SDRE2D5I.js} +29 -11
  56. package/dist/wallets/walletConnectors/{chunk-HWRZGGGN.js → chunk-VBNZ7HA3.js} +1 -1
  57. package/dist/wallets/walletConnectors/{chunk-YKFI6ZGM.js → chunk-VLHDGDFH.js} +1 -1
  58. package/dist/wallets/walletConnectors/{chunk-645DT4TS.js → chunk-ZLH3W5PQ.js} +2 -2
  59. package/dist/wallets/walletConnectors/index.d.ts +2 -1
  60. package/dist/wallets/walletConnectors/index.js +57 -53
  61. package/dist/wallets/walletConnectors/klipWallet/klipWallet.js +3 -63
  62. package/dist/wallets/walletConnectors/klipWallet-TBZJ5GGT.js +7 -0
  63. package/package.json +1 -1
  64. package/dist/wallets/walletConnectors/chunk-4PDTJS5L.js +0 -57
  65. package/dist/wallets/walletConnectors/chunk-BRXYKYKT.js +0 -360
  66. package/dist/wallets/walletConnectors/chunk-IPH3SIC3.js +0 -57
  67. package/dist/wallets/walletConnectors/chunk-JBOKTW2Q.js +0 -360
  68. package/dist/wallets/walletConnectors/chunk-MIX4TRKO.js +0 -194
  69. package/dist/wallets/walletConnectors/chunk-NP5PWUVU.js +0 -873
  70. package/dist/wallets/walletConnectors/chunk-TVZHPWFR.js +0 -843
  71. package/dist/wallets/walletConnectors/klipWallet-PPTYYB5G.js +0 -7
@@ -1,360 +0,0 @@
1
- "use client";
2
- import {
3
- setTalkenApiClient
4
- } from "./chunk-R6ZE7JAZ.js";
5
- import {
6
- resolveTalkenApiUrl
7
- } from "./chunk-GFWUFYT2.js";
8
- import {
9
- createTalkenApiClient
10
- } from "./chunk-ASYCOXE6.js";
11
- import {
12
- AbcAccessKeyProvider
13
- } from "./chunk-4JZPP3S7.js";
14
- import {
15
- setGlobalDefaultBitcoinNetwork,
16
- setGlobalDefaultChainId,
17
- setGlobalDefaultSolanaNetwork
18
- } from "./chunk-O4AU63LK.js";
19
- import {
20
- createAbcEvmProvider
21
- } from "./chunk-TVZHPWFR.js";
22
- import {
23
- getCredentialManager
24
- } from "./chunk-QKK3OPQA.js";
25
- import {
26
- clearAuthState,
27
- clearStorage,
28
- loadAuthState,
29
- loadFromStorage,
30
- saveAuthState
31
- } from "./chunk-PF65YS3T.js";
32
-
33
- // src/wallets/walletConnectors/abcWallet/abcConnector.ts
34
- import { getTalkenApiClient } from "@talken/talkenkit";
35
- import { createConnector } from "wagmi";
36
- function abcConnector(options) {
37
- const { config } = options;
38
- if (config.defaultChainId) {
39
- setGlobalDefaultChainId(config.defaultChainId);
40
- }
41
- if (config.defaultSolanaNetwork) {
42
- setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
43
- }
44
- if (config.defaultBitcoinNetwork) {
45
- setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
46
- }
47
- return createConnector((wagmiConfig) => {
48
- const talkenApi = getTalkenApiClient() || createTalkenApiClient({
49
- baseUrl: resolveTalkenApiUrl(config.talkenApiUrl),
50
- environment: config.environment,
51
- debug: config.environment === "development",
52
- defaultChainId: config.defaultChainId
53
- });
54
- setTalkenApiClient(talkenApi);
55
- const isAccessKeyMode = !!config.accessKey;
56
- const provider = isAccessKeyMode ? new AbcAccessKeyProvider(
57
- config.accessKey,
58
- resolveTalkenApiUrl(config.talkenApiUrl)
59
- ) : createAbcEvmProvider(talkenApi);
60
- let accountsChangedHandler;
61
- let chainChangedHandler;
62
- let disconnectHandler;
63
- return {
64
- id: "abc",
65
- name: "ABC Wallet",
66
- type: "abc",
67
- /**
68
- * Connect wallet
69
- */
70
- async connect() {
71
- try {
72
- const authState = loadAuthState();
73
- if (!authState || !authState.isAuthenticated || !authState.wallet) {
74
- throw new Error("ABC_LOGIN_REQUIRED");
75
- }
76
- if (isAccessKeyMode) {
77
- let w = authState.wallet;
78
- if (!w.uid || !w.sessionId) {
79
- try {
80
- const apiUrl = resolveTalkenApiUrl(config.talkenApiUrl);
81
- const res = await fetch(`${apiUrl}/wallet/mpc`, {
82
- method: "POST",
83
- headers: {
84
- "Content-Type": "application/json",
85
- "X-Access-Key": config.accessKey
86
- },
87
- body: JSON.stringify({ action: "info" })
88
- });
89
- const data = await res.json();
90
- const acct = data?.data?.accounts?.[0] || data?.data;
91
- if (acct?.ethAddress || acct?.address) {
92
- w = {
93
- address: acct.ethAddress || acct.address || w.address,
94
- chainId: w.chainId || config.defaultChainId || 1,
95
- uid: acct.uid || data?.data?.uid || "",
96
- sessionId: acct.sid || acct.sessionId || "",
97
- keyId: acct.keyId || (acct.wid != null ? String(acct.wid) : "") || (data?.data?.wid != null ? String(data.data.wid) : ""),
98
- encryptedShare: acct.encryptedShare || acct.pvencstr || "",
99
- sid: acct.sid || "",
100
- type: "evm",
101
- email: authState.user?.email || acct.email || data?.data?.email || ""
102
- };
103
- saveAuthState({ ...authState, wallet: w });
104
- }
105
- } catch (_) {
106
- }
107
- }
108
- const fullWallet = {
109
- address: w.address,
110
- chainId: w.chainId || config.defaultChainId || 1,
111
- uid: w.uid || "",
112
- sessionId: w.sessionId || "",
113
- keyId: w.keyId || "",
114
- encryptedShare: w.encryptedShare || "",
115
- sid: w.sid || "",
116
- type: "evm",
117
- email: w.email || authState.user?.email || ""
118
- };
119
- provider.setWallet(fullWallet);
120
- } else {
121
- provider.setWallet(authState.wallet);
122
- if (authState.accessToken && authState.refreshToken && authState.expiresAt) {
123
- talkenApi.setTokens(
124
- authState.accessToken,
125
- authState.refreshToken,
126
- authState.expiresAt
127
- );
128
- }
129
- }
130
- const accounts = await provider.request({
131
- method: "eth_requestAccounts"
132
- });
133
- let currentChainId = await provider.request({
134
- method: "eth_chainId"
135
- });
136
- const currentChainIdNumber = Number(currentChainId);
137
- const isChainSupported = wagmiConfig.chains.some(
138
- (c) => c.id === currentChainIdNumber
139
- );
140
- if (!isChainSupported && wagmiConfig.chains.length > 0) {
141
- const fallbackChainId = wagmiConfig.chains[0].id;
142
- await provider.request({
143
- method: "wallet_switchEthereumChain",
144
- params: [{ chainId: `0x${fallbackChainId.toString(16)}` }]
145
- });
146
- currentChainId = `0x${fallbackChainId.toString(16)}`;
147
- if (authState.wallet) {
148
- authState.wallet.chainId = fallbackChainId;
149
- saveAuthState(authState);
150
- }
151
- }
152
- if (accountsChangedHandler) {
153
- provider.removeListener("accountsChanged", accountsChangedHandler);
154
- }
155
- accountsChangedHandler = (accounts2) => {
156
- wagmiConfig.emitter.emit("change", {
157
- accounts: accounts2
158
- });
159
- };
160
- provider.on("accountsChanged", accountsChangedHandler);
161
- if (chainChangedHandler) {
162
- provider.removeListener("chainChanged", chainChangedHandler);
163
- }
164
- chainChangedHandler = (chainId) => {
165
- wagmiConfig.emitter.emit("change", {
166
- chainId: Number(chainId)
167
- });
168
- };
169
- provider.on("chainChanged", chainChangedHandler);
170
- if (disconnectHandler) {
171
- provider.removeListener("disconnect", disconnectHandler);
172
- }
173
- disconnectHandler = () => {
174
- wagmiConfig.emitter.emit("disconnect");
175
- this.onDisconnect();
176
- };
177
- provider.on("disconnect", disconnectHandler);
178
- wagmiConfig.emitter.emit("connect", {
179
- accounts,
180
- chainId: Number(currentChainId)
181
- });
182
- return {
183
- accounts,
184
- chainId: Number(currentChainId)
185
- };
186
- } catch (error) {
187
- console.error("\u274C ABC Connector connect() failed:", {
188
- message: error.message,
189
- code: error.code,
190
- error
191
- });
192
- if (error.message === "ABC_LOGIN_REQUIRED") {
193
- throw error;
194
- }
195
- throw error;
196
- }
197
- },
198
- /**
199
- * Disconnect wallet
200
- */
201
- async disconnect() {
202
- if (accountsChangedHandler) {
203
- provider.removeListener("accountsChanged", accountsChangedHandler);
204
- accountsChangedHandler = void 0;
205
- }
206
- if (chainChangedHandler) {
207
- provider.removeListener("chainChanged", chainChangedHandler);
208
- chainChangedHandler = void 0;
209
- }
210
- if (disconnectHandler) {
211
- provider.removeListener("disconnect", disconnectHandler);
212
- disconnectHandler = void 0;
213
- }
214
- provider.clearWallet();
215
- talkenApi.auth.logout();
216
- clearAuthState();
217
- getCredentialManager().clear();
218
- },
219
- /**
220
- * Get accounts
221
- */
222
- async getAccounts() {
223
- const accounts = await provider.request({
224
- method: "eth_accounts"
225
- });
226
- return accounts.map((account) => account);
227
- },
228
- /**
229
- * Get chain ID
230
- */
231
- async getChainId() {
232
- const chainId = await provider.request({
233
- method: "eth_chainId"
234
- });
235
- return Number(chainId);
236
- },
237
- /**
238
- * Get provider
239
- */
240
- async getProvider() {
241
- return provider;
242
- },
243
- /**
244
- * Check if authorized (has valid session)
245
- * Auto-refreshes access token if expired but refresh token is valid
246
- */
247
- async isAuthorized() {
248
- try {
249
- if (isAccessKeyMode) {
250
- if (provider.isConnected())
251
- return true;
252
- const hasKey = !!config.accessKey || typeof localStorage !== "undefined" && !!localStorage.getItem("talken_ak");
253
- const authState2 = loadAuthState();
254
- return hasKey && !!authState2?.wallet?.address;
255
- }
256
- const authState = loadAuthState();
257
- if (!authState || !authState.isAuthenticated) {
258
- return false;
259
- }
260
- if (!authState.wallet) {
261
- return false;
262
- }
263
- if (talkenApi.isAuthenticated()) {
264
- return true;
265
- }
266
- const refreshToken = loadFromStorage(
267
- "refresh_token" /* REFRESH_TOKEN */
268
- );
269
- if (!refreshToken) {
270
- clearStorage();
271
- return false;
272
- }
273
- try {
274
- const api = getTalkenApiClient();
275
- if (!api) {
276
- clearStorage();
277
- return false;
278
- }
279
- const res = await api.auth.refresh();
280
- talkenApi.setTokens(
281
- res.accessToken,
282
- res.refreshToken,
283
- Date.now() + res.expiresIn * 1e3
284
- );
285
- const updatedState = loadAuthState();
286
- return updatedState?.isAuthenticated ?? false;
287
- } catch (error) {
288
- console.error("[AbcConnector] Token refresh failed:", error);
289
- clearStorage();
290
- return false;
291
- }
292
- } catch (error) {
293
- console.error(
294
- "[AbcConnector] Unexpected error in isAuthorized:",
295
- error
296
- );
297
- return false;
298
- }
299
- },
300
- /**
301
- * Switch chain
302
- */
303
- async switchChain({ chainId }) {
304
- await provider.request({
305
- method: "wallet_switchEthereumChain",
306
- params: [{ chainId: `0x${chainId.toString(16)}` }]
307
- });
308
- const newChainId = await this.getChainId();
309
- const authState = loadAuthState();
310
- if (authState?.wallet) {
311
- authState.wallet.chainId = newChainId;
312
- saveAuthState(authState);
313
- }
314
- return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
315
- id: chainId,
316
- name: `Chain ${chainId}`,
317
- nativeCurrency: {
318
- name: "Ether",
319
- decimals: 18,
320
- symbol: "ETH"
321
- },
322
- rpcUrls: {
323
- default: { http: [""] }
324
- }
325
- };
326
- },
327
- /**
328
- * Handle accounts changed
329
- */
330
- onAccountsChanged(accounts) {
331
- if (accounts.length === 0) {
332
- this.onDisconnect();
333
- } else {
334
- wagmiConfig.emitter.emit("change", {
335
- accounts
336
- });
337
- }
338
- },
339
- /**
340
- * Handle chain changed
341
- */
342
- onChainChanged(chain) {
343
- const chainId = Number(chain);
344
- wagmiConfig.emitter.emit("change", { chainId });
345
- },
346
- /**
347
- * Handle disconnect
348
- */
349
- onDisconnect(_error) {
350
- provider.clearWallet();
351
- clearAuthState();
352
- wagmiConfig.emitter.emit("disconnect");
353
- }
354
- };
355
- });
356
- }
357
-
358
- export {
359
- abcConnector
360
- };
@@ -1,194 +0,0 @@
1
- "use client";
2
- import {
3
- getBitcoinNetwork,
4
- getEvmNetwork,
5
- getSolanaNetwork,
6
- getTronNetwork
7
- } from "./chunk-O4AU63LK.js";
8
- import {
9
- getCredentialManager
10
- } from "./chunk-QKK3OPQA.js";
11
- import {
12
- AbcError
13
- } from "./chunk-4P3SPC44.js";
14
-
15
- // src/wallets/walletConnectors/abcWallet/walletGeneration.ts
16
- import { getTalkenApiClient } from "@talken/talkenkit";
17
- async function mapApiResponseToWallets(genResponse, infoResponse, email) {
18
- const accounts = infoResponse?.accounts || [];
19
- const evmAccount = accounts[0] || infoResponse || {};
20
- const uid = String(genResponse.uid || evmAccount.uid || "");
21
- const wid = String(genResponse.wid || evmAccount.wid || "");
22
- const sid = String(
23
- evmAccount.sid || evmAccount.ethAddress || genResponse.evmAddress || ""
24
- );
25
- const pubkey = String(evmAccount.pubkey || genResponse.pubkey || "");
26
- const solMaterial = genResponse.solana || {};
27
- let btcAddress = genResponse.btcAddress || "";
28
- let trxAddress = genResponse.trxAddress || "";
29
- if ((!btcAddress || !trxAddress) && pubkey) {
30
- try {
31
- const api = getTalkenApiClient();
32
- if (api) {
33
- const addrResponse = await api.wallet.getAddressForChain("all");
34
- if (!btcAddress)
35
- btcAddress = addrResponse?.btc || addrResponse?.btcAddress || "";
36
- if (!trxAddress)
37
- trxAddress = addrResponse?.trx || addrResponse?.trxAddress || "";
38
- }
39
- } catch (err) {
40
- console.warn(
41
- "[walletGeneration] Failed to derive BTC/TRX addresses:",
42
- err
43
- );
44
- }
45
- }
46
- const pvencstr = String(evmAccount.pvencstr || "");
47
- const edp = String(evmAccount.encryptDevicePassword || "");
48
- if (uid && wid && sid && pvencstr && edp) {
49
- getCredentialManager().setEvmSigningCredentials({
50
- uid,
51
- wid,
52
- sid,
53
- pvencstr,
54
- encryptDevicePassword: edp
55
- });
56
- }
57
- const evmWallet = {
58
- uid,
59
- sessionId: sid,
60
- keyId: wid,
61
- encryptedShare: pvencstr,
62
- secretStore: edp,
63
- address: genResponse.evmAddress || sid,
64
- chainId: getEvmNetwork(),
65
- sid,
66
- type: "evm",
67
- email,
68
- pubkey
69
- };
70
- const solanaWallet = {
71
- uid,
72
- sessionId: String(solMaterial.shareId || ""),
73
- keyId: String(solMaterial.keyId || ""),
74
- encryptedShare: String(solMaterial.encryptedShare || ""),
75
- secretStore: String(solMaterial.secretStore || ""),
76
- shareId: String(solMaterial.shareId || ""),
77
- publicKey: String(solMaterial.publicKey || ""),
78
- address: genResponse.solAddress || solMaterial.address || "",
79
- network: getSolanaNetwork()
80
- };
81
- const bitcoinWallet = {
82
- uid,
83
- sessionId: sid,
84
- keyId: wid,
85
- encryptedShare: String(evmAccount.pvencstr || ""),
86
- shareId: sid,
87
- publicKey: pubkey,
88
- address: btcAddress,
89
- addressType: "bech32",
90
- network: getBitcoinNetwork()
91
- };
92
- const tronWallet = {
93
- uid,
94
- sessionId: sid,
95
- keyId: wid,
96
- encryptedShare: String(evmAccount.pvencstr || ""),
97
- shareId: sid,
98
- publicKey: pubkey,
99
- address: trxAddress,
100
- network: getTronNetwork()
101
- };
102
- return { evmWallet, solanaWallet, bitcoinWallet, tronWallet };
103
- }
104
- async function generateMpcWallets(hashedPin, email) {
105
- const api = getTalkenApiClient();
106
- if (!api) {
107
- throw new AbcError(
108
- "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
109
- "TalkenApiClient not initialized"
110
- );
111
- }
112
- try {
113
- const genResponse = await api.wallet.generate(hashedPin, email);
114
- const infoResponse = await api.wallet.getInfo().catch(() => ({}));
115
- return await mapApiResponseToWallets(
116
- genResponse,
117
- infoResponse,
118
- email || ""
119
- );
120
- } catch (error) {
121
- throw new AbcError(
122
- "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
123
- `Failed to generate MPC wallets: ${error.message}`,
124
- { originalError: error }
125
- );
126
- }
127
- }
128
- async function recoverMpcWallets(hashedPin, email) {
129
- const api = getTalkenApiClient();
130
- if (!api) {
131
- throw new AbcError(
132
- "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
133
- "TalkenApiClient not initialized"
134
- );
135
- }
136
- try {
137
- const genResponse = await api.wallet.recover(hashedPin, email);
138
- const infoResponse = await api.wallet.getInfo().catch(() => ({}));
139
- return await mapApiResponseToWallets(
140
- genResponse,
141
- infoResponse,
142
- email || ""
143
- );
144
- } catch (error) {
145
- throw new AbcError(
146
- "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
147
- `Failed to recover MPC wallets: ${error.message}`,
148
- { originalError: error }
149
- );
150
- }
151
- }
152
- function validateMpcWallets(result) {
153
- const errors = [];
154
- if (!result.evmWallet) {
155
- errors.push("EVM wallet is missing");
156
- } else {
157
- if (!result.evmWallet.address || !result.evmWallet.address.startsWith("0x")) {
158
- errors.push("Invalid EVM wallet address");
159
- }
160
- }
161
- if (!result.solanaWallet) {
162
- errors.push("Solana wallet is missing");
163
- } else {
164
- if (!result.solanaWallet.address) {
165
- errors.push("Invalid Solana wallet address");
166
- }
167
- }
168
- if (!result.bitcoinWallet) {
169
- errors.push("Bitcoin wallet is missing");
170
- } else {
171
- if (!result.bitcoinWallet.address) {
172
- errors.push("Invalid Bitcoin wallet address");
173
- }
174
- }
175
- if (!result.tronWallet) {
176
- errors.push("TRON wallet is missing");
177
- } else {
178
- if (!result.tronWallet.address) {
179
- errors.push("Invalid TRON wallet address");
180
- } else if (!result.tronWallet.address.startsWith("T")) {
181
- errors.push("Invalid TRON address format (expected T prefix)");
182
- }
183
- }
184
- return {
185
- valid: errors.length === 0,
186
- errors
187
- };
188
- }
189
-
190
- export {
191
- generateMpcWallets,
192
- recoverMpcWallets,
193
- validateMpcWallets
194
- };