{"id":100,"date":"2025-12-22T00:00:00","date_gmt":"2025-12-22T00:00:00","guid":{"rendered":"https:\/\/wordpress.securinsight.ca\/index.php\/2025\/12\/22\/agents-workers-agents-sdk-v0-3-0-workers-ai-provider-v3-0-0-and-ai-gateway-provider-v3-0-0-with-ai-sdk-v6-support-5\/"},"modified":"2025-12-22T00:00:00","modified_gmt":"2025-12-22T00:00:00","slug":"agents-workers-agents-sdk-v0-3-0-workers-ai-provider-v3-0-0-and-ai-gateway-provider-v3-0-0-with-ai-sdk-v6-support-5","status":"publish","type":"post","link":"https:\/\/wordpress.securinsight.ca\/index.php\/2025\/12\/22\/agents-workers-agents-sdk-v0-3-0-workers-ai-provider-v3-0-0-and-ai-gateway-provider-v3-0-0-with-ai-sdk-v6-support-5\/","title":{"rendered":"Agents, Workers &#8211; Agents SDK v0.3.0, workers-ai-provider v3.0.0, and ai-gateway-provider v3.0.0 with AI SDK v6 support"},"content":{"rendered":"<p>We&#8217;ve shipped a new release for the <a href=\"https:\/\/github.com\/cloudflare\/agents\" target=\"_blank\">Agents SDK<\/a> v0.3.0 bringing full compatibility with <a href=\"https:\/\/ai-sdk.dev\/docs\/introduction\" target=\"_blank\">AI SDK v6<\/a> and introducing the unified tool pattern, dynamic tool approval, and enhanced React hooks with improved tool handling.<\/p>\n<p>This release includes improved streaming and tool support, dynamic tool approval (for &#8220;human in the loop&#8221; systems), enhanced React hooks with <code>onToolCall<\/code> callback, improved error handling for streaming responses, and seamless migration from v5 patterns.<\/p>\n<p>This makes it ideal for building production AI chat interfaces with Cloudflare Workers AI models, agent workflows, human-in-the-loop systems, or any application requiring reliable tool execution and approval workflows.<\/p>\n<p>Additionally, we&#8217;ve updated <strong>workers-ai-provider v3.0.0<\/strong>, the official provider for Cloudflare Workers AI models, and <strong>ai-gateway-provider v3.0.0<\/strong>, the provider for Cloudflare AI Gateway, to be compatible with AI SDK v6.<\/p>\n<h4>Agents SDK v0.3.0<\/h4>\n<h4>Unified Tool Pattern<\/h4>\n<p>AI SDK v6 introduces a unified tool pattern where all tools are defined on the server using the <code>tool()<\/code> function. This replaces the previous client-side <code>AITool<\/code> pattern.<\/p>\n<h4>Server-Side Tool Definition<\/h4>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>tool<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>z<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"zod\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ Server: Define ALL tools on the server<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>tools<\/span><span> <\/span><span>=<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span>  <\/span><span>\/\/ Server-executed tool<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>getWeather<\/span><span>:<\/span><span> <\/span><span>tool<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>description<\/span><span>:<\/span><span> <\/span><span>\"Get weather for a city\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>inputSchema<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{<\/span><span> city<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>string<\/span><span>() <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span>    <\/span><span>execute<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>city<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>fetchWeather<\/span><span>(<\/span><span>city<\/span><span>)<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>  <\/span><span>\/\/ Client-executed tool (no execute = client handles via onToolCall)<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>getLocation<\/span><span>:<\/span><span> <\/span><span>tool<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>description<\/span><span>:<\/span><span> <\/span><span>\"Get user location from browser\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>inputSchema<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{}<\/span><span>)<\/span><\/div><\/div><div><div><span>    <\/span><span>\/\/ No execute function<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>  <\/span><span>\/\/ Tool requiring approval (dynamic based on input)<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>processPayment<\/span><span>:<\/span><span> <\/span><span>tool<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>description<\/span><span>:<\/span><span> <\/span><span>\"Process a payment\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>inputSchema<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{<\/span><span> amount<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>number<\/span><span>() <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span>    <\/span><span>needsApproval<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>amount<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>amount<\/span><span> <\/span><span>&gt;<\/span><span> <\/span><span>100<\/span><span>,<\/span><\/div><\/div><div><div><span>    <\/span><span>execute<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>amount<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>charge<\/span><span>(<\/span><span>amount<\/span><span>)<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><\/div><\/div><div><div><span>};<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Client-Side Tool Handling<\/h4>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>\/\/ Client: Handle client-side tools via onToolCall callback<\/span><\/div><\/div><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>useAgentChat<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"agents\/ai-react\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>const<\/span><span> <\/span><span>{<\/span><span> <\/span><span>messages<\/span><span>,<\/span><span> <\/span><span>sendMessage<\/span><span>,<\/span><span> <\/span><span>addToolOutput<\/span><span> <\/span><span>}<\/span><span> <\/span><span>=<\/span><span> <\/span><span>useAgentChat<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span>  <\/span><span>agent<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>onToolCall<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>toolCall<\/span><span>,<\/span><span> <\/span><span>addToolOutput<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>if<\/span><span> (<\/span><span>toolCall<\/span><span>.<\/span><span>toolName<\/span><span> <\/span><span>===<\/span><span> <\/span><span>\"getLocation\"<\/span><span>) <\/span><span>{<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>const<\/span><span> <\/span><span>position<\/span><span> <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>new<\/span><span> <\/span><span>Promise<\/span><span>(<\/span><span>(<\/span><span>resolve<\/span><span>,<\/span><span> <\/span><span>reject<\/span><span>)<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span>        <\/span><span>navigator<\/span><span>.<\/span><span>geolocation<\/span><span>.<\/span><span>getCurrentPosition<\/span><span>(<\/span><span>resolve<\/span><span>,<\/span><span> <\/span><span>reject<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>      <\/span><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>      <\/span><span>addToolOutput<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>        <\/span><\/span><span>toolCallId<\/span><span>:<\/span><span> <\/span><span>toolCall<\/span><span>.<\/span><span>toolCallId<\/span><span>,<\/span><\/div><\/div><div><div><span><span>        <\/span><\/span><span>output<\/span><span>:<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span><span>          <\/span><\/span><span>lat<\/span><span>:<\/span><span> <\/span><span>position<\/span><span>.<\/span><span>coords<\/span><span>.<\/span><span>latitude<\/span><span>,<\/span><\/div><\/div><div><div><span><span>          <\/span><\/span><span>lng<\/span><span>:<\/span><span> <\/span><span>position<\/span><span>.<\/span><span>coords<\/span><span>.<\/span><span>longitude<\/span><\/div><\/div><div><div><span>        <\/span><span>}<\/span><\/div><\/div><div><div><span>      <\/span><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>    <\/span><span>}<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<p><strong>Key benefits of the unified tool pattern:<\/strong><\/p>\n<ul>\n<li><strong>Server-defined tools<\/strong>: All tools are defined in one place on the server<\/li>\n<li><strong>Dynamic approval<\/strong>: Use <code>needsApproval<\/code> to conditionally require user confirmation<\/li>\n<li><strong>Cleaner client code<\/strong>: Use <code>onToolCall<\/code> callback instead of managing tool configs<\/li>\n<li><strong>Type safety<\/strong>: Full TypeScript support with proper tool typing<\/li>\n<\/ul>\n<h4>useAgentChat(options)<\/h4>\n<p>Creates a new chat interface with enhanced v6 capabilities.<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>\/\/ Basic chat setup with onToolCall<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>{<\/span><span> <\/span><span>messages<\/span><span>,<\/span><span> <\/span><span>sendMessage<\/span><span>,<\/span><span> <\/span><span>addToolOutput<\/span><span> <\/span><span>}<\/span><span> <\/span><span>=<\/span><span> <\/span><span>useAgentChat<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span>  <\/span><span>agent<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>onToolCall<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>toolCall<\/span><span>,<\/span><span> <\/span><span>addToolOutput<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span>    <\/span><span>\/\/ Handle client-side tool execution<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>await<\/span><span> <\/span><span>addToolOutput<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>toolCallId<\/span><span>:<\/span><span> <\/span><span>toolCall<\/span><span>.<\/span><span>toolCallId<\/span><span>,<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>output<\/span><span>:<\/span><span> <\/span><span>{<\/span><span> result<\/span><span>:<\/span><span> <\/span><span>\"success\"<\/span><span> <\/span><span>}<\/span><\/div><\/div><div><div><span>    <\/span><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Dynamic Tool Approval<\/h4>\n<p>Use <code>needsApproval<\/code> on server tools to conditionally require user confirmation:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>const<\/span><span> <\/span><span>paymentTool<\/span><span> <\/span><span>=<\/span><span> <\/span><span>tool<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>description<\/span><span>:<\/span><span> <\/span><span>\"Process a payment\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>inputSchema<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>amount<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>number<\/span><span>()<\/span><span>,<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>recipient<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>string<\/span><span>()<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>needsApproval<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>amount<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>amount<\/span><span> <\/span><span>&gt;<\/span><span> <\/span><span>1000<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>execute<\/span><span>:<\/span><span> <\/span><span>async<\/span><span> <\/span><span>({<\/span><span> <\/span><span>amount<\/span><span>,<\/span><span> <\/span><span>recipient<\/span><span> <\/span><span>})<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>return<\/span><span> <\/span><span>await<\/span><span> <\/span><span>processPayment<\/span><span>(<\/span><span>amount<\/span><span>,<\/span><span> <\/span><span>recipient<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Tool Confirmation Detection<\/h4>\n<p>The <code>isToolUIPart<\/code> and <code>getToolName<\/code> functions now check both static and dynamic tool parts:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>isToolUIPart<\/span><\/span><span>,<\/span><span><span> <\/span><span>getToolName<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>const<\/span><span> <\/span><span>pendingToolCallConfirmation<\/span><span> <\/span><span>=<\/span><span> <\/span><span>messages<\/span><span>.<\/span><span>some<\/span><span>(<\/span><span>(<\/span><span>m<\/span><span>)<\/span><span> <\/span><span>=&gt;<\/span><\/div><\/div><div><div><span>  <\/span><span>m<\/span><span>.<\/span><span>parts<\/span><span>?.<\/span><span>some<\/span><span>(<\/span><\/div><\/div><div><div><span>    <\/span><span>(<\/span><span>part<\/span><span>)<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>isToolUIPart<\/span><span>(<\/span><span>part<\/span><span>) <\/span><span>&amp;&amp;<\/span><span> <\/span><span>part<\/span><span>.<\/span><span>state<\/span><span> <\/span><span>===<\/span><span> <\/span><span>\"input-available\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span>)<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ Handle tool confirmation<\/span><\/div><\/div><div><div><span>if<\/span><span> (<\/span><span>pendingToolCallConfirmation<\/span><span>) <\/span><span>{<\/span><\/div><\/div><div><div><span>  <\/span><span>await<\/span><span> <\/span><span>addToolOutput<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>toolCallId<\/span><span>:<\/span><span> <\/span><span>part<\/span><span>.<\/span><span>toolCallId<\/span><span>,<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>output<\/span><span>:<\/span><span> <\/span><span>\"User approved the action\"<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>}<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<p>If you need the v5 behavior (static-only checks), use the new functions:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>isStaticToolUIPart<\/span><\/span><span>,<\/span><span><span> <\/span><span>getStaticToolName<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>convertToModelMessages() is now async<\/h4>\n<p>The <code>convertToModelMessages()<\/code> function is now asynchronous. Update all calls to await the result:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>convertToModelMessages<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>const<\/span><span> <\/span><span>result<\/span><span> <\/span><span>=<\/span><span> <\/span><span>streamText<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>messages<\/span><span>:<\/span><span> <\/span><span>await<\/span><span> <\/span><span>convertToModelMessages<\/span><span>(<\/span><span>this<\/span><span>.<\/span><span>messages<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>model<\/span><span>:<\/span><span> <\/span><span>openai<\/span><span>(<\/span><span>\"gpt-4o\"<\/span><span>)<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>ModelMessage type<\/h4>\n<p>The <code>CoreMessage<\/code> type has been removed. Use <code>ModelMessage<\/code> instead:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>convertToModelMessages<\/span><\/span><span>,<\/span><span><span> type <\/span><span>ModelMessage<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>const<\/span><span> <\/span><span>modelMessages<\/span><span>:<\/span><span> <\/span><span>ModelMessage<\/span><span>[] <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>convertToModelMessages<\/span><span>(<\/span><span>messages<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>generateObject mode option removed<\/h4>\n<p>The <code>mode<\/code> option for <code>generateObject<\/code> has been removed:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>\/\/ Before (v5)<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>result<\/span><span> <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>generateObject<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>mode<\/span><span>:<\/span><span> <\/span><span>\"json\"<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>model<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>schema<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>prompt<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ After (v6)<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>result<\/span><span> <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>generateObject<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span>  <\/span><span>model<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>schema<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>prompt<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Structured Output with generateText<\/h4>\n<p>While <code>generateObject<\/code> and <code>streamObject<\/code> are still functional, the recommended approach is to use <code>generateText<\/code>\/<code>streamText<\/code> with the <code>Output.object()<\/code> helper:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>generateText<\/span><\/span><span>,<\/span><span><span> <\/span><span>Output<\/span><\/span><span>,<\/span><span><span> <\/span><span>stepCountIs<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>const<\/span><span> <\/span><span>{<\/span><span> <\/span><span>output<\/span><span> <\/span><span>}<\/span><span> <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>generateText<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>model<\/span><span>:<\/span><span> <\/span><span>openai<\/span><span>(<\/span><span>\"gpt-4\"<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>output<\/span><span>:<\/span><span> <\/span><span>Output<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>    <\/span><\/span><span>schema<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>object<\/span><span>(<\/span><span>{<\/span><span> name<\/span><span>:<\/span><span> <\/span><span>z<\/span><span>.<\/span><span>string<\/span><span>() <\/span><span>}<\/span><span>)<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>stopWhen<\/span><span>:<\/span><span> <\/span><span>stepCountIs<\/span><span>(<\/span><span>2<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>prompt<\/span><span>:<\/span><span> <\/span><span>\"Generate a name\"<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<blockquote>\n<p><strong>Note<\/strong>: When using structured output with <code>generateText<\/code>, you must configure multiple steps with <code>stopWhen<\/code> because generating the structured output is itself a step.<\/p>\n<\/blockquote>\n<h4>workers-ai-provider v3.0.0<\/h4>\n<p>Seamless integration with Cloudflare Workers AI models through the updated workers-ai-provider v3.0.0 with AI SDK v6 support.<\/p>\n<h4>Model Setup with Workers AI<\/h4>\n<p>Use Cloudflare Workers AI models directly in your agent workflows:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>createWorkersAI<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"workers-ai-provider\"<\/span><span>;<\/span><\/div><\/div><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>useAgentChat<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"agents\/ai-react\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ Create Workers AI model (v3.0.0 - enhanced v6 internals)<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>model<\/span><span> <\/span><span>=<\/span><span> <\/span><span>createWorkersAI<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>binding<\/span><span>:<\/span><span> <\/span><span>env<\/span><span>.<\/span><span>AI<\/span><span>,<\/span><\/div><\/div><div><div><span>}<\/span><span>)(<\/span><span>\"@cf\/meta\/llama-3.2-3b-instruct\"<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Enhanced File and Image Support<\/h4>\n<p>Workers AI models now support v6 file handling with automatic conversion:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>\/\/ Send images and files to Workers AI models<\/span><\/div><\/div><div><div><span>sendMessage<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>role<\/span><span>:<\/span><span> <\/span><span>\"user\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>parts<\/span><span>:<\/span><span> [<\/span><\/div><\/div><div><div><span>    <\/span><span>{<\/span><span> type<\/span><span>:<\/span><span> <\/span><span>\"text\"<\/span><span>,<\/span><span> text<\/span><span>:<\/span><span> <\/span><span>\"Analyze this image:\"<\/span><span> <\/span><span>},<\/span><\/div><\/div><div><div><span>    <\/span><span>{<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>type<\/span><span>:<\/span><span> <\/span><span>\"file\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>data<\/span><span>:<\/span><span> <\/span><span>imageBuffer<\/span><span>,<\/span><\/div><\/div><div><div><span><span>      <\/span><\/span><span>mediaType<\/span><span>:<\/span><span> <\/span><span>\"image\/jpeg\"<\/span><span>,<\/span><\/div><\/div><div><div><span>    <\/span><span>},<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>]<\/span><span>,<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ Workers AI provider automatically converts to proper format<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Streaming with Workers AI<\/h4>\n<p>Enhanced streaming support with automatic warning detection:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>\/\/ Streaming with Workers AI models<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>result<\/span><span> <\/span><span>=<\/span><span> <\/span><span>await<\/span><span> <\/span><span>streamText<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>model<\/span><span>:<\/span><span> <\/span><span>createWorkersAI<\/span><span>(<\/span><span>{<\/span><span> binding<\/span><span>:<\/span><span> <\/span><span>env<\/span><span>.<\/span><span>AI<\/span><span> <\/span><span>}<\/span><span>)(<\/span><span>\"@cf\/meta\/llama-3.2-3b-instruct\"<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>messages<\/span><span>:<\/span><span> <\/span><span>await<\/span><span> <\/span><span>convertToModelMessages<\/span><span>(<\/span><span>messages<\/span><span>)<\/span><span>,<\/span><\/div><\/div><div><div><span>  <\/span><span>onChunk<\/span><span>:<\/span><span> <\/span><span>(<\/span><span>chunk<\/span><span>)<\/span><span> <\/span><span>=&gt;<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span>    <\/span><span>\/\/ Enhanced streaming with warning handling<\/span><\/div><\/div><div><div><span>    <\/span><span>console<\/span><span>.<\/span><span>log<\/span><span>(<\/span><span>chunk<\/span><span>)<\/span><span>;<\/span><\/div><\/div><div><div><span>  <\/span><span>},<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>ai-gateway-provider v3.0.0<\/h4>\n<p>The ai-gateway-provider v3.0.0 now supports AI SDK v6, enabling you to use Cloudflare AI Gateway with multiple AI providers including Anthropic, Azure, AWS Bedrock, Google Vertex, and Perplexity.<\/p>\n<h4>AI Gateway Setup<\/h4>\n<p>Use Cloudflare AI Gateway to add analytics, caching, and rate limiting to your AI applications:<\/p>\n<div>\n<figure>\n<pre data-language=\"ts\"><code class=\"language-ts\"><div><div><span>import <\/span><span>{<\/span><span><span> <\/span><span>createAIGateway<\/span><span> <\/span><\/span><span>}<\/span><span> from <\/span><span>\"ai-gateway-provider\"<\/span><span>;<\/span><\/div><\/div><div><div>\n<\/div><\/div><div><div><span>\/\/ Create AI Gateway provider (v3.0.0 - enhanced v6 internals)<\/span><\/div><\/div><div><div><span>const<\/span><span> <\/span><span>model<\/span><span> <\/span><span>=<\/span><span> <\/span><span>createAIGateway<\/span><span>(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>gatewayUrl<\/span><span>:<\/span><span> <\/span><span>\"https:\/\/gateway.ai.cloudflare.com\/v1\/your-account-id\/gateway\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>headers<\/span><span>:<\/span><span> <\/span><span>{<\/span><\/div><\/div><div><div><span>    <\/span><span>\"Authorization\"<\/span><span>:<\/span><span> <\/span><span>`Bearer <\/span><span>${<\/span><span>env<\/span><span>.<\/span><span>AI_GATEWAY_TOKEN<\/span><span>}<\/span><span>`<\/span><\/div><\/div><div><div><span>  <\/span><span>}<\/span><\/div><\/div><div><div><span>}<\/span><span>)(<\/span><span>{<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>provider<\/span><span>:<\/span><span> <\/span><span>\"openai\"<\/span><span>,<\/span><\/div><\/div><div><div><span><span>  <\/span><\/span><span>model<\/span><span>:<\/span><span> <\/span><span>\"gpt-4o\"<\/span><\/div><\/div><div><div><span>}<\/span><span>)<\/span><span>;<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Migration from v5<\/h4>\n<h4>Deprecated APIs<\/h4>\n<p>The following APIs are deprecated in favor of the unified tool pattern:<\/p>\n<table>\n<thead>\n<tr>\n<th>Deprecated<\/th>\n<th>Replacement<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>AITool<\/code> type<\/td>\n<td>Use AI SDK&#8217;s <code>tool()<\/code> function on server<\/td>\n<\/tr>\n<tr>\n<td><code>extractClientToolSchemas()<\/code><\/td>\n<td>Define tools on server, no client schemas needed<\/td>\n<\/tr>\n<tr>\n<td><code>createToolsFromClientSchemas()<\/code><\/td>\n<td>Define tools on server with <code>tool()<\/code><\/td>\n<\/tr>\n<tr>\n<td><code>toolsRequiringConfirmation<\/code> option<\/td>\n<td>Use <code>needsApproval<\/code> on server tools<\/td>\n<\/tr>\n<tr>\n<td><code>experimental_automaticToolResolution<\/code><\/td>\n<td>Use <code>onToolCall<\/code> callback<\/td>\n<\/tr>\n<tr>\n<td><code>tools<\/code> option in <code>useAgentChat<\/code><\/td>\n<td>Use <code>onToolCall<\/code> for client-side execution<\/td>\n<\/tr>\n<tr>\n<td><code>addToolResult()<\/code><\/td>\n<td>Use <code>addToolOutput()<\/code><\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<h4>Breaking Changes Summary<\/h4>\n<ol>\n<li><strong>Unified Tool Pattern<\/strong>: All tools must be defined on the server using <code>tool()<\/code><\/li>\n<li><strong><code>convertToModelMessages()<\/code> is async<\/strong>: Add <code>await<\/code> to all calls<\/li>\n<li><strong><code>CoreMessage<\/code> removed<\/strong>: Use <code>ModelMessage<\/code> instead<\/li>\n<li><strong><code>generateObject<\/code> mode removed<\/strong>: Remove <code>mode<\/code> option<\/li>\n<li><strong><code>isToolUIPart<\/code> behavior changed<\/strong>: Now checks both static and dynamic tool parts<\/li>\n<\/ol>\n<h4>Installation<\/h4>\n<p>Update your dependencies to use the latest versions:<\/p>\n<div>\n<figure>\n<pre data-language=\"bash\"><code class=\"language-bash\"><div><div><span>npm<\/span><span> <\/span><span>install<\/span><span> <\/span><span>agents@^0.3.0<\/span><span> <\/span><span>workers-ai-provider@^3.0.0<\/span><span> <\/span><span>ai-gateway-provider@^3.0.0<\/span><span> <\/span><span>ai@^6.0.0<\/span><span> <\/span><span>@ai-sdk\/react@^3.0.0<\/span><span> <\/span><span>@ai-sdk\/openai@^3.0.0<\/span><\/div><\/div><\/code><\/pre>\n<div><\/div>\n<\/figure>\n<\/div>\n<h4>Resources<\/h4>\n<ul>\n<li><a href=\"https:\/\/github.com\/cloudflare\/agents\/blob\/main\/docs\/migration-to-ai-sdk-v6.md\" target=\"_blank\">Migration Guide<\/a> &#8211; Comprehensive migration documentation from v5 to v6<\/li>\n<li><a href=\"https:\/\/ai-sdk.dev\/docs\/migration-guides\/migration-guide-6-0\" target=\"_blank\">AI SDK v6 Documentation<\/a> &#8211; Official AI SDK migration guide<\/li>\n<li><a href=\"https:\/\/vercel.com\/blog\/ai-sdk-6\" target=\"_blank\">AI SDK v6 Announcement<\/a> &#8211; Learn about new features in v6<\/li>\n<li><a href=\"https:\/\/sdk.vercel.ai\/docs\" target=\"_blank\">AI SDK Documentation<\/a> &#8211; Complete AI SDK reference<\/li>\n<li><a href=\"https:\/\/github.com\/cloudflare\/agents\/issues\" target=\"_blank\">GitHub Issues<\/a> &#8211; Report bugs or request features<\/li>\n<\/ul>\n<h4>Feedback Welcome<\/h4>\n<p>We&#8217;d love your feedback! We&#8217;re particularly interested in feedback on:<\/p>\n<ul>\n<li><strong>Migration experience<\/strong> &#8211; How smooth was the upgrade from v5 to v6?<\/li>\n<li><strong>Unified tool pattern<\/strong> &#8211; How does the new server-defined tool pattern work for you?<\/li>\n<li><strong>Dynamic tool approval<\/strong> &#8211; Does the <code>needsApproval<\/code> feature meet your needs?<\/li>\n<li><strong>AI Gateway integration<\/strong> &#8211; How well does the new provider work with your setup?<\/li>\n<\/ul>","protected":false},"excerpt":{"rendered":"<p>We&#8217;ve shipped a new release for the Agents SDK v0.3.0 bringing full compatibility with AI SDK v6 and introducing the unified tool pattern, dynamic tool approval, and enhanced React hooks with improved tool handling. This release includes improved streaming and tool support, dynamic tool approval (for &#8220;human in the loop&#8221; systems), enhanced React hooks with [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[1],"tags":[],"class_list":["post-100","post","type-post","status-publish","format-standard","hentry","category-uncategorized"],"_links":{"self":[{"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/posts\/100","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/comments?post=100"}],"version-history":[{"count":0,"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/posts\/100\/revisions"}],"wp:attachment":[{"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/media?parent=100"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/categories?post=100"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/wordpress.securinsight.ca\/index.php\/wp-json\/wp\/v2\/tags?post=100"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}