@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
package/README.md
CHANGED
|
@@ -86,31 +86,10 @@ const config = getDefaultConfig({
|
|
|
86
86
|
**Environment Variables:**
|
|
87
87
|
|
|
88
88
|
```bash
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
# Required — Environment (production | development)
|
|
93
|
-
NEXT_PUBLIC_ENVIRONMENT=production
|
|
94
|
-
|
|
95
|
-
# Optional — Firebase (for Google social login)
|
|
96
|
-
NEXT_PUBLIC_FIREBASE_API_KEY=your_firebase_api_key
|
|
97
|
-
NEXT_PUBLIC_FIREBASE_AUTH_DOMAIN=your_project.firebaseapp.com
|
|
98
|
-
NEXT_PUBLIC_FIREBASE_PROJECT_ID=your_project
|
|
99
|
-
NEXT_PUBLIC_FIREBASE_STORAGE_BUCKET=your_project.firebasestorage.app
|
|
100
|
-
NEXT_PUBLIC_FIREBASE_MESSAGING_SENDER_ID=your_sender_id
|
|
101
|
-
NEXT_PUBLIC_FIREBASE_APP_ID=your_app_id
|
|
102
|
-
|
|
103
|
-
# Optional — Social OAuth (enable via NEXT_PUBLIC_*_OAUTH_ENABLED=true)
|
|
104
|
-
NEXT_PUBLIC_GOOGLE_OAUTH_ENABLED=true
|
|
105
|
-
NEXT_PUBLIC_APPLE_OAUTH_ENABLED=true
|
|
106
|
-
NEXT_PUBLIC_APPLE_OAUTH_CLIENT_ID=your_apple_client_id
|
|
107
|
-
NEXT_PUBLIC_KAKAO_OAUTH_ENABLED=true
|
|
108
|
-
NEXT_PUBLIC_KAKAO_JS_KEY=your_kakao_js_key
|
|
109
|
-
NEXT_PUBLIC_KAKAO_REST_API_KEY=your_kakao_rest_api_key
|
|
89
|
+
NEXT_PUBLIC_ABC_WAAS_URL=https://your-waas-url.com
|
|
90
|
+
NEXT_PUBLIC_API_SERVER=https://your-api-server.com
|
|
110
91
|
```
|
|
111
92
|
|
|
112
|
-
> **Note**: `NEXT_PUBLIC_ABC_WAAS_URL` is no longer needed. All WaaS calls are proxied through `NEXT_PUBLIC_TALKEN_API_URL` (talken-api).
|
|
113
|
-
|
|
114
93
|
For detailed configuration options, see [Configuration Guide](./docs/configuration.md).
|
|
115
94
|
|
|
116
95
|
## Documentation
|
|
@@ -118,11 +97,12 @@ For detailed configuration options, see [Configuration Guide](./docs/configurati
|
|
|
118
97
|
**Quick Start:**
|
|
119
98
|
|
|
120
99
|
- [Package API Reference](./packages/talkenkit/README.md)
|
|
100
|
+
- [ABC WaaS Integration Guide](./docs/abc-waas.md)
|
|
121
101
|
- [Configuration Guide](./docs/configuration.md)
|
|
122
102
|
|
|
123
103
|
**Technical:**
|
|
124
104
|
|
|
125
|
-
- [Architecture Documentation](./docs/architecture.md)
|
|
105
|
+
- [Architecture Documentation](./docs/abc-waas-architecture.md)
|
|
126
106
|
- [Development Guide](./CLAUDE.md)
|
|
127
107
|
|
|
128
108
|
**RainbowKit Compatibility:**
|
|
@@ -199,9 +179,9 @@ talken-kit/
|
|
|
199
179
|
│ └── ...
|
|
200
180
|
│
|
|
201
181
|
└── docs/ # Documentation
|
|
202
|
-
├──
|
|
203
|
-
├──
|
|
204
|
-
└──
|
|
182
|
+
├── abc-waas.md
|
|
183
|
+
├── abc-waas-architecture.md
|
|
184
|
+
└── configuration.md
|
|
205
185
|
```
|
|
206
186
|
|
|
207
187
|
## Key Features
|
|
@@ -269,7 +249,7 @@ Please follow our [contributing guidelines](/.github/CONTRIBUTING.md).
|
|
|
269
249
|
For security best practices and implementation details, see:
|
|
270
250
|
|
|
271
251
|
- [Security in Package README](./packages/talkenkit/README.md#security)
|
|
272
|
-
- [Architecture Security](./docs/architecture.md)
|
|
252
|
+
- [Architecture Security](./docs/abc-waas-architecture.md#security-architecture)
|
|
273
253
|
|
|
274
254
|
## License
|
|
275
255
|
|
|
@@ -56,7 +56,7 @@ import {
|
|
|
56
56
|
validateEmail,
|
|
57
57
|
validateMpcWallets,
|
|
58
58
|
validatePin
|
|
59
|
-
} from "./chunk-
|
|
59
|
+
} from "./chunk-KOK5ZBR4.js";
|
|
60
60
|
import {
|
|
61
61
|
ABC_EVENTS,
|
|
62
62
|
ABC_FEATURES,
|
|
@@ -79,7 +79,7 @@ import {
|
|
|
79
79
|
SUCCESS_MESSAGES,
|
|
80
80
|
TOKEN_EXPIRY,
|
|
81
81
|
getCredentialManager
|
|
82
|
-
} from "./chunk-
|
|
82
|
+
} from "./chunk-ALBABQ53.js";
|
|
83
83
|
export {
|
|
84
84
|
ABC_EVENTS,
|
|
85
85
|
ABC_FEATURES,
|
|
@@ -0,0 +1,162 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
AbcBitcoinConnector,
|
|
4
|
+
AbcBitcoinProvider,
|
|
5
|
+
AbcError,
|
|
6
|
+
AbcErrorCode,
|
|
7
|
+
AbcEvmProvider,
|
|
8
|
+
AbcSolanaProvider,
|
|
9
|
+
AbcStorageKey,
|
|
10
|
+
AbcTronProvider,
|
|
11
|
+
BITCOIN_NETWORKS,
|
|
12
|
+
BitcoinNetwork,
|
|
13
|
+
BitcoinProviderError,
|
|
14
|
+
ConfigApi,
|
|
15
|
+
GasApi,
|
|
16
|
+
SessionExpiredError,
|
|
17
|
+
SolanaApi,
|
|
18
|
+
SolanaNetwork,
|
|
19
|
+
SolanaProviderError,
|
|
20
|
+
TRON_NETWORKS,
|
|
21
|
+
TalkenApiClient,
|
|
22
|
+
TokenApi,
|
|
23
|
+
TronNetwork,
|
|
24
|
+
TronProviderError,
|
|
25
|
+
WalletscanApi,
|
|
26
|
+
abcConnector,
|
|
27
|
+
abcWallet,
|
|
28
|
+
calculateExpiryTimestamp,
|
|
29
|
+
clearAuthState,
|
|
30
|
+
clearStorage,
|
|
31
|
+
createAbcBitcoinConnector,
|
|
32
|
+
createAbcError,
|
|
33
|
+
createAbcEvmProvider,
|
|
34
|
+
createAbcProvider,
|
|
35
|
+
createTalkenApiClient,
|
|
36
|
+
dispatchSessionExpired,
|
|
37
|
+
fetchWithSessionCheck,
|
|
38
|
+
generateMpcWallets,
|
|
39
|
+
getBitcoinNetwork,
|
|
40
|
+
getEvmNetwork,
|
|
41
|
+
getSolanaNetwork,
|
|
42
|
+
getStorageKey,
|
|
43
|
+
getTronNetwork,
|
|
44
|
+
handleUnauthorizedResponse,
|
|
45
|
+
hashPin,
|
|
46
|
+
hexToNumber,
|
|
47
|
+
isTokenExpired,
|
|
48
|
+
loadAuthState,
|
|
49
|
+
loadFromStorage,
|
|
50
|
+
numberToHex,
|
|
51
|
+
recoverMpcWallets,
|
|
52
|
+
refreshAccessToken,
|
|
53
|
+
removeFromStorage,
|
|
54
|
+
saveAuthState,
|
|
55
|
+
saveToStorage,
|
|
56
|
+
validateEmail,
|
|
57
|
+
validateMpcWallets,
|
|
58
|
+
validatePin
|
|
59
|
+
} from "./chunk-WPRIYR63.js";
|
|
60
|
+
import {
|
|
61
|
+
ABC_EVENTS,
|
|
62
|
+
ABC_FEATURES,
|
|
63
|
+
ABC_WALLET_METADATA,
|
|
64
|
+
AUTH_PROVIDERS,
|
|
65
|
+
BITCOIN_CHAIN_ID,
|
|
66
|
+
CHAIN_TYPES,
|
|
67
|
+
DEBUG_MODE,
|
|
68
|
+
DEFAULT_ABC_CONFIG,
|
|
69
|
+
ERROR_MESSAGES,
|
|
70
|
+
EVM_CHAINS,
|
|
71
|
+
MODAL_CONFIG,
|
|
72
|
+
PIN_CONFIG,
|
|
73
|
+
REQUEST_TIMEOUT,
|
|
74
|
+
RETRY_CONFIG,
|
|
75
|
+
SOCIAL_BUTTONS,
|
|
76
|
+
SOLANA_CHAIN_ID,
|
|
77
|
+
STORAGE_PREFIX,
|
|
78
|
+
STORAGE_VERSION,
|
|
79
|
+
SUCCESS_MESSAGES,
|
|
80
|
+
TOKEN_EXPIRY,
|
|
81
|
+
getCredentialManager
|
|
82
|
+
} from "./chunk-DNEDHHS4.js";
|
|
83
|
+
import "./chunk-R6ZE7JAZ.js";
|
|
84
|
+
export {
|
|
85
|
+
ABC_EVENTS,
|
|
86
|
+
ABC_FEATURES,
|
|
87
|
+
ABC_WALLET_METADATA,
|
|
88
|
+
AUTH_PROVIDERS,
|
|
89
|
+
AbcBitcoinConnector,
|
|
90
|
+
BitcoinNetwork as AbcBitcoinNetwork,
|
|
91
|
+
AbcBitcoinProvider,
|
|
92
|
+
AbcError,
|
|
93
|
+
AbcErrorCode,
|
|
94
|
+
AbcEvmProvider,
|
|
95
|
+
SolanaNetwork as AbcSolanaNetwork,
|
|
96
|
+
AbcSolanaProvider,
|
|
97
|
+
AbcStorageKey,
|
|
98
|
+
TronNetwork as AbcTronNetwork,
|
|
99
|
+
AbcTronProvider,
|
|
100
|
+
BITCOIN_CHAIN_ID,
|
|
101
|
+
BITCOIN_NETWORKS,
|
|
102
|
+
BitcoinProviderError,
|
|
103
|
+
CHAIN_TYPES,
|
|
104
|
+
ConfigApi,
|
|
105
|
+
DEBUG_MODE,
|
|
106
|
+
DEFAULT_ABC_CONFIG,
|
|
107
|
+
ERROR_MESSAGES,
|
|
108
|
+
EVM_CHAINS,
|
|
109
|
+
GasApi,
|
|
110
|
+
MODAL_CONFIG,
|
|
111
|
+
PIN_CONFIG,
|
|
112
|
+
REQUEST_TIMEOUT,
|
|
113
|
+
RETRY_CONFIG,
|
|
114
|
+
SOCIAL_BUTTONS,
|
|
115
|
+
SOLANA_CHAIN_ID,
|
|
116
|
+
STORAGE_PREFIX,
|
|
117
|
+
STORAGE_VERSION,
|
|
118
|
+
SUCCESS_MESSAGES,
|
|
119
|
+
SessionExpiredError,
|
|
120
|
+
SolanaApi,
|
|
121
|
+
SolanaProviderError,
|
|
122
|
+
TOKEN_EXPIRY,
|
|
123
|
+
TRON_NETWORKS,
|
|
124
|
+
TalkenApiClient,
|
|
125
|
+
TokenApi,
|
|
126
|
+
TronProviderError,
|
|
127
|
+
WalletscanApi,
|
|
128
|
+
abcConnector,
|
|
129
|
+
abcWallet,
|
|
130
|
+
calculateExpiryTimestamp,
|
|
131
|
+
clearAuthState,
|
|
132
|
+
clearStorage,
|
|
133
|
+
createAbcBitcoinConnector,
|
|
134
|
+
createAbcError,
|
|
135
|
+
createAbcEvmProvider,
|
|
136
|
+
createAbcProvider,
|
|
137
|
+
createTalkenApiClient,
|
|
138
|
+
dispatchSessionExpired,
|
|
139
|
+
fetchWithSessionCheck,
|
|
140
|
+
generateMpcWallets,
|
|
141
|
+
getBitcoinNetwork,
|
|
142
|
+
getCredentialManager,
|
|
143
|
+
getEvmNetwork,
|
|
144
|
+
getSolanaNetwork,
|
|
145
|
+
getStorageKey,
|
|
146
|
+
getTronNetwork,
|
|
147
|
+
handleUnauthorizedResponse,
|
|
148
|
+
hashPin,
|
|
149
|
+
hexToNumber,
|
|
150
|
+
isTokenExpired,
|
|
151
|
+
loadAuthState,
|
|
152
|
+
loadFromStorage,
|
|
153
|
+
numberToHex,
|
|
154
|
+
recoverMpcWallets,
|
|
155
|
+
refreshAccessToken,
|
|
156
|
+
removeFromStorage,
|
|
157
|
+
saveAuthState,
|
|
158
|
+
saveToStorage,
|
|
159
|
+
validateEmail,
|
|
160
|
+
validateMpcWallets,
|
|
161
|
+
validatePin
|
|
162
|
+
};
|
|
@@ -165,15 +165,12 @@ var TALKEN_API_ENDPOINTS = {
|
|
|
165
165
|
SOLANA_TX_STATUS: "/wallet/solana/tx-status",
|
|
166
166
|
TX_BTC: "/wallet/tx/btc",
|
|
167
167
|
TX_TVM: "/wallet/tx/tvm",
|
|
168
|
-
TRON_UTIL: "/wallet/tron",
|
|
169
168
|
// ── Gas (WaaS proxy) ───────────────────────────────────────────────
|
|
170
169
|
GAS_PRICE: "/wallet/gas/price",
|
|
171
170
|
GAS_SUGGESTED: "/wallet/gas/suggested",
|
|
172
171
|
GAS_ESTIMATE: "/wallet/gas/estimate",
|
|
173
|
-
// ── Nonce
|
|
172
|
+
// ── Nonce (WaaS proxy) ─────────────────────────────────────────────
|
|
174
173
|
NONCE: "/wallet/nonce",
|
|
175
|
-
ADDRESS_BALANCE: "/wallet/address/balance",
|
|
176
|
-
ETH_CALL: "/wallet/contract/eth-call",
|
|
177
174
|
// ── Relayer ────────────────────────────────────────────────────────
|
|
178
175
|
RELAYER_FEE_ESTIMATE: "/relayer/estimate-fee",
|
|
179
176
|
// ── Config / Runtime ───────────────────────────────────────────────
|
|
@@ -0,0 +1,379 @@
|
|
|
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
|
+
// src/wallets/walletConnectors/abcWallet/AbcCredentialManager.ts
|
|
207
|
+
var EMAIL_STORAGE_KEY = `${STORAGE_PREFIX}saved_email`;
|
|
208
|
+
var AUTH_STATE_KEY = `${STORAGE_PREFIX}auth_state`;
|
|
209
|
+
var EVM_CREDS_SESSION_KEY = `${STORAGE_PREFIX}evm_signing_creds`;
|
|
210
|
+
var PIN_HASH_SESSION_KEY = `${STORAGE_PREFIX}pin_hash`;
|
|
211
|
+
var AbcCredentialManager = class _AbcCredentialManager {
|
|
212
|
+
constructor() {
|
|
213
|
+
this.pinHash = null;
|
|
214
|
+
this.email_ = null;
|
|
215
|
+
this.restoreEmailFromStorage();
|
|
216
|
+
}
|
|
217
|
+
static getInstance() {
|
|
218
|
+
if (!_AbcCredentialManager.instance) {
|
|
219
|
+
_AbcCredentialManager.instance = new _AbcCredentialManager();
|
|
220
|
+
}
|
|
221
|
+
return _AbcCredentialManager.instance;
|
|
222
|
+
}
|
|
223
|
+
// ── PIN Hash (memory + sessionStorage) ───────────────────────────
|
|
224
|
+
setPinHash(hash) {
|
|
225
|
+
this.pinHash = hash;
|
|
226
|
+
if (typeof window !== "undefined") {
|
|
227
|
+
try {
|
|
228
|
+
sessionStorage.setItem(PIN_HASH_SESSION_KEY, hash);
|
|
229
|
+
} catch {
|
|
230
|
+
}
|
|
231
|
+
}
|
|
232
|
+
}
|
|
233
|
+
getPinHash() {
|
|
234
|
+
if (this.pinHash)
|
|
235
|
+
return this.pinHash;
|
|
236
|
+
if (typeof window !== "undefined") {
|
|
237
|
+
try {
|
|
238
|
+
const cached = sessionStorage.getItem(PIN_HASH_SESSION_KEY);
|
|
239
|
+
if (cached) {
|
|
240
|
+
this.pinHash = cached;
|
|
241
|
+
return cached;
|
|
242
|
+
}
|
|
243
|
+
} catch {
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
return null;
|
|
247
|
+
}
|
|
248
|
+
clearPinHash() {
|
|
249
|
+
this.pinHash = null;
|
|
250
|
+
if (typeof window !== "undefined") {
|
|
251
|
+
try {
|
|
252
|
+
sessionStorage.removeItem(PIN_HASH_SESSION_KEY);
|
|
253
|
+
} catch {
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
}
|
|
257
|
+
// ── Email ─────────────────────────────────────────────────────────
|
|
258
|
+
setEmail(email) {
|
|
259
|
+
this.email_ = email;
|
|
260
|
+
if (typeof window !== "undefined") {
|
|
261
|
+
try {
|
|
262
|
+
localStorage.setItem(EMAIL_STORAGE_KEY, email);
|
|
263
|
+
} catch {
|
|
264
|
+
}
|
|
265
|
+
}
|
|
266
|
+
}
|
|
267
|
+
/**
|
|
268
|
+
* Get recovery email.
|
|
269
|
+
* Priority: in-memory → auth_state JSON → saved_email localStorage
|
|
270
|
+
*/
|
|
271
|
+
getEmail() {
|
|
272
|
+
if (this.email_)
|
|
273
|
+
return this.email_;
|
|
274
|
+
if (typeof window === "undefined")
|
|
275
|
+
return null;
|
|
276
|
+
try {
|
|
277
|
+
const authState = localStorage.getItem(AUTH_STATE_KEY);
|
|
278
|
+
if (authState) {
|
|
279
|
+
const data = JSON.parse(authState);
|
|
280
|
+
const email = data?.user?.email || data?.wallet?.email;
|
|
281
|
+
if (typeof email === "string" && email.trim()) {
|
|
282
|
+
this.email_ = email.trim();
|
|
283
|
+
return this.email_;
|
|
284
|
+
}
|
|
285
|
+
}
|
|
286
|
+
} catch {
|
|
287
|
+
}
|
|
288
|
+
try {
|
|
289
|
+
const saved = localStorage.getItem(EMAIL_STORAGE_KEY);
|
|
290
|
+
if (saved?.trim()) {
|
|
291
|
+
this.email_ = saved.trim();
|
|
292
|
+
return this.email_;
|
|
293
|
+
}
|
|
294
|
+
} catch {
|
|
295
|
+
}
|
|
296
|
+
return null;
|
|
297
|
+
}
|
|
298
|
+
// ── EVM Signing Credentials (sessionStorage — tab-scoped) ────────
|
|
299
|
+
setEvmSigningCredentials(creds) {
|
|
300
|
+
if (typeof window === "undefined")
|
|
301
|
+
return;
|
|
302
|
+
try {
|
|
303
|
+
sessionStorage.setItem(EVM_CREDS_SESSION_KEY, JSON.stringify(creds));
|
|
304
|
+
} catch {
|
|
305
|
+
}
|
|
306
|
+
}
|
|
307
|
+
getEvmSigningCredentials() {
|
|
308
|
+
if (typeof window === "undefined")
|
|
309
|
+
return null;
|
|
310
|
+
try {
|
|
311
|
+
const raw = sessionStorage.getItem(EVM_CREDS_SESSION_KEY);
|
|
312
|
+
if (!raw)
|
|
313
|
+
return null;
|
|
314
|
+
const parsed = JSON.parse(raw);
|
|
315
|
+
if (parsed?.uid && parsed?.wid && parsed?.sid && parsed?.pvencstr && parsed?.encryptDevicePassword) {
|
|
316
|
+
return parsed;
|
|
317
|
+
}
|
|
318
|
+
return null;
|
|
319
|
+
} catch {
|
|
320
|
+
return null;
|
|
321
|
+
}
|
|
322
|
+
}
|
|
323
|
+
clearEvmSigningCredentials() {
|
|
324
|
+
if (typeof window === "undefined")
|
|
325
|
+
return;
|
|
326
|
+
try {
|
|
327
|
+
sessionStorage.removeItem(EVM_CREDS_SESSION_KEY);
|
|
328
|
+
} catch {
|
|
329
|
+
}
|
|
330
|
+
}
|
|
331
|
+
// ── Lifecycle ─────────────────────────────────────────────────────
|
|
332
|
+
/**
|
|
333
|
+
* Restore email from localStorage on initialization.
|
|
334
|
+
* PIN hash is intentionally NOT restored (memory-only).
|
|
335
|
+
*/
|
|
336
|
+
restoreEmailFromStorage() {
|
|
337
|
+
if (typeof window === "undefined")
|
|
338
|
+
return;
|
|
339
|
+
this.getEmail();
|
|
340
|
+
}
|
|
341
|
+
/**
|
|
342
|
+
* Clear all credentials (logout).
|
|
343
|
+
*/
|
|
344
|
+
clear() {
|
|
345
|
+
this.pinHash = null;
|
|
346
|
+
this.email_ = null;
|
|
347
|
+
this.clearEvmSigningCredentials();
|
|
348
|
+
}
|
|
349
|
+
};
|
|
350
|
+
function getCredentialManager() {
|
|
351
|
+
return AbcCredentialManager.getInstance();
|
|
352
|
+
}
|
|
353
|
+
|
|
354
|
+
export {
|
|
355
|
+
DEFAULT_ABC_CONFIG,
|
|
356
|
+
TOKEN_EXPIRY,
|
|
357
|
+
AUTH_PROVIDERS,
|
|
358
|
+
CHAIN_TYPES,
|
|
359
|
+
SOLANA_CHAIN_ID,
|
|
360
|
+
BITCOIN_CHAIN_ID,
|
|
361
|
+
EVM_CHAINS,
|
|
362
|
+
PIN_CONFIG,
|
|
363
|
+
STORAGE_VERSION,
|
|
364
|
+
REQUEST_TIMEOUT,
|
|
365
|
+
RETRY_CONFIG,
|
|
366
|
+
ABC_WALLET_METADATA,
|
|
367
|
+
MODAL_CONFIG,
|
|
368
|
+
SOCIAL_BUTTONS,
|
|
369
|
+
ERROR_MESSAGES,
|
|
370
|
+
SUCCESS_MESSAGES,
|
|
371
|
+
ABC_EVENTS,
|
|
372
|
+
STORAGE_PREFIX,
|
|
373
|
+
DEBUG_MODE,
|
|
374
|
+
ABC_FEATURES,
|
|
375
|
+
DEFAULT_TALKEN_API_CONFIG,
|
|
376
|
+
TALKEN_API_ENDPOINTS,
|
|
377
|
+
loadTgAccessKey,
|
|
378
|
+
getCredentialManager
|
|
379
|
+
};
|