@elizaos/plugin-wallet 2.0.0-beta.1 → 2.0.3-beta.6

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 (356) hide show
  1. package/README.md +70 -45
  2. package/auto-enable.ts +1 -1
  3. package/dist/actions/failure-codes.d.ts +12 -0
  4. package/dist/actions/index.d.ts +1 -0
  5. package/dist/analytics/birdeye/actions/wallet-search-address.d.ts +7 -0
  6. package/dist/analytics/birdeye/birdeye-task.d.ts +27 -0
  7. package/dist/analytics/birdeye/birdeye.d.ts +140 -0
  8. package/dist/analytics/birdeye/constants.d.ts +68 -0
  9. package/dist/analytics/birdeye/providers/agent-portfolio-provider.d.ts +8 -0
  10. package/dist/analytics/birdeye/providers/market.d.ts +18 -0
  11. package/dist/analytics/birdeye/providers/portfolio-factory.d.ts +10 -0
  12. package/dist/analytics/birdeye/providers/trending.d.ts +19 -0
  13. package/dist/analytics/birdeye/providers/wallet.d.ts +5 -0
  14. package/dist/analytics/birdeye/search-category.d.ts +52 -0
  15. package/dist/analytics/birdeye/service.d.ts +94 -0
  16. package/dist/analytics/birdeye/types/api/common.d.ts +199 -0
  17. package/dist/analytics/birdeye/types/api/defi.d.ts +187 -0
  18. package/dist/analytics/birdeye/types/api/pair.d.ts +182 -0
  19. package/dist/analytics/birdeye/types/api/search.d.ts +64 -0
  20. package/dist/analytics/birdeye/types/api/token.d.ts +580 -0
  21. package/dist/analytics/birdeye/types/api/trader.d.ts +70 -0
  22. package/dist/analytics/birdeye/types/api/wallet.d.ts +161 -0
  23. package/dist/analytics/birdeye/types/shared.d.ts +83 -0
  24. package/dist/analytics/birdeye/utils.d.ts +74 -0
  25. package/dist/analytics/dexscreener/errors.d.ts +2 -0
  26. package/dist/analytics/dexscreener/index.d.ts +3 -0
  27. package/dist/analytics/dexscreener/search-category.d.ts +3 -0
  28. package/dist/analytics/dexscreener/service.d.ts +34 -0
  29. package/dist/analytics/dexscreener/types.d.ts +131 -0
  30. package/dist/analytics/lpinfo/index.d.ts +31 -0
  31. package/dist/analytics/lpinfo/kamino/index.d.ts +7 -0
  32. package/dist/analytics/lpinfo/kamino/providers/kaminoLiquidityProvider.d.ts +6 -0
  33. package/dist/analytics/lpinfo/kamino/providers/kaminoPoolProvider.d.ts +6 -0
  34. package/dist/analytics/lpinfo/kamino/providers/kaminoProvider.d.ts +6 -0
  35. package/dist/analytics/lpinfo/kamino/services/kaminoLiquidityService.d.ts +203 -0
  36. package/dist/analytics/lpinfo/kamino/services/kaminoService.d.ts +171 -0
  37. package/dist/analytics/lpinfo/steer/index.d.ts +7 -0
  38. package/dist/analytics/lpinfo/steer/providers/steerLiquidityProvider.d.ts +6 -0
  39. package/dist/analytics/lpinfo/steer/services/steerLiquidityService.d.ts +208 -0
  40. package/dist/analytics/lpinfo/steer/steer-display-types.d.ts +97 -0
  41. package/dist/analytics/news/index.d.ts +32 -0
  42. package/dist/analytics/news/interfaces/types.d.ts +177 -0
  43. package/dist/analytics/news/providers/defiNewsProvider.d.ts +106 -0
  44. package/dist/analytics/news/services/newsDataService.d.ts +72 -0
  45. package/dist/analytics/news/utils/formatters.d.ts +54 -0
  46. package/dist/analytics/token-info/action.d.ts +6 -0
  47. package/dist/analytics/token-info/index.d.ts +3 -0
  48. package/dist/analytics/token-info/params.d.ts +10 -0
  49. package/dist/analytics/token-info/providers.d.ts +4 -0
  50. package/dist/analytics/token-info/service.d.ts +19 -0
  51. package/dist/analytics/token-info/types.d.ts +45 -0
  52. package/dist/api/wallet-routes.d.ts +100 -0
  53. package/dist/audit/audit-log.d.ts +29 -0
  54. package/dist/browser-shim/build-shim.d.ts +31 -0
  55. package/dist/browser-shim/index.d.ts +1 -0
  56. package/dist/chains/evm/actions/helpers.d.ts +31 -0
  57. package/dist/chains/evm/actions/swap.d.ts +53 -0
  58. package/dist/chains/evm/actions/transfer.d.ts +10 -0
  59. package/dist/chains/evm/bridge-router.d.ts +44 -0
  60. package/dist/chains/evm/build.d.ts +2 -0
  61. package/dist/chains/evm/chain-handler.d.ts +37 -0
  62. package/dist/chains/evm/constants.d.ts +16 -0
  63. package/dist/chains/evm/dex/aerodrome/index.d.ts +6 -0
  64. package/dist/chains/evm/dex/aerodrome/services/AerodromeLpService.d.ts +27 -0
  65. package/dist/chains/evm/dex/aerodrome/types.d.ts +435 -0
  66. package/dist/chains/evm/dex/pancakeswp/index.d.ts +6 -0
  67. package/dist/chains/evm/dex/pancakeswp/services/PancakeSwapV3LpService.d.ts +28 -0
  68. package/dist/chains/evm/dex/pancakeswp/types.d.ts +19 -0
  69. package/dist/chains/evm/dex/uniswap/index.d.ts +6 -0
  70. package/dist/chains/evm/dex/uniswap/services/UniswapV3LpService.d.ts +28 -0
  71. package/dist/chains/evm/dex/uniswap/types.d.ts +458 -0
  72. package/dist/chains/evm/generated/specs/spec-helpers.d.ts +35 -0
  73. package/dist/chains/evm/generated/specs/specs.d.ts +99 -0
  74. package/dist/chains/evm/gov-router.d.ts +6 -0
  75. package/dist/chains/evm/index.browser.d.ts +3 -0
  76. package/dist/chains/evm/index.d.ts +6 -0
  77. package/dist/chains/evm/prompts.d.ts +24 -0
  78. package/dist/chains/evm/providers/get-balance.d.ts +2 -0
  79. package/dist/chains/evm/providers/wallet.d.ts +35 -0
  80. package/dist/chains/evm/routes/sign.d.ts +13 -0
  81. package/dist/chains/evm/rpc-providers.d.ts +26 -0
  82. package/dist/chains/evm/service.d.ts +26 -0
  83. package/dist/chains/evm/templates/index.d.ts +1 -0
  84. package/dist/chains/evm/types/index.d.ts +296 -0
  85. package/dist/chains/evm/vitest.config.d.ts +2 -0
  86. package/dist/chains/registry.d.ts +3 -0
  87. package/dist/chains/solana/actions/confirmation.d.ts +9 -0
  88. package/dist/chains/solana/bn.d.ts +6 -0
  89. package/dist/chains/solana/build.d.ts +2 -0
  90. package/dist/chains/solana/constants.d.ts +2 -0
  91. package/dist/chains/solana/dex/meteora/e2e/scenarios.d.ts +10 -0
  92. package/dist/chains/solana/dex/meteora/e2e/test-utils.d.ts +28 -0
  93. package/dist/chains/solana/dex/meteora/index.d.ts +3 -0
  94. package/dist/chains/solana/dex/meteora/providers/positionProvider.d.ts +9 -0
  95. package/dist/chains/solana/dex/meteora/services/MeteoraLpService.d.ts +37 -0
  96. package/dist/chains/solana/dex/meteora/utils/dlmm.d.ts +6 -0
  97. package/dist/chains/solana/dex/meteora/utils/loadWallet.d.ts +14 -0
  98. package/dist/chains/solana/dex/meteora/utils/sendTransaction.d.ts +2 -0
  99. package/dist/chains/solana/dex/orca/index.d.ts +6 -0
  100. package/dist/chains/solana/dex/orca/providers/positionProvider.d.ts +10 -0
  101. package/dist/chains/solana/dex/orca/services/srv_orca.d.ts +10 -0
  102. package/dist/chains/solana/dex/orca/types.d.ts +61 -0
  103. package/dist/chains/solana/dex/orca/utils/loadWallet.d.ts +1 -0
  104. package/dist/chains/solana/dex/orca/utils/sendTransaction.d.ts +2 -0
  105. package/dist/chains/solana/dex/raydium/index.d.ts +6 -0
  106. package/dist/chains/solana/dex/raydium/providers/positionProvider.d.ts +10 -0
  107. package/dist/chains/solana/dex/raydium/services/srv_raydium.d.ts +104 -0
  108. package/dist/chains/solana/dex/raydium/types.d.ts +42 -0
  109. package/dist/chains/solana/environment.d.ts +15 -0
  110. package/dist/chains/solana/generated/specs/spec-helpers.d.ts +35 -0
  111. package/dist/chains/solana/generated/specs/specs.d.ts +73 -0
  112. package/dist/chains/solana/index.browser.d.ts +3 -0
  113. package/dist/chains/solana/index.d.ts +7 -0
  114. package/dist/chains/solana/keypairUtils.d.ts +7 -0
  115. package/dist/chains/solana/prompts.d.ts +12 -0
  116. package/dist/chains/solana/providers/wallet.d.ts +2 -0
  117. package/dist/chains/solana/routes/index.d.ts +2 -0
  118. package/dist/chains/solana/routes/sign.d.ts +16 -0
  119. package/dist/chains/solana/service.d.ts +237 -0
  120. package/dist/chains/solana/types.d.ts +377 -0
  121. package/dist/chains/solana/vitest.config.d.ts +2 -0
  122. package/dist/chains/wallet-action.d.ts +3 -0
  123. package/dist/contracts.d.ts +58 -0
  124. package/dist/core-augmentation.d.ts +9 -0
  125. package/dist/index.d.mts +27 -34727
  126. package/dist/index.d.ts +27 -0
  127. package/dist/index.mjs +28246 -21186
  128. package/dist/index.mjs.map +153 -0
  129. package/dist/lib/server-wallet-trade.d.ts +22 -0
  130. package/dist/lib/server-wallet-trade.js +333 -0
  131. package/dist/lib/server-wallet-trade.js.map +11 -0
  132. package/dist/lib/wallet-export-guard.d.ts +45 -0
  133. package/dist/lp/actions/liquidity.d.ts +2 -0
  134. package/dist/lp/e2e/real-token-tests.d.ts +6 -0
  135. package/dist/lp/e2e/scenarios.d.ts +9 -0
  136. package/dist/lp/e2e/test-utils.d.ts +28 -0
  137. package/dist/lp/lp-manager-entry.d.ts +18 -0
  138. package/dist/lp/services/ConcentratedLiquidityService.d.ts +32 -0
  139. package/dist/lp/services/DexInteractionService.d.ts +34 -0
  140. package/dist/lp/services/LpManagementService.d.ts +116 -0
  141. package/dist/lp/services/UserLpProfileService.d.ts +18 -0
  142. package/dist/lp/services/VaultService.d.ts +21 -0
  143. package/dist/lp/services/YieldOptimizationService.d.ts +59 -0
  144. package/dist/lp/services/__tests__/MockLpService.d.ts +17 -0
  145. package/dist/lp/types.d.ts +439 -0
  146. package/dist/lp/utils/solanaClient.d.ts +26 -0
  147. package/dist/plugin.d.ts +7 -0
  148. package/dist/policy/policy.d.ts +14 -0
  149. package/dist/providers/canonical-provider.d.ts +19 -0
  150. package/dist/providers/wallet-provider.d.ts +5 -0
  151. package/dist/register-routes.d.ts +1 -0
  152. package/dist/routes/plugin.d.ts +14 -0
  153. package/dist/routes/wallet-market-overview-route.d.ts +7 -0
  154. package/dist/sdk/abi.d.ts +396 -0
  155. package/dist/sdk/bridge/abis.d.ts +63 -0
  156. package/dist/sdk/bridge/client.d.ts +48 -0
  157. package/dist/sdk/bridge/index.d.ts +14 -0
  158. package/dist/sdk/bridge/solana.d.ts +131 -0
  159. package/dist/sdk/bridge/types.d.ts +92 -0
  160. package/dist/sdk/convenience.d.ts +104 -0
  161. package/dist/sdk/escrow/MutualStakeEscrow.d.ts +75 -0
  162. package/dist/sdk/escrow/types.d.ts +58 -0
  163. package/dist/sdk/escrow/verifiers.d.ts +25 -0
  164. package/dist/sdk/identity/erc8004.d.ts +304 -0
  165. package/dist/sdk/identity/reputation.d.ts +317 -0
  166. package/dist/sdk/identity/uaid.d.ts +192 -0
  167. package/dist/sdk/identity/validation.d.ts +282 -0
  168. package/dist/sdk/index.d.ts +133 -0
  169. package/dist/sdk/index.js +5284 -0
  170. package/dist/sdk/index.js.map +40 -0
  171. package/dist/sdk/policy/SpendingPolicy.d.ts +105 -0
  172. package/dist/sdk/policy/UptoBillingPolicy.d.ts +87 -0
  173. package/dist/sdk/router/PaymentRouter.d.ts +77 -0
  174. package/dist/sdk/router/index.d.ts +2 -0
  175. package/dist/sdk/swap/SwapModule.d.ts +47 -0
  176. package/dist/sdk/swap/abi.d.ts +50 -0
  177. package/dist/sdk/swap/index.d.ts +11 -0
  178. package/dist/sdk/swap/types.d.ts +101 -0
  179. package/dist/sdk/tokens/decimals.d.ts +64 -0
  180. package/dist/sdk/tokens/registry.d.ts +81 -0
  181. package/dist/sdk/tokens/solana.d.ts +107 -0
  182. package/dist/sdk/tokens/transfers.d.ts +94 -0
  183. package/dist/sdk/types.d.ts +129 -0
  184. package/dist/sdk/wallet-core.d.ts +29450 -0
  185. package/dist/sdk/x402/budget.d.ts +51 -0
  186. package/dist/sdk/x402/chains/abstract/index.d.ts +134 -0
  187. package/dist/sdk/x402/client.d.ts +66 -0
  188. package/dist/sdk/x402/index.d.ts +8 -0
  189. package/dist/sdk/x402/middleware.d.ts +37 -0
  190. package/dist/sdk/x402/multi-asset.d.ts +53 -0
  191. package/dist/sdk/x402/types.d.ts +109 -0
  192. package/dist/security/wallet-context-safety.d.ts +7 -0
  193. package/dist/security/wallet-financial-confirmation.d.ts +23 -0
  194. package/dist/services/wallet-backend-service.d.ts +39 -0
  195. package/dist/types/wallet-router.d.ts +130 -0
  196. package/dist/utils/intent-trajectory.d.ts +34 -0
  197. package/dist/wallet/backend.d.ts +41 -0
  198. package/dist/wallet/errors.d.ts +17 -0
  199. package/dist/wallet/index.d.ts +6 -0
  200. package/dist/wallet/local-eoa-backend.d.ts +37 -0
  201. package/dist/wallet/pending.d.ts +47 -0
  202. package/dist/wallet/select-backend.d.ts +11 -0
  203. package/dist/wallet/steward-backend.d.ts +22 -0
  204. package/dist/wallet-action.d.ts +1 -0
  205. package/dist/wallet-action.js +6292 -0
  206. package/dist/wallet-action.js.map +44 -0
  207. package/package.json +35 -21
  208. package/registry-entry.json +134 -0
  209. package/src/analytics/birdeye/actions/wallet-search-address.ts +85 -5
  210. package/src/analytics/birdeye/birdeye-task.ts +25 -9
  211. package/src/analytics/birdeye/birdeye.ts +6 -7
  212. package/src/analytics/birdeye/constants.ts +0 -1
  213. package/src/analytics/birdeye/providers/agent-portfolio-provider.ts +0 -1
  214. package/src/analytics/birdeye/providers/market.ts +51 -45
  215. package/src/analytics/birdeye/providers/portfolio-factory.ts +79 -38
  216. package/src/analytics/birdeye/providers/trending.ts +43 -46
  217. package/src/analytics/birdeye/providers/wallet.ts +0 -1
  218. package/src/analytics/birdeye/search-category.test.ts +1 -1
  219. package/src/analytics/birdeye/search-category.ts +77 -12
  220. package/src/analytics/birdeye/service.test.ts +146 -0
  221. package/src/analytics/birdeye/service.ts +220 -105
  222. package/src/analytics/birdeye/types/api/common.ts +0 -1
  223. package/src/analytics/birdeye/types/api/defi.ts +0 -1
  224. package/src/analytics/birdeye/types/api/pair.ts +0 -1
  225. package/src/analytics/birdeye/types/api/search.ts +0 -1
  226. package/src/analytics/birdeye/types/api/token.ts +0 -1
  227. package/src/analytics/birdeye/types/api/trader.ts +0 -1
  228. package/src/analytics/birdeye/types/api/wallet.ts +0 -1
  229. package/src/analytics/birdeye/types/shared.ts +0 -11
  230. package/src/analytics/birdeye/utils.test.ts +69 -0
  231. package/src/analytics/birdeye/utils.ts +11 -8
  232. package/src/analytics/dexscreener/search-category.ts +0 -1
  233. package/src/analytics/dexscreener/service.ts +7 -12
  234. package/src/analytics/dexscreener/types.ts +0 -1
  235. package/src/analytics/lpinfo/index.ts +5 -2
  236. package/src/analytics/lpinfo/kamino/README.md +2 -2
  237. package/src/analytics/lpinfo/kamino/index.ts +9 -2
  238. package/src/analytics/lpinfo/kamino/providers/kaminoLiquidityProvider.ts +6 -26
  239. package/src/analytics/lpinfo/kamino/providers/kaminoPoolProvider.ts +11 -12
  240. package/src/analytics/lpinfo/kamino/providers/kaminoProvider.ts +76 -32
  241. package/src/analytics/lpinfo/kamino/services/kaminoLiquidityService.ts +78 -38
  242. package/src/analytics/lpinfo/kamino/services/kaminoService.ts +71 -31
  243. package/src/analytics/lpinfo/steer/index.ts +7 -2
  244. package/src/analytics/lpinfo/steer/providers/steerLiquidityProvider.ts +25 -26
  245. package/src/analytics/lpinfo/steer/services/steerLiquidityService.ts +367 -149
  246. package/src/analytics/news/index.ts +7 -2
  247. package/src/analytics/news/interfaces/types.ts +0 -1
  248. package/src/analytics/news/providers/defiNewsProvider.ts +17 -44
  249. package/src/analytics/news/services/newsDataService.ts +1 -22
  250. package/src/analytics/news/utils/formatters.test.ts +60 -0
  251. package/src/analytics/news/utils/formatters.ts +0 -1
  252. package/src/analytics/token-info/action.ts +52 -212
  253. package/src/analytics/token-info/index.ts +1 -1
  254. package/src/analytics/token-info/params.test.ts +69 -0
  255. package/src/analytics/token-info/params.ts +13 -11
  256. package/src/analytics/token-info/providers.ts +46 -17
  257. package/src/analytics/token-info/service.ts +3 -3
  258. package/src/analytics/token-info/types.ts +2 -2
  259. package/src/api/wallet-routes.test.ts +56 -0
  260. package/src/api/wallet-routes.ts +1728 -0
  261. package/src/audit/audit-log.ts +57 -2
  262. package/src/browser-shim/build-shim.ts +1 -1
  263. package/src/browser-shim/shim.template.js +107 -117
  264. package/src/chains/{wallet-router.test.ts → __tests__/wallet-router.test.ts} +57 -10
  265. package/src/chains/evm/actions/helpers.ts +9 -7
  266. package/src/chains/evm/actions/swap.ts +176 -22
  267. package/src/chains/evm/actions/transfer.ts +29 -22
  268. package/src/chains/evm/biome.json +1 -1
  269. package/src/chains/evm/build.ts +6 -1
  270. package/src/chains/evm/constants.ts +19 -0
  271. package/src/chains/evm/contracts/artifacts/OZGovernor.json +25 -1682
  272. package/src/chains/evm/dex/aerodrome/index.ts +6 -1
  273. package/src/chains/evm/dex/aerodrome/services/AerodromeLpService.ts +41 -15
  274. package/src/chains/evm/dex/aerodrome/types.ts +1 -2
  275. package/src/chains/evm/dex/pancakeswp/index.ts +6 -1
  276. package/src/chains/evm/dex/pancakeswp/services/PancakeSwapV3LpService.ts +54 -17
  277. package/src/chains/evm/dex/pancakeswp/types.ts +1 -2
  278. package/src/chains/evm/dex/uniswap/index.ts +6 -1
  279. package/src/chains/evm/dex/uniswap/services/UniswapV3LpService.ts +20 -9
  280. package/src/chains/evm/dex/uniswap/types.ts +1 -2
  281. package/src/chains/evm/gov-router.ts +3 -1
  282. package/src/chains/evm/index.browser.ts +1 -1
  283. package/src/chains/evm/index.ts +5 -1
  284. package/src/chains/evm/prompts.ts +5 -0
  285. package/src/chains/evm/providers/get-balance.ts +1 -1
  286. package/src/chains/evm/providers/wallet.ts +80 -9
  287. package/src/chains/evm/routes/sign.ts +35 -26
  288. package/src/chains/evm/rpc-providers.ts +1 -1
  289. package/src/chains/evm/types/index.ts +22 -2
  290. package/src/chains/registry.ts +1 -1
  291. package/src/chains/wallet-action.ts +301 -91
  292. package/src/index.ts +9 -5
  293. package/src/lib/wallet-export-guard.test.ts +233 -0
  294. package/src/lib/wallet-export-guard.ts +1 -1
  295. package/src/lp/actions/liquidity.ts +53 -26
  296. package/src/lp/e2e/real-token-tests.ts +0 -1
  297. package/src/lp/e2e/scenarios.ts +1 -2
  298. package/src/lp/e2e/test-utils.ts +20 -7
  299. package/src/lp/lp-manager-entry.ts +2 -5
  300. package/src/lp/services/ConcentratedLiquidityService.ts +3 -10
  301. package/src/lp/services/DexInteractionService.ts +1 -2
  302. package/src/lp/services/LpManagementService.test.ts +0 -1
  303. package/src/lp/services/LpManagementService.ts +75 -35
  304. package/src/lp/services/UserLpProfileService.ts +2 -3
  305. package/src/lp/services/VaultService.ts +10 -4
  306. package/src/lp/services/YieldOptimizationService.ts +29 -13
  307. package/src/lp/services/__tests__/MockLpService.ts +1 -2
  308. package/src/lp/types.ts +9 -13
  309. package/src/lp/utils/solanaClient.ts +4 -2
  310. package/src/plugin.routes.test.ts +24 -0
  311. package/src/plugin.ts +30 -13
  312. package/src/providers/canonical-provider.ts +1 -1
  313. package/src/providers/{unified-wallet-provider.ts → wallet-provider.ts} +3 -3
  314. package/src/routes/__fixtures__/coingecko-markets.recorded.json +97 -0
  315. package/src/routes/wallet-market-overview-route.ts +1 -1
  316. package/src/routes/wallet-market-overview.contract.test.ts +139 -0
  317. package/src/routes/wallet-market-overview.real.test.ts +83 -0
  318. package/src/sdk/escrow/MutualStakeEscrow.ts +1 -2
  319. package/src/sdk/identity/erc8004.ts +1 -1
  320. package/src/sdk/identity/validation.ts +3 -4
  321. package/src/sdk/index.ts +2 -2
  322. package/src/sdk/policy/SpendingPolicy.ts +1 -1
  323. package/src/sdk/router/PaymentRouter.ts +8 -11
  324. package/src/sdk/swap/SwapModule.ts +1 -1
  325. package/src/sdk/tokens/registry.ts +1 -1
  326. package/src/sdk/x402/middleware.ts +2 -8
  327. package/src/security/__tests__/wallet-context-safety.test.ts +79 -0
  328. package/src/security/__tests__/wallet-financial-confirmation.test.ts +88 -0
  329. package/src/security/wallet-context-safety.ts +128 -0
  330. package/src/security/wallet-financial-confirmation.ts +150 -0
  331. package/src/services/wallet-backend-service.ts +15 -1
  332. package/src/utils/intent-trajectory.ts +2 -2
  333. package/src/wallet/steward-backend.ts +4 -4
  334. package/dist/LpManagementService-BWrQ5-cO.mjs +0 -353
  335. package/dist/MockLpService-D_Apn4Fd.mjs +0 -99
  336. package/dist/aerodrome-CfnESC32.mjs +0 -890
  337. package/dist/chunk-hT5z_Zn9.mjs +0 -35
  338. package/dist/lib/server-wallet-trade.d.mts +0 -34
  339. package/dist/lib/server-wallet-trade.mjs +0 -306
  340. package/dist/meteora-BPX39hZo.mjs +0 -22640
  341. package/dist/orca-Bybp1HXO.mjs +0 -249
  342. package/dist/pancakeswp-CkEXlXti.mjs +0 -604
  343. package/dist/plugin-ZO_MTyd0.mjs +0 -529
  344. package/dist/raydium-rfaM9yEf.mjs +0 -539
  345. package/dist/sdk/index.d.mts +0 -32492
  346. package/dist/sdk/index.mjs +0 -6415
  347. package/dist/types-D5252NZk.mjs +0 -487
  348. package/dist/uniswap-CReXgXVN.mjs +0 -573
  349. package/dist/wallet-action.d.mts +0 -6
  350. package/dist/wallet-action.mjs +0 -820
  351. package/src/analytics/birdeye/tasks/birdeye.ts +0 -232
  352. package/src/analytics/lpinfo/index.d.ts +0 -7
  353. package/src/chains/evm/contracts/artifacts/TimelockController.json +0 -1007
  354. package/src/chains/evm/contracts/artifacts/VoteToken.json +0 -895
  355. package/src/lp/tasks/LpAutoRebalanceTask.ts +0 -117
  356. package/src/lp/tasks/__tests__/LpAutoRebalanceTask.test.ts +0 -370
