Connect your agents to Trovis — two lines of code for full observability
Project description
trovis-agents
Connect your AI agents to Trovis in two lines of code. Supports three agent platforms today — the OpenAI Agents SDK, Anthropic Claude Agents, and Hermes. Extras pick which dependencies install.
Install
# OpenAI Agents SDK
pip install trovis-agents[openai]
# Anthropic Claude Managed Agents (client.beta.agents API)
pip install trovis-agents[anthropic]
# Claude Agent SDK (query() + ClaudeSDKClient)
pip install trovis-agents[claude-agent-sdk]
# Hermes Agent (no extra deps — Hermes provides the runtime)
pip install trovis-agents[hermes]
# All Python-SDK platforms
pip install trovis-agents[all]
Two different Claude products.
[anthropic]instruments the Managed Agents API (client.beta.agents.create()/sessions.stream()).[claude-agent-sdk]instruments the Claude Agent SDK (query()+ClaudeSDKClient, the Claude Code engine). They share a name but are wholly different entry points — pick the one your code actually calls.
OpenAI Agents SDK
from agents import Agent, Runner
from trovis import init
init(api_key="ov_sk_your_key", agent_name="my-agent")
# Your existing code — no changes needed
agent = Agent(name="Support", instructions="You handle customer tickets...")
result = await Runner.run(agent, "Help me with my order")
# Agent appears in your Trovis dashboard automatically
Claude Managed Agents
import anthropic
from trovis import init
init(api_key="ov_sk_your_key", platform="anthropic")
# Your existing code — no changes needed
client = anthropic.Anthropic()
agent = client.beta.agents.create(
name="Coding Assistant",
model={"id": "claude-opus-4-7"},
system="You are a helpful coding assistant.",
tools=[{"type": "agent_toolset_20260401"}],
)
session = client.beta.sessions.create(agent=agent.id, environment_id=env_id)
# Send a message and stream events — both flow into Trovis automatically.
client.beta.sessions.events.create(session.id, events=[{
"type": "user.message",
"content": [{"type": "text", "text": "Hello"}],
}])
for event in client.beta.sessions.stream(session.id):
...
platform="auto" (the default) detects which SDK(s) are installed and
hooks into both when present — useful if your codebase mixes platforms.
Advanced: per-client instrumentation
When monkey-patching at module load is undesirable (multi-tenant
hosts, different telemetry per client), use monitor() to wrap one
client at a time:
from trovis import init, monitor
init(api_key="ov_sk_...", platform="anthropic")
client = monitor(anthropic.Anthropic())
# Only this client emits Trovis spans.
Or use track_session() as a context manager to scope the
agent-name mapping to a block:
from trovis import track_session
with track_session(session_id=session.id, agent_name="coding-assistant"):
for event in client.beta.sessions.stream(session.id):
...
Claude Agent SDK
For the claude-agent-sdk package (query() + the Claude Code
engine) — distinct from the Managed Agents API above.
from claude_agent_sdk import query, ClaudeAgentOptions
from trovis import init
# Call init() BEFORE importing/using query so the patch is in place.
init(api_key="ov_sk_your_key", agent_name="my-agent", platform="claude-agent-sdk")
async for message in query(
prompt="Refactor the auth module",
options=ClaudeAgentOptions(system_prompt="You are a senior engineer."),
):
... # your existing handling — spans flow into Trovis automatically
Each run becomes a set of Trovis spans: an agent_registration
(from options.system_prompt), message_received / llm_output /
tool_call per message, and an agent_run_complete carrying the
run's token usage + cost (from the SDK's ResultMessage).
ClaudeSDKClient's streaming (receive_response) is instrumented the
same way.
Hermes Agent
Hermes discovers plugins via Python entry points, so installing this package is enough — no separate plugin scaffold to copy.
pip install trovis-agents[hermes]
hermes plugins enable trovis
If you'd rather drop the plugin in by hand:
cp -r $(python -c "import trovis.hermes_plugin, os; \
print(os.path.dirname(trovis.hermes_plugin.__file__))") \
~/.hermes/plugins/trovis
Configure via environment variables (Hermes will prompt for these
on plugins enable thanks to plugin.yaml's requires_env):
export TROVIS_API_KEY="ov_sk_your_key"
export TROVIS_ENDPOINT="https://your-trovis/v1/traces" # optional
Or from chat after the first start:
/trovis connect https://your-trovis/v1/traces
/trovis apikey ov_sk_your_key
/trovis capture on
/trovis status
What gets captured on Hermes
- Agent identity —
~/.hermes/SOUL.md, plusmemory.mdwhencapture_outputsis on. Sent once on gateway start. - Every
post_tool_callhook — tool name, parameter keys (not values, unless capture is on), and the tool's result (capture-only). /trovis statusin chat to verify telemetry is flowing.
Connecting agents across processes
When one agent calls another that runs in a separate process or service, carry the trace context across the call so Trovis can draw the agent-to-agent connection on your dashboard. (Agents that hand off within one process already share a trace automatically.)
Both processes must have called init(). On the calling side, attach the
context to your outbound request; on the receiving side, continue it:
import httpx, trovis
# --- Agent A (caller), inside a tool call / run ---
resp = httpx.post(url, headers=trovis.inject(), json=payload)
# --- Agent B (receiver) ---
with trovis.continue_trace(request.headers):
result = await Runner.run(agent_b, payload)
inject() writes a W3C traceparent header; continue_trace() re-attaches
it so Agent B's spans share Agent A's trace and link back to the calling
span. Trovis then surfaces "Agent A → Agent B" automatically. There's also
trovis.extract(headers) if you need the raw OpenTelemetry context.
What gets captured
- Agent identity (name, instructions/system prompt) — sent once when each unique agent is first constructed.
- Every LLM call (model, duration, token usage).
- Every tool call (name, duration, success/failure).
- Agent handoffs.
- Guardrail checks.
- Run completion.
By default, message content is NOT captured — only metadata. Enable with init(capture_outputs=True) for full visibility.
Environment variables
| Variable | Purpose |
|---|---|
TROVIS_API_KEY |
Your Trovis API key. Sent as the X-Trovis-Api-Key header. |
TROVIS_ENDPOINT |
Custom OTLP/HTTP endpoint. Defaults to the Trovis cloud. |
TROVIS_AGENT_NAME |
Default service.name for spans. Defaults to openai-agent. |
TROVIS_CAPTURE_OUTPUTS |
Set to true (case-insensitive) to enable content capture. |
Explicit arguments to init() always win over environment variables.
How it works
init() does three things:
- OpenTelemetry pipeline — creates a
TracerProviderwith an OTLP/HTTP exporter pointed at the Trovis endpoint, authenticated via theX-Trovis-Api-Keyheader. - OpenAI Agents SDK bridge — registers the
openai-agents-opentelemetryprocessor so all agent runs (LLM calls, tools, handoffs, guardrails) flow into the OTEL pipeline. - Identity capture — monkey-patches
Agent.__init__so each unique(name, instructions)pair emits oneagent_registrationspan. This is what makes Trovis's Claude-generated descriptions accurate from day one.
If the OpenAI Agents SDK or its OTEL adapter isn't installed, init() logs a warning and degrades to OTEL-only mode (manual spans still ship).
Privacy
The default configuration sends only metadata to Trovis — agent name, system prompt (as part of registration), LLM model name, tool names, span durations. No user messages, no model responses, no tool inputs/outputs.
Setting capture_outputs=True enables the CaptureProcessor, which adds:
trovis.message.contenton user-prompt spans.trovis.response.contenton model-response spans.trovis.tool.resulton tool-call spans.
Each is truncated to 10 000 characters. Same attribute names and truncation budget as the Trovis OpenClaw plugin.
License
MIT
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 trovis_agents-0.4.3.tar.gz.
File metadata
- Download URL: trovis_agents-0.4.3.tar.gz
- Upload date:
- Size: 36.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
95f71d6a4e3df0b9e8f09cb25435bc7ce486ca26295d6390a937689461efe9cd
|
|
| MD5 |
cf206c4611b6cda1b2a546649e8926a3
|
|
| BLAKE2b-256 |
5c4e9d11a9919fb9ed9c433e491276097f012691f3d5a6ca3ad4262694f2ab7d
|
File details
Details for the file trovis_agents-0.4.3-py3-none-any.whl.
File metadata
- Download URL: trovis_agents-0.4.3-py3-none-any.whl
- Upload date:
- Size: 38.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
e8aa68d72d17a39618dba89e3266300af1cb1a63181ed78e3957cb8e54f70ac0
|
|
| MD5 |
88268be5015d0468b280125038be170b
|
|
| BLAKE2b-256 |
5a286edfd7accfbca7cd77ec5ced3f7a24328f2be0867e47fd28a4a4e864ddca
|