@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,194 @@
1
+ "use client";
2
+ import {
3
+ getBitcoinNetwork,
4
+ getEvmNetwork,
5
+ getSolanaNetwork,
6
+ getTronNetwork
7
+ } from "./chunk-O4AU63LK.js";
8
+ import {
9
+ AbcError
10
+ } from "./chunk-4P3SPC44.js";
11
+ import {
12
+ getCredentialManager
13
+ } from "./chunk-QHUBLT7N.js";
14
+
15
+ // src/wallets/walletConnectors/abcWallet/walletGeneration.ts
16
+ import { getTalkenApiClient } from "@talken/talkenkit";
17
+ async function mapApiResponseToWallets(genResponse, infoResponse, email) {
18
+ const accounts = infoResponse?.accounts || [];
19
+ const evmAccount = accounts[0] || infoResponse || {};
20
+ const uid = String(genResponse.uid || evmAccount.uid || "");
21
+ const wid = String(genResponse.wid || evmAccount.wid || "");
22
+ const sid = String(
23
+ evmAccount.sid || evmAccount.ethAddress || genResponse.evmAddress || ""
24
+ );
25
+ const pubkey = String(evmAccount.pubkey || genResponse.pubkey || "");
26
+ const solMaterial = genResponse.solana || {};
27
+ let btcAddress = genResponse.btcAddress || "";
28
+ let trxAddress = genResponse.trxAddress || "";
29
+ if ((!btcAddress || !trxAddress) && pubkey) {
30
+ try {
31
+ const api = getTalkenApiClient();
32
+ if (api) {
33
+ const addrResponse = await api.wallet.getAddressForChain("all");
34
+ if (!btcAddress)
35
+ btcAddress = addrResponse?.btc || addrResponse?.btcAddress || "";
36
+ if (!trxAddress)
37
+ trxAddress = addrResponse?.trx || addrResponse?.trxAddress || "";
38
+ }
39
+ } catch (err) {
40
+ console.warn(
41
+ "[walletGeneration] Failed to derive BTC/TRX addresses:",
42
+ err
43
+ );
44
+ }
45
+ }
46
+ const pvencstr = String(evmAccount.pvencstr || "");
47
+ const edp = String(evmAccount.encryptDevicePassword || "");
48
+ if (uid && wid && sid && pvencstr && edp) {
49
+ getCredentialManager().setEvmSigningCredentials({
50
+ uid,
51
+ wid,
52
+ sid,
53
+ pvencstr,
54
+ encryptDevicePassword: edp
55
+ });
56
+ }
57
+ const evmWallet = {
58
+ uid,
59
+ sessionId: sid,
60
+ keyId: wid,
61
+ encryptedShare: pvencstr,
62
+ secretStore: edp,
63
+ address: genResponse.evmAddress || sid,
64
+ chainId: getEvmNetwork(),
65
+ sid,
66
+ type: "evm",
67
+ email,
68
+ pubkey
69
+ };
70
+ const solanaWallet = {
71
+ uid,
72
+ sessionId: String(solMaterial.shareId || ""),
73
+ keyId: String(solMaterial.keyId || ""),
74
+ encryptedShare: String(solMaterial.encryptedShare || ""),
75
+ secretStore: String(solMaterial.secretStore || ""),
76
+ shareId: String(solMaterial.shareId || ""),
77
+ publicKey: String(solMaterial.publicKey || ""),
78
+ address: genResponse.solAddress || solMaterial.address || "",
79
+ network: getSolanaNetwork()
80
+ };
81
+ const bitcoinWallet = {
82
+ uid,
83
+ sessionId: sid,
84
+ keyId: wid,
85
+ encryptedShare: String(evmAccount.pvencstr || ""),
86
+ shareId: sid,
87
+ publicKey: pubkey,
88
+ address: btcAddress,
89
+ addressType: "bech32",
90
+ network: getBitcoinNetwork()
91
+ };
92
+ const tronWallet = {
93
+ uid,
94
+ sessionId: sid,
95
+ keyId: wid,
96
+ encryptedShare: String(evmAccount.pvencstr || ""),
97
+ shareId: sid,
98
+ publicKey: pubkey,
99
+ address: trxAddress,
100
+ network: getTronNetwork()
101
+ };
102
+ return { evmWallet, solanaWallet, bitcoinWallet, tronWallet };
103
+ }
104
+ async function generateMpcWallets(hashedPin, email) {
105
+ const api = getTalkenApiClient();
106
+ if (!api) {
107
+ throw new AbcError(
108
+ "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
109
+ "TalkenApiClient not initialized"
110
+ );
111
+ }
112
+ try {
113
+ const genResponse = await api.wallet.generate(hashedPin, email);
114
+ const infoResponse = await api.wallet.getInfo().catch(() => ({}));
115
+ return await mapApiResponseToWallets(
116
+ genResponse,
117
+ infoResponse,
118
+ email || ""
119
+ );
120
+ } catch (error) {
121
+ throw new AbcError(
122
+ "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
123
+ `Failed to generate MPC wallets: ${error.message}`,
124
+ { originalError: error }
125
+ );
126
+ }
127
+ }
128
+ async function recoverMpcWallets(hashedPin, email) {
129
+ const api = getTalkenApiClient();
130
+ if (!api) {
131
+ throw new AbcError(
132
+ "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
133
+ "TalkenApiClient not initialized"
134
+ );
135
+ }
136
+ try {
137
+ const genResponse = await api.wallet.recover(hashedPin, email);
138
+ const infoResponse = await api.wallet.getInfo().catch(() => ({}));
139
+ return await mapApiResponseToWallets(
140
+ genResponse,
141
+ infoResponse,
142
+ email || ""
143
+ );
144
+ } catch (error) {
145
+ throw new AbcError(
146
+ "WALLET_NOT_FOUND" /* WALLET_NOT_FOUND */,
147
+ `Failed to recover MPC wallets: ${error.message}`,
148
+ { originalError: error }
149
+ );
150
+ }
151
+ }
152
+ function validateMpcWallets(result) {
153
+ const errors = [];
154
+ if (!result.evmWallet) {
155
+ errors.push("EVM wallet is missing");
156
+ } else {
157
+ if (!result.evmWallet.address || !result.evmWallet.address.startsWith("0x")) {
158
+ errors.push("Invalid EVM wallet address");
159
+ }
160
+ }
161
+ if (!result.solanaWallet) {
162
+ errors.push("Solana wallet is missing");
163
+ } else {
164
+ if (!result.solanaWallet.address) {
165
+ errors.push("Invalid Solana wallet address");
166
+ }
167
+ }
168
+ if (!result.bitcoinWallet) {
169
+ errors.push("Bitcoin wallet is missing");
170
+ } else {
171
+ if (!result.bitcoinWallet.address) {
172
+ errors.push("Invalid Bitcoin wallet address");
173
+ }
174
+ }
175
+ if (!result.tronWallet) {
176
+ errors.push("TRON wallet is missing");
177
+ } else {
178
+ if (!result.tronWallet.address) {
179
+ errors.push("Invalid TRON wallet address");
180
+ } else if (!result.tronWallet.address.startsWith("T")) {
181
+ errors.push("Invalid TRON address format (expected T prefix)");
182
+ }
183
+ }
184
+ return {
185
+ valid: errors.length === 0,
186
+ errors
187
+ };
188
+ }
189
+
190
+ export {
191
+ generateMpcWallets,
192
+ recoverMpcWallets,
193
+ validateMpcWallets
194
+ };
@@ -0,0 +1,273 @@
1
+ "use client";
2
+ import {
3
+ loadAuthState,
4
+ saveAuthState
5
+ } from "./chunk-A66MTFML.js";
6
+
7
+ // src/wallets/walletConnectors/abcWallet/abcBitcoinConnector.ts
8
+ import { getTalkenApiClient } from "@talken/talkenkit";
9
+ var AbcBitcoinConnector = class {
10
+ constructor(config) {
11
+ this.wallet = null;
12
+ this.connected = false;
13
+ // Event listeners
14
+ this.connectListeners = /* @__PURE__ */ new Set();
15
+ this.disconnectListeners = /* @__PURE__ */ new Set();
16
+ this.accountsChangedListeners = /* @__PURE__ */ new Set();
17
+ this.networkChangedListeners = /* @__PURE__ */ new Set();
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
+ const api = getTalkenApiClient();
171
+ return !!api && !api.isTokenExpired();
172
+ } catch {
173
+ return false;
174
+ }
175
+ }
176
+ /**
177
+ * Check if connected
178
+ */
179
+ isConnected() {
180
+ return this.connected && this.provider.isConnected();
181
+ }
182
+ /**
183
+ * Get current wallet
184
+ */
185
+ getWallet() {
186
+ return this.wallet;
187
+ }
188
+ /**
189
+ * Get provider
190
+ */
191
+ getProvider() {
192
+ return this.provider;
193
+ }
194
+ /**
195
+ * Get wallet info
196
+ */
197
+ getWalletInfo() {
198
+ return this.provider.getWalletInfo();
199
+ }
200
+ /**
201
+ * Switch network
202
+ */
203
+ async switchNetwork(network) {
204
+ this.provider.setNetwork(network);
205
+ const authState = loadAuthState();
206
+ if (authState?.bitcoinWallet) {
207
+ authState.bitcoinWallet.network = network === "mainnet" ? "bitcoin" /* Mainnet */ : "bitcoin_testnet" /* Testnet */;
208
+ saveAuthState(authState);
209
+ }
210
+ console.log("[BitcoinConnector] \u{1F504} Network switched to:", network);
211
+ }
212
+ /**
213
+ * Get current network
214
+ */
215
+ getNetwork() {
216
+ return this.provider.getNetwork().type;
217
+ }
218
+ /**
219
+ * Refresh UTXO cache
220
+ */
221
+ async refreshUtxos() {
222
+ return this.provider.refreshUtxos();
223
+ }
224
+ on(event, listener) {
225
+ switch (event) {
226
+ case "connect":
227
+ this.connectListeners.add(listener);
228
+ break;
229
+ case "disconnect":
230
+ this.disconnectListeners.add(listener);
231
+ break;
232
+ case "accountsChanged":
233
+ this.accountsChangedListeners.add(listener);
234
+ break;
235
+ case "networkChanged":
236
+ this.networkChangedListeners.add(listener);
237
+ break;
238
+ }
239
+ }
240
+ off(event, listener) {
241
+ switch (event) {
242
+ case "connect":
243
+ this.connectListeners.delete(listener);
244
+ break;
245
+ case "disconnect":
246
+ this.disconnectListeners.delete(listener);
247
+ break;
248
+ case "accountsChanged":
249
+ this.accountsChangedListeners.delete(listener);
250
+ break;
251
+ case "networkChanged":
252
+ this.networkChangedListeners.delete(listener);
253
+ break;
254
+ }
255
+ }
256
+ /**
257
+ * Remove all listeners
258
+ */
259
+ removeAllListeners() {
260
+ this.connectListeners.clear();
261
+ this.disconnectListeners.clear();
262
+ this.accountsChangedListeners.clear();
263
+ this.networkChangedListeners.clear();
264
+ }
265
+ };
266
+ function createAbcBitcoinConnector(config) {
267
+ return new AbcBitcoinConnector(config);
268
+ }
269
+
270
+ export {
271
+ AbcBitcoinConnector,
272
+ createAbcBitcoinConnector
273
+ };
@@ -0,0 +1,213 @@
1
+ "use client";
2
+ import {
3
+ encryptWithPin
4
+ } from "./chunk-Q42NO7WB.js";
5
+ import {
6
+ getTalkenApiClient
7
+ } from "./chunk-R6ZE7JAZ.js";
8
+ import {
9
+ getBitcoinNetwork,
10
+ getEvmNetwork,
11
+ getSolanaNetwork,
12
+ getTronNetwork
13
+ } from "./chunk-O4AU63LK.js";
14
+ import {
15
+ saveAuthState
16
+ } from "./chunk-GMAYKJEI.js";
17
+ import {
18
+ getCredentialManager
19
+ } from "./chunk-MTC2HJPF.js";
20
+
21
+ // src/wallets/walletConnectors/abcWallet/backfillMissingWallets.ts
22
+ var STORAGE_PREFIX = "talkenkit_abc_";
23
+ function writeBackfillDebug(payload) {
24
+ try {
25
+ localStorage.setItem(
26
+ `${STORAGE_PREFIX}backfill_debug`,
27
+ JSON.stringify({
28
+ timestamp: (/* @__PURE__ */ new Date()).toISOString(),
29
+ ...payload
30
+ })
31
+ );
32
+ } catch {
33
+ }
34
+ }
35
+ function pickAddress(source, keys) {
36
+ if (!source) {
37
+ return null;
38
+ }
39
+ for (const key of keys) {
40
+ const value = source[key];
41
+ if (typeof value === "string" && value.trim()) {
42
+ return value;
43
+ }
44
+ }
45
+ return null;
46
+ }
47
+ function hasMissingBackfillableWallets(authState) {
48
+ if (!authState?.wallet?.address) {
49
+ return false;
50
+ }
51
+ return !authState.solanaWallet || !authState.bitcoinWallet || !authState.tronWallet;
52
+ }
53
+ async function backfillMissingWallets(authState) {
54
+ if (!hasMissingBackfillableWallets(authState)) {
55
+ writeBackfillDebug({
56
+ status: "skipped",
57
+ reason: "nothing-missing"
58
+ });
59
+ return authState;
60
+ }
61
+ const credMgr = getCredentialManager();
62
+ const hashedPin = credMgr.getPinHash();
63
+ const email = authState.user?.email || authState.wallet?.email || credMgr.getEmail();
64
+ writeBackfillDebug({
65
+ status: "started",
66
+ hasHashedPin: !!hashedPin,
67
+ hasEmail: !!email,
68
+ hasWallet: !!authState.wallet?.address,
69
+ hasSolanaWallet: !!authState.solanaWallet,
70
+ hasBitcoinWallet: !!authState.bitcoinWallet,
71
+ hasTronWallet: !!authState.tronWallet
72
+ });
73
+ if (!hashedPin || !email) {
74
+ writeBackfillDebug({
75
+ status: "blocked",
76
+ reason: !hashedPin ? "missing-pin-hash" : "missing-email",
77
+ hasHashedPin: !!hashedPin,
78
+ hasEmail: !!email
79
+ });
80
+ return null;
81
+ }
82
+ const api = getTalkenApiClient();
83
+ if (!api) {
84
+ writeBackfillDebug({
85
+ status: "blocked",
86
+ reason: "missing-api-client",
87
+ hasHashedPin: true,
88
+ hasEmail: true
89
+ });
90
+ return null;
91
+ }
92
+ try {
93
+ api.setTokens(
94
+ authState.accessToken || "",
95
+ authState.refreshToken || "",
96
+ authState.expiresAt || 0
97
+ );
98
+ const genResponse = await api.wallet.generate(hashedPin, email);
99
+ const infoResponse = await api.wallet.getInfo();
100
+ const addressResponse = await api.wallet.getAddresses().catch(() => null);
101
+ const uid = authState.user?.uid || genResponse.uid;
102
+ const accounts = infoResponse?.accounts || [];
103
+ const evmAccount = accounts[0] || infoResponse || {};
104
+ const pubkey = authState.wallet?.pubkey || evmAccount.pubkey || genResponse.pubkey || pickAddress(addressResponse, ["pubkey", "publicKey"]) || "";
105
+ const sid = authState.wallet?.sid || evmAccount.sid || authState.wallet?.address;
106
+ const generatedSolAddress = genResponse.solAddress || pickAddress(addressResponse, ["sol", "solana", "solAddress"]);
107
+ const generatedBtcAddress = genResponse.btcAddress || pickAddress(addressResponse, ["btc", "bitcoin", "btcAddress", "bitcoinAddress"]);
108
+ const generatedTrxAddress = genResponse.trxAddress || pickAddress(addressResponse, ["trx", "tron", "trxAddress", "tronAddress"]);
109
+ const nextAuthState = {
110
+ ...authState,
111
+ isAuthenticated: true,
112
+ user: authState.user || {
113
+ uid,
114
+ email,
115
+ provider: "email"
116
+ },
117
+ wallet: authState.wallet || {
118
+ address: sid,
119
+ chainId: getEvmNetwork(),
120
+ uid,
121
+ sid,
122
+ type: "evm",
123
+ email,
124
+ encryptedShare: "",
125
+ keyId: "0",
126
+ sessionId: sid
127
+ },
128
+ solanaWallet: authState.solanaWallet || (generatedSolAddress ? {
129
+ uid,
130
+ sessionId: genResponse.solana?.keyId || "",
131
+ shareId: genResponse.solana?.keyId || "",
132
+ publicKey: genResponse.solana?.publicKey || "",
133
+ address: generatedSolAddress,
134
+ keyId: genResponse.solana?.keyId || "",
135
+ encryptedShare: genResponse.solana?.encryptedShare || "",
136
+ secretStore: genResponse.solana?.secretStore || "",
137
+ network: getSolanaNetwork()
138
+ } : null),
139
+ bitcoinWallet: authState.bitcoinWallet || (generatedBtcAddress ? {
140
+ uid,
141
+ sessionId: "",
142
+ shareId: "",
143
+ publicKey: pubkey,
144
+ address: generatedBtcAddress,
145
+ keyId: "",
146
+ encryptedShare: "",
147
+ addressType: "bech32",
148
+ network: getBitcoinNetwork()
149
+ } : null),
150
+ tronWallet: authState.tronWallet || (generatedTrxAddress ? {
151
+ uid,
152
+ sessionId: "",
153
+ shareId: "",
154
+ publicKey: pubkey,
155
+ address: generatedTrxAddress,
156
+ keyId: "",
157
+ encryptedShare: "",
158
+ network: getTronNetwork()
159
+ } : null)
160
+ };
161
+ saveAuthState(nextAuthState);
162
+ const saltHex = localStorage.getItem(`${STORAGE_PREFIX}enc_salt`);
163
+ const salt = saltHex ? new Uint8Array(
164
+ saltHex.match(/.{1,2}/g)?.map((byte) => Number.parseInt(byte, 16)) || []
165
+ ) : crypto.getRandomValues(new Uint8Array(16));
166
+ const encryptedSensitiveData = await encryptWithPin(
167
+ JSON.stringify({
168
+ accessToken: nextAuthState.accessToken,
169
+ refreshToken: nextAuthState.refreshToken,
170
+ expiresAt: nextAuthState.expiresAt,
171
+ solanaWallet: nextAuthState.solanaWallet,
172
+ bitcoinWallet: nextAuthState.bitcoinWallet,
173
+ tronWallet: nextAuthState.tronWallet
174
+ }),
175
+ hashedPin,
176
+ salt
177
+ );
178
+ localStorage.setItem(
179
+ `${STORAGE_PREFIX}enc_salt`,
180
+ Array.from(salt).map((byte) => byte.toString(16).padStart(2, "0")).join("")
181
+ );
182
+ localStorage.setItem(`${STORAGE_PREFIX}enc_tokens`, encryptedSensitiveData);
183
+ localStorage.setItem(`${STORAGE_PREFIX}saved_email`, email);
184
+ window.dispatchEvent(
185
+ new CustomEvent("talkenkit:token_updated", {
186
+ detail: { expiresAt: nextAuthState.expiresAt }
187
+ })
188
+ );
189
+ window.dispatchEvent(new Event("talkenkit_storage_update"));
190
+ writeBackfillDebug({
191
+ status: "completed",
192
+ hasSolanaWallet: !!nextAuthState.solanaWallet,
193
+ hasBitcoinWallet: !!nextAuthState.bitcoinWallet,
194
+ hasTronWallet: !!nextAuthState.tronWallet,
195
+ generatedSolAddress: generatedSolAddress || null,
196
+ generatedBtcAddress: generatedBtcAddress || null,
197
+ generatedTrxAddress: generatedTrxAddress || null,
198
+ addressResponseKeys: addressResponse && typeof addressResponse === "object" ? Object.keys(addressResponse) : []
199
+ });
200
+ return nextAuthState;
201
+ } catch (error) {
202
+ writeBackfillDebug({
203
+ status: "failed",
204
+ reason: error instanceof Error ? error.message : "unknown-error"
205
+ });
206
+ throw error;
207
+ }
208
+ }
209
+
210
+ export {
211
+ hasMissingBackfillableWallets,
212
+ backfillMissingWallets
213
+ };