agents 0.0.0-041b40f

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (41) hide show
  1. package/README.md +428 -0
  2. package/dist/ai-chat-agent.d.ts +81 -0
  3. package/dist/ai-chat-agent.js +230 -0
  4. package/dist/ai-chat-agent.js.map +1 -0
  5. package/dist/ai-react.d.ts +100 -0
  6. package/dist/ai-react.js +203 -0
  7. package/dist/ai-react.js.map +1 -0
  8. package/dist/ai-types.d.ts +74 -0
  9. package/dist/ai-types.js +1 -0
  10. package/dist/ai-types.js.map +1 -0
  11. package/dist/chunk-BZXOAZUX.js +106 -0
  12. package/dist/chunk-BZXOAZUX.js.map +1 -0
  13. package/dist/chunk-J6T74FUS.js +783 -0
  14. package/dist/chunk-J6T74FUS.js.map +1 -0
  15. package/dist/chunk-QSGN3REV.js +123 -0
  16. package/dist/chunk-QSGN3REV.js.map +1 -0
  17. package/dist/chunk-Y67CHZBI.js +464 -0
  18. package/dist/chunk-Y67CHZBI.js.map +1 -0
  19. package/dist/client.d.ts +92 -0
  20. package/dist/client.js +11 -0
  21. package/dist/client.js.map +1 -0
  22. package/dist/index.d.ts +411 -0
  23. package/dist/index.js +22 -0
  24. package/dist/index.js.map +1 -0
  25. package/dist/mcp/client.d.ts +783 -0
  26. package/dist/mcp/client.js +9 -0
  27. package/dist/mcp/client.js.map +1 -0
  28. package/dist/mcp/do-oauth-client-provider.d.ts +41 -0
  29. package/dist/mcp/do-oauth-client-provider.js +7 -0
  30. package/dist/mcp/do-oauth-client-provider.js.map +1 -0
  31. package/dist/mcp/index.d.ts +84 -0
  32. package/dist/mcp/index.js +779 -0
  33. package/dist/mcp/index.js.map +1 -0
  34. package/dist/react.d.ts +111 -0
  35. package/dist/react.js +116 -0
  36. package/dist/react.js.map +1 -0
  37. package/dist/schedule.d.ts +53 -0
  38. package/dist/schedule.js +71 -0
  39. package/dist/schedule.js.map +1 -0
  40. package/package.json +102 -0
  41. package/src/index.ts +1250 -0
