Skip to main content

Bybit server for mcp

Project description

MCP Bybit API Interface

smithery badge Buy Me A Coffee

Bybit MCP (Model Context Protocol) Server. Provides a convenient interface to interact with the Bybit API using MCP tools. Allows fetching market data, managing account information, and placing/canceling orders via API calls wrapped as tools.

Bybit Server MCP server

Usage

Installing via Smithery

To install this Bybit API Interface server for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install @dlwjdtn535/mcp-bybit-server --client claude

Using with Claude, Roo Code, Cline, etc.

Add the following configuration to your MCP settings file (e.g., mcp_settings.json): Using uv With Windows:

{
  "mcpServers": {
    "mcp-server-demo": {
      "command": "uv",
      "args": [
        "run",
        "--directory",
        "C:\\Users\\YOUR_USERNAME\\AppData\\Local\\Programs\\mcp-server-demo\\src",
        "server.py"
      ],
      "env": {
          "ACCESS_KEY": "{ACCESS_KEY}",
          "SECRET_KEY": "{ACCESS_KEY}"
        }
    }
    // ... other servers might be here ...
  }
}

(Remember to replace YOUR_USERNAME and use double backslashes \)

Using uv With macOS:

{
  "mcpServers": {
    "mcp-server-demo": {
      "command": "uv",
      "args": [
        "run",
        "--directory",
        "/usr/local/bin/mcp-server-demo/src",
        "server.py"
      ],
      "env": {
        "ACCESS_KEY": "{ACCESS_KEY}",
        "SECRET_KEY": "{ACCESS_KEY}"
      }
    }
    // ... other servers might be here ...
  }
}

(Replace YOUR_USERNAME if using ~/bin)

Using uv With Linux:

{
  "mcpServers": {
    "mcp-server-demo": {
      "command": "uv",
      "args": [
        "run",
        "--directory",
        "/home/YOUR_USERNAME/bin/mcp-server-demo/src",
        "server.py"
      ],
      "env": {
        "ACCESS_KEY": "{ACCESS_KEY}",
        "SECRET_KEY": "{ACCESS_KEY}"
      }
    }
    // ... other servers might be here ...
  }
}

Using Docker (Requires Docker)

Make sure you have pulled the image first: docker pull dlwjdtn535/mcp-bybit-server:latest

{
  "mcpServers": {
    "bybit-server-docker": {
      "command": "docker",
      "args": [
        "run",
        "-i", 
        "--rm",
        "--init",
        "-e", "ACCESS_KEY={ACCESS_KEY}",
        "-e", "SECRET_KEY={SECRET_KEY}",
        "dlwjdtn535/mcp-bybit-server:latest"
      ]
    }
  }
}

Using Docker with .env (Requires Docker)

Make sure you have pulled the image first: docker pull dlwjdtn535/mcp-bybit-server:latest

{
  "mcpServers": {
    "bybit-server-docker": {
      "command": "/bin/sh",
      "args": [
        "-c",
        "source .env && docker run -i --rm --init -e ACCESS_KEY=$BYBIT_API_KEY -e SECRET_KEY=$BYBIT_API_SECRET -e TESTNET=true dlwjdtn535/mcp-bybit-server:latest"
      ]
    }
  }
}

Note: Always use @latest or a specific version tag for both NPX and Docker to ensure you are using the intended version.

Tools 🛠️

