Python SDK for interacting with Decibel, a fully on-chain trading engine built on Aptos.
Project description
decibel-python-sdk
Installation
pip install decibel-python-sdk
Or with uv:
uv add decibel-python-sdk
Configuration
Set the following environment variables:
# Required for write operations
export PRIVATE_KEY="your_private_key_hex"
# Optional: for better rate limits
export APTOS_NODE_API_KEY="your_aptos_node_api_key"
New to Decibel? Follow the Getting Started Guide to create your API Wallet and get your API key from Geomi.
Quick Start
Reading Market Data
import asyncio
from decibel import NETNA_CONFIG
from decibel.read import DecibelReadDex
async def main():
read = DecibelReadDex(NETNA_CONFIG)
# Get all markets
markets = await read.markets.get_all()
for market in markets:
print(f"{market.market_name}: {market.max_leverage}x leverage")
# Get market prices
prices = await read.market_prices.get_all()
for price in prices:
print(f"{price.market}: ${price.mark_px}")
asyncio.run(main())
Placing Orders
import asyncio
import os
from aptos_sdk.account import Account
from aptos_sdk.ed25519 import PrivateKey
from decibel import (
NETNA_CONFIG,
BaseSDKOptions,
DecibelWriteDex,
GasPriceManager,
PlaceOrderSuccess,
TimeInForce,
amount_to_chain_units,
)
from decibel.read import DecibelReadDex
async def main():
private_key = PrivateKey.from_hex(os.environ["PRIVATE_KEY"])
account = Account.load_key(private_key.hex())
gas = GasPriceManager(NETNA_CONFIG)
await gas.initialize()
read = DecibelReadDex(NETNA_CONFIG)
markets = await read.markets.get_all()
btc = next(m for m in markets if m.market_name == "BTC/USD")
write = DecibelWriteDex(
NETNA_CONFIG,
account,
opts=BaseSDKOptions(gas_price_manager=gas),
)
result = await write.place_order(
market_name="BTC/USD",
price=amount_to_chain_units(100000.0, btc.px_decimals),
size=amount_to_chain_units(0.001, btc.sz_decimals),
is_buy=True,
time_in_force=TimeInForce.GoodTillCanceled,
is_reduce_only=False,
)
if isinstance(result, PlaceOrderSuccess):
print(f"Order placed! ID: {result.order_id}")
else:
print(f"Order failed: {result.error}")
await gas.destroy()
asyncio.run(main())
WebSocket Streaming
import asyncio
from decibel import NETNA_CONFIG
from decibel.read import DecibelReadDex
async def main():
read = DecibelReadDex(NETNA_CONFIG)
def on_price(msg):
price = msg.price
print(f"BTC/USD: ${price.mark_px}")
unsubscribe = read.market_prices.subscribe_by_name("BTC/USD", on_price)
await asyncio.sleep(30)
unsubscribe()
await read.ws.close()
asyncio.run(main())
Examples
See the examples directory for complete working examples:
- examples/read - REST API queries (markets, prices, positions, orders)
- examples/read/ws - WebSocket subscriptions (real-time streaming)
- examples/write - Trading operations (orders, deposits, withdrawals)
API Reference
Network Configs
from decibel import MAINNET_CONFIG, TESTNET_CONFIG, NETNA_CONFIG
# MAINNET_CONFIG - Production network
# TESTNET_CONFIG - Test network
# NETNA_CONFIG - Dev network
Read Client
from decibel.read import DecibelReadDex
read = DecibelReadDex(config, api_key=None)
# Market data
read.markets.get_all()
read.market_prices.get_all()
read.market_prices.get_by_name(market_name)
read.market_depth.get_by_name(market_name, limit=50)
read.market_trades.get_by_name(market_name)
read.market_contexts.get_all()
read.candlesticks.get_by_name(market_name, interval, start_time, end_time)
# User data
read.account_overview.get_by_addr(sub_addr=sub_addr)
read.user_positions.get_by_addr(sub_addr=sub_addr)
read.user_open_orders.get_by_addr(sub_addr=sub_addr)
read.user_order_history.get_by_addr(sub_addr=sub_addr)
read.user_trade_history.get_by_addr(sub_addr=sub_addr)
read.user_bulk_orders.get_by_addr(sub_addr=sub_addr)
read.user_subaccounts.get_by_addr(owner_addr=addr)
read.user_fund_history.get_by_addr(sub_addr=sub_addr)
read.user_funding_history.get_by_addr(sub_addr=sub_addr)
read.user_active_twaps.get_by_addr(sub_addr=sub_addr)
read.user_twap_history.get_by_addr(sub_addr=sub_addr)
# Other
read.delegations.get_all(sub_addr=sub_addr)
read.leaderboard.get_leaderboard()
read.portfolio_chart.get_by_addr(sub_addr=sub_addr, time_range="7d", data_type="pnl")
read.vaults.get_vaults()
read.trading_points.get_by_owner(owner_addr=addr)
# WebSocket subscriptions
read.market_prices.subscribe_by_name(market_name, callback)
read.market_prices.subscribe_all(callback)
read.market_depth.subscribe_by_name(market_name, aggregation_size, callback)
read.market_trades.subscribe_by_name(market_name, callback)
read.candlesticks.subscribe_by_name(market_name, interval, callback)
read.account_overview.subscribe_by_addr(sub_addr, callback)
read.user_positions.subscribe_by_addr(sub_addr, callback)
read.user_open_orders.subscribe_by_addr(sub_addr, callback)
read.user_order_history.subscribe_by_addr(sub_addr, callback)
read.user_trade_history.subscribe_by_addr(sub_addr, callback)
read.user_bulk_orders.subscribe_by_addr(sub_addr, callback)
read.user_active_twaps.subscribe_by_addr(sub_addr, callback)
read.user_notifications.subscribe_by_addr(sub_addr, callback)
Write Client
from decibel import DecibelWriteDex, TimeInForce
write = DecibelWriteDex(config, account, opts)
# Orders
write.place_order(market_name=..., price=..., size=..., is_buy=..., time_in_force=..., is_reduce_only=...)
write.cancel_order(order_id=..., market_name=...)
write.cancel_client_order(client_order_id=..., market_name=...)
write.place_bulk_orders(market_name=..., sequence_number=..., bid_prices=..., bid_sizes=..., ask_prices=..., ask_sizes=...)
write.cancel_bulk_order(market_name=...)
# TP/SL
write.place_tp_sl_order_for_position(market_name=..., tp_price=..., sl_price=..., ...)
write.update_tp_order_for_position(market_name=..., order_id=..., new_trigger_price=..., ...)
write.update_sl_order_for_position(market_name=..., order_id=..., new_trigger_price=..., ...)
# TWAP
write.place_twap_order(market_name=..., size=..., is_buy=..., is_reduce_only=..., twap_frequency_seconds=..., twap_duration_seconds=...)
write.cancel_twap_order(market_addr=..., order_id=...)
# Collateral
write.deposit(amount)
write.withdraw(amount)
# Vaults
write.deposit_to_vault(vault_address=..., amount=..., subaccount_addr=...)
write.withdraw_from_vault(vault_address=..., shares=...)
# Subaccounts
write.create_subaccount()
write.deactivate_subaccount(subaccount_addr=...)
Development
make setup # Install dependencies + pre-commit hooks
make # Run full quality pipeline (format, lint, typecheck, test)
make lint # Check for lint errors
make fix # Auto-fix lint and format issues
make typecheck # Run pyright type checking
make test # Run tests
Generating ABI JSON Files
The SDK uses ABI JSON files to build on-chain transactions. These are fetched from the deployed smart contracts and stored in src/decibel/abi/json/. They should be regenerated whenever the on-chain contracts are updated.
# Generate ABIs for a specific network (default: mainnet)
make abi
make abi NETWORK=testnet
make abi NETWORK=mainnet
# Generate ABIs for all networks
make abi-all
Resources
- 📚 Documentation - Full API documentation
- 🌐 Trading Platform - Decibel trading interface
- 💬 Discord - Community support
License
This project is licensed under the MIT License - see the LICENSE file for details.
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
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 decibel_python_sdk-0.2.1.tar.gz.
File metadata
- Download URL: decibel_python_sdk-0.2.1.tar.gz
- Upload date:
- Size: 58.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4179cfdb4a4efef6985b724c75f59d18b7a21adce490cac719ff99893ccd7f4b
|
|
| MD5 |
c698ee86439f738efc81e4b78aac1b1b
|
|
| BLAKE2b-256 |
ab4fa1c077acb62b18203955cbf688119d9ef9bdf71bee221b8e266b7fec2a26
|
Provenance
The following attestation bundles were made for decibel_python_sdk-0.2.1.tar.gz:
Publisher:
pypi_publish.yml on decibeltrade/python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
decibel_python_sdk-0.2.1.tar.gz -
Subject digest:
4179cfdb4a4efef6985b724c75f59d18b7a21adce490cac719ff99893ccd7f4b - Sigstore transparency entry: 1258263044
- Sigstore integration time:
-
Permalink:
decibeltrade/python-sdk@6a5030bc2650d7d2106d18ea1d78eeccf32ae6dc -
Branch / Tag:
refs/heads/main - Owner: https://github.com/decibeltrade
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi_publish.yml@6a5030bc2650d7d2106d18ea1d78eeccf32ae6dc -
Trigger Event:
push
-
Statement type:
File details
Details for the file decibel_python_sdk-0.2.1-py3-none-any.whl.
File metadata
- Download URL: decibel_python_sdk-0.2.1-py3-none-any.whl
- Upload date:
- Size: 81.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3c778693374d91c46f3ca044af98f9a16a4e342b5704aa122be46b95d0753c73
|
|
| MD5 |
d6a9fd9ce0b54dddb6ec78f70c6f4ca5
|
|
| BLAKE2b-256 |
46d658a89de3582417a6f75c0e5bfd4f3a9c60d569339d2ad08c50ad5cf9b566
|
Provenance
The following attestation bundles were made for decibel_python_sdk-0.2.1-py3-none-any.whl:
Publisher:
pypi_publish.yml on decibeltrade/python-sdk
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
decibel_python_sdk-0.2.1-py3-none-any.whl -
Subject digest:
3c778693374d91c46f3ca044af98f9a16a4e342b5704aa122be46b95d0753c73 - Sigstore transparency entry: 1258263116
- Sigstore integration time:
-
Permalink:
decibeltrade/python-sdk@6a5030bc2650d7d2106d18ea1d78eeccf32ae6dc -
Branch / Tag:
refs/heads/main - Owner: https://github.com/decibeltrade
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
pypi_publish.yml@6a5030bc2650d7d2106d18ea1d78eeccf32ae6dc -
Trigger Event:
push
-
Statement type: