LangChain Reference home pageLangChain ReferenceLangChain Reference
  • GitHub
  • Main Docs
Deep Agents
LangChain
LangGraph
Integrations
LangSmith
LangGraph
  • Web
  • Channels
  • Pregel
  • Prebuilt
  • Remote
LangGraph SDK
  • Ui
  • Client
  • Auth
  • React
  • Logging
  • React Ui
  • Utils
  • Server
LangGraph Checkpoint
LangGraph Checkpoint MongoDB
LangGraph Checkpoint Postgres
  • Store
LangGraph Checkpoint Redis
  • Shallow
  • Store
LangGraph Checkpoint SQLite
LangGraph Checkpoint Validation
  • Cli
LangGraph API
LangGraph CLI
LangGraph CUA
  • Utils
LangGraph Supervisor
LangGraph Swarm
⌘I

LangChain Assistant

Ask a question to get started

Enter to send•Shift+Enter new line

Menu

LangGraph
WebChannelsPregelPrebuiltRemote
LangGraph SDK
UiClientAuthReactLoggingReact UiUtilsServer
LangGraph Checkpoint
LangGraph Checkpoint MongoDB
LangGraph Checkpoint Postgres
Store
LangGraph Checkpoint Redis
ShallowStore
LangGraph Checkpoint SQLite
LangGraph Checkpoint Validation
Cli
LangGraph API
LangGraph CLI
LangGraph CUA
Utils
LangGraph Supervisor
LangGraph Swarm
Language
Theme
JavaScript@langchain/langgraph-sdkuiSubagentStreamInterface
Interface●Since v1.7

SubagentStreamInterface

Copy
interface SubagentStreamInterface

Bases

StreamBase<StateType, ToolCall>

Properties

Inherited fromStreamBase

Properties

PactiveSubagents: SubagentStreamInterface<SubagentStates[keyof SubagentStates], ToolCall, keyof SubagentStates & string>[]
—

Currently active subagents (where status === "running").

Perror: unknown
—

Last seen error from the stream, if any.

PgetSubagent: (toolCallId: string)
—

Get subagent stream by tool call ID.

View source on GitHub
P
getSubagentsByMessage
: (messageId: string)
—

Get all subagents triggered by a specific AI message.

PgetSubagentsByType: (type: TName)
—

Get all subagents of a specific type.

PgetToolCalls: (message: AIMessage<ToolCall>)
—

Get tool calls for a specific AI message.

Pinterrupt: Interrupt<GetInterruptType<Bag>> | undefined
—

Current interrupt, if the stream is interrupted.

Pinterrupts: Interrupt<GetInterruptType<Bag>>[]
—

All current interrupts from the stream.

PisLoading: boolean
—

Whether the stream is currently running.

Pmessages: Message<ToolCall>[]
—

Messages accumulated during the stream.

Psubagents: Map<string, SubagentStreamInterface<SubagentStates[keyof SubagentStates], ToolCall, keyof SubagentStates & string>>
—

All currently active and completed subagent streams.

PswitchThread: (newThreadId: string | null)
—

Switch to a different thread, clearing the current stream state.

PtoolCalls: ToolCallWithResult<ToolCall>[]
—

Tool calls paired with their results.

Pvalues: StateType
—

The current state values of the stream.

property
activeSubagents: SubagentStreamInterface<Record<string, unknown>, ToolCall, string>[]
property
completedAt: Date | null
property
depth: number
property
error: unknown
property
getSubagent: (toolCallId: string) => SubagentStreamInterface<Record<string, unknown>, ToolCall, string> | undefined
property
getSubagentsByMessage: (messageId: string) => SubagentStreamInterface<Record<string, unknown>, ToolCall, string>[]
property
getSubagentsByType: (type: TName) => SubagentStreamInterface<Record<string, unknown>, ToolCall, TName>[]
property
getToolCalls: (message: AIMessage<ToolCall>) => ToolCallWithResult<ToolCall>[]
property
id: string
property
interrupt: Interrupt<unknown> | undefined
property
interrupts: Interrupt<unknown>[]
property
isLoading: boolean
property
messages: Message<ToolCall>[]
property
namespace: string[]
property
parentId: string | null
property
result: string | null
property
startedAt: Date | null
property
status: SubagentStatus
property
subagents: Map<string, SubagentStreamInterface<Record<string, unknown>, ToolCall, string>>
property
switchThread: (newThreadId: string | null) => void
property
toolCall: SubagentToolCall<SubagentName>
property
toolCalls: ToolCallWithResult<ToolCall>[]
property
values: StateType

