Binance-Futures-MCP-Server

SamerElhamdo/Binance-Futures-MCP-Server

3.2

If you are the rightful owner of Binance-Futures-MCP-Server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.

The Binance Futures MCP server facilitates trading on Binance USDⓈ-M Futures using the Model Context Protocol, enabling AI assistants to perform trading operations.

Tools
5
Resources
0
Prompts
0

🚀 Binance Futures MCP Server

Powerful Model Context Protocol server for Binance USDⓈ-M Futures trading

npm version npm downloads GitHub Repo stars License: MIT TypeScript Node.js

Binance Futures Trading Connect AI assistants like Claude to Binance Futures trading seamlessly

FeaturesInstallationToolsConfigurationDocumentation


Developed by Samer Elhamdo


📋 Table of Contents

🎯 Overview

The Binance Futures MCP Server is a comprehensive Model Context Protocol (MCP) server that enables AI assistants like Claude to interact with Binance USDⓈ-M Futures API. With 14 powerful trading tools, you can manage your futures trading portfolio directly through conversational AI.

Key Highlights

  • 14 Trading Tools - Complete futures trading functionality
  • 🔒 Secure - HMAC SHA256 signature authentication
  • 🚀 Fast - Optimized API calls with proper error handling
  • 📊 Comprehensive - Order management, position tracking, and account monitoring
  • 🎨 Easy to Use - Simple configuration and intuitive tool names

✨ Features

Features Overview

Core Trading Operations

  • 📝 Order Management: Create, modify, query, and cancel orders
  • 💼 Account Management: View balances, margins, and positions
  • 📈 Position Control: Monitor and manage open positions
  • ⚙️ Risk Management: Adjust leverage, margin types, and position modes

Advanced Capabilities

  • 🔄 Order Modification: Update orders without canceling
  • 📊 Trade History: View complete trading history
  • 🎛️ Settings Management: Change leverage, position mode, and margin type
  • 📋 Comprehensive Queries: Get all orders, open orders, and account details

📦 Prerequisites

Before you begin, ensure you have:

RequirementDescriptionLink
Binance API KeysAPI Key with Futures trading enabledGet API Keys
Claude DesktopFor desktop AI assistantDownload Claude
CursorAlternative AI-powered IDEDownload Cursor
Node.jsVersion 20 or higherDownload Node.js

API Key Setup Checklist

  • Create Binance API key
  • Enable Futures trading permissions
  • Copy API Key and Secret Key
  • (Optional) Set IP whitelist restrictions
  • (Recommended) Use read-only keys for testing

🚀 Installation

Quick Start (NPX)

npx -y binance-futures-mcp@latest

Install via NPM

npm install -g binance-futures-mcp

Install via Smithery

npx -y @smithery/cli install @smithery/binance-futures-mcp --client claude

⚙️ Configuration

Claude Desktop Configuration

macOS Instructions
# Create config file
touch "$HOME/Library/Application Support/Claude/claude_desktop_config.json"

# Open in editor
open -e "$HOME/Library/Application Support/Claude/claude_desktop_config.json"
# OR using VS Code
code "$HOME/Library/Application Support/Claude/claude_desktop_config.json"
Windows Instructions
# Open config file in VS Code
code %APPDATA%\Claude\claude_desktop_config.json

Configuration JSON

Add this configuration to your claude_desktop_config.json:

{
  "mcpServers": {
    "binance-futures-mcp": {
      "command": "npx",
      "args": ["-y", "binance-futures-mcp@latest"],
      "env": {
        "BINANCE_API_KEY": "your-api-key-here",
        "BINANCE_SECRET_KEY": "your-secret-key-here"
      }
    }
  }
}

Cline Configuration

# macOS
code ~/Library/Application\ Support/Code/User/globalStorage/saoudrizwan.claude-dev/settings/cline_mcp_settings.json

# Windows
code %APPDATA%\Code\User\globalStorage\saoudrizwan.claude-dev\settings\cline_mcp_settings.json

Then add the same configuration as above.

🛠️ Available Tools

📊 Complete Tools Table

