Back to Ai

LanguageModelV4Middleware

content/docs/07-reference/01-ai-sdk-core/65-language-model-v2-middleware.mdx

2.1.102.5 KB
Original Source

LanguageModelV4Middleware

<Note type="warning"> Language model middleware is an experimental feature. </Note>

Language model middleware provides a way to enhance the behavior of language models by intercepting and modifying the calls to the language model. It can be used to add features like guardrails, RAG, caching, and logging in a language model agnostic way.

See Language Model Middleware for more information.

Import

<Snippet text={import { LanguageModelV4Middleware } from "ai"} prompt={false} />

API Signature

<PropertiesTable content={[ { name: 'specificationVersion', type: "'v3'", description: 'The specification version of the middleware. Must be "v3".', }, { name: 'transformParams', type: '({ type: "generate" | "stream", params: LanguageModelV4CallOptions, model: LanguageModelV4 }) => PromiseLike<LanguageModelV4CallOptions>', isOptional: true, description: 'Transforms the parameters before they are passed to the language model.', }, { name: 'wrapGenerate', type: '({ doGenerate: () => PromiseLike<LanguageModelV4GenerateResult>, doStream: () => PromiseLike<LanguageModelV4StreamResult>, params: LanguageModelV4CallOptions, model: LanguageModelV4 }) => PromiseLike<LanguageModelV4GenerateResult>', isOptional: true, description: 'Wraps the generate operation of the language model. Receives both doGenerate and doStream functions.', }, { name: 'wrapStream', type: '({ doGenerate: () => PromiseLike<LanguageModelV4GenerateResult>, doStream: () => PromiseLike<LanguageModelV4StreamResult>, params: LanguageModelV4CallOptions, model: LanguageModelV4 }) => PromiseLike<LanguageModelV4StreamResult>', isOptional: true, description: 'Wraps the stream operation of the language model. Receives both doGenerate and doStream functions.', }, { name: 'overrideProvider', type: '(options: { model: LanguageModelV4 }) => string', isOptional: true, description: 'Override the provider ID of the model.', }, { name: 'overrideModelId', type: '(options: { model: LanguageModelV4 }) => string', isOptional: true, description: 'Override the model ID of the model.', }, { name: 'overrideSupportedUrls', type: '(options: { model: LanguageModelV4 }) => PromiseLike<Record<string, RegExp[]>> | Record<string, RegExp[]>', isOptional: true, description: 'Override the supported URLs for the model.', }, ]} />