@coinbase/agentkit 0.9.1 → 0.10.1

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 (151) hide show
  1. package/README.md +181 -54
  2. package/dist/action-providers/across/acrossActionProvider.js +3 -3
  3. package/dist/action-providers/cdp/cdpApiActionProvider.d.ts +3 -12
  4. package/dist/action-providers/cdp/cdpApiActionProvider.js +2 -79
  5. package/dist/action-providers/cdp/cdpApiActionProvider.test.js +0 -125
  6. package/dist/action-providers/cdp/cdpEvmWalletActionProvider.d.ts +58 -0
  7. package/dist/action-providers/cdp/cdpEvmWalletActionProvider.js +351 -0
  8. package/dist/action-providers/cdp/cdpEvmWalletActionProvider.test.d.ts +1 -0
  9. package/dist/action-providers/cdp/cdpEvmWalletActionProvider.test.js +520 -0
  10. package/dist/action-providers/cdp/cdpSmartWalletActionProvider.d.ts +57 -0
  11. package/dist/action-providers/cdp/cdpSmartWalletActionProvider.js +337 -0
  12. package/dist/action-providers/cdp/cdpSmartWalletActionProvider.test.d.ts +1 -0
  13. package/dist/action-providers/cdp/cdpSmartWalletActionProvider.test.js +463 -0
  14. package/dist/action-providers/cdp/index.d.ts +3 -0
  15. package/dist/action-providers/cdp/index.js +3 -0
  16. package/dist/action-providers/cdp/schemas.d.ts +38 -9
  17. package/dist/action-providers/cdp/schemas.js +49 -6
  18. package/dist/action-providers/cdp/spendPermissionUtils.d.ts +24 -0
  19. package/dist/action-providers/cdp/spendPermissionUtils.js +66 -0
  20. package/dist/action-providers/cdp/swapUtils.d.ts +32 -0
  21. package/dist/action-providers/cdp/swapUtils.js +142 -0
  22. package/dist/action-providers/clanker/clankerActionProvider.d.ts +43 -0
  23. package/dist/action-providers/clanker/clankerActionProvider.js +130 -0
  24. package/dist/action-providers/clanker/clankerActionProvider.test.d.ts +4 -0
  25. package/dist/action-providers/clanker/clankerActionProvider.test.js +119 -0
  26. package/dist/action-providers/clanker/index.d.ts +2 -0
  27. package/dist/action-providers/clanker/index.js +18 -0
  28. package/dist/action-providers/clanker/schemas.d.ts +56 -0
  29. package/dist/action-providers/clanker/schemas.js +47 -0
  30. package/dist/action-providers/clanker/utils.d.ts +9 -0
  31. package/dist/action-providers/clanker/utils.js +23 -0
  32. package/dist/action-providers/compound/constants.d.ts +1 -1
  33. package/dist/action-providers/compound/constants.js +2 -2
  34. package/dist/action-providers/erc20/constants.d.ts +35 -135
  35. package/dist/action-providers/erc20/constants.js +37 -189
  36. package/dist/action-providers/erc20/erc20ActionProvider.d.ts +9 -1
  37. package/dist/action-providers/erc20/erc20ActionProvider.js +87 -35
  38. package/dist/action-providers/erc20/erc20ActionProvider.test.js +115 -52
  39. package/dist/action-providers/erc20/schemas.d.ts +25 -12
  40. package/dist/action-providers/erc20/schemas.js +34 -6
  41. package/dist/action-providers/erc20/utils.d.ts +19 -0
  42. package/dist/action-providers/erc20/utils.js +54 -0
  43. package/dist/action-providers/flaunch/constants.d.ts +1 -1
  44. package/dist/action-providers/flaunch/constants.js +2 -2
  45. package/dist/action-providers/flaunch/flaunchActionProvider.js +3 -11
  46. package/dist/action-providers/flaunch/flaunchActionProvider.test.js +5 -0
  47. package/dist/action-providers/index.d.ts +4 -0
  48. package/dist/action-providers/index.js +4 -0
  49. package/dist/action-providers/jupiter/schemas.d.ts +1 -1
  50. package/dist/action-providers/moonwell/schemas.d.ts +2 -2
  51. package/dist/action-providers/morpho/morphoActionProvider.js +5 -5
  52. package/dist/action-providers/morpho/schemas.d.ts +2 -2
  53. package/dist/action-providers/pyth/pythActionProvider.js +5 -0
  54. package/dist/action-providers/pyth/pythActionProvider.test.js +5 -1
  55. package/dist/action-providers/superfluid/constants.d.ts +814 -0
  56. package/dist/action-providers/superfluid/constants.js +2826 -0
  57. package/dist/action-providers/superfluid/graphQueries/endpoints.d.ts +2 -0
  58. package/dist/action-providers/superfluid/graphQueries/endpoints.js +5 -0
  59. package/dist/action-providers/superfluid/graphQueries/queries.d.ts +1 -0
  60. package/dist/action-providers/superfluid/graphQueries/queries.js +35 -0
  61. package/dist/action-providers/superfluid/graphQueries/superfluidGraphQueries.d.ts +8 -0
  62. package/dist/action-providers/superfluid/graphQueries/superfluidGraphQueries.js +24 -0
  63. package/dist/action-providers/superfluid/graphQueries/types.d.ts +27 -0
  64. package/dist/action-providers/superfluid/graphQueries/types.js +2 -0
  65. package/dist/action-providers/superfluid/index.d.ts +7 -0
  66. package/dist/action-providers/superfluid/index.js +23 -0
  67. package/dist/action-providers/superfluid/schemas.d.ts +86 -0
  68. package/dist/action-providers/superfluid/schemas.js +103 -0
  69. package/dist/action-providers/superfluid/superfluidActionProvider.d.ts +20 -0
  70. package/dist/action-providers/superfluid/superfluidActionProvider.js +36 -0
  71. package/dist/action-providers/superfluid/superfluidPoolActionProvider.d.ts +46 -0
  72. package/dist/action-providers/superfluid/superfluidPoolActionProvider.js +143 -0
  73. package/dist/action-providers/superfluid/superfluidPoolActionProvider.test.d.ts +1 -0
  74. package/dist/action-providers/superfluid/superfluidPoolActionProvider.test.js +92 -0
  75. package/dist/action-providers/superfluid/superfluidQueryActionProvider.d.ts +27 -0
  76. package/dist/action-providers/superfluid/superfluidQueryActionProvider.js +71 -0
  77. package/dist/action-providers/superfluid/superfluidQueryActionProvider.test.d.ts +1 -0
  78. package/dist/action-providers/superfluid/superfluidQueryActionProvider.test.js +57 -0
  79. package/dist/action-providers/superfluid/superfluidStreamActionProvider.d.ts +56 -0
  80. package/dist/action-providers/superfluid/superfluidStreamActionProvider.js +191 -0
  81. package/dist/action-providers/superfluid/superfluidStreamActionProvider.test.d.ts +1 -0
  82. package/dist/action-providers/superfluid/superfluidStreamActionProvider.test.js +80 -0
  83. package/dist/action-providers/superfluid/superfluidSuperTokenCreatorActionProvider.d.ts +30 -0
  84. package/dist/action-providers/superfluid/superfluidSuperTokenCreatorActionProvider.js +108 -0
  85. package/dist/action-providers/superfluid/superfluidSuperTokenCreatorActionProvider.test.d.ts +1 -0
  86. package/dist/action-providers/superfluid/superfluidSuperTokenCreatorActionProvider.test.js +75 -0
  87. package/dist/action-providers/superfluid/superfluidWrapperActionProvider.d.ts +32 -0
  88. package/dist/action-providers/superfluid/superfluidWrapperActionProvider.js +101 -0
  89. package/dist/action-providers/superfluid/superfluidWrapperActionProvider.test.d.ts +1 -0
  90. package/dist/action-providers/superfluid/superfluidWrapperActionProvider.test.js +85 -0
  91. package/dist/action-providers/superfluid/utils/parseLogs.d.ts +18 -0
  92. package/dist/action-providers/superfluid/utils/parseLogs.js +78 -0
  93. package/dist/action-providers/truemarkets/truemarketsActionProvider.d.ts +4 -16
  94. package/dist/action-providers/truemarkets/truemarketsActionProvider.js +20 -41
  95. package/dist/action-providers/truemarkets/truemarketsActionProvider.test.js +11 -33
  96. package/dist/action-providers/wallet/walletActionProvider.js +21 -10
  97. package/dist/action-providers/wallet/walletActionProvider.test.js +6 -2
  98. package/dist/action-providers/zerion/constants.d.ts +1 -0
  99. package/dist/action-providers/zerion/constants.js +4 -0
  100. package/dist/action-providers/zerion/index.d.ts +2 -0
  101. package/dist/action-providers/zerion/index.js +18 -0
  102. package/dist/action-providers/zerion/schemas.d.ts +11 -0
  103. package/dist/action-providers/zerion/schemas.js +15 -0
  104. package/dist/action-providers/zerion/types.d.ts +125 -0
  105. package/dist/action-providers/zerion/types.js +16 -0
  106. package/dist/action-providers/zerion/utils.d.ts +3 -0
  107. package/dist/action-providers/zerion/utils.js +45 -0
  108. package/dist/action-providers/zerion/zerionActionProvider.d.ts +57 -0
  109. package/dist/action-providers/zerion/zerionActionProvider.js +159 -0
  110. package/dist/action-providers/zerion/zerionActionProvider.test.d.ts +1 -0
  111. package/dist/action-providers/zerion/zerionActionProvider.test.js +213 -0
  112. package/dist/action-providers/zeroX/index.d.ts +1 -0
  113. package/dist/action-providers/zeroX/index.js +17 -0
  114. package/dist/action-providers/zeroX/schemas.d.ts +51 -0
  115. package/dist/action-providers/zeroX/schemas.js +82 -0
  116. package/dist/action-providers/zeroX/utils.d.ts +23 -0
  117. package/dist/action-providers/zeroX/utils.js +106 -0
  118. package/dist/action-providers/zeroX/zeroXActionProvider.d.ts +57 -0
  119. package/dist/action-providers/zeroX/zeroXActionProvider.js +407 -0
  120. package/dist/action-providers/zeroX/zeroXActionProvider.test.d.ts +1 -0
  121. package/dist/action-providers/zeroX/zeroXActionProvider.test.js +445 -0
  122. package/dist/wallet-providers/cdpEvmWalletProvider.d.ts +20 -2
  123. package/dist/wallet-providers/cdpEvmWalletProvider.js +40 -15
  124. package/dist/wallet-providers/cdpShared.d.ts +9 -0
  125. package/dist/wallet-providers/cdpSmartWalletProvider.d.ts +29 -3
  126. package/dist/wallet-providers/cdpSmartWalletProvider.js +64 -28
  127. package/dist/wallet-providers/cdpSolanaWalletProvider.d.ts +1 -1
  128. package/dist/wallet-providers/cdpSolanaWalletProvider.js +7 -7
  129. package/dist/wallet-providers/cdpSolanaWalletProvider.test.js +15 -12
  130. package/dist/wallet-providers/evmWalletProvider.d.ts +5 -1
  131. package/dist/wallet-providers/legacyCdpSmartWalletProvider.d.ts +9 -2
  132. package/dist/wallet-providers/legacyCdpSmartWalletProvider.js +12 -2
  133. package/dist/wallet-providers/legacyCdpWalletProvider.d.ts +12 -2
  134. package/dist/wallet-providers/legacyCdpWalletProvider.js +11 -2
  135. package/dist/wallet-providers/privyEvmDelegatedEmbeddedWalletProvider.d.ts +10 -2
  136. package/dist/wallet-providers/privyEvmDelegatedEmbeddedWalletProvider.js +12 -3
  137. package/dist/wallet-providers/privyEvmDelegatedEmbeddedWalletProvider.test.js +1 -1
  138. package/dist/wallet-providers/privyEvmWalletProvider.d.ts +2 -0
  139. package/dist/wallet-providers/privyEvmWalletProvider.js +2 -1
  140. package/dist/wallet-providers/privyEvmWalletProvider.test.js +1 -1
  141. package/dist/wallet-providers/solanaKeypairWalletProvider.d.ts +1 -1
  142. package/dist/wallet-providers/solanaKeypairWalletProvider.js +3 -4
  143. package/dist/wallet-providers/solanaKeypairWalletProvider.test.js +4 -2
  144. package/dist/wallet-providers/viemWalletProvider.d.ts +12 -2
  145. package/dist/wallet-providers/viemWalletProvider.js +12 -3
  146. package/dist/wallet-providers/viemWalletProvider.test.js +6 -5
  147. package/dist/wallet-providers/walletProvider.d.ts +1 -1
  148. package/dist/wallet-providers/zeroDevWalletProvider.d.ts +10 -2
  149. package/dist/wallet-providers/zeroDevWalletProvider.js +14 -5
  150. package/dist/wallet-providers/zeroDevWalletProvider.test.js +2 -2
  151. package/package.json +4 -2
