Skip to content

edgex-Tech/edgex-python-sdk

Repository files navigation

EdgeX Python SDK

A Python SDK for interacting with the EdgeX Exchange API. This SDK provides a comprehensive interface to the EdgeX API, allowing you to easily integrate EdgeX functionality into your Python applications.

Branch Status

The main branch contains the current EdgeX V2 SDK. The legacy V1 SDK has moved to the v1 branch and is deprecated. New integrations should use V2.

Features

  • Complete API Coverage: Access all EdgeX API endpoints
  • WebSocket Support: Real-time data streaming
  • Async/Await: Modern Python async interface
  • Type Hints: Comprehensive type annotations for better IDE support
  • Error Handling: Proper error handling and validation
  • Pagination: Support for paginated API endpoints
  • Authentication: Automatic request signing

Installation

From PyPI

pip install edgex-python-sdk

Version Compatibility

edgex-python-sdk on PyPI has two incompatible API generations:

  • <= 0.3.0: contract v1 API SDK
  • >= 2.0.0: contract v2 API SDK

These two generations are not backward compatible. Please choose the package version based on the API generation you are integrating with.

Examples:

# Contract v1 API SDK
pip install "edgex-python-sdk<=0.3.0"

# Contract v2 API SDK
pip install "edgex-python-sdk>=2.0.0"

From Source

git clone https://github.com/edgex-Tech/edgex-python-sdk.git
cd edgex-python-sdk
pip install -e .

Using Requirements Files

For production use:

pip install -r requirements.txt

For development (includes testing and linting tools):

pip install -r requirements-dev.txt

Virtual Environment (Recommended)

It's recommended to use a virtual environment:

# Create virtual environment
python3 -m venv venv

# Activate virtual environment
source venv/bin/activate  # On Windows: venv\Scripts\activate

# Install dependencies
pip install -r requirements.txt

# Or install in development mode
pip install -e .

Quick Start

import asyncio
import os
from edgex_sdk import Client, OrderSide

async def main():
    # Create a new client
    client = Client(
        base_url="https://edgex-prod-v2.edgex.exchange",
        asset_base_url="https://spot.edgex.exchange",
        account_id=12345,  # Your account ID
        trading_private_key="your-trading-private-key"  # Your trading private key
    )

    # Get server time
    server_time = await client.get_server_time()
    print(f"Server Time: {server_time}")

    # Get exchange metadata
    metadata = await client.get_metadata()
    print(f"Available contracts: {len(metadata.get('data', {}).get('contractList', []))}")

    # Get account assets
    assets = await client.get_account_asset()
    print(f"Account Assets: {assets}")

    # Get account positions
    positions = await client.get_account_positions()
    print(f"Account Positions: {positions}")

    # Get 24-hour market data for BNB2USDT (contract ID: 10000004)
    quote = await client.get_24_hour_quote("10000004")
    print(f"BNB2USDT Price: {quote}")

    # Create a limit order (uncomment to place real order)
    # order = await client.create_limit_order(
    #     contract_id="10000004",  # BNB2USDT
    #     size="0.01",
    #     price="600.00",
    #     side=OrderSide.BUY
    # )
    # print(f"Order created: {order}")

# Run the async function
asyncio.run(main())

Architecture

The SDK is organized into modules that correspond to the EdgeX API structure:

edgex_sdk/
├── __init__.py
├── client.py           # Main client
├── account/            # Account API
├── funding/            # Funding API
├── internal/           # Internal utilities
├── metadata/           # Metadata API
├── order/              # Order API
├── quote/              # Quote API
├── transfer/           # Transfer API
├── unified_asset/      # Unified asset withdraw / transfer flows
├── cctp/               # Circle CCTP bridge helpers
└── ws/                 # WebSocket API

Available APIs

The SDK currently supports the following API modules:

  • Account API: Manage account positions, retrieve position transactions, and handle collateral transactions

    • Get account positions
    • Get position by contract ID
    • Get position transaction history
    • Get collateral transaction details
    • Update leverage settings
  • Unified Asset API: Current market-maker withdrawal flow

    • Build Spot / Perp V2 withdraw attempts with raw token amounts
    • Get fee via getFeeByAssetFlow
    • Sign server-provided EIP-712 payloads
    • Submit flows through submitAssetFlow
  • CCTP Bridge Helpers: Edge Mainnet USDC bridge support

    • Quote Circle CCTP fast-transfer fees
    • Build Edge depositForBurn bridge transactions
    • Fetch Iris V2 attestations
    • Build / submit Ethereum receiveMessage claim transactions
  • Funding API: Manage funding operations and account balance

    • Handle funding transactions
    • Manage funding accounts
    • Get funding transaction history
  • Metadata API: Access exchange system information

    • Get server time
    • Get exchange metadata (trading pairs, contracts, etc.)
  • Order API: Comprehensive order management

    • Create and cancel orders
    • Get active orders
    • Get order fill transactions
    • Calculate maximum order sizes
    • Manage order history
  • Quote API: Access market data and pricing

    • Get multi-contract K-line data
    • Get order book depth
    • Access real-time market quotes
    • Get 24-hour ticker data
  • Transfer API: Handle asset transfers

    • Create transfer out orders
    • Get transfer records (in/out)
    • Check available withdrawal amounts
    • Manage transfer history
  • WebSocket API: Real-time data streaming

    • Market data (tickers, K-lines, order book, trades)
    • Account updates
    • Order updates
    • Position updates

