@eth-optimism/actions-sdk 0.0.0-main-20251009211102

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 (648) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +106 -0
  3. package/dist/actions.d.ts +58 -0
  4. package/dist/actions.d.ts.map +1 -0
  5. package/dist/actions.js +88 -0
  6. package/dist/actions.js.map +1 -0
  7. package/dist/actions.test.d.ts +2 -0
  8. package/dist/actions.test.d.ts.map +1 -0
  9. package/dist/actions.test.js +620 -0
  10. package/dist/actions.test.js.map +1 -0
  11. package/dist/constants/assets.d.ts +3 -0
  12. package/dist/constants/assets.d.ts.map +1 -0
  13. package/dist/constants/assets.js +16 -0
  14. package/dist/constants/assets.js.map +1 -0
  15. package/dist/constants/config.d.ts +10 -0
  16. package/dist/constants/config.d.ts.map +1 -0
  17. package/dist/constants/config.js +10 -0
  18. package/dist/constants/config.js.map +1 -0
  19. package/dist/constants/supportedChains.d.ts +3 -0
  20. package/dist/constants/supportedChains.d.ts.map +1 -0
  21. package/dist/constants/supportedChains.js +8 -0
  22. package/dist/constants/supportedChains.js.map +1 -0
  23. package/dist/core/asset/__mocks__/mockAsset.d.ts +6 -0
  24. package/dist/core/asset/__mocks__/mockAsset.d.ts.map +1 -0
  25. package/dist/core/asset/__mocks__/mockAsset.js +12 -0
  26. package/dist/core/asset/__mocks__/mockAsset.js.map +1 -0
  27. package/dist/core/error/errors.d.ts +19 -0
  28. package/dist/core/error/errors.d.ts.map +1 -0
  29. package/dist/core/error/errors.js +22 -0
  30. package/dist/core/error/errors.js.map +1 -0
  31. package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts +2 -0
  32. package/dist/core/utils/__tests__/retryOnStaleRead.spec.d.ts.map +1 -0
  33. package/dist/core/utils/__tests__/retryOnStaleRead.spec.js +41 -0
  34. package/dist/core/utils/__tests__/retryOnStaleRead.spec.js.map +1 -0
  35. package/dist/core/utils/retryOnStaleRead.d.ts +14 -0
  36. package/dist/core/utils/retryOnStaleRead.d.ts.map +1 -0
  37. package/dist/core/utils/retryOnStaleRead.js +29 -0
  38. package/dist/core/utils/retryOnStaleRead.js.map +1 -0
  39. package/dist/index.d.ts +11 -0
  40. package/dist/index.d.ts.map +1 -0
  41. package/dist/index.js +8 -0
  42. package/dist/index.js.map +1 -0
  43. package/dist/index.node.d.ts +5 -0
  44. package/dist/index.node.d.ts.map +1 -0
  45. package/dist/index.node.js +4 -0
  46. package/dist/index.node.js.map +1 -0
  47. package/dist/index.react.d.ts +5 -0
  48. package/dist/index.react.d.ts.map +1 -0
  49. package/dist/index.react.js +4 -0
  50. package/dist/index.react.js.map +1 -0
  51. package/dist/lend/__mocks__/mockLendTransaction.d.ts +22 -0
  52. package/dist/lend/__mocks__/mockLendTransaction.d.ts.map +1 -0
  53. package/dist/lend/__mocks__/mockLendTransaction.js +32 -0
  54. package/dist/lend/__mocks__/mockLendTransaction.js.map +1 -0
  55. package/dist/lend/core/LendProvider.d.ts +122 -0
  56. package/dist/lend/core/LendProvider.d.ts.map +1 -0
  57. package/dist/lend/core/LendProvider.js +183 -0
  58. package/dist/lend/core/LendProvider.js.map +1 -0
  59. package/dist/lend/core/__tests__/LendProvider.test.d.ts +2 -0
  60. package/dist/lend/core/__tests__/LendProvider.test.d.ts.map +1 -0
  61. package/dist/lend/core/__tests__/LendProvider.test.js +247 -0
  62. package/dist/lend/core/__tests__/LendProvider.test.js.map +1 -0
  63. package/dist/lend/index.d.ts +3 -0
  64. package/dist/lend/index.d.ts.map +1 -0
  65. package/dist/lend/index.js +3 -0
  66. package/dist/lend/index.js.map +1 -0
  67. package/dist/lend/namespaces/ActionsLendNamespace.d.ts +15 -0
  68. package/dist/lend/namespaces/ActionsLendNamespace.d.ts.map +1 -0
  69. package/dist/lend/namespaces/ActionsLendNamespace.js +17 -0
  70. package/dist/lend/namespaces/ActionsLendNamespace.js.map +1 -0
  71. package/dist/lend/namespaces/WalletLendNamespace.d.ts +36 -0
  72. package/dist/lend/namespaces/WalletLendNamespace.d.ts.map +1 -0
  73. package/dist/lend/namespaces/WalletLendNamespace.js +68 -0
  74. package/dist/lend/namespaces/WalletLendNamespace.js.map +1 -0
  75. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts +2 -0
  76. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.d.ts.map +1 -0
  77. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js +41 -0
  78. package/dist/lend/namespaces/__tests__/ActionsLendNamespace.spec.js.map +1 -0
  79. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts +2 -0
  80. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.d.ts.map +1 -0
  81. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js +188 -0
  82. package/dist/lend/namespaces/__tests__/WalletLendNamespace.spec.js.map +1 -0
  83. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts +55 -0
  84. package/dist/lend/providers/morpho/MorphoLendProvider.d.ts.map +1 -0
  85. package/dist/lend/providers/morpho/MorphoLendProvider.js +193 -0
  86. package/dist/lend/providers/morpho/MorphoLendProvider.js.map +1 -0
  87. package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts +21 -0
  88. package/dist/lend/providers/morpho/__mocks__/mockVault.d.ts.map +1 -0
  89. package/dist/lend/providers/morpho/__mocks__/mockVault.js +27 -0
  90. package/dist/lend/providers/morpho/__mocks__/mockVault.js.map +1 -0
  91. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts +2 -0
  92. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.d.ts.map +1 -0
  93. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js +259 -0
  94. package/dist/lend/providers/morpho/__tests__/MorphoLendProvider.test.js.map +1 -0
  95. package/dist/lend/providers/morpho/__tests__/api.test.d.ts +2 -0
  96. package/dist/lend/providers/morpho/__tests__/api.test.d.ts.map +1 -0
  97. package/dist/lend/providers/morpho/__tests__/api.test.js +66 -0
  98. package/dist/lend/providers/morpho/__tests__/api.test.js.map +1 -0
  99. package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts +2 -0
  100. package/dist/lend/providers/morpho/__tests__/sdk.test.d.ts.map +1 -0
  101. package/dist/lend/providers/morpho/__tests__/sdk.test.js +332 -0
  102. package/dist/lend/providers/morpho/__tests__/sdk.test.js.map +1 -0
  103. package/dist/lend/providers/morpho/api.d.ts +14 -0
  104. package/dist/lend/providers/morpho/api.d.ts.map +1 -0
  105. package/dist/lend/providers/morpho/api.js +76 -0
  106. package/dist/lend/providers/morpho/api.js.map +1 -0
  107. package/dist/lend/providers/morpho/sdk.d.ts +61 -0
  108. package/dist/lend/providers/morpho/sdk.d.ts.map +1 -0
  109. package/dist/lend/providers/morpho/sdk.js +300 -0
  110. package/dist/lend/providers/morpho/sdk.js.map +1 -0
  111. package/dist/nodeActionsFactory.d.ts +19 -0
  112. package/dist/nodeActionsFactory.d.ts.map +1 -0
  113. package/dist/nodeActionsFactory.js +17 -0
  114. package/dist/nodeActionsFactory.js.map +1 -0
  115. package/dist/reactActionsFactory.d.ts +19 -0
  116. package/dist/reactActionsFactory.d.ts.map +1 -0
  117. package/dist/reactActionsFactory.js +17 -0
  118. package/dist/reactActionsFactory.js.map +1 -0
  119. package/dist/services/ChainManager.d.ts +90 -0
  120. package/dist/services/ChainManager.d.ts.map +1 -0
  121. package/dist/services/ChainManager.js +183 -0
  122. package/dist/services/ChainManager.js.map +1 -0
  123. package/dist/services/ChainManager.spec.d.ts +2 -0
  124. package/dist/services/ChainManager.spec.d.ts.map +1 -0
  125. package/dist/services/ChainManager.spec.js +260 -0
  126. package/dist/services/ChainManager.spec.js.map +1 -0
  127. package/dist/services/tokenBalance.d.ts +15 -0
  128. package/dist/services/tokenBalance.d.ts.map +1 -0
  129. package/dist/services/tokenBalance.js +82 -0
  130. package/dist/services/tokenBalance.js.map +1 -0
  131. package/dist/services/tokenBalance.spec.d.ts +2 -0
  132. package/dist/services/tokenBalance.spec.d.ts.map +1 -0
  133. package/dist/services/tokenBalance.spec.js +73 -0
  134. package/dist/services/tokenBalance.spec.js.map +1 -0
  135. package/dist/supported/tokens.d.ts +25 -0
  136. package/dist/supported/tokens.d.ts.map +1 -0
  137. package/dist/supported/tokens.js +88 -0
  138. package/dist/supported/tokens.js.map +1 -0
  139. package/dist/test/MockAssets.d.ts +10 -0
  140. package/dist/test/MockAssets.d.ts.map +1 -0
  141. package/dist/test/MockAssets.js +29 -0
  142. package/dist/test/MockAssets.js.map +1 -0
  143. package/dist/test/MockChainManager.d.ts +31 -0
  144. package/dist/test/MockChainManager.d.ts.map +1 -0
  145. package/dist/test/MockChainManager.js +92 -0
  146. package/dist/test/MockChainManager.js.map +1 -0
  147. package/dist/test/MockLendProvider.d.ts +68 -0
  148. package/dist/test/MockLendProvider.d.ts.map +1 -0
  149. package/dist/test/MockLendProvider.js +258 -0
  150. package/dist/test/MockLendProvider.js.map +1 -0
  151. package/dist/test/MockMarkets.d.ts +15 -0
  152. package/dist/test/MockMarkets.d.ts.map +1 -0
  153. package/dist/test/MockMarkets.js +26 -0
  154. package/dist/test/MockMarkets.js.map +1 -0
  155. package/dist/test/MockPrivyClient.d.ts +66 -0
  156. package/dist/test/MockPrivyClient.d.ts.map +1 -0
  157. package/dist/test/MockPrivyClient.js +93 -0
  158. package/dist/test/MockPrivyClient.js.map +1 -0
  159. package/dist/test/utils.d.ts +2 -0
  160. package/dist/test/utils.d.ts.map +1 -0
  161. package/dist/test/utils.js +5 -0
  162. package/dist/test/utils.js.map +1 -0
  163. package/dist/types/actions.d.ts +69 -0
  164. package/dist/types/actions.d.ts.map +1 -0
  165. package/dist/types/actions.js +2 -0
  166. package/dist/types/actions.js.map +1 -0
  167. package/dist/types/asset.d.ts +32 -0
  168. package/dist/types/asset.d.ts.map +1 -0
  169. package/dist/types/asset.js +2 -0
  170. package/dist/types/asset.js.map +1 -0
  171. package/dist/types/chain.d.ts +26 -0
  172. package/dist/types/chain.d.ts.map +1 -0
  173. package/dist/types/chain.js +2 -0
  174. package/dist/types/chain.js.map +1 -0
  175. package/dist/types/index.d.ts +6 -0
  176. package/dist/types/index.d.ts.map +1 -0
  177. package/dist/types/index.js +6 -0
  178. package/dist/types/index.js.map +1 -0
  179. package/dist/types/lend/base.d.ts +370 -0
  180. package/dist/types/lend/base.d.ts.map +1 -0
  181. package/dist/types/lend/base.js +4 -0
  182. package/dist/types/lend/base.js.map +1 -0
  183. package/dist/types/lend/index.d.ts +3 -0
  184. package/dist/types/lend/index.d.ts.map +1 -0
  185. package/dist/types/lend/index.js +3 -0
  186. package/dist/types/lend/index.js.map +1 -0
  187. package/dist/types/lend/morpho.d.ts +7 -0
  188. package/dist/types/lend/morpho.d.ts.map +1 -0
  189. package/dist/types/lend/morpho.js +6 -0
  190. package/dist/types/lend/morpho.js.map +1 -0
  191. package/dist/types/wallet.d.ts +26 -0
  192. package/dist/types/wallet.d.ts.map +1 -0
  193. package/dist/types/wallet.js +2 -0
  194. package/dist/types/wallet.js.map +1 -0
  195. package/dist/utils/assets.d.ts +33 -0
  196. package/dist/utils/assets.d.ts.map +1 -0
  197. package/dist/utils/assets.js +53 -0
  198. package/dist/utils/assets.js.map +1 -0
  199. package/dist/utils/assets.test.d.ts +2 -0
  200. package/dist/utils/assets.test.d.ts.map +1 -0
  201. package/dist/utils/assets.test.js +24 -0
  202. package/dist/utils/assets.test.js.map +1 -0
  203. package/dist/utils/markets.d.ts +17 -0
  204. package/dist/utils/markets.d.ts.map +1 -0
  205. package/dist/utils/markets.js +25 -0
  206. package/dist/utils/markets.js.map +1 -0
  207. package/dist/utils/test.d.ts +117 -0
  208. package/dist/utils/test.d.ts.map +1 -0
  209. package/dist/utils/test.js +265 -0
  210. package/dist/utils/test.js.map +1 -0
  211. package/dist/wallet/core/namespace/WalletNamespace.d.ts +84 -0
  212. package/dist/wallet/core/namespace/WalletNamespace.d.ts.map +1 -0
  213. package/dist/wallet/core/namespace/WalletNamespace.js +89 -0
  214. package/dist/wallet/core/namespace/WalletNamespace.js.map +1 -0
  215. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.d.ts +2 -0
  216. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.d.ts.map +1 -0
  217. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js +249 -0
  218. package/dist/wallet/core/namespace/__tests__/WalletNamespace.spec.js.map +1 -0
  219. package/dist/wallet/core/providers/WalletProvider.d.ts +63 -0
  220. package/dist/wallet/core/providers/WalletProvider.d.ts.map +1 -0
  221. package/dist/wallet/core/providers/WalletProvider.js +85 -0
  222. package/dist/wallet/core/providers/WalletProvider.js.map +1 -0
  223. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.d.ts +2 -0
  224. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.d.ts.map +1 -0
  225. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js +246 -0
  226. package/dist/wallet/core/providers/__tests__/WalletProvider.spec.js.map +1 -0
  227. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts +33 -0
  228. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.d.ts.map +1 -0
  229. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js +13 -0
  230. package/dist/wallet/core/providers/hosted/abstract/HostedWalletProvider.js.map +1 -0
  231. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts +20 -0
  232. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.d.ts.map +1 -0
  233. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js +29 -0
  234. package/dist/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.js.map +1 -0
  235. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.d.ts +2 -0
  236. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.d.ts.map +1 -0
  237. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js +52 -0
  238. package/dist/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.js.map +1 -0
  239. package/dist/wallet/core/providers/hosted/types/index.d.ts +70 -0
  240. package/dist/wallet/core/providers/hosted/types/index.d.ts.map +1 -0
  241. package/dist/wallet/core/providers/hosted/types/index.js +2 -0
  242. package/dist/wallet/core/providers/hosted/types/index.js.map +1 -0
  243. package/dist/wallet/core/providers/smart/abstract/SmartWalletProvider.d.ts +61 -0
  244. package/dist/wallet/core/providers/smart/abstract/SmartWalletProvider.d.ts.map +1 -0
  245. package/dist/wallet/core/providers/smart/abstract/SmartWalletProvider.js +7 -0
  246. package/dist/wallet/core/providers/smart/abstract/SmartWalletProvider.js.map +1 -0
  247. package/dist/wallet/core/providers/smart/abstract/types/index.d.ts +16 -0
  248. package/dist/wallet/core/providers/smart/abstract/types/index.d.ts.map +1 -0
  249. package/dist/wallet/core/providers/smart/abstract/types/index.js +2 -0
  250. package/dist/wallet/core/providers/smart/abstract/types/index.js.map +1 -0
  251. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts +77 -0
  252. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.d.ts.map +1 -0
  253. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js +125 -0
  254. package/dist/wallet/core/providers/smart/default/DefaultSmartWalletProvider.js.map +1 -0
  255. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.d.ts +2 -0
  256. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.d.ts.map +1 -0
  257. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js +325 -0
  258. package/dist/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.js.map +1 -0
  259. package/dist/wallet/core/wallets/abstract/Wallet.d.ts +96 -0
  260. package/dist/wallet/core/wallets/abstract/Wallet.d.ts.map +1 -0
  261. package/dist/wallet/core/wallets/abstract/Wallet.js +81 -0
  262. package/dist/wallet/core/wallets/abstract/Wallet.js.map +1 -0
  263. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts +15 -0
  264. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.d.ts.map +1 -0
  265. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js +18 -0
  266. package/dist/wallet/core/wallets/abstract/__mocks__/TestWallet.js.map +1 -0
  267. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.d.ts +2 -0
  268. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.d.ts.map +1 -0
  269. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js +44 -0
  270. package/dist/wallet/core/wallets/abstract/__tests__/Wallet.spec.js.map +1 -0
  271. package/dist/wallet/core/wallets/abstract/types/index.d.ts +30 -0
  272. package/dist/wallet/core/wallets/abstract/types/index.d.ts.map +1 -0
  273. package/dist/wallet/core/wallets/abstract/types/index.js +2 -0
  274. package/dist/wallet/core/wallets/abstract/types/index.js.map +1 -0
  275. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts +44 -0
  276. package/dist/wallet/core/wallets/eoa/EOAWallet.d.ts.map +1 -0
  277. package/dist/wallet/core/wallets/eoa/EOAWallet.js +67 -0
  278. package/dist/wallet/core/wallets/eoa/EOAWallet.js.map +1 -0
  279. package/dist/wallet/core/wallets/eoa/__mocks__/EOAWallet.d.ts +28 -0
  280. package/dist/wallet/core/wallets/eoa/__mocks__/EOAWallet.d.ts.map +1 -0
  281. package/dist/wallet/core/wallets/eoa/__mocks__/EOAWallet.js +51 -0
  282. package/dist/wallet/core/wallets/eoa/__mocks__/EOAWallet.js.map +1 -0
  283. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.d.ts +2 -0
  284. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.d.ts.map +1 -0
  285. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js +191 -0
  286. package/dist/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.js.map +1 -0
  287. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts +69 -0
  288. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.d.ts.map +1 -0
  289. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.js +8 -0
  290. package/dist/wallet/core/wallets/smart/abstract/SmartWallet.js.map +1 -0
  291. package/dist/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.d.ts +43 -0
  292. package/dist/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.d.ts.map +1 -0
  293. package/dist/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.js +67 -0
  294. package/dist/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.js.map +1 -0
  295. package/dist/wallet/core/wallets/smart/abstract/types/index.d.ts +19 -0
  296. package/dist/wallet/core/wallets/smart/abstract/types/index.d.ts.map +1 -0
  297. package/dist/wallet/core/wallets/smart/abstract/types/index.js +2 -0
  298. package/dist/wallet/core/wallets/smart/abstract/types/index.js.map +1 -0
  299. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts +191 -0
  300. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.d.ts.map +1 -0
  301. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js +436 -0
  302. package/dist/wallet/core/wallets/smart/default/DefaultSmartWallet.js.map +1 -0
  303. package/dist/wallet/core/wallets/smart/default/__mocks__/DefaultSmartWallet.d.ts +40 -0
  304. package/dist/wallet/core/wallets/smart/default/__mocks__/DefaultSmartWallet.d.ts.map +1 -0
  305. package/dist/wallet/core/wallets/smart/default/__mocks__/DefaultSmartWallet.js +72 -0
  306. package/dist/wallet/core/wallets/smart/default/__mocks__/DefaultSmartWallet.js.map +1 -0
  307. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.d.ts +2 -0
  308. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.d.ts.map +1 -0
  309. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js +561 -0
  310. package/dist/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.js.map +1 -0
  311. package/dist/wallet/core/wallets/smart/default/constants/index.d.ts +719 -0
  312. package/dist/wallet/core/wallets/smart/default/constants/index.d.ts.map +1 -0
  313. package/dist/wallet/core/wallets/smart/default/constants/index.js +480 -0
  314. package/dist/wallet/core/wallets/smart/default/constants/index.js.map +1 -0
  315. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.d.ts +2 -0
  316. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.d.ts.map +1 -0
  317. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js +52 -0
  318. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.js.map +1 -0
  319. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerIndexOnChain.spec.d.ts +2 -0
  320. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerIndexOnChain.spec.d.ts.map +1 -0
  321. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerIndexOnChain.spec.js +109 -0
  322. package/dist/wallet/core/wallets/smart/default/utils/__tests__/findSignerIndexOnChain.spec.js.map +1 -0
  323. package/dist/wallet/core/wallets/smart/default/utils/__tests__/formatPublicKey.spec.d.ts +2 -0
  324. package/dist/wallet/core/wallets/smart/default/utils/__tests__/formatPublicKey.spec.d.ts.map +1 -0
  325. package/dist/wallet/core/wallets/smart/default/utils/__tests__/formatPublicKey.spec.js +22 -0
  326. package/dist/wallet/core/wallets/smart/default/utils/__tests__/formatPublicKey.spec.js.map +1 -0
  327. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.d.ts +2 -0
  328. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.d.ts.map +1 -0
  329. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js +44 -0
  330. package/dist/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.js.map +1 -0
  331. package/dist/wallet/core/wallets/smart/default/utils/findSignerInArray.d.ts +12 -0
  332. package/dist/wallet/core/wallets/smart/default/utils/findSignerInArray.d.ts.map +1 -0
  333. package/dist/wallet/core/wallets/smart/default/utils/findSignerInArray.js +23 -0
  334. package/dist/wallet/core/wallets/smart/default/utils/findSignerInArray.js.map +1 -0
  335. package/dist/wallet/core/wallets/smart/default/utils/findSignerIndexOnChain.d.ts +30 -0
  336. package/dist/wallet/core/wallets/smart/default/utils/findSignerIndexOnChain.d.ts.map +1 -0
  337. package/dist/wallet/core/wallets/smart/default/utils/findSignerIndexOnChain.js +40 -0
  338. package/dist/wallet/core/wallets/smart/default/utils/findSignerIndexOnChain.js.map +1 -0
  339. package/dist/wallet/core/wallets/smart/default/utils/formatPublicKey.d.ts +8 -0
  340. package/dist/wallet/core/wallets/smart/default/utils/formatPublicKey.d.ts.map +1 -0
  341. package/dist/wallet/core/wallets/smart/default/utils/formatPublicKey.js +13 -0
  342. package/dist/wallet/core/wallets/smart/default/utils/formatPublicKey.js.map +1 -0
  343. package/dist/wallet/core/wallets/smart/default/utils/getSignerPublicKey.d.ts +12 -0
  344. package/dist/wallet/core/wallets/smart/default/utils/getSignerPublicKey.d.ts.map +1 -0
  345. package/dist/wallet/core/wallets/smart/default/utils/getSignerPublicKey.js +18 -0
  346. package/dist/wallet/core/wallets/smart/default/utils/getSignerPublicKey.js.map +1 -0
  347. package/dist/wallet/core/wallets/smart/error/errors.d.ts +8 -0
  348. package/dist/wallet/core/wallets/smart/error/errors.d.ts.map +1 -0
  349. package/dist/wallet/core/wallets/smart/error/errors.js +9 -0
  350. package/dist/wallet/core/wallets/smart/error/errors.js.map +1 -0
  351. package/dist/wallet/node/index.d.ts +4 -0
  352. package/dist/wallet/node/index.d.ts.map +1 -0
  353. package/dist/wallet/node/index.js +3 -0
  354. package/dist/wallet/node/index.js.map +1 -0
  355. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +34 -0
  356. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -0
  357. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js +43 -0
  358. package/dist/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -0
  359. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.d.ts +2 -0
  360. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.d.ts.map +1 -0
  361. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +80 -0
  362. package/dist/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -0
  363. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts +15 -0
  364. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.d.ts.map +1 -0
  365. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js +37 -0
  366. package/dist/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.js.map +1 -0
  367. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.d.ts +2 -0
  368. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.d.ts.map +1 -0
  369. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js +62 -0
  370. package/dist/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.js.map +1 -0
  371. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +50 -0
  372. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -0
  373. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +60 -0
  374. package/dist/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -0
  375. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.d.ts +2 -0
  376. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.d.ts.map +1 -0
  377. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +132 -0
  378. package/dist/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -0
  379. package/dist/wallet/node/providers/hosted/types/index.d.ts +90 -0
  380. package/dist/wallet/node/providers/hosted/types/index.d.ts.map +1 -0
  381. package/dist/wallet/node/providers/hosted/types/index.js +2 -0
  382. package/dist/wallet/node/providers/hosted/types/index.js.map +1 -0
  383. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts +43 -0
  384. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -0
  385. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js +47 -0
  386. package/dist/wallet/node/wallets/hosted/privy/PrivyWallet.js.map +1 -0
  387. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.d.ts +2 -0
  388. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.d.ts.map +1 -0
  389. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +105 -0
  390. package/dist/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -0
  391. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.d.ts +2 -0
  392. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.d.ts.map +1 -0
  393. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +39 -0
  394. package/dist/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -0
  395. package/dist/wallet/node/wallets/hosted/privy/utils/createSigner.d.ts +15 -0
  396. package/dist/wallet/node/wallets/hosted/privy/utils/createSigner.d.ts.map +1 -0
  397. package/dist/wallet/node/wallets/hosted/privy/utils/createSigner.js +23 -0
  398. package/dist/wallet/node/wallets/hosted/privy/utils/createSigner.js.map +1 -0
  399. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts +46 -0
  400. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -0
  401. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js +34 -0
  402. package/dist/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -0
  403. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.d.ts +2 -0
  404. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.d.ts.map +1 -0
  405. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +82 -0
  406. package/dist/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -0
  407. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.d.ts +2 -0
  408. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.d.ts.map +1 -0
  409. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +61 -0
  410. package/dist/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -0
  411. package/dist/wallet/node/wallets/hosted/turnkey/utils/createSigner.d.ts +17 -0
  412. package/dist/wallet/node/wallets/hosted/turnkey/utils/createSigner.d.ts.map +1 -0
  413. package/dist/wallet/node/wallets/hosted/turnkey/utils/createSigner.js +24 -0
  414. package/dist/wallet/node/wallets/hosted/turnkey/utils/createSigner.js.map +1 -0
  415. package/dist/wallet/react/index.d.ts +3 -0
  416. package/dist/wallet/react/index.d.ts.map +1 -0
  417. package/dist/wallet/react/index.js +2 -0
  418. package/dist/wallet/react/index.js.map +1 -0
  419. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts +29 -0
  420. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.d.ts.map +1 -0
  421. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js +36 -0
  422. package/dist/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.js.map +1 -0
  423. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.d.ts +33 -0
  424. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.d.ts.map +1 -0
  425. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js +30 -0
  426. package/dist/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.js.map +1 -0
  427. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.d.ts +2 -0
  428. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.d.ts.map +1 -0
  429. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js +79 -0
  430. package/dist/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.js.map +1 -0
  431. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts +29 -0
  432. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.d.ts.map +1 -0
  433. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js +38 -0
  434. package/dist/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.js.map +1 -0
  435. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.d.ts +33 -0
  436. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.d.ts.map +1 -0
  437. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js +29 -0
  438. package/dist/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.js.map +1 -0
  439. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.d.ts +2 -0
  440. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.d.ts.map +1 -0
  441. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js +79 -0
  442. package/dist/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.js.map +1 -0
  443. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts +49 -0
  444. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.d.ts.map +1 -0
  445. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js +60 -0
  446. package/dist/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.js.map +1 -0
  447. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.d.ts +2 -0
  448. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.d.ts.map +1 -0
  449. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js +110 -0
  450. package/dist/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.js.map +1 -0
  451. package/dist/wallet/react/providers/hosted/types/index.d.ts +86 -0
  452. package/dist/wallet/react/providers/hosted/types/index.d.ts.map +1 -0
  453. package/dist/wallet/react/providers/hosted/types/index.js +2 -0
  454. package/dist/wallet/react/providers/hosted/types/index.js.map +1 -0
  455. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts +15 -0
  456. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.d.ts.map +1 -0
  457. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js +46 -0
  458. package/dist/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.js.map +1 -0
  459. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.d.ts +2 -0
  460. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.d.ts.map +1 -0
  461. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js +68 -0
  462. package/dist/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.js.map +1 -0
  463. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts +39 -0
  464. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.d.ts.map +1 -0
  465. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js +43 -0
  466. package/dist/wallet/react/wallets/hosted/dynamic/DynamicWallet.js.map +1 -0
  467. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts +16 -0
  468. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.d.ts.map +1 -0
  469. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js +15 -0
  470. package/dist/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.js.map +1 -0
  471. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.d.ts +2 -0
  472. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.d.ts.map +1 -0
  473. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js +117 -0
  474. package/dist/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.js.map +1 -0
  475. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.d.ts +2 -0
  476. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.d.ts.map +1 -0
  477. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js +62 -0
  478. package/dist/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.js.map +1 -0
  479. package/dist/wallet/react/wallets/hosted/dynamic/utils/createSigner.d.ts +13 -0
  480. package/dist/wallet/react/wallets/hosted/dynamic/utils/createSigner.d.ts.map +1 -0
  481. package/dist/wallet/react/wallets/hosted/dynamic/utils/createSigner.js +32 -0
  482. package/dist/wallet/react/wallets/hosted/dynamic/utils/createSigner.js.map +1 -0
  483. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts +34 -0
  484. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.d.ts.map +1 -0
  485. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js +38 -0
  486. package/dist/wallet/react/wallets/hosted/privy/PrivyWallet.js.map +1 -0
  487. package/dist/wallet/react/wallets/hosted/privy/__mocks__/PrivyWalletMock.d.ts +16 -0
  488. package/dist/wallet/react/wallets/hosted/privy/__mocks__/PrivyWalletMock.d.ts.map +1 -0
  489. package/dist/wallet/react/wallets/hosted/privy/__mocks__/PrivyWalletMock.js +15 -0
  490. package/dist/wallet/react/wallets/hosted/privy/__mocks__/PrivyWalletMock.js.map +1 -0
  491. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.d.ts +2 -0
  492. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.d.ts.map +1 -0
  493. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js +95 -0
  494. package/dist/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.js.map +1 -0
  495. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.d.ts +2 -0
  496. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.d.ts.map +1 -0
  497. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js +55 -0
  498. package/dist/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.js.map +1 -0
  499. package/dist/wallet/react/wallets/hosted/privy/utils/createSigner.d.ts +13 -0
  500. package/dist/wallet/react/wallets/hosted/privy/utils/createSigner.d.ts.map +1 -0
  501. package/dist/wallet/react/wallets/hosted/privy/utils/createSigner.js +24 -0
  502. package/dist/wallet/react/wallets/hosted/privy/utils/createSigner.js.map +1 -0
  503. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts +53 -0
  504. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.d.ts.map +1 -0
  505. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js +43 -0
  506. package/dist/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.js.map +1 -0
  507. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.d.ts +2 -0
  508. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.d.ts.map +1 -0
  509. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js +82 -0
  510. package/dist/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.js.map +1 -0
  511. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.d.ts +2 -0
  512. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.d.ts.map +1 -0
  513. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js +61 -0
  514. package/dist/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.js.map +1 -0
  515. package/dist/wallet/react/wallets/hosted/turnkey/utils/createSigner.d.ts +17 -0
  516. package/dist/wallet/react/wallets/hosted/turnkey/utils/createSigner.d.ts.map +1 -0
  517. package/dist/wallet/react/wallets/hosted/turnkey/utils/createSigner.js +24 -0
  518. package/dist/wallet/react/wallets/hosted/turnkey/utils/createSigner.js.map +1 -0
  519. package/package.json +86 -0
  520. package/src/actions.test.ts +885 -0
  521. package/src/actions.ts +190 -0
  522. package/src/constants/assets.ts +20 -0
  523. package/src/constants/config.ts +9 -0
  524. package/src/constants/supportedChains.ts +10 -0
  525. package/src/core/asset/__mocks__/mockAsset.ts +13 -0
  526. package/src/core/error/errors.ts +27 -0
  527. package/src/core/utils/__tests__/retryOnStaleRead.spec.ts +56 -0
  528. package/src/core/utils/retryOnStaleRead.ts +39 -0
  529. package/src/index.node.ts +4 -0
  530. package/src/index.react.ts +4 -0
  531. package/src/index.ts +35 -0
  532. package/src/lend/__mocks__/mockLendTransaction.ts +47 -0
  533. package/src/lend/core/LendProvider.ts +311 -0
  534. package/src/lend/core/__tests__/LendProvider.test.ts +305 -0
  535. package/src/lend/index.ts +2 -0
  536. package/src/lend/namespaces/ActionsLendNamespace.ts +26 -0
  537. package/src/lend/namespaces/WalletLendNamespace.ts +116 -0
  538. package/src/lend/namespaces/__tests__/ActionsLendNamespace.spec.ts +58 -0
  539. package/src/lend/namespaces/__tests__/WalletLendNamespace.spec.ts +223 -0
  540. package/src/lend/providers/morpho/MorphoLendProvider.ts +258 -0
  541. package/src/lend/providers/morpho/__mocks__/mockVault.ts +28 -0
  542. package/src/lend/providers/morpho/__tests__/MorphoLendProvider.test.ts +356 -0
  543. package/src/lend/providers/morpho/__tests__/api.test.ts +104 -0
  544. package/src/lend/providers/morpho/__tests__/sdk.test.ts +366 -0
  545. package/src/lend/providers/morpho/api.ts +86 -0
  546. package/src/lend/providers/morpho/sdk.ts +418 -0
  547. package/src/nodeActionsFactory.ts +37 -0
  548. package/src/reactActionsFactory.ts +37 -0
  549. package/src/services/ChainManager.spec.ts +332 -0
  550. package/src/services/ChainManager.ts +237 -0
  551. package/src/services/tokenBalance.spec.ts +93 -0
  552. package/src/services/tokenBalance.ts +122 -0
  553. package/src/supported/tokens.ts +103 -0
  554. package/src/test/MockAssets.ts +33 -0
  555. package/src/test/MockChainManager.ts +138 -0
  556. package/src/test/MockLendProvider.ts +397 -0
  557. package/src/test/MockMarkets.ts +32 -0
  558. package/src/test/MockPrivyClient.ts +118 -0
  559. package/src/test/utils.ts +5 -0
  560. package/src/types/actions.ts +80 -0
  561. package/src/types/asset.ts +34 -0
  562. package/src/types/chain.ts +30 -0
  563. package/src/types/index.ts +5 -0
  564. package/src/types/lend/base.ts +415 -0
  565. package/src/types/lend/index.ts +2 -0
  566. package/src/types/lend/morpho.ts +16 -0
  567. package/src/types/wallet.ts +28 -0
  568. package/src/utils/assets.test.ts +28 -0
  569. package/src/utils/assets.ts +71 -0
  570. package/src/utils/markets.ts +35 -0
  571. package/src/utils/test.ts +379 -0
  572. package/src/wallet/core/namespace/WalletNamespace.ts +125 -0
  573. package/src/wallet/core/namespace/__tests__/WalletNamespace.spec.ts +398 -0
  574. package/src/wallet/core/providers/WalletProvider.ts +123 -0
  575. package/src/wallet/core/providers/__tests__/WalletProvider.spec.ts +374 -0
  576. package/src/wallet/core/providers/hosted/abstract/HostedWalletProvider.ts +45 -0
  577. package/src/wallet/core/providers/hosted/registry/HostedWalletProviderRegistry.ts +46 -0
  578. package/src/wallet/core/providers/hosted/registry/__tests__/HostedWalletProviderRegistry.spec.ts +77 -0
  579. package/src/wallet/core/providers/hosted/types/index.ts +76 -0
  580. package/src/wallet/core/providers/smart/abstract/SmartWalletProvider.ts +64 -0
  581. package/src/wallet/core/providers/smart/abstract/types/index.ts +17 -0
  582. package/src/wallet/core/providers/smart/default/DefaultSmartWalletProvider.ts +175 -0
  583. package/src/wallet/core/providers/smart/default/__tests__/DefaultSmartWalletProvider.spec.ts +467 -0
  584. package/src/wallet/core/wallets/abstract/Wallet.ts +149 -0
  585. package/src/wallet/core/wallets/abstract/__mocks__/TestWallet.ts +40 -0
  586. package/src/wallet/core/wallets/abstract/__tests__/Wallet.spec.ts +61 -0
  587. package/src/wallet/core/wallets/abstract/types/index.ts +42 -0
  588. package/src/wallet/core/wallets/eoa/EOAWallet.ts +96 -0
  589. package/src/wallet/core/wallets/eoa/__mocks__/EOAWallet.ts +112 -0
  590. package/src/wallet/core/wallets/eoa/__tests__/EOAWallet.spec.ts +299 -0
  591. package/src/wallet/core/wallets/smart/abstract/SmartWallet.ts +93 -0
  592. package/src/wallet/core/wallets/smart/abstract/__mocks__/SmartWallet.ts +161 -0
  593. package/src/wallet/core/wallets/smart/abstract/types/index.ts +19 -0
  594. package/src/wallet/core/wallets/smart/default/DefaultSmartWallet.ts +598 -0
  595. package/src/wallet/core/wallets/smart/default/__mocks__/DefaultSmartWallet.ts +172 -0
  596. package/src/wallet/core/wallets/smart/default/__tests__/DefaultSmartWallet.spec.ts +781 -0
  597. package/src/wallet/core/wallets/smart/default/constants/index.ts +482 -0
  598. package/src/wallet/core/wallets/smart/default/utils/__tests__/findSignerInArray.spec.ts +68 -0
  599. package/src/wallet/core/wallets/smart/default/utils/__tests__/findSignerIndexOnChain.spec.ts +147 -0
  600. package/src/wallet/core/wallets/smart/default/utils/__tests__/formatPublicKey.spec.ts +28 -0
  601. package/src/wallet/core/wallets/smart/default/utils/__tests__/getSignerPublicKey.spec.ts +60 -0
  602. package/src/wallet/core/wallets/smart/default/utils/findSignerInArray.ts +30 -0
  603. package/src/wallet/core/wallets/smart/default/utils/findSignerIndexOnChain.ts +66 -0
  604. package/src/wallet/core/wallets/smart/default/utils/formatPublicKey.ts +14 -0
  605. package/src/wallet/core/wallets/smart/default/utils/getSignerPublicKey.ts +18 -0
  606. package/src/wallet/core/wallets/smart/error/errors.ts +18 -0
  607. package/src/wallet/node/index.ts +7 -0
  608. package/src/wallet/node/providers/hosted/privy/PrivyHostedWalletProvider.ts +65 -0
  609. package/src/wallet/node/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +112 -0
  610. package/src/wallet/node/providers/hosted/registry/NodeHostedWalletProviderRegistry.ts +55 -0
  611. package/src/wallet/node/providers/hosted/registry/__tests__/NodeHostedWalletProviderRegistry.spec.ts +89 -0
  612. package/src/wallet/node/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +84 -0
  613. package/src/wallet/node/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +182 -0
  614. package/src/wallet/node/providers/hosted/types/index.ts +102 -0
  615. package/src/wallet/node/wallets/hosted/privy/PrivyWallet.ts +78 -0
  616. package/src/wallet/node/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +142 -0
  617. package/src/wallet/node/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +48 -0
  618. package/src/wallet/node/wallets/hosted/privy/utils/createSigner.ts +32 -0
  619. package/src/wallet/node/wallets/hosted/turnkey/TurnkeyWallet.ts +90 -0
  620. package/src/wallet/node/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +104 -0
  621. package/src/wallet/node/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +77 -0
  622. package/src/wallet/node/wallets/hosted/turnkey/utils/createSigner.ts +32 -0
  623. package/src/wallet/react/index.ts +5 -0
  624. package/src/wallet/react/providers/hosted/dynamic/DynamicHostedWalletProvider.ts +54 -0
  625. package/src/wallet/react/providers/hosted/dynamic/__mocks__/DynamicHostedWalletProviderMock.ts +57 -0
  626. package/src/wallet/react/providers/hosted/dynamic/__tests__/DynamicHostedWalletProvider.spec.ts +105 -0
  627. package/src/wallet/react/providers/hosted/privy/PrivyHostedWalletProvider.ts +56 -0
  628. package/src/wallet/react/providers/hosted/privy/__mocks__/PrivyHostedWalletProviderMock.ts +56 -0
  629. package/src/wallet/react/providers/hosted/privy/__tests__/PrivyHostedWalletProvider.spec.ts +103 -0
  630. package/src/wallet/react/providers/hosted/turnkey/TurnkeyHostedWalletProvider.ts +78 -0
  631. package/src/wallet/react/providers/hosted/turnkey/__tests__/TurnkeyHostedWalletProvider.spec.ts +142 -0
  632. package/src/wallet/react/providers/hosted/types/index.ts +100 -0
  633. package/src/wallet/react/providers/registry/ReactHostedWalletProviderRegistry.ts +57 -0
  634. package/src/wallet/react/providers/registry/__tests__/ReactHostedWalletProviderRegistry.spec.ts +117 -0
  635. package/src/wallet/react/wallets/hosted/dynamic/DynamicWallet.ts +67 -0
  636. package/src/wallet/react/wallets/hosted/dynamic/__mocks__/DynamicWalletMock.ts +22 -0
  637. package/src/wallet/react/wallets/hosted/dynamic/__tests__/DynamicWallet.spec.ts +148 -0
  638. package/src/wallet/react/wallets/hosted/dynamic/utils/__tests__/createSigner.spec.ts +82 -0
  639. package/src/wallet/react/wallets/hosted/dynamic/utils/createSigner.ts +38 -0
  640. package/src/wallet/react/wallets/hosted/privy/PrivyWallet.ts +63 -0
  641. package/src/wallet/react/wallets/hosted/privy/__mocks__/PrivyWalletMock.ts +22 -0
  642. package/src/wallet/react/wallets/hosted/privy/__tests__/PrivyWallet.spec.ts +109 -0
  643. package/src/wallet/react/wallets/hosted/privy/utils/__tests__/createSigner.spec.ts +66 -0
  644. package/src/wallet/react/wallets/hosted/privy/utils/createSigner.ts +30 -0
  645. package/src/wallet/react/wallets/hosted/turnkey/TurnkeyWallet.ts +94 -0
  646. package/src/wallet/react/wallets/hosted/turnkey/__tests__/TurnkeyWallet.spec.ts +99 -0
  647. package/src/wallet/react/wallets/hosted/turnkey/utils/__tests__/createSigner.spec.ts +72 -0
  648. package/src/wallet/react/wallets/hosted/turnkey/utils/createSigner.ts +29 -0
