generateText()
Generates text and calls tools for a given prompt using a language model.
It is ideal for non-interactive use cases such as automation tasks where you need to write text (e.g. drafting email or summarizing web pages) and for agents that use tools.
import { generateText } from 'ai';
const { text } = await generateText({ model: "anthropic/claude-sonnet-4.5", prompt: 'Invent a new holiday and describe its traditions.',});
console.log(text);To see generateText in action, check out these examples.
Import
import { generateText } 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
output:
unknown
isError?:
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_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>>
providerOptions?:
Record<string,Record<string,JSONValue>> | undefined
activeTools?:
Array<TOOLNAME>
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
experimental_output?:
Output
Output
Output.text():
Output
Output.object():
Output
Options
schema:
Schema<OBJECT>
onStepFinish?:
(result: OnStepFinishResult) => Promise<void> | void
OnStepFinishResult
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
toolCalls:
ToolCall[]
toolResults:
ToolResult[]
warnings:
Warning[] | undefined
response?:
Response
Response
id:
string
modelId:
string
timestamp:
Date
headers?:
Record<string, string>
body?:
unknown
isContinued:
boolean
providerMetadata?:
Record<string,Record<string,JSONValue>> | undefined
Returns
content:
Array<ContentPart<TOOLS>>
text:
string
reasoning:
Array<ReasoningOutput>
ReasoningOutput
type:
'reasoning'
text:
string
providerMetadata?:
SharedV2ProviderMetadata
reasoningText:
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:
ToolCallArray<TOOLS>
toolResults:
ToolResultArray<TOOLS>
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
totalUsage:
CompletionTokenUsage
LanguageModelUsage
inputTokens:
number | undefined
outputTokens:
number | undefined
totalTokens:
number | undefined
reasoningTokens?:
number | undefined
cachedInputTokens?:
number | undefined
request?:
LanguageModelRequestMetadata
LanguageModelRequestMetadata
body:
string
response?:
LanguageModelResponseMetadata
LanguageModelResponseMetadata
id:
string
modelId:
string
timestamp:
Date
headers?:
Record<string, string>
body?:
unknown
messages:
Array<ResponseMessage>
warnings:
CallWarning[] | undefined
providerMetadata:
ProviderMetadata | undefined
experimental_output?:
Output
steps:
Array<StepResult<TOOLS>>
StepResult
content:
Array<ContentPart<TOOLS>>
text:
string
reasoning:
Array<ReasoningPart>
ReasoningPart
type:
'reasoning'
text:
string
reasoningText:
string | undefined
files:
Array<GeneratedFile>
GeneratedFile
base64:
string
uint8Array:
Uint8Array
mediaType:
string
sources:
Array<Source>
Source
sourceType:
'url'
id:
string
url:
string
title?:
string
providerMetadata?:
SharedV2ProviderMetadata
toolCalls:
ToolCallArray<TOOLS>
toolResults:
ToolResultArray<TOOLS>
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
warnings:
CallWarning[] | undefined
request:
LanguageModelRequestMetadata
LanguageModelRequestMetadata
body:
string
response:
LanguageModelResponseMetadata
LanguageModelResponseMetadata
id:
string
modelId:
string
timestamp:
Date
headers?:
Record<string, string>
body?:
unknown
messages:
Array<ResponseMessage>
providerMetadata:
ProviderMetadata | undefined
Examples
Learn to generate text using a language model in Next.js
Learn to generate a chat completion using a language model in Next.js
Learn to call tools using a language model in Next.js
Learn to render a React component as a tool call using a language model in Next.js
Learn to generate text using a language model in Node.js
Learn to generate chat completions using a language model in Node.js