@assistant-ui/react 0.8.20 → 0.9.1
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.
- package/dist/api/ThreadRuntime.d.ts.map +1 -1
- package/dist/api/ThreadRuntime.js +3 -1
- package/dist/api/ThreadRuntime.js.map +1 -1
- package/dist/api/ThreadRuntime.mjs +3 -1
- package/dist/api/ThreadRuntime.mjs.map +1 -1
- package/dist/cloud/AssistantCloudRuns.d.ts +2 -2
- package/dist/cloud/AssistantCloudRuns.d.ts.map +1 -1
- package/dist/cloud/AssistantCloudRuns.js.map +1 -1
- package/dist/cloud/AssistantCloudRuns.mjs.map +1 -1
- package/dist/cloud/auiV0.d.ts +1 -2
- package/dist/cloud/auiV0.d.ts.map +1 -1
- package/dist/cloud/auiV0.js.map +1 -1
- package/dist/cloud/auiV0.mjs.map +1 -1
- package/dist/context/react/AttachmentContext.d.ts +108 -108
- package/dist/index.d.ts +0 -1
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +1 -4
- package/dist/index.js.map +1 -1
- package/dist/index.mjs +1 -3
- package/dist/index.mjs.map +1 -1
- package/dist/internal.d.ts +1 -1
- package/dist/internal.d.ts.map +1 -1
- package/dist/internal.js +4 -4
- package/dist/internal.js.map +1 -1
- package/dist/internal.mjs +3 -3
- package/dist/internal.mjs.map +1 -1
- package/dist/primitives/assistantModal/AssistantModalRoot.d.ts.map +1 -1
- package/dist/primitives/assistantModal/AssistantModalRoot.js +5 -2
- package/dist/primitives/assistantModal/AssistantModalRoot.js.map +1 -1
- package/dist/primitives/assistantModal/AssistantModalRoot.mjs +5 -2
- package/dist/primitives/assistantModal/AssistantModalRoot.mjs.map +1 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.d.ts +1 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.d.ts.map +1 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.js +3 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.js.map +1 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.mjs +3 -1
- package/dist/runtimes/composer/BaseComposerRuntimeCore.mjs.map +1 -1
- package/dist/runtimes/external-store/ThreadMessageLike.d.ts.map +1 -1
- package/dist/runtimes/external-store/ThreadMessageLike.js +2 -2
- package/dist/runtimes/external-store/ThreadMessageLike.js.map +1 -1
- package/dist/runtimes/external-store/ThreadMessageLike.mjs +1 -1
- package/dist/runtimes/external-store/ThreadMessageLike.mjs.map +1 -1
- package/dist/runtimes/index.d.ts +1 -2
- package/dist/runtimes/index.d.ts.map +1 -1
- package/dist/runtimes/index.js +6 -5
- package/dist/runtimes/index.js.map +1 -1
- package/dist/runtimes/index.mjs +7 -3
- package/dist/runtimes/index.mjs.map +1 -1
- package/dist/runtimes/local/LocalThreadRuntimeCore.d.ts.map +1 -1
- package/dist/runtimes/local/LocalThreadRuntimeCore.js +3 -3
- package/dist/runtimes/local/LocalThreadRuntimeCore.js.map +1 -1
- package/dist/runtimes/local/LocalThreadRuntimeCore.mjs +4 -4
- package/dist/runtimes/local/LocalThreadRuntimeCore.mjs.map +1 -1
- package/dist/runtimes/remote-thread-list/adapter/cloud.d.ts.map +1 -1
- package/dist/runtimes/remote-thread-list/adapter/cloud.js +2 -2
- package/dist/runtimes/remote-thread-list/adapter/cloud.js.map +1 -1
- package/dist/runtimes/remote-thread-list/adapter/cloud.mjs +2 -2
- package/dist/runtimes/remote-thread-list/adapter/cloud.mjs.map +1 -1
- package/dist/runtimes/{edge/streams → streams}/toolResultStream.d.ts +1 -1
- package/dist/runtimes/streams/toolResultStream.d.ts.map +1 -0
- package/dist/runtimes/{edge/streams → streams}/toolResultStream.js +1 -1
- package/dist/runtimes/streams/toolResultStream.js.map +1 -0
- package/dist/runtimes/{edge/streams → streams}/toolResultStream.mjs +1 -1
- package/dist/runtimes/streams/toolResultStream.mjs.map +1 -0
- package/dist/runtimes/utils/MessageRepository.d.ts +2 -2
- package/dist/runtimes/utils/MessageRepository.d.ts.map +1 -1
- package/dist/runtimes/utils/MessageRepository.js +1 -5
- package/dist/runtimes/utils/MessageRepository.js.map +1 -1
- package/dist/runtimes/utils/MessageRepository.mjs +1 -5
- package/dist/runtimes/utils/MessageRepository.mjs.map +1 -1
- package/dist/types/AssistantTypes.d.ts +3 -60
- package/dist/types/AssistantTypes.d.ts.map +1 -1
- package/dist/types/AssistantTypes.js.map +1 -1
- package/dist/types/AttachmentTypes.d.ts +3 -3
- package/dist/types/AttachmentTypes.d.ts.map +1 -1
- package/dist/types/AttachmentTypes.js.map +1 -1
- package/dist/types/index.d.ts +1 -1
- package/dist/types/index.d.ts.map +1 -1
- package/dist/types/index.js.map +1 -1
- package/package.json +11 -17
- package/src/api/ThreadRuntime.ts +2 -0
- package/src/cloud/AssistantCloudRuns.tsx +2 -2
- package/src/cloud/auiV0.ts +1 -2
- package/src/index.ts +0 -2
- package/src/internal.ts +1 -1
- package/src/primitives/assistantModal/AssistantModalRoot.tsx +6 -2
- package/src/runtimes/composer/BaseComposerRuntimeCore.tsx +2 -0
- package/src/runtimes/external-store/ThreadMessageLike.tsx +1 -1
- package/src/runtimes/index.ts +4 -2
- package/src/runtimes/local/LocalThreadRuntimeCore.tsx +4 -4
- package/src/runtimes/remote-thread-list/adapter/cloud.tsx +1 -2
- package/src/runtimes/{edge/streams → streams}/toolResultStream.ts +1 -1
- package/src/runtimes/utils/MessageRepository.tsx +3 -7
- package/src/tests/MessageRepository.test.ts +7 -10
- package/src/types/AssistantTypes.ts +3 -81
- package/src/types/AttachmentTypes.ts +3 -3
- package/src/types/index.ts +0 -9
- package/dist/edge.d.ts +0 -2
- package/dist/edge.d.ts.map +0 -1
- package/dist/edge.js +0 -33
- package/dist/edge.js.map +0 -1
- package/dist/edge.mjs +0 -10
- package/dist/edge.mjs.map +0 -1
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.d.ts +0 -9
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.d.ts.map +0 -1
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.js +0 -58
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.js.map +0 -1
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.mjs +0 -35
- package/dist/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.mjs.map +0 -1
- package/dist/runtimes/dangerous-in-browser/index.d.ts +0 -2
- package/dist/runtimes/dangerous-in-browser/index.d.ts.map +0 -1
- package/dist/runtimes/dangerous-in-browser/index.js +0 -31
- package/dist/runtimes/dangerous-in-browser/index.js.map +0 -1
- package/dist/runtimes/dangerous-in-browser/index.mjs +0 -8
- package/dist/runtimes/dangerous-in-browser/index.mjs.map +0 -1
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.d.ts +0 -5
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.d.ts.map +0 -1
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.js +0 -40
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.js.map +0 -1
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.mjs +0 -18
- package/dist/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.mjs.map +0 -1
- package/dist/runtimes/edge/EdgeModelAdapter.d.ts +0 -48
- package/dist/runtimes/edge/EdgeModelAdapter.d.ts.map +0 -1
- package/dist/runtimes/edge/EdgeModelAdapter.js +0 -127
- package/dist/runtimes/edge/EdgeModelAdapter.js.map +0 -1
- package/dist/runtimes/edge/EdgeModelAdapter.mjs +0 -94
- package/dist/runtimes/edge/EdgeModelAdapter.mjs.map +0 -1
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.d.ts +0 -345
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.d.ts.map +0 -1
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.js +0 -106
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.js.map +0 -1
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.mjs +0 -84
- package/dist/runtimes/edge/EdgeRuntimeRequestOptions.mjs.map +0 -1
- package/dist/runtimes/edge/converters/fromCoreMessage.d.ts +0 -8
- package/dist/runtimes/edge/converters/fromCoreMessage.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/fromCoreMessage.js +0 -89
- package/dist/runtimes/edge/converters/fromCoreMessage.js.map +0 -1
- package/dist/runtimes/edge/converters/fromCoreMessage.mjs +0 -63
- package/dist/runtimes/edge/converters/fromCoreMessage.mjs.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.d.ts +0 -8
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.js +0 -149
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.js.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.mjs +0 -124
- package/dist/runtimes/edge/converters/fromLanguageModelMessages.mjs.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelTools.d.ts +0 -4
- package/dist/runtimes/edge/converters/fromLanguageModelTools.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelTools.js +0 -41
- package/dist/runtimes/edge/converters/fromLanguageModelTools.js.map +0 -1
- package/dist/runtimes/edge/converters/fromLanguageModelTools.mjs +0 -16
- package/dist/runtimes/edge/converters/fromLanguageModelTools.mjs.map +0 -1
- package/dist/runtimes/edge/converters/index.d.ts +0 -35
- package/dist/runtimes/edge/converters/index.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/index.js +0 -50
- package/dist/runtimes/edge/converters/index.js.map +0 -1
- package/dist/runtimes/edge/converters/index.mjs +0 -24
- package/dist/runtimes/edge/converters/index.mjs.map +0 -1
- package/dist/runtimes/edge/converters/toCoreMessages.d.ts +0 -12
- package/dist/runtimes/edge/converters/toCoreMessages.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/toCoreMessages.js +0 -74
- package/dist/runtimes/edge/converters/toCoreMessages.js.map +0 -1
- package/dist/runtimes/edge/converters/toCoreMessages.mjs +0 -48
- package/dist/runtimes/edge/converters/toCoreMessages.mjs.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelMessages.d.ts +0 -6
- package/dist/runtimes/edge/converters/toLanguageModelMessages.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelMessages.js +0 -168
- package/dist/runtimes/edge/converters/toLanguageModelMessages.js.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelMessages.mjs +0 -143
- package/dist/runtimes/edge/converters/toLanguageModelMessages.mjs.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelTools.d.ts +0 -4
- package/dist/runtimes/edge/converters/toLanguageModelTools.d.ts.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelTools.js +0 -50
- package/dist/runtimes/edge/converters/toLanguageModelTools.js.map +0 -1
- package/dist/runtimes/edge/converters/toLanguageModelTools.mjs +0 -15
- package/dist/runtimes/edge/converters/toLanguageModelTools.mjs.map +0 -1
- package/dist/runtimes/edge/createEdgeRuntimeAPI.d.ts +0 -36
- package/dist/runtimes/edge/createEdgeRuntimeAPI.d.ts.map +0 -1
- package/dist/runtimes/edge/createEdgeRuntimeAPI.js +0 -179
- package/dist/runtimes/edge/createEdgeRuntimeAPI.js.map +0 -1
- package/dist/runtimes/edge/createEdgeRuntimeAPI.mjs +0 -156
- package/dist/runtimes/edge/createEdgeRuntimeAPI.mjs.map +0 -1
- package/dist/runtimes/edge/index.d.ts +0 -6
- package/dist/runtimes/edge/index.d.ts.map +0 -1
- package/dist/runtimes/edge/index.js +0 -40
- package/dist/runtimes/edge/index.js.map +0 -1
- package/dist/runtimes/edge/index.mjs +0 -11
- package/dist/runtimes/edge/index.mjs.map +0 -1
- package/dist/runtimes/edge/streams/toolResultStream.d.ts.map +0 -1
- package/dist/runtimes/edge/streams/toolResultStream.js.map +0 -1
- package/dist/runtimes/edge/streams/toolResultStream.mjs.map +0 -1
- package/dist/runtimes/edge/useEdgeRuntime.d.ts +0 -5
- package/dist/runtimes/edge/useEdgeRuntime.d.ts.map +0 -1
- package/dist/runtimes/edge/useEdgeRuntime.js +0 -41
- package/dist/runtimes/edge/useEdgeRuntime.js.map +0 -1
- package/dist/runtimes/edge/useEdgeRuntime.mjs +0 -17
- package/dist/runtimes/edge/useEdgeRuntime.mjs.map +0 -1
- package/dist/utils/json/parse-partial-json.d.ts +0 -4
- package/dist/utils/json/parse-partial-json.d.ts.map +0 -1
- package/dist/utils/json/parse-partial-json.js +0 -90
- package/dist/utils/json/parse-partial-json.js.map +0 -1
- package/dist/utils/json/parse-partial-json.mjs +0 -54
- package/dist/utils/json/parse-partial-json.mjs.map +0 -1
- package/edge/README.md +0 -1
- package/edge/package.json +0 -5
- package/src/edge.ts +0 -4
- package/src/runtimes/dangerous-in-browser/DangerousInBrowserAdapter.ts +0 -42
- package/src/runtimes/dangerous-in-browser/index.ts +0 -4
- package/src/runtimes/dangerous-in-browser/useDangerousInBrowserRuntime.ts +0 -21
- package/src/runtimes/edge/EdgeModelAdapter.ts +0 -188
- package/src/runtimes/edge/EdgeRuntimeRequestOptions.ts +0 -109
- package/src/runtimes/edge/converters/fromCoreMessage.ts +0 -76
- package/src/runtimes/edge/converters/fromLanguageModelMessages.ts +0 -149
- package/src/runtimes/edge/converters/fromLanguageModelTools.ts +0 -16
- package/src/runtimes/edge/converters/index.ts +0 -41
- package/src/runtimes/edge/converters/toCoreMessages.ts +0 -64
- package/src/runtimes/edge/converters/toLanguageModelMessages.ts +0 -184
- package/src/runtimes/edge/converters/toLanguageModelTools.ts +0 -18
- package/src/runtimes/edge/createEdgeRuntimeAPI.ts +0 -234
- package/src/runtimes/edge/index.ts +0 -7
- package/src/runtimes/edge/useEdgeRuntime.ts +0 -17
- package/src/utils/json/parse-partial-json.ts +0 -74
@@ -1,168 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __defProp = Object.defineProperty;
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
6
|
-
var __export = (target, all) => {
|
7
|
-
for (var name in all)
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
9
|
-
};
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
12
|
-
for (let key of __getOwnPropNames(from))
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
15
|
-
}
|
16
|
-
return to;
|
17
|
-
};
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
19
|
-
|
20
|
-
// src/runtimes/edge/converters/toLanguageModelMessages.ts
|
21
|
-
var toLanguageModelMessages_exports = {};
|
22
|
-
__export(toLanguageModelMessages_exports, {
|
23
|
-
toLanguageModelMessages: () => toLanguageModelMessages
|
24
|
-
});
|
25
|
-
module.exports = __toCommonJS(toLanguageModelMessages_exports);
|
26
|
-
var assistantMessageSplitter = () => {
|
27
|
-
const stash = [];
|
28
|
-
let assistantMessage = {
|
29
|
-
role: "assistant",
|
30
|
-
content: []
|
31
|
-
};
|
32
|
-
let toolMessage = {
|
33
|
-
role: "tool",
|
34
|
-
content: []
|
35
|
-
};
|
36
|
-
return {
|
37
|
-
addTextContentPart: (part) => {
|
38
|
-
if (toolMessage.content.length > 0) {
|
39
|
-
stash.push(assistantMessage);
|
40
|
-
stash.push(toolMessage);
|
41
|
-
assistantMessage = {
|
42
|
-
role: "assistant",
|
43
|
-
content: []
|
44
|
-
};
|
45
|
-
toolMessage = {
|
46
|
-
role: "tool",
|
47
|
-
content: []
|
48
|
-
};
|
49
|
-
}
|
50
|
-
assistantMessage.content.push(part);
|
51
|
-
},
|
52
|
-
addToolCallPart: (part) => {
|
53
|
-
assistantMessage.content.push({
|
54
|
-
type: "tool-call",
|
55
|
-
toolCallId: part.toolCallId,
|
56
|
-
toolName: part.toolName,
|
57
|
-
args: part.args
|
58
|
-
});
|
59
|
-
toolMessage.content.push({
|
60
|
-
type: "tool-result",
|
61
|
-
toolCallId: part.toolCallId,
|
62
|
-
toolName: part.toolName,
|
63
|
-
..."artifact" in part ? { artifact: part.artifact } : {},
|
64
|
-
result: part.result === void 0 ? "Error: tool is has no configured code to run" : part.result,
|
65
|
-
isError: part.isError ?? part.result === void 0
|
66
|
-
});
|
67
|
-
},
|
68
|
-
getMessages: () => {
|
69
|
-
if (toolMessage.content.length > 0) {
|
70
|
-
return [...stash, assistantMessage, toolMessage];
|
71
|
-
}
|
72
|
-
return [...stash, assistantMessage];
|
73
|
-
}
|
74
|
-
};
|
75
|
-
};
|
76
|
-
function toLanguageModelMessages(message, options = {}) {
|
77
|
-
const includeId = options.unstable_includeId ?? false;
|
78
|
-
return message.flatMap((message2) => {
|
79
|
-
const role = message2.role;
|
80
|
-
switch (role) {
|
81
|
-
case "system": {
|
82
|
-
return [
|
83
|
-
{
|
84
|
-
...includeId ? { unstable_id: message2.id } : {},
|
85
|
-
role: "system",
|
86
|
-
content: message2.content[0].text
|
87
|
-
}
|
88
|
-
];
|
89
|
-
}
|
90
|
-
case "user": {
|
91
|
-
const attachments = "attachments" in message2 ? message2.attachments : [];
|
92
|
-
const content = [
|
93
|
-
...message2.content,
|
94
|
-
...attachments.map((a) => a.content).flat()
|
95
|
-
];
|
96
|
-
const msg = {
|
97
|
-
...includeId ? { unstable_id: message2.id } : {},
|
98
|
-
role: "user",
|
99
|
-
content: content.map(
|
100
|
-
(part) => {
|
101
|
-
const type = part.type;
|
102
|
-
switch (type) {
|
103
|
-
case "text": {
|
104
|
-
return part;
|
105
|
-
}
|
106
|
-
case "image": {
|
107
|
-
return {
|
108
|
-
type: "image",
|
109
|
-
image: new URL(part.image)
|
110
|
-
};
|
111
|
-
}
|
112
|
-
case "file": {
|
113
|
-
return {
|
114
|
-
type: "file",
|
115
|
-
data: new URL(part.data),
|
116
|
-
mimeType: part.mimeType
|
117
|
-
};
|
118
|
-
}
|
119
|
-
default: {
|
120
|
-
const unhandledType = type;
|
121
|
-
throw new Error(
|
122
|
-
`Unspported content part type: ${unhandledType}`
|
123
|
-
);
|
124
|
-
}
|
125
|
-
}
|
126
|
-
}
|
127
|
-
)
|
128
|
-
};
|
129
|
-
return [msg];
|
130
|
-
}
|
131
|
-
case "assistant": {
|
132
|
-
const splitter = assistantMessageSplitter();
|
133
|
-
for (const part of message2.content) {
|
134
|
-
const type = part.type;
|
135
|
-
switch (type) {
|
136
|
-
case "reasoning":
|
137
|
-
case "source":
|
138
|
-
case "file": {
|
139
|
-
break;
|
140
|
-
}
|
141
|
-
case "text": {
|
142
|
-
splitter.addTextContentPart(part);
|
143
|
-
break;
|
144
|
-
}
|
145
|
-
case "tool-call": {
|
146
|
-
splitter.addToolCallPart(part);
|
147
|
-
break;
|
148
|
-
}
|
149
|
-
default: {
|
150
|
-
const unhandledType = type;
|
151
|
-
throw new Error(`Unhandled content part type: ${unhandledType}`);
|
152
|
-
}
|
153
|
-
}
|
154
|
-
}
|
155
|
-
return splitter.getMessages();
|
156
|
-
}
|
157
|
-
default: {
|
158
|
-
const unhandledRole = role;
|
159
|
-
throw new Error(`Unknown message role: ${unhandledRole}`);
|
160
|
-
}
|
161
|
-
}
|
162
|
-
});
|
163
|
-
}
|
164
|
-
// Annotate the CommonJS export names for ESM import in node:
|
165
|
-
0 && (module.exports = {
|
166
|
-
toLanguageModelMessages
|
167
|
-
});
|
168
|
-
//# sourceMappingURL=toLanguageModelMessages.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/runtimes/edge/converters/toLanguageModelMessages.ts"],"sourcesContent":["import {\n LanguageModelV1FilePart,\n LanguageModelV1ImagePart,\n LanguageModelV1Message,\n LanguageModelV1TextPart,\n LanguageModelV1ToolCallPart,\n LanguageModelV1ToolResultPart,\n} from \"@ai-sdk/provider\";\nimport {\n CoreMessage,\n ThreadMessage,\n TextContentPart,\n CoreToolCallContentPart,\n ToolCallContentPart,\n} from \"../../../types/AssistantTypes\";\n\nconst assistantMessageSplitter = () => {\n const stash: LanguageModelV1Message[] = [];\n let assistantMessage = {\n role: \"assistant\" as const,\n content: [] as (LanguageModelV1TextPart | LanguageModelV1ToolCallPart)[],\n };\n let toolMessage = {\n role: \"tool\" as const,\n content: [] as LanguageModelV1ToolResultPart[],\n };\n\n return {\n addTextContentPart: (part: TextContentPart) => {\n if (toolMessage.content.length > 0) {\n stash.push(assistantMessage);\n stash.push(toolMessage);\n\n assistantMessage = {\n role: \"assistant\" as const,\n content: [] as (\n | LanguageModelV1TextPart\n | LanguageModelV1ToolCallPart\n )[],\n };\n\n toolMessage = {\n role: \"tool\" as const,\n content: [] as LanguageModelV1ToolResultPart[],\n };\n }\n\n assistantMessage.content.push(part);\n },\n addToolCallPart: (part: CoreToolCallContentPart | ToolCallContentPart) => {\n assistantMessage.content.push({\n type: \"tool-call\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n args: part.args,\n });\n\n toolMessage.content.push({\n type: \"tool-result\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n ...(\"artifact\" in part ? { artifact: part.artifact } : {}),\n result:\n part.result === undefined\n ? \"Error: tool is has no configured code to run\"\n : part.result,\n isError: part.isError ?? part.result === undefined,\n });\n },\n getMessages: () => {\n if (toolMessage.content.length > 0) {\n return [...stash, assistantMessage, toolMessage];\n }\n\n return [...stash, assistantMessage];\n },\n };\n};\n\nexport function toLanguageModelMessages(\n message: readonly CoreMessage[] | readonly ThreadMessage[],\n options: { unstable_includeId?: boolean | undefined } = {},\n): LanguageModelV1Message[] {\n const includeId = options.unstable_includeId ?? false;\n return message.flatMap((message) => {\n const role = message.role;\n switch (role) {\n case \"system\": {\n return [\n {\n ...(includeId\n ? { unstable_id: (message as ThreadMessage).id }\n : {}),\n role: \"system\",\n content: message.content[0].text,\n },\n ];\n }\n\n case \"user\": {\n const attachments = \"attachments\" in message ? message.attachments : [];\n const content = [\n ...message.content,\n ...attachments.map((a) => a.content).flat(),\n ];\n const msg: LanguageModelV1Message = {\n ...(includeId ? { unstable_id: (message as ThreadMessage).id } : {}),\n role: \"user\",\n content: content.map(\n (\n part,\n ):\n | LanguageModelV1TextPart\n | LanguageModelV1ImagePart\n | LanguageModelV1FilePart => {\n const type = part.type;\n switch (type) {\n case \"text\": {\n return part;\n }\n\n case \"image\": {\n return {\n type: \"image\",\n image: new URL(part.image),\n };\n }\n\n case \"file\": {\n return {\n type: \"file\",\n data: new URL(part.data),\n mimeType: part.mimeType,\n };\n }\n\n default: {\n const unhandledType: \"audio\" = type;\n throw new Error(\n `Unspported content part type: ${unhandledType}`,\n );\n }\n }\n },\n ),\n };\n return [msg];\n }\n\n case \"assistant\": {\n const splitter = assistantMessageSplitter();\n for (const part of message.content) {\n const type = part.type;\n switch (type) {\n case \"reasoning\":\n case \"source\":\n case \"file\": {\n break; // reasoning, source, and file parts are omitted\n }\n\n case \"text\": {\n splitter.addTextContentPart(part);\n break;\n }\n case \"tool-call\": {\n splitter.addToolCallPart(part);\n break;\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unhandled content part type: ${unhandledType}`);\n }\n }\n }\n return splitter.getMessages();\n }\n\n default: {\n const unhandledRole: never = role;\n throw new Error(`Unknown message role: ${unhandledRole}`);\n }\n }\n });\n}\n"],"mappings":"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","names":["message"]}
|
@@ -1,143 +0,0 @@
|
|
1
|
-
// src/runtimes/edge/converters/toLanguageModelMessages.ts
|
2
|
-
var assistantMessageSplitter = () => {
|
3
|
-
const stash = [];
|
4
|
-
let assistantMessage = {
|
5
|
-
role: "assistant",
|
6
|
-
content: []
|
7
|
-
};
|
8
|
-
let toolMessage = {
|
9
|
-
role: "tool",
|
10
|
-
content: []
|
11
|
-
};
|
12
|
-
return {
|
13
|
-
addTextContentPart: (part) => {
|
14
|
-
if (toolMessage.content.length > 0) {
|
15
|
-
stash.push(assistantMessage);
|
16
|
-
stash.push(toolMessage);
|
17
|
-
assistantMessage = {
|
18
|
-
role: "assistant",
|
19
|
-
content: []
|
20
|
-
};
|
21
|
-
toolMessage = {
|
22
|
-
role: "tool",
|
23
|
-
content: []
|
24
|
-
};
|
25
|
-
}
|
26
|
-
assistantMessage.content.push(part);
|
27
|
-
},
|
28
|
-
addToolCallPart: (part) => {
|
29
|
-
assistantMessage.content.push({
|
30
|
-
type: "tool-call",
|
31
|
-
toolCallId: part.toolCallId,
|
32
|
-
toolName: part.toolName,
|
33
|
-
args: part.args
|
34
|
-
});
|
35
|
-
toolMessage.content.push({
|
36
|
-
type: "tool-result",
|
37
|
-
toolCallId: part.toolCallId,
|
38
|
-
toolName: part.toolName,
|
39
|
-
..."artifact" in part ? { artifact: part.artifact } : {},
|
40
|
-
result: part.result === void 0 ? "Error: tool is has no configured code to run" : part.result,
|
41
|
-
isError: part.isError ?? part.result === void 0
|
42
|
-
});
|
43
|
-
},
|
44
|
-
getMessages: () => {
|
45
|
-
if (toolMessage.content.length > 0) {
|
46
|
-
return [...stash, assistantMessage, toolMessage];
|
47
|
-
}
|
48
|
-
return [...stash, assistantMessage];
|
49
|
-
}
|
50
|
-
};
|
51
|
-
};
|
52
|
-
function toLanguageModelMessages(message, options = {}) {
|
53
|
-
const includeId = options.unstable_includeId ?? false;
|
54
|
-
return message.flatMap((message2) => {
|
55
|
-
const role = message2.role;
|
56
|
-
switch (role) {
|
57
|
-
case "system": {
|
58
|
-
return [
|
59
|
-
{
|
60
|
-
...includeId ? { unstable_id: message2.id } : {},
|
61
|
-
role: "system",
|
62
|
-
content: message2.content[0].text
|
63
|
-
}
|
64
|
-
];
|
65
|
-
}
|
66
|
-
case "user": {
|
67
|
-
const attachments = "attachments" in message2 ? message2.attachments : [];
|
68
|
-
const content = [
|
69
|
-
...message2.content,
|
70
|
-
...attachments.map((a) => a.content).flat()
|
71
|
-
];
|
72
|
-
const msg = {
|
73
|
-
...includeId ? { unstable_id: message2.id } : {},
|
74
|
-
role: "user",
|
75
|
-
content: content.map(
|
76
|
-
(part) => {
|
77
|
-
const type = part.type;
|
78
|
-
switch (type) {
|
79
|
-
case "text": {
|
80
|
-
return part;
|
81
|
-
}
|
82
|
-
case "image": {
|
83
|
-
return {
|
84
|
-
type: "image",
|
85
|
-
image: new URL(part.image)
|
86
|
-
};
|
87
|
-
}
|
88
|
-
case "file": {
|
89
|
-
return {
|
90
|
-
type: "file",
|
91
|
-
data: new URL(part.data),
|
92
|
-
mimeType: part.mimeType
|
93
|
-
};
|
94
|
-
}
|
95
|
-
default: {
|
96
|
-
const unhandledType = type;
|
97
|
-
throw new Error(
|
98
|
-
`Unspported content part type: ${unhandledType}`
|
99
|
-
);
|
100
|
-
}
|
101
|
-
}
|
102
|
-
}
|
103
|
-
)
|
104
|
-
};
|
105
|
-
return [msg];
|
106
|
-
}
|
107
|
-
case "assistant": {
|
108
|
-
const splitter = assistantMessageSplitter();
|
109
|
-
for (const part of message2.content) {
|
110
|
-
const type = part.type;
|
111
|
-
switch (type) {
|
112
|
-
case "reasoning":
|
113
|
-
case "source":
|
114
|
-
case "file": {
|
115
|
-
break;
|
116
|
-
}
|
117
|
-
case "text": {
|
118
|
-
splitter.addTextContentPart(part);
|
119
|
-
break;
|
120
|
-
}
|
121
|
-
case "tool-call": {
|
122
|
-
splitter.addToolCallPart(part);
|
123
|
-
break;
|
124
|
-
}
|
125
|
-
default: {
|
126
|
-
const unhandledType = type;
|
127
|
-
throw new Error(`Unhandled content part type: ${unhandledType}`);
|
128
|
-
}
|
129
|
-
}
|
130
|
-
}
|
131
|
-
return splitter.getMessages();
|
132
|
-
}
|
133
|
-
default: {
|
134
|
-
const unhandledRole = role;
|
135
|
-
throw new Error(`Unknown message role: ${unhandledRole}`);
|
136
|
-
}
|
137
|
-
}
|
138
|
-
});
|
139
|
-
}
|
140
|
-
export {
|
141
|
-
toLanguageModelMessages
|
142
|
-
};
|
143
|
-
//# sourceMappingURL=toLanguageModelMessages.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/runtimes/edge/converters/toLanguageModelMessages.ts"],"sourcesContent":["import {\n LanguageModelV1FilePart,\n LanguageModelV1ImagePart,\n LanguageModelV1Message,\n LanguageModelV1TextPart,\n LanguageModelV1ToolCallPart,\n LanguageModelV1ToolResultPart,\n} from \"@ai-sdk/provider\";\nimport {\n CoreMessage,\n ThreadMessage,\n TextContentPart,\n CoreToolCallContentPart,\n ToolCallContentPart,\n} from \"../../../types/AssistantTypes\";\n\nconst assistantMessageSplitter = () => {\n const stash: LanguageModelV1Message[] = [];\n let assistantMessage = {\n role: \"assistant\" as const,\n content: [] as (LanguageModelV1TextPart | LanguageModelV1ToolCallPart)[],\n };\n let toolMessage = {\n role: \"tool\" as const,\n content: [] as LanguageModelV1ToolResultPart[],\n };\n\n return {\n addTextContentPart: (part: TextContentPart) => {\n if (toolMessage.content.length > 0) {\n stash.push(assistantMessage);\n stash.push(toolMessage);\n\n assistantMessage = {\n role: \"assistant\" as const,\n content: [] as (\n | LanguageModelV1TextPart\n | LanguageModelV1ToolCallPart\n )[],\n };\n\n toolMessage = {\n role: \"tool\" as const,\n content: [] as LanguageModelV1ToolResultPart[],\n };\n }\n\n assistantMessage.content.push(part);\n },\n addToolCallPart: (part: CoreToolCallContentPart | ToolCallContentPart) => {\n assistantMessage.content.push({\n type: \"tool-call\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n args: part.args,\n });\n\n toolMessage.content.push({\n type: \"tool-result\",\n toolCallId: part.toolCallId,\n toolName: part.toolName,\n ...(\"artifact\" in part ? { artifact: part.artifact } : {}),\n result:\n part.result === undefined\n ? \"Error: tool is has no configured code to run\"\n : part.result,\n isError: part.isError ?? part.result === undefined,\n });\n },\n getMessages: () => {\n if (toolMessage.content.length > 0) {\n return [...stash, assistantMessage, toolMessage];\n }\n\n return [...stash, assistantMessage];\n },\n };\n};\n\nexport function toLanguageModelMessages(\n message: readonly CoreMessage[] | readonly ThreadMessage[],\n options: { unstable_includeId?: boolean | undefined } = {},\n): LanguageModelV1Message[] {\n const includeId = options.unstable_includeId ?? false;\n return message.flatMap((message) => {\n const role = message.role;\n switch (role) {\n case \"system\": {\n return [\n {\n ...(includeId\n ? { unstable_id: (message as ThreadMessage).id }\n : {}),\n role: \"system\",\n content: message.content[0].text,\n },\n ];\n }\n\n case \"user\": {\n const attachments = \"attachments\" in message ? message.attachments : [];\n const content = [\n ...message.content,\n ...attachments.map((a) => a.content).flat(),\n ];\n const msg: LanguageModelV1Message = {\n ...(includeId ? { unstable_id: (message as ThreadMessage).id } : {}),\n role: \"user\",\n content: content.map(\n (\n part,\n ):\n | LanguageModelV1TextPart\n | LanguageModelV1ImagePart\n | LanguageModelV1FilePart => {\n const type = part.type;\n switch (type) {\n case \"text\": {\n return part;\n }\n\n case \"image\": {\n return {\n type: \"image\",\n image: new URL(part.image),\n };\n }\n\n case \"file\": {\n return {\n type: \"file\",\n data: new URL(part.data),\n mimeType: part.mimeType,\n };\n }\n\n default: {\n const unhandledType: \"audio\" = type;\n throw new Error(\n `Unspported content part type: ${unhandledType}`,\n );\n }\n }\n },\n ),\n };\n return [msg];\n }\n\n case \"assistant\": {\n const splitter = assistantMessageSplitter();\n for (const part of message.content) {\n const type = part.type;\n switch (type) {\n case \"reasoning\":\n case \"source\":\n case \"file\": {\n break; // reasoning, source, and file parts are omitted\n }\n\n case \"text\": {\n splitter.addTextContentPart(part);\n break;\n }\n case \"tool-call\": {\n splitter.addToolCallPart(part);\n break;\n }\n default: {\n const unhandledType: never = type;\n throw new Error(`Unhandled content part type: ${unhandledType}`);\n }\n }\n }\n return splitter.getMessages();\n }\n\n default: {\n const unhandledRole: never = role;\n throw new Error(`Unknown message role: ${unhandledRole}`);\n }\n }\n });\n}\n"],"mappings":";AAgBA,IAAM,2BAA2B,MAAM;AACrC,QAAM,QAAkC,CAAC;AACzC,MAAI,mBAAmB;AAAA,IACrB,MAAM;AAAA,IACN,SAAS,CAAC;AAAA,EACZ;AACA,MAAI,cAAc;AAAA,IAChB,MAAM;AAAA,IACN,SAAS,CAAC;AAAA,EACZ;AAEA,SAAO;AAAA,IACL,oBAAoB,CAAC,SAA0B;AAC7C,UAAI,YAAY,QAAQ,SAAS,GAAG;AAClC,cAAM,KAAK,gBAAgB;AAC3B,cAAM,KAAK,WAAW;AAEtB,2BAAmB;AAAA,UACjB,MAAM;AAAA,UACN,SAAS,CAAC;AAAA,QAIZ;AAEA,sBAAc;AAAA,UACZ,MAAM;AAAA,UACN,SAAS,CAAC;AAAA,QACZ;AAAA,MACF;AAEA,uBAAiB,QAAQ,KAAK,IAAI;AAAA,IACpC;AAAA,IACA,iBAAiB,CAAC,SAAwD;AACxE,uBAAiB,QAAQ,KAAK;AAAA,QAC5B,MAAM;AAAA,QACN,YAAY,KAAK;AAAA,QACjB,UAAU,KAAK;AAAA,QACf,MAAM,KAAK;AAAA,MACb,CAAC;AAED,kBAAY,QAAQ,KAAK;AAAA,QACvB,MAAM;AAAA,QACN,YAAY,KAAK;AAAA,QACjB,UAAU,KAAK;AAAA,QACf,GAAI,cAAc,OAAO,EAAE,UAAU,KAAK,SAAS,IAAI,CAAC;AAAA,QACxD,QACE,KAAK,WAAW,SACZ,iDACA,KAAK;AAAA,QACX,SAAS,KAAK,WAAW,KAAK,WAAW;AAAA,MAC3C,CAAC;AAAA,IACH;AAAA,IACA,aAAa,MAAM;AACjB,UAAI,YAAY,QAAQ,SAAS,GAAG;AAClC,eAAO,CAAC,GAAG,OAAO,kBAAkB,WAAW;AAAA,MACjD;AAEA,aAAO,CAAC,GAAG,OAAO,gBAAgB;AAAA,IACpC;AAAA,EACF;AACF;AAEO,SAAS,wBACd,SACA,UAAwD,CAAC,GAC/B;AAC1B,QAAM,YAAY,QAAQ,sBAAsB;AAChD,SAAO,QAAQ,QAAQ,CAACA,aAAY;AAClC,UAAM,OAAOA,SAAQ;AACrB,YAAQ,MAAM;AAAA,MACZ,KAAK,UAAU;AACb,eAAO;AAAA,UACL;AAAA,YACE,GAAI,YACA,EAAE,aAAcA,SAA0B,GAAG,IAC7C,CAAC;AAAA,YACL,MAAM;AAAA,YACN,SAASA,SAAQ,QAAQ,CAAC,EAAE;AAAA,UAC9B;AAAA,QACF;AAAA,MACF;AAAA,MAEA,KAAK,QAAQ;AACX,cAAM,cAAc,iBAAiBA,WAAUA,SAAQ,cAAc,CAAC;AACtE,cAAM,UAAU;AAAA,UACd,GAAGA,SAAQ;AAAA,UACX,GAAG,YAAY,IAAI,CAAC,MAAM,EAAE,OAAO,EAAE,KAAK;AAAA,QAC5C;AACA,cAAM,MAA8B;AAAA,UAClC,GAAI,YAAY,EAAE,aAAcA,SAA0B,GAAG,IAAI,CAAC;AAAA,UAClE,MAAM;AAAA,UACN,SAAS,QAAQ;AAAA,YACf,CACE,SAI6B;AAC7B,oBAAM,OAAO,KAAK;AAClB,sBAAQ,MAAM;AAAA,gBACZ,KAAK,QAAQ;AACX,yBAAO;AAAA,gBACT;AAAA,gBAEA,KAAK,SAAS;AACZ,yBAAO;AAAA,oBACL,MAAM;AAAA,oBACN,OAAO,IAAI,IAAI,KAAK,KAAK;AAAA,kBAC3B;AAAA,gBACF;AAAA,gBAEA,KAAK,QAAQ;AACX,yBAAO;AAAA,oBACL,MAAM;AAAA,oBACN,MAAM,IAAI,IAAI,KAAK,IAAI;AAAA,oBACvB,UAAU,KAAK;AAAA,kBACjB;AAAA,gBACF;AAAA,gBAEA,SAAS;AACP,wBAAM,gBAAyB;AAC/B,wBAAM,IAAI;AAAA,oBACR,iCAAiC,aAAa;AAAA,kBAChD;AAAA,gBACF;AAAA,cACF;AAAA,YACF;AAAA,UACF;AAAA,QACF;AACA,eAAO,CAAC,GAAG;AAAA,MACb;AAAA,MAEA,KAAK,aAAa;AAChB,cAAM,WAAW,yBAAyB;AAC1C,mBAAW,QAAQA,SAAQ,SAAS;AAClC,gBAAM,OAAO,KAAK;AAClB,kBAAQ,MAAM;AAAA,YACZ,KAAK;AAAA,YACL,KAAK;AAAA,YACL,KAAK,QAAQ;AACX;AAAA,YACF;AAAA,YAEA,KAAK,QAAQ;AACX,uBAAS,mBAAmB,IAAI;AAChC;AAAA,YACF;AAAA,YACA,KAAK,aAAa;AAChB,uBAAS,gBAAgB,IAAI;AAC7B;AAAA,YACF;AAAA,YACA,SAAS;AACP,oBAAM,gBAAuB;AAC7B,oBAAM,IAAI,MAAM,gCAAgC,aAAa,EAAE;AAAA,YACjE;AAAA,UACF;AAAA,QACF;AACA,eAAO,SAAS,YAAY;AAAA,MAC9B;AAAA,MAEA,SAAS;AACP,cAAM,gBAAuB;AAC7B,cAAM,IAAI,MAAM,yBAAyB,aAAa,EAAE;AAAA,MAC1D;AAAA,IACF;AAAA,EACF,CAAC;AACH;","names":["message"]}
|
@@ -1,4 +0,0 @@
|
|
1
|
-
import { LanguageModelV1FunctionTool } from "@ai-sdk/provider";
|
2
|
-
import { Tool } from "../../../model-context/ModelContextTypes";
|
3
|
-
export declare const toLanguageModelTools: (tools: Record<string, Tool<any, any>>) => LanguageModelV1FunctionTool[];
|
4
|
-
//# sourceMappingURL=toLanguageModelTools.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"toLanguageModelTools.d.ts","sourceRoot":"","sources":["../../../../src/runtimes/edge/converters/toLanguageModelTools.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,2BAA2B,EAAE,MAAM,kBAAkB,CAAC;AAI/D,OAAO,EAAE,IAAI,EAAE,MAAM,0CAA0C,CAAC;AAEhE,eAAO,MAAM,oBAAoB,GAC/B,OAAO,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,KACpC,2BAA2B,EAS7B,CAAC"}
|
@@ -1,50 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __create = Object.create;
|
3
|
-
var __defProp = Object.defineProperty;
|
4
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
5
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
6
|
-
var __getProtoOf = Object.getPrototypeOf;
|
7
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
8
|
-
var __export = (target, all) => {
|
9
|
-
for (var name in all)
|
10
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
11
|
-
};
|
12
|
-
var __copyProps = (to, from, except, desc) => {
|
13
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
14
|
-
for (let key of __getOwnPropNames(from))
|
15
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
16
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
17
|
-
}
|
18
|
-
return to;
|
19
|
-
};
|
20
|
-
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
21
|
-
// If the importer is in node compatibility mode or this is not an ESM
|
22
|
-
// file that has been converted to a CommonJS file using a Babel-
|
23
|
-
// compatible transform (i.e. "__esModule" has not been set), then set
|
24
|
-
// "default" to the CommonJS "module.exports" for node compatibility.
|
25
|
-
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
26
|
-
mod
|
27
|
-
));
|
28
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
29
|
-
|
30
|
-
// src/runtimes/edge/converters/toLanguageModelTools.ts
|
31
|
-
var toLanguageModelTools_exports = {};
|
32
|
-
__export(toLanguageModelTools_exports, {
|
33
|
-
toLanguageModelTools: () => toLanguageModelTools
|
34
|
-
});
|
35
|
-
module.exports = __toCommonJS(toLanguageModelTools_exports);
|
36
|
-
var import_zod = require("zod");
|
37
|
-
var import_zod_to_json_schema = __toESM(require("zod-to-json-schema"));
|
38
|
-
var toLanguageModelTools = (tools) => {
|
39
|
-
return Object.entries(tools).map(([name, tool]) => ({
|
40
|
-
type: "function",
|
41
|
-
name,
|
42
|
-
...tool.description ? { description: tool.description } : void 0,
|
43
|
-
parameters: tool.parameters instanceof import_zod.z.ZodType ? (0, import_zod_to_json_schema.default)(tool.parameters) : tool.parameters
|
44
|
-
}));
|
45
|
-
};
|
46
|
-
// Annotate the CommonJS export names for ESM import in node:
|
47
|
-
0 && (module.exports = {
|
48
|
-
toLanguageModelTools
|
49
|
-
});
|
50
|
-
//# sourceMappingURL=toLanguageModelTools.js.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/runtimes/edge/converters/toLanguageModelTools.ts"],"sourcesContent":["import { LanguageModelV1FunctionTool } from \"@ai-sdk/provider\";\nimport { JSONSchema7 } from \"json-schema\";\nimport { z } from \"zod\";\nimport zodToJsonSchema from \"zod-to-json-schema\";\nimport { Tool } from \"../../../model-context/ModelContextTypes\";\n\nexport const toLanguageModelTools = (\n tools: Record<string, Tool<any, any>>,\n): LanguageModelV1FunctionTool[] => {\n return Object.entries(tools).map(([name, tool]) => ({\n type: \"function\",\n name,\n ...(tool.description ? { description: tool.description } : undefined),\n parameters: (tool.parameters instanceof z.ZodType\n ? zodToJsonSchema(tool.parameters)\n : tool.parameters) as JSONSchema7,\n }));\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAEA,iBAAkB;AAClB,gCAA4B;AAGrB,IAAM,uBAAuB,CAClC,UACkC;AAClC,SAAO,OAAO,QAAQ,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,IAAI,OAAO;AAAA,IAClD,MAAM;AAAA,IACN;AAAA,IACA,GAAI,KAAK,cAAc,EAAE,aAAa,KAAK,YAAY,IAAI;AAAA,IAC3D,YAAa,KAAK,sBAAsB,aAAE,cACtC,0BAAAA,SAAgB,KAAK,UAAU,IAC/B,KAAK;AAAA,EACX,EAAE;AACJ;","names":["zodToJsonSchema"]}
|
@@ -1,15 +0,0 @@
|
|
1
|
-
// src/runtimes/edge/converters/toLanguageModelTools.ts
|
2
|
-
import { z } from "zod";
|
3
|
-
import zodToJsonSchema from "zod-to-json-schema";
|
4
|
-
var toLanguageModelTools = (tools) => {
|
5
|
-
return Object.entries(tools).map(([name, tool]) => ({
|
6
|
-
type: "function",
|
7
|
-
name,
|
8
|
-
...tool.description ? { description: tool.description } : void 0,
|
9
|
-
parameters: tool.parameters instanceof z.ZodType ? zodToJsonSchema(tool.parameters) : tool.parameters
|
10
|
-
}));
|
11
|
-
};
|
12
|
-
export {
|
13
|
-
toLanguageModelTools
|
14
|
-
};
|
15
|
-
//# sourceMappingURL=toLanguageModelTools.mjs.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"sources":["../../../../src/runtimes/edge/converters/toLanguageModelTools.ts"],"sourcesContent":["import { LanguageModelV1FunctionTool } from \"@ai-sdk/provider\";\nimport { JSONSchema7 } from \"json-schema\";\nimport { z } from \"zod\";\nimport zodToJsonSchema from \"zod-to-json-schema\";\nimport { Tool } from \"../../../model-context/ModelContextTypes\";\n\nexport const toLanguageModelTools = (\n tools: Record<string, Tool<any, any>>,\n): LanguageModelV1FunctionTool[] => {\n return Object.entries(tools).map(([name, tool]) => ({\n type: \"function\",\n name,\n ...(tool.description ? { description: tool.description } : undefined),\n parameters: (tool.parameters instanceof z.ZodType\n ? zodToJsonSchema(tool.parameters)\n : tool.parameters) as JSONSchema7,\n }));\n};\n"],"mappings":";AAEA,SAAS,SAAS;AAClB,OAAO,qBAAqB;AAGrB,IAAM,uBAAuB,CAClC,UACkC;AAClC,SAAO,OAAO,QAAQ,KAAK,EAAE,IAAI,CAAC,CAAC,MAAM,IAAI,OAAO;AAAA,IAClD,MAAM;AAAA,IACN;AAAA,IACA,GAAI,KAAK,cAAc,EAAE,aAAa,KAAK,YAAY,IAAI;AAAA,IAC3D,YAAa,KAAK,sBAAsB,EAAE,UACtC,gBAAgB,KAAK,UAAU,IAC/B,KAAK;AAAA,EACX,EAAE;AACJ;","names":[]}
|
@@ -1,36 +0,0 @@
|
|
1
|
-
import { LanguageModelV1, LanguageModelV1ToolChoice, LanguageModelV1Prompt } from "@ai-sdk/provider";
|
2
|
-
import { CoreMessage, ThreadMessage, ThreadStep } from "../../types/AssistantTypes";
|
3
|
-
import { EdgeRuntimeRequestOptionsSchema } from "./EdgeRuntimeRequestOptions";
|
4
|
-
import { LanguageModelConfig, LanguageModelV1CallSettings, Tool } from "../../model-context/ModelContextTypes";
|
5
|
-
import { z } from "zod";
|
6
|
-
import { AssistantStreamChunk } from "assistant-stream";
|
7
|
-
type FinishResult = {
|
8
|
-
messages: readonly (CoreMessage | ThreadMessage)[];
|
9
|
-
metadata: {
|
10
|
-
steps: readonly ThreadStep[];
|
11
|
-
};
|
12
|
-
};
|
13
|
-
type LanguageModelCreator = (config: LanguageModelConfig) => Promise<LanguageModelV1> | LanguageModelV1;
|
14
|
-
export type CreateEdgeRuntimeAPIOptions = LanguageModelV1CallSettings & {
|
15
|
-
model: LanguageModelV1 | LanguageModelCreator;
|
16
|
-
system?: string;
|
17
|
-
tools?: Record<string, Tool<any, any>>;
|
18
|
-
toolChoice?: LanguageModelV1ToolChoice;
|
19
|
-
onFinish?: (result: FinishResult) => void;
|
20
|
-
};
|
21
|
-
type GetEdgeRuntimeStreamOptions = {
|
22
|
-
abortSignal: AbortSignal;
|
23
|
-
requestData: z.infer<typeof EdgeRuntimeRequestOptionsSchema>;
|
24
|
-
options: CreateEdgeRuntimeAPIOptions;
|
25
|
-
};
|
26
|
-
export declare const getEdgeRuntimeStream: ({ abortSignal, requestData: unsafeRequest, options: { model: modelOrCreator, system: serverSystem, tools: serverTools, toolChoice, onFinish, ...unsafeSettings }, }: GetEdgeRuntimeStreamOptions) => Promise<ReadableStream<AssistantStreamChunk>>;
|
27
|
-
export declare namespace getEdgeRuntimeResponse {
|
28
|
-
export type { GetEdgeRuntimeStreamOptions as Options };
|
29
|
-
}
|
30
|
-
export declare const getEdgeRuntimeResponse: (options: getEdgeRuntimeResponse.Options) => Promise<Response>;
|
31
|
-
export declare const createEdgeRuntimeAPI: (options: CreateEdgeRuntimeAPIOptions) => {
|
32
|
-
POST: (request: Request) => Promise<Response>;
|
33
|
-
};
|
34
|
-
export declare function convertToLanguageModelPrompt(system: string | undefined, messages: readonly CoreMessage[]): LanguageModelV1Prompt;
|
35
|
-
export {};
|
36
|
-
//# sourceMappingURL=createEdgeRuntimeAPI.d.ts.map
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"createEdgeRuntimeAPI.d.ts","sourceRoot":"","sources":["../../../src/runtimes/edge/createEdgeRuntimeAPI.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,eAAe,EACf,yBAAyB,EAEzB,qBAAqB,EAEtB,MAAM,kBAAkB,CAAC;AAC1B,OAAO,EACL,WAAW,EACX,aAAa,EACb,UAAU,EACX,MAAM,4BAA4B,CAAC;AACpC,OAAO,EAAE,+BAA+B,EAAE,MAAM,6BAA6B,CAAC;AAI9E,OAAO,EACL,mBAAmB,EACnB,2BAA2B,EAE3B,IAAI,EACL,MAAM,uCAAuC,CAAC;AAC/C,OAAO,EAAE,CAAC,EAAE,MAAM,KAAK,CAAC;AACxB,OAAO,EAGL,oBAAoB,EAErB,MAAM,kBAAkB,CAAC;AAG1B,KAAK,YAAY,GAAG;IAClB,QAAQ,EAAE,SAAS,CAAC,WAAW,GAAG,aAAa,CAAC,EAAE,CAAC;IACnD,QAAQ,EAAE;QACR,KAAK,EAAE,SAAS,UAAU,EAAE,CAAC;KAC9B,CAAC;CACH,CAAC;AAEF,KAAK,oBAAoB,GAAG,CAC1B,MAAM,EAAE,mBAAmB,KACxB,OAAO,CAAC,eAAe,CAAC,GAAG,eAAe,CAAC;AAEhD,MAAM,MAAM,2BAA2B,GAAG,2BAA2B,GAAG;IACtE,KAAK,EAAE,eAAe,GAAG,oBAAoB,CAAC;IAC9C,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,IAAI,CAAC,GAAG,EAAE,GAAG,CAAC,CAAC,CAAC;IACvC,UAAU,CAAC,EAAE,yBAAyB,CAAC;IACvC,QAAQ,CAAC,EAAE,CAAC,MAAM,EAAE,YAAY,KAAK,IAAI,CAAC;CAC3C,CAAC;AAEF,KAAK,2BAA2B,GAAG;IACjC,WAAW,EAAE,WAAW,CAAC;IACzB,WAAW,EAAE,CAAC,CAAC,KAAK,CAAC,OAAO,+BAA+B,CAAC,CAAC;IAC7D,OAAO,EAAE,2BAA2B,CAAC;CACtC,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAU,qKAWxC,2BAA2B,kDAkG7B,CAAC;AAEF,MAAM,CAAC,OAAO,WAAW,sBAAsB,CAAC;IAC9C,YAAY,EAAE,2BAA2B,IAAI,OAAO,EAAE,CAAC;CACxD;AAED,eAAO,MAAM,sBAAsB,GACjC,SAAS,sBAAsB,CAAC,OAAO,sBASxC,CAAC;AAEF,eAAO,MAAM,oBAAoB,GAAI,SAAS,2BAA2B;oBACjD,OAAO;CAM7B,CAAC;AA+BH,wBAAgB,4BAA4B,CAC1C,MAAM,EAAE,MAAM,GAAG,SAAS,EAC1B,QAAQ,EAAE,SAAS,WAAW,EAAE,GAC/B,qBAAqB,CASvB"}
|
@@ -1,179 +0,0 @@
|
|
1
|
-
"use strict";
|
2
|
-
var __defProp = Object.defineProperty;
|
3
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
4
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
5
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
6
|
-
var __export = (target, all) => {
|
7
|
-
for (var name in all)
|
8
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
9
|
-
};
|
10
|
-
var __copyProps = (to, from, except, desc) => {
|
11
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
12
|
-
for (let key of __getOwnPropNames(from))
|
13
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
14
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
15
|
-
}
|
16
|
-
return to;
|
17
|
-
};
|
18
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
19
|
-
|
20
|
-
// src/runtimes/edge/createEdgeRuntimeAPI.ts
|
21
|
-
var createEdgeRuntimeAPI_exports = {};
|
22
|
-
__export(createEdgeRuntimeAPI_exports, {
|
23
|
-
convertToLanguageModelPrompt: () => convertToLanguageModelPrompt,
|
24
|
-
createEdgeRuntimeAPI: () => createEdgeRuntimeAPI,
|
25
|
-
getEdgeRuntimeResponse: () => getEdgeRuntimeResponse,
|
26
|
-
getEdgeRuntimeStream: () => getEdgeRuntimeStream
|
27
|
-
});
|
28
|
-
module.exports = __toCommonJS(createEdgeRuntimeAPI_exports);
|
29
|
-
var import_EdgeRuntimeRequestOptions = require("./EdgeRuntimeRequestOptions.js");
|
30
|
-
var import_toLanguageModelMessages = require("./converters/toLanguageModelMessages.js");
|
31
|
-
var import_toLanguageModelTools = require("./converters/toLanguageModelTools.js");
|
32
|
-
var import_toolResultStream = require("./streams/toolResultStream.js");
|
33
|
-
var import_ModelContextTypes = require("../../model-context/ModelContextTypes.js");
|
34
|
-
var import_assistant_stream = require("assistant-stream");
|
35
|
-
var import_ai_sdk = require("assistant-stream/ai-sdk");
|
36
|
-
var getEdgeRuntimeStream = async ({
|
37
|
-
abortSignal,
|
38
|
-
requestData: unsafeRequest,
|
39
|
-
options: {
|
40
|
-
model: modelOrCreator,
|
41
|
-
system: serverSystem,
|
42
|
-
tools: serverTools = {},
|
43
|
-
toolChoice,
|
44
|
-
onFinish,
|
45
|
-
...unsafeSettings
|
46
|
-
}
|
47
|
-
}) => {
|
48
|
-
const settings = import_ModelContextTypes.LanguageModelV1CallSettingsSchema.parse(unsafeSettings);
|
49
|
-
const lmServerTools = (0, import_toLanguageModelTools.toLanguageModelTools)(serverTools);
|
50
|
-
const hasServerTools = Object.values(serverTools).some((v) => !!v.execute);
|
51
|
-
const {
|
52
|
-
system: clientSystem,
|
53
|
-
tools: clientTools = [],
|
54
|
-
messages,
|
55
|
-
apiKey,
|
56
|
-
baseUrl,
|
57
|
-
modelName,
|
58
|
-
...callSettings
|
59
|
-
} = import_EdgeRuntimeRequestOptions.EdgeRuntimeRequestOptionsSchema.parse(unsafeRequest);
|
60
|
-
const systemMessages = [];
|
61
|
-
if (serverSystem) systemMessages.push(serverSystem);
|
62
|
-
if (clientSystem) systemMessages.push(clientSystem);
|
63
|
-
const system = systemMessages.join("\n\n");
|
64
|
-
for (const clientTool of clientTools) {
|
65
|
-
if (serverTools?.[clientTool.name]) {
|
66
|
-
throw new Error(
|
67
|
-
`Tool ${clientTool.name} was defined in both the client and server tools. This is not allowed.`
|
68
|
-
);
|
69
|
-
}
|
70
|
-
}
|
71
|
-
const model = typeof modelOrCreator === "function" ? await modelOrCreator({ apiKey, baseUrl, modelName }) : modelOrCreator;
|
72
|
-
let stream;
|
73
|
-
const streamResult = await streamMessage({
|
74
|
-
...settings,
|
75
|
-
...callSettings,
|
76
|
-
model,
|
77
|
-
abortSignal,
|
78
|
-
...!!system ? { system } : void 0,
|
79
|
-
messages,
|
80
|
-
tools: lmServerTools.concat(clientTools),
|
81
|
-
...toolChoice ? { toolChoice } : void 0
|
82
|
-
});
|
83
|
-
stream = streamResult.stream.pipeThrough(new import_ai_sdk.LanguageModelV1StreamDecoder());
|
84
|
-
const canExecuteTools = hasServerTools && toolChoice?.type !== "none";
|
85
|
-
if (canExecuteTools) {
|
86
|
-
stream = stream.pipeThrough((0, import_toolResultStream.toolResultStream)(serverTools, abortSignal));
|
87
|
-
}
|
88
|
-
if (canExecuteTools || onFinish) {
|
89
|
-
const tees = stream.tee();
|
90
|
-
stream = tees[0];
|
91
|
-
let serverStream = tees[1];
|
92
|
-
if (onFinish) {
|
93
|
-
let lastChunk;
|
94
|
-
serverStream.pipeThrough(new import_assistant_stream.AssistantMessageAccumulator()).pipeTo(
|
95
|
-
new WritableStream({
|
96
|
-
write(chunk) {
|
97
|
-
lastChunk = chunk;
|
98
|
-
},
|
99
|
-
close() {
|
100
|
-
if (!lastChunk?.status || lastChunk.status.type === "running")
|
101
|
-
return;
|
102
|
-
const resultingMessages = [
|
103
|
-
...messages,
|
104
|
-
{
|
105
|
-
id: "DEFAULT",
|
106
|
-
createdAt: /* @__PURE__ */ new Date(),
|
107
|
-
role: "assistant",
|
108
|
-
content: lastChunk.content,
|
109
|
-
status: lastChunk.status,
|
110
|
-
metadata: lastChunk.metadata
|
111
|
-
}
|
112
|
-
];
|
113
|
-
onFinish({
|
114
|
-
messages: resultingMessages,
|
115
|
-
metadata: {
|
116
|
-
steps: lastChunk.metadata.steps
|
117
|
-
}
|
118
|
-
});
|
119
|
-
},
|
120
|
-
abort(e) {
|
121
|
-
console.error("Server stream processing error:", e);
|
122
|
-
}
|
123
|
-
})
|
124
|
-
);
|
125
|
-
}
|
126
|
-
}
|
127
|
-
return stream;
|
128
|
-
};
|
129
|
-
var getEdgeRuntimeResponse = async (options) => {
|
130
|
-
const stream = await getEdgeRuntimeStream(options);
|
131
|
-
return new Response(stream.pipeThrough(new import_assistant_stream.DataStreamEncoder()), {
|
132
|
-
headers: {
|
133
|
-
"Content-Type": "text/plain; charset=utf-8",
|
134
|
-
"x-vercel-ai-data-stream": "v1"
|
135
|
-
}
|
136
|
-
});
|
137
|
-
};
|
138
|
-
var createEdgeRuntimeAPI = (options) => ({
|
139
|
-
POST: async (request) => getEdgeRuntimeResponse({
|
140
|
-
abortSignal: request.signal,
|
141
|
-
requestData: await request.json(),
|
142
|
-
options
|
143
|
-
})
|
144
|
-
});
|
145
|
-
async function streamMessage({
|
146
|
-
model,
|
147
|
-
system,
|
148
|
-
messages,
|
149
|
-
tools,
|
150
|
-
toolChoice,
|
151
|
-
...options
|
152
|
-
}) {
|
153
|
-
return model.doStream({
|
154
|
-
inputFormat: "messages",
|
155
|
-
mode: {
|
156
|
-
type: "regular",
|
157
|
-
...tools ? { tools } : void 0,
|
158
|
-
...toolChoice ? { toolChoice } : void 0
|
159
|
-
},
|
160
|
-
prompt: convertToLanguageModelPrompt(system, messages),
|
161
|
-
...options
|
162
|
-
});
|
163
|
-
}
|
164
|
-
function convertToLanguageModelPrompt(system, messages) {
|
165
|
-
const languageModelMessages = [];
|
166
|
-
if (system != null) {
|
167
|
-
languageModelMessages.push({ role: "system", content: system });
|
168
|
-
}
|
169
|
-
languageModelMessages.push(...(0, import_toLanguageModelMessages.toLanguageModelMessages)(messages));
|
170
|
-
return languageModelMessages;
|
171
|
-
}
|
172
|
-
// Annotate the CommonJS export names for ESM import in node:
|
173
|
-
0 && (module.exports = {
|
174
|
-
convertToLanguageModelPrompt,
|
175
|
-
createEdgeRuntimeAPI,
|
176
|
-
getEdgeRuntimeResponse,
|
177
|
-
getEdgeRuntimeStream
|
178
|
-
});
|
179
|
-
//# sourceMappingURL=createEdgeRuntimeAPI.js.map
|