@@ -0,0 +1,230 @@
1
+ import {
2
+ Agent
3
+ } from "./chunk-J6T74FUS.js";
4
+ import "./chunk-BZXOAZUX.js";
5
+ import "./chunk-QSGN3REV.js";
6
+ import "./chunk-Y67CHZBI.js";
7
+
8
+ // src/ai-chat-agent.ts
9
+ import { appendResponseMessages } from "ai";
10
+ var decoder = new TextDecoder();
11
+ var AIChatAgent = class extends Agent {
12
+ constructor(ctx, env) {
13
+ super(ctx, env);
14
+ this.sql`create table if not exists cf_ai_chat_agent_messages (
15
+ id text primary key,
16
+ message text not null,
17
+ created_at datetime default current_timestamp
18
+ )`;
19
+ this.messages = (this.sql`select * from cf_ai_chat_agent_messages` || []).map((row) => {
20
+ return JSON.parse(row.message);
21
+ });
22
+ this._chatMessageAbortControllers = /* @__PURE__ */ new Map();
23
+ }
24
+ _broadcastChatMessage(message, exclude) {
25
+ this.broadcast(JSON.stringify(message), exclude);
26
+ }
27
+ async onMessage(connection, message) {
28
+ if (typeof message === "string") {
29
+ let data;
30
+ try {
31
+ data = JSON.parse(message);
32
+ } catch (error) {
33
+ return;
34
+ }
35
+ if (data.type === "cf_agent_use_chat_request" && data.init.method === "POST") {
36
+ const {
37
+ method,
38
+ keepalive,
39
+ headers,
40
+ body,
41
+ // we're reading this
42
+ redirect,
43
+ integrity,
44
+ credentials,
45
+ mode,
46
+ referrer,
47
+ referrerPolicy,
48
+ window
49
+ // dispatcher,
50
+ // duplex
51
+ } = data.init;
52
+ const { messages } = JSON.parse(body);
53
+ this._broadcastChatMessage(
54
+ {
55
+ type: "cf_agent_chat_messages",
56
+ messages
57
+ },
58
+ [connection.id]
59
+ );
60
+ await this.persistMessages(messages, [connection.id]);
61
+ const chatMessageId = data.id;
62
+ const abortSignal = this._getAbortSignal(chatMessageId);
63
+ return this._tryCatchChat(async () => {
64
+ const response = await this.onChatMessage(
65
+ async ({ response: response2 }) => {
66
+ const finalMessages = appendResponseMessages({
67
+ messages,
68
+ responseMessages: response2.messages
69
+ });
70
+ await this.persistMessages(finalMessages, [connection.id]);
71
+ this._removeAbortController(chatMessageId);
72
+ },
73
+ abortSignal ? { abortSignal } : void 0
74
+ );
75
+ if (response) {
76
+ await this._reply(data.id, response);
77
+ }
78
+ });
79
+ }
80
+ if (data.type === "cf_agent_chat_clear") {
81
+ this._destroyAbortControllers();
82
+ this.sql`delete from cf_ai_chat_agent_messages`;
83
+ this.messages = [];
84
+ this._broadcastChatMessage(
85
+ {
86
+ type: "cf_agent_chat_clear"
87
+ },
88
+ [connection.id]
89
+ );
90
+ } else if (data.type === "cf_agent_chat_messages") {
91
+ await this.persistMessages(data.messages, [connection.id]);
92
+ } else if (data.type === "cf_agent_chat_request_cancel") {
93
+ this._cancelChatRequest(data.id);
94
+ }
95
+ }
96
+ }
97
+ async onRequest(request) {
98
+ return this._tryCatchChat(() => {
99
+ const url = new URL(request.url);
100
+ if (url.pathname.endsWith("/get-messages")) {
101
+ const messages = (this.sql`select * from cf_ai_chat_agent_messages` || []).map((row) => {
102
+ return JSON.parse(row.message);
103
+ });
104
+ return Response.json(messages);
105
+ }
106
+ return super.onRequest(request);
107
+ });
108
+ }
109
+ async _tryCatchChat(fn) {
110
+ try {
111
+ return await fn();
112
+ } catch (e) {
113
+ throw this.onError(e);
114
+ }
115
+ }
116
+ /**
117
+ * Handle incoming chat messages and generate a response
118
+ * @param onFinish Callback to be called when the response is finished
119
+ * @param options.signal A signal to pass to any child requests which can be used to cancel them
120
+ * @returns Response to send to the client or undefined
121
+ */
122
+ async onChatMessage(onFinish, options) {
123
+ throw new Error(
124
+ "recieved a chat message, override onChatMessage and return a Response to send to the client"
125
+ );
126
+ }
127
+ /**
128
+ * Save messages on the server side and trigger AI response
129
+ * @param messages Chat messages to save
130
+ */
131
+ async saveMessages(messages) {
132
+ await this.persistMessages(messages);
133
+ const response = await this.onChatMessage(async ({ response: response2 }) => {
134
+ const finalMessages = appendResponseMessages({
135
+ messages,
136
+ responseMessages: response2.messages
137
+ });
138
+ await this.persistMessages(finalMessages, []);
139
+ });
140
+ if (response) {
141
+ for await (const chunk of response.body) {
142
+ decoder.decode(chunk);
143
+ }
144
+ response.body?.cancel();
145
+ }
146
+ }
147
+ async persistMessages(messages, excludeBroadcastIds = []) {
148
+ this.sql`delete from cf_ai_chat_agent_messages`;
149
+ for (const message of messages) {
150
+ this.sql`insert into cf_ai_chat_agent_messages (id, message) values (${message.id},${JSON.stringify(message)})`;
151
+ }
152
+ this.messages = messages;
153
+ this._broadcastChatMessage(
154
+ {
155
+ type: "cf_agent_chat_messages",
156
+ messages
157
+ },
158
+ excludeBroadcastIds
159
+ );
160
+ }
161
+ async _reply(id, response) {
162
+ return this._tryCatchChat(async () => {
163
+ for await (const chunk of response.body) {
164
+ const body = decoder.decode(chunk);
165
+ this._broadcastChatMessage({
166
+ id,
167
+ type: "cf_agent_use_chat_response",
168
+ body,
169
+ done: false
170
+ });
171
+ }
172
+ this._broadcastChatMessage({
173
+ id,
174
+ type: "cf_agent_use_chat_response",
175
+ body: "",
176
+ done: true
177
+ });
178
+ });
179
+ }
180
+ /**
181
+ * For the given message id, look up its associated AbortController
182
+ * If the AbortController does not exist, create and store one in memory
183
+ *
184
+ * returns the AbortSignal associated with the AbortController
185
+ */
186
+ _getAbortSignal(id) {
187
+ if (typeof id !== "string") {
188
+ return void 0;
189
+ }
190
+ if (!this._chatMessageAbortControllers.has(id)) {
191
+ this._chatMessageAbortControllers.set(id, new AbortController());
192
+ }
193
+ return this._chatMessageAbortControllers.get(id)?.signal;
194
+ }
195
+ /**
196
+ * Remove an abort controller from the cache of pending message responses
197
+ */
198
+ _removeAbortController(id) {
199
+ this._chatMessageAbortControllers.delete(id);
200
+ }
201
+ /**
202
+ * Propagate an abort signal for any requests associated with the given message id
203
+ */
204
+ _cancelChatRequest(id) {
205
+ if (this._chatMessageAbortControllers.has(id)) {
206
+ const abortController = this._chatMessageAbortControllers.get(id);
207
+ abortController?.abort();
208
+ }
209
+ }
210
+ /**
211
+ * Abort all pending requests and clear the cache of AbortControllers
212
+ */
213
+ _destroyAbortControllers() {
214
+ for (const controller of this._chatMessageAbortControllers.values()) {
215
+ controller?.abort();
216
+ }
217
+ this._chatMessageAbortControllers.clear();
218
+ }
219
+ /**
220
+ * When the DO is destroyed, cancel all pending requests
221
+ */
222
+ async destroy() {
223
+ this._destroyAbortControllers();
224
+ await super.destroy();
225
+ }
226
+ };
227
+ export {
228
+ AIChatAgent
229
+ };
230
+ //# sourceMappingURL=ai-chat-agent.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ai-chat-agent.ts"],"sourcesContent":["import { Agent, type AgentContext, type Connection, type WSMessage } from \"./\";\nimport type {\n Message as ChatMessage,\n StreamTextOnFinishCallback,\n ToolSet,\n} from \"ai\";\nimport { appendResponseMessages } from \"ai\";\nimport type { OutgoingMessage, IncomingMessage } from \"./ai-types\";\n\nconst decoder = new TextDecoder();\n\n/**\n * Extension of Agent with built-in chat capabilities\n * @template Env Environment type containing bindings\n */\nexport class AIChatAgent<Env = unknown, State = unknown> extends Agent<\n Env,\n State\n> {\n /**\n * Map of message `id`s to `AbortController`s\n * useful to propagate request cancellation signals for any external calls made by the agent\n */\n private _chatMessageAbortControllers: Map<string, AbortController>;\n /** Array of chat messages for the current conversation */\n messages: ChatMessage[];\n constructor(ctx: AgentContext, env: Env) {\n super(ctx, env);\n this.sql`create table if not exists cf_ai_chat_agent_messages (\n id text primary key,\n message text not null,\n created_at datetime default current_timestamp\n )`;\n this.messages = (\n this.sql`select * from cf_ai_chat_agent_messages` || []\n ).map((row) => {\n return JSON.parse(row.message as string);\n });\n\n this._chatMessageAbortControllers = new Map();\n }\n\n private _broadcastChatMessage(message: OutgoingMessage, exclude?: string[]) {\n this.broadcast(JSON.stringify(message), exclude);\n }\n\n override async onMessage(connection: Connection, message: WSMessage) {\n if (typeof message === \"string\") {\n let data: IncomingMessage;\n try {\n data = JSON.parse(message) as IncomingMessage;\n } catch (error) {\n // silently ignore invalid messages for now\n // TODO: log errors with log levels\n return;\n }\n if (\n data.type === \"cf_agent_use_chat_request\" &&\n data.init.method === \"POST\"\n ) {\n const {\n method,\n keepalive,\n headers,\n body, // we're reading this\n redirect,\n integrity,\n credentials,\n mode,\n referrer,\n referrerPolicy,\n window,\n // dispatcher,\n // duplex\n } = data.init;\n const { messages } = JSON.parse(body as string);\n this._broadcastChatMessage(\n {\n type: \"cf_agent_chat_messages\",\n messages,\n },\n [connection.id]\n );\n await this.persistMessages(messages, [connection.id]);\n\n const chatMessageId = data.id;\n const abortSignal = this._getAbortSignal(chatMessageId);\n\n return this._tryCatchChat(async () => {\n const response = await this.onChatMessage(\n async ({ response }) => {\n const finalMessages = appendResponseMessages({\n messages,\n responseMessages: response.messages,\n });\n\n await this.persistMessages(finalMessages, [connection.id]);\n this._removeAbortController(chatMessageId);\n },\n abortSignal ? { abortSignal } : undefined\n );\n\n if (response) {\n await this._reply(data.id, response);\n }\n });\n }\n if (data.type === \"cf_agent_chat_clear\") {\n this._destroyAbortControllers();\n this.sql`delete from cf_ai_chat_agent_messages`;\n this.messages = [];\n this._broadcastChatMessage(\n {\n type: \"cf_agent_chat_clear\",\n },\n [connection.id]\n );\n } else if (data.type === \"cf_agent_chat_messages\") {\n // replace the messages with the new ones\n await this.persistMessages(data.messages, [connection.id]);\n } else if (data.type === \"cf_agent_chat_request_cancel\") {\n // propagate an abort signal for the associated request\n this._cancelChatRequest(data.id);\n }\n }\n }\n\n override async onRequest(request: Request): Promise<Response> {\n return this._tryCatchChat(() => {\n const url = new URL(request.url);\n if (url.pathname.endsWith(\"/get-messages\")) {\n const messages = (\n this.sql`select * from cf_ai_chat_agent_messages` || []\n ).map((row) => {\n return JSON.parse(row.message as string);\n });\n return Response.json(messages);\n }\n return super.onRequest(request);\n });\n }\n\n private async _tryCatchChat<T>(fn: () => T | Promise<T>) {\n try {\n return await fn();\n } catch (e) {\n throw this.onError(e);\n }\n }\n\n /**\n * Handle incoming chat messages and generate a response\n * @param onFinish Callback to be called when the response is finished\n * @param options.signal A signal to pass to any child requests which can be used to cancel them\n * @returns Response to send to the client or undefined\n */\n async onChatMessage(\n onFinish: StreamTextOnFinishCallback<ToolSet>,\n options?: { abortSignal: AbortSignal | undefined }\n ): Promise<Response | undefined> {\n throw new Error(\n \"recieved a chat message, override onChatMessage and return a Response to send to the client\"\n );\n }\n\n /**\n * Save messages on the server side and trigger AI response\n * @param messages Chat messages to save\n */\n async saveMessages(messages: ChatMessage[]) {\n await this.persistMessages(messages);\n const response = await this.onChatMessage(async ({ response }) => {\n const finalMessages = appendResponseMessages({\n messages,\n responseMessages: response.messages,\n });\n\n await this.persistMessages(finalMessages, []);\n });\n if (response) {\n // we're just going to drain the body\n // @ts-ignore TODO: fix this type error\n for await (const chunk of response.body!) {\n decoder.decode(chunk);\n }\n response.body?.cancel();\n }\n }\n\n async persistMessages(\n messages: ChatMessage[],\n excludeBroadcastIds: string[] = []\n ) {\n this.sql`delete from cf_ai_chat_agent_messages`;\n for (const message of messages) {\n this.sql`insert into cf_ai_chat_agent_messages (id, message) values (${\n message.id\n },${JSON.stringify(message)})`;\n }\n this.messages = messages;\n this._broadcastChatMessage(\n {\n type: \"cf_agent_chat_messages\",\n messages: messages,\n },\n excludeBroadcastIds\n );\n }\n\n private async _reply(id: string, response: Response) {\n // now take chunks out from dataStreamResponse and send them to the client\n return this._tryCatchChat(async () => {\n // @ts-expect-error TODO: fix this type error\n for await (const chunk of response.body!) {\n const body = decoder.decode(chunk);\n\n this._broadcastChatMessage({\n id,\n type: \"cf_agent_use_chat_response\",\n body,\n done: false,\n });\n }\n\n this._broadcastChatMessage({\n id,\n type: \"cf_agent_use_chat_response\",\n body: \"\",\n done: true,\n });\n });\n }\n\n /**\n * For the given message id, look up its associated AbortController\n * If the AbortController does not exist, create and store one in memory\n *\n * returns the AbortSignal associated with the AbortController\n */\n private _getAbortSignal(id: string): AbortSignal | undefined {\n // Defensive check, since we're coercing message types at the moment\n if (typeof id !== \"string\") {\n return undefined;\n }\n\n if (!this._chatMessageAbortControllers.has(id)) {\n this._chatMessageAbortControllers.set(id, new AbortController());\n }\n\n return this._chatMessageAbortControllers.get(id)?.signal;\n }\n\n /**\n * Remove an abort controller from the cache of pending message responses\n */\n private _removeAbortController(id: string) {\n this._chatMessageAbortControllers.delete(id);\n }\n\n /**\n * Propagate an abort signal for any requests associated with the given message id\n */\n private _cancelChatRequest(id: string) {\n if (this._chatMessageAbortControllers.has(id)) {\n const abortController = this._chatMessageAbortControllers.get(id);\n abortController?.abort();\n }\n }\n\n /**\n * Abort all pending requests and clear the cache of AbortControllers\n */\n private _destroyAbortControllers() {\n for (const controller of this._chatMessageAbortControllers.values()) {\n controller?.abort();\n }\n this._chatMessageAbortControllers.clear();\n }\n\n /**\n * When the DO is destroyed, cancel all pending requests\n */\n async destroy() {\n this._destroyAbortControllers();\n await super.destroy();\n }\n}\n"],"mappings":"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","names":["response"]}
@@ -0,0 +1,100 @@
1
+ import * as ai from "ai";
2
+ import { Message } from "ai";
3
+ import { useChat } from "@ai-sdk/react";
4
+ import { useAgent } from "./react.js";
5
+ import "partysocket";
6
+ import "partysocket/react";
7
+ import "./index.js";
8
+ import "partyserver";
9
+ import "./mcp/client.js";
10
+ import "zod";
11
+ import "@modelcontextprotocol/sdk/types.js";
12
+ import "@modelcontextprotocol/sdk/client/index.js";
13
+ import "@modelcontextprotocol/sdk/client/sse.js";
14
+ import "./mcp/do-oauth-client-provider.js";
15
+ import "@modelcontextprotocol/sdk/client/auth.js";
16
+ import "@modelcontextprotocol/sdk/shared/auth.js";
17
+ import "@modelcontextprotocol/sdk/shared/protocol.js";
18
+ import "./client.js";
19
+
20
+ type GetInitialMessagesOptions = {
21
+ agent: string;
22
+ name: string;
23
+ url: string;
24
+ };
25
+ /**
26
+ * Options for the useAgentChat hook
27
+ */
28
+ type UseAgentChatOptions<State> = Omit<
29
+ Parameters<typeof useChat>[0] & {
30
+ /** Agent connection from useAgent */
31
+ agent: ReturnType<typeof useAgent<State>>;
32
+ getInitialMessages?:
33
+ | undefined
34
+ | null
35
+ | ((options: GetInitialMessagesOptions) => Promise<Message[]>);
36
+ },
37
+ "fetch"
38
+ >;
39
+ /**
40
+ * React hook for building AI chat interfaces using an Agent
41
+ * @param options Chat options including the agent connection
42
+ * @returns Chat interface controls and state with added clearHistory method
43
+ */
44
+ declare function useAgentChat<State = unknown>(
45
+ options: UseAgentChatOptions<State>
46
+ ): {
47
+ /**
48
+ * Set the chat messages and synchronize with the Agent
49
+ * @param messages New messages to set
50
+ */
51
+ setMessages: (messages: Message[]) => void;
52
+ /**
53
+ * Clear chat history on both client and Agent
54
+ */
55
+ clearHistory: () => void;
56
+ messages: ai.UIMessage[];
57
+ error: undefined | Error;
58
+ append: (
59
+ message: Message | ai.CreateMessage,
60
+ chatRequestOptions?: ai.ChatRequestOptions
61
+ ) => Promise<string | null | undefined>;
62
+ reload: (
63
+ chatRequestOptions?: ai.ChatRequestOptions
64
+ ) => Promise<string | null | undefined>;
65
+ stop: () => void;
66
+ experimental_resume: () => void;
67
+ input: string;
68
+ setInput: React.Dispatch<React.SetStateAction<string>>;
69
+ handleInputChange: (
70
+ e:
71
+ | React.ChangeEvent<HTMLInputElement>
72
+ | React.ChangeEvent<HTMLTextAreaElement>
73
+ ) => void;
74
+ handleSubmit: (
75
+ event?: {
76
+ preventDefault?: () => void;
77
+ },
78
+ chatRequestOptions?: ai.ChatRequestOptions
79
+ ) => void;
80
+ metadata?: Object;
81
+ isLoading: boolean;
82
+ status: "submitted" | "streaming" | "ready" | "error";
83
+ data?: ai.JSONValue[];
84
+ setData: (
85
+ data:
86
+ | ai.JSONValue[]
87
+ | undefined
88
+ | ((data: ai.JSONValue[] | undefined) => ai.JSONValue[] | undefined)
89
+ ) => void;
90
+ id: string;
91
+ addToolResult: ({
92
+ toolCallId,
93
+ result,
94
+ }: {
95
+ toolCallId: string;
96
+ result: any;
97
+ }) => void;
98
+ };
99
+
100
+ export { useAgentChat };
@@ -0,0 +1,203 @@
1
+ // src/ai-react.tsx
2
+ import { useChat } from "@ai-sdk/react";
3
+ import { use, useEffect } from "react";
4
+ import { nanoid } from "nanoid";
5
+ var requestCache = /* @__PURE__ */ new Map();
6
+ function useAgentChat(options) {
7
+ const { agent, getInitialMessages, ...rest } = options;
8
+ const agentUrl = new URL(
9
+ `${// @ts-expect-error we're using a protected _url property that includes query params
10
+ (agent._url || agent._pkurl)?.replace("ws://", "http://").replace("wss://", "https://")}`
11
+ );
12
+ agentUrl.searchParams.delete("_pk");
13
+ const agentUrlString = agentUrl.toString();
14
+ async function defaultGetInitialMessagesFetch({
15
+ url
16
+ }) {
17
+ const getMessagesUrl = new URL(url);
18
+ getMessagesUrl.pathname += "/get-messages";
19
+ const response = await fetch(getMessagesUrl.toString(), {
20
+ headers: options.headers,
21
+ credentials: options.credentials
22
+ });
23
+ return response.json();
24
+ }
25
+ const getInitialMessagesFetch = getInitialMessages || defaultGetInitialMessagesFetch;
26
+ function doGetInitialMessages(getInitialMessagesOptions) {
27
+ if (requestCache.has(agentUrlString)) {
28
+ return requestCache.get(agentUrlString);
29
+ }
30
+ const promise = getInitialMessagesFetch(getInitialMessagesOptions);
31
+ requestCache.set(agentUrlString, promise);
32
+ return promise;
33
+ }
34
+ const initialMessagesPromise = getInitialMessages === null ? null : doGetInitialMessages({
35
+ agent: agent.agent,
36
+ name: agent.name,
37
+ url: agentUrlString
38
+ });
39
+ const initialMessages = initialMessagesPromise ? use(initialMessagesPromise) : rest.initialMessages ?? [];
40
+ useEffect(() => {
41
+ if (!initialMessagesPromise) {
42
+ return;
43
+ }
44
+ requestCache.set(agentUrlString, initialMessagesPromise);
45
+ return () => {
46
+ if (requestCache.get(agentUrlString) === initialMessagesPromise) {
47
+ requestCache.delete(agentUrlString);
48
+ }
49
+ };
50
+ }, [agentUrlString, initialMessagesPromise]);
51
+ async function aiFetch(request, options2 = {}) {
52
+ const {
53
+ method,
54
+ keepalive,
55
+ headers,
56
+ body,
57
+ redirect,
58
+ integrity,
59
+ signal,
60
+ credentials,
61
+ mode,
62
+ referrer,
63
+ referrerPolicy,
64
+ window
65
+ // dispatcher, duplex
66
+ } = options2;
67
+ const id = nanoid(8);
68
+ const abortController = new AbortController();
69
+ signal?.addEventListener("abort", () => {
70
+ agent.send(
71
+ JSON.stringify({
72
+ type: "cf_agent_chat_request_cancel",
73
+ id
74
+ })
75
+ );
76
+ abortController.abort();
77
+ controller.close();
78
+ });
79
+ agent.addEventListener(
80
+ "message",
81
+ (event) => {
82
+ let data;
83
+ try {
84
+ data = JSON.parse(event.data);
85
+ } catch (error) {
86
+ return;
87
+ }
88
+ if (data.type === "cf_agent_use_chat_response") {
89
+ if (data.id === id) {
90
+ controller.enqueue(new TextEncoder().encode(data.body));
91
+ if (data.done) {
92
+ controller.close();
93
+ abortController.abort();
94
+ }
95
+ }
96
+ }
97
+ },
98
+ { signal: abortController.signal }
99
+ );
100
+ let controller;
101
+ const stream = new ReadableStream({
102
+ start(c) {
103
+ controller = c;
104
+ }
105
+ });
106
+ agent.send(
107
+ JSON.stringify({
108
+ type: "cf_agent_use_chat_request",
109
+ id,
110
+ url: request.toString(),
111
+ init: {
112
+ method,
113
+ keepalive,
114
+ headers,
115
+ body,
116
+ redirect,
117
+ integrity,
118
+ credentials,
119
+ mode,
120
+ referrer,
121
+ referrerPolicy,
122
+ window
123
+ // dispatcher,
124
+ // duplex
125
+ }
126
+ })
127
+ );
128
+ return new Response(stream);
129
+ }
130
+ const useChatHelpers = useChat({
131
+ initialMessages,
132
+ sendExtraMessageFields: true,
133
+ fetch: aiFetch,
134
+ ...rest
135
+ });
136
+ useEffect(() => {
137
+ function onClearHistory(event) {
138
+ if (typeof event.data !== "string") {
139
+ return;
140
+ }
141
+ let data;
142
+ try {
143
+ data = JSON.parse(event.data);
144
+ } catch (error) {
145
+ return;
146
+ }
147
+ if (data.type === "cf_agent_chat_clear") {
148
+ useChatHelpers.setMessages([]);
149
+ }
150
+ }
151
+ function onMessages(event) {
152
+ if (typeof event.data !== "string") {
153
+ return;
154
+ }
155
+ let data;
156
+ try {
157
+ data = JSON.parse(event.data);
158
+ } catch (error) {
159
+ return;
160
+ }
161
+ if (data.type === "cf_agent_chat_messages") {
162
+ useChatHelpers.setMessages(data.messages);
163
+ }
164
+ }
165
+ agent.addEventListener("message", onClearHistory);
166
+ agent.addEventListener("message", onMessages);
167
+ return () => {
168
+ agent.removeEventListener("message", onClearHistory);
169
+ agent.removeEventListener("message", onMessages);
170
+ };
171
+ }, [agent, useChatHelpers.setMessages]);
172
+ return {
173
+ ...useChatHelpers,
174
+ /**
175
+ * Set the chat messages and synchronize with the Agent
176
+ * @param messages New messages to set
177
+ */
178
+ setMessages: (messages) => {
179
+ useChatHelpers.setMessages(messages);
180
+ agent.send(
181
+ JSON.stringify({
182
+ type: "cf_agent_chat_messages",
183
+ messages
184
+ })
185
+ );
186
+ },
187
+ /**
188
+ * Clear chat history on both client and Agent
189
+ */
190
+ clearHistory: () => {
191
+ useChatHelpers.setMessages([]);
192
+ agent.send(
193
+ JSON.stringify({
194
+ type: "cf_agent_chat_clear"
195
+ })
196
+ );
197
+ }
198
+ };
199
+ }
200
+ export {
201
+ useAgentChat
202
+ };
203
+ //# sourceMappingURL=ai-react.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["../src/ai-react.tsx"],"sourcesContent":["import { useChat } from \"@ai-sdk/react\";\nimport type { Message } from \"ai\";\nimport { use, useEffect } from \"react\";\nimport type { OutgoingMessage } from \"./ai-types\";\nimport type { useAgent } from \"./react\";\nimport { nanoid } from \"nanoid\";\n\ntype GetInitialMessagesOptions = {\n agent: string;\n name: string;\n url: string;\n};\n\n/**\n * Options for the useAgentChat hook\n */\ntype UseAgentChatOptions<State> = Omit<\n Parameters<typeof useChat>[0] & {\n /** Agent connection from useAgent */\n agent: ReturnType<typeof useAgent<State>>;\n getInitialMessages?:\n | undefined\n | null\n // | (() => Message[])\n | ((options: GetInitialMessagesOptions) => Promise<Message[]>);\n },\n \"fetch\"\n>;\n\nconst requestCache = new Map<string, Promise<Message[]>>();\n\n/**\n * React hook for building AI chat interfaces using an Agent\n * @param options Chat options including the agent connection\n * @returns Chat interface controls and state with added clearHistory method\n */\nexport function useAgentChat<State = unknown>(\n options: UseAgentChatOptions<State>\n) {\n const { agent, getInitialMessages, ...rest } = options;\n\n const agentUrl = new URL(\n `${// @ts-expect-error we're using a protected _url property that includes query params\n ((agent._url as string | null) || agent._pkurl)\n ?.replace(\"ws://\", \"http://\")\n .replace(\"wss://\", \"https://\")}`\n );\n\n // delete the _pk query param\n agentUrl.searchParams.delete(\"_pk\");\n const agentUrlString = agentUrl.toString();\n\n async function defaultGetInitialMessagesFetch({\n url,\n }: GetInitialMessagesOptions) {\n const getMessagesUrl = new URL(url);\n getMessagesUrl.pathname += \"/get-messages\";\n const response = await fetch(getMessagesUrl.toString(), {\n headers: options.headers,\n credentials: options.credentials,\n });\n return response.json<Message[]>();\n }\n\n const getInitialMessagesFetch =\n getInitialMessages || defaultGetInitialMessagesFetch;\n\n function doGetInitialMessages(\n getInitialMessagesOptions: GetInitialMessagesOptions\n ) {\n if (requestCache.has(agentUrlString)) {\n return requestCache.get(agentUrlString)!;\n }\n const promise = getInitialMessagesFetch(getInitialMessagesOptions);\n // immediately cache the promise so that we don't\n // create multiple requests for the same agent during multiple\n // concurrent renders\n requestCache.set(agentUrlString, promise);\n return promise;\n }\n\n const initialMessagesPromise =\n getInitialMessages === null\n ? null\n : doGetInitialMessages({\n agent: agent.agent,\n name: agent.name,\n url: agentUrlString,\n });\n const initialMessages = initialMessagesPromise\n ? use(initialMessagesPromise)\n : (rest.initialMessages ?? []);\n\n // manages adding and removing the promise from the cache\n useEffect(() => {\n if (!initialMessagesPromise) {\n return;\n }\n // this effect is responsible for removing the promise from the cache\n // when the component unmounts or the promise changes,\n // but that means it also must add the promise to the cache\n // so that multiple arbitrary effect runs produce the expected state\n // when resolved.\n requestCache.set(agentUrlString, initialMessagesPromise!);\n return () => {\n if (requestCache.get(agentUrlString) === initialMessagesPromise) {\n requestCache.delete(agentUrlString);\n }\n };\n }, [agentUrlString, initialMessagesPromise]);\n\n async function aiFetch(\n request: RequestInfo | URL,\n options: RequestInit = {}\n ) {\n // we're going to use a websocket to do the actual \"fetching\"\n // but still satisfy the type signature of the fetch function\n // so we'll return a promise that resolves to a response\n\n const {\n method,\n keepalive,\n headers,\n body,\n redirect,\n integrity,\n signal,\n credentials,\n mode,\n referrer,\n referrerPolicy,\n window,\n // dispatcher, duplex\n } = options;\n const id = nanoid(8);\n const abortController = new AbortController();\n\n signal?.addEventListener(\"abort\", () => {\n // Propagate request cancellation to the Agent\n // We need to communciate cancellation as a websocket message, instead of a request signal\n agent.send(\n JSON.stringify({\n type: \"cf_agent_chat_request_cancel\",\n id,\n })\n );\n\n // NOTE - If we wanted to, we could preserve the \"interrupted\" message here, with the code below\n // However, I think it might be the responsibility of the library user to implement that behavior manually?\n // Reasoning: This code could be subject to collisions, as it \"force saves\" the messages we have locally\n //\n // agent.send(JSON.stringify({\n // type: \"cf_agent_chat_messages\",\n // messages: ... /* some way of getting current messages ref? */\n // }))\n\n abortController.abort();\n // Make sure to also close the stream (cf. https://github.com/cloudflare/agents-starter/issues/69)\n controller.close();\n });\n\n agent.addEventListener(\n \"message\",\n (event) => {\n let data: OutgoingMessage;\n try {\n data = JSON.parse(event.data) as OutgoingMessage;\n } catch (error) {\n // silently ignore invalid messages for now\n // TODO: log errors with log levels\n return;\n }\n if (data.type === \"cf_agent_use_chat_response\") {\n if (data.id === id) {\n controller.enqueue(new TextEncoder().encode(data.body));\n if (data.done) {\n controller.close();\n abortController.abort();\n }\n }\n }\n },\n { signal: abortController.signal }\n );\n\n let controller: ReadableStreamDefaultController;\n\n const stream = new ReadableStream({\n start(c) {\n controller = c;\n },\n });\n\n agent.send(\n JSON.stringify({\n type: \"cf_agent_use_chat_request\",\n id,\n url: request.toString(),\n init: {\n method,\n keepalive,\n headers,\n body,\n redirect,\n integrity,\n credentials,\n mode,\n referrer,\n referrerPolicy,\n window,\n // dispatcher,\n // duplex\n },\n })\n );\n\n return new Response(stream);\n }\n const useChatHelpers = useChat({\n initialMessages,\n sendExtraMessageFields: true,\n fetch: aiFetch,\n ...rest,\n });\n\n useEffect(() => {\n function onClearHistory(event: MessageEvent) {\n if (typeof event.data !== \"string\") {\n return;\n }\n let data: OutgoingMessage;\n try {\n data = JSON.parse(event.data) as OutgoingMessage;\n } catch (error) {\n // silently ignore invalid messages for now\n // TODO: log errors with log levels\n return;\n }\n if (data.type === \"cf_agent_chat_clear\") {\n useChatHelpers.setMessages([]);\n }\n }\n\n function onMessages(event: MessageEvent) {\n if (typeof event.data !== \"string\") {\n return;\n }\n let data: OutgoingMessage;\n try {\n data = JSON.parse(event.data) as OutgoingMessage;\n } catch (error) {\n // silently ignore invalid messages for now\n // TODO: log errors with log levels\n return;\n }\n if (data.type === \"cf_agent_chat_messages\") {\n useChatHelpers.setMessages(data.messages);\n }\n }\n\n agent.addEventListener(\"message\", onClearHistory);\n agent.addEventListener(\"message\", onMessages);\n\n return () => {\n agent.removeEventListener(\"message\", onClearHistory);\n agent.removeEventListener(\"message\", onMessages);\n };\n }, [agent, useChatHelpers.setMessages]);\n\n return {\n ...useChatHelpers,\n /**\n * Set the chat messages and synchronize with the Agent\n * @param messages New messages to set\n */\n setMessages: (messages: Message[]) => {\n useChatHelpers.setMessages(messages);\n agent.send(\n JSON.stringify({\n type: \"cf_agent_chat_messages\",\n messages,\n })\n );\n },\n /**\n * Clear chat history on both client and Agent\n */\n clearHistory: () => {\n useChatHelpers.setMessages([]);\n agent.send(\n JSON.stringify({\n type: \"cf_agent_chat_clear\",\n })\n );\n },\n };\n}\n"],"mappings":"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","names":["options"]}
@@ -0,0 +1,74 @@
1
+ import { Message } from "ai";
2
+
3
+ /**
4
+ * Types of messages sent from the Agent to clients
5
+ */
6
+ type OutgoingMessage =
7
+ | {
8
+ /** Indicates this message contains updated chat messages */
9
+ type: "cf_agent_chat_messages";
10
+ /** Array of chat messages */
11
+ messages: Message[];
12
+ }
13
+ | {
14
+ /** Indicates this message is a response to a chat request */
15
+ type: "cf_agent_use_chat_response";
16
+ /** Unique ID of the request this response corresponds to */
17
+ id: string;
18
+ /** Content body of the response */
19
+ body: string;
20
+ /** Whether this is the final chunk of the response */
21
+ done: boolean;
22
+ }
23
+ | {
24
+ /** Indicates this message contains updated chat messages */
25
+ type: "cf_agent_chat_messages";
26
+ /** Array of chat messages */
27
+ messages: Message[];
28
+ }
29
+ | {
30
+ /** Indicates this message is a command to clear chat history */
31
+ type: "cf_agent_chat_clear";
32
+ };
33
+ /**
34
+ * Types of messages sent from clients to the Agent
35
+ */
36
+ type IncomingMessage =
37
+ | {
38
+ /** Indicates this message is a request to the chat API */
39
+ type: "cf_agent_use_chat_request";
40
+ /** Unique ID for this request */
41
+ id: string;
42
+ /** Request initialization options */
43
+ init: Pick<
44
+ RequestInit,
45
+ | "method"
46
+ | "keepalive"
47
+ | "headers"
48
+ | "body"
49
+ | "redirect"
50
+ | "integrity"
51
+ | "credentials"
52
+ | "mode"
53
+ | "referrer"
54
+ | "referrerPolicy"
55
+ | "window"
56
+ >;
57
+ }
58
+ | {
59
+ /** Indicates this message is a command to clear chat history */
60
+ type: "cf_agent_chat_clear";
61
+ }
62
+ | {
63
+ /** Indicates this message contains updated chat messages */
64
+ type: "cf_agent_chat_messages";
65
+ /** Array of chat messages */
66
+ messages: Message[];
67
+ }
68
+ | {
69
+ /** Indicates the user wants to stop generation of this message */
70
+ type: "cf_agent_chat_request_cancel";
71
+ id: string;
72
+ };
73
+
74
+ export type { IncomingMessage, OutgoingMessage };
@@ -0,0 +1 @@
1
+ //# sourceMappingURL=ai-types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"sources":[],"sourcesContent":[],"mappings":"","names":[]}