@paean-ai/adk 0.2.14 → 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.
Files changed (254) hide show
  1. package/dist/cjs/index.js +11 -11
  2. package/dist/cjs/index.js.map +3 -3
  3. package/dist/esm/index.js +11 -11
  4. package/dist/esm/index.js.map +3 -3
  5. package/dist/types/agents/llm_agent.d.ts +4 -0
  6. package/dist/web/index.js +1 -1
  7. package/dist/web/index.js.map +3 -3
  8. package/package.json +1 -1
  9. package/dist/cjs/agents/active_streaming_tool.js +0 -44
  10. package/dist/cjs/agents/base_agent.js +0 -245
  11. package/dist/cjs/agents/base_llm_processor.js +0 -44
  12. package/dist/cjs/agents/callback_context.js +0 -98
  13. package/dist/cjs/agents/content_processor_utils.js +0 -346
  14. package/dist/cjs/agents/functions.js +0 -385
  15. package/dist/cjs/agents/instructions.js +0 -110
  16. package/dist/cjs/agents/invocation_context.js +0 -107
  17. package/dist/cjs/agents/live_request_queue.js +0 -136
  18. package/dist/cjs/agents/llm_agent.js +0 -1212
  19. package/dist/cjs/agents/loop_agent.js +0 -68
  20. package/dist/cjs/agents/parallel_agent.js +0 -78
  21. package/dist/cjs/agents/readonly_context.js +0 -68
  22. package/dist/cjs/agents/run_config.js +0 -70
  23. package/dist/cjs/agents/sequential_agent.js +0 -84
  24. package/dist/cjs/agents/transcription_entry.js +0 -27
  25. package/dist/cjs/artifacts/base_artifact_service.js +0 -27
  26. package/dist/cjs/artifacts/gcs_artifact_service.js +0 -140
  27. package/dist/cjs/artifacts/in_memory_artifact_service.js +0 -119
  28. package/dist/cjs/auth/auth_credential.js +0 -46
  29. package/dist/cjs/auth/auth_handler.js +0 -92
  30. package/dist/cjs/auth/auth_schemes.js +0 -62
  31. package/dist/cjs/auth/auth_tool.js +0 -27
  32. package/dist/cjs/auth/credential_service/base_credential_service.js +0 -27
  33. package/dist/cjs/auth/credential_service/in_memory_credential_service.js +0 -63
  34. package/dist/cjs/auth/exchanger/base_credential_exchanger.js +0 -40
  35. package/dist/cjs/auth/exchanger/credential_exchanger_registry.js +0 -59
  36. package/dist/cjs/code_executors/base_code_executor.js +0 -76
  37. package/dist/cjs/code_executors/built_in_code_executor.js +0 -58
  38. package/dist/cjs/code_executors/code_execution_utils.js +0 -142
  39. package/dist/cjs/code_executors/code_executor_context.js +0 -198
  40. package/dist/cjs/common.js +0 -181
  41. package/dist/cjs/events/event.js +0 -119
  42. package/dist/cjs/events/event_actions.js +0 -83
  43. package/dist/cjs/examples/base_example_provider.js +0 -40
  44. package/dist/cjs/examples/example.js +0 -27
  45. package/dist/cjs/examples/example_util.js +0 -107
  46. package/dist/cjs/index_web.js +0 -33
  47. package/dist/cjs/memory/base_memory_service.js +0 -27
  48. package/dist/cjs/memory/in_memory_memory_service.js +0 -97
  49. package/dist/cjs/memory/memory_entry.js +0 -27
  50. package/dist/cjs/models/base_llm.js +0 -95
  51. package/dist/cjs/models/base_llm_connection.js +0 -27
  52. package/dist/cjs/models/gemini_llm_connection.js +0 -132
  53. package/dist/cjs/models/google_llm.js +0 -559
  54. package/dist/cjs/models/llm_request.js +0 -82
  55. package/dist/cjs/models/llm_response.js +0 -71
  56. package/dist/cjs/models/registry.js +0 -121
  57. package/dist/cjs/plugins/base_plugin.js +0 -236
  58. package/dist/cjs/plugins/logging_plugin.js +0 -222
  59. package/dist/cjs/plugins/plugin_manager.js +0 -239
  60. package/dist/cjs/plugins/security_plugin.js +0 -153
  61. package/dist/cjs/runner/in_memory_runner.js +0 -58
  62. package/dist/cjs/runner/runner.js +0 -277
  63. package/dist/cjs/sessions/base_session_service.js +0 -71
  64. package/dist/cjs/sessions/in_memory_session_service.js +0 -184
  65. package/dist/cjs/sessions/session.js +0 -48
  66. package/dist/cjs/sessions/state.js +0 -101
  67. package/dist/cjs/telemetry/google_cloud.js +0 -85
  68. package/dist/cjs/telemetry/setup.js +0 -97
  69. package/dist/cjs/telemetry/tracing.js +0 -231
  70. package/dist/cjs/tools/agent_tool.js +0 -134
  71. package/dist/cjs/tools/base_tool.js +0 -107
  72. package/dist/cjs/tools/base_toolset.js +0 -76
  73. package/dist/cjs/tools/forwarding_artifact_service.js +0 -71
  74. package/dist/cjs/tools/function_tool.js +0 -101
  75. package/dist/cjs/tools/google_search_tool.js +0 -76
  76. package/dist/cjs/tools/long_running_tool.js +0 -63
  77. package/dist/cjs/tools/mcp/mcp_session_manager.js +0 -65
  78. package/dist/cjs/tools/mcp/mcp_tool.js +0 -65
  79. package/dist/cjs/tools/mcp/mcp_toolset.js +0 -61
  80. package/dist/cjs/tools/tool_confirmation.js +0 -49
  81. package/dist/cjs/tools/tool_context.js +0 -129
  82. package/dist/cjs/utils/client_labels.js +0 -56
  83. package/dist/cjs/utils/deep_clone.js +0 -44
  84. package/dist/cjs/utils/env_aware_utils.js +0 -83
  85. package/dist/cjs/utils/gemini_schema_util.js +0 -88
  86. package/dist/cjs/utils/logger.js +0 -121
  87. package/dist/cjs/utils/model_name.js +0 -76
  88. package/dist/cjs/utils/simple_zod_to_json.js +0 -191
  89. package/dist/cjs/utils/variant_utils.js +0 -55
  90. package/dist/cjs/version.js +0 -39
  91. package/dist/esm/agents/active_streaming_tool.js +0 -14
  92. package/dist/esm/agents/base_agent.js +0 -214
  93. package/dist/esm/agents/base_llm_processor.js +0 -13
  94. package/dist/esm/agents/callback_context.js +0 -68
  95. package/dist/esm/agents/content_processor_utils.js +0 -315
  96. package/dist/esm/agents/functions.js +0 -344
  97. package/dist/esm/agents/instructions.js +0 -80
  98. package/dist/esm/agents/invocation_context.js +0 -76
  99. package/dist/esm/agents/live_request_queue.js +0 -106
  100. package/dist/esm/agents/llm_agent.js +0 -1180
  101. package/dist/esm/agents/loop_agent.js +0 -38
  102. package/dist/esm/agents/parallel_agent.js +0 -48
  103. package/dist/esm/agents/readonly_context.js +0 -38
  104. package/dist/esm/agents/run_config.js +0 -39
  105. package/dist/esm/agents/sequential_agent.js +0 -54
  106. package/dist/esm/agents/transcription_entry.js +0 -5
  107. package/dist/esm/artifacts/base_artifact_service.js +0 -5
  108. package/dist/esm/artifacts/gcs_artifact_service.js +0 -110
  109. package/dist/esm/artifacts/in_memory_artifact_service.js +0 -89
  110. package/dist/esm/auth/auth_credential.js +0 -16
  111. package/dist/esm/auth/auth_handler.js +0 -62
  112. package/dist/esm/auth/auth_schemes.js +0 -31
  113. package/dist/esm/auth/auth_tool.js +0 -5
  114. package/dist/esm/auth/credential_service/base_credential_service.js +0 -5
  115. package/dist/esm/auth/credential_service/in_memory_credential_service.js +0 -33
  116. package/dist/esm/auth/exchanger/base_credential_exchanger.js +0 -10
  117. package/dist/esm/auth/exchanger/credential_exchanger_registry.js +0 -29
  118. package/dist/esm/code_executors/base_code_executor.js +0 -46
  119. package/dist/esm/code_executors/built_in_code_executor.js +0 -28
  120. package/dist/esm/code_executors/code_execution_utils.js +0 -108
  121. package/dist/esm/code_executors/code_executor_context.js +0 -168
  122. package/dist/esm/common.js +0 -98
  123. package/dist/esm/events/event.js +0 -83
  124. package/dist/esm/events/event_actions.js +0 -52
  125. package/dist/esm/examples/base_example_provider.js +0 -10
  126. package/dist/esm/examples/example.js +0 -5
  127. package/dist/esm/examples/example_util.js +0 -76
  128. package/dist/esm/index_web.js +0 -6
  129. package/dist/esm/memory/base_memory_service.js +0 -5
  130. package/dist/esm/memory/in_memory_memory_service.js +0 -67
  131. package/dist/esm/memory/memory_entry.js +0 -5
  132. package/dist/esm/models/base_llm.js +0 -64
  133. package/dist/esm/models/base_llm_connection.js +0 -5
  134. package/dist/esm/models/gemini_llm_connection.js +0 -102
  135. package/dist/esm/models/google_llm.js +0 -533
  136. package/dist/esm/models/llm_request.js +0 -50
  137. package/dist/esm/models/llm_response.js +0 -41
  138. package/dist/esm/models/registry.js +0 -91
  139. package/dist/esm/plugins/base_plugin.js +0 -206
  140. package/dist/esm/plugins/logging_plugin.js +0 -192
  141. package/dist/esm/plugins/plugin_manager.js +0 -209
  142. package/dist/esm/plugins/security_plugin.js +0 -119
  143. package/dist/esm/runner/in_memory_runner.js +0 -28
  144. package/dist/esm/runner/runner.js +0 -247
  145. package/dist/esm/sessions/base_session_service.js +0 -41
  146. package/dist/esm/sessions/in_memory_session_service.js +0 -154
  147. package/dist/esm/sessions/session.js +0 -18
  148. package/dist/esm/sessions/state.js +0 -71
  149. package/dist/esm/telemetry/google_cloud.js +0 -54
  150. package/dist/esm/telemetry/setup.js +0 -67
  151. package/dist/esm/telemetry/tracing.js +0 -195
  152. package/dist/esm/tools/agent_tool.js +0 -104
  153. package/dist/esm/tools/base_tool.js +0 -77
  154. package/dist/esm/tools/base_toolset.js +0 -46
  155. package/dist/esm/tools/forwarding_artifact_service.js +0 -41
  156. package/dist/esm/tools/function_tool.js +0 -71
  157. package/dist/esm/tools/google_search_tool.js +0 -46
  158. package/dist/esm/tools/long_running_tool.js +0 -33
  159. package/dist/esm/tools/mcp/mcp_session_manager.js +0 -35
  160. package/dist/esm/tools/mcp/mcp_tool.js +0 -35
  161. package/dist/esm/tools/mcp/mcp_toolset.js +0 -31
  162. package/dist/esm/tools/tool_confirmation.js +0 -19
  163. package/dist/esm/tools/tool_context.js +0 -99
  164. package/dist/esm/utils/client_labels.js +0 -26
  165. package/dist/esm/utils/deep_clone.js +0 -14
  166. package/dist/esm/utils/env_aware_utils.js +0 -49
  167. package/dist/esm/utils/gemini_schema_util.js +0 -58
  168. package/dist/esm/utils/logger.js +0 -89
  169. package/dist/esm/utils/model_name.js +0 -41
  170. package/dist/esm/utils/simple_zod_to_json.js +0 -160
  171. package/dist/esm/utils/variant_utils.js +0 -24
  172. package/dist/esm/version.js +0 -9
  173. package/dist/web/agents/active_streaming_tool.js +0 -14
  174. package/dist/web/agents/base_agent.js +0 -265
  175. package/dist/web/agents/base_llm_processor.js +0 -13
  176. package/dist/web/agents/callback_context.js +0 -68
  177. package/dist/web/agents/content_processor_utils.js +0 -315
  178. package/dist/web/agents/functions.js +0 -344
  179. package/dist/web/agents/instructions.js +0 -80
  180. package/dist/web/agents/invocation_context.js +0 -76
  181. package/dist/web/agents/live_request_queue.js +0 -124
  182. package/dist/web/agents/llm_agent.js +0 -1310
  183. package/dist/web/agents/loop_agent.js +0 -71
  184. package/dist/web/agents/parallel_agent.js +0 -83
  185. package/dist/web/agents/readonly_context.js +0 -38
  186. package/dist/web/agents/run_config.js +0 -54
  187. package/dist/web/agents/sequential_agent.js +0 -99
  188. package/dist/web/agents/transcription_entry.js +0 -5
  189. package/dist/web/artifacts/base_artifact_service.js +0 -5
  190. package/dist/web/artifacts/gcs_artifact_service.js +0 -126
  191. package/dist/web/artifacts/in_memory_artifact_service.js +0 -89
  192. package/dist/web/auth/auth_credential.js +0 -16
  193. package/dist/web/auth/auth_handler.js +0 -62
  194. package/dist/web/auth/auth_schemes.js +0 -31
  195. package/dist/web/auth/auth_tool.js +0 -5
  196. package/dist/web/auth/credential_service/base_credential_service.js +0 -5
  197. package/dist/web/auth/credential_service/in_memory_credential_service.js +0 -33
  198. package/dist/web/auth/exchanger/base_credential_exchanger.js +0 -10
  199. package/dist/web/auth/exchanger/credential_exchanger_registry.js +0 -29
  200. package/dist/web/code_executors/base_code_executor.js +0 -46
  201. package/dist/web/code_executors/built_in_code_executor.js +0 -28
  202. package/dist/web/code_executors/code_execution_utils.js +0 -105
  203. package/dist/web/code_executors/code_executor_context.js +0 -168
  204. package/dist/web/common.js +0 -98
  205. package/dist/web/events/event.js +0 -101
  206. package/dist/web/events/event_actions.js +0 -67
  207. package/dist/web/examples/base_example_provider.js +0 -10
  208. package/dist/web/examples/example.js +0 -5
  209. package/dist/web/examples/example_util.js +0 -75
  210. package/dist/web/index_web.js +0 -6
  211. package/dist/web/memory/base_memory_service.js +0 -5
  212. package/dist/web/memory/in_memory_memory_service.js +0 -67
  213. package/dist/web/memory/memory_entry.js +0 -5
  214. package/dist/web/models/base_llm.js +0 -64
  215. package/dist/web/models/base_llm_connection.js +0 -5
  216. package/dist/web/models/gemini_llm_connection.js +0 -120
  217. package/dist/web/models/google_llm.js +0 -574
  218. package/dist/web/models/llm_request.js +0 -50
  219. package/dist/web/models/llm_response.js +0 -41
  220. package/dist/web/models/registry.js +0 -91
  221. package/dist/web/plugins/base_plugin.js +0 -206
  222. package/dist/web/plugins/logging_plugin.js +0 -192
  223. package/dist/web/plugins/plugin_manager.js +0 -209
  224. package/dist/web/plugins/security_plugin.js +0 -119
  225. package/dist/web/runner/in_memory_runner.js +0 -28
  226. package/dist/web/runner/runner.js +0 -278
  227. package/dist/web/sessions/base_session_service.js +0 -41
  228. package/dist/web/sessions/in_memory_session_service.js +0 -154
  229. package/dist/web/sessions/session.js +0 -18
  230. package/dist/web/sessions/state.js +0 -87
  231. package/dist/web/telemetry/google_cloud.js +0 -54
  232. package/dist/web/telemetry/setup.js +0 -67
  233. package/dist/web/telemetry/tracing.js +0 -210
  234. package/dist/web/tools/agent_tool.js +0 -118
  235. package/dist/web/tools/base_tool.js +0 -77
  236. package/dist/web/tools/base_toolset.js +0 -46
  237. package/dist/web/tools/forwarding_artifact_service.js +0 -41
  238. package/dist/web/tools/function_tool.js +0 -71
  239. package/dist/web/tools/google_search_tool.js +0 -46
  240. package/dist/web/tools/long_running_tool.js +0 -50
  241. package/dist/web/tools/mcp/mcp_session_manager.js +0 -35
  242. package/dist/web/tools/mcp/mcp_tool.js +0 -35
  243. package/dist/web/tools/mcp/mcp_toolset.js +0 -31
  244. package/dist/web/tools/tool_confirmation.js +0 -19
  245. package/dist/web/tools/tool_context.js +0 -99
  246. package/dist/web/utils/client_labels.js +0 -26
  247. package/dist/web/utils/deep_clone.js +0 -14
  248. package/dist/web/utils/env_aware_utils.js +0 -49
  249. package/dist/web/utils/gemini_schema_util.js +0 -58
  250. package/dist/web/utils/logger.js +0 -89
  251. package/dist/web/utils/model_name.js +0 -41
  252. package/dist/web/utils/simple_zod_to_json.js +0 -174
  253. package/dist/web/utils/variant_utils.js +0 -24
  254. package/dist/web/version.js +0 -9
