@talken/talkenkit 2.4.23 → 2.4.25

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 (267) hide show
  1. package/dist/AbcCredentialManager-DDHLW2IH.js +7 -0
  2. package/dist/AbcCredentialManager-E723A55X.js +7 -0
  3. package/dist/AbcCredentialManager-GUV5JQ2V.js +7 -0
  4. package/dist/AbcCredentialManager-Z7GDJHYR.js +7 -0
  5. package/dist/abcWallet-3PWHJXWR.js +181 -0
  6. package/dist/abcWallet-3XPV7ATY.js +185 -0
  7. package/dist/abcWallet-3XSSUDLJ.js +155 -0
  8. package/dist/abcWallet-53HAU4MH.js +155 -0
  9. package/dist/abcWallet-5B2YHZGY.js +155 -0
  10. package/dist/abcWallet-664AHBNM.js +183 -0
  11. package/dist/abcWallet-BV7HK3OX.js +181 -0
  12. package/dist/abcWallet-CRKQ3O6J.js +155 -0
  13. package/dist/abcWallet-H4JOSC4N.js +155 -0
  14. package/dist/abcWallet-HM7KZIMP.js +155 -0
  15. package/dist/abcWallet-I5DVALAS.js +155 -0
  16. package/dist/abcWallet-IF3EOKHC.js +183 -0
  17. package/dist/abcWallet-IUG22ZE3.js +155 -0
  18. package/dist/abcWallet-IYC3CKEO.js +155 -0
  19. package/dist/abcWallet-JE6UR4QF.js +181 -0
  20. package/dist/abcWallet-KPKVEGNP.js +185 -0
  21. package/dist/abcWallet-MWUFO3JQ.js +161 -0
  22. package/dist/abcWallet-MZAL5NXP.js +181 -0
  23. package/dist/abcWallet-N2UADRNR.js +155 -0
  24. package/dist/abcWallet-OGHORNUW.js +181 -0
  25. package/dist/abcWallet-OL47MLVO.js +161 -0
  26. package/dist/abcWallet-QSK6VJFU.js +181 -0
  27. package/dist/abcWallet-RKT3W3FX.js +155 -0
  28. package/dist/abcWallet-VHXTAARP.js +155 -0
  29. package/dist/abcWallet-VYU3TEGJ.js +161 -0
  30. package/dist/abcWallet-WZGXGXUA.js +161 -0
  31. package/dist/abcWallet-YFYTW2JH.js +155 -0
  32. package/dist/abcWallet-ZPVQY4XE.js +155 -0
  33. package/dist/chunk-2OHX4KTB.js +5382 -0
  34. package/dist/chunk-3VPMUBCL.js +5196 -0
  35. package/dist/chunk-5SDWPKKX.js +5322 -0
  36. package/dist/chunk-6RBGFYAF.js +5076 -0
  37. package/dist/chunk-7L2ANWBB.js +5139 -0
  38. package/dist/chunk-7VIEAJAM.js +5172 -0
  39. package/dist/chunk-ALBABQ53.js +354 -0
  40. package/dist/chunk-BY6GTSWI.js +5059 -0
  41. package/dist/chunk-DWE3CZEL.js +5171 -0
  42. package/dist/chunk-J6P2IT7Z.js +5465 -0
  43. package/dist/chunk-JIRBQUIB.js +5348 -0
  44. package/dist/chunk-K6CLOFGV.js +5129 -0
  45. package/dist/chunk-KYTIQ23P.js +5390 -0
  46. package/dist/chunk-MARFD3QV.js +5164 -0
  47. package/dist/chunk-MRRWKS2W.js +348 -0
  48. package/dist/chunk-NQCUKFAV.js +5381 -0
  49. package/dist/chunk-PILL2YTG.js +5075 -0
  50. package/dist/chunk-QW7D53VM.js +5129 -0
  51. package/dist/chunk-RAWLCGOW.js +5058 -0
  52. package/dist/chunk-RIEG3EJO.js +5385 -0
  53. package/dist/chunk-SHUPSYR2.js +5004 -0
  54. package/dist/chunk-UIGQOSRS.js +5174 -0
  55. package/dist/chunk-UINIIZCG.js +5098 -0
  56. package/dist/chunk-UKIPSWEV.js +5386 -0
  57. package/dist/chunk-VOQSYTG3.js +5419 -0
  58. package/dist/chunk-VT5Q2XKZ.js +5193 -0
  59. package/dist/chunk-VXQYKPGQ.js +5476 -0
  60. package/dist/chunk-VYLJNEKY.js +5129 -0
  61. package/dist/chunk-X24B5DJR.js +323 -0
  62. package/dist/chunk-X3C73JWU.js +5370 -0
  63. package/dist/chunk-XIDK5P36.js +288 -0
  64. package/dist/chunk-ZHRI7SGC.js +5359 -0
  65. package/dist/components/ConnectOptions/AbcWaasAuth/AbcWaasAuthFlow.d.ts +1 -2
  66. package/dist/components/RainbowKitProvider/InternalPinProvider.d.ts +1 -1
  67. package/dist/contexts/MultiChainContext.d.ts +2 -2
  68. package/dist/hooks/internal/abcEmbeddedWallet.d.ts +26 -0
  69. package/dist/hooks/useProfile.d.ts +13 -6
  70. package/dist/hooks/useSolanaWallet.d.ts +13 -8
  71. package/dist/index.d.ts +3 -3
  72. package/dist/index.js +1211 -1158
  73. package/dist/providers/AbcAuthProvider.d.ts +3 -1
  74. package/dist/providers/SignConfirmationProvider/useApiClient.d.ts +3 -0
  75. package/dist/solana/ConfiguredWalletProvider.d.ts +10 -0
  76. package/dist/solana/LegacySolflareWalletAdapter.d.ts +32 -0
  77. package/dist/solana/connectExternalWallet.d.ts +9 -0
  78. package/dist/solana/isWalletReady.d.ts +2 -0
  79. package/dist/transactions/transactionStore.d.ts +2 -5
  80. package/dist/utils/apiClientFactory.d.ts +16 -1
  81. package/dist/utils/encryption.d.ts +0 -4
  82. package/dist/wallets/walletConnectors/abcWallet/AbcCredentialManager.d.ts +49 -0
  83. package/dist/wallets/walletConnectors/abcWallet/AbcCredentialManager.js +8 -0
  84. package/dist/wallets/walletConnectors/abcWallet/AbcEvmAutoConnector.d.ts +4 -0
  85. package/dist/wallets/walletConnectors/abcWallet/AbcEvmAutoConnector.js +12 -15
  86. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinConnector.js +4 -4
  87. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.d.ts +2 -0
  88. package/dist/wallets/walletConnectors/abcWallet/abcBitcoinProvider.js +3 -1
  89. package/dist/wallets/walletConnectors/abcWallet/abcConnector.js +7 -6
  90. package/dist/wallets/walletConnectors/abcWallet/abcProvider.d.ts +25 -1
  91. package/dist/wallets/walletConnectors/abcWallet/abcProvider.js +5 -4
  92. package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.d.ts +0 -4
  93. package/dist/wallets/walletConnectors/abcWallet/abcSolanaProvider.js +11 -1
  94. package/dist/wallets/walletConnectors/abcWallet/abcSolanaWalletAdapter.js +14 -9
  95. package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.d.ts +3 -2
  96. package/dist/wallets/walletConnectors/abcWallet/abcTronProvider.js +3 -1
  97. package/dist/wallets/walletConnectors/abcWallet/abcWallet.js +8 -7
  98. package/dist/wallets/walletConnectors/abcWallet/api/ConfigApi.d.ts +21 -0
  99. package/dist/wallets/walletConnectors/abcWallet/api/ConfigApi.js +8 -0
  100. package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.d.ts +28 -115
  101. package/dist/wallets/walletConnectors/abcWallet/api/SolanaApi.js +1 -6
  102. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.d.ts +24 -1
  103. package/dist/wallets/walletConnectors/abcWallet/api/TalkenApiClient.js +4 -3
  104. package/dist/wallets/walletConnectors/abcWallet/api/TokenApi.d.ts +14 -0
  105. package/dist/wallets/walletConnectors/abcWallet/api/TokenApi.js +8 -0
  106. package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.d.ts +20 -0
  107. package/dist/wallets/walletConnectors/abcWallet/api/WalletscanApi.js +1 -1
  108. package/dist/wallets/walletConnectors/abcWallet/api/index.d.ts +3 -0
  109. package/dist/wallets/walletConnectors/abcWallet/api/index.js +19 -6
  110. package/dist/wallets/walletConnectors/abcWallet/backfillMissingWallets.d.ts +3 -0
  111. package/dist/wallets/walletConnectors/abcWallet/backfillMissingWallets.js +16 -0
  112. package/dist/wallets/walletConnectors/abcWallet/constants.d.ts +4 -0
  113. package/dist/wallets/walletConnectors/abcWallet/constants.js +1 -1
  114. package/dist/wallets/walletConnectors/abcWallet/index.d.ts +3 -2
  115. package/dist/wallets/walletConnectors/abcWallet/index.js +39 -53
  116. package/dist/wallets/walletConnectors/abcWallet/sessionUtils.js +2 -1
  117. package/dist/wallets/walletConnectors/abcWallet/types.d.ts +10 -9
  118. package/dist/wallets/walletConnectors/abcWallet/types.js +1 -1
  119. package/dist/wallets/walletConnectors/abcWallet/utils.d.ts +0 -83
  120. package/dist/wallets/walletConnectors/abcWallet/utils.js +3 -41
  121. package/dist/wallets/walletConnectors/abcWallet/walletGeneration.d.ts +9 -3
  122. package/dist/wallets/walletConnectors/abcWallet/walletGeneration.js +5 -2
  123. package/dist/wallets/walletConnectors/chunk-2XX4LJSQ.js +1387 -0
  124. package/dist/wallets/walletConnectors/chunk-3BUGPUMD.js +151 -0
  125. package/dist/wallets/walletConnectors/chunk-3H7YKUJZ.js +1407 -0
  126. package/dist/wallets/walletConnectors/chunk-3OWQ6MEU.js +54 -0
  127. package/dist/wallets/walletConnectors/chunk-3VDYWOS4.js +300 -0
  128. package/dist/wallets/walletConnectors/chunk-3XOXT4AM.js +314 -0
  129. package/dist/wallets/walletConnectors/chunk-42D2UPKR.js +439 -0
  130. package/dist/wallets/walletConnectors/chunk-42MF6LUP.js +563 -0
  131. package/dist/wallets/walletConnectors/chunk-4LIJB776.js +273 -0
  132. package/dist/wallets/walletConnectors/chunk-4P3SPC44.js +51 -0
  133. package/dist/wallets/walletConnectors/chunk-4RZVAQQ4.js +574 -0
  134. package/dist/wallets/walletConnectors/chunk-53UTBIKF.js +209 -0
  135. package/dist/wallets/walletConnectors/chunk-54KVT46V.js +1477 -0
  136. package/dist/wallets/walletConnectors/chunk-5UBUX5BT.js +440 -0
  137. package/dist/wallets/walletConnectors/chunk-5ZBV5WE2.js +94 -0
  138. package/dist/wallets/walletConnectors/chunk-6EUOVOQK.js +151 -0
  139. package/dist/wallets/walletConnectors/chunk-6WF4SXLB.js +156 -0
  140. package/dist/wallets/walletConnectors/chunk-6YUJPIJ5.js +351 -0
  141. package/dist/wallets/walletConnectors/chunk-77YYMCMD.js +273 -0
  142. package/dist/wallets/walletConnectors/chunk-7DM6H5BJ.js +54 -0
  143. package/dist/wallets/walletConnectors/chunk-7EQNUYV2.js +482 -0
  144. package/dist/wallets/walletConnectors/chunk-7K77YGQN.js +54 -0
  145. package/dist/wallets/walletConnectors/chunk-7MMVOEZF.js +393 -0
  146. package/dist/wallets/walletConnectors/chunk-7ORDZ6EQ.js +1479 -0
  147. package/dist/wallets/walletConnectors/chunk-7RDMH4SD.js +54 -0
  148. package/dist/wallets/walletConnectors/chunk-7S4N4DRT.js +306 -0
  149. package/dist/wallets/walletConnectors/chunk-7SWRH3EI.js +96 -0
  150. package/dist/wallets/walletConnectors/chunk-A3OJZTDV.js +54 -0
  151. package/dist/wallets/walletConnectors/chunk-A66MTFML.js +223 -0
  152. package/dist/wallets/walletConnectors/chunk-ACLPF2UW.js +96 -0
  153. package/dist/wallets/walletConnectors/chunk-AJBRO3VA.js +300 -0
  154. package/dist/wallets/walletConnectors/chunk-BKVGLYLI.js +194 -0
  155. package/dist/wallets/walletConnectors/chunk-BXH3GDX5.js +273 -0
  156. package/dist/wallets/walletConnectors/chunk-C3FPON5L.js +213 -0
  157. package/dist/wallets/walletConnectors/chunk-CABLJOMU.js +194 -0
  158. package/dist/wallets/walletConnectors/chunk-CBIDNYV4.js +1407 -0
  159. package/dist/wallets/walletConnectors/chunk-CE37VZAR.js +300 -0
  160. package/dist/wallets/walletConnectors/chunk-DD6KK4BR.js +54 -0
  161. package/dist/wallets/walletConnectors/chunk-DPTDOCWL.js +205 -0
  162. package/dist/wallets/walletConnectors/chunk-DSNVWCPD.js +131 -0
  163. package/dist/wallets/walletConnectors/chunk-DULGAYBU.js +785 -0
  164. package/dist/wallets/walletConnectors/chunk-DZUXOGSA.js +54 -0
  165. package/dist/wallets/walletConnectors/chunk-E7TDM6P6.js +205 -0
  166. package/dist/wallets/walletConnectors/chunk-EVJIFLSY.js +93 -0
  167. package/dist/wallets/walletConnectors/chunk-EVW3ZB3Q.js +386 -0
  168. package/dist/wallets/walletConnectors/chunk-F2UWSAMX.js +54 -0
  169. package/dist/wallets/walletConnectors/chunk-FBVPR472.js +314 -0
  170. package/dist/wallets/walletConnectors/chunk-FKS2YLVW.js +273 -0
  171. package/dist/wallets/walletConnectors/chunk-FOGNJZPY.js +54 -0
  172. package/dist/wallets/walletConnectors/chunk-FSSV6JY3.js +54 -0
  173. package/dist/wallets/walletConnectors/chunk-GBMOX5JN.js +54 -0
  174. package/dist/wallets/walletConnectors/chunk-GFLJ2MAG.js +54 -0
  175. package/dist/wallets/walletConnectors/chunk-GGPJJ6KS.js +1407 -0
  176. package/dist/wallets/walletConnectors/chunk-GMAYKJEI.js +508 -0
  177. package/dist/wallets/walletConnectors/chunk-GWYZ2IPP.js +1479 -0
  178. package/dist/wallets/walletConnectors/chunk-H3OWNM73.js +300 -0
  179. package/dist/wallets/walletConnectors/chunk-HF6GFAE5.js +54 -0
  180. package/dist/wallets/walletConnectors/chunk-IM7DEERX.js +585 -0
  181. package/dist/wallets/walletConnectors/chunk-INFMRNND.js +300 -0
  182. package/dist/wallets/walletConnectors/chunk-INT6LGH7.js +180 -0
  183. package/dist/wallets/walletConnectors/chunk-ITZ42A33.js +273 -0
  184. package/dist/wallets/walletConnectors/chunk-J4IF6BFF.js +300 -0
  185. package/dist/wallets/walletConnectors/chunk-JADQLTFW.js +194 -0
  186. package/dist/wallets/walletConnectors/chunk-JAMJLNYQ.js +54 -0
  187. package/dist/wallets/walletConnectors/chunk-JDJUIRGF.js +439 -0
  188. package/dist/wallets/walletConnectors/chunk-JEWCPQJZ.js +300 -0
  189. package/dist/wallets/walletConnectors/chunk-JGXJY3SB.js +1 -0
  190. package/dist/wallets/walletConnectors/chunk-JK7LJ4B6.js +1407 -0
  191. package/dist/wallets/walletConnectors/chunk-JPOSJU2D.js +594 -0
  192. package/dist/wallets/walletConnectors/chunk-JUFEPIO4.js +1479 -0
  193. package/dist/wallets/walletConnectors/chunk-JV4IC5Z7.js +54 -0
  194. package/dist/wallets/walletConnectors/chunk-K3VHBOXQ.js +32 -0
  195. package/dist/wallets/walletConnectors/chunk-KZS2C73S.js +814 -0
  196. package/dist/wallets/walletConnectors/chunk-LJNUFDGO.js +205 -0
  197. package/dist/wallets/walletConnectors/chunk-MO2AXXLI.js +30 -0
  198. package/dist/wallets/walletConnectors/chunk-MP3WVXPS.js +273 -0
  199. package/dist/wallets/walletConnectors/chunk-MTC2HJPF.js +96 -0
  200. package/dist/wallets/walletConnectors/chunk-MTJF3SVB.js +1487 -0
  201. package/dist/wallets/walletConnectors/chunk-NBVPVTJZ.js +192 -0
  202. package/dist/wallets/walletConnectors/chunk-NISMGNEE.js +223 -0
  203. package/dist/wallets/walletConnectors/chunk-NY5O2OBG.js +1477 -0
  204. package/dist/wallets/walletConnectors/chunk-NYDDRNUI.js +445 -0
  205. package/dist/wallets/walletConnectors/chunk-O4DNG6JJ.js +54 -0
  206. package/dist/wallets/walletConnectors/chunk-OTLZVWY7.js +39 -0
  207. package/dist/wallets/walletConnectors/chunk-OYF6AQOW.js +194 -0
  208. package/dist/wallets/walletConnectors/chunk-PBOCVGUC.js +782 -0
  209. package/dist/wallets/walletConnectors/chunk-PDXO6AOG.js +300 -0
  210. package/dist/wallets/walletConnectors/chunk-PJSN4YRI.js +1387 -0
  211. package/dist/wallets/walletConnectors/chunk-PVIO7FM7.js +314 -0
  212. package/dist/wallets/walletConnectors/chunk-PWJOXYDF.js +54 -0
  213. package/dist/wallets/walletConnectors/chunk-PYBSONED.js +771 -0
  214. package/dist/wallets/walletConnectors/chunk-PYKECUZ3.js +54 -0
  215. package/dist/wallets/walletConnectors/chunk-Q42NO7WB.js +46 -0
  216. package/dist/wallets/walletConnectors/chunk-Q7XBI5F6.js +300 -0
  217. package/dist/wallets/walletConnectors/chunk-QHUBLT7N.js +156 -0
  218. package/dist/wallets/walletConnectors/chunk-RMV23JXO.js +300 -0
  219. package/dist/wallets/walletConnectors/chunk-S3L2SA4J.js +300 -0
  220. package/dist/wallets/walletConnectors/chunk-S466OQOC.js +393 -0
  221. package/dist/wallets/walletConnectors/chunk-SA7IXAFG.js +54 -0
  222. package/dist/wallets/walletConnectors/chunk-SDB6BBHX.js +585 -0
  223. package/dist/wallets/walletConnectors/chunk-SFGVPX2G.js +351 -0
  224. package/dist/wallets/walletConnectors/chunk-SFQKJ6X6.js +314 -0
  225. package/dist/wallets/walletConnectors/chunk-SKLRJRER.js +1464 -0
  226. package/dist/wallets/walletConnectors/chunk-SQVWIBWR.js +351 -0
  227. package/dist/wallets/walletConnectors/chunk-SSLHXCOX.js +439 -0
  228. package/dist/wallets/walletConnectors/chunk-SU6LV3EO.js +314 -0
  229. package/dist/wallets/walletConnectors/chunk-SU7IEZE2.js +300 -0
  230. package/dist/wallets/walletConnectors/chunk-TMRB5SCL.js +167 -0
  231. package/dist/wallets/walletConnectors/chunk-TMUPUOQR.js +54 -0
  232. package/dist/wallets/walletConnectors/chunk-TNZ7QKXH.js +771 -0
  233. package/dist/wallets/walletConnectors/chunk-TT2NLKIU.js +1465 -0
  234. package/dist/wallets/walletConnectors/chunk-U3WGMWTH.js +585 -0
  235. package/dist/wallets/walletConnectors/chunk-UAV4SI4Y.js +408 -0
  236. package/dist/wallets/walletConnectors/chunk-UAWWPNS7.js +54 -0
  237. package/dist/wallets/walletConnectors/chunk-UXRJASPW.js +785 -0
  238. package/dist/wallets/walletConnectors/chunk-UY5TAYLM.js +54 -0
  239. package/dist/wallets/walletConnectors/chunk-VB5IZDY7.js +300 -0
  240. package/dist/wallets/walletConnectors/chunk-VDWJ3NQ5.js +52 -0
  241. package/dist/wallets/walletConnectors/chunk-VIKJNKJZ.js +219 -0
  242. package/dist/wallets/walletConnectors/chunk-VKOPUEQG.js +445 -0
  243. package/dist/wallets/walletConnectors/chunk-VTOD7PXP.js +817 -0
  244. package/dist/wallets/walletConnectors/chunk-VVEXF6KG.js +273 -0
  245. package/dist/wallets/walletConnectors/chunk-W2YIRNMB.js +300 -0
  246. package/dist/wallets/walletConnectors/chunk-W7L2SBIG.js +138 -0
  247. package/dist/wallets/walletConnectors/chunk-WC7BGU5Z.js +814 -0
  248. package/dist/wallets/walletConnectors/chunk-WS5FG53X.js +54 -0
  249. package/dist/wallets/walletConnectors/chunk-WVRGC2YL.js +300 -0
  250. package/dist/wallets/walletConnectors/chunk-X33WL7R7.js +300 -0
  251. package/dist/wallets/walletConnectors/chunk-XG2R64B7.js +785 -0
  252. package/dist/wallets/walletConnectors/chunk-Y2BWF42Z.js +54 -0
  253. package/dist/wallets/walletConnectors/chunk-Y446VZWI.js +585 -0
  254. package/dist/wallets/walletConnectors/chunk-YDSBY7NO.js +54 -0
  255. package/dist/wallets/walletConnectors/chunk-YROAFC7Z.js +54 -0
  256. package/dist/wallets/walletConnectors/chunk-YV6IZWGE.js +393 -0
  257. package/dist/wallets/walletConnectors/chunk-Z4WVT3G2.js +1416 -0
  258. package/dist/wallets/walletConnectors/chunk-Z5SBGIWT.js +300 -0
  259. package/dist/wallets/walletConnectors/chunk-ZK3PZIAH.js +300 -0
  260. package/dist/wallets/walletConnectors/chunk-ZKCUYHBK.js +300 -0
  261. package/dist/wallets/walletConnectors/chunk-ZPJLV3E7.js +151 -0
  262. package/dist/wallets/walletConnectors/chunk-ZQ3LCYGH.js +408 -0
  263. package/dist/wallets/walletConnectors/chunk-ZX6HMX7N.js +1468 -0
  264. package/dist/wallets/walletConnectors/chunk-ZXN465CA.js +209 -0
  265. package/dist/wallets/walletConnectors/index.js +73 -72
  266. package/package.json +12 -11
  267. package/LICENSE +0 -9
