Skip to main content

Asynchronous Python client for the ByBit API

Project description

AioPyBit - Python Client for ByBit API (v5)

Python Version ByBit API License

AioPyBit is a modern and convenient Python client for the ByBit cryptocurrency exchange API (v5). The module provides real-time access to market data and private account information via efficient WebSocket connections, and also supports HTTP requests with advanced error handling and auto-retry mechanisms.

🚀 Features

  • 🔗 Advanced WebSocket Manager: Unified manager for multiple connections and subscriptions
  • 📊 Real-time Market Data: Access live ticker, orderbook, trades, and kline data
  • 👤 Private Account Streams: Monitor orders, executions, positions, and wallet balances
  • 🌍 Multiple Environments: Support for mainnet, testnet, and demo environments
  • 💪 Robust Connection Management: Automatic ping/pong, error handling, and reconnection
  • 🔄 Enhanced Retry Mechanism: HTTP requests with exponential backoff retry
  • ⚡ Auto-Reconnection: WebSocket automatic reconnection with subscription restoration
  • 📝 Subscription Management: Easy subscribe/unsubscribe with pattern matching
  • 🛡️ Type-Safe: Full type annotations with protocol definitions
  • 🎯 Easy Integration: Simple async/await interface with callback handlers
  • 🧹 Connection Cleanup: Graceful cleanup and resource management

📋 Requirements

  • Python 3.10+
  • websockets >= 10.0
  • aiohttp >= 3.8.0
  • asyncio (built-in)

🛠️ Installation

pip install aiopybit

# The module is ready to use - no separate installation needed

🏗️ Architecture

Core Components

  • ByBitWebSocketManager: High-level manager for multiple WebSocket connections
  • ByBitWebSocketClient: Low-level WebSocket client with connection management
  • ByBitPublicStreamsMixin: Methods for public market data streams
  • ByBitPrivateStreamsMixin: Methods for private account data streams
  • Protocol Definitions: Type-safe interfaces in protocols.py

Supported Streams

Public Streams (No Authentication Required)

  • Tickers: Real-time price and volume data
  • Orderbook: Live order book updates with configurable depth
  • Public Trades: Recent trade executions
  • Klines/Candlesticks: OHLCV data with various intervals
  • Liquidations: Liquidation events

Private Streams (API Credentials Required)

  • Orders: Real-time order status updates
  • Executions: Trade execution notifications
  • Positions: Position changes and P&L updates
  • Wallet: Account balance updates
  • Greeks: Option portfolio greeks (for options accounts)

🔧 Quick Start

Simple WebSocket Manager Usage

import asyncio
from aiopybit import ByBitClient


client = ByBitClient(API_KEY, API_SECRET, MODE)


async def handle_ticker(data):
	ticker = data.get('data', {})
	symbol = ticker.get('symbol', 'N/A')
	price = ticker.get('lastPrice', 'N/A')
	print(f'📊 {symbol}: ${price}')


async def main():
	await client.ws.subscribe_to_ticker(
		category='spot', symbol='BTCUSDT', on_message=handle_ticker
	)
	try:
		while True:
			await asyncio.sleep(1)
	except KeyboardInterrupt:
		pass

	await client.close()


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

The examples/ directory contains comprehensive usage examples:

🔐 Authentication

For private streams, you need ByBit API credentials:

  1. Create account at ByBit
  2. Go to API Management
  3. Create new API key with appropriate permissions
  4. Use testnet for development: ByBit Testnet

Required Permissions for Private Streams

  • Read: For position, wallet, and order data
  • Trade: For order and execution streams (if trading)

🌐 Supported Environments

Environment Description WebSocket URLs
mainnet Production environment wss://stream.bybit.com/v5/
testnet Testing environment wss://stream-testnet.bybit.com/v5/
demo Demo environment (limited features) wss://stream-demo.bybit.com/v5/

📊 Market Categories

Category Description Supported Streams
linear USDT/USDC perpetual contracts All public streams
spot Spot trading pairs Tickers, orderbook, trades
option Options contracts All public + greeks

🔄 Connection Management

The client includes robust connection management features:

  • Automatic Ping/Pong: Maintains connection with 20-second intervals
  • Error Handling: Graceful handling of connection errors
  • Resource Cleanup: Proper cleanup of tasks and connections

📖 API Reference

ByBitWebSocketManager

High-level WebSocket manager for multiple connections and subscriptions.

