Skip to main content

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

Project description

observra — framework-agnostic agent behavior analytics

observra

Framework-agnostic agent behavior analytics.

License: Apache-2.0 Python 3.10+

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

Project sponsor

observra is sponsored by Exabeam. Exabeam contributed the initial code and continues to provide ongoing support and contributions to the project as part of its commitment to security in an increasingly agentic world.

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.2.tar.gz (140.2 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.2-py3-none-any.whl (174.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: observra-1.0.2.tar.gz
  • Upload date:
  • Size: 140.2 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.2.tar.gz
Algorithm Hash digest
SHA256 23eefaa43e167cf603060d4cbb22e7b99f184f62fd99c48ec843ebc129f083e7
MD5 5a2d75af686945cf2cd63f207645789c
BLAKE2b-256 e60329e595d0c8700382acd59e9c6114ae43a1082d619d3fc0a64a6f1e2c1fb2

See more details on using hashes here.

Provenance

The following attestation bundles were made for observra-1.0.2.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.2-py3-none-any.whl.

File metadata

  • Download URL: observra-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 174.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.2-py3-none-any.whl
Algorithm Hash digest
SHA256 52fefd111c098062489bbdc5bb06370183776faab22c4d65fa45c0d00e0dd6d0
MD5 bd566417352afd223750bf324f20571b
BLAKE2b-256 76c80ccad6384283d3b89e0ac7ca093a5fd3f63a274d822c9855abbb508012f8

See more details on using hashes here.

Provenance

The following attestation bundles were made for observra-1.0.2-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