@talken/talkenkit 2.5.0 → 2.5.2
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/{AbcCredentialManager-DDHLW2IH.js → AbcCredentialManager-5W3B7GI4.js} +1 -1
- package/dist/{abcWallet-5GTT47V6.js → abcWallet-HRNBHY5Q.js} +2 -2
- package/dist/{chunk-ALBABQ53.js → chunk-PN6K4CMZ.js} +4 -1
- package/dist/{chunk-REVMSQIO.js → chunk-VCQZZ6SN.js} +478 -58
- package/dist/components/TransactionResultModal/TransactionResultModal.css.d.ts +17 -0
- package/dist/components/TransactionResultModal/TransactionResultModal.d.ts +9 -0
- package/dist/index.css +138 -0
- package/dist/index.d.ts +2 -0
- package/dist/index.js +1341 -977
- package/dist/providers/TransactionResultProvider/TransactionResultContext.d.ts +6 -0
- package/dist/providers/TransactionResultProvider/TransactionResultProvider.d.ts +7 -0
- package/dist/providers/TransactionResultProvider/TransactionResultSingleton.d.ts +16 -0
- package/dist/providers/TransactionResultProvider/index.d.ts +4 -0
- package/dist/providers/TransactionResultProvider/types.d.ts +14 -0
- package/dist/wallets/walletConnectors/abcWallet/AbcCredentialManager.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/AbcEvmAutoConnector.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/abcAccessKeyProvider.d.ts +29 -3
- package/dist/wallets/walletConnectors/abcWallet/abcAccessKeyProvider.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +8 -8
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.d.ts +8 -0
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +5 -5
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.d.ts +1 -0
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +8 -8
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.d.ts +1 -0
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +9 -9
- package/dist/wallets/walletConnectors/abcWallet/api/ConfigApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +25 -0
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/api/TokenApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/api/index.js +9 -9
- package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +3 -0
- package/dist/wallets/walletConnectors/abcWallet/constants.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/index.d.ts +1 -1
- package/dist/wallets/walletConnectors/abcWallet/index.js +21 -21
- package/dist/wallets/walletConnectors/abcWallet/sessionUtils.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/types.d.ts +9 -0
- package/dist/wallets/walletConnectors/abcWallet/utils.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/walletGeneration.js +3 -3
- package/dist/wallets/walletConnectors/{chunk-VDWJ3NQ5.js → chunk-25ZDAJ3L.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-HWXOTEC3.js → chunk-2A5XTST5.js} +64 -14
- package/dist/wallets/walletConnectors/chunk-4JZPP3S7.js +380 -0
- package/dist/wallets/walletConnectors/{chunk-QSP2A4LA.js → chunk-4PDTJS5L.js} +3 -3
- package/dist/wallets/walletConnectors/{chunk-IN3HEGZM.js → chunk-645DT4TS.js} +46 -5
- package/dist/wallets/walletConnectors/{chunk-BHEVY4QY.js → chunk-ASYCOXE6.js} +50 -4
- package/dist/wallets/walletConnectors/chunk-BRXYKYKT.js +360 -0
- package/dist/wallets/walletConnectors/{chunk-MO2AXXLI.js → chunk-FKI5AZVH.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-JADQLTFW.js → chunk-H2AZTZMM.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-NULM3THX.js → chunk-HWRZGGGN.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-IPH3SIC3.js +57 -0
- package/dist/wallets/walletConnectors/chunk-JBOKTW2Q.js +360 -0
- package/dist/wallets/walletConnectors/{chunk-TQHS6APN.js → chunk-L6FCF3FH.js} +89 -7
- package/dist/wallets/walletConnectors/{chunk-ACLPF2UW.js → chunk-LIGH2LEU.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-MIX4TRKO.js +194 -0
- package/dist/wallets/walletConnectors/chunk-NP5PWUVU.js +873 -0
- package/dist/wallets/walletConnectors/{chunk-K66HU6GX.js → chunk-OASBABPG.js} +15 -1
- package/dist/wallets/walletConnectors/{chunk-A66MTFML.js → chunk-PF65YS3T.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-6WF4SXLB.js → chunk-QKK3OPQA.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-3LF7FVL6.js → chunk-RGYZNNB6.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-DPTDOCWL.js → chunk-RX2VOIUB.js} +4 -1
- package/dist/wallets/walletConnectors/chunk-TVZHPWFR.js +843 -0
- package/dist/wallets/walletConnectors/{chunk-YV6IZWGE.js → chunk-URS2KVYK.js} +45 -2
- package/dist/wallets/walletConnectors/chunk-WKP53WWR.js +57 -0
- package/dist/wallets/walletConnectors/{chunk-BXH3GDX5.js → chunk-YKFI6ZGM.js} +1 -1
- package/dist/wallets/walletConnectors/index.js +48 -48
- package/package.json +1 -1
- package/dist/wallets/walletConnectors/chunk-S2SQYPGR.js +0 -220
|
@@ -0,0 +1,360 @@
|
|
|
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,21 +1,26 @@
|
|
|
1
1
|
"use client";
|
|
2
2
|
import {
|
|
3
3
|
getChainKey,
|
|
4
|
+
getExplorerTxUrl,
|
|
4
5
|
getNetworkName
|
|
5
|
-
} from "./chunk-
|
|
6
|
+
} from "./chunk-OASBABPG.js";
|
|
6
7
|
import {
|
|
7
8
|
hexToNumber,
|
|
8
9
|
numberToHex
|
|
9
|
-
} from "./chunk-
|
|
10
|
+
} from "./chunk-PF65YS3T.js";
|
|
10
11
|
import {
|
|
11
12
|
TalkenApiError
|
|
12
13
|
} from "./chunk-4P3SPC44.js";
|
|
13
14
|
import {
|
|
14
15
|
getCredentialManager
|
|
15
|
-
} from "./chunk-
|
|
16
|
+
} from "./chunk-QKK3OPQA.js";
|
|
16
17
|
|
|
17
18
|
// src/wallets/walletConnectors/abcWallet/abcProvider.ts
|
|
18
|
-
import {
|
|
19
|
+
import {
|
|
20
|
+
getShowPendingTransaction,
|
|
21
|
+
getTalkenApiClient,
|
|
22
|
+
getUpdateTransactionResult
|
|
23
|
+
} from "@talken/talkenkit";
|
|
19
24
|
import { parseGwei } from "viem";
|
|
20
25
|
var EventEmitter = class {
|
|
21
26
|
constructor() {
|
|
@@ -260,10 +265,12 @@ var AbcEvmProvider = class extends EventEmitter {
|
|
|
260
265
|
return this.eth_getTransactionCount(
|
|
261
266
|
Array.isArray(params) ? params : []
|
|
262
267
|
);
|
|
263
|
-
case "eth_blockNumber":
|
|
264
268
|
case "eth_call":
|
|
265
|
-
|
|
269
|
+
return this.eth_call(params);
|
|
266
270
|
case "eth_getBalance":
|
|
271
|
+
return this.eth_getBalance(params);
|
|
272
|
+
case "eth_blockNumber":
|
|
273
|
+
case "eth_gasPrice":
|
|
267
274
|
case "eth_getBlockByHash":
|
|
268
275
|
case "eth_getBlockByNumber":
|
|
269
276
|
case "eth_getCode":
|
|
@@ -386,10 +393,20 @@ var AbcEvmProvider = class extends EventEmitter {
|
|
|
386
393
|
const hexValue = tx.value || "0x0";
|
|
387
394
|
const amountWei = BigInt(hexValue).toString();
|
|
388
395
|
const email = this.getRecoveryEmail();
|
|
396
|
+
const chainKey = getChainKey(this.chainId);
|
|
397
|
+
const showPending = getShowPendingTransaction();
|
|
398
|
+
if (showPending) {
|
|
399
|
+
showPending({
|
|
400
|
+
txHash: "",
|
|
401
|
+
network: chainKey,
|
|
402
|
+
chain: "evm",
|
|
403
|
+
explorerUrl: void 0
|
|
404
|
+
});
|
|
405
|
+
}
|
|
389
406
|
const api = this.getTalkenApiClientOrThrow();
|
|
390
407
|
const result = await this.withSigningCredentialRetry(
|
|
391
408
|
() => api.evm.sendTransaction({
|
|
392
|
-
chainKey
|
|
409
|
+
chainKey,
|
|
393
410
|
to: tx.to,
|
|
394
411
|
amountWei,
|
|
395
412
|
pin: pinHash,
|
|
@@ -397,9 +414,20 @@ var AbcEvmProvider = class extends EventEmitter {
|
|
|
397
414
|
gasLimit: tx.gas || tx.gasLimit,
|
|
398
415
|
maxFeePerGas: tx.maxFeePerGas,
|
|
399
416
|
maxPriorityFeePerGas: tx.maxPriorityFeePerGas,
|
|
417
|
+
waitForReceipt: true,
|
|
400
418
|
...email && { email }
|
|
401
419
|
})
|
|
402
420
|
);
|
|
421
|
+
const updateResult = getUpdateTransactionResult();
|
|
422
|
+
if (updateResult) {
|
|
423
|
+
updateResult({
|
|
424
|
+
txHash: result.txHash,
|
|
425
|
+
network: chainKey,
|
|
426
|
+
chain: "evm",
|
|
427
|
+
receipt: result.receipt ?? null,
|
|
428
|
+
explorerUrl: getExplorerTxUrl(this.chainId, result.txHash)
|
|
429
|
+
});
|
|
430
|
+
}
|
|
403
431
|
return result.txHash;
|
|
404
432
|
}
|
|
405
433
|
/**
|
|
@@ -730,6 +758,60 @@ var AbcEvmProvider = class extends EventEmitter {
|
|
|
730
758
|
return "0x5208";
|
|
731
759
|
}
|
|
732
760
|
}
|
|
761
|
+
/**
|
|
762
|
+
* Execute read-only eth_call via talken-api
|
|
763
|
+
*/
|
|
764
|
+
async eth_call(params) {
|
|
765
|
+
const p = Array.isArray(params) ? params : [];
|
|
766
|
+
const tx = p[0];
|
|
767
|
+
if (!tx?.to || !tx?.data) {
|
|
768
|
+
throw new ProviderRpcError(
|
|
769
|
+
ErrorCode.INVALID_PARAMS,
|
|
770
|
+
"eth_call requires to and data"
|
|
771
|
+
);
|
|
772
|
+
}
|
|
773
|
+
try {
|
|
774
|
+
const api = this.getTalkenApiClientOrThrow();
|
|
775
|
+
const response = await api.evm.ethCall({
|
|
776
|
+
network: getNetworkName(this.chainId),
|
|
777
|
+
to: tx.to,
|
|
778
|
+
data: tx.data,
|
|
779
|
+
from: tx.from || this.wallet?.address
|
|
780
|
+
});
|
|
781
|
+
return response?.result ?? response?.data ?? "0x";
|
|
782
|
+
} catch (error) {
|
|
783
|
+
throw new ProviderRpcError(
|
|
784
|
+
ErrorCode.INTERNAL_ERROR,
|
|
785
|
+
`eth_call failed: ${error instanceof Error ? error.message : String(error)}`
|
|
786
|
+
);
|
|
787
|
+
}
|
|
788
|
+
}
|
|
789
|
+
/**
|
|
790
|
+
* Get native balance via talken-api
|
|
791
|
+
*/
|
|
792
|
+
async eth_getBalance(params) {
|
|
793
|
+
const p = Array.isArray(params) ? params : [];
|
|
794
|
+
const address = p[0] || this.wallet?.address;
|
|
795
|
+
if (!address) {
|
|
796
|
+
throw new ProviderRpcError(
|
|
797
|
+
ErrorCode.INVALID_PARAMS,
|
|
798
|
+
"Missing address parameter"
|
|
799
|
+
);
|
|
800
|
+
}
|
|
801
|
+
try {
|
|
802
|
+
const api = this.getTalkenApiClientOrThrow();
|
|
803
|
+
const response = await api.evm.getBalance(
|
|
804
|
+
getNetworkName(this.chainId),
|
|
805
|
+
address
|
|
806
|
+
);
|
|
807
|
+
return response?.balance ?? "0x0";
|
|
808
|
+
} catch (error) {
|
|
809
|
+
throw new ProviderRpcError(
|
|
810
|
+
ErrorCode.INTERNAL_ERROR,
|
|
811
|
+
`eth_getBalance failed: ${error instanceof Error ? error.message : String(error)}`
|
|
812
|
+
);
|
|
813
|
+
}
|
|
814
|
+
}
|
|
733
815
|
/**
|
|
734
816
|
* Check if connected
|
|
735
817
|
*/
|
|
@@ -0,0 +1,194 @@
|
|
|
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
|
+
};
|