UNPKG

@tanstack/ai

Version:

Core TanStack AI library - Open source AI SDK

81 lines (80 loc) 3.48 kB
import { Context as AGUIContext } from '@ag-ui/core'; import { JSONSchema, ModelMessage, Tool, UIMessage } from '../types.js'; /** * Parse and validate an HTTP request body as an AG-UI `RunAgentInput`. * * Returns a spread-friendly object whose `messages` field is suitable for * passing directly to `chat({ messages })`. The existing * `convertMessagesToModelMessages` handles AG-UI fan-out dedup and * reasoning/activity/developer-role normalization internally. * * @throws An error with a migration-pointing message when the body does * not conform to AG-UI 0.0.52 `RunAgentInputSchema`. Surface this as a * 400 Bad Request to the client. */ export declare function chatParamsFromRequestBody(body: unknown): Promise<{ messages: Array<UIMessage | ModelMessage>; threadId: string; runId: string; parentRunId?: string; tools: Array<{ name: string; description: string; parameters: JSONSchema; }>; forwardedProps: Record<string, unknown>; state: unknown; context: Array<AGUIContext>; }>; /** * Read an HTTP `Request`, parse its JSON body, and validate it as an * AG-UI `RunAgentInput` — collapsing the standard `req.json()` + * `chatParamsFromRequestBody(...)` pair into a single call. * * On a malformed body or invalid AG-UI shape, this **throws a * `Response`** with status 400 and a migration-pointing message in the * body. Frameworks that natively handle thrown `Response` objects * (TanStack Start, SolidStart, Remix, React Router 7) will return the * 400 to the client automatically, so the handler reduces to: * * ```ts * export async function POST(req: Request) { * const params = await chatParamsFromRequest(req) * // ...use params * } * ``` * * In frameworks that do not auto-handle thrown `Response` objects * (Next.js Route Handlers, SvelteKit, Hono, raw Node), wrap the call * with try/catch and return the caught Response yourself, or use * `chatParamsFromRequestBody` directly with your own JSON-parsing. * * @throws {Response} 400 on malformed JSON or invalid AG-UI shape. */ export declare function chatParamsFromRequest(req: Request): Promise<Awaited<ReturnType<typeof chatParamsFromRequestBody>>>; /** * Merge a server-side tool array with the AG-UI client-declared tools * received in the request body. * * Rules: * - Server tools win on name collision. The client's declaration is * ignored if the server already has a tool with that name. The client's * UI-side handler still fires when the streamed tool-result event comes * through (see `chat-client.ts` `onToolCall`), giving the * "after server execution the client also handles" semantic for free. * - Client-only tools (name not in `serverTools`) become no-execute * entries: the runtime's existing `ClientToolRequest` path handles * them — server emits a tool-call request, client executes via its * registered handler, client posts back the result. * * @param serverTools - The server's tool array (e.g. from * `[myToolDef.server(...)]`). Pass directly to `chat({ tools })`. * @param clientTools - The `tools` array received from * `chatParamsFromRequest(...)` / `chatParamsFromRequestBody(...)`. * @returns A merged array suitable for `chat({ tools })`. */ export declare function mergeAgentTools(serverTools: ReadonlyArray<Tool>, clientTools: ReadonlyArray<{ name: string; description: string; parameters: JSONSchema; }>): Array<Tool>;