Jupiter MCP
Provides tools for swapping tokens and managing limit orders on the Solana blockchain using Jupiter DEX aggregator.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@Jupiter MCPSwap 1 SOL for USDC"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
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 | shWindows:
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=eyJjb21tYW5kIjoidXZ4IiwiYXJncyI6WyItLWZyb20iLCJnaXQraHR0cHM6Ly9naXRodWIuY29tL2FyYWE0Ny9qdXBpdGVyLW1jcCIsImp1cGl0ZXItbWNwIl0sImVudiI6eyJQUklWQVRFX0tFWSI6IlJFUExBQ0VfVEhJUyIsIlNPTEFOQV9SUENfVVJMIjoiaHR0cHM6Ly9hcGkubWFpbm5ldC1iZXRhLnNvbGFuYS5jb20iLCJTT0xBTkFfTkVUV09SSyI6Im1haW5uZXQtYmV0YSIsIlJFUVVFU1RfVElNRU9VVCI6IjMwIn19Note: 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/folderSimple Naming: Always creates
jupiter-mcp-latest.dxtfor easy downloadsAuto-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.dxtPre-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 configurationEnvironment 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=30Local 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 -sTest Safety Features
Paid tests clearly marked with
@pytest.mark.paidMinimal 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
"Invalid PRIVATE_KEY format"
Use base58 encoded private key (from Phantom wallet export)
Connection timeouts
Try different RPC URL or increase
REQUEST_TIMEOUT
๐ Ready to Trade!
Your Jupiter MCP server is ready for Solana DeFi interactions! ๐
This server cannot be installed
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/araa47/jupiter-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server