npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2026 – Pkg Stats / Ryan Hefner

binance-futures-mcp

v0.2.1

Published

Powerful Model Context Protocol server for Binance USDⓈ-M Futures trading. 14 comprehensive tools for order management, position tracking, account monitoring, and risk management. Enables AI assistants like Claude to interact with Binance Futures API seam

Readme

🚀 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:

| Requirement | Description | Link | |------------|-------------|------| | Binance API Keys | API Key with Futures trading enabled | Get API Keys | | Claude Desktop | For desktop AI assistant | Download Claude | | Cursor | Alternative AI-powered IDE | Download Cursor | | Node.js | Version 20 or higher | Download 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

# 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"
# 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 Name | Category | Description | Method | |-----------|----------|-------------|--------| | new-order | Orders | Create new orders (LIMIT, MARKET, STOP, etc.) | POST | | query-order | Orders | Query status of a specific order | GET | | modify-order | Orders | Modify existing order (price/quantity) | PUT | | cancel-order | Orders | Cancel a specific order | DELETE | | cancel-all-orders | Orders | Cancel all orders for a symbol | DELETE | | get-open-orders | Orders | Get all current open orders | GET | | get-all-orders | Orders | Get order history (all statuses) | GET | | get-account | Account | Get account info, balances, positions | GET | | get-position | Positions | Get position details | GET | | get-trade-history | Trading | Get executed trade history | GET | | change-leverage | Settings | Change leverage for a symbol | POST | | change-position-mode | Settings | Switch One-way/Hedge mode | POST | | change-margin-type | Settings | Switch Isolated/Cross margin | POST | | modify-position-margin | Positions | Adjust isolated position margin | POST |

📝 Detailed Tool Descriptions

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)

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)

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 Measure | Description | Priority | |----------------|-------------|----------| | Never Share Keys | Keep API keys private and secure | 🔴 Critical | | Read-Only Testing | Use read-only keys for testing | 🟡 High | | Restrict Permissions | Enable only necessary permissions | 🟡 High | | IP Whitelist | Restrict API access by IP address | 🟢 Recommended | | No Version Control | Never commit keys to git | 🔴 Critical | | Environment Variables | Use environment variables only | 🟡 High | | Regular Rotation | Rotate 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

| Script | Description | |--------|-------------| | npm run build | Compile TypeScript to JavaScript | | npm test | List all available tools | | npm run watch | Watch mode for development | | npm run inspector | Run 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

| Endpoint | Method | Description | |----------|--------|-------------| | /fapi/v1/order | POST | Create new order | | /fapi/v1/order | PUT | Modify order | | /fapi/v1/order | GET | Query order | | /fapi/v1/order | DELETE | Cancel order | | /fapi/v1/allOpenOrders | DELETE | Cancel all orders | | /fapi/v1/openOrders | GET | Get open orders | | /fapi/v1/allOrders | GET | Get all orders | | /fapi/v1/userTrades | GET | Get trade history | | /fapi/v2/account | GET | Get account info | | /fapi/v2/positionRisk | GET | Get position risk | | /fapi/v1/leverage | POST | Change leverage | | /fapi/v1/positionSide/dual | POST | Change position mode | | /fapi/v1/marginType | POST | Change margin type | | /fapi/v1/positionMargin | POST | Modify position margin |

Error Handling

The server provides detailed error messages from Binance API:

| Error Code | Description | Solution | |------------|-------------|----------| | -1022 | Invalid signature | Check API keys and timestamp | | -1117 | Invalid side | Ensure side is BUY or SELL | | -1102 | Missing parameter | Check required parameters | | -2010 | Insufficient balance | Ensure sufficient account balance | | -4131 | Invalid order | Check 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 LICENCE 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