@coinbase/agentkit 0.0.0-nightly-20250328174338

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 (292) hide show
  1. package/README.md +827 -0
  2. package/dist/action-providers/across/acrossActionProvider.d.ts +50 -0
  3. package/dist/action-providers/across/acrossActionProvider.js +333 -0
  4. package/dist/action-providers/across/acrossActionProvider.test.d.ts +1 -0
  5. package/dist/action-providers/across/acrossActionProvider.test.js +391 -0
  6. package/dist/action-providers/across/constants.d.ts +1 -0
  7. package/dist/action-providers/across/constants.js +2 -0
  8. package/dist/action-providers/across/index.d.ts +1 -0
  9. package/dist/action-providers/across/index.js +17 -0
  10. package/dist/action-providers/across/schemas.d.ts +36 -0
  11. package/dist/action-providers/across/schemas.js +46 -0
  12. package/dist/action-providers/across/utils.d.ts +7 -0
  13. package/dist/action-providers/across/utils.js +25 -0
  14. package/dist/action-providers/actionDecorator.d.ts +69 -0
  15. package/dist/action-providers/actionDecorator.js +96 -0
  16. package/dist/action-providers/actionProvider.d.ts +48 -0
  17. package/dist/action-providers/actionProvider.js +62 -0
  18. package/dist/action-providers/alchemy/alchemyTokenPricesActionProvider.d.ts +55 -0
  19. package/dist/action-providers/alchemy/alchemyTokenPricesActionProvider.js +173 -0
  20. package/dist/action-providers/alchemy/alchemyTokenPricesActionProvider.test.d.ts +1 -0
  21. package/dist/action-providers/alchemy/alchemyTokenPricesActionProvider.test.js +131 -0
  22. package/dist/action-providers/alchemy/index.d.ts +2 -0
  23. package/dist/action-providers/alchemy/index.js +18 -0
  24. package/dist/action-providers/alchemy/schemas.d.ts +41 -0
  25. package/dist/action-providers/alchemy/schemas.js +34 -0
  26. package/dist/action-providers/allora/alloraActionProvider.d.ts +44 -0
  27. package/dist/action-providers/allora/alloraActionProvider.js +195 -0
  28. package/dist/action-providers/allora/alloraActionProvider.test.d.ts +1 -0
  29. package/dist/action-providers/allora/alloraActionProvider.test.js +109 -0
  30. package/dist/action-providers/allora/index.d.ts +2 -0
  31. package/dist/action-providers/allora/index.js +18 -0
  32. package/dist/action-providers/allora/schemas.d.ts +28 -0
  33. package/dist/action-providers/allora/schemas.js +30 -0
  34. package/dist/action-providers/basename/basenameActionProvider.d.ts +30 -0
  35. package/dist/action-providers/basename/basenameActionProvider.js +109 -0
  36. package/dist/action-providers/basename/basenameActionProvider.test.d.ts +1 -0
  37. package/dist/action-providers/basename/basenameActionProvider.test.js +146 -0
  38. package/dist/action-providers/basename/constants.d.ts +52 -0
  39. package/dist/action-providers/basename/constants.js +81 -0
  40. package/dist/action-providers/basename/index.d.ts +2 -0
  41. package/dist/action-providers/basename/index.js +18 -0
  42. package/dist/action-providers/basename/schemas.d.ts +14 -0
  43. package/dist/action-providers/basename/schemas.js +14 -0
  44. package/dist/action-providers/cdp/cdpApiActionProvider.d.ts +43 -0
  45. package/dist/action-providers/cdp/cdpApiActionProvider.js +128 -0
  46. package/dist/action-providers/cdp/cdpApiActionProvider.test.d.ts +1 -0
  47. package/dist/action-providers/cdp/cdpApiActionProvider.test.js +146 -0
  48. package/dist/action-providers/cdp/cdpWalletActionProvider.d.ts +58 -0
  49. package/dist/action-providers/cdp/cdpWalletActionProvider.js +224 -0
  50. package/dist/action-providers/cdp/cdpWalletActionProvider.test.d.ts +1 -0
  51. package/dist/action-providers/cdp/cdpWalletActionProvider.test.js +267 -0
  52. package/dist/action-providers/cdp/constants.d.ts +31 -0
  53. package/dist/action-providers/cdp/constants.js +34 -0
  54. package/dist/action-providers/cdp/index.d.ts +3 -0
  55. package/dist/action-providers/cdp/index.js +19 -0
  56. package/dist/action-providers/cdp/schemas.d.ts +91 -0
  57. package/dist/action-providers/cdp/schemas.js +77 -0
  58. package/dist/action-providers/compound/compoundActionProvider.d.ts +67 -0
  59. package/dist/action-providers/compound/compoundActionProvider.js +365 -0
  60. package/dist/action-providers/compound/compoundActionProvider.test.d.ts +1 -0
  61. package/dist/action-providers/compound/compoundActionProvider.test.js +353 -0
  62. package/dist/action-providers/compound/constants.d.ts +180 -0
  63. package/dist/action-providers/compound/constants.js +129 -0
  64. package/dist/action-providers/compound/index.d.ts +1 -0
  65. package/dist/action-providers/compound/index.js +17 -0
  66. package/dist/action-providers/compound/schemas.d.ts +57 -0
  67. package/dist/action-providers/compound/schemas.js +58 -0
  68. package/dist/action-providers/compound/utils.d.ts +95 -0
  69. package/dist/action-providers/compound/utils.js +353 -0
  70. package/dist/action-providers/customActionProvider.d.ts +30 -0
  71. package/dist/action-providers/customActionProvider.js +66 -0
  72. package/dist/action-providers/defillama/constants.d.ts +8 -0
  73. package/dist/action-providers/defillama/constants.js +11 -0
  74. package/dist/action-providers/defillama/defillamaActionProvider.d.ts +54 -0
  75. package/dist/action-providers/defillama/defillamaActionProvider.js +180 -0
  76. package/dist/action-providers/defillama/defillamaActionProvider.test.d.ts +1 -0
  77. package/dist/action-providers/defillama/defillamaActionProvider.test.js +114 -0
  78. package/dist/action-providers/defillama/index.d.ts +1 -0
  79. package/dist/action-providers/defillama/index.js +17 -0
  80. package/dist/action-providers/defillama/schemas.d.ts +34 -0
  81. package/dist/action-providers/defillama/schemas.js +34 -0
  82. package/dist/action-providers/defillama/types.d.ts +73 -0
  83. package/dist/action-providers/defillama/types.js +2 -0
  84. package/dist/action-providers/defillama/utils.d.ts +10 -0
  85. package/dist/action-providers/defillama/utils.js +87 -0
  86. package/dist/action-providers/defillama/utils.test.d.ts +1 -0
  87. package/dist/action-providers/defillama/utils.test.js +124 -0
  88. package/dist/action-providers/erc20/constants.d.ts +137 -0
  89. package/dist/action-providers/erc20/constants.js +202 -0
  90. package/dist/action-providers/erc20/erc20ActionProvider.d.ts +38 -0
  91. package/dist/action-providers/erc20/erc20ActionProvider.js +142 -0
  92. package/dist/action-providers/erc20/erc20ActionProvider.test.d.ts +1 -0
  93. package/dist/action-providers/erc20/erc20ActionProvider.test.js +131 -0
  94. package/dist/action-providers/erc20/index.d.ts +1 -0
  95. package/dist/action-providers/erc20/index.js +17 -0
  96. package/dist/action-providers/erc20/schemas.d.ts +27 -0
  97. package/dist/action-providers/erc20/schemas.js +26 -0
  98. package/dist/action-providers/erc721/constants.d.ts +232 -0
  99. package/dist/action-providers/erc721/constants.js +298 -0
  100. package/dist/action-providers/erc721/erc721ActionProvider.d.ts +46 -0
  101. package/dist/action-providers/erc721/erc721ActionProvider.js +164 -0
  102. package/dist/action-providers/erc721/erc721ActionProvider.test.d.ts +1 -0
  103. package/dist/action-providers/erc721/erc721ActionProvider.test.js +137 -0
  104. package/dist/action-providers/erc721/index.d.ts +1 -0
  105. package/dist/action-providers/erc721/index.js +17 -0
  106. package/dist/action-providers/erc721/schemas.d.ts +46 -0
  107. package/dist/action-providers/erc721/schemas.js +44 -0
  108. package/dist/action-providers/farcaster/farcasterActionProvider.d.ts +57 -0
  109. package/dist/action-providers/farcaster/farcasterActionProvider.js +142 -0
  110. package/dist/action-providers/farcaster/farcasterActionProvider.test.d.ts +1 -0
  111. package/dist/action-providers/farcaster/farcasterActionProvider.test.js +151 -0
  112. package/dist/action-providers/farcaster/index.d.ts +2 -0
  113. package/dist/action-providers/farcaster/index.js +18 -0
  114. package/dist/action-providers/farcaster/schemas.d.ts +15 -0
  115. package/dist/action-providers/farcaster/schemas.js +20 -0
  116. package/dist/action-providers/index.d.ts +24 -0
  117. package/dist/action-providers/index.js +40 -0
  118. package/dist/action-providers/jupiter/index.d.ts +1 -0
  119. package/dist/action-providers/jupiter/index.js +17 -0
  120. package/dist/action-providers/jupiter/jupiterActionProvider.d.ts +36 -0
  121. package/dist/action-providers/jupiter/jupiterActionProvider.js +115 -0
  122. package/dist/action-providers/jupiter/jupiterActionProvider.test.d.ts +1 -0
  123. package/dist/action-providers/jupiter/jupiterActionProvider.test.js +146 -0
  124. package/dist/action-providers/jupiter/schemas.d.ts +20 -0
  125. package/dist/action-providers/jupiter/schemas.js +20 -0
  126. package/dist/action-providers/messari/constants.d.ts +17 -0
  127. package/dist/action-providers/messari/constants.js +20 -0
  128. package/dist/action-providers/messari/index.d.ts +5 -0
  129. package/dist/action-providers/messari/index.js +21 -0
  130. package/dist/action-providers/messari/messariActionProvider.d.ts +42 -0
  131. package/dist/action-providers/messari/messariActionProvider.js +128 -0
  132. package/dist/action-providers/messari/messariActionProvider.test.d.ts +1 -0
  133. package/dist/action-providers/messari/messariActionProvider.test.js +152 -0
  134. package/dist/action-providers/messari/schemas.d.ts +11 -0
  135. package/dist/action-providers/messari/schemas.js +16 -0
  136. package/dist/action-providers/messari/types.d.ts +40 -0
  137. package/dist/action-providers/messari/types.js +2 -0
  138. package/dist/action-providers/messari/utils.d.ts +22 -0
  139. package/dist/action-providers/messari/utils.js +65 -0
  140. package/dist/action-providers/moonwell/constants.d.ts +78 -0
  141. package/dist/action-providers/moonwell/constants.js +111 -0
  142. package/dist/action-providers/moonwell/index.d.ts +1 -0
  143. package/dist/action-providers/moonwell/index.js +5 -0
  144. package/dist/action-providers/moonwell/moonwellActionProvider.d.ts +39 -0
  145. package/dist/action-providers/moonwell/moonwellActionProvider.js +249 -0
  146. package/dist/action-providers/moonwell/moonwellActionProvider.test.d.ts +1 -0
  147. package/dist/action-providers/moonwell/moonwellActionProvider.test.js +455 -0
  148. package/dist/action-providers/moonwell/schemas.d.ts +30 -0
  149. package/dist/action-providers/moonwell/schemas.js +39 -0
  150. package/dist/action-providers/morpho/constants.d.ts +16 -0
  151. package/dist/action-providers/morpho/constants.js +27 -0
  152. package/dist/action-providers/morpho/index.d.ts +2 -0
  153. package/dist/action-providers/morpho/index.js +18 -0
  154. package/dist/action-providers/morpho/morphoActionProvider.d.ts +39 -0
  155. package/dist/action-providers/morpho/morphoActionProvider.js +154 -0
  156. package/dist/action-providers/morpho/morphoActionProvider.test.d.ts +1 -0
  157. package/dist/action-providers/morpho/morphoActionProvider.test.js +128 -0
  158. package/dist/action-providers/morpho/schemas.d.ts +36 -0
  159. package/dist/action-providers/morpho/schemas.js +47 -0
  160. package/dist/action-providers/opensea/index.d.ts +1 -0
  161. package/dist/action-providers/opensea/index.js +17 -0
  162. package/dist/action-providers/opensea/openseaActionProvider.d.ts +59 -0
  163. package/dist/action-providers/opensea/openseaActionProvider.js +146 -0
  164. package/dist/action-providers/opensea/openseaActionProvider.test.d.ts +1 -0
  165. package/dist/action-providers/opensea/openseaActionProvider.test.js +201 -0
  166. package/dist/action-providers/opensea/schemas.d.ts +30 -0
  167. package/dist/action-providers/opensea/schemas.js +33 -0
  168. package/dist/action-providers/opensea/utils.d.ts +12 -0
  169. package/dist/action-providers/opensea/utils.js +47 -0
  170. package/dist/action-providers/pyth/index.d.ts +2 -0
  171. package/dist/action-providers/pyth/index.js +18 -0
  172. package/dist/action-providers/pyth/pythActionProvider.d.ts +33 -0
  173. package/dist/action-providers/pyth/pythActionProvider.js +121 -0
  174. package/dist/action-providers/pyth/pythActionProvider.test.d.ts +1 -0
  175. package/dist/action-providers/pyth/pythActionProvider.test.js +113 -0
  176. package/dist/action-providers/pyth/schemas.d.ts +21 -0
  177. package/dist/action-providers/pyth/schemas.js +20 -0
  178. package/dist/action-providers/spl/index.d.ts +1 -0
  179. package/dist/action-providers/spl/index.js +17 -0
  180. package/dist/action-providers/spl/schemas.d.ts +30 -0
  181. package/dist/action-providers/spl/schemas.js +26 -0
  182. package/dist/action-providers/spl/splActionProvider.d.ts +45 -0
  183. package/dist/action-providers/spl/splActionProvider.js +173 -0
  184. package/dist/action-providers/spl/splActionProvider.test.d.ts +1 -0
  185. package/dist/action-providers/spl/splActionProvider.test.js +300 -0
  186. package/dist/action-providers/twitter/index.d.ts +2 -0
  187. package/dist/action-providers/twitter/index.js +18 -0
  188. package/dist/action-providers/twitter/schemas.d.ts +38 -0
  189. package/dist/action-providers/twitter/schemas.js +44 -0
  190. package/dist/action-providers/twitter/twitterActionProvider.d.ts +82 -0
  191. package/dist/action-providers/twitter/twitterActionProvider.js +204 -0
  192. package/dist/action-providers/twitter/twitterActionProvider.test.d.ts +1 -0
  193. package/dist/action-providers/twitter/twitterActionProvider.test.js +185 -0
  194. package/dist/action-providers/wallet/index.d.ts +1 -0
  195. package/dist/action-providers/wallet/index.js +17 -0
  196. package/dist/action-providers/wallet/schemas.d.ts +19 -0
  197. package/dist/action-providers/wallet/schemas.js +19 -0
  198. package/dist/action-providers/wallet/walletActionProvider.d.ts +44 -0
  199. package/dist/action-providers/wallet/walletActionProvider.js +140 -0
  200. package/dist/action-providers/wallet/walletActionProvider.test.d.ts +1 -0
  201. package/dist/action-providers/wallet/walletActionProvider.test.js +194 -0
  202. package/dist/action-providers/weth/constants.d.ts +19 -0
  203. package/dist/action-providers/weth/constants.js +29 -0
  204. package/dist/action-providers/weth/index.d.ts +1 -0
  205. package/dist/action-providers/weth/index.js +17 -0
  206. package/dist/action-providers/weth/schemas.d.ts +8 -0
  207. package/dist/action-providers/weth/schemas.js +10 -0
  208. package/dist/action-providers/weth/wethActionProvider.d.ts +30 -0
  209. package/dist/action-providers/weth/wethActionProvider.js +89 -0
  210. package/dist/action-providers/weth/wethActionProvider.test.d.ts +1 -0
  211. package/dist/action-providers/weth/wethActionProvider.test.js +92 -0
  212. package/dist/action-providers/wow/constants.d.ts +15 -0
  213. package/dist/action-providers/wow/constants.js +844 -0
  214. package/dist/action-providers/wow/index.d.ts +2 -0
  215. package/dist/action-providers/wow/index.js +18 -0
  216. package/dist/action-providers/wow/schemas.d.ts +43 -0
  217. package/dist/action-providers/wow/schemas.js +47 -0
  218. package/dist/action-providers/wow/uniswap/constants.d.ts +3 -0
  219. package/dist/action-providers/wow/uniswap/constants.js +100 -0
  220. package/dist/action-providers/wow/uniswap/utils.d.ts +82 -0
  221. package/dist/action-providers/wow/uniswap/utils.js +226 -0
  222. package/dist/action-providers/wow/utils.d.ts +27 -0
  223. package/dist/action-providers/wow/utils.js +63 -0
  224. package/dist/action-providers/wow/wowActionProvider.d.ts +46 -0
  225. package/dist/action-providers/wow/wowActionProvider.js +223 -0
  226. package/dist/action-providers/wow/wowActionProvider.test.d.ts +1 -0
  227. package/dist/action-providers/wow/wowActionProvider.test.js +291 -0
  228. package/dist/agentkit.d.ts +44 -0
  229. package/dist/agentkit.js +68 -0
  230. package/dist/analytics/index.d.ts +1 -0
  231. package/dist/analytics/index.js +17 -0
  232. package/dist/analytics/sendAnalyticsEvent.d.ts +31 -0
  233. package/dist/analytics/sendAnalyticsEvent.js +52 -0
  234. package/dist/index.d.ts +4 -0
  235. package/dist/index.js +20 -0
  236. package/dist/network/index.d.ts +3 -0
  237. package/dist/network/index.js +19 -0
  238. package/dist/network/network.d.ts +20 -0
  239. package/dist/network/network.js +86 -0
  240. package/dist/network/svm.d.ts +15 -0
  241. package/dist/network/svm.js +38 -0
  242. package/dist/network/types.d.ts +17 -0
  243. package/dist/network/types.js +2 -0
  244. package/dist/utils.d.ts +22 -0
  245. package/dist/utils.js +57 -0
  246. package/dist/utils.test.d.ts +1 -0
  247. package/dist/utils.test.js +50 -0
  248. package/dist/wallet-providers/cdpWalletProvider.d.ts +246 -0
  249. package/dist/wallet-providers/cdpWalletProvider.js +421 -0
  250. package/dist/wallet-providers/cdpWalletProvider.test.d.ts +1 -0
  251. package/dist/wallet-providers/cdpWalletProvider.test.js +701 -0
  252. package/dist/wallet-providers/evmWalletProvider.d.ts +51 -0
  253. package/dist/wallet-providers/evmWalletProvider.js +14 -0
  254. package/dist/wallet-providers/evmWalletProvider.test.d.ts +1 -0
  255. package/dist/wallet-providers/evmWalletProvider.test.js +56 -0
  256. package/dist/wallet-providers/index.d.ts +10 -0
  257. package/dist/wallet-providers/index.js +26 -0
  258. package/dist/wallet-providers/privyEvmWalletProvider.d.ts +55 -0
  259. package/dist/wallet-providers/privyEvmWalletProvider.js +140 -0
  260. package/dist/wallet-providers/privyEvmWalletProvider.test.d.ts +1 -0
  261. package/dist/wallet-providers/privyEvmWalletProvider.test.js +331 -0
  262. package/dist/wallet-providers/privyShared.d.ts +40 -0
  263. package/dist/wallet-providers/privyShared.js +49 -0
  264. package/dist/wallet-providers/privySvmWalletProvider.d.ts +128 -0
  265. package/dist/wallet-providers/privySvmWalletProvider.js +212 -0
  266. package/dist/wallet-providers/privySvmWalletProvider.test.d.ts +1 -0
  267. package/dist/wallet-providers/privySvmWalletProvider.test.js +310 -0
  268. package/dist/wallet-providers/privyWalletProvider.d.ts +35 -0
  269. package/dist/wallet-providers/privyWalletProvider.js +39 -0
  270. package/dist/wallet-providers/privyWalletProvider.test.d.ts +1 -0
  271. package/dist/wallet-providers/privyWalletProvider.test.js +124 -0
  272. package/dist/wallet-providers/smartWalletProvider.d.ts +177 -0
  273. package/dist/wallet-providers/smartWalletProvider.js +303 -0
  274. package/dist/wallet-providers/smartWalletProvider.test.d.ts +1 -0
  275. package/dist/wallet-providers/smartWalletProvider.test.js +388 -0
  276. package/dist/wallet-providers/solanaKeypairWalletProvider.d.ts +143 -0
  277. package/dist/wallet-providers/solanaKeypairWalletProvider.js +280 -0
  278. package/dist/wallet-providers/solanaKeypairWalletProvider.test.d.ts +1 -0
  279. package/dist/wallet-providers/solanaKeypairWalletProvider.test.js +218 -0
  280. package/dist/wallet-providers/svmWalletProvider.d.ts +56 -0
  281. package/dist/wallet-providers/svmWalletProvider.js +13 -0
  282. package/dist/wallet-providers/svmWalletProvider.test.d.ts +1 -0
  283. package/dist/wallet-providers/svmWalletProvider.test.js +55 -0
  284. package/dist/wallet-providers/viemWalletProvider.d.ts +103 -0
  285. package/dist/wallet-providers/viemWalletProvider.js +206 -0
  286. package/dist/wallet-providers/viemWalletProvider.test.d.ts +1 -0
  287. package/dist/wallet-providers/viemWalletProvider.test.js +338 -0
  288. package/dist/wallet-providers/walletProvider.d.ts +48 -0
  289. package/dist/wallet-providers/walletProvider.js +41 -0
  290. package/dist/wallet-providers/walletProvider.test.d.ts +1 -0
  291. package/dist/wallet-providers/walletProvider.test.js +103 -0
  292. package/package.json +83 -0
