streamText()
Streams text generations from a language model.
You can use the streamText function for interactive use cases such as chat bots and other real-time applications. You can also generate UI components with tools.
import { streamText } from 'ai';
const { textStream } = streamText({ model: "anthropic/claude-sonnet-4.5", prompt: 'Invent a new holiday and describe its traditions.',});
for await (const textPart of textStream) { process.stdout.write(textPart);}To see streamText in action, check out these examples.
Import
import { streamText } from "ai"API Signature
Parameters
model:
LanguageModel
system:
string
prompt:
string | Array<SystemModelMessage | UserModelMessage | AssistantModelMessage | ToolModelMessage>
messages:
Array<SystemModelMessage | UserModelMessage | AssistantModelMessage | ToolModelMessage>
SystemModelMessage
role:
'system'
content:
string
UserModelMessage
role:
'user'
content:
string | Array<TextPart | ImagePart | FilePart>
TextPart
type:
'text'
text:
string
ImagePart
type:
'image'
image:
string | Uint8Array | Buffer | ArrayBuffer | URL
mediaType?:
string
FilePart
type:
'file'
data:
string | Uint8Array | Buffer | ArrayBuffer | URL
mediaType:
string
AssistantModelMessage
role:
'assistant'
content:
string | Array<TextPart | FilePart | ReasoningPart | ToolCallPart>
TextPart
type:
'text'
text:
string
ReasoningPart
type:
'reasoning'
text:
string
FilePart
type:
'file'
data:
string | Uint8Array | Buffer | ArrayBuffer | URL
mediaType:
string
filename?:
string
ToolCallPart
type:
'tool-call'
toolCallId:
string
toolName:
string
input:
object based on zod schema
ToolModelMessage
role:
'tool'
content:
Array<ToolResultPart>
ToolResultPart
type:
'tool-result'
toolCallId:
string
toolName:
string
result:
unknown
isError?:
boolean
allowSystemInMessages?:
boolean
tools:
ToolSet
Tool
description?:
string
inputSchema:
Zod Schema | JSON Schema
execute?:
async (parameters: T, options: ToolExecutionOptions) => RESULT
ToolExecutionOptions
toolCallId:
string
messages:
ModelMessage[]
abortSignal:
AbortSignal
toolChoice?:
"auto" | "none" | "required" | { "type": "tool", "toolName": string }
maxOutputTokens?:
number
temperature?:
number
topP?:
number
topK?:
number
presencePenalty?:
number
frequencyPenalty?:
number
stopSequences?:
string[]
seed?:
number
maxRetries?:
number
abortSignal?:
AbortSignal
headers?:
Record<string, string>
experimental_generateMessageId?:
() => string
experimental_telemetry?:
TelemetrySettings
TelemetrySettings
isEnabled?:
boolean
recordInputs?:
boolean
recordOutputs?:
boolean
functionId?:
string
metadata?:
Record<string, string | number | boolean | Array<null | undefined | string> | Array<null | undefined | number> | Array<null | undefined | boolean>>
experimental_transform?:
StreamTextTransform | Array<StreamTextTransform>
StreamTextTransform
transform:
(options: TransformOptions) => TransformStream<TextStreamPart<TOOLS>, TextStreamPart<TOOLS>>
TransformOptions
stopStream:
() => void
tools:
TOOLS
includeRawChunks?:
boolean
providerOptions?:
Record<string,Record<string,JSONValue>> | undefined
activeTools?:
Array<TOOLNAME> | undefined
stopWhen?:
StopCondition<TOOLS> | Array<StopCondition<TOOLS>>
prepareStep?:
(options: PrepareStepOptions) => PrepareStepResult<TOOLS> | Promise<PrepareStepResult<TOOLS>>
PrepareStepFunction<TOOLS>
options:
object
PrepareStepOptions
steps:
Array<StepResult<TOOLS>>
stepNumber:
number
model:
LanguageModel
messages:
Array<ModelMessage>
PrepareStepResult<TOOLS>
model?:
LanguageModel
toolChoice?:
ToolChoice<TOOLS>
activeTools?:
Array<keyof TOOLS>
system?:
string
messages?:
Array<ModelMessage>
experimental_context?:
unknown
experimental_download?:
(requestedDownloads: Array<{ url: URL; isUrlSupportedByModel: boolean }>) => Promise<Array<null | { data: Uint8Array; mediaType?: string }>>
experimental_repairToolCall?:
(options: ToolCallRepairOptions) => Promise<LanguageModelV2ToolCall | null>
ToolCallRepairOptions
system:
string | undefined
messages:
ModelMessage[]
toolCall:
LanguageModelV2ToolCall
tools:
TOOLS
parameterSchema:
(options: { toolName: string }) => JSONSchema7
error:
NoSuchToolError | InvalidToolInputError
onChunk?:
(event: OnChunkResult) => Promise<void> |void
OnChunkResult
chunk:
TextStreamPart
TextStreamPart
type:
'text'
text:
string
TextStreamPart
type:
'reasoning'
text:
string
TextStreamPart
type:
'source'
source:
Source
TextStreamPart
type:
'tool-call'
toolCallId:
string
toolName:
string
input:
object based on zod schema
TextStreamPart
type:
'tool-call-streaming-start'
toolCallId:
string
toolName:
string
TextStreamPart
type:
'tool-call-delta'
toolCallId:
string
toolName:
string
argsTextDelta:
string
TextStreamPart
type:
'tool-result'
toolCallId:
string
toolName:
string
input:
object based on zod schema
output:
any
onError?:
(event: OnErrorResult) => Promise<void> |void
OnErrorResult
error:
unknown
experimental_output?:
Output
Output
Output.text():
Output
Output.object():
Output
Options
schema:
Schema<OBJECT>
onStepFinish?:
(result: onStepFinishResult) => Promise<void> | void
onStepFinishResult
stepType:
"initial" | "continue" | "tool-result"
finishReason:
"stop" | "length" | "content-filter" | "tool-calls" | "error" | "other" | "unknown"
usage:
LanguageModelUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
text:
string
reasoning:
string | undefined
sources:
Array<Source>
Source
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
SharedV2ProviderMetadata
files:
Array<GeneratedFile>
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
toolCalls:
ToolCall[]
toolResults:
ToolResult[]
warnings:
Warning[] | undefined
response?:
Response
Response
id:
string
model:
string
timestamp:
Date
headers?:
Record<string, string>
isContinued:
boolean
providerMetadata?:
Record<string,Record<string,JSONValue>> | undefined
onFinish?:
(result: OnFinishResult) => Promise<void> | void
OnFinishResult
finishReason:
"stop" | "length" | "content-filter" | "tool-calls" | "error" | "other" | "unknown"
usage:
LanguageModelUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
providerMetadata:
Record<string,Record<string,JSONValue>> | undefined
text:
string
reasoningText:
string | undefined
reasoning:
Array<ReasoningDetail>
ReasoningDetail
type:
'text'
text:
string
signature?:
string
ReasoningDetail
type:
'redacted'
data:
string
sources:
Array<Source>
Source
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
SharedV2ProviderMetadata
files:
Array<GeneratedFile>
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
toolCalls:
ToolCall[]
toolResults:
ToolResult[]
warnings:
Warning[] | undefined
response?:
Response
Response
id:
string
model:
string
timestamp:
Date
headers?:
Record<string, string>
messages:
Array<ResponseMessage>
steps:
Array<StepResult>
onAbort?:
(event: OnAbortResult) => Promise<void> | void
OnAbortResult
steps:
Array<StepResult>
Returns
content:
Promise<Array<ContentPart<TOOLS>>>
finishReason:
Promise<'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'>
usage:
Promise<LanguageModelUsage>
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
totalUsage:
Promise<LanguageModelUsage>
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
providerMetadata:
Promise<ProviderMetadata | undefined>
text:
Promise<string>
reasoning:
Promise<Array<ReasoningOutput>>
ReasoningOutput
type:
'reasoning'
text:
string
providerMetadata?:
SharedV2ProviderMetadata
reasoningText:
Promise<string | undefined>
sources:
Promise<Array<Source>>
Source
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
SharedV2ProviderMetadata
files:
Promise<Array<GeneratedFile>>
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
toolCalls:
Promise<TypedToolCall<TOOLS>[]>
toolResults:
Promise<TypedToolResult<TOOLS>[]>
request:
Promise<LanguageModelRequestMetadata>
LanguageModelRequestMetadata
body:
string
response:
Promise<LanguageModelResponseMetadata & { messages: Array<ResponseMessage>; }>
LanguageModelResponseMetadata
id:
string
model:
string
timestamp:
Date
headers?:
Record<string, string>
messages:
Array<ResponseMessage>
warnings:
Promise<CallWarning[] | undefined>
steps:
Promise<Array<StepResult>>
StepResult
stepType:
"initial" | "continue" | "tool-result"
text:
string
reasoning:
string | undefined
sources:
Array<Source>
Source
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
SharedV2ProviderMetadata
files:
Array<GeneratedFile>
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
toolCalls:
array
toolResults:
array
finishReason:
'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'
usage:
LanguageModelUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
request?:
RequestMetadata
RequestMetadata
body:
string
response?:
ResponseMetadata
ResponseMetadata
id:
string
model:
string
timestamp:
Date
headers?:
Record<string, string>
messages:
Array<ResponseMessage>
warnings:
Warning[] | undefined
isContinued:
boolean
providerMetadata?:
Record<string,Record<string,JSONValue>> | undefined
textStream:
AsyncIterableStream<string>
fullStream:
AsyncIterable<TextStreamPart<TOOLS>> & ReadableStream<TextStreamPart<TOOLS>>
TextStreamPart
type:
'text'
text:
string
TextStreamPart
type:
'reasoning'
text:
string
providerMetadata?:
ProviderMetadata
TextStreamPart
type:
'source'
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
ProviderMetadata
TextStreamPart
type:
'file'
file:
GeneratedFile
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
TextStreamPart
type:
'tool-call'
toolCallId:
string
toolName:
string
input:
object based on tool parameters
TextStreamPart
type:
'tool-call-streaming-start'
toolCallId:
string
toolName:
string
TextStreamPart
type:
'tool-call-delta'
toolCallId:
string
toolName:
string
argsTextDelta:
string
TextStreamPart
type:
'tool-result'
toolCallId:
string
toolName:
string
input:
object based on tool parameters
output:
tool execution return type
TextStreamPart
type:
'start-step'
request:
LanguageModelRequestMetadata
LanguageModelRequestMetadata
body:
string
warnings:
CallWarning[]
TextStreamPart
type:
'finish-step'
response:
LanguageModelResponseMetadata
LanguageModelResponseMetadata
id:
string
model:
string
timestamp:
Date
headers:
Record<string, string>
usage:
LanguageModelUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
finishReason:
'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'
providerMetadata?:
ProviderMetadata | undefined
TextStreamPart
type:
'start'
TextStreamPart
type:
'finish'
finishReason:
'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'
totalUsage:
LanguageModelUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
TextStreamPart
type:
'reasoning-part-finish'
TextStreamPart
type:
'error'
error:
unknown
TextStreamPart
type:
'abort'
experimental_partialOutputStream:
AsyncIterableStream<PARTIAL_OUTPUT>
consumeStream:
(options?: ConsumeStreamOptions) => Promise<void>
ConsumeStreamOptions
onError?:
(error: unknown) => void
toUIMessageStream:
(options?: UIMessageStreamOptions) => AsyncIterableStream<UIMessageChunk>
UIMessageStreamOptions
originalMessages?:
UIMessage[]
onFinish?:
(options: { messages: UIMessage[]; isContinuation: boolean; responseMessage: UIMessage; isAborted: boolean; }) => void
messageMetadata?:
(options: { part: TextStreamPart<TOOLS> & { type: "start" | "finish" | "start-step" | "finish-step"; }; }) => unknown
sendReasoning?:
boolean
sendSources?:
boolean
sendFinish?:
boolean
sendStart?:
boolean
onError?:
(error: unknown) => string
consumeSseStream?:
(stream: ReadableStream) => Promise<void>
pipeUIMessageStreamToResponse:
(response: ServerResponse, options?: ResponseInit & UIMessageStreamOptions) => void
ResponseInit & UIMessageStreamOptions
status?:
number
statusText?:
string
headers?:
HeadersInit
pipeTextStreamToResponse:
(response: ServerResponse, init?: ResponseInit) => void
ResponseInit
status?:
number
statusText?:
string
headers?:
Record<string, string>
toUIMessageStreamResponse:
(options?: ResponseInit & UIMessageStreamOptions) => Response
ResponseInit & UIMessageStreamOptions
status?:
number
statusText?:
string
headers?:
HeadersInit
toTextStreamResponse:
(init?: ResponseInit) => Response
ResponseInit
status?:
number
statusText?:
string
headers?:
Record<string, string>