ai
Version:
AI SDK by Vercel - The AI Toolkit for TypeScript and JavaScript
95 lines (81 loc) • 2.61 kB
text/mdx
title: jsonSchema
description: Helper function for creating JSON schemas
# `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](/docs/ai-sdk-core/generating-structured-data) and in [tools](/docs/ai-sdk-core/tools-and-tool-calling).
`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.
```ts
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
<Snippet text={`import { jsonSchema } from "ai"`} prompt={false} />
## API Signature
### Parameters
<PropertiesTable
content={[
{
name: 'schema',
type: 'JSONSchema7',
description: 'The JSON schema definition.',
},
{
name: 'options',
type: 'SchemaOptions',
description: 'Additional options for the JSON schema.',
properties: [
{
type: 'SchemaOptions',
parameters: [
{
name: 'validate',
isOptional: true,
type: '(value: unknown) => { success: true; value: OBJECT } | { success: false; error: Error };',
description:
'A function that validates the value against the JSON schema. If the value is valid, the function should return an object with a `success` property set to `true` and a `value` property set to the validated value. If the value is invalid, the function should return an object with a `success` property set to `false` and an `error` property set to the error.',
},
],
},
],
},
]}
/>
### Returns
A JSON schema object that is compatible with the AI SDK.