Base interface for a single subagent stream. Tracks the lifecycle of a subagent from invocation to completion.

Extends StreamBase to share common properties with UseStream, allowing subagents to be treated similarly to the main stream.

Prefer using SubagentStream which supports passing an agent type directly for automatic type inference.

Currently active subagents (where status === "running").

Use this to track and display subagents that are actively executing. Completed or errored subagents are not included.

When the subagent completed

Nesting depth (0 = called by main agent, 1 = called by subagent, etc.)

Last seen error from the stream, if any. Reset to undefined when a new stream starts.

Get subagent stream by tool call ID.

Use this when you have a specific tool call ID and need to access its corresponding subagent stream.

Get all subagents triggered by a specific AI message.

Useful for rendering subagent activities grouped by conversation turn. Each AI message that contains subagent tool calls will have its triggered subagents returned by this method.

Get all subagents of a specific type.

Returns streams with properly inferred state types based on subagent name. When called with a literal string that matches a subagent name, TypeScript will infer the correct state type for that subagent.

Get tool calls for a specific AI message.

Use this to find which tool calls were initiated by a particular assistant message, useful for rendering tool calls inline with messages.

The ID of the interrupt.

Current interrupt, if the stream is interrupted. Convenience alias for interrupts[0]. For workflows with multiple concurrent interrupts, use interrupts instead.

All current interrupts from the stream. When using Send() fan-out with per-task interrupt() calls, multiple interrupts may be pending simultaneously.

Whether the stream is currently running. true while streaming, false when idle or completed.

Messages accumulated during the stream. Includes both human and AI messages. AI messages include typed tool calls based on the agent's tools.

Tool call ID of parent subagent (for nested subagents)

When the subagent started

All currently active and completed subagent streams.

Keyed by tool call ID for easy lookup. Includes subagents in all states: pending, running, complete, and error.

Switch to a different thread, clearing the current stream state. Pass null to reset to no thread (a new thread will be created on next submit).

The tool call that invoked this subagent

Tool calls paired with their results.

Each entry contains the tool call request and its corresponding result. Useful for rendering tool invocations and their outputs together.

The current state values of the stream. Updated as streaming events are received.

Copy
// Show loading indicators for active subagents
stream.activeSubagents.map(subagent => (
  <SubagentCard
    key={subagent.id}
    type={subagent.toolCall.args.subagent_type}
    isLoading={true}
  />
));
Copy
// In a tool call component
const subagent = stream.getSubagent(toolCall.id);
if (subagent) {
  return <SubagentProgress subagent={subagent} />;
}
Copy
// Get all researcher subagents with typed state
const researchers = stream.getSubagentsByType("researcher");

researchers.forEach(researcher => {
  // researcher.values is typed based on ResearchMiddleware
  console.log("Research messages:", researcher.values.messages.length);
  console.log("Status:", researcher.status);
});

// Get all writer subagents
const writers = stream.getSubagentsByType("writer");
// writers have different state type based on WriterMiddleware
Copy
messages.map(message => {
  if (message.type === "ai") {
    const calls = stream.getToolCalls(message);
    return (
      <>
        <MessageBubble message={message} />
        {calls.map(tc => <ToolCallCard key={tc.call.id} {...tc} />)}
      </>
    );
  }
  return <MessageBubble message={message} />;
});
Copy
// Iterate over all subagents
stream.subagents.forEach((subagent, toolCallId) => {
  console.log(`Subagent ${toolCallId}: ${subagent.status}`);
});

// Get a specific subagent
const specific = stream.subagents.get("call_abc123");
Copy
stream.toolCalls.map(({ call, result }) => (
  <ToolCallCard
    name={call.name}
    args={call.args}
    result={result}
  />
));
Copy
// Render subagents inline after the AI message that triggered them
{stream.messages.map((msg) => (
  <div key={msg.id}>
    <MessageBubble message={msg} />
    {msg.type === "ai" && "tool_calls" in msg && (
      <SubagentPipeline
        subagents={stream.getSubagentsByMessage(msg.id)}
      />
    )}
  </div>
))}