@talken/talkenkit 2.4.20 → 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 +2007 -1067
- 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 +17 -17
- 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 +88 -88
- 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,302 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
createAbcEvmProvider
|
|
4
|
+
} from "./chunk-4FKUVQCM.js";
|
|
5
|
+
import {
|
|
6
|
+
setGlobalDefaultBitcoinNetwork,
|
|
7
|
+
setGlobalDefaultChainId,
|
|
8
|
+
setGlobalDefaultSolanaNetwork
|
|
9
|
+
} from "./chunk-O4AU63LK.js";
|
|
10
|
+
import {
|
|
11
|
+
createAbcWaasClient
|
|
12
|
+
} from "./chunk-JIJNCMJR.js";
|
|
13
|
+
import {
|
|
14
|
+
clearAuthState,
|
|
15
|
+
clearEncryptedTokens,
|
|
16
|
+
clearStorage,
|
|
17
|
+
loadAuthState,
|
|
18
|
+
loadFromStorage,
|
|
19
|
+
saveAuthState
|
|
20
|
+
} from "./chunk-LOSXI36Y.js";
|
|
21
|
+
|
|
22
|
+
// src/wallets/walletConnectors/abcWallet/abcConnector.ts
|
|
23
|
+
import { getTalkenApiClient } from "@talken/talkenkit";
|
|
24
|
+
import { createConnector } from "wagmi";
|
|
25
|
+
function abcConnector(options) {
|
|
26
|
+
const { config } = options;
|
|
27
|
+
if (config.defaultChainId) {
|
|
28
|
+
setGlobalDefaultChainId(config.defaultChainId);
|
|
29
|
+
}
|
|
30
|
+
if (config.defaultSolanaNetwork) {
|
|
31
|
+
setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
|
|
32
|
+
}
|
|
33
|
+
if (config.defaultBitcoinNetwork) {
|
|
34
|
+
setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
|
|
35
|
+
}
|
|
36
|
+
return createConnector((wagmiConfig) => {
|
|
37
|
+
const client = createAbcWaasClient(config);
|
|
38
|
+
const provider = createAbcEvmProvider(client);
|
|
39
|
+
let accountsChangedHandler;
|
|
40
|
+
let chainChangedHandler;
|
|
41
|
+
let disconnectHandler;
|
|
42
|
+
return {
|
|
43
|
+
id: "abc",
|
|
44
|
+
name: "ABC Wallet",
|
|
45
|
+
type: "abc",
|
|
46
|
+
/**
|
|
47
|
+
* Connect wallet
|
|
48
|
+
*/
|
|
49
|
+
async connect() {
|
|
50
|
+
try {
|
|
51
|
+
const authState = loadAuthState();
|
|
52
|
+
if (!authState || !authState.isAuthenticated || !authState.wallet) {
|
|
53
|
+
throw new Error("ABC_LOGIN_REQUIRED");
|
|
54
|
+
}
|
|
55
|
+
provider.setWallet(authState.wallet);
|
|
56
|
+
if (authState.accessToken && authState.refreshToken && authState.expiresAt) {
|
|
57
|
+
client.setTokens(
|
|
58
|
+
authState.accessToken,
|
|
59
|
+
authState.refreshToken,
|
|
60
|
+
authState.expiresAt
|
|
61
|
+
);
|
|
62
|
+
}
|
|
63
|
+
const accounts = await provider.request({
|
|
64
|
+
method: "eth_requestAccounts"
|
|
65
|
+
});
|
|
66
|
+
let currentChainId = await provider.request({
|
|
67
|
+
method: "eth_chainId"
|
|
68
|
+
});
|
|
69
|
+
const currentChainIdNumber = Number(currentChainId);
|
|
70
|
+
const isChainSupported = wagmiConfig.chains.some(
|
|
71
|
+
(c) => c.id === currentChainIdNumber
|
|
72
|
+
);
|
|
73
|
+
if (!isChainSupported && wagmiConfig.chains.length > 0) {
|
|
74
|
+
const fallbackChainId = wagmiConfig.chains[0].id;
|
|
75
|
+
await provider.request({
|
|
76
|
+
method: "wallet_switchEthereumChain",
|
|
77
|
+
params: [{ chainId: `0x${fallbackChainId.toString(16)}` }]
|
|
78
|
+
});
|
|
79
|
+
currentChainId = `0x${fallbackChainId.toString(16)}`;
|
|
80
|
+
if (authState.wallet) {
|
|
81
|
+
authState.wallet.chainId = fallbackChainId;
|
|
82
|
+
saveAuthState(authState);
|
|
83
|
+
}
|
|
84
|
+
}
|
|
85
|
+
if (accountsChangedHandler) {
|
|
86
|
+
provider.removeListener("accountsChanged", accountsChangedHandler);
|
|
87
|
+
}
|
|
88
|
+
accountsChangedHandler = (accounts2) => {
|
|
89
|
+
wagmiConfig.emitter.emit("change", {
|
|
90
|
+
accounts: accounts2
|
|
91
|
+
});
|
|
92
|
+
};
|
|
93
|
+
provider.on("accountsChanged", accountsChangedHandler);
|
|
94
|
+
if (chainChangedHandler) {
|
|
95
|
+
provider.removeListener("chainChanged", chainChangedHandler);
|
|
96
|
+
}
|
|
97
|
+
chainChangedHandler = (chainId) => {
|
|
98
|
+
wagmiConfig.emitter.emit("change", {
|
|
99
|
+
chainId: Number(chainId)
|
|
100
|
+
});
|
|
101
|
+
};
|
|
102
|
+
provider.on("chainChanged", chainChangedHandler);
|
|
103
|
+
if (disconnectHandler) {
|
|
104
|
+
provider.removeListener("disconnect", disconnectHandler);
|
|
105
|
+
}
|
|
106
|
+
disconnectHandler = () => {
|
|
107
|
+
wagmiConfig.emitter.emit("disconnect");
|
|
108
|
+
this.onDisconnect();
|
|
109
|
+
};
|
|
110
|
+
provider.on("disconnect", disconnectHandler);
|
|
111
|
+
wagmiConfig.emitter.emit("connect", {
|
|
112
|
+
accounts,
|
|
113
|
+
chainId: Number(currentChainId)
|
|
114
|
+
});
|
|
115
|
+
return {
|
|
116
|
+
accounts,
|
|
117
|
+
chainId: Number(currentChainId)
|
|
118
|
+
};
|
|
119
|
+
} catch (error) {
|
|
120
|
+
console.error("\u274C ABC Connector connect() failed:", {
|
|
121
|
+
message: error.message,
|
|
122
|
+
code: error.code,
|
|
123
|
+
error
|
|
124
|
+
});
|
|
125
|
+
if (error.message === "ABC_LOGIN_REQUIRED") {
|
|
126
|
+
throw error;
|
|
127
|
+
}
|
|
128
|
+
throw error;
|
|
129
|
+
}
|
|
130
|
+
},
|
|
131
|
+
/**
|
|
132
|
+
* Disconnect wallet
|
|
133
|
+
*/
|
|
134
|
+
async disconnect() {
|
|
135
|
+
if (accountsChangedHandler) {
|
|
136
|
+
provider.removeListener("accountsChanged", accountsChangedHandler);
|
|
137
|
+
accountsChangedHandler = void 0;
|
|
138
|
+
}
|
|
139
|
+
if (chainChangedHandler) {
|
|
140
|
+
provider.removeListener("chainChanged", chainChangedHandler);
|
|
141
|
+
chainChangedHandler = void 0;
|
|
142
|
+
}
|
|
143
|
+
if (disconnectHandler) {
|
|
144
|
+
provider.removeListener("disconnect", disconnectHandler);
|
|
145
|
+
disconnectHandler = void 0;
|
|
146
|
+
}
|
|
147
|
+
provider.clearWallet();
|
|
148
|
+
await client.logout();
|
|
149
|
+
let savedPinHash = null;
|
|
150
|
+
let savedEmail = null;
|
|
151
|
+
if (typeof window !== "undefined") {
|
|
152
|
+
savedPinHash = localStorage.getItem("talkenkit_abc_pin_hash");
|
|
153
|
+
savedEmail = localStorage.getItem("talkenkit_abc_saved_email");
|
|
154
|
+
}
|
|
155
|
+
clearAuthState();
|
|
156
|
+
clearEncryptedTokens();
|
|
157
|
+
if (typeof window !== "undefined") {
|
|
158
|
+
localStorage.removeItem("talkenkit_abc_enc_salt");
|
|
159
|
+
localStorage.removeItem("talkenkit_abc_enc_tokens");
|
|
160
|
+
if (savedPinHash) {
|
|
161
|
+
localStorage.setItem("talkenkit_abc_pin_hash", savedPinHash);
|
|
162
|
+
}
|
|
163
|
+
if (savedEmail) {
|
|
164
|
+
localStorage.setItem("talkenkit_abc_saved_email", savedEmail);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
},
|
|
168
|
+
/**
|
|
169
|
+
* Get accounts
|
|
170
|
+
*/
|
|
171
|
+
async getAccounts() {
|
|
172
|
+
const accounts = await provider.request({
|
|
173
|
+
method: "eth_accounts"
|
|
174
|
+
});
|
|
175
|
+
return accounts.map((account) => account);
|
|
176
|
+
},
|
|
177
|
+
/**
|
|
178
|
+
* Get chain ID
|
|
179
|
+
*/
|
|
180
|
+
async getChainId() {
|
|
181
|
+
const chainId = await provider.request({
|
|
182
|
+
method: "eth_chainId"
|
|
183
|
+
});
|
|
184
|
+
return Number(chainId);
|
|
185
|
+
},
|
|
186
|
+
/**
|
|
187
|
+
* Get provider
|
|
188
|
+
*/
|
|
189
|
+
async getProvider() {
|
|
190
|
+
return provider;
|
|
191
|
+
},
|
|
192
|
+
/**
|
|
193
|
+
* Check if authorized (has valid session)
|
|
194
|
+
* Auto-refreshes access token if expired but refresh token is valid
|
|
195
|
+
*/
|
|
196
|
+
async isAuthorized() {
|
|
197
|
+
try {
|
|
198
|
+
const authState = loadAuthState();
|
|
199
|
+
if (!authState || !authState.isAuthenticated) {
|
|
200
|
+
return false;
|
|
201
|
+
}
|
|
202
|
+
if (!authState.wallet) {
|
|
203
|
+
return false;
|
|
204
|
+
}
|
|
205
|
+
if (client.isAuthenticated()) {
|
|
206
|
+
return true;
|
|
207
|
+
}
|
|
208
|
+
const refreshToken = loadFromStorage(
|
|
209
|
+
"refresh_token" /* REFRESH_TOKEN */
|
|
210
|
+
);
|
|
211
|
+
if (!refreshToken) {
|
|
212
|
+
clearStorage();
|
|
213
|
+
return false;
|
|
214
|
+
}
|
|
215
|
+
try {
|
|
216
|
+
const api = getTalkenApiClient();
|
|
217
|
+
if (!api) {
|
|
218
|
+
clearStorage();
|
|
219
|
+
return false;
|
|
220
|
+
}
|
|
221
|
+
const res = await api.auth.refresh();
|
|
222
|
+
client.setTokens(
|
|
223
|
+
res.accessToken,
|
|
224
|
+
res.refreshToken,
|
|
225
|
+
Date.now() + res.expiresIn * 1e3
|
|
226
|
+
);
|
|
227
|
+
const updatedState = loadAuthState();
|
|
228
|
+
return updatedState?.isAuthenticated ?? false;
|
|
229
|
+
} catch (error) {
|
|
230
|
+
console.error("[AbcConnector] Token refresh failed:", error);
|
|
231
|
+
clearStorage();
|
|
232
|
+
return false;
|
|
233
|
+
}
|
|
234
|
+
} catch (error) {
|
|
235
|
+
console.error(
|
|
236
|
+
"[AbcConnector] Unexpected error in isAuthorized:",
|
|
237
|
+
error
|
|
238
|
+
);
|
|
239
|
+
return false;
|
|
240
|
+
}
|
|
241
|
+
},
|
|
242
|
+
/**
|
|
243
|
+
* Switch chain
|
|
244
|
+
*/
|
|
245
|
+
async switchChain({ chainId }) {
|
|
246
|
+
await provider.request({
|
|
247
|
+
method: "wallet_switchEthereumChain",
|
|
248
|
+
params: [{ chainId: `0x${chainId.toString(16)}` }]
|
|
249
|
+
});
|
|
250
|
+
const newChainId = await this.getChainId();
|
|
251
|
+
const authState = loadAuthState();
|
|
252
|
+
if (authState?.wallet) {
|
|
253
|
+
authState.wallet.chainId = newChainId;
|
|
254
|
+
saveAuthState(authState);
|
|
255
|
+
}
|
|
256
|
+
return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
|
|
257
|
+
id: chainId,
|
|
258
|
+
name: `Chain ${chainId}`,
|
|
259
|
+
nativeCurrency: {
|
|
260
|
+
name: "Ether",
|
|
261
|
+
decimals: 18,
|
|
262
|
+
symbol: "ETH"
|
|
263
|
+
},
|
|
264
|
+
rpcUrls: {
|
|
265
|
+
default: { http: [""] }
|
|
266
|
+
}
|
|
267
|
+
};
|
|
268
|
+
},
|
|
269
|
+
/**
|
|
270
|
+
* Handle accounts changed
|
|
271
|
+
*/
|
|
272
|
+
onAccountsChanged(accounts) {
|
|
273
|
+
if (accounts.length === 0) {
|
|
274
|
+
this.onDisconnect();
|
|
275
|
+
} else {
|
|
276
|
+
wagmiConfig.emitter.emit("change", {
|
|
277
|
+
accounts
|
|
278
|
+
});
|
|
279
|
+
}
|
|
280
|
+
},
|
|
281
|
+
/**
|
|
282
|
+
* Handle chain changed
|
|
283
|
+
*/
|
|
284
|
+
onChainChanged(chain) {
|
|
285
|
+
const chainId = Number(chain);
|
|
286
|
+
wagmiConfig.emitter.emit("change", { chainId });
|
|
287
|
+
},
|
|
288
|
+
/**
|
|
289
|
+
* Handle disconnect
|
|
290
|
+
*/
|
|
291
|
+
onDisconnect(_error) {
|
|
292
|
+
provider.clearWallet();
|
|
293
|
+
clearAuthState();
|
|
294
|
+
wagmiConfig.emitter.emit("disconnect");
|
|
295
|
+
}
|
|
296
|
+
};
|
|
297
|
+
});
|
|
298
|
+
}
|
|
299
|
+
|
|
300
|
+
export {
|
|
301
|
+
abcConnector
|
|
302
|
+
};
|
|
@@ -0,0 +1,272 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
loadAuthState,
|
|
4
|
+
saveAuthState
|
|
5
|
+
} from "./chunk-3AX66UHT.js";
|
|
6
|
+
|
|
7
|
+
// src/wallets/walletConnectors/abcWallet/abcBitcoinConnector.ts
|
|
8
|
+
var AbcBitcoinConnector = class {
|
|
9
|
+
constructor(config) {
|
|
10
|
+
this.wallet = null;
|
|
11
|
+
this.connected = false;
|
|
12
|
+
// Event listeners
|
|
13
|
+
this.connectListeners = /* @__PURE__ */ new Set();
|
|
14
|
+
this.disconnectListeners = /* @__PURE__ */ new Set();
|
|
15
|
+
this.accountsChangedListeners = /* @__PURE__ */ new Set();
|
|
16
|
+
this.networkChangedListeners = /* @__PURE__ */ new Set();
|
|
17
|
+
this.client = config.client;
|
|
18
|
+
this.provider = config.provider;
|
|
19
|
+
this.setupProviderListeners();
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Setup provider event listeners
|
|
23
|
+
*/
|
|
24
|
+
setupProviderListeners() {
|
|
25
|
+
this.provider.on("connect", () => {
|
|
26
|
+
this.connected = true;
|
|
27
|
+
if (this.wallet) {
|
|
28
|
+
for (const listener of this.connectListeners) {
|
|
29
|
+
listener(this.wallet);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
});
|
|
33
|
+
this.provider.on("disconnect", () => {
|
|
34
|
+
this.connected = false;
|
|
35
|
+
this.wallet = null;
|
|
36
|
+
for (const listener of this.disconnectListeners) {
|
|
37
|
+
listener();
|
|
38
|
+
}
|
|
39
|
+
});
|
|
40
|
+
this.provider.on("accountsChanged", (accounts) => {
|
|
41
|
+
for (const listener of this.accountsChangedListeners) {
|
|
42
|
+
listener(accounts);
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
this.provider.on("networkChanged", (network) => {
|
|
46
|
+
for (const listener of this.networkChangedListeners) {
|
|
47
|
+
listener(network);
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
}
|
|
51
|
+
/**
|
|
52
|
+
* Connect Bitcoin wallet
|
|
53
|
+
*/
|
|
54
|
+
async connect() {
|
|
55
|
+
try {
|
|
56
|
+
const authState = loadAuthState();
|
|
57
|
+
console.log("[BitcoinConnector] \u{1F527} connect() called:", {
|
|
58
|
+
hasAuthState: !!authState,
|
|
59
|
+
isAuthenticated: authState?.isAuthenticated,
|
|
60
|
+
hasBitcoinWallet: !!authState?.bitcoinWallet,
|
|
61
|
+
bitcoinAddress: authState?.bitcoinWallet?.address
|
|
62
|
+
});
|
|
63
|
+
if (!authState || !authState.isAuthenticated || !authState.bitcoinWallet) {
|
|
64
|
+
throw new Error("BITCOIN_LOGIN_REQUIRED");
|
|
65
|
+
}
|
|
66
|
+
this.wallet = authState.bitcoinWallet;
|
|
67
|
+
this.provider.setWallet(authState.bitcoinWallet);
|
|
68
|
+
console.log("[BitcoinConnector] \u2705 Wallet set:", {
|
|
69
|
+
address: authState.bitcoinWallet.address,
|
|
70
|
+
publicKey: authState.bitcoinWallet.publicKey,
|
|
71
|
+
addressType: authState.bitcoinWallet.addressType,
|
|
72
|
+
network: authState.bitcoinWallet.network
|
|
73
|
+
});
|
|
74
|
+
this.connected = true;
|
|
75
|
+
return {
|
|
76
|
+
address: authState.bitcoinWallet.address,
|
|
77
|
+
publicKey: authState.bitcoinWallet.publicKey,
|
|
78
|
+
network: authState.bitcoinWallet.network
|
|
79
|
+
};
|
|
80
|
+
} catch (error) {
|
|
81
|
+
if (error.message === "BITCOIN_LOGIN_REQUIRED") {
|
|
82
|
+
throw error;
|
|
83
|
+
}
|
|
84
|
+
console.error("[BitcoinConnector] \u274C connect error:", error);
|
|
85
|
+
throw error;
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Disconnect Bitcoin wallet
|
|
90
|
+
*/
|
|
91
|
+
async disconnect() {
|
|
92
|
+
try {
|
|
93
|
+
this.provider.clearWallet();
|
|
94
|
+
this.wallet = null;
|
|
95
|
+
this.connected = false;
|
|
96
|
+
console.log("[BitcoinConnector] \u2705 Wallet disconnected");
|
|
97
|
+
} catch (error) {
|
|
98
|
+
console.error("[BitcoinConnector] \u274C disconnect error:", error);
|
|
99
|
+
throw error;
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
/**
|
|
103
|
+
* Get Bitcoin address
|
|
104
|
+
*/
|
|
105
|
+
async getAddress() {
|
|
106
|
+
return this.provider.getAddress();
|
|
107
|
+
}
|
|
108
|
+
/**
|
|
109
|
+
* Get compressed public key (33 bytes)
|
|
110
|
+
*/
|
|
111
|
+
async getPublicKey() {
|
|
112
|
+
return this.provider.getPublicKey();
|
|
113
|
+
}
|
|
114
|
+
/**
|
|
115
|
+
* Get address type (bech32, p2pkh, etc.)
|
|
116
|
+
*/
|
|
117
|
+
getAddressType() {
|
|
118
|
+
return this.provider.getAddressType();
|
|
119
|
+
}
|
|
120
|
+
/**
|
|
121
|
+
* Get UTXOs
|
|
122
|
+
*/
|
|
123
|
+
async getUtxos(forceRefresh = false) {
|
|
124
|
+
return this.provider.getUtxos(forceRefresh);
|
|
125
|
+
}
|
|
126
|
+
/**
|
|
127
|
+
* Get balance (in satoshis)
|
|
128
|
+
*/
|
|
129
|
+
async getBalance(forceRefresh = false) {
|
|
130
|
+
return this.provider.getBalance(forceRefresh);
|
|
131
|
+
}
|
|
132
|
+
/**
|
|
133
|
+
* Estimate transaction fee
|
|
134
|
+
*/
|
|
135
|
+
async estimateFee(targetBlocks = 6) {
|
|
136
|
+
return this.provider.estimateFee(targetBlocks);
|
|
137
|
+
}
|
|
138
|
+
/**
|
|
139
|
+
* Sign Bitcoin message (BIP-322)
|
|
140
|
+
* NOTE: Currently not supported - Bitcoin uses v2 API which doesn't have message signing endpoint
|
|
141
|
+
*/
|
|
142
|
+
async signMessage(message) {
|
|
143
|
+
return this.provider.signMessage(message);
|
|
144
|
+
}
|
|
145
|
+
/**
|
|
146
|
+
* Send Bitcoin transaction (high-level API)
|
|
147
|
+
* Creates, signs, and broadcasts transaction
|
|
148
|
+
*/
|
|
149
|
+
async sendTransaction(params) {
|
|
150
|
+
return this.provider.sendTransaction(params);
|
|
151
|
+
}
|
|
152
|
+
/**
|
|
153
|
+
* Broadcast signed transaction to network (low-level API)
|
|
154
|
+
*/
|
|
155
|
+
async broadcastTransaction(rawTransaction, psbt) {
|
|
156
|
+
return this.provider.broadcastTransaction(rawTransaction, psbt);
|
|
157
|
+
}
|
|
158
|
+
/**
|
|
159
|
+
* Check if authorized (has valid session)
|
|
160
|
+
*/
|
|
161
|
+
async isAuthorized() {
|
|
162
|
+
try {
|
|
163
|
+
const authState = loadAuthState();
|
|
164
|
+
if (!authState || !authState.isAuthenticated) {
|
|
165
|
+
return false;
|
|
166
|
+
}
|
|
167
|
+
if (!authState.bitcoinWallet) {
|
|
168
|
+
return false;
|
|
169
|
+
}
|
|
170
|
+
return !this.client.auth.isTokenExpired();
|
|
171
|
+
} catch {
|
|
172
|
+
return false;
|
|
173
|
+
}
|
|
174
|
+
}
|
|
175
|
+
/**
|
|
176
|
+
* Check if connected
|
|
177
|
+
*/
|
|
178
|
+
isConnected() {
|
|
179
|
+
return this.connected && this.provider.isConnected();
|
|
180
|
+
}
|
|
181
|
+
/**
|
|
182
|
+
* Get current wallet
|
|
183
|
+
*/
|
|
184
|
+
getWallet() {
|
|
185
|
+
return this.wallet;
|
|
186
|
+
}
|
|
187
|
+
/**
|
|
188
|
+
* Get provider
|
|
189
|
+
*/
|
|
190
|
+
getProvider() {
|
|
191
|
+
return this.provider;
|
|
192
|
+
}
|
|
193
|
+
/**
|
|
194
|
+
* Get wallet info
|
|
195
|
+
*/
|
|
196
|
+
getWalletInfo() {
|
|
197
|
+
return this.provider.getWalletInfo();
|
|
198
|
+
}
|
|
199
|
+
/**
|
|
200
|
+
* Switch network
|
|
201
|
+
*/
|
|
202
|
+
async switchNetwork(network) {
|
|
203
|
+
this.provider.setNetwork(network);
|
|
204
|
+
const authState = loadAuthState();
|
|
205
|
+
if (authState?.bitcoinWallet) {
|
|
206
|
+
authState.bitcoinWallet.network = network === "mainnet" ? "bitcoin" /* Mainnet */ : "bitcoin_testnet" /* Testnet */;
|
|
207
|
+
saveAuthState(authState);
|
|
208
|
+
}
|
|
209
|
+
console.log("[BitcoinConnector] \u{1F504} Network switched to:", network);
|
|
210
|
+
}
|
|
211
|
+
/**
|
|
212
|
+
* Get current network
|
|
213
|
+
*/
|
|
214
|
+
getNetwork() {
|
|
215
|
+
return this.provider.getNetwork().type;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Refresh UTXO cache
|
|
219
|
+
*/
|
|
220
|
+
async refreshUtxos() {
|
|
221
|
+
return this.provider.refreshUtxos();
|
|
222
|
+
}
|
|
223
|
+
on(event, listener) {
|
|
224
|
+
switch (event) {
|
|
225
|
+
case "connect":
|
|
226
|
+
this.connectListeners.add(listener);
|
|
227
|
+
break;
|
|
228
|
+
case "disconnect":
|
|
229
|
+
this.disconnectListeners.add(listener);
|
|
230
|
+
break;
|
|
231
|
+
case "accountsChanged":
|
|
232
|
+
this.accountsChangedListeners.add(listener);
|
|
233
|
+
break;
|
|
234
|
+
case "networkChanged":
|
|
235
|
+
this.networkChangedListeners.add(listener);
|
|
236
|
+
break;
|
|
237
|
+
}
|
|
238
|
+
}
|
|
239
|
+
off(event, listener) {
|
|
240
|
+
switch (event) {
|
|
241
|
+
case "connect":
|
|
242
|
+
this.connectListeners.delete(listener);
|
|
243
|
+
break;
|
|
244
|
+
case "disconnect":
|
|
245
|
+
this.disconnectListeners.delete(listener);
|
|
246
|
+
break;
|
|
247
|
+
case "accountsChanged":
|
|
248
|
+
this.accountsChangedListeners.delete(listener);
|
|
249
|
+
break;
|
|
250
|
+
case "networkChanged":
|
|
251
|
+
this.networkChangedListeners.delete(listener);
|
|
252
|
+
break;
|
|
253
|
+
}
|
|
254
|
+
}
|
|
255
|
+
/**
|
|
256
|
+
* Remove all listeners
|
|
257
|
+
*/
|
|
258
|
+
removeAllListeners() {
|
|
259
|
+
this.connectListeners.clear();
|
|
260
|
+
this.disconnectListeners.clear();
|
|
261
|
+
this.accountsChangedListeners.clear();
|
|
262
|
+
this.networkChangedListeners.clear();
|
|
263
|
+
}
|
|
264
|
+
};
|
|
265
|
+
function createAbcBitcoinConnector(config) {
|
|
266
|
+
return new AbcBitcoinConnector(config);
|
|
267
|
+
}
|
|
268
|
+
|
|
269
|
+
export {
|
|
270
|
+
AbcBitcoinConnector,
|
|
271
|
+
createAbcBitcoinConnector
|
|
272
|
+
};
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
"use client";
|
|
2
|
+
import {
|
|
3
|
+
BaseApiClient
|
|
4
|
+
} from "./chunk-FFU26Y5Y.js";
|
|
5
|
+
import {
|
|
6
|
+
createAbcError
|
|
7
|
+
} from "./chunk-3AX66UHT.js";
|
|
8
|
+
import {
|
|
9
|
+
ABC_ENDPOINTS
|
|
10
|
+
} from "./chunk-RCIABMG5.js";
|
|
11
|
+
|
|
12
|
+
// src/wallets/walletConnectors/abcWallet/api/TransactionApi.ts
|
|
13
|
+
var TransactionApi = class extends BaseApiClient {
|
|
14
|
+
/**
|
|
15
|
+
* Get transaction count (nonce)
|
|
16
|
+
*/
|
|
17
|
+
async getTransactionCount(address, network, block = "latest") {
|
|
18
|
+
const nonceUrl = `${this.baseURL}${ABC_ENDPOINTS.TRANSACTION_COUNT}?address=${address}&network=${network}&block=${block}`;
|
|
19
|
+
const response = await fetch(nonceUrl, {
|
|
20
|
+
method: "GET",
|
|
21
|
+
headers: {
|
|
22
|
+
...this.accessToken ? { Authorization: `Bearer ${this.accessToken}` } : {}
|
|
23
|
+
}
|
|
24
|
+
});
|
|
25
|
+
if (response.ok) {
|
|
26
|
+
const data = await response.json();
|
|
27
|
+
return Number.parseInt(data.result, 16);
|
|
28
|
+
}
|
|
29
|
+
throw createAbcError(
|
|
30
|
+
"NETWORK_ERROR" /* NETWORK_ERROR */,
|
|
31
|
+
"Failed to get transaction count"
|
|
32
|
+
);
|
|
33
|
+
}
|
|
34
|
+
/**
|
|
35
|
+
* Get suggested gas fees for EIP-1559
|
|
36
|
+
*/
|
|
37
|
+
async getSuggestedGasFees(network) {
|
|
38
|
+
const url = `${this.baseURL}${ABC_ENDPOINTS.GAS_SUGGESTED_FEES}?network=${network}`;
|
|
39
|
+
const response = await fetch(url, {
|
|
40
|
+
method: "GET",
|
|
41
|
+
headers: {
|
|
42
|
+
...this.accessToken ? { Authorization: `Bearer ${this.accessToken}` } : {}
|
|
43
|
+
}
|
|
44
|
+
});
|
|
45
|
+
if (response.ok) {
|
|
46
|
+
const data = await response.json();
|
|
47
|
+
return data;
|
|
48
|
+
}
|
|
49
|
+
throw createAbcError(
|
|
50
|
+
"NETWORK_ERROR" /* NETWORK_ERROR */,
|
|
51
|
+
"Failed to get suggested gas fees"
|
|
52
|
+
);
|
|
53
|
+
}
|
|
54
|
+
/**
|
|
55
|
+
* Estimate gas limit for EIP-1559 transaction
|
|
56
|
+
*/
|
|
57
|
+
async estimateGas(params) {
|
|
58
|
+
const estimateBody = new URLSearchParams({
|
|
59
|
+
network: params.network,
|
|
60
|
+
to: params.to || "0x",
|
|
61
|
+
...params.from ? { from: params.from } : {},
|
|
62
|
+
...params.value ? { value: params.value } : {},
|
|
63
|
+
...params.data && params.data !== "0x" ? { data: params.data } : {},
|
|
64
|
+
...params.maxFeePerGas ? { maxFeePerGas: params.maxFeePerGas } : {},
|
|
65
|
+
...params.maxPriorityFeePerGas ? { maxPriorityFeePerGas: params.maxPriorityFeePerGas } : {}
|
|
66
|
+
});
|
|
67
|
+
const url = `${this.baseURL}${ABC_ENDPOINTS.GAS_ESTIMATE_EIP1559}`;
|
|
68
|
+
const response = await fetch(url, {
|
|
69
|
+
method: "POST",
|
|
70
|
+
headers: {
|
|
71
|
+
"Content-Type": "application/x-www-form-urlencoded",
|
|
72
|
+
...this.accessToken ? { Authorization: `Bearer ${this.accessToken}` } : {}
|
|
73
|
+
},
|
|
74
|
+
body: estimateBody.toString()
|
|
75
|
+
});
|
|
76
|
+
const data = await response.json();
|
|
77
|
+
if (response.ok && data.result) {
|
|
78
|
+
return data.result;
|
|
79
|
+
}
|
|
80
|
+
const fallbackGasLimit = "0x2dc6c0";
|
|
81
|
+
console.warn("\u26A0\uFE0F Gas estimate failed, using fallback:", {
|
|
82
|
+
error: data.errorMessage || data.msg,
|
|
83
|
+
fallbackGasLimit
|
|
84
|
+
});
|
|
85
|
+
return fallbackGasLimit;
|
|
86
|
+
}
|
|
87
|
+
};
|
|
88
|
+
|
|
89
|
+
export {
|
|
90
|
+
TransactionApi
|
|
91
|
+
};
|