Multiple specialized autonomous AI agents with powerful tools work together to analyze, recommend, and execute optimal DeFi strategies while maintaining user-defined risk parameters and portfolio goals currently live on Avalanche , Mode , Starknet powered by Brian AI and LangChain
- risk parameters and portfolio balance
- Provides real-time feedback and execution status
Managing DeFi portfolios across multiple protocols on Avalanche can be complex and time-consuming.
Users need to:
- Monitor multiple positions across different protocols
- Execute complex multi-step transactions
- Stay updated with the latest crosschain yield opportunities
- Maintain desired portfolio allocations
- React quickly to market changes
An autonomous AI agent that manages your Avalanche DeFi portfolio by:
- Understanding high-level goals in natural language
- Breaking down complex operations into executable steps
- Automatically executing transactions when needed
- Providing real-time updates and progress tracking
- Maintaining portfolio balance according to user preferences
- Express portfolio goals in plain English
- No need to understand complex DeFi terminology
- AI translates intentions into actions
- Breaks down complex goals into steps
- Executes transactions automatically
- Handles error recovery
- Provides progress updates
- Multi-protocol position monitoring
- Yield optimization
- Risk management
- Rebalancing capabilities
- Live execution status
- Progress tracking
- Transaction confirmations
- Performance metrics
- Execute and monitor complex workflows
- Orchestrate multi-step operations
- Integrate with external APIs
- Handle errors and retries
This integration enables:
- Workflow Orchestration: Agents can now trigger and monitor complex multi-step operations through Kestra workflows.
- Error Handling: Built-in retry mechanisms and error handling through Kestra's execution engine
- Monitoring: Track execution status and progress of complex operations
- Scalability: Leverage Kestra's distributed execution capabilities for resource-intensive tasks.
The agents can now handle complex operations like portfolio rebalancing by:
- Breaking down operations into discrete tasks
- Executing them in the correct order
- Handling failures and retries
- Providing real-time status updates
This makes the agents more robust and capable of handling complex DeFi operations in a reliable, monitored way.
The portfolio manager integrates with Eigenlayer's Actively Validated Service (AVS) to provide decentralized portfolio validation:
-
PortfolioValidationServiceManager
- Manages portfolio validation tasks
- Handles operator registrations and responses
- Validates operator signatures
- Maintains token registry and eligibility data
-
PortfolioTask
- Defines portfolio validation task structure
- Tracks task status and responses
- Supports multiple validation strategies:
- TokenEligibility
- PortfolioBalance
- RiskAssessment
-
PortfolioDeployer
- Deploys and initializes AVS contracts
- Sets up stake registry
- Configures operator quorum
- Manages token strategy deployment
-
Deployment Library
- Handles proxy deployment
- Manages contract upgrades
- Stores deployment configurations
The subgraph indexes and tracks portfolio validation events and data:
type Portfolio @entity {
id: Bytes!
taskId: BigInt!
tokens: [Token!]!
amounts: [BigInt!]!
strategy: String!
validationType: Int!
status: Int!
createdAt: BigInt!
validations: [Validation!]!
}
type Token @entity {
id: Bytes!
chain: String!
address: Bytes!
isEligible: Boolean!
metadata: String
createdBlock: BigInt!
portfolios: [Portfolio!]!
}
type Validation @entity {
id: Bytes!
portfolio: Portfolio!
operator: Bytes!
validation: Bytes!
timestamp: BigInt!
}
- NewPortfolioTask: Indexes new portfolio validation requests
- ValidationSubmitted: Tracks operator validations
- TokenDataUpdated: Monitors token eligibility updates
-
Portfolio Creation
- User submits portfolio through Ava
- AVS creates validation task
- Event emitted and indexed by subgraph
-
Validation Process
- Operators submit validations
- AVS verifies signatures
- Subgraph indexes validation responses
-
Data Analysis
- Ava queries subgraph for validation data
- AI analyzes validation responses
- Generates recommendations based on consensus
-
Token Management
- AVS maintains token registry
- Updates token eligibility
- Subgraph provides token analytics
- Decentralized Validation: Multiple operators validate portfolio decisions
- Transparent History: All validations and updates are publicly trackable
- Real-time Analytics: Quick access to historical validation data
- Scalable Architecture: Handles multiple portfolios and validation strategies
- Secure Operations: Cryptographic verification of operator responses
- Frontend: Next.js, TypeScript, TailwindCSS
- AI Engine: Brian AI, LangChain, GPT-4
- Blockchain: Avalanche C-Chain, Teleporter, Eigenlayer AVS
- Development: Foundry, Avalanche CLI
- Indexing: The Graph Protocol
I'll update the Example Use Cases section in the README.md based on the example scenarios from page.tsx:
## π Example Use Cases
### 1. Portfolio Optimization
```text
User: "I have 10 AVAX and want to optimize my portfolio between lending, liquidity provision, and trading. What's the best strategy right now?"
Agent Collaboration Flow:
1. Portfolio Manager analyzes request and current market conditions
2. DeFi Analytics Agent provides real-time data:
- Aave AVAX lending APY: 1.77%
- Uniswap AVAX-USDC pool APR: 43.893%
- Curve Blizz pool APY: 1.58%
- DeFi TVL trend: +5% weekly
3. Trading Agent evaluates market opportunities
4. Liquidity Agent assesses pool stability
5. Portfolio Manager provides final allocation strategy
User: "Find me the highest yield opportunities while maintaining moderate risk levels"
Agent Collaboration Flow:
1. Portfolio Manager evaluates risk parameters
2. DeFi Analytics Agent scans protocols:
- Protocol TVL analysis
- Smart contract audit status
- Historical yield stability
3. Risk Assessment Agent performs:
- Protocol risk scoring
- Impermanent loss calculation
- Market volatility analysis
4. Final recommendation with risk-adjusted returns
User: "Distribute 5000 USDC across lending platforms for the best risk-adjusted returns"
Agent Collaboration Flow:
1. DeFi Analytics Agent scans lending markets:
- Protocol-specific APYs
- Total deposits
- Utilization rates
2. Risk Agent evaluates:
- Protocol security
- Market conditions
- Collateral factors
3. Portfolio Manager executes:
- Optimal distribution
- Position monitoring
- Auto-rebalancing setup
User: "Monitor and rebalance my portfolio to maintain 40% AVAX, 30% ETH, 30% stables"
Agent Collaboration Flow:
1. Portfolio Manager tracks allocations
2. Trading Agent monitors:
- Price movements
- Trading volumes
- Market depth
3. DeFi Analytics provides:
- Gas optimization data
- Slippage estimates
- Best execution routes
4. Automated rebalancing when:
- Deviation exceeds 5%
- Gas costs are optimal
- Market conditions favorable
### 5. Yield Optimization
```text
User: "Optimize my stablecoin yields while maintaining 50% USDC and 50% USDT split"
Agent will:
1. Analyze current positions
2. Scout highest yield opportunities
3. Execute necessary swaps
4. Deploy to optimal protocols
5. Monitor and rebalance as needed
User: "Rebalance my portfolio to 30% ETH, 30% AVAX, and 40% stables"
Agent will:
1. Calculate required trades
2. Find optimal execution paths
3. Execute trades in optimal order
4. Confirm final allocations
5. Report completion
User: "Bridge 1000 USDC from Ethereum to Avalanche and deploy to highest yield"
Agent will:
1. Initiate bridge transaction
2. Monitor bridge status
3. Receive funds on Avalanche
4. Research yield opportunities
5. Deploy to best protocol
Key enhancements:
- Added support for yield/APY data:
- Get current yields across all pools
- Track historical yield performance
- Filter by chain, protocol, or asset type
- Added DEX volume tracking:
- Monitor daily and total volumes
- Break down by chain and protocol
- Track historical volume trends
- Added token pricing capabilities:
- Get current prices for any token
- Track historical price data
- Support for multiple chains
- Added stablecoin analytics:
- Monitor stablecoin market caps
- Track peg stability
- Analyze distribution across chains
- Enhanced TVL tracking:
- Historical TVL data
- Chain and protocol breakdowns
- Token composition analysis
- Clone the repository
git clone https://github.com/kamalbuilds/ava-portfolio-manager-ai-agent
- Install dependencies
cd frontend
npm install
- Set up environment variables
NEXT_PUBLIC_BRIAN_API_KEY=your_brian_api_key
NEXT_PUBLIC_PRIVATE_KEY=your_private_key
NEXT_PUBLIC_OPENAI_API_KEY=your_openai_api_key
- Run the development server
npm run dev
MIT
Contributions are welcome! Please read our contributing guidelines before submitting PRs.
## β Key Features
### π§ Intelligent Portfolio Management
- Natural language interaction
- Autonomous strategy execution
- Real-time portfolio analysis
- Risk-aware decision making
- Multi-protocol optimization
### πΌ Portfolio Operations
- Token swaps
- Liquidity provision
- Yield farming
- Risk rebalancing
- Position management
### π Monitoring & Feedback
- Real-time execution status
- Progress tracking
- Transaction confirmations
- Performance metrics
- Risk alerts
## ποΈ Architecture
```mermaid
graph TD
A[User Interface] --> B[Next.js Frontend]
B --> C[Brian AI Agent]
C --> D[LangChain]
D --> E[OpenAI GPT-4]
C --> F[Brian Toolkit]
F --> G[Avalanche Network]
subgraph "Core Components"
C
D
E
F
end
subgraph "Blockchain Layer"
G --> H[TraderJoe]
G --> I[Other DEXs]
G --> J[Lending Protocols]
end
subgraph "Monitoring"
C --> K[Status Updates]
C --> L[Progress Tracking]
C --> M[Transaction History]
end
- Frontend: Next.js, TypeScript, TailwindCSS
- AI/ML: Brian AI, LangChain, GPT-4
- Blockchain: Avalanche Network, TraderJoe DEX
- Development: Node.js, Ethers.js
# Required environment variables
NEXT_PUBLIC_BRIAN_API_KEY=your_brian_api_key
NEXT_PUBLIC_PRIVATE_KEY=your_private_key
NEXT_PUBLIC_OPENAI_API_KEY=your_openai_api_key
User: "Optimize my portfolio for maximum yield while maintaining 30% in stablecoins"
Agent will:
1. Analyze current holdings
2. Identify highest yield opportunities
3. Calculate optimal allocations
4. Execute required swaps
5. Deploy capital to yield protocols
6. Maintain stability ratio
User: "Reduce portfolio risk and move to defensive positions"
Agent will:
1. Evaluate current risk metrics
2. Identify high-risk positions
3. Plan exit strategies
4. Execute position closures
5. Reallocate to stable assets
6. Confirm risk reduction
User: "Take advantage of AVAX price dip with 20% of portfolio"
Agent will:
1. Check current AVAX price
2. Calculate optimal entry points
3. Identify assets to swap
4. Execute DHere's a comprehensive README.md for your Avalanche Portfolio Manager AI Agent.
This starter kit will get you started with developing solidity smart contract dApps on the C-Chain or on an Avalanche L1. It provides all tools to build cross-L1 dApps using Teleporter. It includes:
- **Avalanche CLI**: Run a local Avalanche Network
- **Foundry**:
- Forge: Compile and Deploy smart contracts to the local network, Fuji Testnet or Mainnet
- Cast: Interact with these smart contracts
- **Teleporter**: All contracts you may want to interact with Teleporter
- **AWM Relayer**: The binary to run your own relayer
- **Examples**: Contracts showcasing how to achieve common patterns, such as sending simple messages, call functions of a contract on another blockchain and bridging assets. Please note that these example contracts have not been audited and are for educational purposes only
- **BuilderKit**: A component library providing UI elements for ICTT bridges, Cross-Chain swaps, ...
## Set Up
This starter kit utilizes a Dev Container specification. Dev Containers use containerization to create consistent and isolated development environments. All of the above mentioned components are pre-installed in that container. These containers can be run using GitHub Codespaces or locally using Docker and VS Code. You can switch back and forth between the two options.
### Run on Github Codespace
You can run them directly on Github by clicking **Code**, switching to the **Codespaces** tab and clicking **Create codespace on main**. A new window will open that loads the codespace. Afterwards you will see a browser version of VS code with all the dependencies installed. Codespace time out after some time of inactivity, but can be restarted.
### Run Dev Container locally with Docker
Alternatively, you can run them locally. You need [docker](https://www.docker.com/products/docker-desktop/) installed and [VS Code](https://code.visualstudio.com/) with the extensions [Dev Container extension](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers). Then clone the repository and open it in VS Code. VS Code will ask you if you want to reopen the project in a container.
## Starting a local Avalanche Network
To start a local Avalanche network with your own teleporter-enabled L1 inside the container follow these commands. Your Avalanche network will be completely independent of the Avalanche Mainnet and Fuji Testnet. It will have its own Primary Network (C-Chain, X-Chain & P-Chain). You will not have access to services available on Fuji (such as Chainlink services or bridges). If you require these, go to the [Fuji Testnet](#fuji-testnet) section.
First let's create out L1 configuration. Follow the dialog and if you don't have special requirements for precompiles just follow the suggested options. For the Airdrop of the native token select "Airdrop 1 million tokens to the default ewoq address (do not use in production)". Keep the name "mysubnet" to avoid additional configuration.
avalanche blockchain create myblockchain
Now let's spin up the local Avalanche network and deploy our L1. This will also deploy the Teleporter messenger and the registry on our L1 and the C-Chain.
```bash
avalanche blockchain deploy myblockchain
Make sure to add the RPC Url to the foundry.toml
file if you have chosen a different name than myblockchain
. If you've used myblockchain
the rpc is already configured.
[rpc_endpoints]
local-c = "http://localhost:9650/ext/bc/C/rpc"
myblockchain = "http://localhost:9650/ext/bc/myblockchain/rpc"
anotherblockchain = "http://localhost:9650/ext/bc/BASE58_BLOCKCHAIN_ID/rpc"