@talken/talkenkit 2.4.15 → 2.4.17

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.
Files changed (234) hide show
  1. package/dist/abcWallet-54KUGWUZ.js +192 -0
  2. package/dist/abcWallet-KZHOADBJ.js +192 -0
  3. package/dist/abcWallet-NZAVB4PI.js +190 -0
  4. package/dist/chunk-5X3ROW3U.js +8777 -0
  5. package/dist/chunk-DKA3NVFM.js +8497 -0
  6. package/dist/chunk-QNZ5HSPM.js +8339 -0
  7. package/dist/chunk-VE53ZNZV.js +331 -0
  8. package/dist/components/ConfirmationModal/ApproveSection.css.d.ts +16 -0
  9. package/dist/components/ConfirmationModal/ApproveSection.d.ts +8 -0
  10. package/dist/components/ConfirmationModal/NFTPlaceholder.css.d.ts +7 -0
  11. package/dist/components/ConfirmationModal/NFTPlaceholder.d.ts +8 -0
  12. package/dist/components/ConfirmationModal/NftApprovalSection.css.d.ts +10 -0
  13. package/dist/components/ConfirmationModal/NftApprovalSection.d.ts +7 -0
  14. package/dist/components/ConfirmationModal/SignConfirmationModal.css.d.ts +35 -0
  15. package/dist/components/ConfirmationModal/SignConfirmationModal.d.ts +17 -0
  16. package/dist/components/ConfirmationModal/SwapSection.css.d.ts +17 -0
  17. package/dist/components/ConfirmationModal/SwapSection.d.ts +7 -0
  18. package/dist/components/ConfirmationModal/TransactionConfirmationModal.css.d.ts +49 -0
  19. package/dist/components/ConfirmationModal/TransactionConfirmationModal.d.ts +12 -0
  20. package/dist/components/ConfirmationModal/TransferSection.css.d.ts +17 -0
  21. package/dist/components/ConfirmationModal/TransferSection.d.ts +7 -0
  22. package/dist/components/ConfirmationModal/commonStyles.css.d.ts +37 -0
  23. package/dist/components/ConfirmationModal/constants.d.ts +16 -0
  24. package/dist/components/ConfirmationModal/index.d.ts +9 -0
  25. package/dist/components/ConfirmationModal/modalTheme.css.d.ts +20 -0
  26. package/dist/components/ConfirmationModal/transactionUIRegistry.d.ts +134 -0
  27. package/dist/components/ConfirmationModal/utils.d.ts +37 -0
  28. package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthSections.css.d.ts +1 -0
  29. package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthSections.d.ts +1 -1
  30. package/dist/components/ConnectOptions/AbcWaasAuth/hooks/useAbcWaasAuth.d.ts +2 -25
  31. package/dist/components/ConnectOptions/AbcWaasAuth/hooks/useAbcWaasSocial.d.ts +1 -47
  32. package/dist/components/ConnectOptions/PinAuth/hooks/useWalletGeneration.d.ts +4 -21
  33. package/dist/components/GasFeeModal/GasFeeEditModal.css.d.ts +32 -0
  34. package/dist/components/GasFeeModal/GasFeeEditModal.d.ts +21 -0
  35. package/dist/components/GasFeeModal/index.d.ts +3 -0
  36. package/dist/components/GasFeeModal/modalTheme.css.d.ts +19 -0
  37. package/dist/components/Icons/Close2.d.ts +7 -0
  38. package/dist/components/Icons/Copy2.d.ts +4 -0
  39. package/dist/components/Icons/Dropdown2.d.ts +4 -0
  40. package/dist/components/Icons/Edit.d.ts +4 -0
  41. package/dist/components/Icons/InfoCircle.d.ts +4 -0
  42. package/dist/components/Icons/Kakao.d.ts +2 -0
  43. package/dist/components/Icons/Minus.d.ts +4 -0
  44. package/dist/components/Icons/Plus.d.ts +4 -0
  45. package/dist/components/Icons/SettingsGear.d.ts +4 -0
  46. package/dist/components/Icons/SpeedHigh.d.ts +4 -0
  47. package/dist/components/Icons/SpeedLow.d.ts +4 -0
  48. package/dist/components/Icons/SpeedMedium.d.ts +4 -0
  49. package/dist/components/RainbowKitProvider/InternalPinProvider.d.ts +7 -9
  50. package/dist/components/RainbowKitProvider/RainbowKitConfigProvider.d.ts +1 -6
  51. package/dist/components/RainbowKitProvider/RainbowKitProvider.d.ts +7 -7
  52. package/dist/components/Toast/Toast.css.d.ts +2 -0
  53. package/dist/components/Toast/Toast.d.ts +6 -0
  54. package/dist/components/Toast/index.d.ts +4 -0
  55. package/dist/components/Toast/useToast.d.ts +10 -0
  56. package/dist/config/networks.d.ts +10 -0
  57. package/dist/css/sprinkles.css.d.ts +1 -1
  58. package/dist/hooks/useSolanaWallet.d.ts +5 -23
  59. package/dist/hooks/useTronWallet.d.ts +63 -0
  60. package/dist/index.css +1903 -236
  61. package/dist/index.d.ts +8 -3
  62. package/dist/index.js +7557 -3592
  63. package/dist/klipWallet-RD5Y4UEK.js +8 -0
  64. package/dist/providers/SignConfirmationProvider/SignConfirmationProvider.d.ts +22 -0
  65. package/dist/providers/SignConfirmationProvider/index.d.ts +6 -0
  66. package/dist/providers/SignConfirmationProvider/requestParsers.d.ts +24 -0
  67. package/dist/providers/SignConfirmationProvider/types.d.ts +91 -0
  68. package/dist/providers/SignConfirmationProvider/useApiClient.d.ts +15 -0
  69. package/dist/providers/SignConfirmationProvider/useTransactionResolver.d.ts +18 -0
  70. package/dist/secure-AEBFSVWE.js +8 -0
  71. package/dist/services/AbcAgenticWalletService.d.ts +111 -0
  72. package/dist/services/AbcAuthService.d.ts +26 -20
  73. package/dist/types/index.d.ts +3 -0
  74. package/dist/types/token.d.ts +82 -0
  75. package/dist/utils/abi/abiDecoder.d.ts +144 -0
  76. package/dist/utils/apiClientFactory.d.ts +21 -0
  77. package/dist/utils/blockies.d.ts +12 -0
  78. package/dist/utils/tokenMapper.d.ts +10 -0
  79. package/dist/wallets/walletConnectors/abcWallet/abcApi.d.ts +4 -1
  80. package/dist/wallets/walletConnectors/abcWallet/abcApi.js +7 -7
  81. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +5 -5
  82. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.d.ts +6 -8
  83. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +1 -1
  84. package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +9 -9
  85. package/dist/wallets/walletConnectors/abcWallet/abcProvider.d.ts +17 -6
  86. package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +5 -4
  87. package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.d.ts +11 -34
  88. package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +1 -1
  89. package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.d.ts +3 -11
  90. package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +17 -80
  91. package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.d.ts +112 -0
  92. package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +11 -0
  93. package/dist/wallets/walletConnectors/abcWallet/abcWallet.d.ts +2 -0
  94. package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +11 -10
  95. package/dist/wallets/walletConnectors/abcWallet/api/AuthApi.d.ts +9 -11
  96. package/dist/wallets/walletConnectors/abcWallet/api/AuthApi.js +6 -6
  97. package/dist/wallets/walletConnectors/abcWallet/api/BaseApiClient.d.ts +1 -1
  98. package/dist/wallets/walletConnectors/abcWallet/api/BaseApiClient.js +5 -5
  99. package/dist/wallets/walletConnectors/abcWallet/api/BitcoinApi.js +6 -6
  100. package/dist/wallets/walletConnectors/abcWallet/api/GasApi.d.ts +45 -0
  101. package/dist/wallets/walletConnectors/abcWallet/api/GasApi.js +12 -0
  102. package/dist/wallets/walletConnectors/abcWallet/api/SigningApi.js +7 -7
  103. package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.d.ts +9 -1
  104. package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.js +7 -7
  105. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +333 -0
  106. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +11 -0
  107. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiSingleton.d.ts +18 -0
  108. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiSingleton.js +14 -0
  109. package/dist/wallets/walletConnectors/abcWallet/api/TransactionApi.d.ts +2 -2
  110. package/dist/wallets/walletConnectors/abcWallet/api/TransactionApi.js +7 -7
  111. package/dist/wallets/walletConnectors/abcWallet/api/TronApi.d.ts +102 -0
  112. package/dist/wallets/walletConnectors/abcWallet/api/TronApi.js +12 -0
  113. package/dist/wallets/walletConnectors/abcWallet/api/WalletApi.d.ts +4 -2
  114. package/dist/wallets/walletConnectors/abcWallet/api/WalletApi.js +7 -7
  115. package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.d.ts +60 -0
  116. package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +12 -0
  117. package/dist/wallets/walletConnectors/abcWallet/api/index.d.ts +24 -0
  118. package/dist/wallets/walletConnectors/abcWallet/api/index.js +35 -17
  119. package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +39 -1
  120. package/dist/wallets/walletConnectors/abcWallet/constants.js +5 -1
  121. package/dist/wallets/walletConnectors/abcWallet/googleAuth.d.ts +6 -0
  122. package/dist/wallets/walletConnectors/abcWallet/googleAuth.js +37 -1
  123. package/dist/wallets/walletConnectors/abcWallet/index.d.ts +5 -3
  124. package/dist/wallets/walletConnectors/abcWallet/index.js +44 -31
  125. package/dist/wallets/walletConnectors/abcWallet/kakaoAuth.d.ts +27 -0
  126. package/dist/wallets/walletConnectors/abcWallet/kakaoAuth.js +290 -0
  127. package/dist/wallets/walletConnectors/abcWallet/networkConfig.d.ts +39 -3
  128. package/dist/wallets/walletConnectors/abcWallet/networkConfig.js +11 -3
  129. package/dist/wallets/walletConnectors/abcWallet/secure.js +2 -2
  130. package/dist/wallets/walletConnectors/abcWallet/sessionUtils.js +1 -1
  131. package/dist/wallets/walletConnectors/abcWallet/types.d.ts +369 -7
  132. package/dist/wallets/walletConnectors/abcWallet/types.js +5 -3
  133. package/dist/wallets/walletConnectors/abcWallet/utils.js +3 -3
  134. package/dist/wallets/walletConnectors/abcWallet/walletGeneration.d.ts +10 -19
  135. package/dist/wallets/walletConnectors/abcWallet/walletGeneration.js +2 -2
  136. package/dist/wallets/walletConnectors/berasigWallet/berasigWallet.js +2 -2
  137. package/dist/wallets/walletConnectors/bifrostWallet/bifrostWallet.js +2 -2
  138. package/dist/wallets/walletConnectors/binanceWallet/binanceWallet.js +2 -2
  139. package/dist/wallets/walletConnectors/bitgetWallet/bitgetWallet.js +2 -2
  140. package/dist/wallets/walletConnectors/bybitWallet/bybitWallet.js +2 -2
  141. package/dist/wallets/walletConnectors/chunk-25V3FW3O.js +282 -0
  142. package/dist/wallets/walletConnectors/chunk-27346T3J.js +134 -0
  143. package/dist/wallets/walletConnectors/chunk-5CNLMOB2.js +75 -0
  144. package/dist/wallets/walletConnectors/chunk-5K45TCAM.js +333 -0
  145. package/dist/wallets/walletConnectors/chunk-5VDSMZC4.js +286 -0
  146. package/dist/wallets/walletConnectors/chunk-5W7RBMPH.js +351 -0
  147. package/dist/wallets/walletConnectors/chunk-5XORKEWE.js +326 -0
  148. package/dist/wallets/walletConnectors/chunk-63WBO52A.js +77 -0
  149. package/dist/wallets/walletConnectors/chunk-7IRF225N.js +75 -0
  150. package/dist/wallets/walletConnectors/chunk-7QHCSJDN.js +726 -0
  151. package/dist/wallets/walletConnectors/chunk-A27H6PEU.js +739 -0
  152. package/dist/wallets/walletConnectors/chunk-A4WR3CFN.js +130 -0
  153. package/dist/wallets/walletConnectors/chunk-A6FUNQWF.js +572 -0
  154. package/dist/wallets/walletConnectors/chunk-AF4OCS7N.js +46 -0
  155. package/dist/wallets/walletConnectors/chunk-AFWBXEEC.js +66 -0
  156. package/dist/wallets/walletConnectors/chunk-AUGP2LJR.js +182 -0
  157. package/dist/wallets/walletConnectors/chunk-AWLDVQXC.js +317 -0
  158. package/dist/wallets/walletConnectors/chunk-BLEKTKBN.js +479 -0
  159. package/dist/wallets/walletConnectors/chunk-BVL6G5HI.js +1757 -0
  160. package/dist/wallets/walletConnectors/chunk-CMTGEHDI.js +485 -0
  161. package/dist/wallets/walletConnectors/chunk-D5EFTEOM.js +56 -0
  162. package/dist/wallets/walletConnectors/chunk-DM5NLSWD.js +346 -0
  163. package/dist/wallets/walletConnectors/chunk-EBGI4D2T.js +69 -0
  164. package/dist/wallets/walletConnectors/chunk-EEH2HMFG.js +47 -0
  165. package/dist/wallets/walletConnectors/chunk-F5JWDBKK.js +47 -0
  166. package/dist/wallets/walletConnectors/chunk-FN67MIIH.js +75 -0
  167. package/dist/wallets/walletConnectors/chunk-FWYVBX5F.js +75 -0
  168. package/dist/wallets/walletConnectors/chunk-GH6ZDY4K.js +58 -0
  169. package/dist/wallets/walletConnectors/chunk-GIJZMIBD.js +63 -0
  170. package/dist/wallets/walletConnectors/chunk-GO6OLTNF.js +479 -0
  171. package/dist/wallets/walletConnectors/chunk-HKXBK3NY.js +75 -0
  172. package/dist/wallets/walletConnectors/chunk-HMD2WWFQ.js +75 -0
  173. package/dist/wallets/walletConnectors/chunk-HO5Z2CTL.js +280 -0
  174. package/dist/wallets/walletConnectors/chunk-I3GFVK5O.js +151 -0
  175. package/dist/wallets/walletConnectors/chunk-IUHZ5ZCE.js +121 -0
  176. package/dist/wallets/walletConnectors/chunk-JODNZWWG.js +330 -0
  177. package/dist/wallets/walletConnectors/chunk-JTST3KMW.js +75 -0
  178. package/dist/wallets/walletConnectors/chunk-KH2L3ONV.js +1599 -0
  179. package/dist/wallets/walletConnectors/chunk-LHV22375.js +182 -0
  180. package/dist/wallets/walletConnectors/chunk-LZZE462U.js +315 -0
  181. package/dist/wallets/walletConnectors/chunk-MGCRUAHX.js +276 -0
  182. package/dist/wallets/walletConnectors/chunk-MURSKRMJ.js +63 -0
  183. package/dist/wallets/walletConnectors/chunk-NG7PSAPX.js +115 -0
  184. package/dist/wallets/walletConnectors/chunk-NHP6D6AH.js +204 -0
  185. package/dist/wallets/walletConnectors/chunk-O4AU63LK.js +181 -0
  186. package/dist/wallets/walletConnectors/chunk-OBS74J5N.js +221 -0
  187. package/dist/wallets/walletConnectors/chunk-ON4U54WO.js +115 -0
  188. package/dist/wallets/walletConnectors/chunk-PPYBE5TV.js +276 -0
  189. package/dist/wallets/walletConnectors/chunk-PWWSAM4G.js +309 -0
  190. package/dist/wallets/walletConnectors/chunk-QB5GDLRU.js +330 -0
  191. package/dist/wallets/walletConnectors/chunk-QMLG7MAP.js +107 -0
  192. package/dist/wallets/walletConnectors/chunk-RGIB7FFH.js +47 -0
  193. package/dist/wallets/walletConnectors/chunk-SHJBMDP4.js +278 -0
  194. package/dist/wallets/walletConnectors/chunk-SOBJYYIX.js +484 -0
  195. package/dist/wallets/walletConnectors/chunk-T66U3ADD.js +58 -0
  196. package/dist/wallets/walletConnectors/chunk-THCKLFSJ.js +75 -0
  197. package/dist/wallets/walletConnectors/chunk-TS466TDR.js +286 -0
  198. package/dist/wallets/walletConnectors/chunk-UJGFYQEV.js +459 -0
  199. package/dist/wallets/walletConnectors/chunk-UXNEBBUV.js +224 -0
  200. package/dist/wallets/walletConnectors/chunk-VRCNFVPM.js +276 -0
  201. package/dist/wallets/walletConnectors/chunk-WODNUC65.js +333 -0
  202. package/dist/wallets/walletConnectors/chunk-X6A2FSHK.js +484 -0
  203. package/dist/wallets/walletConnectors/chunk-XVRNEES5.js +1541 -0
  204. package/dist/wallets/walletConnectors/chunk-XWVM2Y5A.js +306 -0
  205. package/dist/wallets/walletConnectors/chunk-XXG7ABSJ.js +328 -0
  206. package/dist/wallets/walletConnectors/chunk-YJH4BHSB.js +254 -0
  207. package/dist/wallets/walletConnectors/chunk-YRDNIP2H.js +90 -0
  208. package/dist/wallets/walletConnectors/chunk-YTPAWPCA.js +156 -0
  209. package/dist/wallets/walletConnectors/chunk-ZCSHD7UG.js +562 -0
  210. package/dist/wallets/walletConnectors/chunk-ZZCZ3RJU.js +272 -0
  211. package/dist/wallets/walletConnectors/clvWallet/clvWallet.js +2 -2
  212. package/dist/wallets/walletConnectors/coin98Wallet/coin98Wallet.js +2 -2
  213. package/dist/wallets/walletConnectors/coreWallet/coreWallet.js +2 -2
  214. package/dist/wallets/walletConnectors/foxWallet/foxWallet.js +2 -2
  215. package/dist/wallets/walletConnectors/frontierWallet/frontierWallet.js +2 -2
  216. package/dist/wallets/walletConnectors/gateWallet/gateWallet.js +2 -2
  217. package/dist/wallets/walletConnectors/index.js +62 -61
  218. package/dist/wallets/walletConnectors/iopayWallet/iopayWallet.js +2 -2
  219. package/dist/wallets/walletConnectors/kaiaWallet/kaiaWallet.js +2 -2
  220. package/dist/wallets/walletConnectors/kaikasWallet/kaikasWallet.js +2 -2
  221. package/dist/wallets/walletConnectors/klipWallet/klipWallet.d.ts +3 -0
  222. package/dist/wallets/walletConnectors/klipWallet/klipWallet.js +8 -0
  223. package/dist/wallets/walletConnectors/klipWallet-PPTYYB5G.js +7 -0
  224. package/dist/wallets/walletConnectors/metaMaskWallet/metaMaskWallet.js +2 -2
  225. package/dist/wallets/walletConnectors/okxWallet/okxWallet.js +2 -2
  226. package/dist/wallets/walletConnectors/rainbowWallet/rainbowWallet.js +2 -2
  227. package/dist/wallets/walletConnectors/roninWallet/roninWallet.js +2 -2
  228. package/dist/wallets/walletConnectors/safepalWallet/safepalWallet.js +2 -2
  229. package/dist/wallets/walletConnectors/subWallet/subWallet.js +2 -2
  230. package/dist/wallets/walletConnectors/tokenPocketWallet/tokenPocketWallet.js +2 -2
  231. package/dist/wallets/walletConnectors/trustWallet/trustWallet.js +2 -2
  232. package/dist/wallets/walletConnectors/zealWallet/zealWallet.js +2 -2
  233. package/dist/wallets/walletConnectors/zerionWallet/zerionWallet.js +2 -2
  234. package/package.json +2 -1
