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.