Constructor Parameters

  • mode: Environment ('mainnet', 'testnet', 'demo')
  • api_key: ByBit API key (required for private streams)
  • api_secret: ByBit API secret (required for private streams)
  • ping_interval: Ping interval in seconds (default: 20)
  • ping_timeout: Ping timeout in seconds (default: 10)
  • auto_reconnect: Enable auto-reconnection (default: True)

Connection Management Methods

  • get_websocket(channel_type): Get or create WebSocket for channel
  • close_all(): Close all WebSocket connections

Public Stream Methods

  • subscribe_to_ticker(category, symbol, on_message)
  • subscribe_to_orderbook(category, symbol, on_message, depth)
  • subscribe_to_public_trades(category, symbol, on_message)
  • subscribe_to_kline(category, symbol, interval, on_message)
  • subscribe_to_liquidations(category, symbol, on_message)

Private Stream Methods

  • subscribe_to_order(on_message)
  • subscribe_to_execution(on_message)
  • subscribe_to_position(on_message)
  • subscribe_to_wallet(on_message)
  • subscribe_to_greeks(on_message)

ByBitWebSocketClient

Low-level WebSocket client class with connection management.

Constructor Parameters

  • url: WebSocket URL
  • api_key: ByBit API key (optional for public streams)
  • api_secret: ByBit API secret (optional for public streams)
  • ping_interval: Ping interval in seconds (default: 20)
  • ping_timeout: Ping timeout in seconds (default: 10)
  • auto_reconnect: Enable auto-reconnection (default: True)

📝 Logging

Enable logging to monitor connection status and debug issues:

import logging

# Configure logging
logging.basicConfig(
    level=logging.INFO,
    format='%(asctime)s [%(levelname)s] %(name)s: %(message)s'
)

# Set specific logger levels
logging.getLogger('aiopybit').setLevel(logging.INFO)

# For detailed debugging
logging.getLogger('aiopybit').setLevel(logging.DEBUG)

Log levels:

  • DEBUG: Detailed connection and message information
  • INFO: Connection status and important events
  • WARNING: Connection issues and recoverable errors
  • ERROR: Critical errors and failures

Example log output:

2024-01-15 10:30:45 [INFO] aiopybit: WebSocket connection for wss://stream.bybit.com/v5/public/linear established
2024-01-15 10:30:45 [INFO] aiopybit: ✅ Subscribed to tickers.BTCUSDT
2024-01-15 10:30:46 [DEBUG] aiopybit: Sending ping for wss://stream.bybit.com/v5/public/linear
2024-01-15 10:31:05 [INFO] aiopybit: 📊 BTCUSDT: $45,123.45

🔗 Related Links

📄 License

This project is licensed under the MIT License. See the LICENSE file for details.

🤝 Contributing

Contributions are welcome! Please feel free to submit pull requests or open issues for bugs and feature requests.

⚠️ Disclaimer

This software is for educational and development purposes. Use at your own risk. The authors are not responsible for any financial losses incurred through the use of this software.


Happy Trading! 🚀

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

aiopybit-0.1.2.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

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

aiopybit-0.1.2-py3-none-any.whl (22.8 kB view details)

Uploaded Python 3

File details

Details for the file aiopybit-0.1.2.tar.gz.

File metadata

  • Download URL: aiopybit-0.1.2.tar.gz
  • Upload date:
  • Size: 21.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.12

File hashes

Hashes for aiopybit-0.1.2.tar.gz
Algorithm Hash digest
SHA256 5eaf50d4f25f49a3a45c03e89fb60344eb18e406faf4b8811c5b35e52693e763
MD5 ad8a26d52b08335b1453d7e0476d6913
BLAKE2b-256 a279c4205158e349a7b549ed02f85c49424cff07603e9c7aae01b6a2144790ac

See more details on using hashes here.

File details

Details for the file aiopybit-0.1.2-py3-none-any.whl.

File metadata

  • Download URL: aiopybit-0.1.2-py3-none-any.whl
  • Upload date:
  • Size: 22.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.12

File hashes

Hashes for aiopybit-0.1.2-py3-none-any.whl
Algorithm Hash digest
SHA256 cb4227d7265a5ac90e692e57161bca5c2d1847ac3c0048197e74b14c5732608f
MD5 a3cc5c9d60334913474c3be7bdb9990e
BLAKE2b-256 b6a72255a48fc18a502be5b17d792e168f862c802da0252bc3cc5c8f70a6da02

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