@@ -0,0 +1,223 @@
1
+ "use client";
2
+ import {
3
+ AbcError
4
+ } from "./chunk-4P3SPC44.js";
5
+ import {
6
+ PIN_CONFIG,
7
+ STORAGE_PREFIX,
8
+ TOKEN_EXPIRY
9
+ } from "./chunk-DPTDOCWL.js";
10
+
11
+ // src/wallets/walletConnectors/abcWallet/utils.ts
12
+ async function hashPin(pin) {
13
+ if (typeof window === "undefined" || !window.crypto?.subtle) {
14
+ return btoa(pin);
15
+ }
16
+ const encoder = new TextEncoder();
17
+ const data = encoder.encode(pin);
18
+ const hashBuffer = await window.crypto.subtle.digest("SHA-256", data);
19
+ const hashArray = Array.from(new Uint8Array(hashBuffer));
20
+ const hashHex = hashArray.map((b) => b.toString(16).padStart(2, "0")).join("");
21
+ return hashHex;
22
+ }
23
+ function validatePin(pin) {
24
+ if (!pin || typeof pin !== "string") {
25
+ return false;
26
+ }
27
+ const pinLength = pin.length;
28
+ if (pinLength < PIN_CONFIG.MIN_LENGTH || pinLength > PIN_CONFIG.MAX_LENGTH) {
29
+ return false;
30
+ }
31
+ return /^\d+$/.test(pin);
32
+ }
33
+ function validateEmail(email) {
34
+ if (!email || typeof email !== "string") {
35
+ return false;
36
+ }
37
+ const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
38
+ return emailRegex.test(email);
39
+ }
40
+ function getStorageKey(key) {
41
+ return `${STORAGE_PREFIX}${key}`;
42
+ }
43
+ function saveToStorage(key, value) {
44
+ if (typeof window === "undefined")
45
+ return;
46
+ try {
47
+ const storageKey = getStorageKey(key);
48
+ const serialized = JSON.stringify(value);
49
+ localStorage.setItem(storageKey, serialized);
50
+ } catch (error) {
51
+ console.error("Failed to save to storage:", error);
52
+ }
53
+ }
54
+ function loadFromStorage(key) {
55
+ if (typeof window === "undefined")
56
+ return null;
57
+ try {
58
+ const storageKey = getStorageKey(key);
59
+ const serialized = localStorage.getItem(storageKey);
60
+ if (!serialized)
61
+ return null;
62
+ try {
63
+ return JSON.parse(serialized);
64
+ } catch {
65
+ return serialized;
66
+ }
67
+ } catch (error) {
68
+ console.error("Failed to load from storage:", error);
69
+ return null;
70
+ }
71
+ }
72
+ function removeFromStorage(key) {
73
+ if (typeof window === "undefined")
74
+ return;
75
+ try {
76
+ const storageKey = getStorageKey(key);
77
+ localStorage.removeItem(storageKey);
78
+ } catch (error) {
79
+ console.error("Failed to remove from storage:", error);
80
+ }
81
+ }
82
+ function clearStorage() {
83
+ if (typeof window === "undefined")
84
+ return;
85
+ const keysToRemove = [];
86
+ for (let i = 0; i < localStorage.length; i++) {
87
+ const key = localStorage.key(i);
88
+ if (key?.startsWith(STORAGE_PREFIX)) {
89
+ keysToRemove.push(key);
90
+ }
91
+ }
92
+ for (const key of keysToRemove) {
93
+ localStorage.removeItem(key);
94
+ }
95
+ }
96
+ function isTokenExpired(expiresAt) {
97
+ if (!expiresAt)
98
+ return true;
99
+ return Date.now() >= expiresAt - TOKEN_EXPIRY.REFRESH_BUFFER;
100
+ }
101
+ function calculateExpiryTimestamp(expiresIn) {
102
+ return Date.now() + expiresIn * 1e3;
103
+ }
104
+ function saveAuthState(state) {
105
+ saveToStorage("auth_state" /* AUTH_STATE */, state);
106
+ if (state.user) {
107
+ saveToStorage("user" /* USER */, state.user);
108
+ }
109
+ if (state.wallet) {
110
+ saveToStorage("wallet" /* WALLET */, state.wallet);
111
+ }
112
+ if (state.solanaWallet) {
113
+ saveToStorage("solana_wallet" /* SOLANA_WALLET */, state.solanaWallet);
114
+ }
115
+ if (state.bitcoinWallet) {
116
+ saveToStorage("bitcoin_wallet" /* BITCOIN_WALLET */, state.bitcoinWallet);
117
+ }
118
+ if (state.tronWallet) {
119
+ saveToStorage("tron_wallet" /* TRON_WALLET */, state.tronWallet);
120
+ }
121
+ if (state.accessToken) {
122
+ saveToStorage("access_token" /* ACCESS_TOKEN */, state.accessToken);
123
+ }
124
+ if (state.refreshToken) {
125
+ saveToStorage("refresh_token" /* REFRESH_TOKEN */, state.refreshToken);
126
+ }
127
+ if (state.expiresAt) {
128
+ saveToStorage("expires_at" /* EXPIRES_AT */, state.expiresAt);
129
+ }
130
+ }
131
+ function hydrateAuthStateFromIndividualStorage(state) {
132
+ const user = loadFromStorage("user" /* USER */);
133
+ const wallet = loadFromStorage("wallet" /* WALLET */);
134
+ const solanaWallet = loadFromStorage(
135
+ "solana_wallet" /* SOLANA_WALLET */
136
+ );
137
+ const bitcoinWallet = loadFromStorage(
138
+ "bitcoin_wallet" /* BITCOIN_WALLET */
139
+ );
140
+ const tronWallet = loadFromStorage("tron_wallet" /* TRON_WALLET */);
141
+ const accessToken = loadFromStorage("access_token" /* ACCESS_TOKEN */);
142
+ const refreshToken = loadFromStorage("refresh_token" /* REFRESH_TOKEN */);
143
+ const expiresAt = loadFromStorage("expires_at" /* EXPIRES_AT */);
144
+ const nextState = {
145
+ ...state,
146
+ user: state.user || user || null,
147
+ wallet: state.wallet || wallet || null,
148
+ solanaWallet: state.solanaWallet || solanaWallet || null,
149
+ bitcoinWallet: state.bitcoinWallet || bitcoinWallet || null,
150
+ tronWallet: state.tronWallet || tronWallet || null,
151
+ accessToken: state.accessToken || accessToken || null,
152
+ refreshToken: state.refreshToken || refreshToken || null,
153
+ expiresAt: state.expiresAt || expiresAt || null
154
+ };
155
+ const wasHydrated = nextState.user !== state.user || nextState.wallet !== state.wallet || nextState.solanaWallet !== state.solanaWallet || nextState.bitcoinWallet !== state.bitcoinWallet || nextState.tronWallet !== state.tronWallet || nextState.accessToken !== state.accessToken || nextState.refreshToken !== state.refreshToken || nextState.expiresAt !== state.expiresAt;
156
+ if (wasHydrated) {
157
+ saveToStorage("auth_state" /* AUTH_STATE */, nextState);
158
+ }
159
+ return nextState;
160
+ }
161
+ function loadAuthState() {
162
+ const state = loadFromStorage("auth_state" /* AUTH_STATE */);
163
+ if (state) {
164
+ if (state.accessToken && isTokenExpired(state.expiresAt)) {
165
+ clearStorage();
166
+ return null;
167
+ }
168
+ return hydrateAuthStateFromIndividualStorage(state);
169
+ }
170
+ const user = loadFromStorage("user" /* USER */);
171
+ const wallet = loadFromStorage("wallet" /* WALLET */);
172
+ const solanaWallet = loadFromStorage("solana_wallet" /* SOLANA_WALLET */);
173
+ const accessToken = loadFromStorage("access_token" /* ACCESS_TOKEN */);
174
+ const refreshToken = loadFromStorage("refresh_token" /* REFRESH_TOKEN */);
175
+ const expiresAt = loadFromStorage("expires_at" /* EXPIRES_AT */);
176
+ if (!user || !accessToken) {
177
+ return null;
178
+ }
179
+ const bitcoinWallet = loadFromStorage("bitcoin_wallet" /* BITCOIN_WALLET */);
180
+ const tronWallet = loadFromStorage("tron_wallet" /* TRON_WALLET */);
181
+ return {
182
+ isAuthenticated: true,
183
+ user,
184
+ wallet,
185
+ solanaWallet,
186
+ bitcoinWallet,
187
+ tronWallet,
188
+ accessToken,
189
+ refreshToken,
190
+ expiresAt
191
+ };
192
+ }
193
+ function clearAuthState() {
194
+ clearStorage();
195
+ }
196
+ function createAbcError(code, message, details, statusCode) {
197
+ return new AbcError(code, message, details, statusCode);
198
+ }
199
+ function hexToNumber(hex) {
200
+ return Number.parseInt(hex, 16);
201
+ }
202
+ function numberToHex(num) {
203
+ return `0x${num.toString(16)}`;
204
+ }
205
+
206
+ export {
207
+ hashPin,
208
+ validatePin,
209
+ validateEmail,
210
+ getStorageKey,
211
+ saveToStorage,
212
+ loadFromStorage,
213
+ removeFromStorage,
214
+ clearStorage,
215
+ isTokenExpired,
216
+ calculateExpiryTimestamp,
217
+ saveAuthState,
218
+ loadAuthState,
219
+ clearAuthState,
220
+ createAbcError,
221
+ hexToNumber,
222
+ numberToHex
223
+ };
@@ -0,0 +1,96 @@
1
+ "use client";
2
+ import {
3
+ STORAGE_PREFIX
4
+ } from "./chunk-DPTDOCWL.js";
5
+
6
+ // src/wallets/walletConnectors/abcWallet/sessionUtils.ts
7
+ import { getTalkenApiClient } from "@talken/talkenkit";
8
+ var SessionExpiredError = class extends Error {
9
+ constructor(message = "Session expired. Please reconnect your wallet.") {
10
+ super(message);
11
+ this.name = "SessionExpiredError";
12
+ }
13
+ };
14
+ function dispatchSessionExpired() {
15
+ if (typeof window !== "undefined") {
16
+ console.warn("[SessionUtils] \u{1F6A8} dispatchSessionExpired called from:");
17
+ console.trace();
18
+ window.dispatchEvent(new CustomEvent("talkenkit:session_expired"));
19
+ }
20
+ }
21
+ function handleUnauthorizedResponse(response) {
22
+ if (response.status === 401) {
23
+ dispatchSessionExpired();
24
+ throw new SessionExpiredError(
25
+ "Session expired. Please reconnect your wallet."
26
+ );
27
+ }
28
+ }
29
+ async function fetchWithSessionCheck(url, options) {
30
+ const response = await fetch(url, options);
31
+ if (!response.ok && response.status === 401) {
32
+ const errorText = await response.text();
33
+ console.error("[ABC WaaS] \u274C Unauthorized (401):", errorText);
34
+ dispatchSessionExpired();
35
+ throw new SessionExpiredError(
36
+ "Session expired. Please reconnect your wallet."
37
+ );
38
+ }
39
+ return response;
40
+ }
41
+ async function refreshAccessToken(pinCallback) {
42
+ if (pinCallback) {
43
+ await pinCallback();
44
+ }
45
+ const api = getTalkenApiClient();
46
+ if (!api) {
47
+ console.warn(
48
+ "[SessionUtils] TalkenApiClient not initialized - opening connect modal"
49
+ );
50
+ dispatchSessionExpired();
51
+ await new Promise((resolve) => setTimeout(resolve, 100));
52
+ throw new SessionExpiredError(
53
+ "Session expired. Please reconnect your wallet."
54
+ );
55
+ }
56
+ const refreshToken = api.getRefreshToken() || localStorage.getItem(`${STORAGE_PREFIX}refresh_token`);
57
+ if (!refreshToken) {
58
+ console.warn("[SessionUtils] No refresh token - opening connect modal");
59
+ dispatchSessionExpired();
60
+ await new Promise((resolve) => setTimeout(resolve, 100));
61
+ throw new SessionExpiredError(
62
+ "Session expired. Please reconnect your wallet."
63
+ );
64
+ }
65
+ try {
66
+ const res = await api.auth.refresh();
67
+ const expiresAt = Date.now() + res.expiresIn * 1e3;
68
+ api.setTokens(res.accessToken, res.refreshToken || refreshToken, expiresAt);
69
+ localStorage.setItem(`${STORAGE_PREFIX}access_token`, res.accessToken);
70
+ if (res.refreshToken) {
71
+ localStorage.setItem(`${STORAGE_PREFIX}refresh_token`, res.refreshToken);
72
+ }
73
+ localStorage.setItem(`${STORAGE_PREFIX}expires_at`, String(expiresAt));
74
+ console.log(
75
+ "[SessionUtils] \u2705 Token refreshed - expires in:",
76
+ (res.expiresIn / 60 / 60).toFixed(2),
77
+ "hours"
78
+ );
79
+ return res.accessToken;
80
+ } catch (error) {
81
+ console.error("[SessionUtils] Token refresh failed:", error);
82
+ dispatchSessionExpired();
83
+ await new Promise((resolve) => setTimeout(resolve, 100));
84
+ throw new SessionExpiredError(
85
+ "Session expired. Please reconnect your wallet."
86
+ );
87
+ }
88
+ }
89
+
90
+ export {
91
+ SessionExpiredError,
92
+ dispatchSessionExpired,
93
+ handleUnauthorizedResponse,
94
+ fetchWithSessionCheck,
95
+ refreshAccessToken
96
+ };
@@ -0,0 +1,300 @@
1
+ "use client";
2
+ import {
3
+ setTalkenApiClient
4
+ } from "./chunk-R6ZE7JAZ.js";
5
+ import {
6
+ setGlobalDefaultBitcoinNetwork,
7
+ setGlobalDefaultChainId,
8
+ setGlobalDefaultSolanaNetwork
9
+ } from "./chunk-O4AU63LK.js";
10
+ import {
11
+ createAbcEvmProvider
12
+ } from "./chunk-NY5O2OBG.js";
13
+ import {
14
+ clearAuthState,
15
+ clearStorage,
16
+ loadAuthState,
17
+ loadFromStorage,
18
+ saveAuthState
19
+ } from "./chunk-NISMGNEE.js";
20
+ import {
21
+ createTalkenApiClient
22
+ } from "./chunk-UXRJASPW.js";
23
+ import {
24
+ resolveTalkenApiUrl
25
+ } from "./chunk-GFWUFYT2.js";
26
+ import {
27
+ getCredentialManager
28
+ } from "./chunk-DSNVWCPD.js";
29
+
30
+ // src/wallets/walletConnectors/abcWallet/abcConnector.ts
31
+ import { getTalkenApiClient } from "@talken/talkenkit";
32
+ import { createConnector } from "wagmi";
33
+ function abcConnector(options) {
34
+ const { config } = options;
35
+ if (config.defaultChainId) {
36
+ setGlobalDefaultChainId(config.defaultChainId);
37
+ }
38
+ if (config.defaultSolanaNetwork) {
39
+ setGlobalDefaultSolanaNetwork(config.defaultSolanaNetwork);
40
+ }
41
+ if (config.defaultBitcoinNetwork) {
42
+ setGlobalDefaultBitcoinNetwork(config.defaultBitcoinNetwork);
43
+ }
44
+ return createConnector((wagmiConfig) => {
45
+ const talkenApi = getTalkenApiClient() || createTalkenApiClient({
46
+ baseUrl: resolveTalkenApiUrl(config.talkenApiUrl),
47
+ environment: config.environment,
48
+ debug: config.environment === "development",
49
+ defaultChainId: config.defaultChainId
50
+ });
51
+ setTalkenApiClient(talkenApi);
52
+ const provider = createAbcEvmProvider(talkenApi);
53
+ let accountsChangedHandler;
54
+ let chainChangedHandler;
55
+ let disconnectHandler;
56
+ return {
57
+ id: "abc",
58
+ name: "ABC Wallet",
59
+ type: "abc",
60
+ /**
61
+ * Connect wallet
62
+ */
63
+ async connect() {
64
+ try {
65
+ const authState = loadAuthState();
66
+ if (!authState || !authState.isAuthenticated || !authState.wallet) {
67
+ throw new Error("ABC_LOGIN_REQUIRED");
68
+ }
69
+ provider.setWallet(authState.wallet);
70
+ if (authState.accessToken && authState.refreshToken && authState.expiresAt) {
71
+ talkenApi.setTokens(
72
+ authState.accessToken,
73
+ authState.refreshToken,
74
+ authState.expiresAt
75
+ );
76
+ }
77
+ const accounts = await provider.request({
78
+ method: "eth_requestAccounts"
79
+ });
80
+ let currentChainId = await provider.request({
81
+ method: "eth_chainId"
82
+ });
83
+ const currentChainIdNumber = Number(currentChainId);
84
+ const isChainSupported = wagmiConfig.chains.some(
85
+ (c) => c.id === currentChainIdNumber
86
+ );
87
+ if (!isChainSupported && wagmiConfig.chains.length > 0) {
88
+ const fallbackChainId = wagmiConfig.chains[0].id;
89
+ await provider.request({
90
+ method: "wallet_switchEthereumChain",
91
+ params: [{ chainId: `0x${fallbackChainId.toString(16)}` }]
92
+ });
93
+ currentChainId = `0x${fallbackChainId.toString(16)}`;
94
+ if (authState.wallet) {
95
+ authState.wallet.chainId = fallbackChainId;
96
+ saveAuthState(authState);
97
+ }
98
+ }
99
+ if (accountsChangedHandler) {
100
+ provider.removeListener("accountsChanged", accountsChangedHandler);
101
+ }
102
+ accountsChangedHandler = (accounts2) => {
103
+ wagmiConfig.emitter.emit("change", {
104
+ accounts: accounts2
105
+ });
106
+ };
107
+ provider.on("accountsChanged", accountsChangedHandler);
108
+ if (chainChangedHandler) {
109
+ provider.removeListener("chainChanged", chainChangedHandler);
110
+ }
111
+ chainChangedHandler = (chainId) => {
112
+ wagmiConfig.emitter.emit("change", {
113
+ chainId: Number(chainId)
114
+ });
115
+ };
116
+ provider.on("chainChanged", chainChangedHandler);
117
+ if (disconnectHandler) {
118
+ provider.removeListener("disconnect", disconnectHandler);
119
+ }
120
+ disconnectHandler = () => {
121
+ wagmiConfig.emitter.emit("disconnect");
122
+ this.onDisconnect();
123
+ };
124
+ provider.on("disconnect", disconnectHandler);
125
+ wagmiConfig.emitter.emit("connect", {
126
+ accounts,
127
+ chainId: Number(currentChainId)
128
+ });
129
+ return {
130
+ accounts,
131
+ chainId: Number(currentChainId)
132
+ };
133
+ } catch (error) {
134
+ console.error("\u274C ABC Connector connect() failed:", {
135
+ message: error.message,
136
+ code: error.code,
137
+ error
138
+ });
139
+ if (error.message === "ABC_LOGIN_REQUIRED") {
140
+ throw error;
141
+ }
142
+ throw error;
143
+ }
144
+ },
145
+ /**
146
+ * Disconnect wallet
147
+ */
148
+ async disconnect() {
149
+ if (accountsChangedHandler) {
150
+ provider.removeListener("accountsChanged", accountsChangedHandler);
151
+ accountsChangedHandler = void 0;
152
+ }
153
+ if (chainChangedHandler) {
154
+ provider.removeListener("chainChanged", chainChangedHandler);
155
+ chainChangedHandler = void 0;
156
+ }
157
+ if (disconnectHandler) {
158
+ provider.removeListener("disconnect", disconnectHandler);
159
+ disconnectHandler = void 0;
160
+ }
161
+ provider.clearWallet();
162
+ talkenApi.auth.logout();
163
+ clearAuthState();
164
+ getCredentialManager().clear();
165
+ },
166
+ /**
167
+ * Get accounts
168
+ */
169
+ async getAccounts() {
170
+ const accounts = await provider.request({
171
+ method: "eth_accounts"
172
+ });
173
+ return accounts.map((account) => account);
174
+ },
175
+ /**
176
+ * Get chain ID
177
+ */
178
+ async getChainId() {
179
+ const chainId = await provider.request({
180
+ method: "eth_chainId"
181
+ });
182
+ return Number(chainId);
183
+ },
184
+ /**
185
+ * Get provider
186
+ */
187
+ async getProvider() {
188
+ return provider;
189
+ },
190
+ /**
191
+ * Check if authorized (has valid session)
192
+ * Auto-refreshes access token if expired but refresh token is valid
193
+ */
194
+ async isAuthorized() {
195
+ try {
196
+ const authState = loadAuthState();
197
+ if (!authState || !authState.isAuthenticated) {
198
+ return false;
199
+ }
200
+ if (!authState.wallet) {
201
+ return false;
202
+ }
203
+ if (talkenApi.isAuthenticated()) {
204
+ return true;
205
+ }
206
+ const refreshToken = loadFromStorage(
207
+ "refresh_token" /* REFRESH_TOKEN */
208
+ );
209
+ if (!refreshToken) {
210
+ clearStorage();
211
+ return false;
212
+ }
213
+ try {
214
+ const api = getTalkenApiClient();
215
+ if (!api) {
216
+ clearStorage();
217
+ return false;
218
+ }
219
+ const res = await api.auth.refresh();
220
+ talkenApi.setTokens(
221
+ res.accessToken,
222
+ res.refreshToken,
223
+ Date.now() + res.expiresIn * 1e3
224
+ );
225
+ const updatedState = loadAuthState();
226
+ return updatedState?.isAuthenticated ?? false;
227
+ } catch (error) {
228
+ console.error("[AbcConnector] Token refresh failed:", error);
229
+ clearStorage();
230
+ return false;
231
+ }
232
+ } catch (error) {
233
+ console.error(
234
+ "[AbcConnector] Unexpected error in isAuthorized:",
235
+ error
236
+ );
237
+ return false;
238
+ }
239
+ },
240
+ /**
241
+ * Switch chain
242
+ */
243
+ async switchChain({ chainId }) {
244
+ await provider.request({
245
+ method: "wallet_switchEthereumChain",
246
+ params: [{ chainId: `0x${chainId.toString(16)}` }]
247
+ });
248
+ const newChainId = await this.getChainId();
249
+ const authState = loadAuthState();
250
+ if (authState?.wallet) {
251
+ authState.wallet.chainId = newChainId;
252
+ saveAuthState(authState);
253
+ }
254
+ return wagmiConfig.chains.find((x) => x.id === chainId) ?? {
255
+ id: chainId,
256
+ name: `Chain ${chainId}`,
257
+ nativeCurrency: {
258
+ name: "Ether",
259
+ decimals: 18,
260
+ symbol: "ETH"
261
+ },
262
+ rpcUrls: {
263
+ default: { http: [""] }
264
+ }
265
+ };
266
+ },
267
+ /**
268
+ * Handle accounts changed
269
+ */
270
+ onAccountsChanged(accounts) {
271
+ if (accounts.length === 0) {
272
+ this.onDisconnect();
273
+ } else {
274
+ wagmiConfig.emitter.emit("change", {
275
+ accounts
276
+ });
277
+ }
278
+ },
279
+ /**
280
+ * Handle chain changed
281
+ */
282
+ onChainChanged(chain) {
283
+ const chainId = Number(chain);
284
+ wagmiConfig.emitter.emit("change", { chainId });
285
+ },
286
+ /**
287
+ * Handle disconnect
288
+ */
289
+ onDisconnect(_error) {
290
+ provider.clearWallet();
291
+ clearAuthState();
292
+ wagmiConfig.emitter.emit("disconnect");
293
+ }
294
+ };
295
+ });
296
+ }
297
+
298
+ export {
299
+ abcConnector
300
+ };