Skip to main content
Glama
doubledare704

aiowhitebit-mcp

aiowhitebit-mcp

Message Control Protocol (MCP) server and client implementation for WhiteBit cryptocurrency exchange API. Built on top of aiowhitebit library and fastmcp.

Features

  • MCP server for WhiteBit API with public endpoints

  • Support for multiple transport protocols (stdio, SSE, WebSocket)

  • Easy-to-use client for interacting with the MCP server

  • Command-line interface for running the server

  • Integration with Claude Desktop

  • Real-time market data via WebSocket

  • Comprehensive test coverage and type checking

  • Modern development tools (ruff, pyright, pre-commit)

  • Caching with disk persistence

  • Rate limiting and circuit breaker patterns

New in aiowhitebit 0.3.0 Integration

  • BookTicker WebSocket Streams: Real-time best bid/ask price updates

  • Funding History for Futures: Access historical funding rates for futures markets

  • Enhanced WebSocket Events: All WebSocket events now include optional metadata (event_time, update_id)

Quick Start

# Install the package
pip install aiowhitebit-mcp

# Run the server (stdio transport for Claude Desktop)
aiowhitebit-mcp --transport stdio

# Or run with SSE transport
aiowhitebit-mcp --transport sse --host 127.0.0.1 --port 8000

Basic Usage

Client with Network Transport

import asyncio
import os
from aiowhitebit_mcp.client import WhiteBitMCPClient

async def main():
    # Set the server URL (or use environment variable)
    server_url = "http://localhost:8000/sse"
    os.environ["WHITEBIT_MCP_URL"] = server_url

    async with WhiteBitMCPClient() as client:
        # Get market info
        btc_usdt = await client.get_market_resource("BTC_USDT")
        print("BTC/USDT Market Info:", btc_usdt)

        # Get real-time price via WebSocket
        price = await client.get_last_price("BTC_USDT")
        print("Current BTC/USDT price:", price)

        # Get order book
        orderbook = await client.get_orderbook("BTC_USDT")
        print("Order book:", orderbook)

        # Get funding history for futures market
        funding_history = await client.get_funding_history("BTC_USDT")
        print("Funding history:", funding_history)

        # Subscribe to BookTicker for real-time best bid/ask
        subscription = await client.bookticker_subscribe("BTC_USDT")
        print("BookTicker subscription:", subscription)

if __name__ == "__main__":
    asyncio.run(main())

Server Configuration

from aiowhitebit_mcp.server import create_server
import asyncio

# Create the server with custom configuration
server = create_server(
    name="WhiteBit API"
)

# Run the server with desired transport
if __name__ == "__main__":
    asyncio.run(
        server.run(
            transport="stdio",  # or "sse"
            host="127.0.0.1",   # for network transports
            port=8000           # for network transports
        )
    )

Available Tools

Public API

  • get_server_time(): Get current server time

  • get_market_info(): Get all markets information

  • get_orderbook(market: str): Get order book

  • get_recent_trades(market: str, limit: int = 100): Get recent trades

  • get_ticker(market: str): Get ticker information

  • get_fee(market: str): Get trading fees

  • get_server_status(): Get server status

  • get_asset_status_list(): Get status of all assets

  • get_funding_history(market: str): Get funding rate history for futures markets

WebSocket API

  • get_last_price(market: str): Get real-time price

  • get_market_depth(market: str): Get real-time order book

  • bookticker_subscribe(market: str): Subscribe to BookTicker stream for best bid/ask prices

  • bookticker_unsubscribe(market: str): Unsubscribe from BookTicker stream

  • connect_websocket(): Connect to WebSocket API

  • disconnect_websocket(): Disconnect from WebSocket API

Resources

  • whitebit://markets: Get all markets information

  • whitebit://markets/{market}: Get specific market information

  • whitebit://assets: Get all assets information

  • whitebit://assets/{asset}: Get specific asset information

Command-line Interface

# Show help
aiowhitebit-mcp --help

# Run with stdio transport (for Claude Desktop)
aiowhitebit-mcp --transport stdio

# Run with SSE transport
aiowhitebit-mcp --transport sse --host localhost --port 8000

Development

# Clone the repository
git clone https://github.com/yourusername/aiowhitebit-mcp.git
cd aiowhitebit-mcp

# Install development dependencies
pip install -e ".[dev]"

# Install pre-commit hooks
pre-commit install

# Run tests
pytest

# Run type checking
pyright src/aiowhitebit_mcp

# Run linting
ruff check .

Examples

Check the examples/ directory for more usage examples:

  • claude_desktop_server.py: Run the server with stdio transport for Claude Desktop

  • claude_desktop_client.py: Client for connecting to a stdio server

  • sse_server.py: Run the server with SSE transport

  • sse_client.py: Client for connecting to an SSE server

License

Apache License 2.0

Install Server
A
license - permissive license
B
quality
B
maintenance

Maintenance

Maintainers
Response time
7wRelease cycle
4Releases (12mo)

Resources

Unclaimed servers have limited discoverability.

Looking for Admin?

If you are the server author, to access and configure the admin panel.

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/doubledare704/aiowhitebit-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server