@paean-ai/adk 0.2.13 → 0.2.15
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/cjs/index.js +11 -11
- package/dist/cjs/index.js.map +3 -3
- package/dist/esm/index.js +11 -11
- package/dist/esm/index.js.map +3 -3
- package/dist/types/agents/llm_agent.d.ts +4 -0
- package/dist/web/index.js +1 -1
- package/dist/web/index.js.map +3 -3
- package/package.json +3 -3
- package/dist/cjs/agents/active_streaming_tool.js +0 -44
- package/dist/cjs/agents/base_agent.js +0 -245
- package/dist/cjs/agents/base_llm_processor.js +0 -44
- package/dist/cjs/agents/callback_context.js +0 -98
- package/dist/cjs/agents/content_processor_utils.js +0 -346
- package/dist/cjs/agents/functions.js +0 -385
- package/dist/cjs/agents/instructions.js +0 -110
- package/dist/cjs/agents/invocation_context.js +0 -107
- package/dist/cjs/agents/live_request_queue.js +0 -136
- package/dist/cjs/agents/llm_agent.js +0 -1212
- package/dist/cjs/agents/loop_agent.js +0 -68
- package/dist/cjs/agents/parallel_agent.js +0 -78
- package/dist/cjs/agents/readonly_context.js +0 -68
- package/dist/cjs/agents/run_config.js +0 -70
- package/dist/cjs/agents/sequential_agent.js +0 -84
- package/dist/cjs/agents/transcription_entry.js +0 -27
- package/dist/cjs/artifacts/base_artifact_service.js +0 -27
- package/dist/cjs/artifacts/gcs_artifact_service.js +0 -140
- package/dist/cjs/artifacts/in_memory_artifact_service.js +0 -119
- package/dist/cjs/auth/auth_credential.js +0 -46
- package/dist/cjs/auth/auth_handler.js +0 -92
- package/dist/cjs/auth/auth_schemes.js +0 -62
- package/dist/cjs/auth/auth_tool.js +0 -27
- package/dist/cjs/auth/credential_service/base_credential_service.js +0 -27
- package/dist/cjs/auth/credential_service/in_memory_credential_service.js +0 -63
- package/dist/cjs/auth/exchanger/base_credential_exchanger.js +0 -40
- package/dist/cjs/auth/exchanger/credential_exchanger_registry.js +0 -59
- package/dist/cjs/code_executors/base_code_executor.js +0 -76
- package/dist/cjs/code_executors/built_in_code_executor.js +0 -58
- package/dist/cjs/code_executors/code_execution_utils.js +0 -142
- package/dist/cjs/code_executors/code_executor_context.js +0 -198
- package/dist/cjs/common.js +0 -181
- package/dist/cjs/events/event.js +0 -119
- package/dist/cjs/events/event_actions.js +0 -83
- package/dist/cjs/examples/base_example_provider.js +0 -40
- package/dist/cjs/examples/example.js +0 -27
- package/dist/cjs/examples/example_util.js +0 -107
- package/dist/cjs/index_web.js +0 -33
- package/dist/cjs/memory/base_memory_service.js +0 -27
- package/dist/cjs/memory/in_memory_memory_service.js +0 -97
- package/dist/cjs/memory/memory_entry.js +0 -27
- package/dist/cjs/models/base_llm.js +0 -95
- package/dist/cjs/models/base_llm_connection.js +0 -27
- package/dist/cjs/models/gemini_llm_connection.js +0 -132
- package/dist/cjs/models/google_llm.js +0 -559
- package/dist/cjs/models/llm_request.js +0 -82
- package/dist/cjs/models/llm_response.js +0 -71
- package/dist/cjs/models/registry.js +0 -121
- package/dist/cjs/plugins/base_plugin.js +0 -236
- package/dist/cjs/plugins/logging_plugin.js +0 -222
- package/dist/cjs/plugins/plugin_manager.js +0 -239
- package/dist/cjs/plugins/security_plugin.js +0 -153
- package/dist/cjs/runner/in_memory_runner.js +0 -58
- package/dist/cjs/runner/runner.js +0 -277
- package/dist/cjs/sessions/base_session_service.js +0 -71
- package/dist/cjs/sessions/in_memory_session_service.js +0 -184
- package/dist/cjs/sessions/session.js +0 -48
- package/dist/cjs/sessions/state.js +0 -101
- package/dist/cjs/telemetry/google_cloud.js +0 -85
- package/dist/cjs/telemetry/setup.js +0 -97
- package/dist/cjs/telemetry/tracing.js +0 -231
- package/dist/cjs/tools/agent_tool.js +0 -134
- package/dist/cjs/tools/base_tool.js +0 -107
- package/dist/cjs/tools/base_toolset.js +0 -76
- package/dist/cjs/tools/forwarding_artifact_service.js +0 -71
- package/dist/cjs/tools/function_tool.js +0 -101
- package/dist/cjs/tools/google_search_tool.js +0 -76
- package/dist/cjs/tools/long_running_tool.js +0 -63
- package/dist/cjs/tools/mcp/mcp_session_manager.js +0 -65
- package/dist/cjs/tools/mcp/mcp_tool.js +0 -65
- package/dist/cjs/tools/mcp/mcp_toolset.js +0 -61
- package/dist/cjs/tools/tool_confirmation.js +0 -49
- package/dist/cjs/tools/tool_context.js +0 -129
- package/dist/cjs/utils/client_labels.js +0 -56
- package/dist/cjs/utils/deep_clone.js +0 -44
- package/dist/cjs/utils/env_aware_utils.js +0 -83
- package/dist/cjs/utils/gemini_schema_util.js +0 -88
- package/dist/cjs/utils/logger.js +0 -121
- package/dist/cjs/utils/model_name.js +0 -76
- package/dist/cjs/utils/simple_zod_to_json.js +0 -191
- package/dist/cjs/utils/variant_utils.js +0 -55
- package/dist/cjs/version.js +0 -39
- package/dist/esm/agents/active_streaming_tool.js +0 -14
- package/dist/esm/agents/base_agent.js +0 -214
- package/dist/esm/agents/base_llm_processor.js +0 -13
- package/dist/esm/agents/callback_context.js +0 -68
- package/dist/esm/agents/content_processor_utils.js +0 -315
- package/dist/esm/agents/functions.js +0 -344
- package/dist/esm/agents/instructions.js +0 -80
- package/dist/esm/agents/invocation_context.js +0 -76
- package/dist/esm/agents/live_request_queue.js +0 -106
- package/dist/esm/agents/llm_agent.js +0 -1180
- package/dist/esm/agents/loop_agent.js +0 -38
- package/dist/esm/agents/parallel_agent.js +0 -48
- package/dist/esm/agents/readonly_context.js +0 -38
- package/dist/esm/agents/run_config.js +0 -39
- package/dist/esm/agents/sequential_agent.js +0 -54
- package/dist/esm/agents/transcription_entry.js +0 -5
- package/dist/esm/artifacts/base_artifact_service.js +0 -5
- package/dist/esm/artifacts/gcs_artifact_service.js +0 -110
- package/dist/esm/artifacts/in_memory_artifact_service.js +0 -89
- package/dist/esm/auth/auth_credential.js +0 -16
- package/dist/esm/auth/auth_handler.js +0 -62
- package/dist/esm/auth/auth_schemes.js +0 -31
- package/dist/esm/auth/auth_tool.js +0 -5
- package/dist/esm/auth/credential_service/base_credential_service.js +0 -5
- package/dist/esm/auth/credential_service/in_memory_credential_service.js +0 -33
- package/dist/esm/auth/exchanger/base_credential_exchanger.js +0 -10
- package/dist/esm/auth/exchanger/credential_exchanger_registry.js +0 -29
- package/dist/esm/code_executors/base_code_executor.js +0 -46
- package/dist/esm/code_executors/built_in_code_executor.js +0 -28
- package/dist/esm/code_executors/code_execution_utils.js +0 -108
- package/dist/esm/code_executors/code_executor_context.js +0 -168
- package/dist/esm/common.js +0 -98
- package/dist/esm/events/event.js +0 -83
- package/dist/esm/events/event_actions.js +0 -52
- package/dist/esm/examples/base_example_provider.js +0 -10
- package/dist/esm/examples/example.js +0 -5
- package/dist/esm/examples/example_util.js +0 -76
- package/dist/esm/index_web.js +0 -6
- package/dist/esm/memory/base_memory_service.js +0 -5
- package/dist/esm/memory/in_memory_memory_service.js +0 -67
- package/dist/esm/memory/memory_entry.js +0 -5
- package/dist/esm/models/base_llm.js +0 -64
- package/dist/esm/models/base_llm_connection.js +0 -5
- package/dist/esm/models/gemini_llm_connection.js +0 -102
- package/dist/esm/models/google_llm.js +0 -533
- package/dist/esm/models/llm_request.js +0 -50
- package/dist/esm/models/llm_response.js +0 -41
- package/dist/esm/models/registry.js +0 -91
- package/dist/esm/plugins/base_plugin.js +0 -206
- package/dist/esm/plugins/logging_plugin.js +0 -192
- package/dist/esm/plugins/plugin_manager.js +0 -209
- package/dist/esm/plugins/security_plugin.js +0 -119
- package/dist/esm/runner/in_memory_runner.js +0 -28
- package/dist/esm/runner/runner.js +0 -247
- package/dist/esm/sessions/base_session_service.js +0 -41
- package/dist/esm/sessions/in_memory_session_service.js +0 -154
- package/dist/esm/sessions/session.js +0 -18
- package/dist/esm/sessions/state.js +0 -71
- package/dist/esm/telemetry/google_cloud.js +0 -54
- package/dist/esm/telemetry/setup.js +0 -67
- package/dist/esm/telemetry/tracing.js +0 -195
- package/dist/esm/tools/agent_tool.js +0 -104
- package/dist/esm/tools/base_tool.js +0 -77
- package/dist/esm/tools/base_toolset.js +0 -46
- package/dist/esm/tools/forwarding_artifact_service.js +0 -41
- package/dist/esm/tools/function_tool.js +0 -71
- package/dist/esm/tools/google_search_tool.js +0 -46
- package/dist/esm/tools/long_running_tool.js +0 -33
- package/dist/esm/tools/mcp/mcp_session_manager.js +0 -35
- package/dist/esm/tools/mcp/mcp_tool.js +0 -35
- package/dist/esm/tools/mcp/mcp_toolset.js +0 -31
- package/dist/esm/tools/tool_confirmation.js +0 -19
- package/dist/esm/tools/tool_context.js +0 -99
- package/dist/esm/utils/client_labels.js +0 -26
- package/dist/esm/utils/deep_clone.js +0 -14
- package/dist/esm/utils/env_aware_utils.js +0 -49
- package/dist/esm/utils/gemini_schema_util.js +0 -58
- package/dist/esm/utils/logger.js +0 -89
- package/dist/esm/utils/model_name.js +0 -41
- package/dist/esm/utils/simple_zod_to_json.js +0 -160
- package/dist/esm/utils/variant_utils.js +0 -24
- package/dist/esm/version.js +0 -9
- package/dist/web/agents/active_streaming_tool.js +0 -14
- package/dist/web/agents/base_agent.js +0 -265
- package/dist/web/agents/base_llm_processor.js +0 -13
- package/dist/web/agents/callback_context.js +0 -68
- package/dist/web/agents/content_processor_utils.js +0 -315
- package/dist/web/agents/functions.js +0 -344
- package/dist/web/agents/instructions.js +0 -80
- package/dist/web/agents/invocation_context.js +0 -76
- package/dist/web/agents/live_request_queue.js +0 -124
- package/dist/web/agents/llm_agent.js +0 -1310
- package/dist/web/agents/loop_agent.js +0 -71
- package/dist/web/agents/parallel_agent.js +0 -83
- package/dist/web/agents/readonly_context.js +0 -38
- package/dist/web/agents/run_config.js +0 -54
- package/dist/web/agents/sequential_agent.js +0 -99
- package/dist/web/agents/transcription_entry.js +0 -5
- package/dist/web/artifacts/base_artifact_service.js +0 -5
- package/dist/web/artifacts/gcs_artifact_service.js +0 -126
- package/dist/web/artifacts/in_memory_artifact_service.js +0 -89
- package/dist/web/auth/auth_credential.js +0 -16
- package/dist/web/auth/auth_handler.js +0 -62
- package/dist/web/auth/auth_schemes.js +0 -31
- package/dist/web/auth/auth_tool.js +0 -5
- package/dist/web/auth/credential_service/base_credential_service.js +0 -5
- package/dist/web/auth/credential_service/in_memory_credential_service.js +0 -33
- package/dist/web/auth/exchanger/base_credential_exchanger.js +0 -10
- package/dist/web/auth/exchanger/credential_exchanger_registry.js +0 -29
- package/dist/web/code_executors/base_code_executor.js +0 -46
- package/dist/web/code_executors/built_in_code_executor.js +0 -28
- package/dist/web/code_executors/code_execution_utils.js +0 -105
- package/dist/web/code_executors/code_executor_context.js +0 -168
- package/dist/web/common.js +0 -98
- package/dist/web/events/event.js +0 -101
- package/dist/web/events/event_actions.js +0 -67
- package/dist/web/examples/base_example_provider.js +0 -10
- package/dist/web/examples/example.js +0 -5
- package/dist/web/examples/example_util.js +0 -75
- package/dist/web/index_web.js +0 -6
- package/dist/web/memory/base_memory_service.js +0 -5
- package/dist/web/memory/in_memory_memory_service.js +0 -67
- package/dist/web/memory/memory_entry.js +0 -5
- package/dist/web/models/base_llm.js +0 -64
- package/dist/web/models/base_llm_connection.js +0 -5
- package/dist/web/models/gemini_llm_connection.js +0 -120
- package/dist/web/models/google_llm.js +0 -574
- package/dist/web/models/llm_request.js +0 -50
- package/dist/web/models/llm_response.js +0 -41
- package/dist/web/models/registry.js +0 -91
- package/dist/web/plugins/base_plugin.js +0 -206
- package/dist/web/plugins/logging_plugin.js +0 -192
- package/dist/web/plugins/plugin_manager.js +0 -209
- package/dist/web/plugins/security_plugin.js +0 -119
- package/dist/web/runner/in_memory_runner.js +0 -28
- package/dist/web/runner/runner.js +0 -278
- package/dist/web/sessions/base_session_service.js +0 -41
- package/dist/web/sessions/in_memory_session_service.js +0 -154
- package/dist/web/sessions/session.js +0 -18
- package/dist/web/sessions/state.js +0 -87
- package/dist/web/telemetry/google_cloud.js +0 -54
- package/dist/web/telemetry/setup.js +0 -67
- package/dist/web/telemetry/tracing.js +0 -210
- package/dist/web/tools/agent_tool.js +0 -118
- package/dist/web/tools/base_tool.js +0 -77
- package/dist/web/tools/base_toolset.js +0 -46
- package/dist/web/tools/forwarding_artifact_service.js +0 -41
- package/dist/web/tools/function_tool.js +0 -71
- package/dist/web/tools/google_search_tool.js +0 -46
- package/dist/web/tools/long_running_tool.js +0 -50
- package/dist/web/tools/mcp/mcp_session_manager.js +0 -35
- package/dist/web/tools/mcp/mcp_tool.js +0 -35
- package/dist/web/tools/mcp/mcp_toolset.js +0 -31
- package/dist/web/tools/tool_confirmation.js +0 -19
- package/dist/web/tools/tool_context.js +0 -99
- package/dist/web/utils/client_labels.js +0 -26
- package/dist/web/utils/deep_clone.js +0 -14
- package/dist/web/utils/env_aware_utils.js +0 -49
- package/dist/web/utils/gemini_schema_util.js +0 -58
- package/dist/web/utils/logger.js +0 -89
- package/dist/web/utils/model_name.js +0 -41
- package/dist/web/utils/simple_zod_to_json.js +0 -174
- package/dist/web/utils/variant_utils.js +0 -24
- package/dist/web/version.js +0 -9
|
@@ -1,346 +0,0 @@
|
|
|
1
|
-
/**
|
|
2
|
-
* @license
|
|
3
|
-
* Copyright 2025 Google LLC
|
|
4
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
5
|
-
*/
|
|
6
|
-
|
|
7
|
-
"use strict";
|
|
8
|
-
var __defProp = Object.defineProperty;
|
|
9
|
-
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
10
|
-
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
11
|
-
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
12
|
-
var __export = (target, all) => {
|
|
13
|
-
for (var name in all)
|
|
14
|
-
__defProp(target, name, { get: all[name], enumerable: true });
|
|
15
|
-
};
|
|
16
|
-
var __copyProps = (to, from, except, desc) => {
|
|
17
|
-
if (from && typeof from === "object" || typeof from === "function") {
|
|
18
|
-
for (let key of __getOwnPropNames(from))
|
|
19
|
-
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
20
|
-
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
21
|
-
}
|
|
22
|
-
return to;
|
|
23
|
-
};
|
|
24
|
-
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
25
|
-
var content_processor_utils_exports = {};
|
|
26
|
-
__export(content_processor_utils_exports, {
|
|
27
|
-
getContents: () => getContents,
|
|
28
|
-
getCurrentTurnContents: () => getCurrentTurnContents
|
|
29
|
-
});
|
|
30
|
-
module.exports = __toCommonJS(content_processor_utils_exports);
|
|
31
|
-
var import_event = require("../events/event.js");
|
|
32
|
-
var import_deep_clone = require("../utils/deep_clone.js");
|
|
33
|
-
var import_logger = require("../utils/logger.js");
|
|
34
|
-
var import_functions = require("./functions.js");
|
|
35
|
-
/**
|
|
36
|
-
* @license
|
|
37
|
-
* Copyright 2025 Google LLC
|
|
38
|
-
* SPDX-License-Identifier: Apache-2.0
|
|
39
|
-
*/
|
|
40
|
-
function getContents(events, agentName, currentBranch) {
|
|
41
|
-
var _a, _b, _c, _d, _e, _f;
|
|
42
|
-
const filteredEvents = [];
|
|
43
|
-
for (const event of events) {
|
|
44
|
-
if (!((_a = event.content) == null ? void 0 : _a.role) || !((_b = event.content.parts) == null ? void 0 : _b.length)) {
|
|
45
|
-
continue;
|
|
46
|
-
}
|
|
47
|
-
if (currentBranch && event.branch && !currentBranch.startsWith(event.branch)) {
|
|
48
|
-
continue;
|
|
49
|
-
}
|
|
50
|
-
if (isAuthEvent(event)) {
|
|
51
|
-
continue;
|
|
52
|
-
}
|
|
53
|
-
if (isToolConfirmationEvent(event)) {
|
|
54
|
-
continue;
|
|
55
|
-
}
|
|
56
|
-
filteredEvents.push(
|
|
57
|
-
isEventFromAnotherAgent(agentName, event) ? convertForeignEvent(event) : event
|
|
58
|
-
);
|
|
59
|
-
}
|
|
60
|
-
let resultEvents = rearrangeEventsForLatestFunctionResponse(filteredEvents);
|
|
61
|
-
resultEvents = rearrangeEventsForAsyncFunctionResponsesInHistory(resultEvents);
|
|
62
|
-
const contents = [];
|
|
63
|
-
for (const event of resultEvents) {
|
|
64
|
-
const content = (0, import_deep_clone.deepClone)(event.content);
|
|
65
|
-
(0, import_functions.removeClientFunctionCallId)(content);
|
|
66
|
-
contents.push(content);
|
|
67
|
-
}
|
|
68
|
-
let hasFunctionCallWithoutSignature = false;
|
|
69
|
-
let problematicBlockIndex = -1;
|
|
70
|
-
for (let i = 0; i < contents.length; i++) {
|
|
71
|
-
const content = contents[i];
|
|
72
|
-
const hasFunctionCalls = (_c = content.parts) == null ? void 0 : _c.some((p) => p.functionCall);
|
|
73
|
-
const hasThoughtSignature = (_d = content.parts) == null ? void 0 : _d.some((p) => p.thoughtSignature);
|
|
74
|
-
const hasThought = (_e = content.parts) == null ? void 0 : _e.some((p) => p.thought);
|
|
75
|
-
if (hasFunctionCalls) {
|
|
76
|
-
import_logger.logger.info(
|
|
77
|
-
`[getContents] Content block ${i + 1}/${contents.length}: role=${content.role}, hasFunctionCalls=true, hasThought=${hasThought}, hasSignature=${hasThoughtSignature}`
|
|
78
|
-
);
|
|
79
|
-
if (!hasThoughtSignature && content.role === "model") {
|
|
80
|
-
hasFunctionCallWithoutSignature = true;
|
|
81
|
-
problematicBlockIndex = i + 1;
|
|
82
|
-
}
|
|
83
|
-
for (let j = 0; j < (((_f = content.parts) == null ? void 0 : _f.length) || 0); j++) {
|
|
84
|
-
const part = content.parts[j];
|
|
85
|
-
if (part.functionCall) {
|
|
86
|
-
import_logger.logger.info(
|
|
87
|
-
`[getContents] Part ${j}: functionCall=${part.functionCall.name}, hasSignature=${!!part.thoughtSignature}`
|
|
88
|
-
);
|
|
89
|
-
} else if (part.thought) {
|
|
90
|
-
import_logger.logger.info(
|
|
91
|
-
`[getContents] Part ${j}: thought=true, hasSignature=${!!part.thoughtSignature}`
|
|
92
|
-
);
|
|
93
|
-
}
|
|
94
|
-
}
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
if (hasFunctionCallWithoutSignature) {
|
|
98
|
-
import_logger.logger.warn(
|
|
99
|
-
`[getContents] WARNING: Content block ${problematicBlockIndex} has model function calls but NO thoughtSignature! This will likely cause a 400 error from Gemini 3 API.`
|
|
100
|
-
);
|
|
101
|
-
}
|
|
102
|
-
return contents;
|
|
103
|
-
}
|
|
104
|
-
function getCurrentTurnContents(events, agentName, currentBranch) {
|
|
105
|
-
for (let i = events.length - 1; i >= 0; i--) {
|
|
106
|
-
const event = events[i];
|
|
107
|
-
if (event.author === "user" || isEventFromAnotherAgent(agentName, event)) {
|
|
108
|
-
return getContents(events.slice(i), agentName, currentBranch);
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
return [];
|
|
112
|
-
}
|
|
113
|
-
function isAuthEvent(event) {
|
|
114
|
-
var _a, _b, _c;
|
|
115
|
-
if (!((_a = event.content) == null ? void 0 : _a.parts)) {
|
|
116
|
-
return false;
|
|
117
|
-
}
|
|
118
|
-
for (const part of event.content.parts) {
|
|
119
|
-
if (((_b = part.functionCall) == null ? void 0 : _b.name) === import_functions.REQUEST_EUC_FUNCTION_CALL_NAME || ((_c = part.functionResponse) == null ? void 0 : _c.name) === import_functions.REQUEST_EUC_FUNCTION_CALL_NAME) {
|
|
120
|
-
return true;
|
|
121
|
-
}
|
|
122
|
-
}
|
|
123
|
-
return false;
|
|
124
|
-
}
|
|
125
|
-
function isToolConfirmationEvent(event) {
|
|
126
|
-
var _a, _b, _c;
|
|
127
|
-
if (!((_a = event.content) == null ? void 0 : _a.parts)) {
|
|
128
|
-
return false;
|
|
129
|
-
}
|
|
130
|
-
for (const part of event.content.parts) {
|
|
131
|
-
if (((_b = part.functionCall) == null ? void 0 : _b.name) === import_functions.REQUEST_CONFIRMATION_FUNCTION_CALL_NAME || ((_c = part.functionResponse) == null ? void 0 : _c.name) === import_functions.REQUEST_CONFIRMATION_FUNCTION_CALL_NAME) {
|
|
132
|
-
return true;
|
|
133
|
-
}
|
|
134
|
-
}
|
|
135
|
-
return false;
|
|
136
|
-
}
|
|
137
|
-
function isEventFromAnotherAgent(agentName, event) {
|
|
138
|
-
return !!agentName && event.author !== agentName && event.author !== "user";
|
|
139
|
-
}
|
|
140
|
-
function convertForeignEvent(event) {
|
|
141
|
-
var _a, _b, _c, _d, _e, _f;
|
|
142
|
-
if (!((_b = (_a = event.content) == null ? void 0 : _a.parts) == null ? void 0 : _b.length)) {
|
|
143
|
-
return event;
|
|
144
|
-
}
|
|
145
|
-
const content = {
|
|
146
|
-
role: "user",
|
|
147
|
-
parts: [{
|
|
148
|
-
text: "For context:"
|
|
149
|
-
}]
|
|
150
|
-
};
|
|
151
|
-
for (const part of event.content.parts) {
|
|
152
|
-
if (part.text && !part.thought) {
|
|
153
|
-
(_c = content.parts) == null ? void 0 : _c.push({
|
|
154
|
-
text: `[${event.author}] said: ${part.text}`
|
|
155
|
-
});
|
|
156
|
-
} else if (part.functionCall) {
|
|
157
|
-
const argsText = safeStringify(part.functionCall.args);
|
|
158
|
-
(_d = content.parts) == null ? void 0 : _d.push({
|
|
159
|
-
text: `[${event.author}] called tool \`${part.functionCall.name}\` with parameters: ${argsText}`
|
|
160
|
-
});
|
|
161
|
-
} else if (part.functionResponse) {
|
|
162
|
-
const responseText = safeStringify(part.functionResponse.response);
|
|
163
|
-
(_e = content.parts) == null ? void 0 : _e.push({
|
|
164
|
-
text: `[${event.author}] tool \`${part.functionResponse.name}\` returned result: ${responseText}`
|
|
165
|
-
});
|
|
166
|
-
} else {
|
|
167
|
-
(_f = content.parts) == null ? void 0 : _f.push(part);
|
|
168
|
-
}
|
|
169
|
-
}
|
|
170
|
-
return (0, import_event.createEvent)({
|
|
171
|
-
invocationId: event.invocationId,
|
|
172
|
-
author: "user",
|
|
173
|
-
content,
|
|
174
|
-
branch: event.branch,
|
|
175
|
-
timestamp: event.timestamp
|
|
176
|
-
});
|
|
177
|
-
}
|
|
178
|
-
function mergeFunctionResponseEvents(events) {
|
|
179
|
-
var _a;
|
|
180
|
-
if (events.length === 0) {
|
|
181
|
-
throw new Error("Cannot merge an empty list of events.");
|
|
182
|
-
}
|
|
183
|
-
const mergedEvent = (0, import_event.createEvent)(events[0]);
|
|
184
|
-
const partsInMergedEvent = ((_a = mergedEvent.content) == null ? void 0 : _a.parts) || [];
|
|
185
|
-
if (partsInMergedEvent.length === 0) {
|
|
186
|
-
throw new Error("There should be at least one function_response part.");
|
|
187
|
-
}
|
|
188
|
-
const partIndicesInMergedEvent = {};
|
|
189
|
-
for (let i = 0; i < partsInMergedEvent.length; i++) {
|
|
190
|
-
const part = partsInMergedEvent[i];
|
|
191
|
-
if (part.functionResponse && part.functionResponse.id) {
|
|
192
|
-
partIndicesInMergedEvent[part.functionResponse.id] = i;
|
|
193
|
-
}
|
|
194
|
-
}
|
|
195
|
-
for (const event of events.slice(1)) {
|
|
196
|
-
if (!event.content || !event.content.parts) {
|
|
197
|
-
throw new Error("There should be at least one function_response part.");
|
|
198
|
-
}
|
|
199
|
-
for (const part of event.content.parts) {
|
|
200
|
-
if (part.functionResponse && part.functionResponse.id) {
|
|
201
|
-
const functionCallId = part.functionResponse.id;
|
|
202
|
-
if (functionCallId in partIndicesInMergedEvent) {
|
|
203
|
-
partsInMergedEvent[partIndicesInMergedEvent[functionCallId]] = part;
|
|
204
|
-
} else {
|
|
205
|
-
partsInMergedEvent.push(part);
|
|
206
|
-
partIndicesInMergedEvent[functionCallId] = partsInMergedEvent.length - 1;
|
|
207
|
-
}
|
|
208
|
-
} else {
|
|
209
|
-
partsInMergedEvent.push(part);
|
|
210
|
-
}
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
return mergedEvent;
|
|
214
|
-
}
|
|
215
|
-
function rearrangeEventsForLatestFunctionResponse(events) {
|
|
216
|
-
if (events.length === 0) {
|
|
217
|
-
return events;
|
|
218
|
-
}
|
|
219
|
-
const latestEvent = events[events.length - 1];
|
|
220
|
-
const functionResponses = (0, import_event.getFunctionResponses)(latestEvent);
|
|
221
|
-
if (!(functionResponses == null ? void 0 : functionResponses.length)) {
|
|
222
|
-
return events;
|
|
223
|
-
}
|
|
224
|
-
let functionResponsesIds = new Set(
|
|
225
|
-
functionResponses.filter((response) => !!response.id).map((response) => response.id)
|
|
226
|
-
);
|
|
227
|
-
const secondLatestEvent = events.at(-2);
|
|
228
|
-
if (secondLatestEvent) {
|
|
229
|
-
const functionCallsFromSecondLatest = (0, import_event.getFunctionCalls)(secondLatestEvent);
|
|
230
|
-
if (functionCallsFromSecondLatest) {
|
|
231
|
-
for (const functionCall of functionCallsFromSecondLatest) {
|
|
232
|
-
if (functionCall.id && functionResponsesIds.has(functionCall.id)) {
|
|
233
|
-
return events;
|
|
234
|
-
}
|
|
235
|
-
}
|
|
236
|
-
}
|
|
237
|
-
}
|
|
238
|
-
let functionCallEventIdx = -1;
|
|
239
|
-
for (let idx = events.length - 2; idx >= 0; idx--) {
|
|
240
|
-
const event = events[idx];
|
|
241
|
-
const functionCalls = (0, import_event.getFunctionCalls)(event);
|
|
242
|
-
if (!(functionCalls == null ? void 0 : functionCalls.length)) {
|
|
243
|
-
continue;
|
|
244
|
-
}
|
|
245
|
-
for (const functionCall of functionCalls) {
|
|
246
|
-
if (functionCall.id && functionResponsesIds.has(functionCall.id)) {
|
|
247
|
-
functionCallEventIdx = idx;
|
|
248
|
-
const functionCallIds = new Set(
|
|
249
|
-
functionCalls.map((fc) => fc.id).filter((id) => !!id)
|
|
250
|
-
);
|
|
251
|
-
const isSubset = Array.from(functionResponsesIds).every((id) => functionCallIds.has(id));
|
|
252
|
-
if (!isSubset) {
|
|
253
|
-
throw new Error(
|
|
254
|
-
`Last response event should only contain the responses for the function calls in the same function call event. Function call ids found : ${Array.from(functionCallIds).join(", ")}, function response ids provided: ${Array.from(functionResponsesIds).join(", ")}`
|
|
255
|
-
);
|
|
256
|
-
}
|
|
257
|
-
functionResponsesIds = functionCallIds;
|
|
258
|
-
break;
|
|
259
|
-
}
|
|
260
|
-
}
|
|
261
|
-
}
|
|
262
|
-
if (functionCallEventIdx === -1) {
|
|
263
|
-
throw new Error(
|
|
264
|
-
`No function call event found for function responses ids: ${Array.from(
|
|
265
|
-
functionResponsesIds
|
|
266
|
-
).join(", ")}`
|
|
267
|
-
);
|
|
268
|
-
}
|
|
269
|
-
const functionResponseEvents = [];
|
|
270
|
-
for (let idx = functionCallEventIdx + 1; idx < events.length - 1; idx++) {
|
|
271
|
-
const event = events[idx];
|
|
272
|
-
const responses = (0, import_event.getFunctionResponses)(event);
|
|
273
|
-
if (responses && responses.some(
|
|
274
|
-
(response) => response.id && functionResponsesIds.has(response.id)
|
|
275
|
-
)) {
|
|
276
|
-
functionResponseEvents.push(event);
|
|
277
|
-
}
|
|
278
|
-
}
|
|
279
|
-
functionResponseEvents.push(events[events.length - 1]);
|
|
280
|
-
const resultEvents = events.slice(0, functionCallEventIdx + 1);
|
|
281
|
-
resultEvents.push(mergeFunctionResponseEvents(functionResponseEvents));
|
|
282
|
-
return resultEvents;
|
|
283
|
-
}
|
|
284
|
-
function rearrangeEventsForAsyncFunctionResponsesInHistory(events) {
|
|
285
|
-
const functionCallIdToResponseEventIndex = /* @__PURE__ */ new Map();
|
|
286
|
-
for (let i = 0; i < events.length; i++) {
|
|
287
|
-
const event = events[i];
|
|
288
|
-
const functionResponses = (0, import_event.getFunctionResponses)(event);
|
|
289
|
-
if (functionResponses == null ? void 0 : functionResponses.length) {
|
|
290
|
-
for (const functionResponse of functionResponses) {
|
|
291
|
-
if (!functionResponse.id) {
|
|
292
|
-
continue;
|
|
293
|
-
}
|
|
294
|
-
functionCallIdToResponseEventIndex.set(functionResponse.id, i);
|
|
295
|
-
}
|
|
296
|
-
}
|
|
297
|
-
}
|
|
298
|
-
const resultEvents = [];
|
|
299
|
-
for (const event of events) {
|
|
300
|
-
if ((0, import_event.getFunctionResponses)(event).length > 0) {
|
|
301
|
-
continue;
|
|
302
|
-
}
|
|
303
|
-
const functionCalls = (0, import_event.getFunctionCalls)(event);
|
|
304
|
-
if (functionCalls == null ? void 0 : functionCalls.length) {
|
|
305
|
-
const functionResponseEventsIndices = /* @__PURE__ */ new Set();
|
|
306
|
-
for (const functionCall of functionCalls) {
|
|
307
|
-
const functionCallId = functionCall.id;
|
|
308
|
-
if (functionCallId && functionCallIdToResponseEventIndex.has(functionCallId)) {
|
|
309
|
-
functionResponseEventsIndices.add(
|
|
310
|
-
functionCallIdToResponseEventIndex.get(functionCallId)
|
|
311
|
-
);
|
|
312
|
-
}
|
|
313
|
-
}
|
|
314
|
-
resultEvents.push(event);
|
|
315
|
-
if (functionResponseEventsIndices.size === 0) {
|
|
316
|
-
continue;
|
|
317
|
-
}
|
|
318
|
-
if (functionResponseEventsIndices.size === 1) {
|
|
319
|
-
const [responseIndex] = [...functionResponseEventsIndices];
|
|
320
|
-
resultEvents.push(events[responseIndex]);
|
|
321
|
-
} else {
|
|
322
|
-
const indicesArray = Array.from(functionResponseEventsIndices).sort((a, b) => a - b);
|
|
323
|
-
const eventsToMerge = indicesArray.map((index) => events[index]);
|
|
324
|
-
resultEvents.push(mergeFunctionResponseEvents(eventsToMerge));
|
|
325
|
-
}
|
|
326
|
-
} else {
|
|
327
|
-
resultEvents.push(event);
|
|
328
|
-
}
|
|
329
|
-
}
|
|
330
|
-
return resultEvents;
|
|
331
|
-
}
|
|
332
|
-
function safeStringify(obj) {
|
|
333
|
-
if (typeof obj === "string") {
|
|
334
|
-
return obj;
|
|
335
|
-
}
|
|
336
|
-
try {
|
|
337
|
-
return JSON.stringify(obj);
|
|
338
|
-
} catch (e) {
|
|
339
|
-
return String(obj);
|
|
340
|
-
}
|
|
341
|
-
}
|
|
342
|
-
// Annotate the CommonJS export names for ESM import in node:
|
|
343
|
-
0 && (module.exports = {
|
|
344
|
-
getContents,
|
|
345
|
-
getCurrentTurnContents
|
|
346
|
-
});
|