๐ CoinGecko API Server MCP
The CoinGecko API Server MCP is a Node.js solution providing access to cryptocurrency market data via a RESTful API and MCP interface, bridging AI systems with real-time crypto data.
โจ Key Features
- Dual API Support: Integrates with CoinGecko Free and Pro APIs.
- AI Integration: Implements the MCP protocol for AI assistants.
- Intelligent Fallback: Switches between APIs to prevent rate limiting.
- Optimized Performance: Efficient request handling and response caching.
- Comprehensive Data: Access to essential cryptocurrency metrics.
- Simple Interface: RESTful endpoints and JSON-RPC methods.
- Robust Error Handling: Clear error messages.
- Easy Deployment: Minimal configuration with guided setup.
- Extensive Documentation: Clear usage instructions and examples.
๐ Quick Start
npx coingecko-api-server
This will:
- Download and install the server
- Run an interactive setup wizard
- Ask for your CoinGecko API key (optional)
- Start the server automatically
๐ฆ Installation
Option 1: Using npx (Recommended)
npx coingecko-api-server
Option 2: Manual Installation
git clone https://github.com/yourusername/coingecko-api-server.git
cd coingecko-api-server
npm install
npm run setup
npm start
โ๏ธ Configuration
The server is configured using environment variables in the .env
file:
Variable | Description | Default |
---|---|---|
PORT | Server port | 3000 |
COINGECKO_API_KEY | CoinGecko Pro API key (optional) | - |
CACHE_DURATION | Cache duration in seconds | 60 |
LOG_LEVEL | Logging level (error, warn, info, debug) | info |
๐ API Reference
RESTful Endpoints
Basic Endpoints
GET /api/ping
- Check API server status
Price Data
GET /api/simple/price
- Get price data for specified coins- Query params:
ids
,vs_currencies
,include_market_cap
,include_24hr_vol
,include_24hr_change
,include_last_updated_at
,precision
- Query params:
Coin Data
GET /api/coins/markets
- Get market data for coins- Query params:
vs_currency
,ids
,category
,order
,per_page
,page
,sparkline
,price_change_percentage
- Query params:
Market Data
GET /api/global
- Get global cryptocurrency dataGET /api/search/trending
- Get trending coins
Examples
Get Bitcoin Price in USD:
curl "http://localhost:3000/api/simple/price?ids=bitcoin&vs_currencies=usd"
Response:
{
"bitcoin": {
"usd": 45678.12
}
}
Get Top 5 Cryptocurrencies by Market Cap:
curl "http://localhost:3000/api/coins/markets?vs_currency=usd&order=market_cap_desc&per_page=5&page=1"
๐ค AI Integration (MCP)
This server implements the Marketplace Component Program (MCP) protocol, enabling AI systems like Claude to access cryptocurrency data.
MCP Integration Points
- JSON-RPC Endpoint:
/rpc
- Handles method calls from AI clients - Schema Definition:
/mcp/schema
- Defines available tools and parameters
Available MCP Methods
ping
- Check API statusgetPrice
- Get price data for specified cryptocurrenciesgetSupportedVsCurrencies
- Get list of supported currenciesgetCoinMarkets
- Get market data for coinsgetGlobal
- Get global cryptocurrency datagetTrending
- Get trending coins
For detailed integration instructions, see MCP_INTEGRATION.md.
๐ Pro API Benefits
This server supports both the CoinGecko Pro API and the free API:
Feature | Free API | Pro API |
---|---|---|
Rate Limit | ~30 calls/minute | ~500 calls/minute |
API Throttling | Yes | No |
Support | Community | Priority |
Data Freshness | 10-30 minutes | 1-2 minutes |
Price | Free | Subscription |
For more details about the Pro API setup, see USING_COINGECKO_PRO.md.
๐ง Troubleshooting
Issue | Solution |
---|---|
Rate limiting errors | Consider upgrading to Pro API or adjust your request frequency |
Connection refused | Ensure the server is running on the specified port |
Authentication errors | Check your API key in the .env file |
Missing data | Verify the parameters in your request |
๐งช Development
# Run in development mode with hot reload
npm run dev
# Run tests
npm test
# Build for production
npm run build
๐ How It Works
The server acts as a middleware between your applications and the CoinGecko API:
- Request Routing: Handles incoming requests from RESTful and JSON-RPC clients
- API Selection: Chooses between Free and Pro APIs based on configuration
- Rate Limit Management: Implements intelligent request throttling
- Response Processing: Formats and returns data in a consistent structure
- Error Handling: Provides detailed error information for troubleshooting
๐ฑ Use Cases
- AI-Powered Financial Advisors: Enable AI systems to access real-time crypto data
- Investment Dashboards: Build cryptocurrency dashboards with reliable data access
- Portfolio Trackers: Create applications to monitor crypto holdings
- Market Analysis Tools: Develop tools for technical and fundamental analysis
- Trading Bots: Power automated trading systems with market data
๐ License
This project is licensed under the MIT License - see the LICENSE file for details.
๐ Acknowledgments
- CoinGecko for the comprehensive cryptocurrency data API
- Anthropic for Claude AI and the MCP program
- The open-source community for their invaluable contributions
Made with โค๏ธ by [Your Organization]