Jupiter Solana MCP Server
A comprehensive MCP (Model Context Protocol) server for interacting with Jupiter Protocol on Solana. Features token swaps, search, portfolio management, and intelligent error diagnostics.
Jupiter MCP Server
A comprehensive MCP (Model Context Protocol) server for interacting with Jupiter Protocol on Solana. Features token swaps, search, portfolio management, and intelligent error diagnostics.
🚀 Features
- Token Swaps: Execute swaps via Jupiter's Ultra API with intelligent slippage and fee handling
- Token Search: Find tokens by symbol, name, or mint address with detailed market data
- Portfolio Management: View token balances and holdings across your wallet
- Smart Diagnostics: Intelligent error detection with helpful user guidance
- SOL Fee Checking: Automatic validation of sufficient SOL for transaction fees
- Multi-language Support: Full English localization for international users
📋 Prerequisites
- Node.js: Version 18 or higher (for native
fetchsupport) - Jupiter API Key: Get your free API key at Jupiter Portal
- Solana Wallet: A private key (base58-encoded) for signing transactions
- RPC Endpoint: Access to a Solana RPC node (e.g.,
https://api.mainnet-beta.solana.com)
📦 Installation
-
Clone the Repository:
git clone https://github.com/pipedude/jupiter-mcp.git cd jupiter-mcp -
Install Dependencies:
npm install -
Environment Setup: Copy the example environment file and configure your settings:
cp .env.example .env -
Configure Environment Variables: Edit
.envfile with your credentials:SOLANA_RPC_URL=https://api.mainnet-beta.solana.com PRIVATE_KEY=your_base58_encoded_private_key_here JUPITER_API_KEY=your_jupiter_api_key_here -
Client Configuration: Add to your MCP client configuration:
{ "mcpServers": { "Jupiter-MCP": { "command": "node", "args": ["path/to/jupiter-mcp/index.js"], "env": { "SOLANA_RPC_URL": "https://api.mainnet-beta.solana.com", "PRIVATE_KEY": "your_base58_encoded_private_key_here", "JUPITER_API_KEY": "your_jupiter_api_key_here" } } } }
🛠️ Available Tools
1. search-token
Search for tokens by symbol, name, or mint address with detailed market information.
Inputs:
query: Token symbol (SOL, USDC), name (Solana), or mint address
Returns: Comprehensive token data including:
- Price and 24h change percentage
- Trading volume and liquidity metrics
- Security audit (mint/freeze authority status)
- Organic score and verification status
- Holder count and market cap
2. get-balances
Get token balances for any wallet address with automatic token identification.
Inputs:
walletAddress(optional): Wallet to check (defaults to configured wallet)mints(optional): Specific token mints to check
Returns: Complete portfolio overview including SOL and all SPL tokens with UI-friendly amounts.
3. get-ultra-order
Fetch optimized swap orders from Jupiter's Ultra API combining DEX routing and RFQ.
Inputs:
inputMint: Input token mint addressoutputMint: Output token mint addressamount: Input amount as string (e.g., "1.23")slippageBps: Slippage tolerance in basis points (e.g., 50 for 0.5%)
Returns: Swap order with requestId, transaction, amounts, and calculated exchange rates.
4. execute-ultra-order
Execute swap transactions with intelligent error handling and status monitoring.
Inputs:
requestId: Order ID fromget-ultra-ordertransaction: Base64-encoded transaction
Returns: Execution results with transaction signature, Solscan links, and detailed status.
Smart Features:
- ✅ Pre-flight SOL balance checking
- 🔄 Automatic transaction status polling (up to 2 minutes)
- 🧠 Intelligent error analysis with helpful suggestions
- 🔗 Direct Solscan transaction links
💡 Usage Examples
1. Search for Tokens
{
"tool": "search-token",
"arguments": {
"query": "BONK"
}
}
Response: Detailed token information including price, volume, security audit, and holder count.
2. Check Portfolio Balances
{
"tool": "get-balances",
"arguments": {}
}
Response: Complete wallet overview with SOL and all SPL token balances in user-friendly format.
3. Execute Token Swap
Step 1 - Get Quote:
{
"tool": "get-ultra-order",
"arguments": {
"inputMint": "So11111111111111111111111111111111111111112",
"outputMint": "EPjFWdd5AufqSSqeM2qN1xzybapC8G4wEGGkZwyTDt1v",
"amount": "0.1",
"slippageBps": 50
}
}
Step 2 - Execute Swap:
{
"tool": "execute-ultra-order",
"arguments": {
"requestId": "uuid-from-step-1",
"transaction": "base64-encoded-transaction-from-step-1"
}
}
🛡️ Error Handling
The server provides intelligent error detection and user-friendly messages:
- Insufficient SOL: "❌ Insufficient SOL for transaction fees. Add 0.01 SOL (~$1.25) to your wallet"
- Slippage Issues: "⚠️ Slippage tolerance exceeded. Try increasing slippage or retry after some time"
- Network Problems: "🔄 Transaction status determination timeout. You can try again with the same order"
🔧 Troubleshooting
Common Issues
"HTTP 401: Unauthorized"
- Check your
JUPITER_API_KEYin environment variables - Verify your API key at Jupiter Portal
"Insufficient SOL for transaction fees"
- Ensure wallet has at least 0.01 SOL for transaction fees
- Check SOL balance using
get-balancestool
"Connection to RPC failed"
- Verify your
SOLANA_RPC_URLis accessible - Try using a different RPC endpoint (Helius, QuickNode, etc.)
📝 License
This project is licensed under the MIT License. See the LICENSE file for details.
🤝 Contributing
- Fork the repository
- Create your feature branch (
git checkout -b feature/amazing-feature) - Commit your changes (
git commit -m 'Add amazing feature') - Push to the branch (
git push origin feature/amazing-feature) - Open a Pull Request
📞 Support
- Issues: GitHub Issues
- Jupiter Docs: Jupiter Developer Documentation
- Solana Docs: Solana Developer Documentation
Serveurs connexes
Arithmetic MCP Server
Performs basic arithmetic operations such as addition, subtraction, multiplication, and division.
Weather
Provides real-time weather data, forecasts, and alerts using the OpenWeatherMap API.
mcp-atomictoolkit
An MCP-compatible server providing atomistic simulation capabilities through ASE, pymatgen, etc.
Sysmetrics
Give your self-hosted agents 'situational awareness.' This MCP server provides a direct interface for agents to query Linux system telemetry, enabling autonomous resource monitoring, proactive alerting, and interactive troubleshooting via any MCP-compatible client.
Baseball MCP
An MCP server for retrieving Major League Baseball (MLB) game results, schedules, and specific game details using the mlb-statsapi library.
DICOM MCP Server
Enables AI assistants to query, read, and move data on DICOM servers like PACS and VNA.
RateAPI MCP Server
Real interest rates from 1,400+ US credit unions across 50 states. Covers mortgages, auto loans, HELOCs, personal loans, and credit cards. Rates ranked by APR with zero affiliate bias. Works with Claude Desktop and ChatGPT. Free tier available.
Interzoid Data Quality
AI-powered data matching, enrichment, standardization, and verification APIs. 29 tools for company/name/address deduplication, business intelligence, email trust scoring, and more. Supports x402 crypto micropayments.
Neume
Make songs with AI
mcp-datadog-server
Datadog MCP Server