Skip to main content

No project description provided

Project description

Handit Core (Python)

Lightweight function and HTTP tracing for Python applications with zero configuration. Captures function calls/returns with arguments and return values, and outgoing HTTP requests/responses (including bodies) for requests and httpx. Events are buffered in-memory and written once at process exit to handit_events.jsonl.

Install

Build from source (requires Rust and Python toolchain):

python -m pip install maturin
python -m maturin develop --release -m python/pyproject.toml

Quick start

from handit import session, tracing
import requests

@tracing(agent="demo")
def fetch_user(user_id: int) -> dict:
    resp = requests.get(f"https://httpbin.org/anything/{user_id}")
    return resp.json()

if __name__ == "__main__":
    with session(tag="demo-session"):
        fetch_user(42)
# Events will be written to ./handit_events.jsonl at exit

What is captured

  • Function events: call/return/exception
    • Arguments preview on call
    • Return value preview on return
  • HTTP events (client-side)
    • requests/httpx: method, URL, headers, request body; response status, headers, body, size, duration, error
    • aiohttp: method, URL, headers; response status, headers (bodies are not captured by default)

Behavior

  • Zero-config: HTTP instrumentation is enabled on import; no environment variables are required.
  • Noise reduction: internal library frames and stdlib/site-packages are excluded by default.
  • Output: events are buffered and flushed once at exit to handit_events.jsonl.
    • Override path via env HANDIT_OUTPUT_FILE=./path/file.jsonl.

Advanced

  • Manual flush during runtime:
from handit_core import handit_core_native as native
native.flush_events_to_file("./handit_events.jsonl")
  • Optional envs (all have safe defaults):
    • HANDIT_INCLUDE / HANDIT_EXCLUDE: module/function regex filters
    • HANDIT_MAX_STR (default 256), HANDIT_MAX_LOCALS (default 64)
    • HANDIT_REDACT: regex for keys to redact in previews
    • HANDIT_CAPTURE_ONLY_CWD (default true)

Notes

  • Capturing full HTTP bodies may include sensitive data. Ensure you comply with your data policy.
  • For aiohttp streamed bodies, body capture can be added with explicit buffering middleware if needed.

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

handit_ai-0.0.6.tar.gz (27.7 kB view details)

Uploaded Source

Built Distribution

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

handit_ai-0.0.6-cp310-cp310-macosx_11_0_arm64.whl (2.5 MB view details)

Uploaded CPython 3.10macOS 11.0+ ARM64

File details

Details for the file handit_ai-0.0.6.tar.gz.

File metadata

  • Download URL: handit_ai-0.0.6.tar.gz
  • Upload date:
  • Size: 27.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for handit_ai-0.0.6.tar.gz
Algorithm Hash digest
SHA256 2cf09af7afbe49a33a3a23240728115b64f3f84a23d7de0d7682f978836bc164
MD5 b85a52932aa08ff0e85cdf66f248f6a2
BLAKE2b-256 4ec69b34b0fbe4e01af5a346eba6cd16f9a24c5b854e09cf7ffc13c153ec2c6f

See more details on using hashes here.

File details

Details for the file handit_ai-0.0.6-cp310-cp310-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for handit_ai-0.0.6-cp310-cp310-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 f84bd95c440a6b366b5eead448cc9b52ea653429c304d56cf4223e81080d0cf7
MD5 5ce4e15d7ad6fd9a68bb3efc4a45afb9
BLAKE2b-256 97f2b0cecc6f71bf3da1da4793ff94a95fa428abcc781c7e776ee39cc21dc71f

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