Skip to main content

No project description provided

Project description

Derive Client

Python client for Derive Protocol - a decentralized derivatives trading platform on its own Ethereum L2

Trade options, perpetuals, and spot with full self-custody through smart contract wallets.

Full Documentation

CLI Tool Demo

Here is a quick demonstration of the CLI functionality:

Demo of CLI tools

Installation from PyPI

pip install derive-client

Quickstart

Create .env file

DERIVE_SESSION_KEY=0x2ae8be44db8a590d20bffbe3b6872df9b569147d3bf6801a35a28281a4816bbd
DERIVE_WALLET=0xA419f70C696a4b449a4A24F92e955D91482d44e9
DERIVE_SUBACCOUNT_ID=137626
DERIVE_ENV=TEST

Setup client, check market data and place an order.

from derive_client import HTTPClient
from derive_client.data_types import D, Direction, OrderType

# Initialize client
client = HTTPClient.from_env()

# Check market data
ticker = client.markets.get_ticker(instrument_name="ETH-PERP")

# Place an order
order_result = client.orders.create(
    instrument_name="ETH-PERP",
    amount=D("0.10"),  # 0.10 ETH
    limit_price=D("1000"),  # Buy at $1000
    direction=Direction.buy,
    order_type=OrderType.limit,
)

Examples

The fastest way to learn is by running the examples:

# Clone the repo (examples are not included in the package)
git clone git@github.com:8ball030/derive_client.git
cd derive_client

# Install editable with pip
pip install -e .

# Run with testnet credentials (pre-configured)
python examples/01_quickstart.py

The examples use .env.template with pre-filled testnet credentials, so you can run them immediately without setup.

  • 01_quickstart.py - Connect and Place Your First Trade
  • 02_market_data.py - Exploring Available Markets and Price Information
  • 03_collateral_management.py - Deposits, Withdrawals, and Margin.
  • 04_trading_basics.py - Order Lifecycle and Management
  • 05_position_transfer.py - Moving Positions Between Subaccounts
  • 06_bridging.py - Moving Assets Between Chains

NOTE: The bridging example cannot be ran using the TEST environment, as bridging is only available in PROD.

Using Your Own Account

To trade on mainnet or with your own testnet account:

  1. Register at derive.xyz to get your LightAccount wallet
  2. Create a subaccount
  3. Register a session key (regular Ethereum private key for an EOA) as session key via the Developers page
  4. Copy .env.template to .env and add your credentials:
DERIVE_WALLET=0x...           # Your LightAccount address
DERIVE_SESSION_KEY=0x...      # Session key private key
DERIVE_SUBACCOUNT_ID=1        # Your subaccount ID
DERIVE_ENV=PROD               # TEST or PROD

See authentication.md for a more detailed explanation.

Documentation

📖 Full Documentation

Development

From Source (for development)

git clone git@github.com:8ball030/derive_client.git
cd derive_client

# Install and spawn the virtual environment
make install
poetry shell

Quick Commands

make fmt        # Format code
make lint       # Run linters
make typecheck  # Type checking
make tests      # Run tests

Code Generation

make codegen-all

API Docs Generation

make docs

Or, run all the above make commands sequentially using simply:

make all

Releasing

Bump version and create release:

export new_version=0.1.5
tbump $new_version

The release workflow will automatically create a GitHub release and publish to PyPI.

Contributors

Karrenbelt
Zarathustra
8ball030
8ball030
Aviksaikat
Saikat K
andreiaugustin
Andrei Augustin
0xdomrom
DomRom
DeBelg
Mf

Supporting This Project

This client library is developed and maintained as an independent open-source project. When you use this library to trade on Derive, we may receive a small referral bonus (configured via the referral_code field in API requests). This helps sustain ongoing development and maintenance. We also set a default client identifier to help Derive track usage statistics across different client implementations. All code is open source and can be audited in this repository.

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

derive_client-0.3.13.tar.gz (390.4 kB view details)

Uploaded Source

Built Distribution

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

derive_client-0.3.13-py3-none-any.whl (703.1 kB view details)

Uploaded Python 3

File details

Details for the file derive_client-0.3.13.tar.gz.

File metadata

  • Download URL: derive_client-0.3.13.tar.gz
  • Upload date:
  • Size: 390.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for derive_client-0.3.13.tar.gz
Algorithm Hash digest
SHA256 edcbaafa1fe3b363ea5b885b0d16f6323e43fca70eb107c6dca6bf6c4b62f598
MD5 8dfb1c72b7aad0a3417393574258b8c4
BLAKE2b-256 174ea821ab9d6cf67315e9860bab16555cdade78bdaa308c6c835e7e4e49f644

See more details on using hashes here.

File details

Details for the file derive_client-0.3.13-py3-none-any.whl.

File metadata

  • Download URL: derive_client-0.3.13-py3-none-any.whl
  • Upload date:
  • Size: 703.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for derive_client-0.3.13-py3-none-any.whl
Algorithm Hash digest
SHA256 42d577dfc01d4819c4d427c60acee433d3b78b1f71b46e7febb90eb020bedf3e
MD5 93c3d6dfd26cc776554db723518ef181
BLAKE2b-256 7733f29af35aaeb6b22678a9eadb400e2863321e56f4d30f1e2f4c2725989790

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