AgentSpec

Open Agent Specification (Agent Spec) (pyagentspec) is Oracle’s open specification and Python SDK for defining and running agentic systems. It provides a portable way to describe agents, models, and workflows across runtimes. Respan gives you full observability over every spec execution, model call, and tool invocation — and gateway routing through the OpenAI-compatible Respan endpoint.

Create an account at platform.respan.ai and grab an API key. For gateway, also add credits or a provider key.

Run npx @respan/cli setup to set up with your coding agent.

Setup

1

Install packages

$pip install respan-ai openinference-instrumentation-agentspec "pyagentspec[langgraph]"
2

Set environment variables

$export OPENAI_API_KEY="YOUR_OPENAI_API_KEY"
$export RESPAN_API_KEY="YOUR_RESPAN_API_KEY"

OPENAI_API_KEY is used for LLM requests. RESPAN_API_KEY is used to export traces to Respan.

3

Initialize and run

1from openinference.instrumentation.agentspec import AgentSpecInstrumentor
2from pyagentspec.adapters.langgraph import AgentSpecLoader
3from pyagentspec.agent import Agent
4from pyagentspec.llms import OpenAiConfig
5from respan import Respan
6
7respan = Respan(instrumentations=[AgentSpecInstrumentor()])
8
9agent = Agent(
10 name="haiku_assistant",
11 description="A helpful assistant that writes haikus.",
12 llm_config=OpenAiConfig(name="openai", model_id="gpt-4.1-nano"),
13 system_prompt="You are a helpful assistant. Respond only with a haiku.",
14)
15
16langgraph_agent = AgentSpecLoader().load_component(agent)
17
18result = langgraph_agent.invoke(
19 input={"messages": [{"role": "user", "content": "Write a haiku about recursion."}]}
20)
21print(result["messages"][-1].content)
22respan.flush()
4

View your trace

Open the Traces page to see your AgentSpec workflow with specification execution, tool calls, and LLM generations.

Configuration

ParameterTypeDefaultDescription
api_keystr | NoneNoneFalls back to RESPAN_API_KEY env var.
base_urlstr | NoneNoneFalls back to RESPAN_BASE_URL env var.
instrumentationslist[]Plugin instrumentations to activate (e.g. AgentSpecInstrumentor()).
customer_identifierstr | NoneNoneDefault customer identifier for all spans.
metadatadict | NoneNoneDefault metadata attached to all spans.
environmentstr | NoneNoneEnvironment tag (e.g. "production").

Attributes

In Respan()

Set defaults at initialization — these apply to all spans.

1from respan import Respan
2from openinference.instrumentation.agentspec import AgentSpecInstrumentor
3
4respan = Respan(
5 instrumentations=[AgentSpecInstrumentor()],
6 customer_identifier="user_123",
7 metadata={"service": "agentspec-api", "version": "1.0.0"},
8)

With propagate_attributes

Override per-request using a context scope.

1from respan import Respan, propagate_attributes
2from openinference.instrumentation.agentspec import AgentSpecInstrumentor
3
4respan = Respan(instrumentations=[AgentSpecInstrumentor()])
5
6def handle_request(user_id: str, message: str):
7 with propagate_attributes(
8 customer_identifier=user_id,
9 thread_identifier="conv_abc_123",
10 metadata={"plan": "pro"},
11 ):
12 result = langgraph_agent.invoke(
13 input={"messages": [{"role": "user", "content": message}]}
14 )
15 print(result["messages"][-1].content)
AttributeTypeDescription
customer_identifierstrIdentifies the end user in Respan analytics.
thread_identifierstrGroups related messages into a conversation.
metadatadictCustom key-value pairs. Merged with default metadata.