Tool NameCategoryDescriptionMethod
new-orderOrdersCreate new orders (LIMIT, MARKET, STOP, etc.)POST
query-orderOrdersQuery status of a specific orderGET
modify-orderOrdersModify existing order (price/quantity)PUT
cancel-orderOrdersCancel a specific orderDELETE
cancel-all-ordersOrdersCancel all orders for a symbolDELETE
get-open-ordersOrdersGet all current open ordersGET
get-all-ordersOrdersGet order history (all statuses)GET
get-accountAccountGet account info, balances, positionsGET
get-positionPositionsGet position detailsGET
get-trade-historyTradingGet executed trade historyGET
change-leverageSettingsChange leverage for a symbolPOST
change-position-modeSettingsSwitch One-way/Hedge modePOST
change-margin-typeSettingsSwitch Isolated/Cross marginPOST
modify-position-marginPositionsAdjust isolated position marginPOST

📝 Detailed Tool Descriptions

Order Management Tools
1. new-order

Create new orders with various types and options.

Order Types:

  • LIMIT - Limit order with specified price
  • MARKET - Market order at current price
  • STOP - Stop loss limit order
  • STOP_MARKET - Stop loss market order
  • TAKE_PROFIT - Take profit limit order
  • TAKE_PROFIT_MARKET - Take profit market order
  • TRAILING_STOP_MARKET - Trailing stop order

Example:

{
  "symbol": "BTCUSDT",
  "side": "BUY",
  "type": "LIMIT",
  "quantity": 0.01,
  "price": 50000,
  "timeInForce": "GTC"
}
2. query-order

Check the status of a specific order.

Parameters:

  • symbol (required)
  • orderId (optional)
  • origClientOrderId (optional)
3. modify-order

Modify an existing order without canceling it.

Parameters:

  • symbol (required)
  • side (required) - BUY or SELL
  • orderId or origClientOrderId (required)
  • quantity (optional) - New quantity
  • price (optional) - New price
4. cancel-order

Cancel a specific pending order.

Parameters:

  • symbol (required)
  • orderId or origClientOrderId (optional)
5. cancel-all-orders

Cancel all open orders for a specific symbol.

Parameters:

  • symbol (required)
Account & Position Tools
6. get-account

Get comprehensive account information including balances, margins, and positions.

No parameters required.

7. get-position

Get detailed position information.

Parameters:

  • symbol (optional) - If not provided, returns all positions
8. get-open-orders

List all current open orders.

Parameters:

  • symbol (optional) - If not provided, returns all open orders
9. get-all-orders

Get complete order history (filled, canceled, pending).

Parameters:

  • symbol (required)
  • orderId (optional) - Returns orders >= orderId
  • startTime (optional) - Start time in milliseconds
  • endTime (optional) - End time in milliseconds
  • limit (optional) - Number of orders (default: 500, max: 1000)
10. get-trade-history

Get executed trade history with detailed information.

Parameters:

  • symbol (required)
  • startTime (optional)
  • endTime (optional)
  • fromId (optional) - Trade ID to start from
  • limit (optional) - Number of trades (default: 500, max: 1000)
Settings & Risk Management Tools
11. change-leverage

Change the leverage for a specific symbol.

Parameters:

  • symbol (required)
  • leverage (required) - Leverage level (1-125, depends on symbol)

Example:

{
  "symbol": "BTCUSDT",
  "leverage": 10
}
12. change-position-mode

Switch between One-way Mode and Hedge Mode.

Parameters:

  • dualSidePosition (required) - "true" for Hedge Mode, "false" for One-way Mode

Note: Hedge Mode allows holding both LONG and SHORT positions simultaneously.

13. change-margin-type

Switch between Cross Margin and Isolated Margin.

Parameters:

  • symbol (required)
  • marginType (required) - "ISOLATED" or "CROSSED"

Note: Isolated margin limits risk to the specific position.

14. modify-position-margin

Add or reduce margin for isolated positions.

Parameters:

  • symbol (required)
  • amount (required) - Amount to add (positive) or reduce (negative)
  • type (required) - 1 to add margin, 2 to reduce margin

Example:

{
  "symbol": "BTCUSDT",
  "amount": 100,
  "type": 1
}

💡 Usage Examples

Once configured, you can interact with Binance Futures through Claude:

Conversational Commands