@@ -0,0 +1,58 @@
1
+ import { z } from "zod";
2
+ import { WalletProvider } from "../../wallet-providers";
3
+ import { CdpEvmWalletProvider } from "../../wallet-providers/cdpEvmWalletProvider";
4
+ import { ActionProvider } from "../actionProvider";
5
+ import { UseSpendPermissionSchema, ListSpendPermissionsSchema, SwapSchema } from "./schemas";
6
+ import type { Network } from "../../network";
7
+ /**
8
+ * CdpEvmWalletActionProvider is an action provider for CDP EVM Wallet specific actions.
9
+ *
10
+ * This provider is scoped specifically to EVM wallets and provides actions
11
+ * that are optimized for EVM functionality, including spend permission usage.
12
+ */
13
+ export declare class CdpEvmWalletActionProvider extends ActionProvider<CdpEvmWalletProvider> {
14
+ /**
15
+ * Constructor for the CdpEvmWalletActionProvider class.
16
+ */
17
+ constructor();
18
+ /**
19
+ * Lists spend permissions for a smart account.
20
+ *
21
+ * @param walletProvider - The server wallet provider to use for listing permissions.
22
+ * @param args - The input arguments for listing spend permissions.
23
+ * @returns A list of spend permissions available to the current wallet.
24
+ */
25
+ listSpendPermissions(walletProvider: WalletProvider, args: z.infer<typeof ListSpendPermissionsSchema>): Promise<string>;
26
+ /**
27
+ * Uses a spend permission to transfer tokens from a smart account to the current EVM wallet.
28
+ *
29
+ * @param walletProvider - The EVM wallet provider to use for the spend operation.
30
+ * @param args - The input arguments for using the spend permission.
31
+ * @returns A confirmation message with transaction details.
32
+ */
33
+ useSpendPermission(walletProvider: CdpEvmWalletProvider, args: z.infer<typeof UseSpendPermissionSchema>): Promise<string>;
34
+ /**
35
+ * Gets a price quote for swapping tokens using the CDP Swap API.
36
+ *
37
+ * @param walletProvider - The EVM wallet provider to get the quote for.
38
+ * @param args - The input arguments for the swap price action.
39
+ * @returns A JSON string with detailed swap price quote information.
40
+ */
41
+ getSwapPrice(walletProvider: CdpEvmWalletProvider, args: z.infer<typeof SwapSchema>): Promise<string>;
42
+ /**
43
+ * Swaps tokens using the CDP client.
44
+ *
45
+ * @param walletProvider - The EVM wallet provider to perform the swap with.
46
+ * @param args - The input arguments for the swap action.
47
+ * @returns A JSON string with detailed swap execution information.
48
+ */
49
+ swap(walletProvider: CdpEvmWalletProvider, args: z.infer<typeof SwapSchema>): Promise<string>;
50
+ /**
51
+ * Checks if the EVM wallet action provider supports the given network.
52
+ *
53
+ * @param network - The network to check.
54
+ * @returns True if the EVM wallet action provider supports the network, false otherwise.
55
+ */
56
+ supportsNetwork: (network: Network) => boolean;
57
+ }
58
+ export declare const cdpEvmWalletActionProvider: () => CdpEvmWalletActionProvider;
@@ -0,0 +1,351 @@
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
+ Object.defineProperty(exports, "__esModule", { value: true });
12
+ exports.cdpEvmWalletActionProvider = exports.CdpEvmWalletActionProvider = void 0;
13
+ const zod_1 = require("zod");
14
+ const wallet_providers_1 = require("../../wallet-providers");
15
+ const cdpShared_1 = require("../../wallet-providers/cdpShared");
16
+ const cdpEvmWalletProvider_1 = require("../../wallet-providers/cdpEvmWalletProvider");
17
+ const actionDecorator_1 = require("../actionDecorator");
18
+ const actionProvider_1 = require("../actionProvider");
19
+ const schemas_1 = require("./schemas");
20
+ const spendPermissionUtils_1 = require("./spendPermissionUtils");
21
+ const swapUtils_1 = require("./swapUtils");
22
+ const viem_1 = require("viem");
23
+ /**
24
+ * CdpEvmWalletActionProvider is an action provider for CDP EVM Wallet specific actions.
25
+ *
26
+ * This provider is scoped specifically to EVM wallets and provides actions
27
+ * that are optimized for EVM functionality, including spend permission usage.
28
+ */
29
+ class CdpEvmWalletActionProvider extends actionProvider_1.ActionProvider {
30
+ /**
31
+ * Constructor for the CdpEvmWalletActionProvider class.
32
+ */
33
+ constructor() {
34
+ super("cdp_evm_wallet", []);
35
+ /**
36
+ * Checks if the EVM wallet action provider supports the given network.
37
+ *
38
+ * @param network - The network to check.
39
+ * @returns True if the EVM wallet action provider supports the network, false otherwise.
40
+ */
41
+ this.supportsNetwork = (network) => {
42
+ // EVM wallets support EVM networks in general
43
+ return network.protocolFamily === "evm";
44
+ };
45
+ }
46
+ /**
47
+ * Lists spend permissions for a smart account.
48
+ *
49
+ * @param walletProvider - The server wallet provider to use for listing permissions.
50
+ * @param args - The input arguments for listing spend permissions.
51
+ * @returns A list of spend permissions available to the current wallet.
52
+ */
53
+ async listSpendPermissions(walletProvider, args) {
54
+ const network = walletProvider.getNetwork();
55
+ if ((0, cdpShared_1.isWalletProviderWithClient)(walletProvider)) {
56
+ if (network.protocolFamily === "evm") {
57
+ return await (0, spendPermissionUtils_1.listSpendPermissionsForSpender)(walletProvider.getClient(), args.smartAccountAddress, walletProvider.getAddress());
58
+ }
59
+ else {
60
+ return "Spend permissions are currently only supported on EVM networks.";
61
+ }
62
+ }
63
+ else {
64
+ return "Wallet provider is not a CDP Wallet Provider.";
65
+ }
66
+ }
67
+ /**
68
+ * Uses a spend permission to transfer tokens from a smart account to the current EVM wallet.
69
+ *
70
+ * @param walletProvider - The EVM wallet provider to use for the spend operation.
71
+ * @param args - The input arguments for using the spend permission.
72
+ * @returns A confirmation message with transaction details.
73
+ */
74
+ async useSpendPermission(walletProvider, args) {
75
+ const network = walletProvider.getNetwork();
76
+ const cdpNetwork = walletProvider.getCdpSdkNetwork();
77
+ if ((0, cdpShared_1.isWalletProviderWithClient)(walletProvider)) {
78
+ if (network.protocolFamily === "evm") {
79
+ try {
80
+ const spenderAddress = walletProvider.getAddress();
81
+ const permission = await (0, spendPermissionUtils_1.findLatestSpendPermission)(walletProvider.getClient(), args.smartAccountAddress, spenderAddress);
82
+ const account = await walletProvider.getClient().evm.getAccount({
83
+ address: spenderAddress,
84
+ });
85
+ const spendResult = await account.useSpendPermission({
86
+ spendPermission: permission,
87
+ value: BigInt(args.value),
88
+ network: cdpNetwork,
89
+ });
90
+ return `Successfully spent ${args.value} tokens using spend permission. Transaction hash: ${spendResult.transactionHash}`;
91
+ }
92
+ catch (error) {
93
+ return `Failed to use spend permission: ${error}`;
94
+ }
95
+ }
96
+ else {
97
+ return "Spend permissions are currently only supported on EVM networks.";
98
+ }
99
+ }
100
+ else {
101
+ return "Wallet provider is not a CDP Wallet Provider.";
102
+ }
103
+ }
104
+ /**
105
+ * Gets a price quote for swapping tokens using the CDP Swap API.
106
+ *
107
+ * @param walletProvider - The EVM wallet provider to get the quote for.
108
+ * @param args - The input arguments for the swap price action.
109
+ * @returns A JSON string with detailed swap price quote information.
110
+ */
111
+ async getSwapPrice(walletProvider, args) {
112
+ // Get CDP SDK network
113
+ const network = walletProvider.getNetwork();
114
+ const networkId = network.networkId;
115
+ const cdpNetwork = walletProvider.getCdpSdkNetwork();
116
+ // Check if the network is supported
117
+ if (networkId !== "base-mainnet" && networkId !== "ethereum-mainnet")
118
+ return JSON.stringify({
119
+ success: false,
120
+ error: "CDP Swap API is currently only supported on 'base-mainnet' or 'ethereum-mainnet'.",
121
+ });
122
+ try {
123
+ // Get token details
124
+ const { fromTokenDecimals, toTokenDecimals, fromTokenName, toTokenName } = await (0, swapUtils_1.getTokenDetails)(walletProvider, args.fromToken, args.toToken);
125
+ // Get swap price quote
126
+ const swapPrice = (await walletProvider.getClient().evm.getSwapPrice({
127
+ fromToken: args.fromToken,
128
+ toToken: args.toToken,
129
+ fromAmount: (0, viem_1.parseUnits)(args.fromAmount, fromTokenDecimals),
130
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
131
+ network: cdpNetwork,
132
+ taker: walletProvider.getAddress(),
133
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
134
+ }));
135
+ const formattedResponse = {
136
+ success: true,
137
+ fromAmount: args.fromAmount,
138
+ fromTokenName: fromTokenName,
139
+ fromToken: args.fromToken,
140
+ toAmount: (0, viem_1.formatUnits)(swapPrice.toAmount, toTokenDecimals),
141
+ minToAmount: (0, viem_1.formatUnits)(swapPrice.minToAmount, toTokenDecimals),
142
+ toTokenName: toTokenName,
143
+ toToken: args.toToken,
144
+ slippageBps: args.slippageBps,
145
+ liquidityAvailable: swapPrice.liquidityAvailable,
146
+ balanceEnough: swapPrice.issues.balance === undefined,
147
+ priceOfBuyTokenInSellToken: (Number(args.fromAmount) / Number((0, viem_1.formatUnits)(swapPrice.toAmount, toTokenDecimals))).toString(),
148
+ priceOfSellTokenInBuyToken: (Number((0, viem_1.formatUnits)(swapPrice.toAmount, toTokenDecimals)) / Number(args.fromAmount)).toString(),
149
+ };
150
+ return JSON.stringify(formattedResponse);
151
+ }
152
+ catch (error) {
153
+ return JSON.stringify({
154
+ success: false,
155
+ error: `Error fetching swap price: ${error}`,
156
+ });
157
+ }
158
+ }
159
+ /**
160
+ * Swaps tokens using the CDP client.
161
+ *
162
+ * @param walletProvider - The EVM wallet provider to perform the swap with.
163
+ * @param args - The input arguments for the swap action.
164
+ * @returns A JSON string with detailed swap execution information.
165
+ */
166
+ async swap(walletProvider, args) {
167
+ // Get CDP SDK network
168
+ const network = walletProvider.getNetwork();
169
+ const networkId = network.networkId;
170
+ const cdpNetwork = walletProvider.getCdpSdkNetwork();
171
+ // Check if the network is supported
172
+ if (networkId !== "base-mainnet" && networkId !== "ethereum-mainnet")
173
+ return JSON.stringify({
174
+ success: false,
175
+ error: "CDP Swap API is currently only supported on 'base-mainnet' or 'ethereum-mainnet'.",
176
+ });
177
+ try {
178
+ // Get token details
179
+ const { fromTokenDecimals, fromTokenName, toTokenName, toTokenDecimals } = await (0, swapUtils_1.getTokenDetails)(walletProvider, args.fromToken, args.toToken);
180
+ // Get the account
181
+ const account = await walletProvider.getClient().evm.getAccount({
182
+ address: walletProvider.getAddress(),
183
+ });
184
+ // Estimate swap price first to check liquidity, token balance and permit2 approval status
185
+ const swapPrice = await walletProvider.getClient().evm.getSwapPrice({
186
+ fromToken: args.fromToken,
187
+ toToken: args.toToken,
188
+ fromAmount: (0, viem_1.parseUnits)(args.fromAmount, fromTokenDecimals),
189
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
190
+ network: cdpNetwork,
191
+ taker: account.address,
192
+ });
193
+ // Check if liquidity is available
194
+ if (!swapPrice.liquidityAvailable) {
195
+ return JSON.stringify({
196
+ success: false,
197
+ error: `No liquidity available to swap ${args.fromAmount} ${fromTokenName} (${args.fromToken}) to ${toTokenName} (${args.toToken})`,
198
+ });
199
+ }
200
+ // Check if balance is enough
201
+ if (swapPrice.issues.balance) {
202
+ return JSON.stringify({
203
+ success: false,
204
+ error: `Balance is not enough to perform swap. Required: ${args.fromAmount} ${fromTokenName}, but only have ${(0, viem_1.formatUnits)(swapPrice.issues.balance.currentBalance, fromTokenDecimals)} ${fromTokenName} (${args.fromToken})`,
205
+ });
206
+ }
207
+ // Check if allowance is enough
208
+ let approvalTxHash = null;
209
+ if (swapPrice.issues.allowance) {
210
+ try {
211
+ approvalTxHash = await walletProvider.sendTransaction({
212
+ to: args.fromToken,
213
+ data: (0, viem_1.encodeFunctionData)({
214
+ abi: viem_1.erc20Abi,
215
+ functionName: "approve",
216
+ args: [swapUtils_1.PERMIT2_ADDRESS, viem_1.maxUint256],
217
+ }),
218
+ });
219
+ const receipt = await walletProvider.waitForTransactionReceipt(approvalTxHash);
220
+ if (receipt.status !== "success") {
221
+ return JSON.stringify({
222
+ success: false,
223
+ error: `Approval transaction failed`,
224
+ });
225
+ }
226
+ }
227
+ catch (error) {
228
+ return JSON.stringify({
229
+ success: false,
230
+ error: `Error approving token: ${error}`,
231
+ });
232
+ }
233
+ }
234
+ // Execute swap using the all-in-one pattern with retry logic
235
+ const swapResult = await (0, swapUtils_1.retryWithExponentialBackoff)(async () => {
236
+ return (await account.swap({
237
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
238
+ network: cdpNetwork,
239
+ fromToken: args.fromToken,
240
+ toToken: args.toToken,
241
+ fromAmount: (0, viem_1.parseUnits)(args.fromAmount, fromTokenDecimals),
242
+ slippageBps: args.slippageBps,
243
+ signerAddress: account.address,
244
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
245
+ }));
246
+ }, 3, 5000); // Max 3 retries with 5s base delay
247
+ // Check if swap was successful
248
+ const swapReceipt = await walletProvider.waitForTransactionReceipt(swapResult.transactionHash);
249
+ if (swapReceipt.status !== "success") {
250
+ return JSON.stringify({
251
+ success: false,
252
+ error: `Swap transaction failed`,
253
+ });
254
+ }
255
+ // Format the successful response
256
+ const formattedResponse = {
257
+ success: true,
258
+ ...(approvalTxHash ? { approvalTxHash } : {}),
259
+ transactionHash: swapResult.transactionHash,
260
+ fromAmount: args.fromAmount,
261
+ fromTokenName: fromTokenName,
262
+ fromToken: args.fromToken,
263
+ toAmount: (0, viem_1.formatUnits)(swapPrice.toAmount, toTokenDecimals),
264
+ minToAmount: (0, viem_1.formatUnits)(swapPrice.minToAmount, toTokenDecimals),
265
+ toTokenName: toTokenName,
266
+ toToken: args.toToken,
267
+ slippageBps: args.slippageBps,
268
+ network: networkId,
269
+ };
270
+ return JSON.stringify(formattedResponse);
271
+ }
272
+ catch (error) {
273
+ return JSON.stringify({
274
+ success: false,
275
+ error: `Swap failed: ${error}`,
276
+ });
277
+ }
278
+ }
279
+ }
280
+ exports.CdpEvmWalletActionProvider = CdpEvmWalletActionProvider;
281
+ __decorate([
282
+ (0, actionDecorator_1.CreateAction)({
283
+ name: "list_spend_permissions",
284
+ description: `This tool lists spend permissions that have been granted to the current EVM wallet by a smart account.
285
+ It takes a smart account address and returns spend permissions where the current EVM wallet is the spender.
286
+ This is useful to see what spending allowances have been granted before using them.
287
+ This action is specifically designed for EVM wallets.`,
288
+ schema: schemas_1.ListSpendPermissionsSchema,
289
+ }),
290
+ __metadata("design:type", Function),
291
+ __metadata("design:paramtypes", [wallet_providers_1.WalletProvider, void 0]),
292
+ __metadata("design:returntype", Promise)
293
+ ], CdpEvmWalletActionProvider.prototype, "listSpendPermissions", null);
294
+ __decorate([
295
+ (0, actionDecorator_1.CreateAction)({
296
+ name: "use_spend_permission",
297
+ description: `This tool uses a spend permission to spend tokens on behalf of a smart account that the current EVM wallet has permission to spend.
298
+ It automatically finds the latest valid spend permission granted by the smart account to the current EVM wallet and uses it to spend the specified amount.
299
+ The smart account must have previously granted a spend permission to the current EVM wallet using createSpendPermission.
300
+ This action is specifically designed for EVM wallets and uses the EVM wallet for spend permission execution.`,
301
+ schema: schemas_1.UseSpendPermissionSchema,
302
+ }),
303
+ __metadata("design:type", Function),
304
+ __metadata("design:paramtypes", [cdpEvmWalletProvider_1.CdpEvmWalletProvider, void 0]),
305
+ __metadata("design:returntype", Promise)
306
+ ], CdpEvmWalletActionProvider.prototype, "useSpendPermission", null);
307
+ __decorate([
308
+ (0, actionDecorator_1.CreateAction)({
309
+ name: "get_swap_price",
310
+ description: `
311
+ This tool fetches a price quote for swapping (trading) between two tokens using the CDP Swap API but does not execute a swap.
312
+ It takes the following inputs:
313
+ - fromToken: The contract address of the token to sell
314
+ - toToken: The contract address of the token to buy
315
+ - fromAmount: The amount of fromToken to swap in whole units (e.g. 1 ETH or 10.5 USDC)
316
+ - slippageBps: (Optional) Maximum allowed slippage in basis points (100 = 1%)
317
+ Important notes:
318
+ - The contract address for native ETH is "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"
319
+ - Use fromAmount units exactly as provided, do not convert to wei or any other units
320
+ - Never assume token or address, they have to be provided as inputs. If only token symbol is provided, use the get_token_address tool if available to get the token address first
321
+ `,
322
+ schema: schemas_1.SwapSchema,
323
+ }),
324
+ __metadata("design:type", Function),
325
+ __metadata("design:paramtypes", [cdpEvmWalletProvider_1.CdpEvmWalletProvider, void 0]),
326
+ __metadata("design:returntype", Promise)
327
+ ], CdpEvmWalletActionProvider.prototype, "getSwapPrice", null);
328
+ __decorate([
329
+ (0, actionDecorator_1.CreateAction)({
330
+ name: "swap",
331
+ description: `
332
+ This tool executes a token swap (trade) using the CDP Swap API.
333
+ It takes the following inputs:
334
+ - fromToken: The contract address of the token to sell
335
+ - toToken: The contract address of the token to buy
336
+ - fromAmount: The amount of fromToken to swap in whole units (e.g. 1 ETH or 10.5 USDC)
337
+ - slippageBps: (Optional) Maximum allowed slippage in basis points (100 = 1%)
338
+ Important notes:
339
+ - The contract address for native ETH is "0xeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeeee"
340
+ - If needed, it will automatically approve the permit2 contract to spend the fromToken
341
+ - Use fromAmount units exactly as provided, do not convert to wei or any other units.
342
+ - Never assume token or address, they have to be provided as inputs. If only token symbol is provided, use the get_token_address tool if available to get the token address first
343
+ `,
344
+ schema: schemas_1.SwapSchema,
345
+ }),
346
+ __metadata("design:type", Function),
347
+ __metadata("design:paramtypes", [cdpEvmWalletProvider_1.CdpEvmWalletProvider, void 0]),
348
+ __metadata("design:returntype", Promise)
349
+ ], CdpEvmWalletActionProvider.prototype, "swap", null);
350
+ const cdpEvmWalletActionProvider = () => new CdpEvmWalletActionProvider();
351
+ exports.cdpEvmWalletActionProvider = cdpEvmWalletActionProvider;