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 { openai } from '@ai-sdk/openai';
import { generateText } from 'ai';
const { text } = await generateText({
model: openai('gpt-4o'),
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

messages:

Array<CoreSystemMessage | CoreUserMessage | CoreAssistantMessage | CoreToolMessage> | Array<UIMessage>
CoreSystemMessage

role:

'system'

content:

string
CoreUserMessage

role:

'user'

content:

string | Array<TextPart | ImagePart | FilePart>
TextPart

type:

'text'

text:

string
ImagePart

type:

'image'

image:

string | Uint8Array | Buffer | ArrayBuffer | URL

mimeType?:

string
FilePart

type:

'file'

data:

string | Uint8Array | Buffer | ArrayBuffer | URL

mimeType:

string
CoreAssistantMessage

role:

'assistant'

content:

string | Array<TextPart | ReasoningPart | RedactedReasoningPart | ToolCallPart>
TextPart

type:

'text'

text:

string
ReasoningPart

type:

'reasoning'

text:

string

signature?:

string
RedactedReasoningPart

type:

'redacted-reasoning'

data:

string
ToolCallPart

type:

'tool-call'

toolCallId:

string

toolName:

string

args:

object based on zod schema
CoreToolMessage

role:

'tool'

content:

Array<ToolResultPart>
ToolResultPart

type:

'tool-result'

toolCallId:

string

toolName:

string

result:

unknown

isError?:

boolean

tools:

ToolSet
Tool

description?:

string

parameters:

Zod Schema | JSON Schema

execute?:

async (parameters: T, options: ToolExecutionOptions) => RESULT
ToolExecutionOptions

toolCallId:

string

messages:

CoreMessage[]

abortSignal:

AbortSignal

toolChoice?:

"auto" | "none" | "required" | { "type": "tool", "toolName": string }

maxTokens?:

number

temperature?:

number

topP?:

number

topK?:

number

presencePenalty?:

number

frequencyPenalty?:

number

stopSequences?:

string[]

seed?:

number

maxRetries?:

number

abortSignal?:

AbortSignal

headers?:

Record<string, string>

maxSteps?:

number

experimental_generateMessageId?:

() => string

experimental_continueSteps?:

boolean

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

experimental_activeTools?:

Array<TOOLNAME> | undefined

experimental_repairToolCall?:

(options: ToolCallRepairOptions) => Promise<LanguageModelV1FunctionToolCall | null>
ToolCallRepairOptions

system:

string | undefined

messages:

CoreMessage[]

toolCall:

LanguageModelV1FunctionToolCall

tools:

TOOLS

parameterSchema:

(options: { toolName: string }) => JSONSchema7

error:

NoSuchToolError | InvalidToolArgumentsError

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:

TokenUsage
TokenUsage

promptTokens:

number

completionTokens:

number

totalTokens:

number

text:

string

toolCalls:

ToolCall[]

toolResults:

ToolResult[]

warnings:

Warning[] | undefined

response?:

Response
Response

id:

string

model:

string

timestamp:

Date

headers?:

Record<string, string>

body?:

unknown

isContinued:

boolean

providerMetadata?:

Record<string,Record<string,JSONValue>> | undefined

Returns

text:

string

reasoning:

string | undefined

reasoningDetails:

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?:

LanguageModelV1ProviderMetadata

files:

Array<GeneratedFile>
GeneratedFile

base64:

string

uint8Array:

Uint8Array

mimeType:

string

toolCalls:

array

toolResults:

array

finishReason:

'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'

usage:

CompletionTokenUsage
CompletionTokenUsage

promptTokens:

number

completionTokens:

number

totalTokens:

number

request?:

RequestMetadata
RequestMetadata

body:

string

response?:

ResponseMetadata
ResponseMetadata

id:

string

model:

string

timestamp:

Date

headers?:

Record<string, string>

body?:

unknown

messages:

Array<ResponseMessage>

warnings:

Warning[] | undefined

providerMetadata:

Record<string,Record<string,JSONValue>> | undefined

experimental_output?:

Output

steps:

Array<StepResult>
StepResult

stepType:

"initial" | "continue" | "tool-result"

text:

string

reasoning:

string | undefined

reasoningDetails:

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?:

LanguageModelV1ProviderMetadata

files:

Array<GeneratedFile>
GeneratedFile

base64:

string

uint8Array:

Uint8Array

mimeType:

string

toolCalls:

array

toolResults:

array

finishReason:

'stop' | 'length' | 'content-filter' | 'tool-calls' | 'error' | 'other' | 'unknown'

usage:

CompletionTokenUsage
CompletionTokenUsage

promptTokens:

number

completionTokens:

number

totalTokens:

number

request?:

RequestMetadata
RequestMetadata

body:

string

response?:

ResponseMetadata
ResponseMetadata

id:

string

model:

string

timestamp:

Date

headers?:

Record<string, string>

body?:

unknown

messages:

Array<ResponseMessage>

warnings:

Warning[] | undefined

isContinued:

boolean

providerMetadata?:

Record<string,Record<string,JSONValue>> | 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