"Check my Binance Futures account balance"
"Create a limit buy order for 0.01 BTCUSDT at $50,000"
"Show me all my open positions"
"Cancel all open orders for BTCUSDT"
"What's the status of order ID 12345?"
"Change leverage for BTCUSDT to 10x"
"Get my trade history for the last 24 hours"
"Modify order 12345 to new price $51,000"

Example Workflows

  1. Create and Monitor Order:

    • Create a LIMIT order
    • Query order status
    • Modify if needed
    • Monitor execution
  2. Risk Management:

    • Check account balance
    • View open positions
    • Adjust leverage
    • Modify margin if needed
  3. Position Analysis:

    • Get all positions
    • View trade history
    • Analyze PnL

🔒 Security Considerations

⚠️ IMPORTANT SECURITY GUIDELINES ⚠️

Best Practices

Security MeasureDescriptionPriority
Never Share KeysKeep API keys private and secure🔴 Critical
Read-Only TestingUse read-only keys for testing🟡 High
Restrict PermissionsEnable only necessary permissions🟡 High
IP WhitelistRestrict API access by IP address🟢 Recommended
No Version ControlNever commit keys to git🔴 Critical
Environment VariablesUse environment variables only🟡 High
Regular RotationRotate API keys periodically🟢 Recommended

Security Checklist

  • API keys stored in environment variables only
  • Secret key never exposed in logs or errors
  • Read-only keys used for testing
  • IP whitelist configured (if available)
  • API key permissions minimized
  • .env file in .gitignore
  • Keys not committed to version control

💻 Development

Installation from Source

# Clone repository
git clone https://github.com/SamerElhamdo/Binance-Futures-MCP-Server.git
cd Binance-Futures-MCP-Server

# Install dependencies
npm install

# Build project
npm run build

# Run tests
npm test

Project Structure

Binance-Futures-MCP-Server/
├── src/
│   └── index.ts          # Main server implementation
├── build/
│   └── index.js          # Compiled JavaScript
├── package.json           # Project configuration
├── tsconfig.json         # TypeScript configuration
└── README.md            # This file

Available Scripts

ScriptDescription
npm run buildCompile TypeScript to JavaScript
npm testList all available tools
npm run watchWatch mode for development
npm run inspectorRun MCP inspector

Environment Variables

Create a .env file in the project root:

BINANCE_API_KEY=your-api-key-here
BINANCE_SECRET_KEY=your-secret-key-here

📚 API Documentation

Architecture Diagram

This MCP server uses the official Binance USDⓈ-M Futures API.

Key Endpoints

EndpointMethodDescription
/fapi/v1/orderPOSTCreate new order
/fapi/v1/orderPUTModify order
/fapi/v1/orderGETQuery order
/fapi/v1/orderDELETECancel order
/fapi/v1/allOpenOrdersDELETECancel all orders
/fapi/v1/openOrdersGETGet open orders
/fapi/v1/allOrdersGETGet all orders
/fapi/v1/userTradesGETGet trade history
/fapi/v2/accountGETGet account info
/fapi/v2/positionRiskGETGet position risk
/fapi/v1/leveragePOSTChange leverage
/fapi/v1/positionSide/dualPOSTChange position mode
/fapi/v1/marginTypePOSTChange margin type
/fapi/v1/positionMarginPOSTModify position margin

Error Handling

The server provides detailed error messages from Binance API:

Error CodeDescriptionSolution
-1022Invalid signatureCheck API keys and timestamp
-1117Invalid sideEnsure side is BUY or SELL
-1102Missing parameterCheck required parameters
-2010Insufficient balanceEnsure sufficient account balance
-4131Invalid orderCheck order parameters

🤝 Contributing

Contributions are welcome! Please feel free to submit a Pull Request.

Contribution Guidelines

  1. Fork the repository
  2. Create your feature branch (git checkout -b feature/AmazingFeature)
  3. Commit your changes (git commit -m 'Add some AmazingFeature')
  4. Push to the branch (git push origin feature/AmazingFeature)
  5. Open a Pull Request

📄 License

This project is licensed under the MIT License - see the file for details.

🙏 Acknowledgments


⭐ If you find this project useful, please consider giving it a star! ⭐

Made with ❤️ by Samer Elhamdo

Report BugRequest Featurenpm Package