DebugBundle SDK for Python
Project description
debugbundle-python
DebugBundle SDK for Python.
Installation
pip install debugbundle-python
Quick Start
import debugbundle
debugbundle.init(project_token="dbundle_proj_test", service="checkout-api")
debugbundle.capture_exception(RuntimeError("boom"))
debugbundle.flush()
Status
This repository currently contains the full Phase 18 Python SDK scope in eleven implementation slices: core SDK surface, buffering, redaction, duplicate suppression, probe buffering, vanilla runtime hooks, framework integrations for Django, Flask, and FastAPI, remote config polling and capture-policy enforcement, optional structlog and loguru auto-detection when capture_logging() is enabled, contract-aligned EventEnvelope emission for log, request, exception, suppression, and probe payloads, explicit public wrapper signatures and a validated buildable typed package artifact, real HTTP integration coverage against a lightweight mock ingestion server, vendored machine-readable schema validation for all event types the Python SDK currently emits, a standalone CI workflow that validates Ruff, mypy, pytest, and package builds for the Python 3.10+ support floor actually used by the package, an enforced per-file coverage gate that keeps every shipped Python SDK module at or above the required 80% minimum, request-local framework correlation binding so X-DebugBundle-Trace-Id flows through Django, Flask, and FastAPI into the emitted event correlation metadata for cross-context linking, full browser relay handler parity with Django/Flask/FastAPI helpers plus local-only and connected delivery modes, and safe backend runtime process facts on exception payloads without reading environment variables.
Runtime Context
Backend exception events now include safe runtime process facts when the host exposes them, including:
- Python version
- platform
- architecture
- pid
- cwd
- uptime
- hostname
- thread id
- best-effort memory metadata
The SDK does not read or emit environment variables in this runtime block.
Browser Relay
The Python SDK includes a framework-agnostic BrowserRelayHandler plus framework helpers for the contract-required POST /debugbundle/browser endpoint in Python servers that also load @debugbundle/sdk-browser.
create_django_relay_view()returns a Django view for the relay route.create_flask_relay_handler()registers the relay route on a Flask app.create_fastapi_relay_handler()registers the relay route on a FastAPI app.
The relay handler enforces same-origin or configured allowed origins, requires Content-Type: application/json, accepts the canonical batch body shape only, rejects bodies larger than 256 KB, applies per-IP rate limiting, accepts only supported browser event types, strips trust-sensitive headers and fields, forces sdk_name to @debugbundle/sdk-browser, and preserves browser correlation fields (request_id, trace_id, session_id, and user_id_hash) when they are strings or null.
Delivery behavior matches the shared relay contract across the shipped server SDKs:
project_mode="local-only"writes accepted browser events to local event files for CLI processing.project_mode="connected"with the defaultdurable_write=Truewrites a durable relay spool record and then forwards to the ingestion API with the server-side project token.project_mode="connected"withdurable_write=Falseuses the lower-latency forward-only path.
Docs
https://debugbundle.com/docs/sdks/python
License
AGPL-3.0-only
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 debugbundle_python-0.1.6.tar.gz.
File metadata
- Download URL: debugbundle_python-0.1.6.tar.gz
- Upload date:
- Size: 42.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
19c1d48a4ee77c070907047e976b56d4146adbb5249bf8f0e47e7700793e2c63
|
|
| MD5 |
2785c3e6494dda59a40f526ef2c7cb7c
|
|
| BLAKE2b-256 |
aeb464d52235ee7a0e9de86ea91b9ca890fab90130d24db163bb0919ecba9330
|
File details
Details for the file debugbundle_python-0.1.6-py3-none-any.whl.
File metadata
- Download URL: debugbundle_python-0.1.6-py3-none-any.whl
- Upload date:
- Size: 32.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.13
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b6ba052d09402e473dc4dacc5938cc3103f54ffcbdf71b5b10945a0a416a3ede
|
|
| MD5 |
1a8c8c89d1a116da068a4975e8496806
|
|
| BLAKE2b-256 |
acff8c54e9320af44e1a29ee9da258ca4734f56ea9e5d62a3ea93284dcc97d97
|