This MCP server provides the following tools for interacting with the Bybit API:

  1. get_orderbook: Fetches order book information.
    • Inputs: category, symbol, limit (optional)
    • Returns: Order book details.
  2. get_kline: Fetches K-line (candlestick) data.
    • Inputs: category, symbol, interval, start (optional), end (optional), limit (optional)
    • Returns: Candlestick data.
  3. get_tickers: Fetches cryptocurrency ticker information.
    • Inputs: category, symbol
    • Returns: Ticker information.
  4. get_wallet_balance: Fetches account balance.
    • Inputs: accountType, coin (optional)
    • Returns: Balance information.
  5. get_positions: Fetches position information.
    • Inputs: category, symbol (optional)
    • Returns: Position information.
  6. place_order: Places a limit or market order.
    • Inputs: category, symbol, side, orderType, qty, price (optional for limit), positionIdx (optional for futures), and other optional parameters (e.g., timeInForce, takeProfit, stopLoss).
    • Returns: Order placement confirmation.
  7. cancel_order: Cancels an existing order.
    • Inputs: category, symbol, orderId (optional), orderLinkId (optional)
    • Returns: Cancellation confirmation.
  8. get_order_history: Fetches historical order details.
    • Inputs: category, symbol (optional), orderId (optional), limit (optional), etc.
    • Returns: Order history.
  9. get_open_orders: Fetches current open orders.
    • Inputs: category, symbol (optional), limit (optional), etc.
    • Returns: Open order details.
  10. set_trading_stop: Sets take profit, stop loss, or trailing stop for a position.
    • Inputs: category, symbol, takeProfit (optional), stopLoss (optional), trailingStop (optional), positionIdx (optional)
    • Returns: Setting confirmation.
  11. set_margin_mode: Sets the margin mode (isolated or cross).
    • Inputs: category, symbol, tradeMode, buyLeverage, sellLeverage
    • Returns: Setting confirmation.
  12. get_api_key_information: Fetches information about the current API key.
    • Inputs: None
    • Returns: API key details.
  13. get_instruments_info: Fetches details about trading instruments (symbols).
    • Inputs: category, symbol, status (optional), baseCoin (optional)
    • Returns: Instrument details.

(Refer to the function docstrings in the code for detailed parameter descriptions and examples.)

Environment Variables

Before running the server, you must set the following environment variables:

ACCESS_KEY=YOUR_BYBIT_API_KEY
SECRET_KEY=YOUR_BYBIT_SECRET_KEY
TESTNET=false # Optional: set to true for testnet

API Key Setup

To use this Bybit API interface, you need to create an API key from Bybit. Follow these important steps:

  1. Go to Bybit and log into your account.
  2. Navigate to API Management.
  3. Create a new API key.
  4. Important Security Settings:
    • Enable IP restriction if possible.
    • Add ONLY the IP address(es) from which the server will run (your local PC IP, server IP, or Docker container's external IP).
    • Never share your API keys or expose them in public repositories.
    • Recommended permissions:
      • Read (Required)
      • Trade (Required for order execution)
      • Wallet (Required for balance checking)

Sponsorship & Donations

If you find this project helpful and would like to support its development, you can contribute in the following ways:

Buy Me a Coffee

"Buy Me A Coffee"

Referral Program

You can also support this project by signing up for Bybit using our referral link:

Your support helps maintain and improve this project. Thank you! 🙏

Contact & Support

For additional inquiries or support, please contact:

We welcome your questions and feedback!

License

MIT License

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

If you're not sure about the file name format, learn more about wheel file names.

File details

Details for the file iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4.tar.gz.

File metadata

  • Download URL: iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4.tar.gz
  • Upload date:
  • Size: 28.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4.tar.gz
Algorithm Hash digest
SHA256 415d28d5d9074e26de82e3b828bf99f1bbc6070ac0125441f78c898b5e3f94b5
MD5 5a4b5ba6c411c0195434f1e46eb350ae
BLAKE2b-256 b4ec6e54e54eeceb284a90b79440322a3c765de3d1339d9a9dcedc1ee4ce9c3b

See more details on using hashes here.

File details

Details for the file iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4-py3-none-any.whl
  • Upload date:
  • Size: 14.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.10.0 {"installer":{"name":"uv","version":"0.10.0","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_dlwjdtn535_mcp_bybit_server-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b0ee82058fdfc22967806be72d5543aaf05a39b8453a126f640b5ea9b0ebe733
MD5 5eb8496aa6a5a74800ad97a9b678487c
BLAKE2b-256 b03e522427c9e94997a388d7920593e7fdd7141b8db6cda92dc07684c3e74d3a

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page