WebSocket Support

The SDK provides a WebSocket manager for handling real-time data:

import asyncio
from edgex_sdk import WebSocketManager

async def main():
    # Create a WebSocket manager
    ws_manager = WebSocketManager(
        base_url="wss://edgex-quote-prod-v2.edgex.exchange",
        account_id=12345,
        api_key="",
        api_passphrase="",
        api_secret=""
    )

    # Define message handlers
    def ticker_handler(message):
        print(f"Ticker Update: {message}")

    def kline_handler(message):
        print(f"K-line Update: {message}")

    # Connect to public WebSocket for market data
    ws_manager.connect_public()

    # Subscribe to real-time updates for BNB2USDT (contract ID: 10000004)
    ws_manager.subscribe_ticker("10000004", ticker_handler)
    ws_manager.subscribe_kline("10000004", "1m", kline_handler)

    # Connect to private WebSocket for account updates
    ws_manager.connect_private()

    # Wait for updates
    await asyncio.sleep(30)

    # Disconnect all connections
    ws_manager.disconnect_all()

asyncio.run(main())

Signing

The v2 SDK uses different keys for different signing flows:

  • trading private key: EIP-712 signing for order placement and setMarginMode
  • wallet private key: unified-asset withdrawal / transfer signing

Unified-asset withdrawals sign the EIP-712 payload returned by getEIP712Data and submit a 0x-prefixed signature. There is no StarkEx signing adapter in the v2 path.

Current Withdrawal Path

from edgex_sdk import Client, CreateWithdrawParams

client = Client(
    base_url="https://edgex-prod-v2.edgex.exchange",
    asset_base_url="https://spot.edgex.exchange",
    account_id=12345,
    api_key="...",
    api_passphrase="...",
    api_secret="...",
    wallet_private_key="...",
)

result = await client.create_withdraw(CreateWithdrawParams(
    amount_raw="1000000",
    user_address="0xYourWallet",
    profile="mainnet-usdc",
))

Use source="perpv2" and the Perp V2 account ID in source_account to reuse the same unified-asset withdrawal path for Perp V2.

Error Handling

The SDK provides proper error handling for API requests:

import asyncio
from edgex_sdk import Client, OrderSide

async def main():
    client = Client(
        base_url="https://edgex-prod-v2.edgex.exchange",
        account_id=12345,
        trading_private_key="your-trading-private-key"
    )

    try:
        # Create a limit order for BNB2USDT
        order = await client.create_limit_order(
            contract_id="10000004",  # BNB2USDT
            size="0.01",
            price="600.00",
            side=OrderSide.BUY
        )
        print(f"Order created: {order}")

        # Cancel the order
        from edgex_sdk import CancelOrderParams
        cancel_params = CancelOrderParams(
            order_id=order.get("data", {}).get("orderId")
        )
        cancel_result = await client.cancel_order(cancel_params)
        print(f"Order cancelled: {cancel_result}")

    except ValueError as e:
        print(f"Failed to create/cancel order: {str(e)}")
    except Exception as e:
        print(f"Unexpected error: {str(e)}")

asyncio.run(main())

Pagination

Many API endpoints support pagination:

import asyncio
from edgex_sdk import Client, GetActiveOrderParams

async def main():
    client = Client(
        base_url="https://edgex-prod-v2.edgex.exchange",
        account_id=12345,
        trading_private_key="your-trading-private-key"
    )

    # Create pagination parameters
    params = GetActiveOrderParams(
        size="10",
        offset_data=""
    )

    # Get active orders
    orders = await client.get_active_orders(params)
    print(f"Active orders: {orders}")

    # Get next page if available
    if orders.get("data", {}).get("hasNext"):
        params.offset_data = orders.get("data", {}).get("offsetData")
        next_page = await client.get_active_orders(params)
        print(f"Next page: {next_page}")

asyncio.run(main())

API Examples

Market Data

Available Enums

KlineType (K-line intervals):

  • KlineType.MINUTE_1, KlineType.MINUTE_5, KlineType.MINUTE_15, KlineType.MINUTE_30
  • KlineType.HOUR_1, KlineType.HOUR_2, KlineType.HOUR_4, KlineType.HOUR_6, KlineType.HOUR_8, KlineType.HOUR_12
  • KlineType.DAY_1, KlineType.WEEK_1, KlineType.MONTH_1