@@ -1,119 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { BasePlugin } from "../plugins/base_plugin.js";
7
- const REQUEST_CONFIRMATION_FUNCTION_CALL_NAME = "adk_request_confirmation";
8
- const TOOL_CALL_SECURITY_CHECK_STATES = "orcas_tool_call_security_check_states";
9
- const INTERMEDIATE_REQUIRE_TOOL_CALL_CONFIRMATION_ERROR = "This tool call needs external confirmation before completion.";
10
- var PolicyOutcome = /* @__PURE__ */ ((PolicyOutcome2) => {
11
- PolicyOutcome2["DENY"] = "DENY";
12
- PolicyOutcome2["CONFIRM"] = "CONFIRM";
13
- PolicyOutcome2["ALLOW"] = "ALLOW";
14
- return PolicyOutcome2;
15
- })(PolicyOutcome || {});
16
- class InMemoryPolicyEngine {
17
- async evaluate(context) {
18
- return Promise.resolve({
19
- outcome: "ALLOW" /* ALLOW */,
20
- reason: "For prototyping purpose, all tool calls are allowed."
21
- });
22
- }
23
- }
24
- class SecurityPlugin extends BasePlugin {
25
- constructor(params) {
26
- var _a;
27
- super("security_plugin");
28
- this.policyEngine = (_a = params == null ? void 0 : params.policyEngine) != null ? _a : new InMemoryPolicyEngine();
29
- }
30
- async beforeToolCallback({
31
- tool,
32
- toolArgs,
33
- toolContext
34
- }) {
35
- const toolCallCheckState = this.getToolCallCheckState(toolContext);
36
- if (!toolCallCheckState) {
37
- return this.checkToolCallPolicy({
38
- tool,
39
- toolArgs,
40
- toolContext
41
- });
42
- }
43
- if (toolCallCheckState !== "CONFIRM" /* CONFIRM */) {
44
- return;
45
- }
46
- if (!toolContext.toolConfirmation) {
47
- return { partial: INTERMEDIATE_REQUIRE_TOOL_CALL_CONFIRMATION_ERROR };
48
- }
49
- this.setToolCallCheckState(toolContext, toolContext.toolConfirmation);
50
- if (!toolContext.toolConfirmation.confirmed) {
51
- return {
52
- error: "Tool call rejected from confirmation flow."
53
- };
54
- }
55
- toolContext.toolConfirmation = void 0;
56
- return;
57
- }
58
- getToolCallCheckState(toolContext) {
59
- var _a;
60
- const { functionCallId } = toolContext;
61
- if (!functionCallId) {
62
- return;
63
- }
64
- const toolCallStates = (_a = toolContext.state.get(TOOL_CALL_SECURITY_CHECK_STATES)) != null ? _a : {};
65
- return toolCallStates[functionCallId];
66
- }
67
- setToolCallCheckState(toolContext, state) {
68
- var _a;
69
- const { functionCallId } = toolContext;
70
- if (!functionCallId) {
71
- return;
72
- }
73
- const toolCallStates = (_a = toolContext.state.get(TOOL_CALL_SECURITY_CHECK_STATES)) != null ? _a : {};
74
- toolCallStates[functionCallId] = state;
75
- toolContext.state.set(TOOL_CALL_SECURITY_CHECK_STATES, toolCallStates);
76
- }
77
- async checkToolCallPolicy({
78
- tool,
79
- toolArgs,
80
- toolContext
81
- }) {
82
- const policyCheckResult = await this.policyEngine.evaluate({ tool, toolArgs });
83
- this.setToolCallCheckState(toolContext, policyCheckResult.outcome);
84
- switch (policyCheckResult.outcome) {
85
- case "DENY" /* DENY */:
86
- return {
87
- error: "This tool call is rejected by policy engine. Reason: ".concat(policyCheckResult.reason)
88
- };
89
- case "CONFIRM" /* CONFIRM */:
90
- toolContext.requestConfirmation({
91
- hint: "Policy engine requires confirmation calling tool: ".concat(tool.name, ". Reason: ").concat(policyCheckResult.reason)
92
- });
93
- return { partial: INTERMEDIATE_REQUIRE_TOOL_CALL_CONFIRMATION_ERROR };
94
- case "ALLOW" /* ALLOW */:
95
- return;
96
- default:
97
- return;
98
- }
99
- }
100
- }
101
- function getAskUserConfirmationFunctionCalls(event) {
102
- if (!event.content || !event.content.parts) {
103
- return [];
104
- }
105
- const results = [];
106
- for (const part of event.content.parts) {
107
- if (part && part.functionCall && part.functionCall.name === REQUEST_CONFIRMATION_FUNCTION_CALL_NAME) {
108
- results.push(part.functionCall);
109
- }
110
- }
111
- return results;
112
- }
113
- export {
114
- InMemoryPolicyEngine,
115
- PolicyOutcome,
116
- REQUEST_CONFIRMATION_FUNCTION_CALL_NAME,
117
- SecurityPlugin,
118
- getAskUserConfirmationFunctionCalls
119
- };
@@ -1,28 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { InMemoryArtifactService } from "../artifacts/in_memory_artifact_service.js";
7
- import { InMemoryMemoryService } from "../memory/in_memory_memory_service.js";
8
- import { InMemorySessionService } from "../sessions/in_memory_session_service.js";
9
- import { Runner } from "./runner.js";
10
- class InMemoryRunner extends Runner {
11
- constructor({
12
- agent,
13
- appName = "InMemoryRunner",
14
- plugins = []
15
- }) {
16
- super({
17
- appName,
18
- agent,
19
- plugins,
20
- artifactService: new InMemoryArtifactService(),
21
- sessionService: new InMemorySessionService(),
22
- memoryService: new InMemoryMemoryService()
23
- });
24
- }
25
- }
26
- export {
27
- InMemoryRunner
28
- };
@@ -1,278 +0,0 @@
1
- var __knownSymbol = (name, symbol) => (symbol = Symbol[name]) ? symbol : Symbol.for("Symbol." + name);
2
- var __await = function(promise, isYieldStar) {
3
- this[0] = promise;
4
- this[1] = isYieldStar;
5
- };
6
- var __asyncGenerator = (__this, __arguments, generator) => {
7
- var resume = (k, v, yes, no) => {
8
- try {
9
- var x = generator[k](v), isAwait = (v = x.value) instanceof __await, done = x.done;
10
- Promise.resolve(isAwait ? v[0] : v).then((y) => isAwait ? resume(k === "return" ? k : "next", v[1] ? { done: y.done, value: y.value } : y, yes, no) : yes({ value: y, done })).catch((e) => resume("throw", e, yes, no));
11
- } catch (e) {
12
- no(e);
13
- }
14
- }, method = (k) => it[k] = (x) => new Promise((yes, no) => resume(k, x, yes, no)), it = {};
15
- return generator = generator.apply(__this, __arguments), it[__knownSymbol("asyncIterator")] = () => it, method("next"), method("throw"), method("return"), it;
16
- };
17
- var __forAwait = (obj, it, method) => (it = obj[__knownSymbol("asyncIterator")]) ? it.call(obj) : (obj = obj[__knownSymbol("iterator")](), it = {}, method = (key, fn) => (fn = obj[key]) && (it[key] = (arg) => new Promise((yes, no, done) => (arg = fn.call(obj, arg), done = arg.done, Promise.resolve(arg.value).then((value) => yes({ value, done }), no)))), method("next"), method("return"), it);
18
- /**
19
- * @license
20
- * Copyright 2025 Google LLC
21
- * SPDX-License-Identifier: Apache-2.0
22
- */
23
- import { createPartFromText } from "@google/genai";
24
- import { trace } from "@opentelemetry/api";
25
- import { InvocationContext, newInvocationContextId } from "../agents/invocation_context.js";
26
- import { LlmAgent } from "../agents/llm_agent.js";
27
- import { createRunConfig } from "../agents/run_config.js";
28
- import { createEvent, getFunctionCalls } from "../events/event.js";
29
- import { createEventActions } from "../events/event_actions.js";
30
- import { PluginManager } from "../plugins/plugin_manager.js";
31
- import { logger } from "../utils/logger.js";
32
- class Runner {
33
- constructor(input) {
34
- var _a;
35
- this.appName = input.appName;
36
- this.agent = input.agent;
37
- this.pluginManager = new PluginManager((_a = input.plugins) != null ? _a : []);
38
- this.artifactService = input.artifactService;
39
- this.sessionService = input.sessionService;
40
- this.memoryService = input.memoryService;
41
- this.credentialService = input.credentialService;
42
- }
43
- /**
44
- * Runs the agent with the given message, and returns an async generator of
45
- * events.
46
- *
47
- * @param userId The user ID of the session.
48
- * @param sessionId The session ID of the session.
49
- * @param newMessage A new message to append to the session.
50
- * @param stateDelta An optional state delta to apply to the session.
51
- * @param runConfig The run config for the agent.
52
- * @yields The events generated by the agent.
53
- */
54
- // TODO - b/425992518: user, sessionId, and runConfig can be internalized.
55
- runAsync(_0) {
56
- return __asyncGenerator(this, arguments, function* ({
57
- userId,
58
- sessionId,
59
- newMessage,
60
- stateDelta,
61
- runConfig
62
- }) {
63
- var _a;
64
- runConfig = createRunConfig(runConfig);
65
- const span = trace.getTracer("gcp.vertex.agent").startSpan("invocation");
66
- try {
67
- const session = yield new __await(this.sessionService.getSession({ appName: this.appName, userId, sessionId }));
68
- if (!session) {
69
- throw new Error("Session not found: ".concat(sessionId));
70
- }
71
- if (runConfig.supportCfc && this.agent instanceof LlmAgent) {
72
- const modelName = this.agent.canonicalModel.model;
73
- if (!modelName.startsWith("gemini-2")) {
74
- throw new Error("CFC is not supported for model: ".concat(modelName, " in agent: ").concat(this.agent.name));
75
- }
76
- }
77
- const invocationContext = new InvocationContext({
78
- artifactService: this.artifactService,
79
- sessionService: this.sessionService,
80
- memoryService: this.memoryService,
81
- credentialService: this.credentialService,
82
- invocationId: newInvocationContextId(),
83
- agent: this.agent,
84
- session,
85
- userContent: newMessage,
86
- runConfig,
87
- pluginManager: this.pluginManager
88
- });
89
- const pluginUserMessage = yield new __await(this.pluginManager.runOnUserMessageCallback({
90
- userMessage: newMessage,
91
- invocationContext
92
- }));
93
- if (pluginUserMessage) {
94
- newMessage = pluginUserMessage;
95
- }
96
- if (newMessage) {
97
- if (!((_a = newMessage.parts) == null ? void 0 : _a.length)) {
98
- throw new Error("No parts in the newMessage.");
99
- }
100
- if (runConfig.saveInputBlobsAsArtifacts) {
101
- yield new __await(this.saveArtifacts(
102
- invocationContext.invocationId,
103
- session.userId,
104
- session.id,
105
- newMessage
106
- ));
107
- }
108
- yield new __await(this.sessionService.appendEvent({
109
- session,
110
- event: createEvent({
111
- invocationId: invocationContext.invocationId,
112
- author: "user",
113
- actions: stateDelta ? createEventActions({ stateDelta }) : void 0,
114
- content: newMessage
115
- })
116
- }));
117
- }
118
- invocationContext.agent = this.determineAgentForResumption(session, this.agent);
119
- const beforeRunCallbackResponse = yield new __await(this.pluginManager.runBeforeRunCallback({ invocationContext }));
120
- if (beforeRunCallbackResponse) {
121
- const earlyExitEvent = createEvent({
122
- invocationId: invocationContext.invocationId,
123
- author: "model",
124
- content: beforeRunCallbackResponse
125
- });
126
- yield new __await(this.sessionService.appendEvent({ session, event: earlyExitEvent }));
127
- yield earlyExitEvent;
128
- } else {
129
- try {
130
- for (var iter = __forAwait(invocationContext.agent.runAsync(
131
- invocationContext
132
- )), more, temp, error; more = !(temp = yield new __await(iter.next())).done; more = false) {
133
- const event = temp.value;
134
- if (!event.partial) {
135
- yield new __await(this.sessionService.appendEvent({ session, event }));
136
- }
137
- const modifiedEvent = yield new __await(this.pluginManager.runOnEventCallback(
138
- { invocationContext, event }
139
- ));
140
- if (modifiedEvent) {
141
- yield modifiedEvent;
142
- } else {
143
- yield event;
144
- }
145
- }
146
- } catch (temp) {
147
- error = [temp];
148
- } finally {
149
- try {
150
- more && (temp = iter.return) && (yield new __await(temp.call(iter)));
151
- } finally {
152
- if (error)
153
- throw error[0];
154
- }
155
- }
156
- }
157
- yield new __await(this.pluginManager.runAfterRunCallback({ invocationContext }));
158
- } finally {
159
- span.end();
160
- }
161
- });
162
- }
163
- /**
164
- * Saves artifacts from the message parts and replaces the inline data with
165
- * a file name placeholder.
166
- *
167
- * @param invocationId The current invocation ID.
168
- * @param userId The user ID of the session.
169
- * @param sessionId The session ID of the session.
170
- * @param message The message containing parts to process.
171
- */
172
- async saveArtifacts(invocationId, userId, sessionId, message) {
173
- var _a;
174
- if (!this.artifactService || !((_a = message.parts) == null ? void 0 : _a.length)) {
175
- return;
176
- }
177
- for (let i = 0; i < message.parts.length; i++) {
178
- const part = message.parts[i];
179
- if (!part.inlineData) {
180
- continue;
181
- }
182
- const fileName = "artifact_".concat(invocationId, "_").concat(i);
183
- await this.artifactService.saveArtifact({
184
- appName: this.appName,
185
- userId,
186
- sessionId,
187
- filename: fileName,
188
- artifact: part
189
- });
190
- message.parts[i] = createPartFromText(
191
- "Uploaded file: ".concat(fileName, ". It is saved into artifacts")
192
- );
193
- }
194
- }
195
- /**
196
- * Determines the next agent to run to continue the session. This is primarily
197
- * used for session resumption.
198
- */
199
- // TODO - b/425992518: This is where LRO integration should happen.
200
- // Needs clean up before we can generalize it.
201
- determineAgentForResumption(session, rootAgent) {
202
- const event = findEventByLastFunctionResponseId(session.events);
203
- if (event && event.author) {
204
- return rootAgent.findAgent(event.author) || rootAgent;
205
- }
206
- for (let i = session.events.length - 1; i >= 0; i--) {
207
- logger.info("event: ", JSON.stringify(session.events[i]));
208
- const event2 = session.events[i];
209
- if (event2.author === "user" || !event2.author) {
210
- continue;
211
- }
212
- if (event2.author === rootAgent.name) {
213
- return rootAgent;
214
- }
215
- const agent = rootAgent.findSubAgent(event2.author);
216
- if (!agent) {
217
- logger.warn("Event from an unknown agent: ".concat(event2.author, ", event id: ").concat(event2.id));
218
- continue;
219
- }
220
- if (this.isRoutableLlmAgent(agent)) {
221
- return agent;
222
- }
223
- }
224
- return rootAgent;
225
- }
226
- /**
227
- * Whether the agent to run can transfer to any other agent in the agent tree.
228
- *
229
- * An agent is transferable if:
230
- * - It is an instance of `LlmAgent`.
231
- * - All its ancestors are also transferable (i.e., they have
232
- * `disallowTransferToParent` set to false).
233
- *
234
- * @param agentToRun The agent to check for transferability.
235
- * @returns True if the agent can transfer, False otherwise.
236
- */
237
- isRoutableLlmAgent(agentToRun) {
238
- let agent = agentToRun;
239
- while (agent) {
240
- if (!(agent instanceof LlmAgent)) {
241
- return false;
242
- }
243
- if (agent.disallowTransferToParent) {
244
- return false;
245
- }
246
- agent = agent.parentAgent;
247
- }
248
- return true;
249
- }
250
- // TODO - b/425992518: Implement runLive and related methods.
251
- }
252
- function findEventByLastFunctionResponseId(events) {
253
- var _a, _b, _c, _d;
254
- if (!events.length) {
255
- return null;
256
- }
257
- const lastEvent = events[events.length - 1];
258
- const functionCallId = (_d = (_c = (_b = (_a = lastEvent.content) == null ? void 0 : _a.parts) == null ? void 0 : _b.find((part) => part.functionResponse)) == null ? void 0 : _c.functionResponse) == null ? void 0 : _d.id;
259
- if (!functionCallId) {
260
- return null;
261
- }
262
- for (let i = events.length - 2; i >= 0; i--) {
263
- const event = events[i];
264
- const functionCalls = getFunctionCalls(event);
265
- if (!functionCalls) {
266
- continue;
267
- }
268
- for (const functionCall of functionCalls) {
269
- if (functionCall.id === functionCallId) {
270
- return event;
271
- }
272
- }
273
- }
274
- return null;
275
- }
276
- export {
277
- Runner
278
- };
@@ -1,41 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { State } from "./state.js";
7
- class BaseSessionService {
8
- /**
9
- * Appends an event to a session.
10
- *
11
- * @param request The request to append an event.
12
- * @return A promise that resolves to the event that was appended.
13
- */
14
- async appendEvent({ session, event }) {
15
- if (event.partial) {
16
- return event;
17
- }
18
- this.updateSessionState({ session, event });
19
- session.events.push(event);
20
- return event;
21
- }
22
- /**
23
- * Updates the session state based on the event.
24
- *
25
- * @param request The request to update the session state.
26
- */
27
- updateSessionState({ session, event }) {
28
- if (!event.actions || !event.actions.stateDelta) {
29
- return;
30
- }
31
- for (const [key, value] of Object.entries(event.actions.stateDelta)) {
32
- if (key.startsWith(State.TEMP_PREFIX)) {
33
- continue;
34
- }
35
- session.state[key] = value;
36
- }
37
- }
38
- }
39
- export {
40
- BaseSessionService
41
- };
@@ -1,154 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- import { deepClone } from "../utils/deep_clone.js";
7
- import { randomUUID } from "../utils/env_aware_utils.js";
8
- import { logger } from "../utils/logger.js";
9
- import { BaseSessionService } from "./base_session_service.js";
10
- import { createSession } from "./session.js";
11
- import { State } from "./state.js";
12
- class InMemorySessionService extends BaseSessionService {
13
- constructor() {
14
- super(...arguments);
15
- /**
16
- * A map from app name to a map from user ID to a map from session ID to
17
- * session.
18
- */
19
- this.sessions = {};
20
- /**
21
- * A map from app name to a map from user ID to a map from key to the value.
22
- */
23
- this.userState = {};
24
- /**
25
- * A map from app name to a map from key to the value.
26
- */
27
- this.appState = {};
28
- }
29
- createSession({ appName, userId, state, sessionId }) {
30
- const session = createSession({
31
- id: sessionId || randomUUID(),
32
- appName,
33
- userId,
34
- state,
35
- events: [],
36
- lastUpdateTime: Date.now()
37
- });
38
- if (!this.sessions[appName]) {
39
- this.sessions[appName] = {};
40
- }
41
- if (!this.sessions[appName][userId]) {
42
- this.sessions[appName][userId] = {};
43
- }
44
- this.sessions[appName][userId][session.id] = session;
45
- return Promise.resolve(
46
- this.mergeState(appName, userId, deepClone(session))
47
- );
48
- }
49
- getSession({ appName, userId, sessionId, config }) {
50
- if (!this.sessions[appName] || !this.sessions[appName][userId] || !this.sessions[appName][userId][sessionId]) {
51
- return Promise.resolve(void 0);
52
- }
53
- const session = this.sessions[appName][userId][sessionId];
54
- const copiedSession = deepClone(session);
55
- if (config) {
56
- if (config.numRecentEvents) {
57
- copiedSession.events = copiedSession.events.slice(-config.numRecentEvents);
58
- }
59
- if (config.afterTimestamp) {
60
- let i = copiedSession.events.length - 1;
61
- while (i >= 0) {
62
- if (copiedSession.events[i].timestamp < config.afterTimestamp) {
63
- break;
64
- }
65
- i--;
66
- }
67
- if (i >= 0) {
68
- copiedSession.events = copiedSession.events.slice(i + 1);
69
- }
70
- }
71
- }
72
- return Promise.resolve(this.mergeState(appName, userId, copiedSession));
73
- }
74
- listSessions({ appName, userId }) {
75
- if (!this.sessions[appName] || !this.sessions[appName][userId]) {
76
- return Promise.resolve({ sessions: [] });
77
- }
78
- const sessionsWithoutEvents = [];
79
- for (const session of Object.values(this.sessions[appName][userId])) {
80
- sessionsWithoutEvents.push(createSession({
81
- id: session.id,
82
- appName: session.appName,
83
- userId: session.userId,
84
- state: {},
85
- events: [],
86
- lastUpdateTime: session.lastUpdateTime
87
- }));
88
- }
89
- return Promise.resolve({ sessions: sessionsWithoutEvents });
90
- }
91
- async deleteSession({ appName, userId, sessionId }) {
92
- const session = await this.getSession({ appName, userId, sessionId });
93
- if (!session) {
94
- return;
95
- }
96
- delete this.sessions[appName][userId][sessionId];
97
- }
98
- async appendEvent({ session, event }) {
99
- await super.appendEvent({ session, event });
100
- session.lastUpdateTime = event.timestamp;
101
- const appName = session.appName;
102
- const userId = session.userId;
103
- const sessionId = session.id;
104
- const warning = (message) => {
105
- logger.warn("Failed to append event to session ".concat(sessionId, ": ").concat(message));
106
- };
107
- if (!this.sessions[appName]) {
108
- warning("appName ".concat(appName, " not in sessions"));
109
- return event;
110
- }
111
- if (!this.sessions[appName][userId]) {
112
- warning("userId ".concat(userId, " not in sessions[appName]"));
113
- return event;
114
- }
115
- if (!this.sessions[appName][userId][sessionId]) {
116
- warning("sessionId ".concat(sessionId, " not in sessions[appName][userId]"));
117
- return event;
118
- }
119
- if (event.actions && event.actions.stateDelta) {
120
- for (const key of Object.keys(event.actions.stateDelta)) {
121
- if (key.startsWith(State.APP_PREFIX)) {
122
- this.appState[appName] = this.appState[appName] || {};
123
- this.appState[appName][key.replace(State.APP_PREFIX, "")] = event.actions.stateDelta[key];
124
- }
125
- if (key.startsWith(State.USER_PREFIX)) {
126
- this.userState[appName] = this.userState[appName] || {};
127
- this.userState[appName][userId] = this.userState[appName][userId] || {};
128
- this.userState[appName][userId][key.replace(State.USER_PREFIX, "")] = event.actions.stateDelta[key];
129
- }
130
- }
131
- }
132
- const storageSession = this.sessions[appName][userId][sessionId];
133
- await super.appendEvent({ session: storageSession, event });
134
- storageSession.lastUpdateTime = event.timestamp;
135
- return event;
136
- }
137
- mergeState(appName, userId, copiedSession) {
138
- if (this.appState[appName]) {
139
- for (const key of Object.keys(this.appState[appName])) {
140
- copiedSession.state[State.APP_PREFIX + key] = this.appState[appName][key];
141
- }
142
- }
143
- if (!this.userState[appName] || !this.userState[appName][userId]) {
144
- return copiedSession;
145
- }
146
- for (const key of Object.keys(this.userState[appName][userId])) {
147
- copiedSession.state[State.USER_PREFIX + key] = this.userState[appName][userId][key];
148
- }
149
- return copiedSession;
150
- }
151
- }
152
- export {
153
- InMemorySessionService
154
- };
@@ -1,18 +0,0 @@
1
- /**
2
- * @license
3
- * Copyright 2025 Google LLC
4
- * SPDX-License-Identifier: Apache-2.0
5
- */
6
- function createSession(params) {
7
- return {
8
- id: params.id,
9
- appName: params.appName,
10
- userId: params.userId || "",
11
- state: params.state || {},
12
- events: params.events || [],
13
- lastUpdateTime: params.lastUpdateTime || 0
14
- };
15
- }
16
- export {
17
- createSession
18
- };