Zero-config observability for Python web frameworks
Project description
Brakit Python SDK
AI writes your code. Brakit watches what it does.
Every request, query, and API call mapped to the action that triggered it. See your entire backend at a glance.
Open source · Local first · Zero config · AI-native via MCP
GitHub • Website • Contributing
Every endpoint grouped by the action that triggered it — see "Sign Up" and "Load Dashboard", not 47 raw requests
Brakit catches N+1 queries, PII leaks, and slow endpoints as you develop
Claude reads issues via MCP and fixes your code
Quick Start
The Python SDK captures queries, fetches, and requests from your FastAPI or Flask backend and forwards them to the Brakit dashboard running in your Node.js frontend.
1. Install the Node.js core (runs the dashboard)
npx brakit install
2. Install the Python SDK
pip install brakit
3. Add one import to your app
FastAPI:
import brakit # must be before FastAPI import
from fastapi import FastAPI
app = FastAPI()
Flask:
import brakit # must be before Flask import
from flask import Flask
app = Flask(__name__)
That's it. Start both apps normally. The Python SDK auto-detects your framework, instruments queries and fetches, and forwards everything to the Brakit dashboard at http://localhost:<port>/__brakit.
Full setup guide: brakit.ai/docs/introduction
What You Get
- Cross-service tracing — FETCH from Next.js to FastAPI? The DB query inside FastAPI nests under the fetch automatically
- Full server tracing — DB queries, outgoing HTTP calls, errors — zero code changes
- Live dashboard at
/__brakit— performance overview, request timeline, scatter charts - 8 security rules scanned against live traffic — leaked secrets, PII in responses, missing auth flags
- N+1 query detection — same query pattern repeated 5+ times in a single request
- AI-native via MCP — Claude Code and Cursor can query issues and verify fixes directly
Supported Frameworks
| Framework | Status |
|---|---|
| FastAPI | Supported |
| Flask | Supported |
| Django | Planned |
Supported Databases
| Driver | Status |
|---|---|
| SQLAlchemy | Supported |
| asyncpg | Supported |
| psycopg | Planned |
Supported HTTP Clients
| Library | Status |
|---|---|
| urllib3 | Supported |
| httpx | Supported |
| aiohttp | Supported |
| requests | Supported (via urllib3) |
How It Works
import brakit → auto-detect framework → instrument everything
|
+-- DB queries (SQLAlchemy, asyncpg)
+-- HTTP fetches (httpx, aiohttp, urllib3)
+-- Errors (global exception hooks)
+-- Logs (logging module)
|
+-- Forward to Node.js dashboard via localhost
import brakit patches your framework's middleware to capture request/response pairs, hooks into database drivers and HTTP clients, and forwards telemetry to the Brakit dashboard running in your Node.js process. No proxy, no extra ports.
Production Safety
Brakit never runs in production. Multiple layers ensure it:
| Layer | How it blocks |
|---|---|
should_activate() |
Checks NODE_ENV + 15 cloud/CI env vars |
| devDependency | Not installed in production |
safe_wrap + circuit breaker |
Errors in brakit code fall back silently |
BRAKIT_DISABLE=true |
Manual kill switch |
Optional Dependencies
# FastAPI support
pip install brakit[fastapi]
# Flask support
pip install brakit[flask]
# Development (tests, linting)
pip install brakit[dev]
Development
git clone https://github.com/brakit-ai/brakit.git
cd brakit/sdks/python
pip install -e ".[dev]"
pytest tests/ -v
Contributing
Brakit is early and moving fast. Areas where help would be great:
- Database adapters — psycopg, Tortoise ORM, Django ORM
- Framework adapters — Django, Starlette
- HTTP client hooks — more client libraries
- Security rules — new patterns, configurable severity
Please open an issue first for larger changes so we can discuss the approach.
License
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 brakit-0.1.7.tar.gz.
File metadata
- Download URL: brakit-0.1.7.tar.gz
- Upload date:
- Size: 31.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
b52da68bc77cbd3155f399c0ca5dba3be25fcf68e39937d09b86b2ef386a6bbb
|
|
| MD5 |
e4671ee1d4dd1ae29a5482858828c0c9
|
|
| BLAKE2b-256 |
de5bd9c06f9aa6c1df1300fa37b9ef9940c7139c710f98295f27c0e4c908224c
|
File details
Details for the file brakit-0.1.7-py3-none-any.whl.
File metadata
- Download URL: brakit-0.1.7-py3-none-any.whl
- Upload date:
- Size: 47.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.9.6
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a8cc10ddba39ce2bf049b0396cd0f69dfc9848f4477f818232d37923991e32e2
|
|
| MD5 |
f97c521c663cf792c41e1123a5e836a3
|
|
| BLAKE2b-256 |
1d4afb791d18decb39f8fbb11ba652996fcd0801bc605ba228dd0c0ad3895712
|