@langchain/core 1.1.39 → 1.1.40-dev-1777073688723
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/callbacks/base.cjs +1 -1
- package/dist/callbacks/base.d.cts.map +1 -1
- package/dist/callbacks/base.d.ts.map +1 -1
- package/dist/language_models/base.cjs +1 -1
- package/dist/language_models/base.cjs.map +1 -1
- package/dist/language_models/base.js +1 -1
- package/dist/language_models/base.js.map +1 -1
- package/dist/language_models/chat_models.cjs +60 -0
- package/dist/language_models/chat_models.cjs.map +1 -1
- package/dist/language_models/chat_models.d.cts +55 -0
- package/dist/language_models/chat_models.d.cts.map +1 -1
- package/dist/language_models/chat_models.d.ts +55 -0
- package/dist/language_models/chat_models.d.ts.map +1 -1
- package/dist/language_models/chat_models.js +60 -0
- package/dist/language_models/chat_models.js.map +1 -1
- package/dist/language_models/compat.cjs +224 -0
- package/dist/language_models/compat.cjs.map +1 -0
- package/dist/language_models/compat.d.cts +20 -0
- package/dist/language_models/compat.d.cts.map +1 -0
- package/dist/language_models/compat.d.ts +20 -0
- package/dist/language_models/compat.d.ts.map +1 -0
- package/dist/language_models/compat.js +216 -0
- package/dist/language_models/compat.js.map +1 -0
- package/dist/language_models/event.cjs +12 -0
- package/dist/language_models/event.cjs.map +1 -0
- package/dist/language_models/event.d.cts +141 -0
- package/dist/language_models/event.d.cts.map +1 -0
- package/dist/language_models/event.d.ts +141 -0
- package/dist/language_models/event.d.ts.map +1 -0
- package/dist/language_models/event.js +7 -0
- package/dist/language_models/event.js.map +1 -0
- package/dist/language_models/stream.cjs +362 -0
- package/dist/language_models/stream.cjs.map +1 -0
- package/dist/language_models/stream.d.cts +106 -0
- package/dist/language_models/stream.d.cts.map +1 -0
- package/dist/language_models/stream.d.ts +106 -0
- package/dist/language_models/stream.d.ts.map +1 -0
- package/dist/language_models/stream.js +351 -0
- package/dist/language_models/stream.js.map +1 -0
- package/dist/load/import_map.cjs +6 -0
- package/dist/load/import_map.cjs.map +1 -1
- package/dist/load/import_map.js +8 -2
- package/dist/load/import_map.js.map +1 -1
- package/dist/load/map_keys.cjs +2 -2
- package/dist/messages/content/index.cjs.map +1 -1
- package/dist/messages/content/index.d.cts +5 -1
- package/dist/messages/content/index.d.cts.map +1 -1
- package/dist/messages/content/index.d.ts +5 -1
- package/dist/messages/content/index.d.ts.map +1 -1
- package/dist/messages/content/index.js.map +1 -1
- package/dist/messages/index.d.cts +2 -2
- package/dist/messages/index.d.ts +2 -2
- package/dist/output_parsers/openai_functions/json_output_functions_parsers.d.cts +1 -1
- package/dist/output_parsers/openai_functions/json_output_functions_parsers.d.ts +1 -1
- package/dist/prompts/template.cjs +1 -1
- package/dist/singletons/callbacks.cjs +1 -1
- package/dist/tracers/console.cjs +1 -1
- package/dist/types/type-utils.d.cts +2 -1
- package/dist/types/type-utils.d.cts.map +1 -1
- package/dist/types/type-utils.d.ts +2 -1
- package/dist/types/type-utils.d.ts.map +1 -1
- package/dist/utils/async_caller.cjs +3 -2
- package/dist/utils/async_caller.cjs.map +1 -1
- package/dist/utils/async_caller.js +2 -1
- package/dist/utils/async_caller.js.map +1 -1
- package/dist/utils/event_source_parse.cjs +5 -12
- package/dist/utils/event_source_parse.cjs.map +1 -1
- package/dist/utils/event_source_parse.js +5 -12
- package/dist/utils/event_source_parse.js.map +1 -1
- package/package.json +34 -1
- package/agents.cjs +0 -1
- package/agents.d.cts +0 -1
- package/agents.d.ts +0 -1
- package/agents.js +0 -1
- package/caches.cjs +0 -1
- package/caches.d.cts +0 -1
- package/caches.d.ts +0 -1
- package/caches.js +0 -1
- package/callbacks/base.cjs +0 -1
- package/callbacks/base.d.cts +0 -1
- package/callbacks/base.d.ts +0 -1
- package/callbacks/base.js +0 -1
- package/callbacks/dispatch/web.cjs +0 -1
- package/callbacks/dispatch/web.d.cts +0 -1
- package/callbacks/dispatch/web.d.ts +0 -1
- package/callbacks/dispatch/web.js +0 -1
- package/callbacks/dispatch.cjs +0 -1
- package/callbacks/dispatch.d.cts +0 -1
- package/callbacks/dispatch.d.ts +0 -1
- package/callbacks/dispatch.js +0 -1
- package/callbacks/manager.cjs +0 -1
- package/callbacks/manager.d.cts +0 -1
- package/callbacks/manager.d.ts +0 -1
- package/callbacks/manager.js +0 -1
- package/callbacks/promises.cjs +0 -1
- package/callbacks/promises.d.cts +0 -1
- package/callbacks/promises.d.ts +0 -1
- package/callbacks/promises.js +0 -1
- package/chat_history.cjs +0 -1
- package/chat_history.d.cts +0 -1
- package/chat_history.d.ts +0 -1
- package/chat_history.js +0 -1
- package/context.cjs +0 -1
- package/context.d.cts +0 -1
- package/context.d.ts +0 -1
- package/context.js +0 -1
- package/document_loaders/base.cjs +0 -1
- package/document_loaders/base.d.cts +0 -1
- package/document_loaders/base.d.ts +0 -1
- package/document_loaders/base.js +0 -1
- package/document_loaders/langsmith.cjs +0 -1
- package/document_loaders/langsmith.d.cts +0 -1
- package/document_loaders/langsmith.d.ts +0 -1
- package/document_loaders/langsmith.js +0 -1
- package/documents.cjs +0 -1
- package/documents.d.cts +0 -1
- package/documents.d.ts +0 -1
- package/documents.js +0 -1
- package/embeddings.cjs +0 -1
- package/embeddings.d.cts +0 -1
- package/embeddings.d.ts +0 -1
- package/embeddings.js +0 -1
- package/errors.cjs +0 -1
- package/errors.d.cts +0 -1
- package/errors.d.ts +0 -1
- package/errors.js +0 -1
- package/example_selectors.cjs +0 -1
- package/example_selectors.d.cts +0 -1
- package/example_selectors.d.ts +0 -1
- package/example_selectors.js +0 -1
- package/indexing.cjs +0 -1
- package/indexing.d.cts +0 -1
- package/indexing.d.ts +0 -1
- package/indexing.js +0 -1
- package/language_models/base.cjs +0 -1
- package/language_models/base.d.cts +0 -1
- package/language_models/base.d.ts +0 -1
- package/language_models/base.js +0 -1
- package/language_models/chat_models.cjs +0 -1
- package/language_models/chat_models.d.cts +0 -1
- package/language_models/chat_models.d.ts +0 -1
- package/language_models/chat_models.js +0 -1
- package/language_models/llms.cjs +0 -1
- package/language_models/llms.d.cts +0 -1
- package/language_models/llms.d.ts +0 -1
- package/language_models/llms.js +0 -1
- package/language_models/profile.cjs +0 -1
- package/language_models/profile.d.cts +0 -1
- package/language_models/profile.d.ts +0 -1
- package/language_models/profile.js +0 -1
- package/language_models/structured_output.cjs +0 -1
- package/language_models/structured_output.d.cts +0 -1
- package/language_models/structured_output.d.ts +0 -1
- package/language_models/structured_output.js +0 -1
- package/load/serializable.cjs +0 -1
- package/load/serializable.d.cts +0 -1
- package/load/serializable.d.ts +0 -1
- package/load/serializable.js +0 -1
- package/load.cjs +0 -1
- package/load.d.cts +0 -1
- package/load.d.ts +0 -1
- package/load.js +0 -1
- package/memory.cjs +0 -1
- package/memory.d.cts +0 -1
- package/memory.d.ts +0 -1
- package/memory.js +0 -1
- package/messages/tool.cjs +0 -1
- package/messages/tool.d.cts +0 -1
- package/messages/tool.d.ts +0 -1
- package/messages/tool.js +0 -1
- package/messages.cjs +0 -1
- package/messages.d.cts +0 -1
- package/messages.d.ts +0 -1
- package/messages.js +0 -1
- package/output_parsers/openai_functions.cjs +0 -1
- package/output_parsers/openai_functions.d.cts +0 -1
- package/output_parsers/openai_functions.d.ts +0 -1
- package/output_parsers/openai_functions.js +0 -1
- package/output_parsers/openai_tools.cjs +0 -1
- package/output_parsers/openai_tools.d.cts +0 -1
- package/output_parsers/openai_tools.d.ts +0 -1
- package/output_parsers/openai_tools.js +0 -1
- package/output_parsers.cjs +0 -1
- package/output_parsers.d.cts +0 -1
- package/output_parsers.d.ts +0 -1
- package/output_parsers.js +0 -1
- package/outputs.cjs +0 -1
- package/outputs.d.cts +0 -1
- package/outputs.d.ts +0 -1
- package/outputs.js +0 -1
- package/prompt_values.cjs +0 -1
- package/prompt_values.d.cts +0 -1
- package/prompt_values.d.ts +0 -1
- package/prompt_values.js +0 -1
- package/prompts.cjs +0 -1
- package/prompts.d.cts +0 -1
- package/prompts.d.ts +0 -1
- package/prompts.js +0 -1
- package/retrievers/document_compressors.cjs +0 -1
- package/retrievers/document_compressors.d.cts +0 -1
- package/retrievers/document_compressors.d.ts +0 -1
- package/retrievers/document_compressors.js +0 -1
- package/retrievers.cjs +0 -1
- package/retrievers.d.cts +0 -1
- package/retrievers.d.ts +0 -1
- package/retrievers.js +0 -1
- package/runnables/graph.cjs +0 -1
- package/runnables/graph.d.cts +0 -1
- package/runnables/graph.d.ts +0 -1
- package/runnables/graph.js +0 -1
- package/runnables.cjs +0 -1
- package/runnables.d.cts +0 -1
- package/runnables.d.ts +0 -1
- package/runnables.js +0 -1
- package/singletons.cjs +0 -1
- package/singletons.d.cts +0 -1
- package/singletons.d.ts +0 -1
- package/singletons.js +0 -1
- package/stores.cjs +0 -1
- package/stores.d.cts +0 -1
- package/stores.d.ts +0 -1
- package/stores.js +0 -1
- package/structured_query.cjs +0 -1
- package/structured_query.d.cts +0 -1
- package/structured_query.d.ts +0 -1
- package/structured_query.js +0 -1
- package/tools.cjs +0 -1
- package/tools.d.cts +0 -1
- package/tools.d.ts +0 -1
- package/tools.js +0 -1
- package/tracers/base.cjs +0 -1
- package/tracers/base.d.cts +0 -1
- package/tracers/base.d.ts +0 -1
- package/tracers/base.js +0 -1
- package/tracers/console.cjs +0 -1
- package/tracers/console.d.cts +0 -1
- package/tracers/console.d.ts +0 -1
- package/tracers/console.js +0 -1
- package/tracers/log_stream.cjs +0 -1
- package/tracers/log_stream.d.cts +0 -1
- package/tracers/log_stream.d.ts +0 -1
- package/tracers/log_stream.js +0 -1
- package/tracers/run_collector.cjs +0 -1
- package/tracers/run_collector.d.cts +0 -1
- package/tracers/run_collector.d.ts +0 -1
- package/tracers/run_collector.js +0 -1
- package/tracers/tracer_langchain.cjs +0 -1
- package/tracers/tracer_langchain.d.cts +0 -1
- package/tracers/tracer_langchain.d.ts +0 -1
- package/tracers/tracer_langchain.js +0 -1
- package/types/stream.cjs +0 -1
- package/types/stream.d.cts +0 -1
- package/types/stream.d.ts +0 -1
- package/types/stream.js +0 -1
- package/utils/async_caller.cjs +0 -1
- package/utils/async_caller.d.cts +0 -1
- package/utils/async_caller.d.ts +0 -1
- package/utils/async_caller.js +0 -1
- package/utils/chunk_array.cjs +0 -1
- package/utils/chunk_array.d.cts +0 -1
- package/utils/chunk_array.d.ts +0 -1
- package/utils/chunk_array.js +0 -1
- package/utils/context.cjs +0 -1
- package/utils/context.d.cts +0 -1
- package/utils/context.d.ts +0 -1
- package/utils/context.js +0 -1
- package/utils/env.cjs +0 -1
- package/utils/env.d.cts +0 -1
- package/utils/env.d.ts +0 -1
- package/utils/env.js +0 -1
- package/utils/event_source_parse.cjs +0 -1
- package/utils/event_source_parse.d.cts +0 -1
- package/utils/event_source_parse.d.ts +0 -1
- package/utils/event_source_parse.js +0 -1
- package/utils/format.cjs +0 -1
- package/utils/format.d.cts +0 -1
- package/utils/format.d.ts +0 -1
- package/utils/format.js +0 -1
- package/utils/function_calling.cjs +0 -1
- package/utils/function_calling.d.cts +0 -1
- package/utils/function_calling.d.ts +0 -1
- package/utils/function_calling.js +0 -1
- package/utils/hash.cjs +0 -1
- package/utils/hash.d.cts +0 -1
- package/utils/hash.d.ts +0 -1
- package/utils/hash.js +0 -1
- package/utils/json_patch.cjs +0 -1
- package/utils/json_patch.d.cts +0 -1
- package/utils/json_patch.d.ts +0 -1
- package/utils/json_patch.js +0 -1
- package/utils/json_schema.cjs +0 -1
- package/utils/json_schema.d.cts +0 -1
- package/utils/json_schema.d.ts +0 -1
- package/utils/json_schema.js +0 -1
- package/utils/math.cjs +0 -1
- package/utils/math.d.cts +0 -1
- package/utils/math.d.ts +0 -1
- package/utils/math.js +0 -1
- package/utils/ssrf.cjs +0 -1
- package/utils/ssrf.d.cts +0 -1
- package/utils/ssrf.d.ts +0 -1
- package/utils/ssrf.js +0 -1
- package/utils/standard_schema.cjs +0 -1
- package/utils/standard_schema.d.cts +0 -1
- package/utils/standard_schema.d.ts +0 -1
- package/utils/standard_schema.js +0 -1
- package/utils/stream.cjs +0 -1
- package/utils/stream.d.cts +0 -1
- package/utils/stream.d.ts +0 -1
- package/utils/stream.js +0 -1
- package/utils/testing.cjs +0 -1
- package/utils/testing.d.cts +0 -1
- package/utils/testing.d.ts +0 -1
- package/utils/testing.js +0 -1
- package/utils/tiktoken.cjs +0 -1
- package/utils/tiktoken.d.cts +0 -1
- package/utils/tiktoken.d.ts +0 -1
- package/utils/tiktoken.js +0 -1
- package/utils/types.cjs +0 -1
- package/utils/types.d.cts +0 -1
- package/utils/types.d.ts +0 -1
- package/utils/types.js +0 -1
- package/vectorstores.cjs +0 -1
- package/vectorstores.d.cts +0 -1
- package/vectorstores.d.ts +0 -1
- package/vectorstores.js +0 -1
|
@@ -0,0 +1,216 @@
|
|
|
1
|
+
import { __exportAll } from "../_virtual/_rolldown/runtime.js";
|
|
2
|
+
import { isAIMessageChunk } from "../messages/ai.js";
|
|
3
|
+
//#region src/language_models/compat.ts
|
|
4
|
+
/**
|
|
5
|
+
* Compatibility bridge: converts legacy `_streamResponseChunks`
|
|
6
|
+
* (`ChatGenerationChunk` / `AIMessageChunk`) output to the new
|
|
7
|
+
* `ChatModelStreamEvent` protocol.
|
|
8
|
+
*
|
|
9
|
+
* @module
|
|
10
|
+
*/
|
|
11
|
+
var compat_exports = /* @__PURE__ */ __exportAll({
|
|
12
|
+
convertChunksToEvents: () => convertChunksToEvents,
|
|
13
|
+
finalizeContentBlock: () => finalizeContentBlock
|
|
14
|
+
});
|
|
15
|
+
/**
|
|
16
|
+
* Convert an async iterable of legacy `ChatGenerationChunk`s into
|
|
17
|
+
* `ChatModelStreamEvent`s with typed deltas.
|
|
18
|
+
*/
|
|
19
|
+
async function* convertChunksToEvents(chunks, options) {
|
|
20
|
+
const activeBlocks = /* @__PURE__ */ new Map();
|
|
21
|
+
let messageStarted = false;
|
|
22
|
+
let lastUsage;
|
|
23
|
+
for await (const chunk of chunks) {
|
|
24
|
+
options?.signal?.throwIfAborted();
|
|
25
|
+
const msg = chunk.message;
|
|
26
|
+
let usageHandledInStart = false;
|
|
27
|
+
if (!messageStarted) {
|
|
28
|
+
messageStarted = true;
|
|
29
|
+
const startEvent = {
|
|
30
|
+
type: "message-start",
|
|
31
|
+
id: msg.id ?? void 0
|
|
32
|
+
};
|
|
33
|
+
if (isAIMessageChunk(msg) && msg.usage_metadata) {
|
|
34
|
+
startEvent.usage = msg.usage_metadata;
|
|
35
|
+
lastUsage = { ...msg.usage_metadata };
|
|
36
|
+
usageHandledInStart = true;
|
|
37
|
+
}
|
|
38
|
+
yield startEvent;
|
|
39
|
+
}
|
|
40
|
+
const content = msg.content;
|
|
41
|
+
if (typeof content === "string") {
|
|
42
|
+
if (content !== "") {
|
|
43
|
+
const blockIndex = 0;
|
|
44
|
+
if (!activeBlocks.has(blockIndex)) {
|
|
45
|
+
const initial = {
|
|
46
|
+
type: "text",
|
|
47
|
+
text: ""
|
|
48
|
+
};
|
|
49
|
+
activeBlocks.set(blockIndex, {
|
|
50
|
+
type: "text",
|
|
51
|
+
accumulated: initial
|
|
52
|
+
});
|
|
53
|
+
yield {
|
|
54
|
+
type: "content-block-start",
|
|
55
|
+
index: blockIndex,
|
|
56
|
+
content: initial
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
const block = activeBlocks.get(blockIndex);
|
|
60
|
+
block.accumulated = {
|
|
61
|
+
...block.accumulated,
|
|
62
|
+
text: (block.accumulated.text ?? "") + content
|
|
63
|
+
};
|
|
64
|
+
yield {
|
|
65
|
+
type: "content-block-delta",
|
|
66
|
+
index: blockIndex,
|
|
67
|
+
content: {
|
|
68
|
+
type: "text",
|
|
69
|
+
text: content
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
}
|
|
73
|
+
} else if (Array.isArray(content)) for (const part of content) {
|
|
74
|
+
const blockIndex = typeof part.index === "number" ? part.index : activeBlocks.size;
|
|
75
|
+
if (!activeBlocks.has(blockIndex)) {
|
|
76
|
+
activeBlocks.set(blockIndex, {
|
|
77
|
+
type: part.type,
|
|
78
|
+
accumulated: { ...part }
|
|
79
|
+
});
|
|
80
|
+
yield {
|
|
81
|
+
type: "content-block-start",
|
|
82
|
+
index: blockIndex,
|
|
83
|
+
content: { ...part }
|
|
84
|
+
};
|
|
85
|
+
} else {
|
|
86
|
+
const block = activeBlocks.get(blockIndex);
|
|
87
|
+
block.accumulated = applyDeltaToBlock(block.accumulated, part);
|
|
88
|
+
yield {
|
|
89
|
+
type: "content-block-delta",
|
|
90
|
+
index: blockIndex,
|
|
91
|
+
content: part
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
if (isAIMessageChunk(msg) && msg.tool_call_chunks && msg.tool_call_chunks.length > 0) for (const toolChunk of msg.tool_call_chunks) {
|
|
96
|
+
const blockIndex = typeof toolChunk.index === "number" ? toolChunk.index : activeBlocks.size;
|
|
97
|
+
if (!activeBlocks.has(blockIndex)) {
|
|
98
|
+
const initial = {
|
|
99
|
+
type: "tool_call_chunk",
|
|
100
|
+
id: toolChunk.id,
|
|
101
|
+
name: toolChunk.name,
|
|
102
|
+
args: "",
|
|
103
|
+
index: blockIndex
|
|
104
|
+
};
|
|
105
|
+
activeBlocks.set(blockIndex, {
|
|
106
|
+
type: "tool_call_chunk",
|
|
107
|
+
accumulated: initial
|
|
108
|
+
});
|
|
109
|
+
yield {
|
|
110
|
+
type: "content-block-start",
|
|
111
|
+
index: blockIndex,
|
|
112
|
+
content: initial
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
const block = activeBlocks.get(blockIndex);
|
|
116
|
+
const acc = block.accumulated;
|
|
117
|
+
if (toolChunk.id != null) acc.id = toolChunk.id;
|
|
118
|
+
if (toolChunk.name != null) acc.name = toolChunk.name;
|
|
119
|
+
acc.args = (acc.args ?? "") + (toolChunk.args ?? "");
|
|
120
|
+
yield {
|
|
121
|
+
type: "content-block-delta",
|
|
122
|
+
index: blockIndex,
|
|
123
|
+
content: { ...block.accumulated }
|
|
124
|
+
};
|
|
125
|
+
}
|
|
126
|
+
if (!usageHandledInStart && isAIMessageChunk(msg) && msg.usage_metadata) {
|
|
127
|
+
const chunkUsage = msg.usage_metadata;
|
|
128
|
+
if (!lastUsage) lastUsage = { ...chunkUsage };
|
|
129
|
+
else lastUsage = {
|
|
130
|
+
input_tokens: lastUsage.input_tokens + chunkUsage.input_tokens,
|
|
131
|
+
output_tokens: lastUsage.output_tokens + chunkUsage.output_tokens,
|
|
132
|
+
total_tokens: lastUsage.total_tokens + chunkUsage.total_tokens
|
|
133
|
+
};
|
|
134
|
+
yield {
|
|
135
|
+
type: "usage",
|
|
136
|
+
usage: { ...lastUsage }
|
|
137
|
+
};
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
for (const [index, block] of activeBlocks) yield {
|
|
141
|
+
type: "content-block-finish",
|
|
142
|
+
index,
|
|
143
|
+
content: finalizeContentBlock(block.accumulated)
|
|
144
|
+
};
|
|
145
|
+
yield {
|
|
146
|
+
type: "message-finish",
|
|
147
|
+
reason: "stop",
|
|
148
|
+
...lastUsage ? { usage: lastUsage } : {}
|
|
149
|
+
};
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Apply a typed delta to an accumulated content block.
|
|
153
|
+
* @internal
|
|
154
|
+
*/
|
|
155
|
+
function applyDeltaToBlock(block, delta) {
|
|
156
|
+
if (block.type !== delta.type) return { ...delta };
|
|
157
|
+
switch (delta.type) {
|
|
158
|
+
case "text": return {
|
|
159
|
+
...block,
|
|
160
|
+
...delta,
|
|
161
|
+
text: (block.text ?? "") + delta.text
|
|
162
|
+
};
|
|
163
|
+
case "reasoning": return {
|
|
164
|
+
...block,
|
|
165
|
+
...delta,
|
|
166
|
+
reasoning: (block.reasoning ?? "") + delta.reasoning
|
|
167
|
+
};
|
|
168
|
+
case "tool_call_chunk":
|
|
169
|
+
case "server_tool_call_chunk": {
|
|
170
|
+
const merged = {
|
|
171
|
+
...block,
|
|
172
|
+
...delta
|
|
173
|
+
};
|
|
174
|
+
if (delta.id == null && "id" in block && block.id != null) merged.id = block.id;
|
|
175
|
+
if (delta.name == null && "name" in block && block.name != null) merged.name = block.name;
|
|
176
|
+
merged.args = `${("args" in block ? block.args : "") ?? ""}${delta.args ?? ""}`;
|
|
177
|
+
return merged;
|
|
178
|
+
}
|
|
179
|
+
default: return {
|
|
180
|
+
...block,
|
|
181
|
+
...delta
|
|
182
|
+
};
|
|
183
|
+
}
|
|
184
|
+
}
|
|
185
|
+
/**
|
|
186
|
+
* Finalize a content block for the finish event.
|
|
187
|
+
* For tool calls, parse the accumulated JSON args string.
|
|
188
|
+
*/
|
|
189
|
+
function finalizeContentBlock(block) {
|
|
190
|
+
if (block.type === "tool_call_chunk") {
|
|
191
|
+
const chunk = block;
|
|
192
|
+
let parsedArgs;
|
|
193
|
+
try {
|
|
194
|
+
parsedArgs = JSON.parse(chunk.args ?? "{}");
|
|
195
|
+
} catch {
|
|
196
|
+
return {
|
|
197
|
+
type: "invalid_tool_call",
|
|
198
|
+
id: chunk.id,
|
|
199
|
+
name: chunk.name,
|
|
200
|
+
args: chunk.args,
|
|
201
|
+
error: "Failed to parse tool call arguments as JSON"
|
|
202
|
+
};
|
|
203
|
+
}
|
|
204
|
+
return {
|
|
205
|
+
type: "tool_call",
|
|
206
|
+
id: chunk.id,
|
|
207
|
+
name: chunk.name,
|
|
208
|
+
args: parsedArgs
|
|
209
|
+
};
|
|
210
|
+
}
|
|
211
|
+
return block;
|
|
212
|
+
}
|
|
213
|
+
//#endregion
|
|
214
|
+
export { compat_exports, convertChunksToEvents, finalizeContentBlock };
|
|
215
|
+
|
|
216
|
+
//# sourceMappingURL=compat.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"compat.js","names":[],"sources":["../../src/language_models/compat.ts"],"sourcesContent":["/**\n * Compatibility bridge: converts legacy `_streamResponseChunks`\n * (`ChatGenerationChunk` / `AIMessageChunk`) output to the new\n * `ChatModelStreamEvent` protocol.\n *\n * @module\n */\n\nimport { isAIMessageChunk } from \"../messages/ai.js\";\nimport type { ContentBlock } from \"../messages/content/index.js\";\nimport type { ChatGenerationChunk } from \"../outputs.js\";\nimport type { ChatModelStreamEvent } from \"./event.js\";\n\n/**\n * Convert an async iterable of legacy `ChatGenerationChunk`s into\n * `ChatModelStreamEvent`s with typed deltas.\n */\nexport async function* convertChunksToEvents(\n chunks: AsyncIterable<ChatGenerationChunk>,\n options?: { signal?: AbortSignal }\n): AsyncGenerator<ChatModelStreamEvent> {\n const activeBlocks = new Map<\n number,\n { type: string; accumulated: ContentBlock }\n >();\n let messageStarted = false;\n let lastUsage:\n | { input_tokens: number; output_tokens: number; total_tokens: number }\n | undefined;\n\n for await (const chunk of chunks) {\n options?.signal?.throwIfAborted();\n\n const msg = chunk.message;\n\n // Message start\n let usageHandledInStart = false;\n if (!messageStarted) {\n messageStarted = true;\n const startEvent: ChatModelStreamEvent = {\n type: \"message-start\" as const,\n id: msg.id ?? undefined,\n };\n if (isAIMessageChunk(msg) && msg.usage_metadata) {\n (startEvent as { usage?: unknown }).usage = msg.usage_metadata;\n lastUsage = { ...msg.usage_metadata };\n usageHandledInStart = true;\n }\n yield startEvent;\n }\n\n // Process content\n const content = msg.content;\n if (typeof content === \"string\") {\n if (content !== \"\") {\n const blockIndex = 0;\n if (!activeBlocks.has(blockIndex)) {\n const initial: ContentBlock.Text = { type: \"text\", text: \"\" };\n activeBlocks.set(blockIndex, {\n type: \"text\",\n accumulated: initial,\n });\n yield {\n type: \"content-block-start\" as const,\n index: blockIndex,\n content: initial,\n };\n }\n const block = activeBlocks.get(blockIndex)!;\n block.accumulated = {\n ...block.accumulated,\n text: ((block.accumulated as { text?: string }).text ?? \"\") + content,\n };\n yield {\n type: \"content-block-delta\" as const,\n index: blockIndex,\n content: { type: \"text\" as const, text: content },\n };\n }\n } else if (Array.isArray(content)) {\n for (const part of content) {\n const blockIndex =\n typeof part.index === \"number\" ? part.index : activeBlocks.size;\n\n if (!activeBlocks.has(blockIndex)) {\n activeBlocks.set(blockIndex, {\n type: part.type,\n accumulated: { ...part },\n });\n yield {\n type: \"content-block-start\" as const,\n index: blockIndex,\n content: { ...part },\n };\n } else {\n const block = activeBlocks.get(blockIndex)!;\n block.accumulated = applyDeltaToBlock(block.accumulated, part);\n yield {\n type: \"content-block-delta\" as const,\n index: blockIndex,\n content: part,\n };\n }\n }\n }\n\n // Tool call chunks\n if (\n isAIMessageChunk(msg) &&\n msg.tool_call_chunks &&\n msg.tool_call_chunks.length > 0\n ) {\n for (const toolChunk of msg.tool_call_chunks) {\n const blockIndex =\n typeof toolChunk.index === \"number\"\n ? toolChunk.index\n : activeBlocks.size;\n\n if (!activeBlocks.has(blockIndex)) {\n const initial: ContentBlock = {\n type: \"tool_call_chunk\" as const,\n id: toolChunk.id,\n name: toolChunk.name,\n args: \"\",\n index: blockIndex,\n };\n activeBlocks.set(blockIndex, {\n type: \"tool_call_chunk\",\n accumulated: initial,\n });\n yield {\n type: \"content-block-start\" as const,\n index: blockIndex,\n content: initial,\n };\n }\n\n // Accumulate tool call args internally, emit incremental content chunks.\n const block = activeBlocks.get(blockIndex)!;\n const acc = block.accumulated as {\n args?: string;\n id?: string;\n name?: string;\n };\n if (toolChunk.id != null) acc.id = toolChunk.id;\n if (toolChunk.name != null) acc.name = toolChunk.name;\n acc.args = (acc.args ?? \"\") + (toolChunk.args ?? \"\");\n yield {\n type: \"content-block-delta\" as const,\n index: blockIndex,\n content: { ...(block.accumulated as ContentBlock) },\n };\n }\n }\n\n // Usage\n if (!usageHandledInStart && isAIMessageChunk(msg) && msg.usage_metadata) {\n const chunkUsage = msg.usage_metadata;\n if (!lastUsage) {\n lastUsage = { ...chunkUsage };\n } else {\n lastUsage = {\n input_tokens: lastUsage.input_tokens + chunkUsage.input_tokens,\n output_tokens: lastUsage.output_tokens + chunkUsage.output_tokens,\n total_tokens: lastUsage.total_tokens + chunkUsage.total_tokens,\n };\n }\n yield { type: \"usage\" as const, usage: { ...lastUsage } };\n }\n }\n\n // Finish all blocks\n for (const [index, block] of activeBlocks) {\n const finalized = finalizeContentBlock(block.accumulated);\n yield {\n type: \"content-block-finish\" as const,\n index,\n content: finalized,\n };\n }\n\n yield {\n type: \"message-finish\" as const,\n reason: \"stop\" as const,\n ...(lastUsage ? { usage: lastUsage } : {}),\n };\n}\n\n/**\n * Apply a typed delta to an accumulated content block.\n * @internal\n */\nfunction applyDeltaToBlock(\n block: ContentBlock,\n delta: ContentBlock\n): ContentBlock {\n if (block.type !== delta.type) {\n return { ...delta };\n }\n\n switch (delta.type) {\n case \"text\":\n return {\n ...block,\n ...delta,\n text: ((block as { text?: string }).text ?? \"\") + delta.text,\n };\n case \"reasoning\":\n return {\n ...block,\n ...delta,\n reasoning:\n ((block as { reasoning?: string }).reasoning ?? \"\") + delta.reasoning,\n };\n case \"tool_call_chunk\":\n case \"server_tool_call_chunk\": {\n const merged = { ...block, ...delta } as Record<string, unknown>;\n if (delta.id == null && \"id\" in block && block.id != null) {\n merged.id = block.id;\n }\n if (delta.name == null && \"name\" in block && block.name != null) {\n merged.name = block.name;\n }\n merged.args = `${(\"args\" in block ? block.args : \"\") ?? \"\"}${delta.args ?? \"\"}`;\n return merged as unknown as ContentBlock;\n }\n default:\n return { ...block, ...delta };\n }\n}\n\n/**\n * Finalize a content block for the finish event.\n * For tool calls, parse the accumulated JSON args string.\n */\nexport function finalizeContentBlock(block: ContentBlock): ContentBlock {\n if (block.type === \"tool_call_chunk\") {\n const chunk = block as ContentBlock.Tools.ToolCallChunk;\n let parsedArgs: unknown;\n try {\n parsedArgs = JSON.parse(chunk.args ?? \"{}\");\n } catch {\n return {\n type: \"invalid_tool_call\" as const,\n id: chunk.id,\n name: chunk.name,\n args: chunk.args,\n error: \"Failed to parse tool call arguments as JSON\",\n } as ContentBlock.Tools.InvalidToolCall;\n }\n return {\n type: \"tool_call\" as const,\n id: chunk.id,\n name: chunk.name!,\n args: parsedArgs,\n } as ContentBlock.Tools.ToolCall;\n }\n\n return block;\n}\n"],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
|
|
2
|
+
//#region src/language_models/event.ts
|
|
3
|
+
var event_exports = /* @__PURE__ */ require("../_virtual/_rolldown/runtime.cjs").__exportAll({});
|
|
4
|
+
//#endregion
|
|
5
|
+
Object.defineProperty(exports, "event_exports", {
|
|
6
|
+
enumerable: true,
|
|
7
|
+
get: function() {
|
|
8
|
+
return event_exports;
|
|
9
|
+
}
|
|
10
|
+
});
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=event.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.cjs","names":[],"sources":["../../src/language_models/event.ts"],"sourcesContent":["/**\n * Chat model streaming event protocol.\n *\n * Defines a content-block-centric event model for streaming chat model responses.\n * Events carry LangChain {@link ContentBlock} types on lifecycle boundaries\n * and as incremental content updates during streaming.\n *\n * ## Design Principles\n *\n * 1. **Content-block deltas use the content block shape.** Text, reasoning,\n * and tool-call chunks are emitted as partial {@link ContentBlock} values\n * with explicit append semantics.\n *\n * 2. **Lifecycle completeness.** Every streamable entity has explicit start and finish\n * events. Consumers never need to infer boundaries from absence of events.\n *\n * 3. **Interleaving allowed.** Content blocks may interleave (e.g., parallel tool calls).\n * The only invariant: a block's start precedes its deltas, and its deltas precede\n * its finish. No ordering constraint between different blocks.\n *\n * 4. **Provider passthrough.** Native provider events that don't map to standard types\n * are forwarded as {@link ProviderEvent} rather than silently dropped.\n *\n * ## Lifecycle Contract\n *\n * ```\n * MessageStart\n * -> ContentBlockStart(index=0, content=...)\n * -> ContentBlockDelta(index=0, content={ type: \"text\", text: \"Hello\" })\n * -> ContentBlockDelta(index=0, content={ type: \"text\", text: \" world\" })\n * -> ContentBlockFinish(index=0, content=...)\n * -> UsageUpdate(...)\n * -> MessageFinish(reason, usage?)\n * ```\n *\n * @module\n */\n\nimport type { ContentBlock } from \"../messages/content/index.js\";\nimport type { UsageMetadata } from \"../messages/metadata.js\";\n\n// ─── Message Lifecycle ──────────────────────────────────────────\n\n/**\n * Emitted once at the start of a model response.\n */\nexport interface MessageStartEvent {\n type: \"message-start\";\n /** Optional message ID assigned by the provider. */\n id?: string;\n /**\n * Initial usage snapshot, if the provider reports input token counts\n * before content begins streaming (e.g., Anthropic's `message_start`).\n */\n usage?: UsageMetadata;\n}\n\n/**\n * Finish reason for a model response.\n *\n * - `\"stop\"`: Natural end of generation.\n * - `\"length\"`: Hit max token limit.\n * - `\"tool_use\"`: Model is requesting tool execution.\n * - `\"content_filter\"`: Content was filtered by safety systems.\n */\nexport type FinishReason = \"stop\" | \"length\" | \"tool_use\" | \"content_filter\";\n\n/**\n * Emitted once when the model response is complete.\n */\nexport interface MessageFinishEvent {\n type: \"message-finish\";\n /** Why the model stopped generating. */\n reason?: FinishReason;\n /** Final usage snapshot. */\n usage?: UsageMetadata;\n /** Provider-specific response metadata (model name, response ID, headers, etc.). */\n responseMetadata?: Record<string, unknown>;\n}\n\n// ─── Content Block Lifecycle ────────────────────────────────────\n\n/**\n * Emitted when a new content block begins streaming.\n *\n * @example\n * ```ts\n * { type: \"content-block-start\", index: 0,\n * content: { type: \"text\", text: \"\" } }\n * ```\n */\nexport interface ContentBlockStartEvent {\n type: \"content-block-start\";\n /** Positional index of this block within the message. */\n index: number;\n /** Initial state of the content block. */\n content: ContentBlock;\n}\n\n/**\n * Emitted for each incremental update within a content block.\n *\n * The `content` field carries the incremental content block update.\n * Accumulation rules:\n * - `text` → append `text` to the block's text field\n * - `reasoning` → append `reasoning` to the block's reasoning field\n * - `tool_call_chunk` / `server_tool_call_chunk` → append `args`,\n * preserving stable `id`/`name` when later chunks omit them\n * - all other fields are shallow-merged\n *\n * @example\n * ```ts\n * // Text token\n * { type: \"content-block-delta\", index: 0,\n * content: { type: \"text\", text: \" world\" } }\n *\n * // Tool call args chunk\n * { type: \"content-block-delta\", index: 1,\n * content: { type: \"tool_call_chunk\", args: '{\"q\":\"wea' } }\n *\n * // Provider-specific field (e.g., signature)\n * { type: \"content-block-delta\", index: 0,\n * content: { type: \"reasoning\", signature: \"sig_abc\" } }\n * ```\n */\nexport interface ContentBlockDeltaEvent {\n type: \"content-block-delta\";\n /** Positional index of the block being updated. */\n index: number;\n /** Incremental content block update. */\n content: ContentBlock;\n}\n\n/**\n * Emitted when a content block is complete.\n *\n * @example\n * ```ts\n * { type: \"content-block-finish\", index: 0,\n * content: { type: \"text\", text: \"Hello world\" } }\n * ```\n */\nexport interface ContentBlockFinishEvent {\n type: \"content-block-finish\";\n /** Positional index of the completed block. */\n index: number;\n /** Finalized content block. */\n content: ContentBlock;\n}\n\n// ─── Usage ──────────────────────────────────────────────────────\n\n/**\n * Emitted whenever the provider reports updated usage information.\n * Each event carries a **running snapshot** (not an additive delta).\n */\nexport interface UsageUpdateEvent {\n type: \"usage\";\n /** Current usage snapshot. */\n usage: UsageMetadata;\n}\n\n// ─── Provider Passthrough ───────────────────────────────────────\n\n/**\n * Passthrough for native provider events that don't map to standard types.\n */\nexport interface ProviderEvent {\n type: \"provider\";\n /** Provider identifier (e.g., `\"openai\"`, `\"anthropic\"`, `\"google\"`). */\n provider: string;\n /** Raw event type name from the provider SDK. */\n name: string;\n /** Raw event payload from the provider SDK. */\n payload: unknown;\n}\n\n// ─── Error ──────────────────────────────────────────────────────\n\n/**\n * Emitted on unrecoverable stream errors.\n */\nexport interface StreamErrorEvent {\n type: \"error\";\n /** Human-readable error message. */\n message: string;\n /** Optional error code for programmatic handling. */\n code?: string;\n}\n\n// ─── Union ──────────────────────────────────────────────────────\n\n/**\n * Union of all chat model stream event types.\n */\nexport type ChatModelStreamEvent =\n | MessageStartEvent\n | MessageFinishEvent\n | ContentBlockStartEvent\n | ContentBlockDeltaEvent\n | ContentBlockFinishEvent\n | UsageUpdateEvent\n | ProviderEvent\n | StreamErrorEvent;\n"],"mappings":""}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { ContentBlock } from "../messages/content/index.cjs";
|
|
2
|
+
import { UsageMetadata } from "../messages/metadata.cjs";
|
|
3
|
+
|
|
4
|
+
//#region src/language_models/event.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Emitted once at the start of a model response.
|
|
7
|
+
*/
|
|
8
|
+
interface MessageStartEvent {
|
|
9
|
+
type: "message-start";
|
|
10
|
+
/** Optional message ID assigned by the provider. */
|
|
11
|
+
id?: string;
|
|
12
|
+
/**
|
|
13
|
+
* Initial usage snapshot, if the provider reports input token counts
|
|
14
|
+
* before content begins streaming (e.g., Anthropic's `message_start`).
|
|
15
|
+
*/
|
|
16
|
+
usage?: UsageMetadata;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Finish reason for a model response.
|
|
20
|
+
*
|
|
21
|
+
* - `"stop"`: Natural end of generation.
|
|
22
|
+
* - `"length"`: Hit max token limit.
|
|
23
|
+
* - `"tool_use"`: Model is requesting tool execution.
|
|
24
|
+
* - `"content_filter"`: Content was filtered by safety systems.
|
|
25
|
+
*/
|
|
26
|
+
type FinishReason = "stop" | "length" | "tool_use" | "content_filter";
|
|
27
|
+
/**
|
|
28
|
+
* Emitted once when the model response is complete.
|
|
29
|
+
*/
|
|
30
|
+
interface MessageFinishEvent {
|
|
31
|
+
type: "message-finish";
|
|
32
|
+
/** Why the model stopped generating. */
|
|
33
|
+
reason?: FinishReason;
|
|
34
|
+
/** Final usage snapshot. */
|
|
35
|
+
usage?: UsageMetadata;
|
|
36
|
+
/** Provider-specific response metadata (model name, response ID, headers, etc.). */
|
|
37
|
+
responseMetadata?: Record<string, unknown>;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Emitted when a new content block begins streaming.
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```ts
|
|
44
|
+
* { type: "content-block-start", index: 0,
|
|
45
|
+
* content: { type: "text", text: "" } }
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
interface ContentBlockStartEvent {
|
|
49
|
+
type: "content-block-start";
|
|
50
|
+
/** Positional index of this block within the message. */
|
|
51
|
+
index: number;
|
|
52
|
+
/** Initial state of the content block. */
|
|
53
|
+
content: ContentBlock;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Emitted for each incremental update within a content block.
|
|
57
|
+
*
|
|
58
|
+
* The `content` field carries the incremental content block update.
|
|
59
|
+
* Accumulation rules:
|
|
60
|
+
* - `text` → append `text` to the block's text field
|
|
61
|
+
* - `reasoning` → append `reasoning` to the block's reasoning field
|
|
62
|
+
* - `tool_call_chunk` / `server_tool_call_chunk` → append `args`,
|
|
63
|
+
* preserving stable `id`/`name` when later chunks omit them
|
|
64
|
+
* - all other fields are shallow-merged
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```ts
|
|
68
|
+
* // Text token
|
|
69
|
+
* { type: "content-block-delta", index: 0,
|
|
70
|
+
* content: { type: "text", text: " world" } }
|
|
71
|
+
*
|
|
72
|
+
* // Tool call args chunk
|
|
73
|
+
* { type: "content-block-delta", index: 1,
|
|
74
|
+
* content: { type: "tool_call_chunk", args: '{"q":"wea' } }
|
|
75
|
+
*
|
|
76
|
+
* // Provider-specific field (e.g., signature)
|
|
77
|
+
* { type: "content-block-delta", index: 0,
|
|
78
|
+
* content: { type: "reasoning", signature: "sig_abc" } }
|
|
79
|
+
* ```
|
|
80
|
+
*/
|
|
81
|
+
interface ContentBlockDeltaEvent {
|
|
82
|
+
type: "content-block-delta";
|
|
83
|
+
/** Positional index of the block being updated. */
|
|
84
|
+
index: number;
|
|
85
|
+
/** Incremental content block update. */
|
|
86
|
+
content: ContentBlock;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Emitted when a content block is complete.
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* ```ts
|
|
93
|
+
* { type: "content-block-finish", index: 0,
|
|
94
|
+
* content: { type: "text", text: "Hello world" } }
|
|
95
|
+
* ```
|
|
96
|
+
*/
|
|
97
|
+
interface ContentBlockFinishEvent {
|
|
98
|
+
type: "content-block-finish";
|
|
99
|
+
/** Positional index of the completed block. */
|
|
100
|
+
index: number;
|
|
101
|
+
/** Finalized content block. */
|
|
102
|
+
content: ContentBlock;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Emitted whenever the provider reports updated usage information.
|
|
106
|
+
* Each event carries a **running snapshot** (not an additive delta).
|
|
107
|
+
*/
|
|
108
|
+
interface UsageUpdateEvent {
|
|
109
|
+
type: "usage";
|
|
110
|
+
/** Current usage snapshot. */
|
|
111
|
+
usage: UsageMetadata;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Passthrough for native provider events that don't map to standard types.
|
|
115
|
+
*/
|
|
116
|
+
interface ProviderEvent {
|
|
117
|
+
type: "provider";
|
|
118
|
+
/** Provider identifier (e.g., `"openai"`, `"anthropic"`, `"google"`). */
|
|
119
|
+
provider: string;
|
|
120
|
+
/** Raw event type name from the provider SDK. */
|
|
121
|
+
name: string;
|
|
122
|
+
/** Raw event payload from the provider SDK. */
|
|
123
|
+
payload: unknown;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Emitted on unrecoverable stream errors.
|
|
127
|
+
*/
|
|
128
|
+
interface StreamErrorEvent {
|
|
129
|
+
type: "error";
|
|
130
|
+
/** Human-readable error message. */
|
|
131
|
+
message: string;
|
|
132
|
+
/** Optional error code for programmatic handling. */
|
|
133
|
+
code?: string;
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Union of all chat model stream event types.
|
|
137
|
+
*/
|
|
138
|
+
type ChatModelStreamEvent = MessageStartEvent | MessageFinishEvent | ContentBlockStartEvent | ContentBlockDeltaEvent | ContentBlockFinishEvent | UsageUpdateEvent | ProviderEvent | StreamErrorEvent;
|
|
139
|
+
//#endregion
|
|
140
|
+
export { ChatModelStreamEvent, ContentBlockDeltaEvent, ContentBlockFinishEvent, ContentBlockStartEvent, FinishReason, MessageFinishEvent, MessageStartEvent, ProviderEvent, StreamErrorEvent, UsageUpdateEvent };
|
|
141
|
+
//# sourceMappingURL=event.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.d.cts","names":[],"sources":["../../src/language_models/event.ts"],"mappings":";;;;;;;UA8CiB,iBAAA;EACf,IAAA;EAiDqB;EA/CrB,EAAA;EA4Ee;;;;EAvEf,KAAA,GAAQ,aAAA;AAAA;;;;;AAwFV;;;;KA7EY,YAAA;;;;UAKK,kBAAA;EACf,IAAA;EAqFe;EAnFf,MAAA,GAAS,YAAA;;EAET,KAAA,GAAQ,aAAA;EAkFR;EAhFA,gBAAA,GAAmB,MAAA;AAAA;;;AA0FrB;;;;;;;UA5EiB,sBAAA;EACf,IAAA;EAkFO;EAhFP,KAAA;EAwF+B;EAtF/B,OAAA,EAAS,YAAA;AAAA;;;;;;AAmGX;;;;;;;;;;;;;;;;;;;;;UAtEiB,sBAAA;EACf,IAAA;;EAEA,KAAA;;EAEA,OAAA,EAAS,YAAA;AAAA;;;;;;;;;;UAYM,uBAAA;EACf,IAAA;;EAEA,KAAA;;EAEA,OAAA,EAAS,YAAA;AAAA;;;;;UASM,gBAAA;EACf,IAAA;;EAEA,KAAA,EAAO,aAAA;AAAA;;;;UAQQ,aAAA;EACf,IAAA;;EAEA,QAAA;;EAEA,IAAA;;EAEA,OAAA;AAAA;;;;UAQe,gBAAA;EACf,IAAA;;EAEA,OAAA;;EAEA,IAAA;AAAA;;;;KAQU,oBAAA,GACR,iBAAA,GACA,kBAAA,GACA,sBAAA,GACA,sBAAA,GACA,uBAAA,GACA,gBAAA,GACA,aAAA,GACA,gBAAA"}
|
|
@@ -0,0 +1,141 @@
|
|
|
1
|
+
import { ContentBlock } from "../messages/content/index.js";
|
|
2
|
+
import { UsageMetadata } from "../messages/metadata.js";
|
|
3
|
+
|
|
4
|
+
//#region src/language_models/event.d.ts
|
|
5
|
+
/**
|
|
6
|
+
* Emitted once at the start of a model response.
|
|
7
|
+
*/
|
|
8
|
+
interface MessageStartEvent {
|
|
9
|
+
type: "message-start";
|
|
10
|
+
/** Optional message ID assigned by the provider. */
|
|
11
|
+
id?: string;
|
|
12
|
+
/**
|
|
13
|
+
* Initial usage snapshot, if the provider reports input token counts
|
|
14
|
+
* before content begins streaming (e.g., Anthropic's `message_start`).
|
|
15
|
+
*/
|
|
16
|
+
usage?: UsageMetadata;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* Finish reason for a model response.
|
|
20
|
+
*
|
|
21
|
+
* - `"stop"`: Natural end of generation.
|
|
22
|
+
* - `"length"`: Hit max token limit.
|
|
23
|
+
* - `"tool_use"`: Model is requesting tool execution.
|
|
24
|
+
* - `"content_filter"`: Content was filtered by safety systems.
|
|
25
|
+
*/
|
|
26
|
+
type FinishReason = "stop" | "length" | "tool_use" | "content_filter";
|
|
27
|
+
/**
|
|
28
|
+
* Emitted once when the model response is complete.
|
|
29
|
+
*/
|
|
30
|
+
interface MessageFinishEvent {
|
|
31
|
+
type: "message-finish";
|
|
32
|
+
/** Why the model stopped generating. */
|
|
33
|
+
reason?: FinishReason;
|
|
34
|
+
/** Final usage snapshot. */
|
|
35
|
+
usage?: UsageMetadata;
|
|
36
|
+
/** Provider-specific response metadata (model name, response ID, headers, etc.). */
|
|
37
|
+
responseMetadata?: Record<string, unknown>;
|
|
38
|
+
}
|
|
39
|
+
/**
|
|
40
|
+
* Emitted when a new content block begins streaming.
|
|
41
|
+
*
|
|
42
|
+
* @example
|
|
43
|
+
* ```ts
|
|
44
|
+
* { type: "content-block-start", index: 0,
|
|
45
|
+
* content: { type: "text", text: "" } }
|
|
46
|
+
* ```
|
|
47
|
+
*/
|
|
48
|
+
interface ContentBlockStartEvent {
|
|
49
|
+
type: "content-block-start";
|
|
50
|
+
/** Positional index of this block within the message. */
|
|
51
|
+
index: number;
|
|
52
|
+
/** Initial state of the content block. */
|
|
53
|
+
content: ContentBlock;
|
|
54
|
+
}
|
|
55
|
+
/**
|
|
56
|
+
* Emitted for each incremental update within a content block.
|
|
57
|
+
*
|
|
58
|
+
* The `content` field carries the incremental content block update.
|
|
59
|
+
* Accumulation rules:
|
|
60
|
+
* - `text` → append `text` to the block's text field
|
|
61
|
+
* - `reasoning` → append `reasoning` to the block's reasoning field
|
|
62
|
+
* - `tool_call_chunk` / `server_tool_call_chunk` → append `args`,
|
|
63
|
+
* preserving stable `id`/`name` when later chunks omit them
|
|
64
|
+
* - all other fields are shallow-merged
|
|
65
|
+
*
|
|
66
|
+
* @example
|
|
67
|
+
* ```ts
|
|
68
|
+
* // Text token
|
|
69
|
+
* { type: "content-block-delta", index: 0,
|
|
70
|
+
* content: { type: "text", text: " world" } }
|
|
71
|
+
*
|
|
72
|
+
* // Tool call args chunk
|
|
73
|
+
* { type: "content-block-delta", index: 1,
|
|
74
|
+
* content: { type: "tool_call_chunk", args: '{"q":"wea' } }
|
|
75
|
+
*
|
|
76
|
+
* // Provider-specific field (e.g., signature)
|
|
77
|
+
* { type: "content-block-delta", index: 0,
|
|
78
|
+
* content: { type: "reasoning", signature: "sig_abc" } }
|
|
79
|
+
* ```
|
|
80
|
+
*/
|
|
81
|
+
interface ContentBlockDeltaEvent {
|
|
82
|
+
type: "content-block-delta";
|
|
83
|
+
/** Positional index of the block being updated. */
|
|
84
|
+
index: number;
|
|
85
|
+
/** Incremental content block update. */
|
|
86
|
+
content: ContentBlock;
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Emitted when a content block is complete.
|
|
90
|
+
*
|
|
91
|
+
* @example
|
|
92
|
+
* ```ts
|
|
93
|
+
* { type: "content-block-finish", index: 0,
|
|
94
|
+
* content: { type: "text", text: "Hello world" } }
|
|
95
|
+
* ```
|
|
96
|
+
*/
|
|
97
|
+
interface ContentBlockFinishEvent {
|
|
98
|
+
type: "content-block-finish";
|
|
99
|
+
/** Positional index of the completed block. */
|
|
100
|
+
index: number;
|
|
101
|
+
/** Finalized content block. */
|
|
102
|
+
content: ContentBlock;
|
|
103
|
+
}
|
|
104
|
+
/**
|
|
105
|
+
* Emitted whenever the provider reports updated usage information.
|
|
106
|
+
* Each event carries a **running snapshot** (not an additive delta).
|
|
107
|
+
*/
|
|
108
|
+
interface UsageUpdateEvent {
|
|
109
|
+
type: "usage";
|
|
110
|
+
/** Current usage snapshot. */
|
|
111
|
+
usage: UsageMetadata;
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Passthrough for native provider events that don't map to standard types.
|
|
115
|
+
*/
|
|
116
|
+
interface ProviderEvent {
|
|
117
|
+
type: "provider";
|
|
118
|
+
/** Provider identifier (e.g., `"openai"`, `"anthropic"`, `"google"`). */
|
|
119
|
+
provider: string;
|
|
120
|
+
/** Raw event type name from the provider SDK. */
|
|
121
|
+
name: string;
|
|
122
|
+
/** Raw event payload from the provider SDK. */
|
|
123
|
+
payload: unknown;
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Emitted on unrecoverable stream errors.
|
|
127
|
+
*/
|
|
128
|
+
interface StreamErrorEvent {
|
|
129
|
+
type: "error";
|
|
130
|
+
/** Human-readable error message. */
|
|
131
|
+
message: string;
|
|
132
|
+
/** Optional error code for programmatic handling. */
|
|
133
|
+
code?: string;
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Union of all chat model stream event types.
|
|
137
|
+
*/
|
|
138
|
+
type ChatModelStreamEvent = MessageStartEvent | MessageFinishEvent | ContentBlockStartEvent | ContentBlockDeltaEvent | ContentBlockFinishEvent | UsageUpdateEvent | ProviderEvent | StreamErrorEvent;
|
|
139
|
+
//#endregion
|
|
140
|
+
export { ChatModelStreamEvent, ContentBlockDeltaEvent, ContentBlockFinishEvent, ContentBlockStartEvent, FinishReason, MessageFinishEvent, MessageStartEvent, ProviderEvent, StreamErrorEvent, UsageUpdateEvent };
|
|
141
|
+
//# sourceMappingURL=event.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.d.ts","names":[],"sources":["../../src/language_models/event.ts"],"mappings":";;;;;;;UA8CiB,iBAAA;EACf,IAAA;EAiDqB;EA/CrB,EAAA;EA4Ee;;;;EAvEf,KAAA,GAAQ,aAAA;AAAA;;;;;AAwFV;;;;KA7EY,YAAA;;;;UAKK,kBAAA;EACf,IAAA;EAqFe;EAnFf,MAAA,GAAS,YAAA;;EAET,KAAA,GAAQ,aAAA;EAkFR;EAhFA,gBAAA,GAAmB,MAAA;AAAA;;;AA0FrB;;;;;;;UA5EiB,sBAAA;EACf,IAAA;EAkFO;EAhFP,KAAA;EAwF+B;EAtF/B,OAAA,EAAS,YAAA;AAAA;;;;;;AAmGX;;;;;;;;;;;;;;;;;;;;;UAtEiB,sBAAA;EACf,IAAA;;EAEA,KAAA;;EAEA,OAAA,EAAS,YAAA;AAAA;;;;;;;;;;UAYM,uBAAA;EACf,IAAA;;EAEA,KAAA;;EAEA,OAAA,EAAS,YAAA;AAAA;;;;;UASM,gBAAA;EACf,IAAA;;EAEA,KAAA,EAAO,aAAA;AAAA;;;;UAQQ,aAAA;EACf,IAAA;;EAEA,QAAA;;EAEA,IAAA;;EAEA,OAAA;AAAA;;;;UAQe,gBAAA;EACf,IAAA;;EAEA,OAAA;;EAEA,IAAA;AAAA;;;;KAQU,oBAAA,GACR,iBAAA,GACA,kBAAA,GACA,sBAAA,GACA,sBAAA,GACA,uBAAA,GACA,gBAAA,GACA,aAAA,GACA,gBAAA"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"event.js","names":[],"sources":["../../src/language_models/event.ts"],"sourcesContent":["/**\n * Chat model streaming event protocol.\n *\n * Defines a content-block-centric event model for streaming chat model responses.\n * Events carry LangChain {@link ContentBlock} types on lifecycle boundaries\n * and as incremental content updates during streaming.\n *\n * ## Design Principles\n *\n * 1. **Content-block deltas use the content block shape.** Text, reasoning,\n * and tool-call chunks are emitted as partial {@link ContentBlock} values\n * with explicit append semantics.\n *\n * 2. **Lifecycle completeness.** Every streamable entity has explicit start and finish\n * events. Consumers never need to infer boundaries from absence of events.\n *\n * 3. **Interleaving allowed.** Content blocks may interleave (e.g., parallel tool calls).\n * The only invariant: a block's start precedes its deltas, and its deltas precede\n * its finish. No ordering constraint between different blocks.\n *\n * 4. **Provider passthrough.** Native provider events that don't map to standard types\n * are forwarded as {@link ProviderEvent} rather than silently dropped.\n *\n * ## Lifecycle Contract\n *\n * ```\n * MessageStart\n * -> ContentBlockStart(index=0, content=...)\n * -> ContentBlockDelta(index=0, content={ type: \"text\", text: \"Hello\" })\n * -> ContentBlockDelta(index=0, content={ type: \"text\", text: \" world\" })\n * -> ContentBlockFinish(index=0, content=...)\n * -> UsageUpdate(...)\n * -> MessageFinish(reason, usage?)\n * ```\n *\n * @module\n */\n\nimport type { ContentBlock } from \"../messages/content/index.js\";\nimport type { UsageMetadata } from \"../messages/metadata.js\";\n\n// ─── Message Lifecycle ──────────────────────────────────────────\n\n/**\n * Emitted once at the start of a model response.\n */\nexport interface MessageStartEvent {\n type: \"message-start\";\n /** Optional message ID assigned by the provider. */\n id?: string;\n /**\n * Initial usage snapshot, if the provider reports input token counts\n * before content begins streaming (e.g., Anthropic's `message_start`).\n */\n usage?: UsageMetadata;\n}\n\n/**\n * Finish reason for a model response.\n *\n * - `\"stop\"`: Natural end of generation.\n * - `\"length\"`: Hit max token limit.\n * - `\"tool_use\"`: Model is requesting tool execution.\n * - `\"content_filter\"`: Content was filtered by safety systems.\n */\nexport type FinishReason = \"stop\" | \"length\" | \"tool_use\" | \"content_filter\";\n\n/**\n * Emitted once when the model response is complete.\n */\nexport interface MessageFinishEvent {\n type: \"message-finish\";\n /** Why the model stopped generating. */\n reason?: FinishReason;\n /** Final usage snapshot. */\n usage?: UsageMetadata;\n /** Provider-specific response metadata (model name, response ID, headers, etc.). */\n responseMetadata?: Record<string, unknown>;\n}\n\n// ─── Content Block Lifecycle ────────────────────────────────────\n\n/**\n * Emitted when a new content block begins streaming.\n *\n * @example\n * ```ts\n * { type: \"content-block-start\", index: 0,\n * content: { type: \"text\", text: \"\" } }\n * ```\n */\nexport interface ContentBlockStartEvent {\n type: \"content-block-start\";\n /** Positional index of this block within the message. */\n index: number;\n /** Initial state of the content block. */\n content: ContentBlock;\n}\n\n/**\n * Emitted for each incremental update within a content block.\n *\n * The `content` field carries the incremental content block update.\n * Accumulation rules:\n * - `text` → append `text` to the block's text field\n * - `reasoning` → append `reasoning` to the block's reasoning field\n * - `tool_call_chunk` / `server_tool_call_chunk` → append `args`,\n * preserving stable `id`/`name` when later chunks omit them\n * - all other fields are shallow-merged\n *\n * @example\n * ```ts\n * // Text token\n * { type: \"content-block-delta\", index: 0,\n * content: { type: \"text\", text: \" world\" } }\n *\n * // Tool call args chunk\n * { type: \"content-block-delta\", index: 1,\n * content: { type: \"tool_call_chunk\", args: '{\"q\":\"wea' } }\n *\n * // Provider-specific field (e.g., signature)\n * { type: \"content-block-delta\", index: 0,\n * content: { type: \"reasoning\", signature: \"sig_abc\" } }\n * ```\n */\nexport interface ContentBlockDeltaEvent {\n type: \"content-block-delta\";\n /** Positional index of the block being updated. */\n index: number;\n /** Incremental content block update. */\n content: ContentBlock;\n}\n\n/**\n * Emitted when a content block is complete.\n *\n * @example\n * ```ts\n * { type: \"content-block-finish\", index: 0,\n * content: { type: \"text\", text: \"Hello world\" } }\n * ```\n */\nexport interface ContentBlockFinishEvent {\n type: \"content-block-finish\";\n /** Positional index of the completed block. */\n index: number;\n /** Finalized content block. */\n content: ContentBlock;\n}\n\n// ─── Usage ──────────────────────────────────────────────────────\n\n/**\n * Emitted whenever the provider reports updated usage information.\n * Each event carries a **running snapshot** (not an additive delta).\n */\nexport interface UsageUpdateEvent {\n type: \"usage\";\n /** Current usage snapshot. */\n usage: UsageMetadata;\n}\n\n// ─── Provider Passthrough ───────────────────────────────────────\n\n/**\n * Passthrough for native provider events that don't map to standard types.\n */\nexport interface ProviderEvent {\n type: \"provider\";\n /** Provider identifier (e.g., `\"openai\"`, `\"anthropic\"`, `\"google\"`). */\n provider: string;\n /** Raw event type name from the provider SDK. */\n name: string;\n /** Raw event payload from the provider SDK. */\n payload: unknown;\n}\n\n// ─── Error ──────────────────────────────────────────────────────\n\n/**\n * Emitted on unrecoverable stream errors.\n */\nexport interface StreamErrorEvent {\n type: \"error\";\n /** Human-readable error message. */\n message: string;\n /** Optional error code for programmatic handling. */\n code?: string;\n}\n\n// ─── Union ──────────────────────────────────────────────────────\n\n/**\n * Union of all chat model stream event types.\n */\nexport type ChatModelStreamEvent =\n | MessageStartEvent\n | MessageFinishEvent\n | ContentBlockStartEvent\n | ContentBlockDeltaEvent\n | ContentBlockFinishEvent\n | UsageUpdateEvent\n | ProviderEvent\n | StreamErrorEvent;\n"],"mappings":""}
|