Python SDK for interacting with the Ethereal API
Project description
Ethereal Python SDK
A Python library for interacting with the Ethereal trading platform. This SDK provides tools for trading, managing positions, and accessing market data.
SDK Documentation
For full documentation, visit the documentation site.
View the source code on PyPI.
Installation
Using uv (Recommended)
uv is a fast Python package installer and resolver:
# Install uv if you don't have it
curl -LsSf https://astral.sh/uv/install.sh | sh
# Install the SDK
uv add ethereal-sdk
Using pip
pip install ethereal-sdk
uvloop installs automatically on CPython for macOS/Linux; Windows and other platforms fall back to asyncio.
Quick Start
The SDK provides two client types:
AsyncRESTClient (Recommended for new applications):
import asyncio
from decimal import Decimal
from ethereal import AsyncRESTClient
async def main():
client = await AsyncRESTClient.create({
"base_url": "https://api.etherealtest.net",
"chain_config": {
"rpc_url": "https://rpc.etherealtest.net",
"private_key": "your_private_key", # optional - required for trading
}
})
# Get market data
products = await client.list_products()
product_ids = [p.id for p in products]
prices = await client.list_market_prices(product_ids=product_ids)
# Place an order (requires private key)
await client.create_order(
order_type="LIMIT",
quantity=Decimal("1.0"),
side=0, # 0 for buy, 1 for sell
price=Decimal("100.0"),
ticker="BTCUSD"
)
await client.close()
asyncio.run(main())
RESTClient (Synchronous):
from decimal import Decimal
from ethereal import RESTClient
client = RESTClient({
"base_url": "https://api.etherealtest.net",
"chain_config": {
"rpc_url": "https://rpc.etherealtest.net",
"private_key": "your_private_key", # optional - required for trading
}
})
# Get market data
products = client.list_products()
# Place an order (requires private key)
order = client.create_order(
order_type="LIMIT",
quantity=Decimal("1.0"),
side=0,
price=Decimal("100.0"),
ticker="BTCUSD"
)
Main Features
Market Data
- List available trading products
- Get current market prices
- View market order book
- Track funding rates
Trading
- Place market and limit orders
- Cancel orders
- View order history
- Track trades and fills
Account Management
- Manage subaccounts
- View positions
- Track token balances
- Handle deposits and withdrawals
Websocket Support
- Real-time market data
- Live order book updates
Configuration
The SDK can be configured with these options:
private_key: Your private key for authenticationbase_url: API endpoint (default: "https://api.etherealtest.net")timeout: Request timeout in secondsverbose: Enable debug loggingrate_limit_headers: Enable rate limit headers
The SDK automatically enables uvloop on supported platforms and transparently falls back to the built-in asyncio loop elsewhere.
Examples
Get Market Data
async def get_market_data():
client = await AsyncRESTClient.create({"base_url": "https://api.ethereal.trade"})
# List all available products
products = await client.list_products()
# Get current prices
all_product_ids = [product.id for product in products]
prices = await client.list_market_prices(product_ids=all_product_ids)
# View market liquidity
products_by_ticker = await client.products_by_ticker()
btc_product_id = products_by_ticker['BTCUSD'].id
liquidity = await client.get_market_liquidity(product_id=btc_product_id)
await client.close()
asyncio.run(get_market_data())
Manage Orders
async def manage_orders():
config = {
"base_url": "https://api.ethereal.trade",
"chain_config": {
"rpc_url": "https://rpc.ethereal.trade",
"private_key": "your_private_key"
}
}
client = await AsyncRESTClient.create(config)
# Place a limit order
order = await client.create_order(
order_type="LIMIT",
quantity=Decimal("1.0"),
side=0,
price=Decimal("100.0"),
ticker="BTCUSD"
)
# Cancel an order
subaccounts = await client.subaccounts()
await client.cancel_orders(
order_ids=["<uuid of order>"],
sender=client.chain.address,
subaccount=subaccounts[0].name
)
# View order history
subaccount_id = subaccounts[0].id
orders = await client.list_orders(subaccount_id=subaccount_id)
await client.close()
asyncio.run(manage_orders())
Account Operations
async def account_operations():
config = {
"base_url": "https://api.ethereal.trade",
"chain_config": {
"rpc_url": "https://rpc.ethereal.trade",
"private_key": "your_private_key"
}
}
client = await AsyncRESTClient.create(config)
# List subaccounts
subaccounts = await client.subaccounts()
# View positions
positions = await client.list_positions(subaccount_id=subaccounts[0].id)
# Get token balances
balances = await client.get_subaccount_balances(subaccount_id=subaccounts[0].id)
await client.close()
asyncio.run(account_operations())
Ethereal Documentation
For full documentation, visit our documentation site.
Support
For issues and questions, please refer to the project's issue tracker or documentation.
Project details
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ethereal_sdk-0.1.3.tar.gz.
File metadata
- Download URL: ethereal_sdk-0.1.3.tar.gz
- Upload date:
- Size: 407.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2a4a853c107f0a144ec0c8d694a02aa13b5fd31ce21d22f74fa25c19a5bf1152
|
|
| MD5 |
63cee7daac4204abac26a9810406a2e1
|
|
| BLAKE2b-256 |
86fb386bbd9153e751ec620ee1248e0f585f08a4a3052dfa4d455cf115497244
|
File details
Details for the file ethereal_sdk-0.1.3-py3-none-any.whl.
File metadata
- Download URL: ethereal_sdk-0.1.3-py3-none-any.whl
- Upload date:
- Size: 220.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: uv/0.10.11 {"installer":{"name":"uv","version":"0.10.11","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"12","id":"bookworm","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5ef4ef7040eca481d2a777870d1d6be421db8d63a8fea592250c151e7733ecfc
|
|
| MD5 |
46a694bb92910387c27964688d30bc41
|
|
| BLAKE2b-256 |
c2b76f1ba98799d16d145ab4852517d3ad3bfb958b736cf9464bff47729cb8bd
|