@@ -0,0 +1,276 @@
1
+ "use client";
2
+ import {
3
+ createAbcEvmProvider
4
+ } from "./chunk-ZCSHD7UG.js";
5
+ import {
6
+ createAbcWaasClient
7
+ } from "./chunk-KH2L3ONV.js";
8
+ import {
9
+ setGlobalDefaultBitcoinNetwork,
10
+ setGlobalDefaultChainId,
11
+ setGlobalDefaultSolanaNetwork
12
+ } from "./chunk-O4AU63LK.js";
13
+ import {
14
+ clearAuthState,
15
+ clearEncryptedTokens,
16
+ clearStorage,
17
+ loadAuthState,
18
+ loadFromStorage,
19
+ saveAuthState
20
+ } from "./chunk-BLEKTKBN.js";
21
+
22
+ // src/wallets/walletConnectors/abcWallet/abcConnector.ts
23
+ import { createConnector } from "wagmi";
24
+ function abcConnector(options) {
25
+ const { config } = options;
26
+ if (config.defaultChainId) {
27
+ setGlobalDefaultChainId(config.defaultChainId);
28
+ }
29
+ if (config.defaultSolanaNetwork) {
30
+ setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
31
+ }
32
+ if (config.defaultBitcoinNetwork) {
33
+ setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
34
+ }
35
+ return createConnector((wagmiConfig) => {
36
+ const client = createAbcWaasClient(config);
37
+ const provider = createAbcEvmProvider(client);
38
+ let accountsChangedHandler;
39
+ let chainChangedHandler;
40
+ let disconnectHandler;
41
+ return {
42
+ id: "abc",
43
+ name: "ABC Wallet",
44
+ type: "abc",
45
+ /**
46
+ * Connect wallet
47
+ */
48
+ async connect() {
49
+ try {
50
+ const authState = loadAuthState();
51
+ if (!authState || !authState.isAuthenticated || !authState.wallet) {
52
+ throw new Error("ABC_LOGIN_REQUIRED");
53
+ }
54
+ provider.setWallet(authState.wallet);
55
+ if (authState.accessToken && authState.refreshToken && authState.expiresAt) {
56
+ client.setTokens(
57
+ authState.accessToken,
58
+ authState.refreshToken,
59
+ authState.expiresAt
60
+ );
61
+ }
62
+ const accounts = await provider.request({
63
+ method: "eth_requestAccounts"
64
+ });
65
+ const currentChainId = await provider.request({
66
+ method: "eth_chainId"
67
+ });
68
+ if (accountsChangedHandler) {
69
+ provider.removeListener("accountsChanged", accountsChangedHandler);
70
+ }
71
+ accountsChangedHandler = (accounts2) => {
72
+ wagmiConfig.emitter.emit("change", {
73
+ accounts: accounts2
74
+ });
75
+ };
76
+ provider.on("accountsChanged", accountsChangedHandler);
77
+ if (chainChangedHandler) {
78
+ provider.removeListener("chainChanged", chainChangedHandler);
79
+ }
80
+ chainChangedHandler = (chainId) => {
81
+ wagmiConfig.emitter.emit("change", {
82
+ chainId: Number(chainId)
83
+ });
84
+ };
85
+ provider.on("chainChanged", chainChangedHandler);
86
+ if (disconnectHandler) {
87
+ provider.removeListener("disconnect", disconnectHandler);
88
+ }
89
+ disconnectHandler = () => {
90
+ wagmiConfig.emitter.emit("disconnect");
91
+ this.onDisconnect();
92
+ };
93
+ provider.on("disconnect", disconnectHandler);
94
+ wagmiConfig.emitter.emit("connect", {
95
+ accounts,
96
+ chainId: Number(currentChainId)
97
+ });
98
+ return {
99
+ accounts,
100
+ chainId: Number(currentChainId)
101
+ };
102
+ } catch (error) {
103
+ console.error("\u274C ABC Connector connect() failed:", {
104
+ message: error.message,
105
+ code: error.code,
106
+ error
107
+ });
108
+ if (error.message === "ABC_LOGIN_REQUIRED") {
109
+ throw error;
110
+ }
111
+ throw error;
112
+ }
113
+ },
114
+ /**
115
+ * Disconnect wallet
116
+ */
117
+ async disconnect() {
118
+ if (accountsChangedHandler) {
119
+ provider.removeListener("accountsChanged", accountsChangedHandler);
120
+ accountsChangedHandler = void 0;
121
+ }
122
+ if (chainChangedHandler) {
123
+ provider.removeListener("chainChanged", chainChangedHandler);
124
+ chainChangedHandler = void 0;
125
+ }
126
+ if (disconnectHandler) {
127
+ provider.removeListener("disconnect", disconnectHandler);
128
+ disconnectHandler = void 0;
129
+ }
130
+ provider.clearWallet();
131
+ await client.logout();
132
+ let savedPinHash = null;
133
+ let savedEmail = null;
134
+ if (typeof window !== "undefined") {
135
+ savedPinHash = localStorage.getItem("talkenkit_abc_pin_hash");
136
+ savedEmail = localStorage.getItem("talkenkit_abc_saved_email");
137
+ }
138
+ clearAuthState();
139
+ clearEncryptedTokens();
140
+ if (typeof window !== "undefined") {
141
+ localStorage.removeItem("talkenkit_abc_enc_salt");
142
+ localStorage.removeItem("talkenkit_abc_enc_tokens");
143
+ if (savedPinHash) {
144
+ localStorage.setItem("talkenkit_abc_pin_hash", savedPinHash);
145
+ }
146
+ if (savedEmail) {
147
+ localStorage.setItem("talkenkit_abc_saved_email", savedEmail);
148
+ }
149
+ }
150
+ console.log("\u2705 ABC Wallet disconnected (PIN preserved)");
151
+ },
152
+ /**
153
+ * Get accounts
154
+ */
155
+ async getAccounts() {
156
+ const accounts = await provider.request({
157
+ method: "eth_accounts"
158
+ });
159
+ return accounts.map((account) => account);
160
+ },
161
+ /**
162
+ * Get chain ID
163
+ */
164
+ async getChainId() {
165
+ const chainId = await provider.request({
166
+ method: "eth_chainId"
167
+ });
168
+ return Number(chainId);
169
+ },
170
+ /**
171
+ * Get provider
172
+ */
173
+ async getProvider() {
174
+ return provider;
175
+ },
176
+ /**
177
+ * Check if authorized (has valid session)
178
+ * Auto-refreshes access token if expired but refresh token is valid
179
+ */
180
+ async isAuthorized() {
181
+ try {
182
+ const authState = loadAuthState();
183
+ if (!authState || !authState.isAuthenticated) {
184
+ return false;
185
+ }
186
+ if (!authState.wallet) {
187
+ return false;
188
+ }
189
+ if (client.isAuthenticated()) {
190
+ return true;
191
+ }
192
+ const refreshToken = loadFromStorage(
193
+ "refresh_token" /* REFRESH_TOKEN */
194
+ );
195
+ if (!refreshToken) {
196
+ clearStorage();
197
+ return false;
198
+ }
199
+ try {
200
+ await client.refreshTokens(refreshToken);
201
+ const updatedState = loadAuthState();
202
+ return updatedState?.isAuthenticated ?? false;
203
+ } catch (error) {
204
+ console.error("[AbcConnector] Token refresh failed:", error);
205
+ clearStorage();
206
+ return false;
207
+ }
208
+ } catch (error) {
209
+ console.error(
210
+ "[AbcConnector] Unexpected error in isAuthorized:",
211
+ error
212
+ );
213
+ return false;
214
+ }
215
+ },
216
+ /**
217
+ * Switch chain
218
+ */
219
+ async switchChain({ chainId }) {
220
+ await provider.request({
221
+ method: "wallet_switchEthereumChain",
222
+ params: [{ chainId: `0x${chainId.toString(16)}` }]
223
+ });
224
+ const newChainId = await this.getChainId();
225
+ const authState = loadAuthState();
226
+ if (authState?.wallet) {
227
+ authState.wallet.chainId = newChainId;
228
+ saveAuthState(authState);
229
+ }
230
+ return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
231
+ id: chainId,
232
+ name: `Chain ${chainId}`,
233
+ nativeCurrency: {
234
+ name: "Ether",
235
+ decimals: 18,
236
+ symbol: "ETH"
237
+ },
238
+ rpcUrls: {
239
+ default: { http: [""] }
240
+ }
241
+ };
242
+ },
243
+ /**
244
+ * Handle accounts changed
245
+ */
246
+ onAccountsChanged(accounts) {
247
+ if (accounts.length === 0) {
248
+ this.onDisconnect();
249
+ } else {
250
+ wagmiConfig.emitter.emit("change", {
251
+ accounts
252
+ });
253
+ }
254
+ },
255
+ /**
256
+ * Handle chain changed
257
+ */
258
+ onChainChanged(chain) {
259
+ const chainId = Number(chain);
260
+ wagmiConfig.emitter.emit("change", { chainId });
261
+ },
262
+ /**
263
+ * Handle disconnect
264
+ */
265
+ onDisconnect(_error) {
266
+ provider.clearWallet();
267
+ clearAuthState();
268
+ wagmiConfig.emitter.emit("disconnect");
269
+ }
270
+ };
271
+ });
272
+ }
273
+
274
+ export {
275
+ abcConnector
276
+ };
@@ -0,0 +1,333 @@
1
+ "use client";
2
+ import {
3
+ BaseApiClient
4
+ } from "./chunk-LQ2U33WM.js";
5
+ import {
6
+ getSolanaNetwork
7
+ } from "./chunk-A7FIBI6X.js";
8
+ import {
9
+ createAbcError
10
+ } from "./chunk-TYUEB4VT.js";
11
+
12
+ // src/wallets/walletConnectors/abcWallet/api/SolanaApi.ts
13
+ import { PublicKey } from "@solana/web3.js";
14
+ var SolanaApi = class extends BaseApiClient {
15
+ /**
16
+ * Generate Solana wallet (Ed25519)
17
+ * Uses V3 API with Ed25519 curve
18
+ *
19
+ * @param pin - Hashed PIN (SHA-256)
20
+ * @param isRecover - Whether to recover existing wallet (default: false)
21
+ * @returns Solana wallet information
22
+ */
23
+ async generateSolanaWallet(pin, isRecover = false) {
24
+ const endpoint = `/v3/wallet/${isRecover ? "recover" : "generate"}`;
25
+ const network = getSolanaNetwork();
26
+ const response = await this.request(endpoint, {
27
+ method: "POST",
28
+ contentType: "json",
29
+ body: {
30
+ curve: "ed25519",
31
+ password: pin,
32
+ network
33
+ }
34
+ });
35
+ let result;
36
+ if (response.status === "success" && response.result) {
37
+ result = response.result;
38
+ } else if (response.encrypted_share && response.key_id) {
39
+ result = response;
40
+ } else {
41
+ throw createAbcError(
42
+ "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
43
+ `Failed to ${isRecover ? "recover" : "generate"} Solana wallet`,
44
+ response
45
+ );
46
+ }
47
+ let address;
48
+ try {
49
+ address = this.deriveAddressFromPublicKey(result.public_key);
50
+ } catch (_error) {
51
+ address = result.public_key.startsWith("0x") ? result.public_key.slice(2) : result.public_key;
52
+ }
53
+ return {
54
+ uid: result.uid || "",
55
+ sessionId: result.share_id,
56
+ shareId: result.share_id,
57
+ publicKey: result.public_key,
58
+ address,
59
+ keyId: result.key_id || result.share_id,
60
+ // API returns snake_case key_id
61
+ encryptedShare: result.encrypted_share || "",
62
+ // API returns snake_case encrypted_share
63
+ secretStore: result.secret_store || "",
64
+ // API returns snake_case secret_store
65
+ network
66
+ // Use network from request (already has correct value)
67
+ };
68
+ }
69
+ /**
70
+ * Recover Solana wallet (alias for generateSolanaWallet with isRecover=true)
71
+ *
72
+ * @param pin - Hashed PIN (SHA-256)
73
+ * @returns Recovered Solana wallet information
74
+ */
75
+ async recoverSolanaWallet(pin) {
76
+ return this.generateSolanaWallet(pin, true);
77
+ }
78
+ /**
79
+ * Derive Solana address from Ed25519 public key
80
+ * @param publicKey - Ed25519 public key (hex)
81
+ * @returns Solana address (base58)
82
+ */
83
+ deriveAddressFromPublicKey(publicKey) {
84
+ const cleanKey = publicKey.startsWith("0x") ? publicKey.slice(2) : publicKey;
85
+ const bytes = new Uint8Array(
86
+ cleanKey.match(/.{1,2}/g)?.map((byte) => Number.parseInt(byte, 16)) || []
87
+ );
88
+ try {
89
+ const pubkey = new PublicKey(bytes);
90
+ return pubkey.toBase58();
91
+ } catch (error) {
92
+ console.error("[SolanaApi] Failed to encode address:", error);
93
+ return cleanKey;
94
+ }
95
+ }
96
+ /**
97
+ * Sign Solana transaction with Ed25519
98
+ * Reference: /v3/wallet/sign API requires only 5 fields
99
+ */
100
+ async signSolanaTransaction(params) {
101
+ const network = getSolanaNetwork();
102
+ const response = await this.request("/v3/wallet/sign", {
103
+ method: "POST",
104
+ contentType: "json",
105
+ body: {
106
+ curve: "ed25519",
107
+ network,
108
+ key_id: params.keyId,
109
+ encrypted_share: params.encryptedShare,
110
+ secret_store: params.secretStore || "",
111
+ message: params.message
112
+ }
113
+ });
114
+ let signature;
115
+ if (response.status === "success" && response.result?.signature) {
116
+ signature = response.result.signature;
117
+ } else if (response.signature) {
118
+ signature = response.signature;
119
+ } else {
120
+ throw createAbcError(
121
+ "SIGNATURE_FAILED" /* SIGNATURE_FAILED */,
122
+ "Failed to sign Solana transaction",
123
+ response
124
+ );
125
+ }
126
+ return {
127
+ signature
128
+ };
129
+ }
130
+ /**
131
+ * Sign Solana message with Ed25519
132
+ * Reference: /v3/wallet/sign API requires only 5 fields
133
+ */
134
+ async signSolanaMessage(params) {
135
+ const network = getSolanaNetwork();
136
+ const response = await this.request("/v3/wallet/sign", {
137
+ method: "POST",
138
+ contentType: "json",
139
+ body: {
140
+ curve: "ed25519",
141
+ network,
142
+ key_id: params.keyId,
143
+ encrypted_share: params.encryptedShare,
144
+ secret_store: params.secretStore || "",
145
+ message: params.message
146
+ }
147
+ });
148
+ let signature;
149
+ if (response.status === "success" && response.result?.signature) {
150
+ signature = response.result.signature;
151
+ } else if (response.signature) {
152
+ signature = response.signature;
153
+ } else {
154
+ throw createAbcError(
155
+ "SIGNATURE_FAILED" /* SIGNATURE_FAILED */,
156
+ "Failed to sign Solana message",
157
+ response
158
+ );
159
+ }
160
+ return {
161
+ signature
162
+ };
163
+ }
164
+ /**
165
+ * Generate Solana transfer transaction via ABC WaaS API
166
+ * This ensures the transaction uses the same RPC and blockhash as the server
167
+ */
168
+ async generateTransferTransaction(params) {
169
+ const response = await this.request(
170
+ "/wapi/v2/solana/tx/generateTransferSOLTransaction",
171
+ {
172
+ method: "POST",
173
+ contentType: "json",
174
+ body: {
175
+ network: params.network,
176
+ amount: params.amount,
177
+ fromAddress: params.fromAddress,
178
+ toAddress: params.toAddress,
179
+ feePayerAddress: params.feePayerAddress
180
+ }
181
+ }
182
+ );
183
+ const responseData = response;
184
+ const serializedTx = responseData.data?.serialized_tx || response.status === "success" && response.result?.data?.serialized_tx;
185
+ if (!serializedTx) {
186
+ throw createAbcError(
187
+ "NETWORK_ERROR" /* NETWORK_ERROR */,
188
+ "Failed to generate Solana transaction",
189
+ response
190
+ );
191
+ }
192
+ return {
193
+ serialized_tx: serializedTx
194
+ };
195
+ }
196
+ /**
197
+ * Send Solana transaction (unsigned transaction + separate signatures)
198
+ * Used for server-generated transactions that need client signatures
199
+ */
200
+ async sendSolanaTransaction(params) {
201
+ const response = await this.request("/wapi/v2/solana/tx/sendTransaction", {
202
+ method: "POST",
203
+ contentType: "json",
204
+ body: {
205
+ network: params.network,
206
+ serializedTX: params.serializedTX,
207
+ signatures: params.signatures
208
+ }
209
+ });
210
+ const responseData = response;
211
+ const txHash = responseData.data || response.status === "success" && response.result?.data;
212
+ if (!txHash || typeof txHash !== "string") {
213
+ throw createAbcError(
214
+ "NETWORK_ERROR" /* NETWORK_ERROR */,
215
+ "Failed to send Solana transaction",
216
+ response
217
+ );
218
+ }
219
+ return {
220
+ txHash
221
+ };
222
+ }
223
+ /**
224
+ * Send fully signed Solana transaction (for client-built transactions)
225
+ * Sends a completely signed transaction directly to Solana network
226
+ */
227
+ async sendSignedSolanaTransaction(params) {
228
+ const response = await this.request(
229
+ "/wapi/v2/solana/tx/sendSignedTransaction",
230
+ {
231
+ method: "POST",
232
+ contentType: "json",
233
+ body: {
234
+ network: params.network,
235
+ serializedTX: params.serializedTX
236
+ }
237
+ }
238
+ );
239
+ const responseData = response;
240
+ const txHash = responseData.data?.transactionHash || response.status === "success" && response.result?.data?.transactionHash;
241
+ if (!txHash || typeof txHash !== "string") {
242
+ throw createAbcError(
243
+ "NETWORK_ERROR" /* NETWORK_ERROR */,
244
+ "Failed to send signed Solana transaction",
245
+ response
246
+ );
247
+ }
248
+ return {
249
+ txHash
250
+ };
251
+ }
252
+ /**
253
+ * Generate SPL token transfer transaction via ABC WaaS API
254
+ * Uses wallet addresses (not token accounts) - API resolves ATAs internally
255
+ *
256
+ * @param params - SPL transfer parameters
257
+ * @returns Serialized transaction
258
+ */
259
+ async generateSPLTransferTransaction(params) {
260
+ const response = await this.request(
261
+ "/wapi/v2/solana/tx/generateTransferFTTransaction",
262
+ {
263
+ method: "POST",
264
+ contentType: "json",
265
+ body: {
266
+ network: params.network,
267
+ mintAddress: params.mintAddress,
268
+ fromAddress: params.fromAddress,
269
+ toAddress: params.toAddress,
270
+ amount: params.amount,
271
+ ...params.decimals !== void 0 && { decimals: params.decimals },
272
+ ...params.feePayerAddress && {
273
+ feePayerAddress: params.feePayerAddress
274
+ },
275
+ ...params.latestBlockhash && {
276
+ latestBlockhash: params.latestBlockhash
277
+ }
278
+ }
279
+ }
280
+ );
281
+ const responseData = response;
282
+ const data = responseData.data || response.status === "success" && response.result;
283
+ if (!data?.serialized_tx) {
284
+ throw createAbcError(
285
+ "NETWORK_ERROR" /* NETWORK_ERROR */,
286
+ "Failed to generate SPL transfer transaction",
287
+ response
288
+ );
289
+ }
290
+ return {
291
+ serialized_tx: data.serialized_tx,
292
+ estimated_fee: data.estimated_fee || { context: { Slot: 0 }, value: 0 },
293
+ latest_blockhash: data.latest_blockhash || ""
294
+ };
295
+ }
296
+ /**
297
+ * Get SPL token supply information
298
+ *
299
+ * @param params - Token query parameters
300
+ * @returns Token supply information
301
+ */
302
+ async getTokenInfo(params) {
303
+ const response = await this.request(
304
+ "/wapi/v2/solana/token/getTokenSupply",
305
+ {
306
+ method: "POST",
307
+ contentType: "json",
308
+ body: {
309
+ network: params.network,
310
+ tokenAddress: params.tokenAddress
311
+ }
312
+ }
313
+ );
314
+ const responseData = response;
315
+ const value = responseData.data?.value || response.status === "success" && response.result?.data?.value;
316
+ if (!value || typeof value.decimals !== "number") {
317
+ throw createAbcError(
318
+ "NETWORK_ERROR" /* NETWORK_ERROR */,
319
+ "Failed to get token info",
320
+ response
321
+ );
322
+ }
323
+ return {
324
+ amount: value.amount,
325
+ decimals: value.decimals,
326
+ uiAmountString: value.uiAmountString
327
+ };
328
+ }
329
+ };
330
+
331
+ export {
332
+ SolanaApi
333
+ };