@@ -1,117 +0,0 @@
1
- // @ts-nocheck — legacy code from absorbed plugins (lp-manager, lpinfo, dexscreener, defi-news, birdeye); strict types pending cleanup
2
- import { type IAgentRuntime, logger } from "@elizaos/core";
3
-
4
- /**
5
- * LpAutoRebalanceTask - Automated task for rebalancing LP positions
6
- *
7
- * This task monitors LP positions and triggers rebalancing when positions
8
- * drift outside acceptable ranges.
9
- */
10
- export class LpAutoRebalanceTask {
11
- private runtime: IAgentRuntime | null = null;
12
- private intervalId: ReturnType<typeof setInterval> | null = null;
13
- private isRunning = false;
14
-
15
- // Configuration
16
- private checkIntervalMs = 60000; // Default: check every minute
17
- private rebalanceThresholdBps = 500; // Default: 5% drift threshold
18
-
19
- constructor(config?: {
20
- checkIntervalMs?: number;
21
- rebalanceThresholdBps?: number;
22
- }) {
23
- if (config?.checkIntervalMs) {
24
- this.checkIntervalMs = config.checkIntervalMs;
25
- }
26
- if (config?.rebalanceThresholdBps) {
27
- this.rebalanceThresholdBps = config.rebalanceThresholdBps;
28
- }
29
- }
30
-
31
- /**
32
- * Start the auto-rebalance task
33
- */
34
- async start(runtime: IAgentRuntime): Promise<void> {
35
- if (this.isRunning) {
36
- logger.warn("[LpAutoRebalanceTask] Task is already running");
37
- return;
38
- }
39
-
40
- this.runtime = runtime;
41
- this.isRunning = true;
42
-
43
- logger.info(
44
- `[LpAutoRebalanceTask] Starting with interval ${this.checkIntervalMs}ms and threshold ${this.rebalanceThresholdBps}bps`,
45
- );
46
-
47
- // Run initial check
48
- await this.checkAndRebalance();
49
-
50
- // Set up periodic checks
51
- this.intervalId = setInterval(async () => {
52
- await this.checkAndRebalance();
53
- }, this.checkIntervalMs);
54
- }
55
-
56
- /**
57
- * Stop the auto-rebalance task
58
- */
59
- stop(): void {
60
- if (this.intervalId) {
61
- clearInterval(this.intervalId);
62
- this.intervalId = null;
63
- }
64
- this.isRunning = false;
65
- logger.info("[LpAutoRebalanceTask] Stopped");
66
- }
67
-
68
- /**
69
- * Check positions and rebalance if needed
70
- */
71
- private async checkAndRebalance(): Promise<void> {
72
- if (!this.runtime) {
73
- logger.error("[LpAutoRebalanceTask] Runtime not initialized");
74
- return;
75
- }
76
-
77
- try {
78
- logger.debug("[LpAutoRebalanceTask] Checking positions...");
79
-
80
- // Get DexInteractionService to check positions
81
- const dexService = this.runtime.getService("dex-interaction");
82
- if (!dexService) {
83
- logger.debug(
84
- "[LpAutoRebalanceTask] DexInteractionService not available",
85
- );
86
- return;
87
- }
88
-
89
- // The actual rebalancing logic would be implemented here
90
- // This is a placeholder that can be extended with real DEX integration
91
- logger.debug("[LpAutoRebalanceTask] Position check complete");
92
- } catch (error: unknown) {
93
- logger.error(
94
- "[LpAutoRebalanceTask] Error checking positions:",
95
- error instanceof Error ? error.message : String(error),
96
- );
97
- }
98
- }
99
-
100
- /**
101
- * Get current status of the task
102
- */
103
- getStatus(): {
104
- isRunning: boolean;
105
- checkIntervalMs: number;
106
- rebalanceThresholdBps: number;
107
- } {
108
- return {
109
- isRunning: this.isRunning,
110
- checkIntervalMs: this.checkIntervalMs,
111
- rebalanceThresholdBps: this.rebalanceThresholdBps,
112
- };
113
- }
114
- }
115
-
116
- // Export a default instance for convenience
117
- export const lpAutoRebalanceTask = new LpAutoRebalanceTask();
@@ -1,370 +0,0 @@
1
- // @ts-nocheck — legacy code from absorbed plugins (lp-manager, lpinfo, dexscreener, defi-news, birdeye); strict types pending cleanup
2
- /// <reference types="vitest/globals" />
3
- import type { IAgentRuntime } from "@elizaos/core";
4
- import { Keypair as SolanaKeypair } from "@solana/web3.js";
5
- import {
6
- beforeEach,
7
- describe,
8
- expect,
9
- it,
10
- type Mock,
11
- type Mocked,
12
- vi,
13
- } from "vitest";
14
- import type {
15
- IDexInteractionService,
16
- IUserLpProfileService,
17
- IVaultService,
18
- IYieldOptimizationService,
19
- LpPositionDetails,
20
- OptimizationOpportunity,
21
- PoolInfo,
22
- TokenBalance,
23
- TransactionResult,
24
- UserLpProfile,
25
- } from "../../types.ts";
26
- import { LpAutoRebalanceTask } from "../LpAutoRebalanceTask.ts";
27
-
28
- // Extended transaction results (matching the types in LpAutoRebalanceTask)
29
- interface RemoveLiquidityResult extends TransactionResult {
30
- tokensReceived?: TokenBalance[];
31
- }
32
-
33
- interface AddLiquidityResult extends TransactionResult {
34
- lpTokensReceived?: TokenBalance;
35
- }
36
-
37
- // Create a mock runtime with getService method
38
- const createMockRuntime = (services: Record<string, any>): IAgentRuntime => {
39
- return {
40
- getService: vi.fn((serviceName: string) => services[serviceName]),
41
- } as any as IAgentRuntime;
42
- };
43
-
44
- const mockUserLpProfileService: Mocked<IUserLpProfileService> = {
45
- ensureProfile: vi.fn(),
46
- getProfile: vi.fn(),
47
- updateProfile: vi.fn(),
48
- addTrackedPosition: vi.fn(),
49
- removeTrackedPosition: vi.fn(),
50
- getTrackedPositions: vi.fn(),
51
- getAllProfilesWithAutoRebalanceEnabled: vi.fn(),
52
- start: vi.fn(),
53
- stop: vi.fn(),
54
- capabilityDescription: "Mock UserLpProfileService",
55
- } as any;
56
-
57
- const mockDexInteractionService: Mocked<IDexInteractionService> = {
58
- registerDexService: vi.fn(),
59
- getPools: vi.fn(),
60
- addLiquidity: vi.fn(),
61
- removeLiquidity: vi.fn(),
62
- getLpPosition: vi.fn(),
63
- getAllUserLpPositions: vi.fn(),
64
- start: vi.fn(),
65
- stop: vi.fn(),
66
- capabilityDescription: "Mock DexInteractionService",
67
- } as any;
68
-
69
- const mockYieldOptimizationService: Mocked<IYieldOptimizationService> = {
70
- fetchAllPoolData: vi.fn(),
71
- findBestYieldOpportunities: vi.fn(),
72
- calculateRebalanceCost: vi.fn(),
73
- findBestYield: vi.fn(),
74
- start: vi.fn(),
75
- stop: vi.fn(),
76
- capabilityDescription: "Mock YieldOptimizationService",
77
- } as any;
78
-
79
- const mockVaultService: Mocked<IVaultService> = {
80
- createVault: vi.fn(),
81
- getVaultKeypair: vi.fn(),
82
- getVaultPublicKey: vi.fn(),
83
- getBalances: vi.fn(),
84
- exportPrivateKey: vi.fn(),
85
- start: vi.fn(),
86
- stop: vi.fn(),
87
- capabilityDescription: "Mock VaultService",
88
- } as any;
89
-
90
- const testUserKeypair = SolanaKeypair.generate();
91
-
92
- const testUserId1 = "rebalanceUser1";
93
- const testUserProfile1: UserLpProfile = {
94
- userId: testUserId1,
95
- vaultPublicKey: testUserKeypair.publicKey.toBase58(),
96
- encryptedSecretKey: "key1",
97
- autoRebalanceConfig: {
98
- enabled: true,
99
- minGainThresholdPercent: 1,
100
- maxSlippageBps: 50,
101
- preferredDexes: ["meteora"],
102
- },
103
- version: 1,
104
- createdAt: "now",
105
- updatedAt: "now",
106
- trackedPositions: [],
107
- };
108
-
109
- // Updated Mock Data with correct property names
110
- const SOL_MINT = "So11111111111111111111111111111111111111112";
111
- const USDC_MINT = "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v";
112
-
113
- const testLpPosition1: LpPositionDetails = {
114
- poolId: "currentPool1",
115
- dex: "orca",
116
- valueUsd: 1000,
117
- lpTokenBalance: {
118
- address: "lpMint1",
119
- balance: "100",
120
- decimals: 6,
121
- symbol: "ORCA_LP_SOL_USDC",
122
- uiAmount: 0.0001,
123
- },
124
- underlyingTokens: [
125
- {
126
- address: SOL_MINT,
127
- balance: "10",
128
- decimals: 9,
129
- symbol: "SOL",
130
- uiAmount: 0.00000001,
131
- },
132
- {
133
- address: USDC_MINT,
134
- balance: "500",
135
- decimals: 6,
136
- symbol: "USDC",
137
- uiAmount: 0.0005,
138
- },
139
- ],
140
- };
141
-
142
- const targetPool1: PoolInfo = {
143
- id: "targetPoolGood",
144
- dex: "meteora",
145
- tokenA: { mint: SOL_MINT, symbol: "SOL", decimals: 9 },
146
- tokenB: { mint: USDC_MINT, symbol: "USDC", decimals: 6 },
147
- apr: 0.25,
148
- displayName: "Good Yield Pool (SOL/USDC)",
149
- };
150
-
151
- const goodOpportunity: OptimizationOpportunity = {
152
- sourcePosition: testLpPosition1,
153
- targetPool: targetPool1,
154
- estimatedNewYield: 25,
155
- currentYield: 10,
156
- netGainPercent: 5,
157
- actions: ["Withdraw from orca", "Deposit to meteora"],
158
- estimatedCostToMoveLamports: "5000",
159
- };
160
-
161
- describe("LpAutoRebalanceTask", () => {
162
- let task: LpAutoRebalanceTask;
163
- let mockRuntime: IAgentRuntime;
164
-
165
- beforeEach(async () => {
166
- vi.clearAllMocks();
167
-
168
- // Create mock runtime with services
169
- mockRuntime = createMockRuntime({
170
- UserLpProfileService: mockUserLpProfileService,
171
- "dex-interaction": mockDexInteractionService,
172
- YieldOptimizationService: mockYieldOptimizationService,
173
- VaultService: mockVaultService,
174
- });
175
-
176
- // Create task and initialize it
177
- task = new LpAutoRebalanceTask();
178
- await task.onReady(mockRuntime);
179
-
180
- // Setup default mock behaviors
181
- (
182
- mockUserLpProfileService.getAllProfilesWithAutoRebalanceEnabled as Mock
183
- ).mockResolvedValue([testUserProfile1]);
184
- (mockDexInteractionService.getAllUserLpPositions as Mock).mockResolvedValue(
185
- [testLpPosition1],
186
- );
187
- (
188
- mockYieldOptimizationService.findBestYieldOpportunities as Mock
189
- ).mockResolvedValue([goodOpportunity]);
190
- (mockVaultService.getVaultKeypair as Mock).mockImplementation(
191
- async (userId, secret) => {
192
- if (
193
- userId === testUserId1 &&
194
- secret === testUserProfile1.encryptedSecretKey
195
- ) {
196
- return testUserKeypair;
197
- }
198
- console.error(
199
- `MockVaultService.getVaultKeypair called with unexpected args: userId=${userId}, secret=${secret}`,
200
- );
201
- return null;
202
- },
203
- );
204
-
205
- const removeResult: RemoveLiquidityResult = {
206
- success: true,
207
- tokensReceived: testLpPosition1.underlyingTokens,
208
- };
209
- (mockDexInteractionService.removeLiquidity as Mock).mockResolvedValue(
210
- removeResult,
211
- );
212
-
213
- const addResult: AddLiquidityResult = {
214
- success: true,
215
- transactionId: "txAddLiq",
216
- };
217
- (mockDexInteractionService.addLiquidity as Mock).mockResolvedValue(
218
- addResult,
219
- );
220
- });
221
-
222
- describe("execute", () => {
223
- it("should fetch enabled profiles and process them", async () => {
224
- await task.execute();
225
- expect(
226
- mockUserLpProfileService.getAllProfilesWithAutoRebalanceEnabled,
227
- ).toHaveBeenCalled();
228
- expect(
229
- mockYieldOptimizationService.findBestYieldOpportunities,
230
- ).toHaveBeenCalledWith(testUserId1, [testLpPosition1], []);
231
- });
232
-
233
- it("should handle errors when processing a user profile", async () => {
234
- const userProfile2 = { ...testUserProfile1, userId: "rebalanceUser2" };
235
- (
236
- mockUserLpProfileService.getAllProfilesWithAutoRebalanceEnabled as Mock
237
- ).mockResolvedValue([testUserProfile1, userProfile2]);
238
- (mockDexInteractionService.getAllUserLpPositions as Mock)
239
- .mockRejectedValueOnce(new Error("Failed to get positions for user1"))
240
- .mockResolvedValueOnce([]); // For user2, no positions
241
-
242
- await task.execute();
243
- // Should continue processing other users despite error
244
- expect(
245
- mockDexInteractionService.getAllUserLpPositions,
246
- ).toHaveBeenCalledTimes(2);
247
- });
248
- });
249
-
250
- describe("processUserProfile", () => {
251
- it("should execute rebalance if a good opportunity is found and meets criteria", async () => {
252
- // The task should find opportunities and execute rebalance
253
- await task.execute();
254
-
255
- expect(
256
- mockYieldOptimizationService.findBestYieldOpportunities,
257
- ).toHaveBeenCalledWith(testUserProfile1.userId, [testLpPosition1], []);
258
- expect(mockVaultService.getVaultKeypair).toHaveBeenCalledWith(
259
- testUserProfile1.userId,
260
- testUserProfile1.encryptedSecretKey,
261
- );
262
- expect(mockDexInteractionService.removeLiquidity).toHaveBeenCalledTimes(
263
- 1,
264
- );
265
- expect(mockDexInteractionService.addLiquidity).toHaveBeenCalledTimes(1);
266
- });
267
-
268
- it("should handle rebalance execution failures", async () => {
269
- // Make addLiquidity fail
270
- const addResult: AddLiquidityResult = {
271
- success: false,
272
- error: "DEX add liquidity failed",
273
- };
274
- (mockDexInteractionService.addLiquidity as Mock).mockResolvedValue(
275
- addResult,
276
- );
277
-
278
- // Execute should complete without throwing
279
- await task.execute();
280
-
281
- // Verify error was handled gracefully
282
- expect(mockDexInteractionService.removeLiquidity).toHaveBeenCalled();
283
- expect(mockDexInteractionService.addLiquidity).toHaveBeenCalled();
284
- });
285
-
286
- it("should not execute if opportunity does not meet criteria", async () => {
287
- // Create opportunity with low net gain
288
- const lowGainOpp = { ...goodOpportunity, netGainPercent: 0.5 }; // Below 1% threshold
289
- (
290
- mockYieldOptimizationService.findBestYieldOpportunities as Mock
291
- ).mockResolvedValue([lowGainOpp]);
292
-
293
- await task.execute();
294
-
295
- // Should not execute rebalance
296
- expect(mockDexInteractionService.removeLiquidity).not.toHaveBeenCalled();
297
- expect(mockDexInteractionService.addLiquidity).not.toHaveBeenCalled();
298
- });
299
-
300
- it("should not execute if target DEX is not in preferred list", async () => {
301
- // Create opportunity with non-preferred DEX
302
- const nonPreferredDexOpp = {
303
- ...goodOpportunity,
304
- targetPool: { ...targetPool1, dex: "raydium" },
305
- };
306
- (
307
- mockYieldOptimizationService.findBestYieldOpportunities as Mock
308
- ).mockResolvedValue([nonPreferredDexOpp]);
309
-
310
- await task.execute();
311
-
312
- expect(mockDexInteractionService.removeLiquidity).not.toHaveBeenCalled();
313
- });
314
- });
315
-
316
- describe("executeRebalance edge cases", () => {
317
- it("should handle remove liquidity failures", async () => {
318
- const removeResult: RemoveLiquidityResult = {
319
- success: false,
320
- error: "Remove failed",
321
- };
322
- (mockDexInteractionService.removeLiquidity as Mock).mockResolvedValue(
323
- removeResult,
324
- );
325
-
326
- await task.execute();
327
-
328
- // Should not proceed to add liquidity
329
- expect(mockDexInteractionService.addLiquidity).not.toHaveBeenCalled();
330
- });
331
-
332
- it("should handle token mismatch scenarios", async () => {
333
- const mismatchedTokens: TokenBalance[] = [
334
- {
335
- address: "otherToken1",
336
- balance: "1",
337
- decimals: 6,
338
- uiAmount: 0.000001,
339
- },
340
- {
341
- address: "otherToken2",
342
- balance: "1",
343
- decimals: 6,
344
- uiAmount: 0.000001,
345
- },
346
- ];
347
- const removeResult: RemoveLiquidityResult = {
348
- success: true,
349
- tokensReceived: mismatchedTokens,
350
- };
351
- (mockDexInteractionService.removeLiquidity as Mock).mockResolvedValue(
352
- removeResult,
353
- );
354
-
355
- await task.execute();
356
-
357
- // Should not proceed to add liquidity due to token mismatch
358
- expect(mockDexInteractionService.addLiquidity).not.toHaveBeenCalled();
359
- });
360
-
361
- it("should handle null vault keypair", async () => {
362
- (mockVaultService.getVaultKeypair as Mock).mockResolvedValue(null);
363
-
364
- await task.execute();
365
-
366
- // Should not proceed with rebalance
367
- expect(mockDexInteractionService.removeLiquidity).not.toHaveBeenCalled();
368
- });
369
- });
370
- });