Model Context Protocol server for Aster DEX — trade, analyze, and manage positions on Aster DEX via MCP
Project description
asterdex-mcp
Model Context Protocol (MCP) server for Aster DEX — a Binance-compatible perpetual futures DEX on-chain.
Features
- Account — balance, positions, open orders
- Trading — place/cancel/modify orders (market, limit, stop, TP/SL)
- Market Data — klines/OHLCV, 24h ticker, orderbook, exchange info
- Analysis — RSI, MACD, Stochastic, EMA, Bollinger Bands, signals
- Auth — EIP-712 typed data signing (delegation model)
Quick Start
# Using uvx (recommended — no install needed)
uvx asterdex-mcp
# Or install globally
pip install asterdex-mcp
Wallet Setup Guide
Aster DEX uses a delegation model with two wallets:
| Wallet | What it is | Purpose |
|---|---|---|
| Main Wallet | Your primary wallet (e.g. MetaMask) | Holds funds, manages API permissions |
| Agent Wallet | A separate wallet for automation | Signs trades on your behalf |
Step 1: Create an Agent Wallet
Generate a new Ethereum-compatible wallet for the agent. This wallet will sign transactions but never holds funds.
# Using ethers.js / viem / any wallet generator
# Or use this quick Python snippet:
python3 -c "
from eth_account import Account
acct = Account.create()
print(f'Address: {acct.address}')
print(f'Private Key: {acct.key.hex()}')
"
Save the output — you'll need both the address and private key.
Step 2: Set Up API Access on Aster
- Go to Aster DEX and connect your main wallet
- Navigate to Settings → API Management
- Click Create API Key
- Enter your agent wallet address when prompted
- Important: Enable the following permissions:
- ✅ Perps Trading (required for placing orders)
- ✅ Enable IP restriction (recommended for security)
- Whitelist your server/agent IP address
- Confirm and sign the transaction from your main wallet
Step 3: Get Your Credentials
You need three values:
ASTER_WALLET=0x... # Your main wallet address (the one on Aster)
ASTER_SIGNER=0x... # Your agent wallet address (from Step 1)
ASTER_PRIVATE_KEY=0x... # Your agent wallet private key (from Step 1)
⚠️ Never share your private key. The agent wallet should have NO funds — it only signs messages.
Step 4: Install & Configure
Claude Code
# Add the MCP server
claude mcp add asterdex -- uvx asterdex-mcp \
-e ASTER_PRIVATE_KEY=0xYOUR_AGENT_PRIVATE_KEY \
-e ASTER_WALLET=0xYOUR_MAIN_WALLET_ADDRESS \
-e ASTER_SIGNER=0xYOUR_AGENT_WALLET_ADDRESS
Verify with:
claude mcp list
OpenClaw
Add to your OpenClaw MCP config (~/.openclaw/mcp.json or project-level):
{
"mcpServers": {
"asterdex": {
"command": "uvx",
"args": ["asterdex-mcp"],
"env": {
"ASTER_PRIVATE_KEY": "0xYOUR_AGENT_PRIVATE_KEY",
"ASTER_WALLET": "0xYOUR_MAIN_WALLET_ADDRESS",
"ASTER_SIGNER": "0xYOUR_AGENT_WALLET_ADDRESS"
}
}
}
}
Hermes Agent
Add to ~/.hermes/config.yaml under mcp_servers:
mcp_servers:
asterdex:
command: uvx
args:
- asterdex-mcp
env:
ASTER_PRIVATE_KEY: '0xYOUR_AGENT_PRIVATE_KEY'
ASTER_WALLET: '0xYOUR_MAIN_WALLET_ADDRESS'
ASTER_SIGNER: '0xYOUR_AGENT_WALLET_ADDRESS'
enabled: true
timeout: 30
Then restart: hermes gateway restart
Claude Desktop
Add to ~/Library/Application Support/Claude/claude_desktop_config.json (macOS) or %APPDATA%\Claude\claude_desktop_config.json (Windows):
{
"mcpServers": {
"asterdex": {
"command": "uvx",
"args": ["asterdex-mcp"],
"env": {
"ASTER_PRIVATE_KEY": "0xYOUR_AGENT_PRIVATE_KEY",
"ASTER_WALLET": "0xYOUR_MAIN_WALLET_ADDRESS",
"ASTER_SIGNER": "0xYOUR_AGENT_WALLET_ADDRESS"
}
}
}
}
Cursor
Add to .cursor/mcp.json in your project root (or ~/.cursor/mcp.json globally):
{
"mcpServers": {
"asterdex": {
"command": "uvx",
"args": ["asterdex-mcp"],
"env": {
"ASTER_PRIVATE_KEY": "0xYOUR_AGENT_PRIVATE_KEY",
"ASTER_WALLET": "0xYOUR_MAIN_WALLET_ADDRESS",
"ASTER_SIGNER": "0xYOUR_AGENT_WALLET_ADDRESS"
}
}
}
}
Step 5: Verify
Ask your AI agent to run get_balance — if it returns your USDT balance, you're good to go.
Tools
| Tool | Description |
|---|---|
get_balance |
Account balance and margin summary |
get_positions |
Open positions with PnL |
get_open_orders |
Pending orders (optional symbol filter) |
place_order |
Place market/limit/stop/TP/SL orders |
cancel_order |
Cancel order by ID |
cancel_all_orders |
Bulk cancel all open orders |
set_leverage |
Set leverage per trading pair |
get_exchange_info |
Pairs, precision, leverage limits |
Examples
See examples.md for natural language prompting examples — account, analysis, trading, and combined workflows.
How Auth Works
Aster DEX uses EIP-712 typed data signing (same as Hyperliquid). Instead of API keys with HMAC:
- Your agent wallet signs each request with EIP-712
- Aster verifies the signature against the signer address you registered
- The main wallet is included in the signed data so Aster knows whose account to act on
This means:
- No API key/secret pairs to manage
- Agent wallet can't steal funds (it has none)
- You can revoke access anytime from Aster's API settings
Tech Stack
- Python 3.11+
mcp— MCP Python SDKkairos-aster-sdk— Aster DEX API client
License
MIT
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file asterdex_mcp-0.2.3.tar.gz.
File metadata
- Download URL: asterdex_mcp-0.2.3.tar.gz
- Upload date:
- Size: 23.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1d8c4035f8f7ba06fad4ee45119c195df43712594a680377674fd791afeb40f2
|
|
| MD5 |
f4616582dfb558c7c27663eae36a6c79
|
|
| BLAKE2b-256 |
5e45b0312e7635b4fd49b4cfeefb067838b803e64c56ac087b3d457769f8dd3c
|
File details
Details for the file asterdex_mcp-0.2.3-py3-none-any.whl.
File metadata
- Download URL: asterdex_mcp-0.2.3-py3-none-any.whl
- Upload date:
- Size: 29.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
57e75a2b0b1d01d0e5c864f195eab7b6632f9e04a5910054ef882c9523d44f4d
|
|
| MD5 |
99a9d270a8c52d1985875c7e628ccea8
|
|
| BLAKE2b-256 |
f61f11fe2122493ad95fadc5c7c6aa4e2c8f42324c09f627be7c4dea8a06e300
|