|
1 | 1 | import type { IAgentRuntime, Memory, State } from "@elizaos/core";
|
| 2 | +import { |
| 3 | + composeContext, |
| 4 | + generateObjectDeprecated, |
| 5 | + ModelClass, |
| 6 | +} from "@elizaos/core"; |
2 | 7 | import {
|
3 | 8 | createConfig,
|
4 | 9 | executeRoute,
|
5 | 10 | ExtendedChain,
|
6 | 11 | getRoutes,
|
7 | 12 | } from "@lifi/sdk";
|
8 |
| -import { WalletProvider } from "../providers/wallet"; |
| 13 | + |
| 14 | +import { initWalletProvider, WalletProvider } from "../providers/wallet"; |
9 | 15 | import { bridgeTemplate } from "../templates";
|
10 | 16 | import type { BridgeParams, Transaction } from "../types";
|
| 17 | +import { parseEther } from "viem"; |
11 | 18 |
|
12 | 19 | export { bridgeTemplate };
|
13 | 20 |
|
@@ -54,7 +61,7 @@ export class BridgeAction {
|
54 | 61 | toChainId: this.walletProvider.getChainConfigs(params.toChain).id,
|
55 | 62 | fromTokenAddress: params.fromToken,
|
56 | 63 | toTokenAddress: params.toToken,
|
57 |
| - fromAmount: params.amount, |
| 64 | + fromAmount: parseEther(params.amount).toString(), |
58 | 65 | fromAddress: fromAddress,
|
59 | 66 | toAddress: params.toAddress || fromAddress,
|
60 | 67 | });
|
@@ -84,16 +91,56 @@ export const bridgeAction = {
|
84 | 91 | description: "Bridge tokens between different chains",
|
85 | 92 | handler: async (
|
86 | 93 | runtime: IAgentRuntime,
|
87 |
| - message: Memory, |
| 94 | + _message: Memory, |
88 | 95 | state: State,
|
89 |
| - options: any |
| 96 | + _options: any, |
| 97 | + callback?: any |
90 | 98 | ) => {
|
91 |
| - const privateKey = runtime.getSetting( |
92 |
| - "EVM_PRIVATE_KEY" |
93 |
| - ) as `0x${string}`; |
94 |
| - const walletProvider = new WalletProvider(privateKey); |
| 99 | + console.log("Bridge action handler called"); |
| 100 | + const walletProvider = initWalletProvider(runtime); |
95 | 101 | const action = new BridgeAction(walletProvider);
|
96 |
| - return action.bridge(options); |
| 102 | + |
| 103 | + // Compose bridge context |
| 104 | + const bridgeContext = composeContext({ |
| 105 | + state, |
| 106 | + template: bridgeTemplate, |
| 107 | + }); |
| 108 | + const content = await generateObjectDeprecated({ |
| 109 | + runtime, |
| 110 | + context: bridgeContext, |
| 111 | + modelClass: ModelClass.LARGE, |
| 112 | + }); |
| 113 | + |
| 114 | + const bridgeOptions: BridgeParams = { |
| 115 | + fromChain: content.fromChain, |
| 116 | + toChain: content.toChain, |
| 117 | + fromToken: content.token, |
| 118 | + toToken: content.token, |
| 119 | + toAddress: content.toAddress, |
| 120 | + amount: content.amount, |
| 121 | + }; |
| 122 | + |
| 123 | + try { |
| 124 | + const bridgeResp = await action.bridge(bridgeOptions); |
| 125 | + if (callback) { |
| 126 | + callback({ |
| 127 | + text: `Successfully bridge ${bridgeOptions.amount} ${bridgeOptions.fromToken} tokens from ${bridgeOptions.fromChain} to ${bridgeOptions.toChain}\nTransaction Hash: ${bridgeResp.hash}`, |
| 128 | + content: { |
| 129 | + success: true, |
| 130 | + hash: bridgeResp.hash, |
| 131 | + recipient: bridgeResp.to, |
| 132 | + chain: bridgeOptions.fromChain, |
| 133 | + }, |
| 134 | + }); |
| 135 | + } |
| 136 | + return true; |
| 137 | + } catch (error) { |
| 138 | + console.error("Error in bridge handler:", error.message); |
| 139 | + if (callback) { |
| 140 | + callback({ text: `Error: ${error.message}` }); |
| 141 | + } |
| 142 | + return false; |
| 143 | + } |
97 | 144 | },
|
98 | 145 | template: bridgeTemplate,
|
99 | 146 | validate: async (runtime: IAgentRuntime) => {
|
|
0 commit comments