Fast MCP server for interacting with Upbit, South Korea's largest cryptocurrency exchange. This server provides comprehensive access to public market data and optional private trading tools including order management, deposits, and withdrawals.
By implementing the Model Context Protocol (MCP), this server allows Large Language Models (LLMs) to access real-time ticker data, orderbooks, trade history, and execute trading operations directly through their context window.
- Public Market Data: Access real-time ticker data, orderbook snapshots, and recent trades for any Upbit market.
- Account Management: View account balances and positions (requires API key).
- Order Management: Create, query, and cancel orders with support for limit, market, and price order types.
- Deposit Operations: Check deposit eligibility, create deposit addresses, and track deposit history.
- Withdrawal Operations: Create withdrawals, manage withdrawal addresses, and track withdrawal history.
To use this server without installing it globally:
npx @iqai/mcp-upbitgit clone https://github.com/IQAIcom/mcp-upbit.git
cd mcp-upbit
pnpm install
pnpm run buildAdd the following configuration to your MCP client settings (e.g., claude_desktop_config.json).
{
"mcpServers": {
"upbit": {
"command": "npx",
"args": ["-y", "@iqai/mcp-upbit"],
"env": {
"UPBIT_SERVER_URL": "https://api.upbit.com"
}
}
}
}{
"mcpServers": {
"upbit": {
"command": "npx",
"args": ["-y", "@iqai/mcp-upbit"],
"env": {
"UPBIT_SERVER_URL": "https://api.upbit.com",
"UPBIT_ACCESS_KEY": "your_access_key_here",
"UPBIT_SECRET_KEY": "your_secret_key_here",
"UPBIT_ENABLE_TRADING": "true"
}
}
}
}| Variable | Required | Description | Default |
|---|---|---|---|
UPBIT_SERVER_URL |
No | Upbit API server URL | https://api.upbit.com |
UPBIT_ACCESS_KEY |
For trading | Your Upbit API access key | - |
UPBIT_SECRET_KEY |
For trading | Your Upbit API secret key | - |
UPBIT_ENABLE_TRADING |
For trading | Enable private trading tools | false |
- Create an account on Upbit if you don't already have one
- Go to the Upbit Developer Center
- Create a new API key
- Set appropriate permissions (read, trade, withdraw as needed)
- Store your API keys in the environment variables
- Keep your
UPBIT_SECRET_KEYprivate and IP-allowlist your server in Upbit. - Set
UPBIT_ENABLE_TRADING=trueonly when you intend to place/cancel orders or create withdrawals/deposit addresses. - Upbit permission mapping:
- Orders: create/cancel β μ£Όλ¬ΈνκΈ°, query/list β μ£Όλ¬Έμ‘°ν
- Accounts/balances β μμ°μ‘°ν
- Withdrawals: create/cancel β μΆκΈνκΈ°, query/list/address list β μΆκΈμ‘°ν
- Deposits: create deposit address β μ κΈνκΈ°, query/list/chance/address read β μ κΈμ‘°ν
Documentation:
- "What is the current price of Bitcoin on Upbit (KRW-BTC)?"
- "Show me the orderbook for Ethereum (KRW-ETH)."
- "Get the recent trades for XRP (KRW-XRP)."
- "What are my current account balances?"
- "Place a limit buy order for 0.01 BTC at 50,000,000 KRW."
- "Cancel my pending order with UUID xyz123."
- "Show me my open orders for KRW-BTC."
- "Create a deposit address for BTC."
- "List my recent deposits."
- "Withdraw 1 ETH to my wallet address."
- "Check the status of my withdrawal."
Cancel an existing Upbit order (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
uuid |
string | β |
Cancel a digital asset withdrawal by UUID (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
uuid |
string | β |
Request creation of a deposit address (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
currency |
string | β | |
net_type |
string | β |
Create an Upbit order (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
market |
string | β | |
side |
string | β | |
ord_type |
string | β | |
volume |
string | ||
price |
string | ||
time_in_force |
string | ||
smp_type |
string | ||
identifier |
string |
Request a digital asset withdrawal (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
currency |
string | β | |
amount |
string | β | |
address |
string | β | |
net_type |
string | β | |
secondary_address |
string | ||
transaction_type |
string |
Get Upbit account balances (requires private API enabled)
No parameters
Get a single deposit by UUID (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
uuid |
string | β |
Get a single deposit address for a currency and net_type (private)
| Parameter | Type | Required | Description |
|---|---|---|---|
currency |
string | β | |
net_type |
string | β |
Get deposit availability information for a currency (private)
| Parameter | Type | Required | Description |
|---|---|---|---|
currency |
string | β | |
net_type |
string |
Get a single Upbit order (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
uuid |
string | ||
identifier |
string |
Get orderbook snapshot for a given market
| Parameter | Type | Required | Description |
|---|---|---|---|
market |
string | β | Upbit market code, e.g., KRW-BTC |
List Upbit orders (requires private API)
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
market |
string | |||
state |
string | "wait" | ||
page |
integer | 1 | ||
limit |
integer | 100 |
Get the latest ticker data from Upbit for a single market
| Parameter | Type | Required | Description |
|---|---|---|---|
market |
string | β | Upbit market code, e.g., KRW-BTC |
Get recent trades for a market
| Parameter | Type | Required | Description |
|---|---|---|---|
market |
string | β | Upbit market code, e.g., KRW-BTC |
Get a single withdrawal by UUID (requires private API)
| Parameter | Type | Required | Description |
|---|---|---|---|
uuid |
string | β |
List deposit addresses for all currencies (requires private API)
No parameters
List deposits (requires private API)
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
currency |
string | |||
state |
string | |||
page |
integer | 1 | ||
limit |
integer | 50 |
List registered withdrawal-allowed addresses (requires private API)
No parameters
List withdrawals (requires private API)
| Parameter | Type | Required | Default | Description |
|---|---|---|---|---|
currency |
string | |||
state |
string | |||
page |
integer | 1 | ||
limit |
integer | 50 |
pnpm run buildpnpm run watchpnpm run lint
pnpm run formatpnpm run build
npx @modelcontextprotocol/inspector node dist/index.jssrc/tools/: Individual tool definitionssrc/lib/: Configuration, HTTP client, and authentication utilitiessrc/index.ts: Server entry point
This project interacts with the Upbit cryptocurrency exchange API. Trading in cryptocurrencies involves significant risk. Users should exercise caution and verify all data independently. The authors are not responsible for any financial losses incurred through the use of this software.