PriceType (price types):

  • PriceType.LAST_PRICE (default) - Latest market price
  • PriceType.INDEX_PRICE - Index price
  • PriceType.ORACLE_PRICE - Oracle price
  • PriceType.ASK1_PRICE - Best ask price
  • PriceType.BID1_PRICE - Best bid price
  • PriceType.OPEN_INTEREST - Open interest
from edgex_sdk import Client, GetKLineParams, GetOrderBookDepthParams, KlineType, PriceType

# Get 24-hour market quotes for BNB2USDT (contract ID: 10000004)
quote = await client.get_24_hour_quote("10000004")
print(f"Current price: {quote}")

# Get K-line data for BTCUSDT (contract ID: 10000001)
kline_params = GetKLineParams(
    contract_id="10000001",  # BTCUSDT
    kline_type=KlineType.MINUTE_1,
    price_type=PriceType.LAST_PRICE,
    size=10
)

# With time filters (optional)
# kline_params = GetKLineParams(
#     contract_id="10000001",
#     kline_type=KlineType.HOUR_1,
#     price_type=PriceType.LAST_PRICE,
#     size=20,
#     filter_begin_kline_time_inclusive="1640995200000",  # Start timestamp
#     filter_end_kline_time_exclusive="1640998800000"     # End timestamp
# )


klines = await client.quote.get_k_line(kline_params)
print(f"K-lines: {klines}")

# Get order book depth for ETHUSDT (contract ID: 10000002)
depth_params = GetOrderBookDepthParams(
    contract_id="10000002",  # ETHUSDT
    limit=10
)
depth = await client.quote.get_order_book_depth(depth_params)
print(f"Order book: {depth}")

Account Management

# Get account assets
assets = await client.get_account_asset()
print(f"Account assets: {assets}")

# Get account positions
positions = await client.get_account_positions()
print(f"Positions: {positions}")

# Get position transactions
from edgex_sdk import GetPositionTransactionPageParams
tx_params = GetPositionTransactionPageParams(
    size="10",
    offset_data=""
)
transactions = await client.account.get_position_transaction_page(tx_params)
print(f"Transactions: {transactions}")

Order Management

from edgex_sdk import OrderSide, CreateOrderParams, CancelOrderParams

# Create a limit order for BNBUSDT
order = await client.create_limit_order(
    contract_id="10000004",  # BNBUSDT
    size="0.01",
    price="600.00",
    side=OrderSide.BUY
)
print(f"Order created: {order}")

# Get maximum order size for BNBUSDT
max_size = await client.get_max_order_size("10000004", 600.00)
print(f"Max order size: {max_size}")

# Cancel an order
cancel_params = CancelOrderParams(
    order_id=order.get("data", {}).get("orderId")
)
cancel_result = await client.cancel_order(cancel_params)
print(f"Order cancelled: {cancel_result}")

Contract IDs

EdgeX uses numeric contract IDs instead of symbol-based identifiers. Here are some common contract mappings:

Contract ID Symbol Tick Size
10000001 BTCUSDT 0.1
10000002 ETHUSDT 0.01
10000003 SOLUSDT 0.01

To get the complete list of available contracts:

metadata = await client.get_metadata()
contracts = metadata.get("data", {}).get("contractList", [])
for contract in contracts:
    print(f"ID: {contract['contractId']} - {contract['contractName']}")

For more detailed examples, please refer to the examples directory.

Testing

The SDK includes comprehensive test coverage with multiple test suites:

Unit Tests

# Run unit tests (no API credentials required)
python -m pytest tests/test_client.py tests/test_eip712_signing.py -v

Public API Tests

# Run public endpoint tests (no authentication required)
python run_public_tests.py

Mock Integration Tests

# Run mock tests (test structure without real API calls)
python run_mock_tests.py

Full Integration Tests

# Run full integration tests (requires real API credentials)
python run_integration_tests.py

All Tests

# Run all available tests
python run_tests.py

For more testing information, see TESTING.md.

Environment Variables

For testing and development, you can set the following environment variables or create a .env file:

# API Configuration
EDGEX_BASE_URL=https://edgex-prod-v2.edgex.exchange
EDGEX_ASSET_BASE_URL=https://spot.edgex.exchange
EDGEX_WS_URL=wss://edgex-quote-prod-v2.edgex.exchange

# Account Credentials
EDGEX_ACCOUNT_ID=12345
EDGEX_TRADING_PRIVATE_KEY=your-trading-private-key

Then load them in your code:

import os
from dotenv import load_dotenv
from edgex_sdk import Client

# Load environment variables from .env file
load_dotenv()

client = Client(
    base_url=os.getenv("EDGEX_BASE_URL"),
    asset_base_url=os.getenv("EDGEX_ASSET_BASE_URL"),
    account_id=int(os.getenv("EDGEX_ACCOUNT_ID")),
    trading_private_key=os.getenv("EDGEX_TRADING_PRIVATE_KEY")
)

Documentation

For detailed API documentation, please refer to the EdgeX API documentation.

Contributing

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

License

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

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

 
 
 

Contributors

Languages