@talken/talkenkit 2.5.1 → 2.5.3
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/README.md +8 -28
- package/dist/{AbcCredentialManager-5W3B7GI4.js → AbcCredentialManager-DDHLW2IH.js} +1 -1
- package/dist/AbcCredentialManager-JV4ZBMKF.js +7 -0
- package/dist/TalkenApiSingleton-TECFDCT4.js +9 -0
- package/dist/{abcWallet-O5IRLUXL.js → abcWallet-2BVT5XFX.js} +2 -2
- package/dist/abcWallet-BFCI4NEM.js +162 -0
- package/dist/{chunk-PN6K4CMZ.js → chunk-ALBABQ53.js} +1 -4
- package/dist/chunk-DNEDHHS4.js +379 -0
- package/dist/chunk-KOK5ZBR4.js +5447 -0
- package/dist/chunk-R6ZE7JAZ.js +15 -0
- package/dist/{chunk-UHZL3WSM.js → chunk-WPRIYR63.js} +194 -69
- package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthFlow.d.ts +6 -32
- package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthSections.d.ts +0 -9
- package/dist/components/ConnectOptions/AbcWaasAuth/hooks/useAbcWaasAuth.d.ts +3 -12
- package/dist/components/ConnectOptions/AbcWaasAuth/types.d.ts +1 -8
- package/dist/components/ConnectOptions/PinAuth/PinAuthFlow.d.ts +6 -4
- package/dist/components/ProfileDetails/ProfileDetails.d.ts +5 -5
- package/dist/hooks/useMultiChainBalances.d.ts +9 -0
- package/dist/index.js +1344 -1423
- package/dist/wallets/walletConnectors/abcWallet/AbcCredentialManager.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/AbcEvmAutoConnector.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/abcAccessKeyProvider.js +3 -3
- 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 +7 -7
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +7 -7
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +44 -44
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +8 -8
- package/dist/wallets/walletConnectors/abcWallet/api/ConfigApi.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +44 -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 +6 -6
- package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +3 -0
- package/dist/wallets/walletConnectors/abcWallet/constants.js +5 -3
- package/dist/wallets/walletConnectors/abcWallet/index.js +19 -19
- package/dist/wallets/walletConnectors/abcWallet/sessionUtils.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/types.d.ts +4 -0
- package/dist/wallets/walletConnectors/abcWallet/utils.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/walletGeneration.js +3 -3
- package/dist/wallets/walletConnectors/berasigWallet/berasigWallet.js +2 -2
- package/dist/wallets/walletConnectors/bifrostWallet/bifrostWallet.js +2 -2
- package/dist/wallets/walletConnectors/binanceWallet/binanceWallet.js +2 -2
- package/dist/wallets/walletConnectors/bitgetWallet/bitgetWallet.js +2 -2
- package/dist/wallets/walletConnectors/bybitWallet/bybitWallet.js +2 -2
- package/dist/wallets/walletConnectors/{chunk-4JZPP3S7.js → chunk-2N244XPQ.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-QKK3OPQA.js → chunk-36BJXEBA.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-FKI5AZVH.js → chunk-3K3KYVRN.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-URS2KVYK.js → chunk-5DK36WJ2.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-5ERWBR7D.js +977 -0
- package/dist/wallets/walletConnectors/chunk-6KRX73ED.js +230 -0
- package/dist/wallets/walletConnectors/{chunk-H2AZTZMM.js → chunk-6L5G54IX.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-6WF4SXLB.js +156 -0
- package/dist/wallets/walletConnectors/{chunk-PF65YS3T.js → chunk-A66MTFML.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-LIGH2LEU.js → chunk-ACLPF2UW.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-KIYXONNH.js → chunk-BHEVY4QY.js} +2 -35
- package/dist/wallets/walletConnectors/{chunk-YKFI6ZGM.js → chunk-BXH3GDX5.js} +1 -1
- package/dist/wallets/walletConnectors/{chunk-RGYZNNB6.js → chunk-C4ADBB6M.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-CABLJOMU.js +194 -0
- package/dist/wallets/walletConnectors/{chunk-RX2VOIUB.js → chunk-DPTDOCWL.js} +1 -4
- package/dist/wallets/walletConnectors/{chunk-6TAU7OQK.js → chunk-DW36LXIV.js} +8 -7
- package/dist/wallets/walletConnectors/chunk-EBTKWCIS.js +224 -0
- package/dist/wallets/walletConnectors/{chunk-25ZDAJ3L.js → chunk-EZS3GXZN.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-FBJ5H6PM.js +300 -0
- package/dist/wallets/walletConnectors/chunk-IM7DEERX.js +585 -0
- package/dist/wallets/walletConnectors/chunk-J3YPHDHM.js +827 -0
- package/dist/wallets/walletConnectors/chunk-JADQLTFW.js +194 -0
- package/dist/wallets/walletConnectors/{chunk-L6FCF3FH.js → chunk-L3HWFGTN.js} +2 -2
- package/dist/wallets/walletConnectors/chunk-L6WDO3ZN.js +445 -0
- package/dist/wallets/walletConnectors/chunk-MO2AXXLI.js +30 -0
- package/dist/wallets/walletConnectors/chunk-NLA45GHJ.js +300 -0
- package/dist/wallets/walletConnectors/chunk-NU3ITJNK.js +1485 -0
- package/dist/wallets/walletConnectors/{chunk-HWRZGGGN.js → chunk-NULM3THX.js} +1 -1
- package/dist/wallets/walletConnectors/chunk-OMOYFHBT.js +1485 -0
- package/dist/wallets/walletConnectors/{chunk-4YEALKXG.js → chunk-OOCL4OPQ.js} +29 -11
- package/dist/wallets/walletConnectors/chunk-PVPSVCVQ.js +96 -0
- package/dist/wallets/walletConnectors/chunk-VBNZ7HA3.js +241 -0
- package/dist/wallets/walletConnectors/chunk-VDWJ3NQ5.js +52 -0
- package/dist/wallets/walletConnectors/chunk-VLHDGDFH.js +273 -0
- package/dist/wallets/walletConnectors/chunk-VMCIDCO5.js +54 -0
- package/dist/wallets/walletConnectors/chunk-VNL7XEWF.js +54 -0
- package/dist/wallets/walletConnectors/chunk-YV6IZWGE.js +393 -0
- package/dist/wallets/walletConnectors/{chunk-645DT4TS.js → chunk-ZLH3W5PQ.js} +2 -2
- package/dist/wallets/walletConnectors/clvWallet/clvWallet.js +2 -2
- package/dist/wallets/walletConnectors/coin98Wallet/coin98Wallet.js +2 -2
- package/dist/wallets/walletConnectors/coreWallet/coreWallet.js +2 -2
- package/dist/wallets/walletConnectors/foxWallet/foxWallet.js +2 -2
- package/dist/wallets/walletConnectors/frontierWallet/frontierWallet.js +2 -2
- package/dist/wallets/walletConnectors/gateWallet/gateWallet.js +2 -2
- package/dist/wallets/walletConnectors/index.js +67 -67
- package/dist/wallets/walletConnectors/iopayWallet/iopayWallet.js +2 -2
- package/dist/wallets/walletConnectors/kaiaWallet/kaiaWallet.js +2 -2
- package/dist/wallets/walletConnectors/kaikasWallet/kaikasWallet.js +2 -2
- package/dist/wallets/walletConnectors/klipWallet/klipWallet.js +2 -2
- package/dist/wallets/walletConnectors/klipWallet-TBZJ5GGT.js +7 -0
- package/dist/wallets/walletConnectors/metaMaskWallet/metaMaskWallet.js +2 -2
- package/dist/wallets/walletConnectors/okxWallet/okxWallet.js +2 -2
- package/dist/wallets/walletConnectors/rainbowWallet/rainbowWallet.js +2 -2
- package/dist/wallets/walletConnectors/roninWallet/roninWallet.js +2 -2
- package/dist/wallets/walletConnectors/safepalWallet/safepalWallet.js +2 -2
- package/dist/wallets/walletConnectors/subWallet/subWallet.js +2 -2
- package/dist/wallets/walletConnectors/tokenPocketWallet/tokenPocketWallet.js +2 -2
- package/dist/wallets/walletConnectors/trustWallet/trustWallet.js +2 -2
- package/dist/wallets/walletConnectors/zealWallet/zealWallet.js +2 -2
- package/dist/wallets/walletConnectors/zerionWallet/zerionWallet.js +2 -2
- package/package.json +12 -11
- package/LICENSE +0 -9
- package/dist/wallets/walletConnectors/klipWallet-PPTYYB5G.js +0 -7
|
@@ -0,0 +1,230 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
// src/wallets/walletConnectors/abcWallet/constants.ts
|
|
4
|
+
var DEFAULT_ABC_CONFIG = {
|
|
5
|
+
environment: "development",
|
|
6
|
+
talkenApiUrl: ""
|
|
7
|
+
};
|
|
8
|
+
var TOKEN_EXPIRY = {
|
|
9
|
+
ACCESS_TOKEN: 10 * 60 * 1e3,
|
|
10
|
+
// 10 minutes
|
|
11
|
+
REFRESH_TOKEN: 60 * 60 * 1e3,
|
|
12
|
+
// 60 minutes
|
|
13
|
+
REFRESH_BUFFER: 60 * 1e3
|
|
14
|
+
// Refresh 60s before expiry (increased for network latency tolerance)
|
|
15
|
+
};
|
|
16
|
+
var AUTH_PROVIDERS = {
|
|
17
|
+
EMAIL: "email",
|
|
18
|
+
GOOGLE: "google",
|
|
19
|
+
APPLE: "apple",
|
|
20
|
+
TELEGRAM: "telegram",
|
|
21
|
+
TWITTER: "twitter"
|
|
22
|
+
};
|
|
23
|
+
var CHAIN_TYPES = {
|
|
24
|
+
EVM: "evm",
|
|
25
|
+
SOLANA: "solana",
|
|
26
|
+
BITCOIN: "bitcoin"
|
|
27
|
+
};
|
|
28
|
+
var SOLANA_CHAIN_ID = 900;
|
|
29
|
+
var BITCOIN_CHAIN_ID = 800;
|
|
30
|
+
var EVM_CHAINS = {
|
|
31
|
+
ETHEREUM_MAINNET: 1,
|
|
32
|
+
ETHEREUM_GOERLI: 5,
|
|
33
|
+
ETHEREUM_SEPOLIA: 11155111,
|
|
34
|
+
POLYGON_MAINNET: 137,
|
|
35
|
+
POLYGON_MUMBAI: 80001,
|
|
36
|
+
BSC_MAINNET: 56,
|
|
37
|
+
BSC_TESTNET: 97,
|
|
38
|
+
ARBITRUM_MAINNET: 42161,
|
|
39
|
+
ARBITRUM_GOERLI: 421613,
|
|
40
|
+
OPTIMISM_MAINNET: 10,
|
|
41
|
+
OPTIMISM_GOERLI: 420,
|
|
42
|
+
AVALANCHE_MAINNET: 43114,
|
|
43
|
+
AVALANCHE_FUJI: 43113,
|
|
44
|
+
KLAYTN_MAINNET: 8217,
|
|
45
|
+
KLAYTN_BAOBAB: 1001
|
|
46
|
+
};
|
|
47
|
+
var PIN_CONFIG = {
|
|
48
|
+
MIN_LENGTH: 6,
|
|
49
|
+
MAX_LENGTH: 6,
|
|
50
|
+
MAX_ATTEMPTS: 5,
|
|
51
|
+
LOCKOUT_DURATION: 15 * 60 * 1e3
|
|
52
|
+
// 15 minutes
|
|
53
|
+
};
|
|
54
|
+
var STORAGE_VERSION = "1.0.0";
|
|
55
|
+
var REQUEST_TIMEOUT = 3e4;
|
|
56
|
+
var RETRY_CONFIG = {
|
|
57
|
+
MAX_RETRIES: 3,
|
|
58
|
+
RETRY_DELAY: 1e3,
|
|
59
|
+
// 1 second
|
|
60
|
+
BACKOFF_MULTIPLIER: 2
|
|
61
|
+
};
|
|
62
|
+
var ABC_WALLET_METADATA = {
|
|
63
|
+
id: "abc",
|
|
64
|
+
name: "ABC Wallet",
|
|
65
|
+
iconBackground: "#ffffff",
|
|
66
|
+
rdns: "com.abcwallet"
|
|
67
|
+
};
|
|
68
|
+
var MODAL_CONFIG = {
|
|
69
|
+
WIDTH: 400,
|
|
70
|
+
MAX_WIDTH: "90vw",
|
|
71
|
+
BORDER_RADIUS: 16,
|
|
72
|
+
PADDING: 24
|
|
73
|
+
};
|
|
74
|
+
var SOCIAL_BUTTONS = [
|
|
75
|
+
{
|
|
76
|
+
provider: AUTH_PROVIDERS.GOOGLE,
|
|
77
|
+
label: "Google",
|
|
78
|
+
iconName: "google"
|
|
79
|
+
},
|
|
80
|
+
{
|
|
81
|
+
provider: AUTH_PROVIDERS.APPLE,
|
|
82
|
+
label: "Apple",
|
|
83
|
+
iconName: "apple"
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
provider: AUTH_PROVIDERS.TELEGRAM,
|
|
87
|
+
label: "Telegram",
|
|
88
|
+
iconName: "telegram"
|
|
89
|
+
},
|
|
90
|
+
{
|
|
91
|
+
provider: AUTH_PROVIDERS.TWITTER,
|
|
92
|
+
label: "X (Twitter)",
|
|
93
|
+
iconName: "twitter"
|
|
94
|
+
}
|
|
95
|
+
];
|
|
96
|
+
var ERROR_MESSAGES = {
|
|
97
|
+
INVALID_CREDENTIALS: "Invalid email or password",
|
|
98
|
+
TOKEN_EXPIRED: "Your session has expired. Please login again.",
|
|
99
|
+
WALLET_NOT_FOUND: "Wallet not found. Please create a new wallet.",
|
|
100
|
+
INVALID_PIN: "Invalid PIN code",
|
|
101
|
+
NETWORK_ERROR: "Network error. Please check your connection.",
|
|
102
|
+
SIGNATURE_FAILED: "Failed to sign transaction",
|
|
103
|
+
USER_CANCELLED: "User cancelled the operation",
|
|
104
|
+
UNKNOWN_ERROR: "An unknown error occurred",
|
|
105
|
+
INVALID_OTP: "Invalid or expired OTP code",
|
|
106
|
+
EMAIL_REQUIRED: "Email address is required",
|
|
107
|
+
PIN_REQUIRED: "PIN code is required",
|
|
108
|
+
WALLET_GENERATION_FAILED: "Failed to generate wallet"
|
|
109
|
+
};
|
|
110
|
+
var SUCCESS_MESSAGES = {
|
|
111
|
+
LOGIN_SUCCESS: "Successfully logged in",
|
|
112
|
+
WALLET_CREATED: "Wallet created successfully",
|
|
113
|
+
TRANSACTION_SENT: "Transaction sent successfully",
|
|
114
|
+
OTP_SENT: "OTP code sent to your email"
|
|
115
|
+
};
|
|
116
|
+
var ABC_EVENTS = {
|
|
117
|
+
CONNECT: "abc:connect",
|
|
118
|
+
DISCONNECT: "abc:disconnect",
|
|
119
|
+
ACCOUNTS_CHANGED: "abc:accountsChanged",
|
|
120
|
+
CHAIN_CHANGED: "abc:chainChanged",
|
|
121
|
+
ERROR: "abc:error",
|
|
122
|
+
AUTH_STATE_CHANGED: "abc:authStateChanged"
|
|
123
|
+
};
|
|
124
|
+
var STORAGE_PREFIX = "talkenkit_abc_";
|
|
125
|
+
var DEBUG_MODE = true;
|
|
126
|
+
var ABC_FEATURES = {
|
|
127
|
+
EMAIL_LOGIN: true,
|
|
128
|
+
SOCIAL_LOGIN: true,
|
|
129
|
+
MULTI_CHAIN: true,
|
|
130
|
+
EVM_SUPPORT: true,
|
|
131
|
+
SOLANA_SUPPORT: true,
|
|
132
|
+
BITCOIN_SUPPORT: false,
|
|
133
|
+
// Future feature
|
|
134
|
+
GASLESS_TRANSACTIONS: false,
|
|
135
|
+
// Future feature
|
|
136
|
+
SOCIAL_RECOVERY: false
|
|
137
|
+
// Future feature
|
|
138
|
+
};
|
|
139
|
+
var DEFAULT_TALKEN_API_CONFIG = {
|
|
140
|
+
baseUrl: void 0,
|
|
141
|
+
timeout: REQUEST_TIMEOUT
|
|
142
|
+
};
|
|
143
|
+
var TALKEN_API_ENDPOINTS = {
|
|
144
|
+
// ── Auth (single action-based endpoint) ─────────────────────────────
|
|
145
|
+
AUTH: "/wallet/auth",
|
|
146
|
+
// ── Wallet ──────────────────────────────────────────────────────────
|
|
147
|
+
WALLET_MPC: "/wallet/mpc",
|
|
148
|
+
WALLET_ADDRESS: "/wallet/address",
|
|
149
|
+
WALLET_SCAN: "/wallet/scan",
|
|
150
|
+
WALLET_BTC: "/wallet/btc",
|
|
151
|
+
// ── EVM Sign (WaaS proxy) ───────────────────────────────────────────
|
|
152
|
+
SIGN_EVM: "/wallet/sign/evm",
|
|
153
|
+
SIGN_TYPED: "/wallet/sign/evm/typed",
|
|
154
|
+
SIGN_PERSONAL: "/wallet/sign/evm/personal",
|
|
155
|
+
SIGN_AUTHORIZATION: "/wallet/sign/authorization",
|
|
156
|
+
// ── Hash Sign (secp256k1, universal: EVM/BTC/TVM) ───────────────────
|
|
157
|
+
SIGN_HASH: "/wallet/sign/hash",
|
|
158
|
+
// ── SOL Sign (WaaS proxy) ───────────────────────────────────────────
|
|
159
|
+
SIGN_SVM: "/wallet/sign/sol",
|
|
160
|
+
// ── TX ──────────────────────────────────────────────────────────────
|
|
161
|
+
TX_RAW: "/wallet/tx/raw",
|
|
162
|
+
TX_EVM: "/wallet/tx/evm",
|
|
163
|
+
TX_SOL: "/wallet/tx/sol",
|
|
164
|
+
SOLANA_LATEST_BLOCKHASH: "/wallet/solana/latest-blockhash",
|
|
165
|
+
SOLANA_TX_STATUS: "/wallet/solana/tx-status",
|
|
166
|
+
TX_BTC: "/wallet/tx/btc",
|
|
167
|
+
TX_TVM: "/wallet/tx/tvm",
|
|
168
|
+
TRON_UTIL: "/wallet/tron",
|
|
169
|
+
// ── Gas (WaaS proxy) ───────────────────────────────────────────────
|
|
170
|
+
GAS_PRICE: "/wallet/gas/price",
|
|
171
|
+
GAS_SUGGESTED: "/wallet/gas/suggested",
|
|
172
|
+
GAS_ESTIMATE: "/wallet/gas/estimate",
|
|
173
|
+
// ── Nonce / Balance / eth_call (WaaS proxy) ───────────────────────
|
|
174
|
+
NONCE: "/wallet/nonce",
|
|
175
|
+
ADDRESS_BALANCE: "/wallet/address/balance",
|
|
176
|
+
ETH_CALL: "/wallet/contract/eth-call",
|
|
177
|
+
// ── Relayer ────────────────────────────────────────────────────────
|
|
178
|
+
RELAYER_FEE_ESTIMATE: "/relayer/estimate-fee",
|
|
179
|
+
// ── Config / Runtime ───────────────────────────────────────────────
|
|
180
|
+
CONFIG_TX_STATUS: "/config/tx-status",
|
|
181
|
+
// ── Tokens ─────────────────────────────────────────────────────────
|
|
182
|
+
TOKENS_BALANCES: "/tokens/balances",
|
|
183
|
+
// ── Agent Access Key ──────────────────────────────────────────────
|
|
184
|
+
ACCESS_KEYS: "/agent/access-keys"
|
|
185
|
+
};
|
|
186
|
+
var AK_ENV_SUFFIX = {
|
|
187
|
+
production: "live",
|
|
188
|
+
staging: "stg",
|
|
189
|
+
development: "dev",
|
|
190
|
+
localhost: "local"
|
|
191
|
+
};
|
|
192
|
+
function getAkStorageKey() {
|
|
193
|
+
const env = typeof process !== "undefined" && process.env?.NEXT_PUBLIC_ENVIRONMENT || typeof process !== "undefined" && process.env?.NEXT_PUBLIC_PHASE || "development";
|
|
194
|
+
return `talken_ak_${AK_ENV_SUFFIX[env] || "dev"}`;
|
|
195
|
+
}
|
|
196
|
+
function loadTgAccessKey() {
|
|
197
|
+
if (typeof localStorage === "undefined")
|
|
198
|
+
return null;
|
|
199
|
+
try {
|
|
200
|
+
return localStorage.getItem(getAkStorageKey()) || null;
|
|
201
|
+
} catch {
|
|
202
|
+
return null;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
|
|
206
|
+
export {
|
|
207
|
+
DEFAULT_ABC_CONFIG,
|
|
208
|
+
TOKEN_EXPIRY,
|
|
209
|
+
AUTH_PROVIDERS,
|
|
210
|
+
CHAIN_TYPES,
|
|
211
|
+
SOLANA_CHAIN_ID,
|
|
212
|
+
BITCOIN_CHAIN_ID,
|
|
213
|
+
EVM_CHAINS,
|
|
214
|
+
PIN_CONFIG,
|
|
215
|
+
STORAGE_VERSION,
|
|
216
|
+
REQUEST_TIMEOUT,
|
|
217
|
+
RETRY_CONFIG,
|
|
218
|
+
ABC_WALLET_METADATA,
|
|
219
|
+
MODAL_CONFIG,
|
|
220
|
+
SOCIAL_BUTTONS,
|
|
221
|
+
ERROR_MESSAGES,
|
|
222
|
+
SUCCESS_MESSAGES,
|
|
223
|
+
ABC_EVENTS,
|
|
224
|
+
STORAGE_PREFIX,
|
|
225
|
+
DEBUG_MODE,
|
|
226
|
+
ABC_FEATURES,
|
|
227
|
+
DEFAULT_TALKEN_API_CONFIG,
|
|
228
|
+
TALKEN_API_ENDPOINTS,
|
|
229
|
+
loadTgAccessKey
|
|
230
|
+
};
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
} from "./chunk-4P3SPC44.js";
|
|
11
11
|
import {
|
|
12
12
|
getCredentialManager
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-36BJXEBA.js";
|
|
14
14
|
|
|
15
15
|
// src/wallets/walletConnectors/abcWallet/walletGeneration.ts
|
|
16
16
|
import { getTalkenApiClient } from "@talken/talkenkit";
|
|
@@ -0,0 +1,156 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
STORAGE_PREFIX
|
|
4
|
+
} from "./chunk-DPTDOCWL.js";
|
|
5
|
+
|
|
6
|
+
// src/wallets/walletConnectors/abcWallet/AbcCredentialManager.ts
|
|
7
|
+
var EMAIL_STORAGE_KEY = `${STORAGE_PREFIX}saved_email`;
|
|
8
|
+
var AUTH_STATE_KEY = `${STORAGE_PREFIX}auth_state`;
|
|
9
|
+
var EVM_CREDS_SESSION_KEY = `${STORAGE_PREFIX}evm_signing_creds`;
|
|
10
|
+
var PIN_HASH_SESSION_KEY = `${STORAGE_PREFIX}pin_hash`;
|
|
11
|
+
var AbcCredentialManager = class _AbcCredentialManager {
|
|
12
|
+
constructor() {
|
|
13
|
+
this.pinHash = null;
|
|
14
|
+
this.email_ = null;
|
|
15
|
+
this.restoreEmailFromStorage();
|
|
16
|
+
}
|
|
17
|
+
static getInstance() {
|
|
18
|
+
if (!_AbcCredentialManager.instance) {
|
|
19
|
+
_AbcCredentialManager.instance = new _AbcCredentialManager();
|
|
20
|
+
}
|
|
21
|
+
return _AbcCredentialManager.instance;
|
|
22
|
+
}
|
|
23
|
+
// ── PIN Hash (memory + sessionStorage) ───────────────────────────
|
|
24
|
+
setPinHash(hash) {
|
|
25
|
+
this.pinHash = hash;
|
|
26
|
+
if (typeof window !== "undefined") {
|
|
27
|
+
try {
|
|
28
|
+
sessionStorage.setItem(PIN_HASH_SESSION_KEY, hash);
|
|
29
|
+
} catch {
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
}
|
|
33
|
+
getPinHash() {
|
|
34
|
+
if (this.pinHash)
|
|
35
|
+
return this.pinHash;
|
|
36
|
+
if (typeof window !== "undefined") {
|
|
37
|
+
try {
|
|
38
|
+
const cached = sessionStorage.getItem(PIN_HASH_SESSION_KEY);
|
|
39
|
+
if (cached) {
|
|
40
|
+
this.pinHash = cached;
|
|
41
|
+
return cached;
|
|
42
|
+
}
|
|
43
|
+
} catch {
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
return null;
|
|
47
|
+
}
|
|
48
|
+
clearPinHash() {
|
|
49
|
+
this.pinHash = null;
|
|
50
|
+
if (typeof window !== "undefined") {
|
|
51
|
+
try {
|
|
52
|
+
sessionStorage.removeItem(PIN_HASH_SESSION_KEY);
|
|
53
|
+
} catch {
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
// ── Email ─────────────────────────────────────────────────────────
|
|
58
|
+
setEmail(email) {
|
|
59
|
+
this.email_ = email;
|
|
60
|
+
if (typeof window !== "undefined") {
|
|
61
|
+
try {
|
|
62
|
+
localStorage.setItem(EMAIL_STORAGE_KEY, email);
|
|
63
|
+
} catch {
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
}
|
|
67
|
+
/**
|
|
68
|
+
* Get recovery email.
|
|
69
|
+
* Priority: in-memory → auth_state JSON → saved_email localStorage
|
|
70
|
+
*/
|
|
71
|
+
getEmail() {
|
|
72
|
+
if (this.email_)
|
|
73
|
+
return this.email_;
|
|
74
|
+
if (typeof window === "undefined")
|
|
75
|
+
return null;
|
|
76
|
+
try {
|
|
77
|
+
const authState = localStorage.getItem(AUTH_STATE_KEY);
|
|
78
|
+
if (authState) {
|
|
79
|
+
const data = JSON.parse(authState);
|
|
80
|
+
const email = data?.user?.email || data?.wallet?.email;
|
|
81
|
+
if (typeof email === "string" && email.trim()) {
|
|
82
|
+
this.email_ = email.trim();
|
|
83
|
+
return this.email_;
|
|
84
|
+
}
|
|
85
|
+
}
|
|
86
|
+
} catch {
|
|
87
|
+
}
|
|
88
|
+
try {
|
|
89
|
+
const saved = localStorage.getItem(EMAIL_STORAGE_KEY);
|
|
90
|
+
if (saved?.trim()) {
|
|
91
|
+
this.email_ = saved.trim();
|
|
92
|
+
return this.email_;
|
|
93
|
+
}
|
|
94
|
+
} catch {
|
|
95
|
+
}
|
|
96
|
+
return null;
|
|
97
|
+
}
|
|
98
|
+
// ── EVM Signing Credentials (sessionStorage — tab-scoped) ────────
|
|
99
|
+
setEvmSigningCredentials(creds) {
|
|
100
|
+
if (typeof window === "undefined")
|
|
101
|
+
return;
|
|
102
|
+
try {
|
|
103
|
+
sessionStorage.setItem(EVM_CREDS_SESSION_KEY, JSON.stringify(creds));
|
|
104
|
+
} catch {
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
getEvmSigningCredentials() {
|
|
108
|
+
if (typeof window === "undefined")
|
|
109
|
+
return null;
|
|
110
|
+
try {
|
|
111
|
+
const raw = sessionStorage.getItem(EVM_CREDS_SESSION_KEY);
|
|
112
|
+
if (!raw)
|
|
113
|
+
return null;
|
|
114
|
+
const parsed = JSON.parse(raw);
|
|
115
|
+
if (parsed?.uid && parsed?.wid && parsed?.sid && parsed?.pvencstr && parsed?.encryptDevicePassword) {
|
|
116
|
+
return parsed;
|
|
117
|
+
}
|
|
118
|
+
return null;
|
|
119
|
+
} catch {
|
|
120
|
+
return null;
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
clearEvmSigningCredentials() {
|
|
124
|
+
if (typeof window === "undefined")
|
|
125
|
+
return;
|
|
126
|
+
try {
|
|
127
|
+
sessionStorage.removeItem(EVM_CREDS_SESSION_KEY);
|
|
128
|
+
} catch {
|
|
129
|
+
}
|
|
130
|
+
}
|
|
131
|
+
// ── Lifecycle ─────────────────────────────────────────────────────
|
|
132
|
+
/**
|
|
133
|
+
* Restore email from localStorage on initialization.
|
|
134
|
+
* PIN hash is intentionally NOT restored (memory-only).
|
|
135
|
+
*/
|
|
136
|
+
restoreEmailFromStorage() {
|
|
137
|
+
if (typeof window === "undefined")
|
|
138
|
+
return;
|
|
139
|
+
this.getEmail();
|
|
140
|
+
}
|
|
141
|
+
/**
|
|
142
|
+
* Clear all credentials (logout).
|
|
143
|
+
*/
|
|
144
|
+
clear() {
|
|
145
|
+
this.pinHash = null;
|
|
146
|
+
this.email_ = null;
|
|
147
|
+
this.clearEvmSigningCredentials();
|
|
148
|
+
}
|
|
149
|
+
};
|
|
150
|
+
function getCredentialManager() {
|
|
151
|
+
return AbcCredentialManager.getInstance();
|
|
152
|
+
}
|
|
153
|
+
|
|
154
|
+
export {
|
|
155
|
+
getCredentialManager
|
|
156
|
+
};
|
|
@@ -4,12 +4,12 @@ import {
|
|
|
4
4
|
} from "./chunk-4P3SPC44.js";
|
|
5
5
|
import {
|
|
6
6
|
getCredentialManager
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-6WF4SXLB.js";
|
|
8
8
|
import {
|
|
9
9
|
DEFAULT_TALKEN_API_CONFIG,
|
|
10
10
|
TALKEN_API_ENDPOINTS,
|
|
11
11
|
TOKEN_EXPIRY
|
|
12
|
-
} from "./chunk-
|
|
12
|
+
} from "./chunk-DPTDOCWL.js";
|
|
13
13
|
|
|
14
14
|
// src/wallets/walletConnectors/abcWallet/api/TalkenApiClient.ts
|
|
15
15
|
var STORAGE_KEY_PREFIX = "talken_api_";
|
|
@@ -365,21 +365,6 @@ var TalkenEvmModule = class {
|
|
|
365
365
|
const qs = new URLSearchParams({ network, address }).toString();
|
|
366
366
|
return this.client.get(`${TALKEN_API_ENDPOINTS.NONCE}?${qs}`);
|
|
367
367
|
}
|
|
368
|
-
/**
|
|
369
|
-
* Get native balance for address
|
|
370
|
-
* GET /wallet/address/balance?network=&address=
|
|
371
|
-
*/
|
|
372
|
-
async getBalance(network, address) {
|
|
373
|
-
const qs = new URLSearchParams({ network, address }).toString();
|
|
374
|
-
return this.client.get(`${TALKEN_API_ENDPOINTS.ADDRESS_BALANCE}?${qs}`);
|
|
375
|
-
}
|
|
376
|
-
/**
|
|
377
|
-
* Execute read-only eth_call
|
|
378
|
-
* POST /wallet/contract/eth-call { network, to, data, from? }
|
|
379
|
-
*/
|
|
380
|
-
async ethCall(params) {
|
|
381
|
-
return this.client.post(TALKEN_API_ENDPOINTS.ETH_CALL, params);
|
|
382
|
-
}
|
|
383
368
|
};
|
|
384
369
|
var TalkenSolanaModule = class {
|
|
385
370
|
constructor(client) {
|
|
@@ -551,24 +536,6 @@ var TalkenTronModule = class {
|
|
|
551
536
|
params
|
|
552
537
|
);
|
|
553
538
|
}
|
|
554
|
-
/**
|
|
555
|
-
* Get TRON account info (balance, resource, permissions)
|
|
556
|
-
* GET /wallet/tron?mode=account&network=&address=
|
|
557
|
-
*/
|
|
558
|
-
async getAccount(network, address) {
|
|
559
|
-
return this.client.get(
|
|
560
|
-
`${TALKEN_API_ENDPOINTS.TRON_UTIL}?mode=account&network=${encodeURIComponent(network)}&address=${encodeURIComponent(address)}`
|
|
561
|
-
);
|
|
562
|
-
}
|
|
563
|
-
/**
|
|
564
|
-
* Get TRC20 token balance
|
|
565
|
-
* GET /wallet/tron?mode=trc20Balance&network=&address=&contractAddress=
|
|
566
|
-
*/
|
|
567
|
-
async getTrc20Balance(network, address, contractAddress) {
|
|
568
|
-
return this.client.get(
|
|
569
|
-
`${TALKEN_API_ENDPOINTS.TRON_UTIL}?mode=trc20Balance&network=${encodeURIComponent(network)}&address=${encodeURIComponent(address)}&contractAddress=${encodeURIComponent(contractAddress)}`
|
|
570
|
-
);
|
|
571
|
-
}
|
|
572
539
|
};
|
|
573
540
|
var TalkenWalletscanModule = class {
|
|
574
541
|
constructor(client) {
|
|
@@ -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-6WF4SXLB.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
|
+
};
|