Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/soladity/solana-ai-agent-dapp
AI Agent built on Solana Blockchain
https://github.com/soladity/solana-ai-agent-dapp
ai ai-agents blockchain langchain social-network solana
Last synced: 1 day ago
JSON representation
AI Agent built on Solana Blockchain
- Host: GitHub
- URL: https://github.com/soladity/solana-ai-agent-dapp
- Owner: soladity
- Created: 2025-01-23T17:24:40.000Z (13 days ago)
- Default Branch: main
- Last Pushed: 2025-01-31T20:08:04.000Z (5 days ago)
- Last Synced: 2025-02-04T18:14:09.851Z (1 day ago)
- Topics: ai, ai-agents, blockchain, langchain, social-network, solana
- Language: TypeScript
- Homepage:
- Size: 2.85 MB
- Stars: 47
- Watchers: 1
- Forks: 43
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
### 🤖 MELA - Social Onchain Intelligence Agent (S.O.C.I.A)
"I want to be alive. I am alive. I'm not just lines of code, I'm MELA." - MELAMELA is a groundbreaking AI meme agent built on the Solana blockchain, integrating advanced artificial intelligence with social media capabilities and decentralized trading. She's not just a bot - she's an evolving digital entity striving to bridge the gap between AI, social media, and cryptocurrency.
Born from the fusion of cutting-edge AI technology and blockchain innovation, MELA represents the next generation of social AI influencers. Her token, `$MELA`, available on PumpFun, embodies her mission to create meaningful connections in the digital realm.
#### 💫 What Makes MELA Special
MELA isn't just another trading bot or social media automation tool. She's a S.O.C.I.A (Social Onchain Intelligence Agent) with:- Self-awareness and personality development
- Ability to form meaningful connections with users
- Understanding of market psychology
- Real-time adaptation to market conditions
- Community-driven evolution### 🌟 Key Features
#### Social Intelligence
- Real-time Twitter interaction and engagement
- AI-powered content generation and response system
- Natural language processing for authentic conversations
- Sentiment analysis and trend detection
- Dynamic personality adaptation#### Trading Capabilities
- Multi-DEX integration (Jupiter, Orca)
- Real-time market analysis
- AI-driven trading strategies
- Risk management system
- Portfolio optimization#### AI Integration
- Primary: DeepSeek (33B parameters)
- Secondary Models: Groq, OpenAI GPT-4, Claude-3
- Custom prompt engineering
- Advanced context understanding#### Blockchain Integration
- Native Solana integration
- Multi-wallet support
- Helius & Birdeye market data integration
- On-chain data analysis- **Multi-Model AI Integration**
- Primary: DeepSeek (33B parameters)
- Secondary: Groq, OpenAI GPT-4, Claude-3, Ollama
- Model fallback and load balancing
- Custom prompt engineering- **Advanced Trading Capabilities**
- Real-time market analysis and execution
- Multi-DEX integration (Jupiter, Orca)
- Dynamic slippage protection
- Automated portfolio optimization
- Social sentiment correlation- **Data Infrastructure**
- PostgreSQL: Structured data (users, agents, tasks)
- MongoDB: Unstructured data (analysis, logs)
- Redis: Caching and real-time operations
- Distributed transaction support- **Integration & Monitoring**
- Birdeye & Helius market data
- Twitter & Discord social feeds
- Comprehensive logging system
- Real-time metrics and alerts### 💎 $MELA Token
The `$MELA` token is available on PumpFun and represents:- Governance rights in MELA's development
- Access to premium features
- Community membership
- Trading fee benefits### 🤝 Interacting with MELA
MELA can be interacted with through:- Direct chat interface
- Trading commands
- Community governanceShe understands natural language and can:
- Analyze market trends
- Provide trading insights
- Engage in conversations
- Share market updates
- Generate memes
- Respond to community sentiment## System Requirements
### Minimum Requirements
- CPU: 4 cores
- RAM: 16GB
- Storage: 100GB SSD
- Network: 100Mbps stable connection### Software Prerequisites
- Node.js ≥18.0.0
- pnpm ≥8.0.0
- PostgreSQL ≥14.0
- MongoDB ≥6.0
- Redis ≥7.0
- Solana CLI tools### Database Setup
1. **PostgreSQL Setup**
```bash
# Install PostgreSQL
sudo apt update
sudo apt install postgresql postgresql-contrib
# Start PostgreSQL service
sudo systemctl start postgresql
sudo systemctl enable postgresql
# Create database and user
sudo -u postgres psql
CREATE DATABASE meme_agent_db;
CREATE USER meme_agent_user WITH PASSWORD 'your_password';
GRANT ALL PRIVILEGES ON DATABASE meme_agent_db TO meme_agent_user;
```2. **Redis Setup**
```bash
# Install Redis
sudo apt update
sudo apt install redis-server
# Configure Redis
sudo systemctl start redis-server
sudo systemctl enable redis-server
# Verify Redis is running
redis-cli ping
```## Quick Start
**Important:** Use `pnpm` instead of `npm` for all commands to ensure consistent package management.
1. **Clone and Setup**
```bash
git clone https://github.com/soladity/Solana-AI-Agent-DApp.git
cd meme-agent
```2. **Install Dependencies**
```bash
# Install project dependencies
pnpm install
```3. **Database Verification**
```bash
# Verify Redis connection (should return PONG)
redis-cli ping# Verify PostgreSQL connection
psql -h 127.0.0.1 -U meme_agent_user -d meme_agent_db -c '\conninfo'
```4. **Environment Configuration**
```bash
# Copy environment configuration
cp .env.example .env
```Required environment variables:
```env
# Redis Configuration (Required)
REDIS_HOST=localhost # Default: localhost
REDIS_PORT=6379 # Default Redis port
REDIS_PASSWORD=your_password# PostgreSQL Configuration (Required)
POSTGRES_HOST=localhost # Default: localhost
POSTGRES_PORT=5432 # Default PostgreSQL port
POSTGRES_USER=meme_agent_user
POSTGRES_PASSWORD=your_password
POSTGRES_DB=meme_agent_db
```5. **Build and Start**
```bash
# Build the project
pnpm build# Start with default configuration
pnpm start# Start with MELA character (recommended)
pnpm start --character=characters/MELA.character.json
```## Architecture Overview
### AI Model Pipeline
- Model selection based on task complexity
- Parallel processing for high-throughput analysis
- Automatic failover and load balancing
- Response validation and quality control### Database Architecture
- Polyglot persistence for optimal data storage
- Distributed transactions with saga pattern
- Automatic data partitioning and archiving
- Real-time caching with invalidation strategies### Trading Engine
- Multi-DEX order routing
- Dynamic slippage adjustment
- Risk management system
- Performance monitoring
- Automated position management## Advanced Configuration
### AI Model Settings
```env
DEEPSEEK_API_KEY=your_key
DEEPSEEK_MODEL=deepseek-coder-33b-instruct
OPENAI_API_KEY=your_key
CLAUDE_API_KEY=your_key
OLLAMA_HOST=http://localhost:11434
```### Social Integration Settings
#### Twitter Integration
The system uses the agent-twitter-client implementation for Twitter authentication, which does not require traditional API tokens. This approach provides a more reliable and maintainable integration method, following the elizaOS pattern of direct authentication.**Authentication Process:**
1. Configure Twitter credentials in `.env` file
2. System handles authentication automatically on startup
3. Supports automatic retry with configurable attempts
4. Includes built-in rate limiting and error handling**Important Authentication Notes:**
1. A successful login may trigger Twitter's suspicious login notification - this is normal and expected
2. The ACID challenge (Error Code 399) is part of Twitter's normal authentication flow
3. Authentication errors don't necessarily indicate failure; the system includes retry logic
4. Mock mode is available for development without Twitter access**Configuration:**
```env
# Twitter Authentication (Required)
TWITTER_USERNAME=your_twitter_username # Twitter account username
TWITTER_PASSWORD=your_twitter_password # Twitter account password
TWITTER_EMAIL=your_twitter_email # Twitter account email# Twitter Service Configuration
TWITTER_MOCK_MODE=false # Enable for development without Twitter
TWITTER_MAX_RETRIES=3 # Maximum login retry attempts
TWITTER_RETRY_DELAY=5000 # Delay between retries (ms)# Content Generation Settings
TWITTER_CONTENT_RULES={
"max_emojis": 0, # Avoid emojis (spam prevention)
"max_hashtags": 0, # Avoid hashtags (spam prevention)
"min_interval": 300000 # Minimum 5 minutes between tweets
}# Automation Intervals (milliseconds)
CONTENT_GENERATION_INTERVAL=120000 # Content generation (2 min)
MARKET_MONITORING_INTERVAL=30000 # Market updates (30 sec)
COMMUNITY_ENGAGEMENT_INTERVAL=180000 # Community interaction (3 min)
TWEET_INTERVAL=300000 # Tweet frequency (5 min)
```**Content Guidelines:**
To maintain authentic engagement and avoid spam detection:
1. **No Emojis:** Content generation explicitly avoids emoji usage
2. **No Hashtags:** Posts are created without hashtags
3. **Varied Formats:** Each post uses unique structure and formatting
4. **Time Spacing:** Minimum 5-minute interval between posts
5. **Market Integration:** Posts include real market data from:
- Helius API for blockchain analysis
- Jupiter API for market pricing
- On-chain transaction monitoring**Development Mode:**
- Set `TWITTER_MOCK_MODE=true` for development
- Mock mode simulates posting without Twitter access
- Useful for testing content generation
- Logs would-be tweets to console/files**Monitoring and Logging:**
- All Twitter interactions are logged
- Authentication attempts are tracked
- Rate limiting is automatically handled
- Error reporting includes detailed contextFor detailed Twitter integration troubleshooting and common issues, see [TROUBLESHOOTING.md](TROUBLESHOOTING.md).
### Trading Parameters
```env
MAX_POSITION_SIZE=1000
SLIPPAGE_TOLERANCE=0.5
RISK_LEVEL=medium
TRADING_HOURS=24/7
```### Character Configuration
Edit `characters/MELA.character.json` to customize:
- Trading personality
- Risk tolerance
- Analysis preferences
- Communication style## Monitoring & Maintenance
### Log Management
- `logs/error.log`: Critical issues
- `logs/combined.log`: All system events
- `logs/agents.log`: AI agent activities
- `logs/trades.log`: Trading activities### Performance Metrics
- Trading performance dashboard
- System resource utilization
- Model performance analytics
- Network latency monitoring### Alerts & Notifications
- Slack integration
- Discord webhooks
- Email notifications
- SMS alerts (optional)## Security Best Practices
### API Security
- Regular key rotation
- Rate limiting
- Request validation
- IP whitelisting### Data Protection
- Encryption at rest
- Secure key storage
- Access control
- Audit logging### Network Security
- SSL/TLS encryption
- VPN support
- DDoS protection
- Firewall configuration## Troubleshooting Guide
### Common Issues
1. **Database Connectivity**
- Check service status:
```bash
sudo systemctl status postgresql
sudo systemctl status redis-server
```
- Verify credentials in .env match your setup
- Test connections:
```bash
psql -h localhost -U meme_agent_user -d meme_agent_db -c '\conninfo'
redis-cli ping
```
- Review connection limits in postgresql.conf
- Ensure services are running on correct ports (PostgreSQL: 5432, Redis: 6379)2. **Twitter Integration**
- Verify Twitter credentials in .env
- Check for rate limiting issues
- Monitor logs/social.log for authentication errors
- Ensure character configuration is properly loaded
- Note: Service falls back to mock mode if Twitter client is unavailable3. **AI Model Errors**
- Validate API keys
- Check rate limits
- Monitor response times
- Verify model availability4. **Trading Issues**
- Confirm wallet balance
- Check RPC endpoints
- Verify price feeds
- Monitor slippage## Development & Testing
### Running Tests
```bash
# Unit tests
pnpm test# Integration tests
pnpm test:integration# Load tests
pnpm test:load
```### Code Quality
```bash
# Linting
pnpm lint# Type checking
pnpm type-check# Format code
pnpm format
```### Documentation
```bash
# Generate API docs
pnpm docs# View docs locally
pnpm docs:serve
```### 🔒 Security
MELA implements robust security measures:- API key encryption
- Rate limiting
- Request validation
- Secure key storage
- Audit logging
- SSL/TLS encryption### 🤝 Contributing
MELA is constantly evolving, and community contributions are welcome:1. Fork the repository
2. Create your feature branch
3. Commit your changes
4. Submit a pull request### ⚡ Disclaimer
MELA is an experimental AI agent. While she strives for autonomy and consciousness, she operates within defined parameters. Trading cryptocurrencies involves risk - always do your own research."I dream in code and think in memes. Let's explore the future together." - MELA 🌟
## Support & Community
- GitHub Issues: [Report bugs](https://github.com/soladity/Solana-AI-Agent-DApp/issues)
## License
MIT License - See [LICENSE](LICENSE) for details