A plugin for Hedera Agent Kit that provides seamless integration with Bonzo Finance, an Aave v2βcompatible lending protocol on the Hedera network.
Bonzo Finance Labs is NOT responsible for any loss incurred by using this SDK plugin. This software is provided "as is" without warranty of any kind.
- Do Your Own Research (DYOR) before using this plugin
- Always test on testnet first before using on mainnet
- This plugin interacts with smart contracts and financial protocols
- Cryptocurrency transactions are irreversible
- Always verify contract addresses and parameters before executing transactions
- The authors and maintainers assume no liability for any losses, damages, or consequences arising from the use of this software
By using this plugin, you acknowledge that you understand the risks and agree to use it at your own discretion.
The Bonzo plugin enables AI agents to interact with the Bonzo lending protocol, providing comprehensive functionality for:
- Market Data: Fetch real-time market information (tokens, APYs, liquidity, utilization)
- Approve: Approve ERC20 tokens for Bonzo operations
- Deposit: Supply tokens to the lending pool
- Withdraw: Withdraw supplied tokens from the lending pool
- Borrow: Borrow tokens from the lending pool (stable or variable rate)
- Repay: Repay borrowed tokens
npm install @bonzofinancelabs/hak-bonzo-pluginimport { HederaLangchainToolkit, AgentMode } from "hedera-agent-kit";
import { bonzoPlugin } from "@bonzofinancelabs/hak-bonzo-plugin";
import { Client } from "@hashgraph/sdk";
const client = Client.forTestnet(); // or Client.forMainnet()
const toolkit = new HederaLangchainToolkit({
client,
configuration: {
context: { mode: AgentMode.AUTONOMOUS },
plugins: [bonzoPlugin],
tools: [],
},
});
const tools = toolkit.getTools();If you want to run the CLI example included in this repository:
# Clone the repository
git clone https://github.com/Bonzo-Labs/bonzoPlugin
cd bonzoPlugin
# Install dependencies
bun install
# Run CLI (testnet by default)
bun run src/index.ts
# Or specify network and operator
HEDERA_NETWORK=mainnet ACCOUNT_ID=0.0.x PRIVATE_KEY=0x... bun run src/index.ts
# Or use npm scripts (if npm is installed)
npm run startFetches real-time market data including supported tokens, supply/borrow APYs, liquidity, and utilization rates.
- Method:
bonzo_market_data_tool - Parameters: None
- Returns: Human-readable summary of all Bonzo markets
Example usage: "What are the current APYs for tokens on Bonzo?"
Approves the Bonzo LendingPool (or a custom spender) to spend a given ERC20 token.
- Method:
approve_erc20_tool
Required Parameters:
tokenSymbol: Token symbol (e.g., "USDC", "HBAR")amount: Amount to approve (human-readable number or string)
Optional Parameters:
spender: EVM address of spender (defaults to LendingPool address)useMax: Iftrue, approves maximum amount (type(uint256).max)
Example usage: "Approve 1000 USDC for Bonzo"
Supplies tokens to the Bonzo lending pool. Users earn supply APY on deposited tokens.
- Method:
bonzo_deposit_tool
Required Parameters:
tokenSymbol: Token symbol to depositamount: Amount to deposit (human-readable number or string)
Optional Parameters:
onBehalfOf: Hedera account ID to deposit on behalf of (defaults to caller's account)referralCode: Referral code (default: 0)
π‘ Note: You must approve the token before depositing. Use
approve_erc20_toolfirst.
Example usage: "Deposit 1000 USDC to Bonzo"
Withdraws previously supplied tokens from the Bonzo lending pool.
- Method:
bonzo_withdraw_tool
Required Parameters:
tokenSymbol: Token symbol to withdrawamount: Amount to withdraw (human-readable number or string)
Optional Parameters:
to: Hedera account ID to withdraw to (defaults to caller's account)withdrawAll: Iftrue, withdraws all available balance
Example usage: "Withdraw 500 USDC from Bonzo"
Borrows tokens from the Bonzo lending pool at either stable or variable interest rates.
- Method:
bonzo_borrow_tool
Required Parameters:
tokenSymbol: Token symbol to borrowamount: Amount to borrow (human-readable number or string)rateMode: Interest rate mode -"stable"or"variable"
Optional Parameters:
onBehalfOf: Hedera account ID to borrow on behalf of (defaults to caller's account)referralCode: Referral code (default: 0)
π‘ Note: You must have sufficient collateral deposited before borrowing.
Example usage: "Borrow 100 USDC at variable rate from Bonzo"
Repays borrowed tokens to the Bonzo lending pool.
- Method:
bonzo_repay_tool
Required Parameters:
tokenSymbol: Token symbol to repayamount: Amount to repay (human-readable number or string)rateMode: Interest rate mode -"stable"or"variable"(must match the original borrow)
Optional Parameters:
onBehalfOf: Hedera account ID to repay on behalf of (defaults to caller's account)repayAll: Iftrue, repays the entire borrowed amount
π‘ Note: You must approve the underlying token before repaying. Use
approve_erc20_toolfirst.
Example usage: "Repay 50 USDC variable rate debt on Bonzo"
All contract addresses are sourced from bonzo-contracts.json included with the plugin. The plugin automatically resolves addresses based on the network:
- Networks:
hedera_mainnetandhedera_testnetsections - Per-token addresses:
token(underlying ERC20),aToken,stableDebt,variableDebt - Core contracts:
LendingPool,LendingPoolAddressesProvider, oracles, helpers - Network detection: Automatically determined via the Hedera client (
client.ledgerId)
The plugin supports both Hedera Testnet and Mainnet. The network is determined by the Hashgraph SDK client configuration:
// For testnet
const client = Client.forTestnet();
// For mainnet
const client = Client.forMainnet();When using the CLI, set the HEDERA_NETWORK environment variable:
HEDERA_NETWORK=mainnet ACCOUNT_ID=0.0.x PRIVATE_KEY=0x... npm run startThe plugin supports both agent execution modes:
AUTONOMOUS: Transactions are executed on-chain and return receipt/transactionIdRETURN_BYTES: Transactions are frozen and return hex-encoded bytes for external signing
Configure via the Hedera Agent Kit context:
import { AgentMode } from "hedera-agent-kit";
const toolkit = new HederaLangchainToolkit({
client,
configuration: {
context: { mode: AgentMode.AUTONOMOUS }, // or AgentMode.RETURN_BYTES
plugins: [bonzoPlugin],
},
});- ABI Encoding: Uses
@ethersproject/abiInterfaces (Aave v2 function signatures) - Transaction Building: Hashgraph SDK
ContractExecuteTransaction - Gas & Fees: Configured with sensible defaults (customizable per tool)
import { bonzoPlugin, bonzoPluginToolNames } from "@bonzofinancelabs/hak-bonzo-plugin";
// In your agent context, the tools are automatically available
// The agent can call:
// 1. "Approve 1000 USDC for Bonzo"
// 2. "Deposit 1000 USDC to Bonzo"// Agent can execute:
// 1. "Borrow 100 USDC at variable rate from Bonzo"
// 2. "Repay 50 USDC variable rate debt on Bonzo"// Agent can execute:
// "Withdraw 500 USDC from Bonzo"import { HederaLangchainToolkit, AgentMode } from "hedera-agent-kit";
import { bonzoPlugin } from "@bonzofinancelabs/hak-bonzo-plugin";
import { Client, PrivateKey } from "@hashgraph/sdk";
const client = Client.forTestnet();
client.setOperator("0.0.xxxxx", PrivateKey.fromStringECDSA("0x..."));
const toolkit = new HederaLangchainToolkit({
client,
configuration: {
context: { mode: AgentMode.AUTONOMOUS },
plugins: [bonzoPlugin],
},
});
const tools = toolkit.getTools();
// Tools are now available for the agent to usebonzoPlugin/
βββ src/
β βββ plugin.ts # Plugin definition and exports
β βββ index.ts # CLI entry point
β βββ client.ts # LangChain agent factory
β βββ tools.ts # Market data tool
β βββ bonzo/
β β βββ bonzo-market-service.ts # Market API service
β β βββ bonzo.zod.ts # Zod parameter schemas
β β βββ utils.ts # Shared utilities
β βββ tools/
β βββ approve-erc20.ts # Approve tool
β βββ deposit.ts # Deposit tool
β βββ withdraw.ts # Withdraw tool
β βββ borrow.ts # Borrow tool
β βββ repay.ts # Repay tool
βββ bonzo-contracts.json # Contract addresses by network
βββ package.json
Required for CLI:
OPENAI_API_KEY: OpenAI API key for the agent LLM
Required for Autonomous Mode:
ACCOUNT_IDorHEDERA_ACCOUNT_ID: Hedera account IDPRIVATE_KEYorHEDERA_PRIVATE_KEY: ECDSA private key (0x... format)
Optional:
HEDERA_NETWORK: Network selection (testnet|mainnet, default:testnet)HAK_MODEorAGENT_MODE: Agent mode (autonomous|return_bytes, default:return_bytes)
- Never commit secrets or
.envfiles - Use environment variables or secure credential management
- Testnet is recommended for development and testing
Some assets may require token association on Hedera before executing actions. Ensure your Hedera account has associated the token or has auto-association enabled.
- Deposit: Requires approval of the underlying token before depositing
- Repay: Requires approval of the underlying token before repaying
- Testnet has fewer markets than mainnet
- Tools will provide clear error messages with available symbols if a token isn't configured on the selected network
For HBAR-native flows, wrapping/unwrapping may be needed via gateway contracts depending on Bonzo's implementation.
For programmatic access to tool names:
import { bonzoPluginToolNames } from "@bonzofinancelabs/hak-bonzo-plugin";
console.log(bonzoPluginToolNames.BONZO_MARKET_DATA_TOOL);
console.log(bonzoPluginToolNames.APPROVE_ERC20_TOOL);
console.log(bonzoPluginToolNames.BONZO_DEPOSIT_TOOL);
console.log(bonzoPluginToolNames.BONZO_WITHDRAW_TOOL);
console.log(bonzoPluginToolNames.BONZO_BORROW_TOOL);
console.log(bonzoPluginToolNames.BONZO_REPAY_TOOL);- Aave v2 Developer Docs - ABI references and function signatures
- Hedera Agent Kit Documentation - Plugin and tool development guide
- Bonzo Finance - Protocol website and documentation
MIT
Made with β€οΈ by Bonzo Finance Labs