jsonSchema()
jsonSchema is a helper function that creates a JSON schema object that is compatible with the AI SDK.
It takes the JSON schema and an optional validation function as inputs, and can be typed.
You can use it to generate structured data and in tools.
jsonSchema is an alternative to using Zod schemas that provides you with flexibility in dynamic situations
(e.g. when using OpenAPI definitions) or for using other validation libraries.
import { jsonSchema } from 'ai';
const mySchema = jsonSchema<{ recipe: { name: string; ingredients: { name: string; amount: string }[]; steps: string[]; };}>({ type: 'object', properties: { recipe: { type: 'object', properties: { name: { type: 'string' }, ingredients: { type: 'array', items: { type: 'object', properties: { name: { type: 'string' }, amount: { type: 'string' }, }, required: ['name', 'amount'], }, }, steps: { type: 'array', items: { type: 'string' }, }, }, required: ['name', 'ingredients', 'steps'], }, }, required: ['recipe'],});Import
import { jsonSchema } from "ai"API Signature
Parameters
schema:
JSONSchema7
options:
SchemaOptions
SchemaOptions
validate?:
(value: unknown) => { success: true; value: OBJECT } | { success: false; error: Error };
Returns
A JSON schema object that is compatible with the AI SDK.