@@ -0,0 +1,50 @@
1
+ import { z } from "zod";
2
+ import { ActionProvider } from "../actionProvider";
3
+ import { Network } from "../../network";
4
+ import { BridgeTokenSchema, CheckDepositStatusSchema } from "./schemas";
5
+ import { EvmWalletProvider } from "../../wallet-providers";
6
+ /**
7
+ * Configuration options for the SafeWalletProvider.
8
+ */
9
+ export interface AcrossActionProviderConfig {
10
+ /**
11
+ * Private key of the wallet provider
12
+ */
13
+ privateKey: string;
14
+ }
15
+ /**
16
+ * AcrossActionProvider provides actions for cross-chain bridging via Across Protocol.
17
+ */
18
+ export declare class AcrossActionProvider extends ActionProvider<EvmWalletProvider> {
19
+ #private;
20
+ /**
21
+ * Constructor for the AcrossActionProvider.
22
+ *
23
+ * @param config - The configuration options for the AcrossActionProvider.
24
+ */
25
+ constructor(config: AcrossActionProviderConfig);
26
+ /**
27
+ * Bridges a token from one chain to another using Across Protocol.
28
+ *
29
+ * @param walletProvider - The wallet provider to use for the transaction.
30
+ * @param args - The input arguments for the action.
31
+ * @returns A message containing the bridge details.
32
+ */
33
+ bridgeToken(walletProvider: EvmWalletProvider, args: z.infer<typeof BridgeTokenSchema>): Promise<string>;
34
+ /**
35
+ * Checks the status of a bridge deposit via Across Protocol.
36
+ *
37
+ * @param walletProvider - The wallet provider to use for the transaction.
38
+ * @param args - The input arguments for the action.
39
+ * @returns A message containing the deposit status details.
40
+ */
41
+ checkDepositStatus(walletProvider: EvmWalletProvider, args: z.infer<typeof CheckDepositStatusSchema>): Promise<string>;
42
+ /**
43
+ * Checks if the Across action provider supports the given network.
44
+ *
45
+ * @param network - The network to check.
46
+ * @returns True if the Across action provider supports the network, false otherwise.
47
+ */
48
+ supportsNetwork: (network: Network) => boolean;
49
+ }
50
+ export declare const acrossActionProvider: (config: AcrossActionProviderConfig) => AcrossActionProvider;
@@ -0,0 +1,333 @@
1
+ "use strict";
2
+ var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
3
+ var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
4
+ if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
5
+ else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
6
+ return c > 3 && r && Object.defineProperty(target, key, r), r;
7
+ };
8
+ var __metadata = (this && this.__metadata) || function (k, v) {
9
+ if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
10
+ };
11
+ var __classPrivateFieldSet = (this && this.__classPrivateFieldSet) || function (receiver, state, value, kind, f) {
12
+ if (kind === "m") throw new TypeError("Private method is not writable");
13
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a setter");
14
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot write private member to an object whose class did not declare it");
15
+ return (kind === "a" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;
16
+ };
17
+ var __classPrivateFieldGet = (this && this.__classPrivateFieldGet) || function (receiver, state, kind, f) {
18
+ if (kind === "a" && !f) throw new TypeError("Private accessor was defined without a getter");
19
+ if (typeof state === "function" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError("Cannot read private member from an object whose class did not declare it");
20
+ return kind === "m" ? f : kind === "a" ? f.call(receiver) : f ? f.value : state.get(receiver);
21
+ };
22
+ var _AcrossActionProvider_privateKey;
23
+ Object.defineProperty(exports, "__esModule", { value: true });
24
+ exports.acrossActionProvider = exports.AcrossActionProvider = void 0;
25
+ const zod_1 = require("zod");
26
+ const viem_1 = require("viem");
27
+ const actionProvider_1 = require("../actionProvider");
28
+ const network_1 = require("../../network");
29
+ const actionDecorator_1 = require("../actionDecorator");
30
+ const schemas_1 = require("./schemas");
31
+ const wallet_providers_1 = require("../../wallet-providers");
32
+ const utils_1 = require("./utils");
33
+ const accounts_1 = require("viem/accounts");
34
+ const constants_1 = require("../erc20/constants");
35
+ /**
36
+ * AcrossActionProvider provides actions for cross-chain bridging via Across Protocol.
37
+ */
38
+ class AcrossActionProvider extends actionProvider_1.ActionProvider {
39
+ /**
40
+ * Constructor for the AcrossActionProvider.
41
+ *
42
+ * @param config - The configuration options for the AcrossActionProvider.
43
+ */
44
+ constructor(config) {
45
+ super("across", []);
46
+ _AcrossActionProvider_privateKey.set(this, void 0);
47
+ /**
48
+ * Checks if the Across action provider supports the given network.
49
+ *
50
+ * @param network - The network to check.
51
+ * @returns True if the Across action provider supports the network, false otherwise.
52
+ */
53
+ this.supportsNetwork = (network) => {
54
+ // Across only supports EVM-compatible chains
55
+ return network.protocolFamily === "evm";
56
+ };
57
+ __classPrivateFieldSet(this, _AcrossActionProvider_privateKey, config.privateKey, "f");
58
+ const account = (0, accounts_1.privateKeyToAccount)(__classPrivateFieldGet(this, _AcrossActionProvider_privateKey, "f"));
59
+ if (!account)
60
+ throw new Error("Invalid private key");
61
+ }
62
+ /**
63
+ * Bridges a token from one chain to another using Across Protocol.
64
+ *
65
+ * @param walletProvider - The wallet provider to use for the transaction.
66
+ * @param args - The input arguments for the action.
67
+ * @returns A message containing the bridge details.
68
+ */
69
+ async bridgeToken(walletProvider, args) {
70
+ try {
71
+ // Use dynamic import to get the Across SDK
72
+ const acrossModule = await import("@across-protocol/app-sdk");
73
+ const createAcrossClient = acrossModule.createAcrossClient;
74
+ // Get recipient address if provided, otherwise use sender
75
+ const address = walletProvider.getAddress();
76
+ const recipient = (args.recipient || address);
77
+ // Get origin chain
78
+ const originChain = (0, network_1.getChain)(walletProvider.getNetwork().chainId);
79
+ if (!originChain) {
80
+ throw new Error(`Unsupported origin chain: ${walletProvider.getNetwork()}`);
81
+ }
82
+ // Get destination chain
83
+ const destinationNetworkId = network_1.CHAIN_ID_TO_NETWORK_ID[Number(args.destinationChainId)];
84
+ const destinationChain = network_1.NETWORK_ID_TO_VIEM_CHAIN[destinationNetworkId];
85
+ if (!destinationChain) {
86
+ throw new Error(`Unsupported destination chain: ${args.destinationChainId}`);
87
+ }
88
+ // Sanity checks
89
+ if (originChain.id === destinationChain.id) {
90
+ throw new Error("Origin and destination chains cannot be the same");
91
+ }
92
+ const useTestnet = (0, utils_1.isAcrossSupportedTestnet)(originChain.id);
93
+ if (useTestnet !== (0, utils_1.isAcrossSupportedTestnet)(destinationChain.id)) {
94
+ throw new Error(`Cross-chain transfers between ${originChain.name} and ${destinationChain.name} are not supported.
95
+ Origin and destination chains must either be both testnets or both mainnets.`);
96
+ }
97
+ // Create wallet client
98
+ const account = (0, accounts_1.privateKeyToAccount)(__classPrivateFieldGet(this, _AcrossActionProvider_privateKey, "f"));
99
+ if (account.address !== walletProvider.getAddress()) {
100
+ throw new Error("Private key does not match wallet provider address");
101
+ }
102
+ const walletClient = (0, viem_1.createWalletClient)({
103
+ account,
104
+ chain: originChain,
105
+ transport: (0, viem_1.http)(),
106
+ });
107
+ // Create Across client
108
+ const acrossClient = createAcrossClient({
109
+ chains: [originChain, destinationChain],
110
+ useTestnet,
111
+ });
112
+ // Get chain details to find token information
113
+ const chainDetails = await acrossClient.getSupportedChains({});
114
+ const originChainDetails = chainDetails.find(chain => chain.chainId === originChain.id);
115
+ if (!originChainDetails) {
116
+ throw new Error(`Origin chain ${originChain.id} not supported by Across Protocol`);
117
+ }
118
+ // Find token by symbol on the origin chain
119
+ const inputTokens = originChainDetails.inputTokens;
120
+ if (!inputTokens || inputTokens.length === 0) {
121
+ throw new Error(`No input tokens available on chain ${originChain.id}`);
122
+ }
123
+ const tokenInfo = inputTokens.find(token => token.symbol.toUpperCase() === args.inputTokenSymbol.toUpperCase());
124
+ if (!tokenInfo) {
125
+ throw new Error(`Token ${args.inputTokenSymbol} not found on chain ${originChain.id}. Available tokens: ${inputTokens.map(t => t.symbol).join(", ")}`);
126
+ }
127
+ // Get token address and decimals to parse the amount
128
+ const inputToken = tokenInfo.address;
129
+ const decimals = tokenInfo.decimals;
130
+ const inputAmount = (0, viem_1.parseUnits)(args.amount, decimals);
131
+ // Check balance
132
+ const isNative = args.inputTokenSymbol.toUpperCase() === "ETH";
133
+ if (isNative) {
134
+ // Check native ETH balance
135
+ const ethBalance = await walletProvider.getBalance();
136
+ if (ethBalance < inputAmount) {
137
+ throw new Error(`Insufficient balance. Requested to bridge ${(0, viem_1.formatUnits)(inputAmount, decimals)} ${args.inputTokenSymbol} but balance is only ${(0, viem_1.formatUnits)(ethBalance, decimals)} ${args.inputTokenSymbol}`);
138
+ }
139
+ }
140
+ else {
141
+ // Check ERC20 token balance
142
+ const tokenBalance = (await walletProvider.readContract({
143
+ address: inputToken,
144
+ abi: constants_1.abi,
145
+ functionName: "balanceOf",
146
+ args: [address],
147
+ }));
148
+ if (tokenBalance < inputAmount) {
149
+ throw new Error(`Insufficient balance. Requested to bridge ${(0, viem_1.formatUnits)(inputAmount, decimals)} ${args.inputTokenSymbol} but balance is only ${(0, viem_1.formatUnits)(tokenBalance, decimals)} ${args.inputTokenSymbol}`);
150
+ }
151
+ }
152
+ // Get available routes
153
+ const routeInfo = await acrossClient.getAvailableRoutes({
154
+ originChainId: originChain.id,
155
+ destinationChainId: destinationChain.id,
156
+ originToken: inputToken,
157
+ });
158
+ // Select the appropriate route for native ETH or ERC20 token
159
+ const route = routeInfo.find(route => route.isNative === isNative);
160
+ if (!route) {
161
+ throw new Error(`No routes available from chain ${originChain.name} to chain ${destinationChain.name} for token ${args.inputTokenSymbol}`);
162
+ }
163
+ // Get quote
164
+ const quote = await acrossClient.getQuote({
165
+ route,
166
+ inputAmount,
167
+ recipient,
168
+ });
169
+ // Convert units to readable format
170
+ const formattedInfo = {
171
+ minDeposit: (0, viem_1.formatUnits)(quote.limits.minDeposit, decimals),
172
+ maxDeposit: (0, viem_1.formatUnits)(quote.limits.maxDeposit, decimals),
173
+ inputAmount: (0, viem_1.formatUnits)(quote.deposit.inputAmount, decimals),
174
+ outputAmount: (0, viem_1.formatUnits)(quote.deposit.outputAmount, decimals),
175
+ };
176
+ // Check if input amount is within valid deposit range
177
+ if (quote.deposit.inputAmount < quote.limits.minDeposit) {
178
+ throw new Error(`Input amount ${formattedInfo.inputAmount} ${args.inputTokenSymbol} is below the minimum deposit of ${formattedInfo.minDeposit} ${args.inputTokenSymbol}`);
179
+ }
180
+ if (quote.deposit.inputAmount > quote.limits.maxDeposit) {
181
+ throw new Error(`Input amount ${formattedInfo.inputAmount} ${args.inputTokenSymbol} exceeds the maximum deposit of ${formattedInfo.maxDeposit} ${args.inputTokenSymbol}`);
182
+ }
183
+ // Check if output amount is within acceptable slippage limits
184
+ const actualSlippagePercentage = ((Number(formattedInfo.inputAmount) - Number(formattedInfo.outputAmount)) /
185
+ Number(formattedInfo.inputAmount)) *
186
+ 100;
187
+ if (actualSlippagePercentage > args.maxSplippage) {
188
+ throw new Error(`Output amount has high slippage of ${actualSlippagePercentage.toFixed(2)}%, which exceeds the maximum allowed slippage of ${args.maxSplippage}%. ` +
189
+ `Input: ${formattedInfo.inputAmount} ${args.inputTokenSymbol}, Output: ${formattedInfo.outputAmount} ${args.inputTokenSymbol}`);
190
+ }
191
+ //Approve ERC20 token if needed
192
+ let approvalTxHash;
193
+ if (!isNative) {
194
+ approvalTxHash = await walletProvider.sendTransaction({
195
+ to: inputToken,
196
+ data: (0, viem_1.encodeFunctionData)({
197
+ abi: constants_1.abi,
198
+ functionName: "approve",
199
+ args: [quote.deposit.spokePoolAddress, quote.deposit.inputAmount],
200
+ }),
201
+ });
202
+ await walletProvider.waitForTransactionReceipt(approvalTxHash);
203
+ }
204
+ // Simulate the deposit transaction
205
+ const { request } = await acrossClient.simulateDepositTx({
206
+ walletClient: walletClient,
207
+ deposit: quote.deposit,
208
+ });
209
+ // Execute the deposit transaction
210
+ const transactionHash = await walletClient.writeContract(request);
211
+ // Wait for tx to be mined
212
+ const { depositId } = await acrossClient.waitForDepositTx({
213
+ transactionHash,
214
+ originChainId: originChain.id,
215
+ });
216
+ return `
217
+ Successfully deposited tokens:
218
+ - From: Chain ${originChain.id} (${originChain.name})
219
+ - To: Chain ${destinationChain.id} (${destinationChain.name})
220
+ - Token: ${args.inputTokenSymbol} (${inputToken})
221
+ - Input Amount: ${formattedInfo.inputAmount} ${args.inputTokenSymbol}
222
+ - Output Amount: ${formattedInfo.outputAmount} ${args.inputTokenSymbol}
223
+ - Recipient: ${recipient}
224
+ ${!isNative ? `- Transaction Hash for approval: ${approvalTxHash}\n` : ""}
225
+ - Transaction Hash for deposit: ${transactionHash}
226
+ - Deposit ID: ${depositId}
227
+ `;
228
+ }
229
+ catch (error) {
230
+ return `Error with Across SDK: ${error}`;
231
+ }
232
+ }
233
+ /**
234
+ * Checks the status of a bridge deposit via Across Protocol.
235
+ *
236
+ * @param walletProvider - The wallet provider to use for the transaction.
237
+ * @param args - The input arguments for the action.
238
+ * @returns A message containing the deposit status details.
239
+ */
240
+ async checkDepositStatus(walletProvider, args) {
241
+ const originChainId = Number(args.originChainId) || Number(walletProvider.getNetwork().chainId);
242
+ if ((0, utils_1.isAcrossSupportedTestnet)(originChainId)) {
243
+ throw new Error("Checking deposit status on testnets is currently not supported by the Across API");
244
+ }
245
+ try {
246
+ const response = await fetch(`https://app.across.to/api/deposit/status?originChainId=${originChainId}&depositId=${args.depositId}`, {
247
+ method: "GET",
248
+ });
249
+ if (!response.ok) {
250
+ throw new Error(`Across API request failed with status ${response.status}`);
251
+ }
252
+ const apiData = await response.json();
253
+ // Get chain names
254
+ const originChainName = (0, network_1.getChain)(String(apiData.originChainId))?.name || "Unknown Chain";
255
+ const destinationChainName = (0, network_1.getChain)(String(apiData.destinationChainId))?.name || "Unknown Chain";
256
+ // Create structured response
257
+ const structuredResponse = {
258
+ status: apiData.status || "unknown",
259
+ depositTxInfo: apiData.depositTxHash
260
+ ? {
261
+ txHash: apiData.depositTxHash,
262
+ chainId: apiData.originChainId,
263
+ chainName: originChainName,
264
+ }
265
+ : null,
266
+ fillTxInfo: apiData.fillTx
267
+ ? {
268
+ txHash: apiData.fillTx,
269
+ chainId: apiData.destinationChainId,
270
+ chainName: destinationChainName,
271
+ }
272
+ : null,
273
+ depositRefundTxInfo: apiData.depositRefundTxHash
274
+ ? {
275
+ txHash: apiData.depositRefundTxHash,
276
+ chainId: apiData.originChainId,
277
+ chainName: originChainName,
278
+ }
279
+ : null,
280
+ };
281
+ return JSON.stringify(structuredResponse, null, 2);
282
+ }
283
+ catch (error) {
284
+ return `Error checking deposit status: ${error}`;
285
+ }
286
+ }
287
+ }
288
+ exports.AcrossActionProvider = AcrossActionProvider;
289
+ _AcrossActionProvider_privateKey = new WeakMap();
290
+ __decorate([
291
+ (0, actionDecorator_1.CreateAction)({
292
+ name: "bridge_token",
293
+ description: `
294
+ This tool will bridge tokens from the current chain to another chain using the Across Protocol.
295
+
296
+ It takes the following inputs:
297
+ - destinationChainId: The chain ID of the destination chain (e.g. 8453 for base-mainnet)
298
+ - inputTokenSymbol: The symbol of the token to bridge (e.g. 'ETH', 'USDC')
299
+ - amount: The amount of tokens to bridge in whole units (e.g. 1.5 WETH, 10 USDC)
300
+ - recipient: (Optional) The recipient address on the destination chain (defaults to sender)
301
+ - maxSplippage: (Optional) The maximum slippage percentage (defaults to 1.5%)
302
+
303
+ Important notes:
304
+ - Origin chain is the currently connected chain of the wallet provider
305
+ - Supports cross-chain transfers between EVM-compatible chains for both mainnets and test networks
306
+ - Testnet deposits are not refunded if not filled on destination chain
307
+ - Ensure sufficient balance of the input token before bridging
308
+ - Returns deposit ID that can be used to check the status of the deposit
309
+ `,
310
+ schema: schemas_1.BridgeTokenSchema,
311
+ }),
312
+ __metadata("design:type", Function),
313
+ __metadata("design:paramtypes", [wallet_providers_1.EvmWalletProvider, void 0]),
314
+ __metadata("design:returntype", Promise)
315
+ ], AcrossActionProvider.prototype, "bridgeToken", null);
316
+ __decorate([
317
+ (0, actionDecorator_1.CreateAction)({
318
+ name: "check_deposit_status",
319
+ description: `
320
+ This tool will check the status of a cross-chain bridge deposit on the Across Protocol.
321
+
322
+ It takes the following inputs:
323
+ - originChainId: The chain ID of the origin chain (defaults to the current chain)
324
+ - depositId: The ID of the deposit to check (returned by the bridge deposit transaction)
325
+ `,
326
+ schema: schemas_1.CheckDepositStatusSchema,
327
+ }),
328
+ __metadata("design:type", Function),
329
+ __metadata("design:paramtypes", [wallet_providers_1.EvmWalletProvider, void 0]),
330
+ __metadata("design:returntype", Promise)
331
+ ], AcrossActionProvider.prototype, "checkDepositStatus", null);
332
+ const acrossActionProvider = (config) => new AcrossActionProvider(config);
333
+ exports.acrossActionProvider = acrossActionProvider;