Skip to main content

Developer SDK for validating and publishing trading signals

Project description

Quant Signal SDK

This repository now contains only the developer SDK package: quant_signal_sdk.

Local executor client code has been moved to local-executor-client in the workspace.

Features

  • Pydantic signal models and enums (SignalPayload, SignalSide, SignalAction).
  • Retry-enabled HTTP transport (NetworkClient) using requests and urllib3.Retry.
  • Optional HMAC SHA-256 payload signing helper (generate_hmac_signature).
  • High-level API client (QuantSignalClient) for authenticated signal submission.
  • Minimal BaseStrategy contract for strategy inheritance.
  • In-memory portfolio backtest runner with OHLCV replay and execution-policy enforcement.
  • Backtest publishing client for uploading completed BacktestReport objects to the backend.
  • Pluggable dry-run sync helpers (StateSyncer, HttpDryRunSyncer, WebSocketDryRunSyncer, FileSyncer).
  • Dedicated operational telemetry client (TelemetryClient) separate from dry-run PnL/state sync.

Quickstart

from quant_signal_sdk import QuantSignalClient, SignalPayload

client = QuantSignalClient(
    base_url="https://api.example.com",
    api_key="your-api-key",
    signer_secret="optional-signing-secret",
)

signal = SignalPayload(
    side="LONG",
    action="OPEN_LONG",
    symbol="BTCUSDT",
    tp=72000,
    sl=68500,
    confidence_score=0.84,
    metadata={"strategy": "trend_v1"},
)

result = client.send_signal(signal)
print(result)

Backtest

Create a my_bot.py file that exports a strategy class or STRATEGY object with on_event(...), then run:

quant-sdk backtest --bot-file my_bot.py --data-csv candles.csv --initial-cash 1000

The backtest engine replays OHLCV candles, queues signals for the next tick, and prints a simple portfolio summary when the run completes.

If your OHLCV data is stored as Parquet (recommended per GUIDE_DATA.md), point the CLI at the Parquet file or directory. Example using the dataset layout in GUIDE_DATA.md:

python -m quant_signal_sdk.cli backtest --bot-file my_bot.py \
    --data-parquet "D:\Code\Projects\self-projects\macd-overlay - Copy\data\ohlcv\BTCUSDT.parquet" \
    --timestamp-column timestamp --initial-cash 1000 --output-dir backtest_output_parquet --export-html

The CLI accepts either --data-csv (legacy) or --data-parquet (preferred). When a directory is passed to --data-parquet the first *.parquet file is used.

Publish backtest results

The backtest CLI still exports local CSV/HTML/JSON artifacts, but it can also upload the completed report to the backend as a historical run:

quant-sdk backtest --bot-file my_bot.py --data-csv candles.csv --initial-cash 1000 \
  --upload-backtest \
  --backend-url https://api.example.com \
  --bot-id bot_123 \
  --api-key <bot-api-key> \
  --signer-secret <optional-signing-secret>

The upload is batch-only. Equity history and closed trades are stored as HISTORICAL, while live dry-run sync continues through /api/v1/bots/{botId}/dry-run/sync.

Dry-run and telemetry

For live paper trading, build a StateSyncer around DryRunSyncClient and DryRunStateTracker. This keeps the state sync loop outside Runner so the transport can be REST, WebSocket, or file-based without changing core strategy execution.

Operational telemetry is separate. Use TelemetryClient for metrics like CPU, latency, and heartbeat-style signals instead of reusing the dry-run transport.

Requirements

  • Python 3.10+

Setup

Install the library for local development:

pip install -e .

Install with SDK development tools:

pip install -e .[dev]

Install optional market-data helpers:

pip install -e .[market-data]

Install both dev and market-data extras together:

pip install -e .[dev,market-data]

After publishing to PyPI, users can install the released package with:

pip install quant-signal-sdk

Tests

python -m unittest discover -s tests -v

Release

Build the distribution and validate the artifacts before upload:

python -m build --sdist --wheel
python -m twine check dist/*

If you use GitHub Actions trusted publishing, the workflow in .github/workflows/publish-pypi.yml publishes automatically when you create a GitHub Release. Configure the PyPI trusted publisher once for this repository, then stop using API tokens for uploads.

Example: register -> signer secret behavior

When registering a bot via the example examples/sample_bot.py, the backend returns both an apiKey (runtime API key) and a rawSecret (signer secret). The example attaches the returned rawSecret to the QuantSignalClient as the signer_secret when the user did not already supply one. This ensures subsequent signal POSTs include the required X-Timestamp and X-Signature headers that the server validates.

If you prefer to manage signing secrets yourself, pass --bot-signer-secret to the example and the returned rawSecret will not overwrite it.

Build

python -m build --sdist --wheel

Contract Fixtures

  • SDK fixtures are versioned under tests/fixtures/contracts.
  • SDK compatibility checks are in tests/test_contract_compatibility_sdk.py.

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

quant_signal_sdk-0.1.1.tar.gz (56.7 kB view details)

Uploaded Source

Built Distribution

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

quant_signal_sdk-0.1.1-py3-none-any.whl (54.6 kB view details)

Uploaded Python 3

File details

Details for the file quant_signal_sdk-0.1.1.tar.gz.

File metadata

  • Download URL: quant_signal_sdk-0.1.1.tar.gz
  • Upload date:
  • Size: 56.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for quant_signal_sdk-0.1.1.tar.gz
Algorithm Hash digest
SHA256 63f9545222f65080edb410e057ffb24d65c531ee5db6af3ebce8c448db293bf2
MD5 a3e385b56ded9451f7e427f3d0944756
BLAKE2b-256 f67636f220f74415814d8bc9f4d384793fd11ce0dd3e9893ab0ffc7450f271eb

See more details on using hashes here.

Provenance

The following attestation bundles were made for quant_signal_sdk-0.1.1.tar.gz:

Publisher: publish-pypi.yml on gnuhhung317/marcus-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file quant_signal_sdk-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for quant_signal_sdk-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 882d4ea1e84a256fae9a90995787818ede70e59c3cb000384ba75ed90a93dc35
MD5 b27c240722905ebb6a76696cd89fa467
BLAKE2b-256 b4081cb6141bd0907ab37c88b4c37a65a7259f3b411130c0c7e4d5270129bcca

See more details on using hashes here.

Provenance

The following attestation bundles were made for quant_signal_sdk-0.1.1-py3-none-any.whl:

Publisher: publish-pypi.yml on gnuhhung317/marcus-py

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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