hts/packages/isdk/core/tool/tool.ts

54 lines
1.8 KiB
TypeScript

import { z } from 'zod';
/**
A tool contains the description and the schema of the input that the tool expects.
This enables the language model to generate the input.
The tool can also contain an optional execute function for the actual execution function of the tool.
*/
export interface ExperimentalTool<
PARAMETERS extends z.ZodTypeAny = any,
RESULT = any,
> {
/**
An optional description of what the tool does. Will be used by the language model to decide whether to use the tool.
*/
description?: string;
/**
The schema of the input that the tool expects. The language model will use this to generate the input.
Use descriptions to make the input understandable for the language model.
*/
parameters: PARAMETERS;
/**
An optional execute function for the actual execution function of the tool.
If not provided, the tool will not be executed automatically.
*/
execute?: (args: z.infer<PARAMETERS>) => PromiseLike<RESULT>;
}
/**
Helper function for inferring the execute args of a tool.
*/
// Note: special type inference is needed for the execute function args to make sure they are inferred correctly.
export function tool<PARAMETERS extends z.ZodTypeAny, RESULT>(
tool: ExperimentalTool<PARAMETERS, RESULT> & {
execute: (args: z.infer<PARAMETERS>) => PromiseLike<RESULT>;
},
): ExperimentalTool<PARAMETERS, RESULT> & {
execute: (args: z.infer<PARAMETERS>) => PromiseLike<RESULT>;
};
export function tool<PARAMETERS extends z.ZodTypeAny, RESULT>(
tool: ExperimentalTool<PARAMETERS, RESULT> & {
execute?: undefined;
},
): ExperimentalTool<PARAMETERS, RESULT> & {
execute: undefined;
};
export function tool<PARAMETERS extends z.ZodTypeAny, RESULT = any>(
tool: ExperimentalTool<PARAMETERS, RESULT>,
): ExperimentalTool<PARAMETERS, RESULT> {
return tool;
}