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
İlgili Sunucular
Horoscope MCP Server
Provides daily horoscope readings and fortune telling for all 12 zodiac signs using a horoscope API.
Plex MCP Server
An MCP server for managing your Plex media library with AI assistants.
SpeedOf.Me Speed Test MCP
Official SpeedOf.Me server for AI agents - accurate speed tests via 129 global edge servers with analytics dashboard.
myinstants-mcp
A soundboard MCP server with millions of meme sounds from myinstants.com — search, play, and browse categories. npx myinstants-mcp to get started.
MCP-Weather
Provides weather information using the Japan Meteorological Agency API. No authentication required.
CryptoAPIs MCP Prepare Transactions
MCP server for building unsigned transactions on multiple blockchains via Crypto APIs
PolicyLayer MCP
Non-custodial spending controls for AI agent crypto wallets — enforce daily limits, per-tx caps, and recipient whitelists.
Transkribus MCP Server
MCP server for the Transkribus REST API — manage collections, documents, HTR/OCR recognition, models, and more. 290 tools across 22 resource domains.
MCP Minecraft Remote
Remotely control a Minecraft Java Edition server using the Model Context Protocol (MCP).
Global Entry Alerts
Query real-time Global Entry interview appointment wait times across all 130+ US enrollment centers. Free, no auth required.