@@ -0,0 +1,148 @@
1
+ import { isEthereumWallet } from '@dynamic-labs/ethereum'
2
+ import type {
3
+ Address,
4
+ CustomSource,
5
+ Hash,
6
+ LocalAccount,
7
+ WalletClient,
8
+ } from 'viem'
9
+ import { createWalletClient } from 'viem'
10
+ import { toAccount } from 'viem/accounts'
11
+ import { unichain } from 'viem/chains'
12
+ import { describe, expect, it, vi } from 'vitest'
13
+
14
+ import type { ChainManager } from '@/services/ChainManager.js'
15
+ import { MockChainManager } from '@/test/MockChainManager.js'
16
+ import { getRandomAddress } from '@/test/utils.js'
17
+ import type { DynamicHostedWalletToActionsWalletOptions } from '@/wallet/react/providers/hosted/types/index.js'
18
+ import { DynamicWallet } from '@/wallet/react/wallets/hosted/dynamic/DynamicWallet.js'
19
+
20
+ vi.mock('viem', async () => ({
21
+ // @ts-ignore - importActual returns unknown
22
+ ...(await vi.importActual('viem')),
23
+ createWalletClient: vi.fn(),
24
+ }))
25
+
26
+ vi.mock('viem/accounts', async () => ({
27
+ // @ts-ignore - importActual returns unknown
28
+ ...(await vi.importActual('viem/accounts')),
29
+ toAccount: vi.fn(),
30
+ }))
31
+
32
+ vi.mock('@dynamic-labs/ethereum', () => ({
33
+ isEthereumWallet: vi.fn().mockReturnValue(true),
34
+ }))
35
+
36
+ const mockAddress = getRandomAddress()
37
+ const mockChainManager = new MockChainManager({
38
+ supportedChains: [unichain.id],
39
+ }) as unknown as ChainManager
40
+ const mockLocalAccount = {
41
+ address: mockAddress,
42
+ signMessage: vi.fn(),
43
+ sign: vi.fn(),
44
+ signTransaction: vi.fn(),
45
+ signTypedData: vi.fn(),
46
+ } as unknown as LocalAccount
47
+
48
+ function createMockDynamicWallet(): DynamicHostedWalletToActionsWalletOptions['wallet'] {
49
+ const mockConnector = {
50
+ signRawMessage: vi.fn().mockResolvedValue('0xsigned'),
51
+ }
52
+ const mockWalletClient = {
53
+ account: { address: mockAddress },
54
+ signMessage: vi.fn(),
55
+ signTransaction: vi.fn(),
56
+ signTypedData: vi.fn(),
57
+ } as unknown as WalletClient
58
+ return {
59
+ connector: mockConnector,
60
+ getWalletClient: vi.fn().mockResolvedValue(mockWalletClient),
61
+ __mock: { connector: mockConnector, walletClient: mockWalletClient },
62
+ }
63
+ }
64
+
65
+ describe('DynamicWallet', () => {
66
+ it('should initialize signer and address from dynamic wallet', async () => {
67
+ const dynamic = createMockDynamicWallet()
68
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
69
+
70
+ const wallet = await DynamicWallet.create({
71
+ dynamicWallet: dynamic,
72
+ chainManager: mockChainManager,
73
+ })
74
+
75
+ expect(wallet.address).toBe(mockAddress)
76
+ expect(dynamic.getWalletClient).toHaveBeenCalled()
77
+ })
78
+
79
+ it('should wire toAccount signer to connector.signRawMessage with 0x trim', async () => {
80
+ const dynamic = createMockDynamicWallet()
81
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
82
+
83
+ await DynamicWallet.create({
84
+ dynamicWallet: dynamic,
85
+ chainManager: mockChainManager,
86
+ })
87
+
88
+ const calls = vi.mocked(toAccount).mock.calls
89
+ const callArgs = calls[calls.length - 1][0] as CustomSource
90
+ expect(callArgs.address).toBe(dynamic.__mock.walletClient.account.address)
91
+
92
+ // Invoke the sign function and assert message formatting
93
+ await callArgs.sign!({ hash: '0xdeadbeef' })
94
+ expect(dynamic.__mock.connector.signRawMessage).toHaveBeenCalledWith({
95
+ accountAddress: dynamic.__mock.walletClient.account.address,
96
+ message: 'deadbeef',
97
+ })
98
+
99
+ await callArgs.sign!({ hash: 'cafebabe' as Hash })
100
+ expect(dynamic.__mock.connector.signRawMessage).toHaveBeenCalledWith({
101
+ accountAddress: dynamic.__mock.walletClient.account.address,
102
+ message: 'cafebabe',
103
+ })
104
+ })
105
+
106
+ it('should create a wallet client with correct configuration', async () => {
107
+ const dynamic = createMockDynamicWallet()
108
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
109
+
110
+ const wallet = await DynamicWallet.create({
111
+ dynamicWallet: dynamic,
112
+ chainManager: mockChainManager,
113
+ })
114
+
115
+ const mockWalletClient = {
116
+ account: mockLocalAccount,
117
+ address: mockAddress as Address,
118
+ } as unknown as WalletClient
119
+
120
+ vi.mocked(createWalletClient).mockResolvedValue(mockWalletClient)
121
+
122
+ const walletClient = await wallet.walletClient(unichain.id)
123
+
124
+ expect(createWalletClient).toHaveBeenCalledOnce()
125
+ const args = vi.mocked(createWalletClient).mock.calls[0][0]
126
+ expect(args.account).toBe(mockLocalAccount)
127
+ expect(args.chain).toBe(mockChainManager.getChain(unichain.id))
128
+ expect(walletClient).toBe(mockWalletClient)
129
+ })
130
+
131
+ it('should throw if dynamic wallet is not EVM compatible', async () => {
132
+ const dynamic = createMockDynamicWallet()
133
+ // Force isEthereumWallet to return false for this test
134
+ vi.mocked(isEthereumWallet).mockReturnValueOnce(false)
135
+
136
+ try {
137
+ await DynamicWallet.create({
138
+ dynamicWallet: dynamic,
139
+ chainManager: mockChainManager,
140
+ })
141
+ } catch (err) {
142
+ expect((err as Error).message).toBe('Failed to initialize wallet')
143
+ expect((err as any).cause?.message).toBe(
144
+ 'Wallet not connected or not EVM compatible',
145
+ )
146
+ }
147
+ })
148
+ })
@@ -0,0 +1,82 @@
1
+ import { isEthereumWallet } from '@dynamic-labs/ethereum'
2
+ import type { DynamicWaasEVMConnector } from '@dynamic-labs/waas-evm'
3
+ import type { Wallet } from '@dynamic-labs/wallet-connector-core'
4
+ import type { LocalAccount, WalletClient } from 'viem'
5
+ import { toAccount } from 'viem/accounts'
6
+ import { describe, expect, it, vi } from 'vitest'
7
+
8
+ import { getRandomAddress } from '@/test/utils.js'
9
+ import { createSigner } from '@/wallet/react/wallets/hosted/dynamic/utils/createSigner.js'
10
+
11
+ vi.mock('@dynamic-labs/ethereum', async () => ({
12
+ isEthereumWallet: vi.fn(),
13
+ }))
14
+
15
+ vi.mock('viem/accounts', async () => ({
16
+ // @ts-ignore - importActual returns unknown
17
+ ...(await vi.importActual('viem/accounts')),
18
+ toAccount: vi.fn(),
19
+ }))
20
+
21
+ describe('createSigner (React Dynamic)', () => {
22
+ const mockAddress = getRandomAddress()
23
+
24
+ it('should create a LocalAccount with correct configuration', async () => {
25
+ const mockWalletClient = {
26
+ account: {
27
+ address: mockAddress,
28
+ },
29
+ signMessage: vi.fn(),
30
+ signTransaction: vi.fn(),
31
+ signTypedData: vi.fn(),
32
+ } as unknown as WalletClient
33
+
34
+ const mockConnector = {
35
+ signRawMessage: vi.fn(),
36
+ } as unknown as DynamicWaasEVMConnector
37
+
38
+ const mockWallet = {
39
+ getWalletClient: vi.fn().mockResolvedValue(mockWalletClient),
40
+ connector: mockConnector,
41
+ } as unknown as Wallet
42
+
43
+ const mockLocalAccount = {
44
+ address: mockAddress,
45
+ sign: vi.fn(),
46
+ signMessage: vi.fn(),
47
+ signTransaction: vi.fn(),
48
+ signTypedData: vi.fn(),
49
+ } as unknown as LocalAccount
50
+
51
+ vi.mocked(isEthereumWallet).mockReturnValue(true)
52
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
53
+
54
+ const signer = await createSigner({
55
+ wallet: mockWallet,
56
+ })
57
+
58
+ expect(isEthereumWallet).toHaveBeenCalledWith(mockWallet)
59
+ expect(mockWallet.getWalletClient).toHaveBeenCalled()
60
+ expect(toAccount).toHaveBeenCalledWith(
61
+ expect.objectContaining({
62
+ address: mockAddress,
63
+ signMessage: mockWalletClient.signMessage,
64
+ signTransaction: mockWalletClient.signTransaction,
65
+ signTypedData: mockWalletClient.signTypedData,
66
+ }),
67
+ )
68
+ expect(signer).toBe(mockLocalAccount)
69
+ })
70
+
71
+ it('should throw error for non-Ethereum wallet', async () => {
72
+ const mockWallet = {} as unknown as Wallet
73
+
74
+ vi.mocked(isEthereumWallet).mockReturnValue(false)
75
+
76
+ await expect(
77
+ createSigner({
78
+ wallet: mockWallet,
79
+ }),
80
+ ).rejects.toThrow('Wallet not connected or not EVM compatible')
81
+ })
82
+ })
@@ -0,0 +1,38 @@
1
+ import { isEthereumWallet } from '@dynamic-labs/ethereum'
2
+ import type { DynamicWaasEVMConnector } from '@dynamic-labs/waas-evm'
3
+ import type { LocalAccount } from 'viem'
4
+ import { toAccount } from 'viem/accounts'
5
+
6
+ import type { DynamicHostedWalletToActionsWalletOptions } from '@/wallet/react/providers/hosted/types/index.js'
7
+
8
+ /**
9
+ * Create a LocalAccount from a Dynamic wallet
10
+ * @description Converts the Dynamic wallet into a viem-compatible LocalAccount that can sign
11
+ * messages and transactions. The returned account uses Dynamic's signing infrastructure
12
+ * under the hood while providing a standard viem interface.
13
+ * @param params.dynamicWallet - Dynamic wallet instance
14
+ * @returns Promise resolving to a LocalAccount configured for signing operations
15
+ * @throws Error if wallet retrieval fails or signing operations are not supported
16
+ */
17
+ export async function createSigner(
18
+ params: DynamicHostedWalletToActionsWalletOptions,
19
+ ): Promise<LocalAccount> {
20
+ const { wallet } = params
21
+ if (!isEthereumWallet(wallet)) {
22
+ throw new Error('Wallet not connected or not EVM compatible')
23
+ }
24
+ const walletClient = await wallet.getWalletClient()
25
+ const connector = wallet.connector as DynamicWaasEVMConnector
26
+ return toAccount({
27
+ address: walletClient.account.address,
28
+ sign: ({ hash }) => {
29
+ return connector.signRawMessage({
30
+ accountAddress: walletClient.account.address,
31
+ message: hash.startsWith('0x') ? hash.slice(2) : hash,
32
+ })
33
+ },
34
+ signMessage: walletClient.signMessage,
35
+ signTransaction: walletClient.signTransaction,
36
+ signTypedData: walletClient.signTypedData,
37
+ })
38
+ }
@@ -0,0 +1,63 @@
1
+ import type { ConnectedWallet } from '@privy-io/react-auth'
2
+ import type { Address, LocalAccount } from 'viem'
3
+
4
+ import type { ChainManager } from '@/services/ChainManager.js'
5
+ import type { LendConfig, LendProvider } from '@/types/lend/index.js'
6
+ import { EOAWallet } from '@/wallet/core/wallets/eoa/EOAWallet.js'
7
+ import { createSigner } from '@/wallet/react/wallets/hosted/privy/utils/createSigner.js'
8
+
9
+ /**
10
+ * Privy wallet implementation
11
+ * @description Wallet implementation using Privy service
12
+ */
13
+ export class PrivyWallet extends EOAWallet {
14
+ public address!: Address
15
+ public signer!: LocalAccount
16
+
17
+ private readonly connectedWallet: ConnectedWallet
18
+
19
+ private constructor(
20
+ chainManager: ChainManager,
21
+ connectedWallet: ConnectedWallet,
22
+ lendProvider?: LendProvider<LendConfig>,
23
+ ) {
24
+ super(chainManager, lendProvider)
25
+ this.connectedWallet = connectedWallet
26
+ }
27
+
28
+ static async create(params: {
29
+ chainManager: ChainManager
30
+ connectedWallet: ConnectedWallet
31
+ lendProvider?: LendProvider<LendConfig>
32
+ }): Promise<PrivyWallet> {
33
+ const wallet = new PrivyWallet(
34
+ params.chainManager,
35
+ params.connectedWallet,
36
+ params.lendProvider,
37
+ )
38
+ await wallet.initialize()
39
+ return wallet
40
+ }
41
+
42
+ /**
43
+ * Initialize the PrivyWallet by creating the signer account
44
+ */
45
+ protected async performInitialization() {
46
+ this.signer = await this.createSigner()
47
+ this.address = this.signer.address
48
+ }
49
+
50
+ /**
51
+ * Create a LocalAccount from this Privy wallet
52
+ * @description Converts the Privy wallet into a viem-compatible LocalAccount that can sign
53
+ * messages and transactions. The returned account uses Privy's signing infrastructure
54
+ * under the hood while providing a standard viem interface.
55
+ * @returns Promise resolving to a LocalAccount configured for signing operations
56
+ * @throws Error if wallet retrieval fails or signing operations are not supported
57
+ */
58
+ private async createSigner(): Promise<LocalAccount> {
59
+ return createSigner({
60
+ connectedWallet: this.connectedWallet,
61
+ })
62
+ }
63
+ }
@@ -0,0 +1,22 @@
1
+ import type { ConnectedWallet } from '@privy-io/react-auth'
2
+ import { vi } from 'vitest'
3
+
4
+ import type { ChainManager } from '@/services/ChainManager.js'
5
+ import type { Wallet } from '@/wallet/core/wallets/abstract/Wallet.js'
6
+
7
+ /**
8
+ * Minimal mock for PrivyWallet used in React tests
9
+ * @description
10
+ * Provides a static `create` spy that returns a stubbed `Wallet`, avoiding
11
+ * browser-only dependencies. Use with `vi.mock` to replace the real module.
12
+ */
13
+ export class PrivyWalletMock {
14
+ static readonly create = vi.fn(
15
+ async (_params: {
16
+ chainManager: ChainManager
17
+ connectedWallet: ConnectedWallet
18
+ }): Promise<Wallet> => {
19
+ return {} as unknown as Wallet
20
+ },
21
+ )
22
+ }
@@ -0,0 +1,109 @@
1
+ import { type ConnectedWallet, toViemAccount } from '@privy-io/react-auth'
2
+ import type { Address, LocalAccount, WalletClient } from 'viem'
3
+ import { createWalletClient } from 'viem'
4
+ import { toAccount } from 'viem/accounts'
5
+ import { unichain } from 'viem/chains'
6
+ import { beforeEach, describe, expect, it, vi } from 'vitest'
7
+
8
+ import type { ChainManager } from '@/services/ChainManager.js'
9
+ import { MockChainManager } from '@/test/MockChainManager.js'
10
+ import { getRandomAddress } from '@/test/utils.js'
11
+ import { PrivyWallet } from '@/wallet/react/wallets/hosted/privy/PrivyWallet.js'
12
+
13
+ vi.mock('viem', async () => ({
14
+ // @ts-ignore - importActual returns unknown
15
+ ...(await vi.importActual('viem')),
16
+ createWalletClient: vi.fn(),
17
+ }))
18
+
19
+ vi.mock('viem/accounts', async () => ({
20
+ // @ts-ignore - importActual returns unknown
21
+ ...(await vi.importActual('viem/accounts')),
22
+ toAccount: vi.fn(),
23
+ }))
24
+
25
+ vi.mock('@privy-io/react-auth', () => ({
26
+ toViemAccount: vi.fn(),
27
+ }))
28
+
29
+ describe('PrivyWallet (React)', () => {
30
+ beforeEach(() => {
31
+ vi.clearAllMocks()
32
+ })
33
+ const mockAddress = getRandomAddress()
34
+ const mockChainManager = new MockChainManager({
35
+ supportedChains: [unichain.id],
36
+ }) as unknown as ChainManager
37
+ const mockLocalAccount = {
38
+ address: mockAddress,
39
+ signMessage: vi.fn(),
40
+ sign: vi.fn(),
41
+ signTransaction: vi.fn(),
42
+ signTypedData: vi.fn(),
43
+ } as unknown as LocalAccount
44
+
45
+ it('initializes signer and address from Privy viem account', async () => {
46
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
47
+ const mockViemAccount = {
48
+ address: mockAddress,
49
+ sign: vi.fn(),
50
+ signMessage: vi.fn(),
51
+ signTransaction: vi.fn(),
52
+ signTypedData: vi.fn(),
53
+ } as any
54
+ vi.mocked(toViemAccount).mockResolvedValue(mockViemAccount)
55
+ const connectedWallet = {
56
+ __brand: 'privy-connected-wallet',
57
+ } as unknown as ConnectedWallet
58
+
59
+ const wallet = await PrivyWallet.create({
60
+ connectedWallet: connectedWallet,
61
+ chainManager: mockChainManager,
62
+ })
63
+
64
+ expect(wallet.address).toBe(mockViemAccount.address)
65
+ expect(toViemAccount).toHaveBeenCalledWith({
66
+ wallet: connectedWallet,
67
+ })
68
+ expect(toAccount).toHaveBeenCalledWith({
69
+ address: mockAddress,
70
+ sign: mockViemAccount.sign,
71
+ signMessage: mockViemAccount.signMessage,
72
+ signTransaction: mockViemAccount.signTransaction,
73
+ signTypedData: mockViemAccount.signTypedData,
74
+ })
75
+ })
76
+
77
+ it('creates a WalletClient with correct configuration', async () => {
78
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
79
+ vi.mocked(toViemAccount).mockResolvedValue({
80
+ address: mockAddress,
81
+ sign: vi.fn(),
82
+ signMessage: vi.fn(),
83
+ signTransaction: vi.fn(),
84
+ signTypedData: vi.fn(),
85
+ } as any)
86
+ const connectedWallet = {
87
+ __brand: 'privy-connected-wallet',
88
+ } as unknown as ConnectedWallet
89
+ const wallet = await PrivyWallet.create({
90
+ connectedWallet: connectedWallet,
91
+ chainManager: mockChainManager,
92
+ })
93
+
94
+ const mockWalletClient = {
95
+ account: mockLocalAccount,
96
+ address: mockAddress as Address,
97
+ } as unknown as WalletClient
98
+
99
+ vi.mocked(createWalletClient).mockResolvedValue(mockWalletClient)
100
+
101
+ const walletClient = await wallet.walletClient(unichain.id)
102
+
103
+ expect(createWalletClient).toHaveBeenCalledOnce()
104
+ const args = vi.mocked(createWalletClient).mock.calls[0][0]
105
+ expect(args.account).toBe(mockLocalAccount)
106
+ expect(args.chain).toBe(mockChainManager.getChain(unichain.id))
107
+ expect(walletClient).toBe(mockWalletClient)
108
+ })
109
+ })
@@ -0,0 +1,66 @@
1
+ import type { ConnectedWallet } from '@privy-io/react-auth'
2
+ import { toViemAccount } from '@privy-io/react-auth'
3
+ import type { LocalAccount } from 'viem'
4
+ import { toAccount } from 'viem/accounts'
5
+ import { describe, expect, it, vi } from 'vitest'
6
+
7
+ import { getRandomAddress } from '@/test/utils.js'
8
+ import { createSigner } from '@/wallet/react/wallets/hosted/privy/utils/createSigner.js'
9
+
10
+ vi.mock('@privy-io/react-auth', async () => ({
11
+ // @ts-ignore - importActual returns unknown
12
+ ...(await vi.importActual('@privy-io/react-auth')),
13
+ toViemAccount: vi.fn(),
14
+ }))
15
+
16
+ vi.mock('viem/accounts', async () => ({
17
+ // @ts-ignore - importActual returns unknown
18
+ ...(await vi.importActual('viem/accounts')),
19
+ toAccount: vi.fn(),
20
+ }))
21
+
22
+ describe('createSigner', () => {
23
+ const mockAddress = getRandomAddress()
24
+
25
+ it('should create a LocalAccount with correct configuration', async () => {
26
+ const mockConnectedWallet = {
27
+ address: mockAddress,
28
+ walletClientType: 'privy',
29
+ } as unknown as ConnectedWallet
30
+
31
+ const mockPrivyViemAccount = {
32
+ address: mockAddress,
33
+ sign: vi.fn(),
34
+ signMessage: vi.fn(),
35
+ signTransaction: vi.fn(),
36
+ signTypedData: vi.fn(),
37
+ } as unknown as Awaited<ReturnType<typeof toViemAccount>>
38
+
39
+ const mockLocalAccount = {
40
+ address: mockAddress,
41
+ sign: vi.fn(),
42
+ signMessage: vi.fn(),
43
+ signTransaction: vi.fn(),
44
+ signTypedData: vi.fn(),
45
+ } as unknown as LocalAccount
46
+
47
+ vi.mocked(toViemAccount).mockResolvedValue(mockPrivyViemAccount)
48
+ vi.mocked(toAccount).mockReturnValue(mockLocalAccount)
49
+
50
+ const signer = await createSigner({
51
+ connectedWallet: mockConnectedWallet,
52
+ })
53
+
54
+ expect(toViemAccount).toHaveBeenCalledWith({
55
+ wallet: mockConnectedWallet,
56
+ })
57
+ expect(toAccount).toHaveBeenCalledWith({
58
+ address: mockPrivyViemAccount.address,
59
+ sign: mockPrivyViemAccount.sign,
60
+ signMessage: mockPrivyViemAccount.signMessage,
61
+ signTransaction: mockPrivyViemAccount.signTransaction,
62
+ signTypedData: mockPrivyViemAccount.signTypedData,
63
+ })
64
+ expect(signer).toBe(mockLocalAccount)
65
+ })
66
+ })
@@ -0,0 +1,30 @@
1
+ import { toViemAccount } from '@privy-io/react-auth'
2
+ import type { CustomSource, LocalAccount } from 'viem'
3
+ import { toAccount } from 'viem/accounts'
4
+
5
+ import type { PrivyHostedWalletToActionsWalletOptions } from '@/wallet/react/providers/hosted/types/index.js'
6
+
7
+ /**
8
+ * Create a LocalAccount from a Privy wallet
9
+ * @description Converts the Privy wallet into a viem-compatible LocalAccount that can sign
10
+ * messages and transactions. The returned account uses Privy's signing infrastructure
11
+ * under the hood while providing a standard viem interface.
12
+ * @param params.connectedWallet - Privy connected wallet
13
+ * @returns Promise resolving to a LocalAccount configured for signing operations
14
+ * @throws Error if wallet retrieval fails or signing operations are not supported
15
+ */
16
+ export async function createSigner(
17
+ params: PrivyHostedWalletToActionsWalletOptions,
18
+ ): Promise<LocalAccount> {
19
+ const privyViemAccount = await toViemAccount({
20
+ wallet: params.connectedWallet,
21
+ })
22
+ return toAccount({
23
+ address: privyViemAccount.address,
24
+ sign: privyViemAccount.sign,
25
+ signMessage: privyViemAccount.signMessage,
26
+ signTransaction: privyViemAccount.signTransaction,
27
+ signTypedData:
28
+ privyViemAccount.signTypedData as CustomSource['signTypedData'],
29
+ })
30
+ }
@@ -0,0 +1,94 @@
1
+ import type { TurnkeySDKClientBase } from '@turnkey/react-wallet-kit'
2
+ import type { Address, LocalAccount } from 'viem'
3
+
4
+ import type { ChainManager } from '@/services/ChainManager.js'
5
+ import type { LendConfig, LendProvider } from '@/types/lend/index.js'
6
+ import { EOAWallet } from '@/wallet/core/wallets/eoa/EOAWallet.js'
7
+ import { createSigner } from '@/wallet/react/wallets/hosted/turnkey/utils/createSigner.js'
8
+
9
+ /**
10
+ * Turnkey wallet implementation
11
+ * @description Wallet implementation using Turnkey service
12
+ */
13
+ export class TurnkeyWallet extends EOAWallet {
14
+ public address!: Address
15
+ public signer!: LocalAccount
16
+ /**
17
+ * Turnkey client instance
18
+ */
19
+ private readonly client: TurnkeySDKClientBase
20
+ /**
21
+ * Turnkey organization ID that owns the signing key
22
+ */
23
+ private readonly organizationId: string
24
+ /**
25
+ * This can be a wallet account address, private key address, or private key ID.
26
+ */
27
+ private readonly signWith: string
28
+ /**
29
+ * Ethereum address to use for this account, in the case that a private key ID is used to sign.
30
+ * If left undefined, `createSigner` will fetch it from the Turnkey API.
31
+ * We recommend setting this if you're using a passkey client, so that your users are not prompted for a passkey signature just to fetch their address.
32
+ * You may leave this undefined if using an API key client.
33
+ */
34
+ private readonly ethereumAddress?: string
35
+
36
+ private constructor(params: {
37
+ chainManager: ChainManager
38
+ client: TurnkeySDKClientBase
39
+ organizationId: string
40
+ signWith: string
41
+ ethereumAddress?: string
42
+ lendProvider?: LendProvider<LendConfig>
43
+ }) {
44
+ const {
45
+ chainManager,
46
+ client,
47
+ organizationId,
48
+ signWith,
49
+ ethereumAddress,
50
+ lendProvider,
51
+ } = params
52
+ super(chainManager, lendProvider)
53
+ this.client = client
54
+ this.organizationId = organizationId
55
+ this.signWith = signWith
56
+ this.ethereumAddress = ethereumAddress
57
+ }
58
+
59
+ static async create(params: {
60
+ chainManager: ChainManager
61
+ client: TurnkeySDKClientBase
62
+ organizationId: string
63
+ signWith: string
64
+ ethereumAddress?: string
65
+ lendProvider?: LendProvider<LendConfig>
66
+ }): Promise<TurnkeyWallet> {
67
+ const wallet = new TurnkeyWallet(params)
68
+ await wallet.initialize()
69
+ return wallet
70
+ }
71
+
72
+ protected async performInitialization() {
73
+ this.signer = await this.createSigner()
74
+ this.address = this.signer.address
75
+ }
76
+
77
+ /**
78
+ * Create a viem LocalAccount instance backed by Turnkey
79
+ * @description Wraps the Turnkey SDK's `createAccount` to produce a signing
80
+ * account compatible with viem. Under the hood, this uses the provided
81
+ * `client`, `organizationId`, and `signWith` to authenticate signing requests
82
+ * with Turnkey. If `ethereumAddress` is supplied, it's used directly;
83
+ * otherwise the SDK fetches it from the Turnkey API.
84
+ * @returns Promise resolving to a viem `LocalAccount` with Turnkey as the signer backend
85
+ */
86
+ private async createSigner(): Promise<LocalAccount> {
87
+ return createSigner({
88
+ client: this.client,
89
+ organizationId: this.organizationId,
90
+ signWith: this.signWith,
91
+ ethereumAddress: this.ethereumAddress,
92
+ })
93
+ }
94
+ }