Skip to main content

Framework-agnostic agent behavior analytics — CIM-based telemetry for AI agents

Project description

observra

Framework-agnostic agent behavior analytics — capture every meaningful agent action (token usage, tool calls, cost, errors) with structured context based on the Common Information Model (CIM).

Zero custom instrumentation per-agent. Answer "what happened, how much did it cost, and was it normal?" for any agent on any framework.

Install

pip install observra

With framework extras:

pip install observra[adk]           # Google ADK
pip install observra[claude]        # Claude Agent SDK
pip install observra[openai-agents] # OpenAI Agents SDK
pip install observra[langchain]     # LangChain / LangGraph
pip install observra[pydantic-ai]   # Pydantic AI

With backend extras:

pip install observra[otel]          # OTel span + log export

Install everything:

pip install observra[all]

Quick Start

import observra
from observra import log

observra.initialize(backend="jsonl", path="telemetry.jsonl")
log.session_start(agent_name="my-agent")
log.model_response("gpt-4o", input_tokens=500, output_tokens=200)
log.session_end(agent_name="my-agent")

Sample output (one line per event in telemetry.jsonl):

{"ts": "2025-01-15T10:23:45Z", "event_type": "model_response", "framework": "generic", "data": {"model": "gpt-4o", "in": 500, "out": 200, "cost_usd": 0.0035}}

Supported Frameworks

Framework Install Status Captured Events
Google ADK [adk] Stable LLM calls, tool calls, delegation depth, cost
Claude SDK [claude] Stable Tool calls, model responses, session cost
OpenAI Agents SDK [openai-agents] Stable Spans, tool calls, agent handoffs, cost
LangChain / LangGraph [langchain] Stable Chain runs, tool calls, LLM calls, cost
Pydantic AI [pydantic-ai] Stable Agent runs, tool calls, model calls

Backends

Backend Install Description
JSONL (included) Local JSON Lines file (default)
Webhook (included) Generic HTTP webhook POST delivery
Multi (included) Fan-out to multiple backends simultaneously
OTel Spans [otel] Export events as OTel spans via OTLP HTTP
OTel Logs [otel] Export events as OTel log records via OTLP HTTP

OTel Export (Dynatrace, Grafana, etc.)

from observra.backends.otel import OTelExportBackend
from observra.backends.otel_log import OTelLogBackend
from observra.backends.multi import MultiBackend

# Spans only
span_backend = OTelExportBackend(
    endpoint="https://your-collector/v1/traces",
    headers={"Authorization": "Api-Token ..."},
    service_name="my-agent-svc",
)

# Logs only
log_backend = OTelLogBackend(
    endpoint="https://your-collector/v1/logs",
    headers={"Authorization": "Api-Token ..."},
    service_name="my-agent-svc",
)

# Both spans and logs
backend = MultiBackend([span_backend, log_backend])

Key Features

  • Cost tracking — per-session cost with model-specific pricing catalog and threshold alerts
  • PII redaction — automatic secret/PII masking with configurable patterns
  • Non-blocking — drop-oldest queue guarantees zero latency impact on the host agent
  • CIM-normalized — structured events compatible with SIEM/analytics pipelines
  • Safe regex — ReDoS-proof pattern matching via RE2 (optional: [safe-regex])
  • Encryption at rest — AES field-level encryption for sensitive telemetry (optional: [encryption])
  • Prompt injection detection — built-in heuristics for injection attempt classification
  • Observabilityget_metrics() / get_stats() for pipeline health introspection
  • Deduplication — automatic event dedup across backends
  • Session context — trace/span/session ID propagation with scoped contexts

All Extras

Extra Dependencies
[adk] google-adk>=1.0.0
[claude] claude-agent-sdk>=0.1.37, tiktoken>=0.7.0
[openai-agents] openai-agents>=0.9.0
[langchain] langchain-core>=1.0.0, langgraph>=0.2.0
[pydantic-ai] pydantic-ai<2.0.0, opentelemetry-sdk>=1.0.0
[otel] opentelemetry-sdk>=1.0.0, opentelemetry-exporter-otlp-proto-http>=1.0.0
[exabeam] requests>=2.32.0
[safe-regex] google-re2>=1.1
[encryption] cryptography>=41.0
[all] All of the above

Documentation

License

Apache 2.0 — see 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

observra-1.0.1.tar.gz (139.4 kB view details)

Uploaded Source

Built Distribution

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

observra-1.0.1-py3-none-any.whl (169.0 kB view details)

Uploaded Python 3

File details

Details for the file observra-1.0.1.tar.gz.

File metadata

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

File hashes

Hashes for observra-1.0.1.tar.gz
Algorithm Hash digest
SHA256 fe272f7ba0f9d674319d1be82d164a0a86a4e9ec6f859a2b7a101c5ee069ce85
MD5 98f65e63dce6d1ab16f0ba203e69591b
BLAKE2b-256 62ce34d52ed3f04d081c0446d8469924b64c7a768d88e1a952bc903a617dd6e0

See more details on using hashes here.

Provenance

The following attestation bundles were made for observra-1.0.1.tar.gz:

Publisher: publish.yaml on open-agent-ai-security/observra

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

File details

Details for the file observra-1.0.1-py3-none-any.whl.

File metadata

  • Download URL: observra-1.0.1-py3-none-any.whl
  • Upload date:
  • Size: 169.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for observra-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 0c239fce48b122e053450feba06a3a093855762f96513958071e8e1777db6e49
MD5 12962e7ed2da9308467758f5550ef948
BLAKE2b-256 1de12949c06aec374d074723920832a695b7a3acc58f16d97be500f9d073d0e1

See more details on using hashes here.

Provenance

The following attestation bundles were made for observra-1.0.1-py3-none-any.whl:

Publisher: publish.yaml on open-agent-ai-security/observra

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