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) usingrequestsandurllib3.Retry. - Optional HMAC SHA-256 payload signing helper (
generate_hmac_signature). - High-level API client (
QuantSignalClient) for authenticated signal submission. - Minimal
BaseStrategycontract for strategy inheritance. - In-memory portfolio backtest runner with OHLCV replay and execution-policy enforcement.
- Backtest publishing client for uploading completed
BacktestReportobjects 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
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 quant_signal_sdk-0.1.2.tar.gz.
File metadata
- Download URL: quant_signal_sdk-0.1.2.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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8906662fda265adef42311438955b5d21666b48ae9a53bf67b0baaf6d4ca7b99
|
|
| MD5 |
fe1e0e35df34ca7781976b16ae7b4ce5
|
|
| BLAKE2b-256 |
f07d645394b781937195c61c900ec64bd9e50af5045e136ac5c4ac92f4caa39f
|
Provenance
The following attestation bundles were made for quant_signal_sdk-0.1.2.tar.gz:
Publisher:
publish-pypi.yml on gnuhhung317/marcus-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
quant_signal_sdk-0.1.2.tar.gz -
Subject digest:
8906662fda265adef42311438955b5d21666b48ae9a53bf67b0baaf6d4ca7b99 - Sigstore transparency entry: 1721554742
- Sigstore integration time:
-
Permalink:
gnuhhung317/marcus-py@668b7d8cdeeb9f2ee370cdb21de9a32a5e5c354e -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/gnuhhung317
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@668b7d8cdeeb9f2ee370cdb21de9a32a5e5c354e -
Trigger Event:
release
-
Statement type:
File details
Details for the file quant_signal_sdk-0.1.2-py3-none-any.whl.
File metadata
- Download URL: quant_signal_sdk-0.1.2-py3-none-any.whl
- Upload date:
- Size: 54.6 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 |
fd12064ea75b463b6e482da737f44262508298e72553b8798a76e33962b3838f
|
|
| MD5 |
52143a33d6664420c02976c5d1b15fed
|
|
| BLAKE2b-256 |
b739f5cf78d54d7516b428446233e3139868613e8e579ee0cf335806958eb13c
|
Provenance
The following attestation bundles were made for quant_signal_sdk-0.1.2-py3-none-any.whl:
Publisher:
publish-pypi.yml on gnuhhung317/marcus-py
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
quant_signal_sdk-0.1.2-py3-none-any.whl -
Subject digest:
fd12064ea75b463b6e482da737f44262508298e72553b8798a76e33962b3838f - Sigstore transparency entry: 1721554796
- Sigstore integration time:
-
Permalink:
gnuhhung317/marcus-py@668b7d8cdeeb9f2ee370cdb21de9a32a5e5c354e -
Branch / Tag:
refs/tags/v0.1.2 - Owner: https://github.com/gnuhhung317
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish-pypi.yml@668b7d8cdeeb9f2ee370cdb21de9a32a5e5c354e -
Trigger Event:
release
-
Statement type: