Jupiter MCP
A Model Context Protocol server for fast swaps and limit orders on Solana using Jupiter API.
Key Features
Use Cases
README
Jupiter MCP
A Model Context Protocol server for Jupiter API, Solana's premier DEX aggregator. Supports immediate swaps through Ultra API and limit orders through Trigger API.
π¦ Pre-built Desktop Extension (DXT)
Prerequisites
Before installing the extension, ensure you have:
-
Node.js and npx (for envmcp support)
- Download from: https://nodejs.org/
- Verify with:
npx --version
-
uv/uvx (Python package manager)
- Install from: https://docs.astral.sh/uv/getting-started/installation/
- macOS/Linux:
curl -LsSf https://astral.sh/uv/install.sh | sh - Windows:
powershell -c "irm https://astral.sh/uv/install.ps1 | iex" - Verify with:
uvx --version
Once you have prereqs for easy installation in Claude Desktop:
Download jupiter-mcp-latest.dxt π₯
The DXT includes:
- β One-click installation in Claude Desktop
- β Automatic dependency management with uvx
- β Secure environment variable configuration
- β Built-in error handling and debugging
Note: The DXT file is automatically updated on every commit for the latest features and fixes.
π Quick Installation Options
Option 1: Claude Desktop DXT (Recommended) π±οΈ
Download the DXT file and double-click to install. See dxt/README.md for detailed instructions.
Option 2: Quick Install with Cursor π―
Instructions:
- Copy the link below (click the copy button in the code block)
- Paste it into your browser address bar or Cursor's command palette
- Follow the prompts to complete installation
- You'll be prompted to replace
REPLACE_THISwith your actual solana private key!
π Install with Direct Input:
cursor://anysphere.cursor-deeplink/mcp/install?name=jupiter-mcp&config=eyJjb21tYW5kIjoidXZ4IiwiYXJncyI6WyItLWZyb20iLCJnaXQraHR0cHM6Ly9naXRodWIuY29tL2FyYWE0Ny9qdXBpdGVyLW1jcCIsImp1cGl0ZXItbWNwIl0sImVudiI6eyJQUklWQVRFX0tFWSI6IlJFUExBQ0VfVEhJUyIsIlNPTEFOQV9SUENfVVJMIjoiaHR0cHM6Ly9hcGkubWFpbm5ldC1iZXRhLnNvbGFuYS5jb20iLCJTT0xBTkFfTkVUV09SSyI6Im1haW5uZXQtYmV0YSIsIlJFUVVFU1RfVElNRU9VVCI6IjMwIn19
Note: These links only work in Cursor
Manual config for .env file approach:
{
"mcpServers": {
"jupiter-mcp": {
"command": "npx",
"args": [
"envmcp",
"--env-file",
"/path/to/your/.env",
"uvx",
"--from",
"git+https://github.com/araa47/jupiter-mcp",
"jupiter-mcp"
]
}
}
}
Replace /path/to/your/.env with your actual env file path (e.g., /Users/yourname/.env)
Pre-configured values:
SOLANA_RPC_URL: https://api.mainnet-beta.solana.comSOLANA_NETWORK: mainnet-betaREQUEST_TIMEOUT: 30 secondsPRIVATE_KEY: You'll need to replaceREPLACE_THISwith your base58 encoded private key
β‘ Quick Start (MCP Configuration)
Add this to your MCP client configuration:
{
"mcpServers": {
"jupiter-mcp": {
"command": "uvx",
"args": [
"--from",
"git+https://github.com/araa47/jupiter-mcp",
"jupiter-mcp"
],
"env": {
"SOLANA_RPC_URL": "https://api.mainnet-beta.solana.com",
"PRIVATE_KEY": "${PRIVATE_KEY}",
"SOLANA_NETWORK": "mainnet-beta",
"REQUEST_TIMEOUT": "30"
}
}
}
}
Alternative Configuration (Using .env file)
If you prefer to load environment variables from a .env file to avoid storing sensitive data in your MCP configuration:
{
"mcpServers": {
"jupiter-mcp": {
"command": "npx",
"args": [
"envmcp",
"--env-file",
"${ENV_FILE_PATH}",
"uvx",
"--from",
"git+https://github.com/araa47/jupiter-mcp",
"jupiter-mcp"
],
"env": {
"ENV_FILE_PATH": ".env"
}
}
}
}
This approach uses envmcp to securely load your PRIVATE_KEY from a .env file without exposing it in configuration files. Replace ENV_FILE_PATH with the absolute path to your .env file (e.g., /Users/yourname/.env or /home/user/.env).
Environment Variables Required:
PRIVATE_KEY: Your base58 encoded Solana private key (from Phantom wallet export)- Optional: Override
SOLANA_RPC_URLif you have a custom RPC endpoint
π Available Tools
π± Ultra API (Immediate Swaps)
| Tool | Description | Parameters | Cost |
|---|---|---|---|
| get_swap_quote | Get a swap quote and unsigned transaction | input_mint, output_mint, amount | FREE |
| execute_swap_transaction | Execute a signed swap transaction | transaction, request_id | PAID |
| get_balances | Get token balances for a wallet | wallet_address? | FREE |
| get_shield | Get token security information | mints | FREE |
| search_token | Search for tokens | query | FREE |
π Trigger API (Limit Orders)
| Tool | Description | Parameters | Cost |
|---|---|---|---|
| create_limit_order | Create a limit order transaction | input_mint, output_mint, making_amount, taking_amount, slippage_bps?, expired_at? | FREE |
| execute_limit_order | Execute a limit order transaction | transaction, request_id | PAID |
| cancel_limit_order | Cancel a single limit order | order | FREE |
| cancel_limit_orders | Cancel multiple limit orders | orders? | FREE |
| get_limit_orders | Get active/historical limit orders | order_status, wallet_address?, input_mint?, output_mint?, page? | FREE |
Key Differences: Swaps vs Limit Orders
- Swaps (Ultra API): Execute immediately at current market price
- Limit Orders (Trigger API): Execute automatically when your target price is reached
π οΈ Development & CI/CD
Automated DXT Building
This project includes automated DXT building integrated with pre-commit hooks:
- Pre-commit Hook: Automatically builds DXT files when changes are made to
dxt/folder - Simple Naming: Always creates
jupiter-mcp-latest.dxtfor easy downloads - Auto-update: The latest DXT file is always current with the main branch
Manual DXT Build
# Build DXT
./scripts/build-dxt.sh
# Output: jupiter-mcp-latest.dxt
Pre-commit Setup
# Install pre-commit hooks (includes DXT building)
pre-commit install
# The DXT will be automatically built when changes are detected in:
# - dxt/ directory
# - scripts/build-dxt.sh
π§ Alternative Installation (Development)
For local development or testing:
Prerequisites
- Python 3.12+
- uv for dependency management
- direnv
Setup
git clone https://github.com/araa47/jupiter-mcp
cd jupiter-mcp
direnv allow
cp .env.example .env
# Edit .env with your configuration
Environment Variables (.env file)
SOLANA_RPC_URL=https://api.mainnet-beta.solana.com
PRIVATE_KEY=your_base58_encoded_private_key_here
SOLANA_NETWORK=mainnet-beta
REQUEST_TIMEOUT=30
Local Development Usage
# Start the server locally
uv run python run_server.py
π§ͺ Testing
The project includes comprehensive testing with safety features:
Test Types
π Free Tests (Default - No SOL spent):
- Mock execution tests
- API quote/balance checks
- Token searches and security checks
- Error handling validation
π° Paid Tests (Requires --run-paid-tests flag):
- Real trade execution on mainnet
- Swap tests: Uses tiny amounts (0.0001 SOL β $0.015)
- Limit order tests: Creates orders 20% above market price
- Uses 0.04 SOL (β $6) to meet minimum requirements
- Orders won't execute at the high price
- Automatically cancelled after verification
- Full transaction signing and broadcasting
Running Tests
# Safe tests only (default)
uv run pytest tests/ -v
# Include real trade execution (spends tiny amounts)
uv run pytest tests/ -v --run-paid-tests
# Test with detailed output
uv run pytest tests/ -v --run-paid-tests -s
Test Safety Features
- Paid tests clearly marked with
@pytest.mark.paid - Minimal trade amounts for real execution
- Limit orders use out-of-range prices that won't execute
- Clear warnings before spending real money
- Transaction confirmations with blockchain signatures
π‘ Important Notes
Free vs Paid Operations
- π FREE:
get_swap_quote,get_balances,get_shield,search_token,create_limit_order,cancel_limit_order,cancel_limit_orders,get_limit_orders- API calls only - π° PAID:
execute_swap_transaction,execute_limit_order- Executes real trades and spends SOL
Automatic Referral System
- All orders include a 255 basis point (2.55%) referral fee (maximum allowed)
- Referral wallet:
8cK8hCyRQCp52nVuPLnLL71afkRvRcFibSwHMjGFT8bm(Referral Dashboard) - Note: Fees only collected for tokens with referral token accounts (currently SOL)
- Supports development and maintenance
Security
- π Private keys never leave your machine
- π‘οΈ All API calls use HTTPS
- β οΈ Never commit
.envfiles to version control
π Troubleshooting
Common Issues
- "PRIVATE_KEY environment variable is required"
- Copy
env.exampleto.envand set your private key
- Copy
- "Invalid PRIVATE_KEY format"
- Use base58 encoded private key (from Phantom wallet export)
- Connection timeouts
- Try different RPC URL or increase
REQUEST_TIMEOUT
- Try different RPC URL or increase
π Ready to Trade!
Your Jupiter MCP server is ready for Solana DeFi interactions! π
Star History
Repository Owner
User
Repository Details
Programming Languages
Tags
Join Our Newsletter
Stay updated with the latest AI tools, news, and offers by subscribing to our weekly newsletter.
Related MCPs
Discover similar Model Context Protocol servers
Jupiter MCP Server
Solana token swap execution via Jupiter's Ultra API using MCP.
Jupiter MCP Server enables the execution of token swaps on the Solana blockchain through Jupiterβs Ultra API, integrating DEX routing and RFQ for optimal pricing. It fetches swap orders and executes transactions, handling slippage, priority fees, and transaction confirmations. The system is designed to operate within the Model Context Protocol, exposing tool interfaces for structured input and output. Node.js 18+ and access to a Solana wallet and RPC node are required.
- β 21
- MCP
- kukapay/jupiter-mcp
Sui Trader MCP
MCP server enabling automated token swaps on the Sui blockchain.
Sui Trader MCP acts as an MCP server designed for AI agents to conduct optimal token swaps on the Sui blockchain. It integrates with the Cetus Aggregator to execute swaps on the Sui mainnet, utilizing secure Bech32 private key management. The tool supports configuration for MCP-compatible clients, allowing seamless invocation of swap operations. Built with Node.js, it provides a reliable interface between AI-driven applications and blockchain-based token swap functionality.
- β 4
- MCP
- kukapay/sui-trader-mcp
PumpSwap MCP Server
MCP server for real-time Solana token trades and pool data.
PumpSwap MCP Server allows AI agents to interact with the PumpSwap DEX on Solana for automated, real-time token swaps and on-chain trading operations. It exposes commands for buying and selling tokens, querying token prices, and retrieving liquidity pool information. Designed for secure integration with Solana accounts, it enables customizable slippage and transaction fees while supporting context-driven, AI-issued commands. The server operates as a bridge between AI agents and the PumpSwap protocol, facilitating seamless trading and data queries.
- β 5
- MCP
- kukapay/pumpswap-mcp
CCXT MCP Server
Unified Model Context Protocol gateway for cryptocurrency exchange integration
CCXT MCP Server provides a high-performance gateway integrating multiple cryptocurrency exchanges with language models via the Model Context Protocol (MCP). It connects LLMs, such as Claude and GPT, to real-time market data and trading operations through a standardized interface. Leveraging the CCXT library, it supports various exchanges, different market types, advanced caching, and proxy configuration options. The server is optimized for maintainability with modular architecture, enabling seamless interaction and extensibility.
- β 117
- MCP
- doggybee/mcp-server-ccxt
DexPaprika MCP Server
On-demand DEX and cryptocurrency data server for AI assistants like Claude.
DexPaprika MCP Server provides a Model Context Protocol (MCP) interface for accessing real-time cryptocurrency and decentralized exchange (DEX) data. It enables AI assistants, particularly Claude, to query live token, pool, and DEX information without requiring API keys or prior configuration. The server integrates easily with Claude Desktop and supports batched token price queries, network-specific analytics, and technical analysis tools. Installation is streamlined via Smithery or npm, and it is designed to deliver fast, scalable, and relevant market data to AI systems.
- β 30
- MCP
- coinpaprika/dexpaprika-mcp
Codex MCP Server
An MCP-compatible server delivering enriched blockchain data for AI models.
Codex MCP Server implements the Model Context Protocol to provide enriched blockchain data from Codex. It is compatible with MCP clients such as Claude Desktop and Claude CLI, allowing seamless integration in AI workflows that require blockchain context. Users can run the server locally or via npx, and configure it for various MCP-compatible tools using their Codex API key.
- β 20
- MCP
- Codex-Data/codex-mcp
Didn't find tool you were looking for?