@talken/talkenkit 2.4.21 → 2.4.22
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/LICENSE +9 -0
- package/dist/abcWallet-4RS3B4ZG.js +188 -0
- package/dist/abcWallet-EBOW2RJB.js +188 -0
- package/dist/abcWallet-RS4EOJ4I.js +188 -0
- package/dist/abcWallet-SNEZVK7V.js +188 -0
- package/dist/abcWallet-TC7M2JYX.js +188 -0
- package/dist/abcWallet-VZMW2DR3.js +188 -0
- package/dist/abcWallet-XJ3WSUVI.js +188 -0
- package/dist/abcWallet-XNCBZAIQ.js +188 -0
- package/dist/chunk-6FLQAAC4.js +7213 -0
- package/dist/chunk-7GIIMIPN.js +7213 -0
- package/dist/chunk-IBFA37SC.js +7228 -0
- package/dist/chunk-O5ZOC4NJ.js +7215 -0
- package/dist/chunk-OPOAKGEX.js +7216 -0
- package/dist/chunk-OTIHVCVR.js +7213 -0
- package/dist/chunk-P77BVZZF.js +7369 -0
- package/dist/chunk-RFLXXSQH.js +7139 -0
- package/dist/components/ConfirmationModal/NonEvmConfirmationModal.css.d.ts +11 -0
- package/dist/components/ConfirmationModal/NonEvmSignConfirmationModal.d.ts +9 -0
- package/dist/components/ConfirmationModal/NonEvmTransferConfirmationModal.d.ts +9 -0
- package/dist/components/ConfirmationModal/SignConfirmationModal.css.d.ts +1 -19
- package/dist/components/ConfirmationModal/TransactionConfirmationModal.css.d.ts +1 -20
- package/dist/components/ConfirmationModal/commonStyles.css.d.ts +19 -0
- package/dist/components/ConfirmationModal/index.d.ts +2 -0
- package/dist/components/ConfirmationModal/utils.d.ts +2 -1
- package/dist/hooks/useWalletCapabilities.d.ts +2 -0
- package/dist/index.css +227 -307
- package/dist/index.d.ts +4 -2
- package/dist/index.js +2004 -1064
- package/dist/providers/SignConfirmationProvider/NonEvmConfirmationContext.d.ts +6 -0
- package/dist/providers/SignConfirmationProvider/index.d.ts +2 -1
- package/dist/providers/SignConfirmationProvider/requestParsers.d.ts +6 -1
- package/dist/providers/SignConfirmationProvider/types.d.ts +35 -1
- package/dist/wallets/capabilities/detectCapabilities.d.ts +7 -0
- package/dist/wallets/capabilities/requestWalletAction.d.ts +8 -0
- package/dist/wallets/capabilities/types.d.ts +50 -0
- package/dist/wallets/walletConnectors/abcWallet/abcApi.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.d.ts +10 -0
- package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +5 -5
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.d.ts +9 -0
- package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.d.ts +10 -0
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.d.ts +16 -0
- package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +115 -33
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.d.ts +16 -0
- package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +7 -7
- package/dist/wallets/walletConnectors/abcWallet/api/AuthApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/BaseApiClient.js +3 -3
- package/dist/wallets/walletConnectors/abcWallet/api/BitcoinApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/GasApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +9 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +2 -2
- package/dist/wallets/walletConnectors/abcWallet/api/TransactionApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/TronApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/WalletApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +4 -4
- package/dist/wallets/walletConnectors/abcWallet/api/index.js +13 -13
- package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +5 -4
- package/dist/wallets/walletConnectors/abcWallet/constants.js +1 -1
- package/dist/wallets/walletConnectors/abcWallet/index.js +21 -21
- package/dist/wallets/walletConnectors/abcWallet/types.d.ts +31 -1
- package/dist/wallets/walletConnectors/abcWallet/utils.js +2 -2
- 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-2IZBLAHI.js +52 -0
- package/dist/wallets/walletConnectors/chunk-32IJ3ILH.js +71 -0
- package/dist/wallets/walletConnectors/chunk-3AX66UHT.js +479 -0
- package/dist/wallets/walletConnectors/chunk-3BVPV64G.js +36 -0
- package/dist/wallets/walletConnectors/chunk-3DGFHWI3.js +302 -0
- package/dist/wallets/walletConnectors/chunk-4FKUVQCM.js +655 -0
- package/dist/wallets/walletConnectors/chunk-56SF4VRC.js +640 -0
- package/dist/wallets/walletConnectors/chunk-5KOE7NJW.js +52 -0
- package/dist/wallets/walletConnectors/chunk-6CVXZ3ZW.js +771 -0
- package/dist/wallets/walletConnectors/chunk-6GCWEPU7.js +643 -0
- package/dist/wallets/walletConnectors/chunk-6YFP3Q2I.js +118 -0
- package/dist/wallets/walletConnectors/chunk-7EEPPULA.js +118 -0
- package/dist/wallets/walletConnectors/chunk-7QL42XTB.js +302 -0
- package/dist/wallets/walletConnectors/chunk-A7ZSPSFX.js +577 -0
- package/dist/wallets/walletConnectors/chunk-AI3CT254.js +302 -0
- package/dist/wallets/walletConnectors/chunk-AMNVH7CZ.js +151 -0
- package/dist/wallets/walletConnectors/chunk-AOREXGRM.js +350 -0
- package/dist/wallets/walletConnectors/chunk-BLO7E54F.js +302 -0
- package/dist/wallets/walletConnectors/chunk-BNRH5PYS.js +52 -0
- package/dist/wallets/walletConnectors/chunk-BOV5FXU6.js +151 -0
- package/dist/wallets/walletConnectors/chunk-BR25RFNF.js +260 -0
- package/dist/wallets/walletConnectors/chunk-BXQ2UWJ3.js +91 -0
- package/dist/wallets/walletConnectors/chunk-CAMPW7O2.js +874 -0
- package/dist/wallets/walletConnectors/chunk-CLMFCNP7.js +52 -0
- package/dist/wallets/walletConnectors/chunk-DSZOE65L.js +107 -0
- package/dist/wallets/walletConnectors/chunk-DU6RCLWT.js +272 -0
- package/dist/wallets/walletConnectors/chunk-ENN6UGGA.js +421 -0
- package/dist/wallets/walletConnectors/chunk-EXWDLN5V.js +204 -0
- package/dist/wallets/walletConnectors/chunk-FFU26Y5Y.js +272 -0
- package/dist/wallets/walletConnectors/chunk-FGS2WHVA.js +118 -0
- package/dist/wallets/walletConnectors/chunk-FJJ3QI4R.js +91 -0
- package/dist/wallets/walletConnectors/chunk-FS2OOQYF.js +204 -0
- package/dist/wallets/walletConnectors/chunk-G5X3COSW.js +205 -0
- package/dist/wallets/walletConnectors/chunk-H53R4SFZ.js +204 -0
- package/dist/wallets/walletConnectors/chunk-J4QGDATF.js +71 -0
- package/dist/wallets/walletConnectors/chunk-JIJNCMJR.js +874 -0
- package/dist/wallets/walletConnectors/chunk-JSGZYU4A.js +52 -0
- package/dist/wallets/walletConnectors/chunk-JVT7R2GZ.js +771 -0
- package/dist/wallets/walletConnectors/chunk-K3JNN5UK.js +71 -0
- package/dist/wallets/walletConnectors/chunk-KBHPY3NA.js +302 -0
- package/dist/wallets/walletConnectors/chunk-KEX6WS23.js +640 -0
- package/dist/wallets/walletConnectors/chunk-KHYKVVR7.js +52 -0
- package/dist/wallets/walletConnectors/chunk-LOL7ZZ3S.js +302 -0
- package/dist/wallets/walletConnectors/chunk-LOSXI36Y.js +479 -0
- package/dist/wallets/walletConnectors/chunk-M2U5QGM7.js +260 -0
- package/dist/wallets/walletConnectors/chunk-M73AWLIV.js +107 -0
- package/dist/wallets/walletConnectors/chunk-MAUC46AE.js +302 -0
- package/dist/wallets/walletConnectors/chunk-MBRXYEQC.js +272 -0
- package/dist/wallets/walletConnectors/chunk-MDDD4LG2.js +874 -0
- package/dist/wallets/walletConnectors/chunk-MMR2QAEU.js +642 -0
- package/dist/wallets/walletConnectors/chunk-MNZZRFUC.js +302 -0
- package/dist/wallets/walletConnectors/chunk-OIRY24PH.js +302 -0
- package/dist/wallets/walletConnectors/chunk-ORBX4JE2.js +52 -0
- package/dist/wallets/walletConnectors/chunk-OXJFFDW7.js +761 -0
- package/dist/wallets/walletConnectors/chunk-QD3PPWTN.js +272 -0
- package/dist/wallets/walletConnectors/chunk-RCIABMG5.js +259 -0
- package/dist/wallets/walletConnectors/chunk-RHC4SVLB.js +71 -0
- package/dist/wallets/walletConnectors/chunk-S2CB4KFC.js +71 -0
- package/dist/wallets/walletConnectors/chunk-S6HZD4XZ.js +302 -0
- package/dist/wallets/walletConnectors/chunk-S72LCNVX.js +272 -0
- package/dist/wallets/walletConnectors/chunk-SCWE5EEX.js +91 -0
- package/dist/wallets/walletConnectors/chunk-TKEL4D4E.js +151 -0
- package/dist/wallets/walletConnectors/chunk-TKJEMEBZ.js +71 -0
- package/dist/wallets/walletConnectors/chunk-TZ44ZREA.js +302 -0
- package/dist/wallets/walletConnectors/chunk-UGQSI3US.js +547 -0
- package/dist/wallets/walletConnectors/chunk-UU4JYY3C.js +205 -0
- package/dist/wallets/walletConnectors/chunk-V5P5BL6Z.js +302 -0
- package/dist/wallets/walletConnectors/chunk-VH6DIRPF.js +71 -0
- package/dist/wallets/walletConnectors/chunk-VPNZAMW5.js +205 -0
- package/dist/wallets/walletConnectors/chunk-W6QN6QXO.js +52 -0
- package/dist/wallets/walletConnectors/chunk-WDULICVN.js +302 -0
- package/dist/wallets/walletConnectors/chunk-WGGHGODM.js +272 -0
- package/dist/wallets/walletConnectors/chunk-XUCMTLM3.js +52 -0
- package/dist/wallets/walletConnectors/chunk-Y5WAX6WO.js +52 -0
- package/dist/wallets/walletConnectors/chunk-Y62PFBWE.js +640 -0
- package/dist/wallets/walletConnectors/chunk-Z6ABK6G6.js +107 -0
- package/dist/wallets/walletConnectors/chunk-ZCA5QSIM.js +71 -0
- package/dist/wallets/walletConnectors/chunk-ZJDZJW55.js +479 -0
- package/dist/wallets/walletConnectors/chunk-ZOF7ZDGU.js +52 -0
- package/dist/wallets/walletConnectors/chunk-ZUU57RHO.js +36 -0
- package/dist/wallets/walletConnectors/chunk-ZWFGRREM.js +36 -0
- package/dist/wallets/walletConnectors/chunk-ZY5BCHP2.js +302 -0
- 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 +91 -91
- 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/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 +11 -12
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
calculateExpiryTimestamp,
|
|
4
|
+
createAbcError,
|
|
5
|
+
isTokenExpired,
|
|
6
|
+
loadFromStorage,
|
|
7
|
+
parseApiError,
|
|
8
|
+
removeFromStorage,
|
|
9
|
+
saveToStorage
|
|
10
|
+
} from "./chunk-ZJDZJW55.js";
|
|
11
|
+
import {
|
|
12
|
+
DEFAULT_HEADERS,
|
|
13
|
+
REQUEST_TIMEOUT
|
|
14
|
+
} from "./chunk-M2U5QGM7.js";
|
|
15
|
+
|
|
16
|
+
// src/wallets/walletConnectors/abcWallet/api/BaseApiClient.ts
|
|
17
|
+
import { getTalkenApiClient } from "@talken/talkenkit";
|
|
18
|
+
var BaseApiClient = class {
|
|
19
|
+
constructor(config) {
|
|
20
|
+
this.accessToken = null;
|
|
21
|
+
this.refreshToken = null;
|
|
22
|
+
this.expiresAt = null;
|
|
23
|
+
this.isRefreshing = false;
|
|
24
|
+
this.refreshPromise = null;
|
|
25
|
+
this.config = config;
|
|
26
|
+
this.baseURL = config.waasUrl;
|
|
27
|
+
this.loadTokens();
|
|
28
|
+
}
|
|
29
|
+
/**
|
|
30
|
+
* Load tokens from storage
|
|
31
|
+
*/
|
|
32
|
+
loadTokens() {
|
|
33
|
+
this.accessToken = loadFromStorage("access_token" /* ACCESS_TOKEN */);
|
|
34
|
+
this.refreshToken = loadFromStorage("refresh_token" /* REFRESH_TOKEN */);
|
|
35
|
+
this.expiresAt = loadFromStorage("expires_at" /* EXPIRES_AT */);
|
|
36
|
+
}
|
|
37
|
+
/**
|
|
38
|
+
* Set tokens in client instance (useful when restoring from storage or state)
|
|
39
|
+
* Call this before making API requests if tokens are managed externally
|
|
40
|
+
*/
|
|
41
|
+
setTokens(accessToken, refreshToken, expiresAt) {
|
|
42
|
+
this.accessToken = accessToken;
|
|
43
|
+
this.refreshToken = refreshToken;
|
|
44
|
+
this.expiresAt = expiresAt;
|
|
45
|
+
}
|
|
46
|
+
/**
|
|
47
|
+
* Save tokens to storage
|
|
48
|
+
*/
|
|
49
|
+
saveTokens(accessToken, refreshToken, expiresIn) {
|
|
50
|
+
this.accessToken = accessToken;
|
|
51
|
+
this.refreshToken = refreshToken;
|
|
52
|
+
this.expiresAt = calculateExpiryTimestamp(expiresIn);
|
|
53
|
+
saveToStorage("access_token" /* ACCESS_TOKEN */, accessToken);
|
|
54
|
+
saveToStorage("refresh_token" /* REFRESH_TOKEN */, refreshToken);
|
|
55
|
+
saveToStorage("expires_at" /* EXPIRES_AT */, this.expiresAt);
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Clear tokens
|
|
59
|
+
*/
|
|
60
|
+
clearTokens() {
|
|
61
|
+
this.accessToken = null;
|
|
62
|
+
this.refreshToken = null;
|
|
63
|
+
this.expiresAt = null;
|
|
64
|
+
removeFromStorage("access_token" /* ACCESS_TOKEN */);
|
|
65
|
+
removeFromStorage("refresh_token" /* REFRESH_TOKEN */);
|
|
66
|
+
removeFromStorage("expires_at" /* EXPIRES_AT */);
|
|
67
|
+
}
|
|
68
|
+
/**
|
|
69
|
+
* Check if access token is expired
|
|
70
|
+
*/
|
|
71
|
+
isTokenExpired() {
|
|
72
|
+
return isTokenExpired(this.expiresAt);
|
|
73
|
+
}
|
|
74
|
+
/**
|
|
75
|
+
* Get current access token
|
|
76
|
+
*/
|
|
77
|
+
getAccessToken() {
|
|
78
|
+
return this.accessToken;
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* Set access token manually
|
|
82
|
+
*/
|
|
83
|
+
setAccessToken(token) {
|
|
84
|
+
this.accessToken = token;
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* Get base URL
|
|
88
|
+
*/
|
|
89
|
+
getBaseURL() {
|
|
90
|
+
return this.baseURL;
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* Get configuration
|
|
94
|
+
*/
|
|
95
|
+
getConfig() {
|
|
96
|
+
return this.config;
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* Refresh access token via TalkenApiClient
|
|
100
|
+
*/
|
|
101
|
+
async refreshAccessToken() {
|
|
102
|
+
if (this.isRefreshing) {
|
|
103
|
+
if (this.refreshPromise) {
|
|
104
|
+
await this.refreshPromise;
|
|
105
|
+
}
|
|
106
|
+
return;
|
|
107
|
+
}
|
|
108
|
+
const api = getTalkenApiClient();
|
|
109
|
+
if (api) {
|
|
110
|
+
this.isRefreshing = true;
|
|
111
|
+
this.refreshPromise = (async () => {
|
|
112
|
+
try {
|
|
113
|
+
const res = await api.auth.refresh();
|
|
114
|
+
this.saveTokens(res.accessToken, res.refreshToken, res.expiresIn);
|
|
115
|
+
} finally {
|
|
116
|
+
this.isRefreshing = false;
|
|
117
|
+
this.refreshPromise = null;
|
|
118
|
+
}
|
|
119
|
+
})();
|
|
120
|
+
await this.refreshPromise;
|
|
121
|
+
return;
|
|
122
|
+
}
|
|
123
|
+
if (!this.refreshToken) {
|
|
124
|
+
throw createAbcError(
|
|
125
|
+
"TOKEN_EXPIRED" /* TOKEN_EXPIRED */,
|
|
126
|
+
"No refresh token available"
|
|
127
|
+
);
|
|
128
|
+
}
|
|
129
|
+
throw createAbcError(
|
|
130
|
+
"TOKEN_EXPIRED" /* TOKEN_EXPIRED */,
|
|
131
|
+
"TalkenApiClient not initialized for token refresh"
|
|
132
|
+
);
|
|
133
|
+
}
|
|
134
|
+
/**
|
|
135
|
+
* Make HTTP request with automatic token refresh
|
|
136
|
+
*/
|
|
137
|
+
async request(endpoint, options = {}) {
|
|
138
|
+
const {
|
|
139
|
+
method = "GET",
|
|
140
|
+
body,
|
|
141
|
+
headers = {},
|
|
142
|
+
skipAuth = false,
|
|
143
|
+
isRetry = false,
|
|
144
|
+
contentType = "form"
|
|
145
|
+
// Default to form-encoded for backward compatibility
|
|
146
|
+
} = options;
|
|
147
|
+
if (!skipAuth && this.isTokenExpired() && this.refreshToken) {
|
|
148
|
+
await this.refreshAccessToken();
|
|
149
|
+
}
|
|
150
|
+
const url = `${this.baseURL}${endpoint}`;
|
|
151
|
+
const requestHeaders = {
|
|
152
|
+
...DEFAULT_HEADERS,
|
|
153
|
+
...headers
|
|
154
|
+
};
|
|
155
|
+
if (contentType === "json") {
|
|
156
|
+
requestHeaders["Content-Type"] = "application/json";
|
|
157
|
+
requestHeaders["Accept"] = "application/json";
|
|
158
|
+
}
|
|
159
|
+
if (this.config.environment === "production") {
|
|
160
|
+
requestHeaders["User-Agent"] = "Android";
|
|
161
|
+
}
|
|
162
|
+
if (!skipAuth && this.accessToken) {
|
|
163
|
+
requestHeaders.Authorization = `Bearer ${this.accessToken}`;
|
|
164
|
+
}
|
|
165
|
+
if (this.config.apiKey) {
|
|
166
|
+
requestHeaders["X-API-Key"] = this.config.apiKey;
|
|
167
|
+
}
|
|
168
|
+
try {
|
|
169
|
+
const controller = new AbortController();
|
|
170
|
+
const timeoutId = setTimeout(() => controller.abort(), REQUEST_TIMEOUT);
|
|
171
|
+
const requestBody = body ? contentType === "json" ? JSON.stringify(body) : new URLSearchParams(body).toString() : void 0;
|
|
172
|
+
const response = await fetch(url, {
|
|
173
|
+
method,
|
|
174
|
+
headers: requestHeaders,
|
|
175
|
+
body: requestBody,
|
|
176
|
+
signal: controller.signal
|
|
177
|
+
});
|
|
178
|
+
clearTimeout(timeoutId);
|
|
179
|
+
const text = await response.text();
|
|
180
|
+
let data;
|
|
181
|
+
if (text) {
|
|
182
|
+
try {
|
|
183
|
+
data = JSON.parse(text);
|
|
184
|
+
} catch (parseError) {
|
|
185
|
+
console.error("[BaseApiClient] \u274C JSON parse error:", {
|
|
186
|
+
url,
|
|
187
|
+
method,
|
|
188
|
+
status: response.status,
|
|
189
|
+
responseText: text.substring(0, 200)
|
|
190
|
+
});
|
|
191
|
+
throw createAbcError(
|
|
192
|
+
"UNKNOWN_ERROR" /* UNKNOWN_ERROR */,
|
|
193
|
+
"Invalid JSON response from server",
|
|
194
|
+
{ text, parseError }
|
|
195
|
+
);
|
|
196
|
+
}
|
|
197
|
+
} else {
|
|
198
|
+
data = { status: "success" };
|
|
199
|
+
}
|
|
200
|
+
if (response.status === 401 && !skipAuth && this.refreshToken && !isRetry) {
|
|
201
|
+
try {
|
|
202
|
+
await this.refreshAccessToken();
|
|
203
|
+
return await this.request(endpoint, {
|
|
204
|
+
...options,
|
|
205
|
+
isRetry: true
|
|
206
|
+
});
|
|
207
|
+
} catch (refreshError) {
|
|
208
|
+
console.error("Token refresh failed:", refreshError);
|
|
209
|
+
throw parseApiError({
|
|
210
|
+
response: {
|
|
211
|
+
status: response.status,
|
|
212
|
+
data
|
|
213
|
+
}
|
|
214
|
+
});
|
|
215
|
+
}
|
|
216
|
+
}
|
|
217
|
+
if (!response.ok) {
|
|
218
|
+
if (response.status !== 409) {
|
|
219
|
+
console.error("[BaseApiClient] \u274C API Error:", {
|
|
220
|
+
url,
|
|
221
|
+
method,
|
|
222
|
+
status: response.status,
|
|
223
|
+
statusText: response.statusText,
|
|
224
|
+
data
|
|
225
|
+
});
|
|
226
|
+
}
|
|
227
|
+
throw parseApiError({
|
|
228
|
+
response: {
|
|
229
|
+
status: response.status,
|
|
230
|
+
data
|
|
231
|
+
}
|
|
232
|
+
});
|
|
233
|
+
}
|
|
234
|
+
return data;
|
|
235
|
+
} catch (error) {
|
|
236
|
+
if (error.response?.status !== 409 && error.code !== "WALLET_ALREADY_EXISTS") {
|
|
237
|
+
console.error("[BaseApiClient] \u274C Request failed:", {
|
|
238
|
+
url,
|
|
239
|
+
method,
|
|
240
|
+
error: error.message
|
|
241
|
+
});
|
|
242
|
+
}
|
|
243
|
+
if (error.name === "AbortError") {
|
|
244
|
+
throw createAbcError(
|
|
245
|
+
"NETWORK_ERROR" /* NETWORK_ERROR */,
|
|
246
|
+
"Request timeout",
|
|
247
|
+
error
|
|
248
|
+
);
|
|
249
|
+
}
|
|
250
|
+
if (error.code && error.message) {
|
|
251
|
+
throw error;
|
|
252
|
+
}
|
|
253
|
+
throw parseApiError(error);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
/**
|
|
257
|
+
* Check if user is authenticated
|
|
258
|
+
*/
|
|
259
|
+
isAuthenticated() {
|
|
260
|
+
return !!this.accessToken && !this.isTokenExpired();
|
|
261
|
+
}
|
|
262
|
+
/**
|
|
263
|
+
* Logout (clear tokens)
|
|
264
|
+
*/
|
|
265
|
+
async logout() {
|
|
266
|
+
this.clearTokens();
|
|
267
|
+
}
|
|
268
|
+
};
|
|
269
|
+
|
|
270
|
+
export {
|
|
271
|
+
BaseApiClient
|
|
272
|
+
};
|
|
@@ -0,0 +1,259 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
|
|
3
|
+
// src/wallets/walletConnectors/abcWallet/constants.ts
|
|
4
|
+
var DEFAULT_ABC_CONFIG = {
|
|
5
|
+
environment: "development",
|
|
6
|
+
waasUrl: ""
|
|
7
|
+
// All operations routed through TalkenApiClient
|
|
8
|
+
};
|
|
9
|
+
var TOKEN_EXPIRY = {
|
|
10
|
+
ACCESS_TOKEN: 10 * 60 * 1e3,
|
|
11
|
+
// 10 minutes
|
|
12
|
+
REFRESH_TOKEN: 60 * 60 * 1e3,
|
|
13
|
+
// 60 minutes
|
|
14
|
+
REFRESH_BUFFER: 60 * 1e3
|
|
15
|
+
// Refresh 60s before expiry (increased for network latency tolerance)
|
|
16
|
+
};
|
|
17
|
+
var ABC_ENDPOINTS = {
|
|
18
|
+
// Authentication
|
|
19
|
+
SNS_LOGIN: "/abc/snsLogin",
|
|
20
|
+
// Legacy - may need to update
|
|
21
|
+
REGISTER_SNS_USER: "/abc/registerSnsUser",
|
|
22
|
+
// Legacy - may need to update
|
|
23
|
+
// Secure channel
|
|
24
|
+
SECURE_CHANNEL_CREATE: "/secure/channel/create",
|
|
25
|
+
// Email OTP
|
|
26
|
+
SEND_OTP: "/member/mail-service/{email}/sendcode",
|
|
27
|
+
// {email} placeholder
|
|
28
|
+
VERIFY_OTP: "/member/mail-service/{email}/verifycode",
|
|
29
|
+
// {email} placeholder
|
|
30
|
+
// Wallet operations (EVM)
|
|
31
|
+
// Based on tg-wallet-frontend reference
|
|
32
|
+
MPC_WALLETS: "/wapi/v2/mpc/wallets",
|
|
33
|
+
// EVM wallet generation/recovery
|
|
34
|
+
MPC_WALLETS_INFO: "/wapi/v2/mpc/wallets/info",
|
|
35
|
+
// Get wallet info
|
|
36
|
+
// Signing operations
|
|
37
|
+
// Based on tg-wallet-frontend reference implementation
|
|
38
|
+
SIGN_HASH: "/wapi/v2/sign/hash",
|
|
39
|
+
// Personal sign with hash (EIP-191)
|
|
40
|
+
SIGN_TYPED: "/wapi/v2/sign/typed-data",
|
|
41
|
+
// Typed data sign (EIP-712)
|
|
42
|
+
SIGN_TRANSACTION: "/wapi/v2/sign",
|
|
43
|
+
// EVM transaction sign (LEGACY, EIP1559, PERSONAL)
|
|
44
|
+
// Transaction operations
|
|
45
|
+
SEND_RAW_TX: "/wapi/v2/transactions/raw-tx/send",
|
|
46
|
+
// Send signed transaction
|
|
47
|
+
TRANSACTION_COUNT: "/wapi/v2/transactions/count",
|
|
48
|
+
// Get transaction count (nonce)
|
|
49
|
+
// Gas estimation and fee data
|
|
50
|
+
GAS_SUGGESTED_FEES: "/wapi/v2/gas/suggestedGasFees",
|
|
51
|
+
// Get suggested gas fees for EIP-1559
|
|
52
|
+
GAS_ESTIMATE_EIP1559: "/wapi/v2/gas/estimate/eip1559",
|
|
53
|
+
// Estimate gas limit for EIP-1559
|
|
54
|
+
// Token info (Walletscan)
|
|
55
|
+
WALLETSCAN_TOKEN: "/wapi/v2/walletscan/token",
|
|
56
|
+
// GET /{contractAddress}?networks=xxx
|
|
57
|
+
WALLETSCAN_NATIVES: "/wapi/v2/walletscan/natives",
|
|
58
|
+
// GET ?walletAddress=xxx&networks=xxx
|
|
59
|
+
WALLETSCAN_NFTS: "/wapi/v2/walletscan/nfts",
|
|
60
|
+
// GET /{contractAddress}?walletAddress=xxx&networks=xxx
|
|
61
|
+
// Token refresh (based on tg-wallet-frontend reference)
|
|
62
|
+
REFRESH_TOKEN: "/abc/abcRefresh",
|
|
63
|
+
// Token refresh endpoint
|
|
64
|
+
// Legacy endpoints (kept for compatibility)
|
|
65
|
+
WALLETS_V3: "/abc/wallets/v3",
|
|
66
|
+
// Solana only
|
|
67
|
+
INFO: "/abc/info"
|
|
68
|
+
};
|
|
69
|
+
var AUTH_PROVIDERS = {
|
|
70
|
+
EMAIL: "email",
|
|
71
|
+
GOOGLE: "google",
|
|
72
|
+
APPLE: "apple",
|
|
73
|
+
TELEGRAM: "telegram",
|
|
74
|
+
TWITTER: "twitter"
|
|
75
|
+
};
|
|
76
|
+
var CHAIN_TYPES = {
|
|
77
|
+
EVM: "evm",
|
|
78
|
+
SOLANA: "solana",
|
|
79
|
+
BITCOIN: "bitcoin"
|
|
80
|
+
};
|
|
81
|
+
var SOLANA_CHAIN_ID = 900;
|
|
82
|
+
var BITCOIN_CHAIN_ID = 800;
|
|
83
|
+
var EVM_CHAINS = {
|
|
84
|
+
ETHEREUM_MAINNET: 1,
|
|
85
|
+
ETHEREUM_GOERLI: 5,
|
|
86
|
+
ETHEREUM_SEPOLIA: 11155111,
|
|
87
|
+
POLYGON_MAINNET: 137,
|
|
88
|
+
POLYGON_MUMBAI: 80001,
|
|
89
|
+
BSC_MAINNET: 56,
|
|
90
|
+
BSC_TESTNET: 97,
|
|
91
|
+
ARBITRUM_MAINNET: 42161,
|
|
92
|
+
ARBITRUM_GOERLI: 421613,
|
|
93
|
+
OPTIMISM_MAINNET: 10,
|
|
94
|
+
OPTIMISM_GOERLI: 420,
|
|
95
|
+
AVALANCHE_MAINNET: 43114,
|
|
96
|
+
AVALANCHE_FUJI: 43113,
|
|
97
|
+
KLAYTN_MAINNET: 8217,
|
|
98
|
+
KLAYTN_BAOBAB: 1001
|
|
99
|
+
};
|
|
100
|
+
var ABC_AUDIENCE = "https://mw.myabcwallet.com";
|
|
101
|
+
var PIN_CONFIG = {
|
|
102
|
+
MIN_LENGTH: 6,
|
|
103
|
+
MAX_LENGTH: 6,
|
|
104
|
+
MAX_ATTEMPTS: 5,
|
|
105
|
+
LOCKOUT_DURATION: 15 * 60 * 1e3
|
|
106
|
+
// 15 minutes
|
|
107
|
+
};
|
|
108
|
+
var STORAGE_VERSION = "1.0.0";
|
|
109
|
+
var REQUEST_TIMEOUT = 3e4;
|
|
110
|
+
var RETRY_CONFIG = {
|
|
111
|
+
MAX_RETRIES: 3,
|
|
112
|
+
RETRY_DELAY: 1e3,
|
|
113
|
+
// 1 second
|
|
114
|
+
BACKOFF_MULTIPLIER: 2
|
|
115
|
+
};
|
|
116
|
+
var ABC_WALLET_METADATA = {
|
|
117
|
+
id: "abc",
|
|
118
|
+
name: "ABC Wallet",
|
|
119
|
+
iconBackground: "#ffffff",
|
|
120
|
+
rdns: "com.abcwallet"
|
|
121
|
+
};
|
|
122
|
+
var MODAL_CONFIG = {
|
|
123
|
+
WIDTH: 400,
|
|
124
|
+
MAX_WIDTH: "90vw",
|
|
125
|
+
BORDER_RADIUS: 16,
|
|
126
|
+
PADDING: 24
|
|
127
|
+
};
|
|
128
|
+
var SOCIAL_BUTTONS = [
|
|
129
|
+
{
|
|
130
|
+
provider: AUTH_PROVIDERS.GOOGLE,
|
|
131
|
+
label: "Google",
|
|
132
|
+
iconName: "google"
|
|
133
|
+
},
|
|
134
|
+
{
|
|
135
|
+
provider: AUTH_PROVIDERS.APPLE,
|
|
136
|
+
label: "Apple",
|
|
137
|
+
iconName: "apple"
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
provider: AUTH_PROVIDERS.TELEGRAM,
|
|
141
|
+
label: "Telegram",
|
|
142
|
+
iconName: "telegram"
|
|
143
|
+
},
|
|
144
|
+
{
|
|
145
|
+
provider: AUTH_PROVIDERS.TWITTER,
|
|
146
|
+
label: "X (Twitter)",
|
|
147
|
+
iconName: "twitter"
|
|
148
|
+
}
|
|
149
|
+
];
|
|
150
|
+
var ERROR_MESSAGES = {
|
|
151
|
+
INVALID_CREDENTIALS: "Invalid email or password",
|
|
152
|
+
TOKEN_EXPIRED: "Your session has expired. Please login again.",
|
|
153
|
+
WALLET_NOT_FOUND: "Wallet not found. Please create a new wallet.",
|
|
154
|
+
INVALID_PIN: "Invalid PIN code",
|
|
155
|
+
NETWORK_ERROR: "Network error. Please check your connection.",
|
|
156
|
+
SIGNATURE_FAILED: "Failed to sign transaction",
|
|
157
|
+
USER_CANCELLED: "User cancelled the operation",
|
|
158
|
+
UNKNOWN_ERROR: "An unknown error occurred",
|
|
159
|
+
INVALID_OTP: "Invalid or expired OTP code",
|
|
160
|
+
EMAIL_REQUIRED: "Email address is required",
|
|
161
|
+
PIN_REQUIRED: "PIN code is required",
|
|
162
|
+
WALLET_GENERATION_FAILED: "Failed to generate wallet"
|
|
163
|
+
};
|
|
164
|
+
var SUCCESS_MESSAGES = {
|
|
165
|
+
LOGIN_SUCCESS: "Successfully logged in",
|
|
166
|
+
WALLET_CREATED: "Wallet created successfully",
|
|
167
|
+
TRANSACTION_SENT: "Transaction sent successfully",
|
|
168
|
+
OTP_SENT: "OTP code sent to your email"
|
|
169
|
+
};
|
|
170
|
+
var ABC_EVENTS = {
|
|
171
|
+
CONNECT: "abc:connect",
|
|
172
|
+
DISCONNECT: "abc:disconnect",
|
|
173
|
+
ACCOUNTS_CHANGED: "abc:accountsChanged",
|
|
174
|
+
CHAIN_CHANGED: "abc:chainChanged",
|
|
175
|
+
ERROR: "abc:error",
|
|
176
|
+
AUTH_STATE_CHANGED: "abc:authStateChanged"
|
|
177
|
+
};
|
|
178
|
+
var STORAGE_PREFIX = "talkenkit_abc_";
|
|
179
|
+
var DEBUG_MODE = true;
|
|
180
|
+
var DEFAULT_HEADERS = {
|
|
181
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
182
|
+
Accept: "application/json"
|
|
183
|
+
};
|
|
184
|
+
var ABC_FEATURES = {
|
|
185
|
+
EMAIL_LOGIN: true,
|
|
186
|
+
SOCIAL_LOGIN: true,
|
|
187
|
+
MULTI_CHAIN: true,
|
|
188
|
+
EVM_SUPPORT: true,
|
|
189
|
+
SOLANA_SUPPORT: true,
|
|
190
|
+
BITCOIN_SUPPORT: false,
|
|
191
|
+
// Future feature
|
|
192
|
+
GASLESS_TRANSACTIONS: false,
|
|
193
|
+
// Future feature
|
|
194
|
+
SOCIAL_RECOVERY: false
|
|
195
|
+
// Future feature
|
|
196
|
+
};
|
|
197
|
+
var DEFAULT_TALKEN_API_CONFIG = {
|
|
198
|
+
baseUrl: void 0,
|
|
199
|
+
timeout: REQUEST_TIMEOUT
|
|
200
|
+
};
|
|
201
|
+
var TALKEN_API_ENDPOINTS = {
|
|
202
|
+
// ── Auth (single action-based endpoint) ─────────────────────────────
|
|
203
|
+
AUTH: "/wallet/auth",
|
|
204
|
+
// ── Wallet ──────────────────────────────────────────────────────────
|
|
205
|
+
WALLET_MPC: "/wallet/mpc",
|
|
206
|
+
WALLET_ADDRESS: "/wallet/address",
|
|
207
|
+
WALLET_SCAN: "/wallet/scan",
|
|
208
|
+
WALLET_BTC: "/wallet/btc",
|
|
209
|
+
// ── EVM Sign (WaaS proxy) ───────────────────────────────────────────
|
|
210
|
+
SIGN_EVM: "/wallet/sign/evm",
|
|
211
|
+
SIGN_TYPED: "/wallet/sign/typed",
|
|
212
|
+
SIGN_PERSONAL: "/wallet/sign/personal",
|
|
213
|
+
// ── Hash Sign (secp256k1, universal: EVM/BTC/TVM) ───────────────────
|
|
214
|
+
SIGN_HASH: "/wallet/sign/hash",
|
|
215
|
+
// ── SOL Sign (WaaS proxy) ───────────────────────────────────────────
|
|
216
|
+
SIGN_SVM: "/wallet/sign/sol",
|
|
217
|
+
// ── TX ──────────────────────────────────────────────────────────────
|
|
218
|
+
TX_RAW: "/wallet/tx/raw",
|
|
219
|
+
TX_EVM: "/wallet/tx/evm",
|
|
220
|
+
TX_SOL: "/wallet/tx/sol",
|
|
221
|
+
TX_BTC: "/wallet/tx/btc",
|
|
222
|
+
TX_TVM: "/wallet/tx/tvm",
|
|
223
|
+
// ── Gas (WaaS proxy) ───────────────────────────────────────────────
|
|
224
|
+
GAS_PRICE: "/wallet/gas/price",
|
|
225
|
+
GAS_SUGGESTED: "/wallet/gas/suggested",
|
|
226
|
+
GAS_ESTIMATE: "/wallet/gas/estimate",
|
|
227
|
+
// ── Nonce (WaaS proxy) ─────────────────────────────────────────────
|
|
228
|
+
NONCE: "/wallet/nonce",
|
|
229
|
+
// ── Relayer ────────────────────────────────────────────────────────
|
|
230
|
+
RELAYER_FEE_ESTIMATE: "/relayer/estimate-fee"
|
|
231
|
+
};
|
|
232
|
+
|
|
233
|
+
export {
|
|
234
|
+
DEFAULT_ABC_CONFIG,
|
|
235
|
+
TOKEN_EXPIRY,
|
|
236
|
+
ABC_ENDPOINTS,
|
|
237
|
+
AUTH_PROVIDERS,
|
|
238
|
+
CHAIN_TYPES,
|
|
239
|
+
SOLANA_CHAIN_ID,
|
|
240
|
+
BITCOIN_CHAIN_ID,
|
|
241
|
+
EVM_CHAINS,
|
|
242
|
+
ABC_AUDIENCE,
|
|
243
|
+
PIN_CONFIG,
|
|
244
|
+
STORAGE_VERSION,
|
|
245
|
+
REQUEST_TIMEOUT,
|
|
246
|
+
RETRY_CONFIG,
|
|
247
|
+
ABC_WALLET_METADATA,
|
|
248
|
+
MODAL_CONFIG,
|
|
249
|
+
SOCIAL_BUTTONS,
|
|
250
|
+
ERROR_MESSAGES,
|
|
251
|
+
SUCCESS_MESSAGES,
|
|
252
|
+
ABC_EVENTS,
|
|
253
|
+
STORAGE_PREFIX,
|
|
254
|
+
DEBUG_MODE,
|
|
255
|
+
DEFAULT_HEADERS,
|
|
256
|
+
ABC_FEATURES,
|
|
257
|
+
DEFAULT_TALKEN_API_CONFIG,
|
|
258
|
+
TALKEN_API_ENDPOINTS
|
|
259
|
+
};
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
TransactionApi
|
|
4
|
+
} from "./chunk-BXQ2UWJ3.js";
|
|
5
|
+
import {
|
|
6
|
+
TronApi
|
|
7
|
+
} from "./chunk-3BVPV64G.js";
|
|
8
|
+
import {
|
|
9
|
+
WalletApi
|
|
10
|
+
} from "./chunk-7EEPPULA.js";
|
|
11
|
+
import {
|
|
12
|
+
WalletscanApi
|
|
13
|
+
} from "./chunk-BOV5FXU6.js";
|
|
14
|
+
import {
|
|
15
|
+
AuthApi
|
|
16
|
+
} from "./chunk-FS2OOQYF.js";
|
|
17
|
+
import {
|
|
18
|
+
GasApi
|
|
19
|
+
} from "./chunk-M73AWLIV.js";
|
|
20
|
+
import {
|
|
21
|
+
BitcoinApi
|
|
22
|
+
} from "./chunk-G5X3COSW.js";
|
|
23
|
+
import {
|
|
24
|
+
SolanaApi
|
|
25
|
+
} from "./chunk-MNZZRFUC.js";
|
|
26
|
+
|
|
27
|
+
// src/wallets/walletConnectors/abcWallet/api/index.ts
|
|
28
|
+
var AbcWaasApiClient = class {
|
|
29
|
+
constructor(config) {
|
|
30
|
+
this.auth = new AuthApi(config);
|
|
31
|
+
this.wallet = new WalletApi(config);
|
|
32
|
+
this.transaction = new TransactionApi(config);
|
|
33
|
+
this.solana = new SolanaApi(config);
|
|
34
|
+
this.bitcoin = new BitcoinApi(config);
|
|
35
|
+
this.tron = new TronApi(config);
|
|
36
|
+
this.walletscan = new WalletscanApi(config);
|
|
37
|
+
this.gas = new GasApi(config);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Check if user is authenticated
|
|
41
|
+
*/
|
|
42
|
+
isAuthenticated() {
|
|
43
|
+
return this.auth.isAuthenticated();
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if access token is expired
|
|
47
|
+
*/
|
|
48
|
+
isTokenExpired() {
|
|
49
|
+
return this.auth.isTokenExpired();
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Get current access token
|
|
53
|
+
*/
|
|
54
|
+
getAccessToken() {
|
|
55
|
+
return this.auth.getAccessToken();
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Logout (clear tokens)
|
|
59
|
+
*/
|
|
60
|
+
async logout() {
|
|
61
|
+
await this.auth.logout();
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
function createAbcWaasApiClient(config) {
|
|
65
|
+
return new AbcWaasApiClient(config);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
export {
|
|
69
|
+
AbcWaasApiClient,
|
|
70
|
+
createAbcWaasApiClient
|
|
71
|
+
};
|
|
@@ -0,0 +1,71 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
TransactionApi
|
|
4
|
+
} from "./chunk-FJJ3QI4R.js";
|
|
5
|
+
import {
|
|
6
|
+
TronApi
|
|
7
|
+
} from "./chunk-ZUU57RHO.js";
|
|
8
|
+
import {
|
|
9
|
+
WalletApi
|
|
10
|
+
} from "./chunk-FGS2WHVA.js";
|
|
11
|
+
import {
|
|
12
|
+
WalletscanApi
|
|
13
|
+
} from "./chunk-TKEL4D4E.js";
|
|
14
|
+
import {
|
|
15
|
+
AuthApi
|
|
16
|
+
} from "./chunk-EXWDLN5V.js";
|
|
17
|
+
import {
|
|
18
|
+
BitcoinApi
|
|
19
|
+
} from "./chunk-VPNZAMW5.js";
|
|
20
|
+
import {
|
|
21
|
+
GasApi
|
|
22
|
+
} from "./chunk-Z6ABK6G6.js";
|
|
23
|
+
import {
|
|
24
|
+
SolanaApi
|
|
25
|
+
} from "./chunk-OIRY24PH.js";
|
|
26
|
+
|
|
27
|
+
// src/wallets/walletConnectors/abcWallet/api/index.ts
|
|
28
|
+
var AbcWaasApiClient = class {
|
|
29
|
+
constructor(config) {
|
|
30
|
+
this.auth = new AuthApi(config);
|
|
31
|
+
this.wallet = new WalletApi(config);
|
|
32
|
+
this.transaction = new TransactionApi(config);
|
|
33
|
+
this.solana = new SolanaApi(config);
|
|
34
|
+
this.bitcoin = new BitcoinApi(config);
|
|
35
|
+
this.tron = new TronApi(config);
|
|
36
|
+
this.walletscan = new WalletscanApi(config);
|
|
37
|
+
this.gas = new GasApi(config);
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Check if user is authenticated
|
|
41
|
+
*/
|
|
42
|
+
isAuthenticated() {
|
|
43
|
+
return this.auth.isAuthenticated();
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Check if access token is expired
|
|
47
|
+
*/
|
|
48
|
+
isTokenExpired() {
|
|
49
|
+
return this.auth.isTokenExpired();
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Get current access token
|
|
53
|
+
*/
|
|
54
|
+
getAccessToken() {
|
|
55
|
+
return this.auth.getAccessToken();
|
|
56
|
+
}
|
|
57
|
+
/**
|
|
58
|
+
* Logout (clear tokens)
|
|
59
|
+
*/
|
|
60
|
+
async logout() {
|
|
61
|
+
await this.auth.logout();
|
|
62
|
+
}
|
|
63
|
+
};
|
|
64
|
+
function createAbcWaasApiClient(config) {
|
|
65
|
+
return new AbcWaasApiClient(config);
|
|
66
|
+
}
|
|
67
|
+
|
|
68
|
+
export {
|
|
69
|
+
AbcWaasApiClient,
|
|
70
|
+
createAbcWaasApiClient
|
|
71
|
+
};
|