@google/adk 0.2.5 → 0.3.0

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 (166) hide show
  1. package/dist/cjs/agents/base_agent.js +43 -21
  2. package/dist/cjs/agents/callback_context.js +4 -1
  3. package/dist/cjs/agents/content_processor_utils.js +15 -7
  4. package/dist/cjs/agents/functions.js +79 -29
  5. package/dist/cjs/agents/llm_agent.js +59 -33
  6. package/dist/cjs/agents/loop_agent.js +2 -1
  7. package/dist/cjs/agents/parallel_agent.js +3 -4
  8. package/dist/cjs/artifacts/gcs_artifact_service.js +28 -20
  9. package/dist/cjs/artifacts/in_memory_artifact_service.js +18 -4
  10. package/dist/cjs/auth/auth_handler.js +3 -1
  11. package/dist/cjs/code_executors/base_code_executor.js +3 -1
  12. package/dist/cjs/code_executors/built_in_code_executor.js +7 -3
  13. package/dist/cjs/code_executors/code_executor_context.js +5 -5
  14. package/dist/cjs/common.js +4 -0
  15. package/dist/cjs/events/event.js +1 -3
  16. package/dist/cjs/index.js +19 -19
  17. package/dist/cjs/index.js.map +4 -4
  18. package/dist/cjs/memory/in_memory_memory_service.js +3 -1
  19. package/dist/cjs/models/base_llm.js +8 -4
  20. package/dist/cjs/models/gemini_llm_connection.js +1 -0
  21. package/dist/cjs/models/google_llm.js +3 -3
  22. package/dist/cjs/plugins/base_plugin.js +12 -0
  23. package/dist/cjs/plugins/logging_plugin.js +50 -13
  24. package/dist/cjs/plugins/plugin_manager.js +56 -24
  25. package/dist/cjs/plugins/security_plugin.js +1 -1
  26. package/dist/cjs/runner/runner.js +110 -95
  27. package/dist/cjs/sessions/in_memory_session_service.js +38 -14
  28. package/dist/cjs/telemetry/google_cloud.js +7 -9
  29. package/dist/cjs/telemetry/setup.js +15 -7
  30. package/dist/cjs/telemetry/tracing.js +37 -15
  31. package/dist/cjs/tools/agent_tool.js +8 -4
  32. package/dist/cjs/tools/base_tool.js +4 -2
  33. package/dist/cjs/tools/forwarding_artifact_service.js +1 -1
  34. package/dist/cjs/tools/function_tool.js +1 -2
  35. package/dist/cjs/tools/google_search_tool.js +1 -2
  36. package/dist/cjs/tools/mcp/mcp_session_manager.js +16 -10
  37. package/dist/cjs/tools/mcp/mcp_tool.js +1 -3
  38. package/dist/cjs/tools/mcp/mcp_toolset.js +1 -1
  39. package/dist/cjs/utils/env_aware_utils.js +1 -1
  40. package/dist/cjs/utils/gemini_schema_util.js +9 -4
  41. package/dist/cjs/utils/logger.js +47 -3
  42. package/dist/cjs/utils/simple_zod_to_json.js +100 -141
  43. package/dist/cjs/utils/variant_utils.js +1 -1
  44. package/dist/cjs/version.js +1 -1
  45. package/dist/esm/agents/base_agent.js +48 -22
  46. package/dist/esm/agents/callback_context.js +4 -1
  47. package/dist/esm/agents/content_processor_utils.js +25 -9
  48. package/dist/esm/agents/functions.js +83 -29
  49. package/dist/esm/agents/llm_agent.js +63 -33
  50. package/dist/esm/agents/loop_agent.js +2 -1
  51. package/dist/esm/agents/parallel_agent.js +3 -4
  52. package/dist/esm/artifacts/gcs_artifact_service.js +28 -20
  53. package/dist/esm/artifacts/in_memory_artifact_service.js +18 -4
  54. package/dist/esm/auth/auth_handler.js +3 -1
  55. package/dist/esm/code_executors/base_code_executor.js +3 -1
  56. package/dist/esm/code_executors/built_in_code_executor.js +7 -3
  57. package/dist/esm/code_executors/code_executor_context.js +5 -5
  58. package/dist/esm/common.js +3 -1
  59. package/dist/esm/events/event.js +1 -3
  60. package/dist/esm/index.js +19 -19
  61. package/dist/esm/index.js.map +4 -4
  62. package/dist/esm/memory/in_memory_memory_service.js +3 -1
  63. package/dist/esm/models/base_llm.js +8 -4
  64. package/dist/esm/models/gemini_llm_connection.js +1 -0
  65. package/dist/esm/models/google_llm.js +8 -4
  66. package/dist/esm/plugins/base_plugin.js +12 -0
  67. package/dist/esm/plugins/logging_plugin.js +55 -14
  68. package/dist/esm/plugins/plugin_manager.js +56 -24
  69. package/dist/esm/plugins/security_plugin.js +1 -1
  70. package/dist/esm/runner/runner.js +114 -96
  71. package/dist/esm/sessions/in_memory_session_service.js +41 -15
  72. package/dist/esm/telemetry/google_cloud.js +7 -9
  73. package/dist/esm/telemetry/setup.js +23 -9
  74. package/dist/esm/telemetry/tracing.js +37 -15
  75. package/dist/esm/tools/agent_tool.js +8 -4
  76. package/dist/esm/tools/base_tool.js +4 -2
  77. package/dist/esm/tools/forwarding_artifact_service.js +1 -1
  78. package/dist/esm/tools/function_tool.js +1 -2
  79. package/dist/esm/tools/google_search_tool.js +2 -5
  80. package/dist/esm/tools/long_running_tool.js +3 -1
  81. package/dist/esm/tools/mcp/mcp_session_manager.js +22 -12
  82. package/dist/esm/tools/mcp/mcp_tool.js +1 -3
  83. package/dist/esm/tools/mcp/mcp_toolset.js +1 -1
  84. package/dist/esm/utils/env_aware_utils.js +1 -1
  85. package/dist/esm/utils/gemini_schema_util.js +9 -4
  86. package/dist/esm/utils/logger.js +43 -2
  87. package/dist/esm/utils/simple_zod_to_json.js +102 -141
  88. package/dist/esm/utils/variant_utils.js +1 -1
  89. package/dist/esm/version.js +1 -1
  90. package/dist/types/agents/base_agent.d.ts +2 -1
  91. package/dist/types/agents/callback_context.d.ts +1 -1
  92. package/dist/types/agents/llm_agent.d.ts +1 -1
  93. package/dist/types/agents/loop_agent.d.ts +1 -1
  94. package/dist/types/agents/parallel_agent.d.ts +1 -1
  95. package/dist/types/artifacts/in_memory_artifact_service.d.ts +3 -3
  96. package/dist/types/code_executors/built_in_code_executor.d.ts +1 -1
  97. package/dist/types/code_executors/code_executor_context.d.ts +2 -4
  98. package/dist/types/common.d.ts +2 -1
  99. package/dist/types/index.d.ts +3 -3
  100. package/dist/types/models/base_llm_connection.d.ts +1 -1
  101. package/dist/types/models/llm_response.d.ts +1 -1
  102. package/dist/types/plugins/logging_plugin.d.ts +12 -12
  103. package/dist/types/plugins/plugin_manager.d.ts +12 -12
  104. package/dist/types/plugins/security_plugin.d.ts +1 -1
  105. package/dist/types/runner/runner.d.ts +1 -1
  106. package/dist/types/sessions/in_memory_session_service.d.ts +5 -5
  107. package/dist/types/telemetry/setup.d.ts +1 -1
  108. package/dist/types/telemetry/tracing.d.ts +7 -6
  109. package/dist/types/tools/agent_tool.d.ts +1 -1
  110. package/dist/types/tools/base_tool.d.ts +1 -1
  111. package/dist/types/tools/base_toolset.d.ts +2 -1
  112. package/dist/types/tools/forwarding_artifact_service.d.ts +2 -2
  113. package/dist/types/tools/function_tool.d.ts +4 -3
  114. package/dist/types/tools/google_search_tool.d.ts +3 -3
  115. package/dist/types/tools/mcp/mcp_session_manager.d.ts +10 -3
  116. package/dist/types/tools/mcp/mcp_toolset.d.ts +1 -2
  117. package/dist/types/utils/gemini_schema_util.d.ts +4 -12
  118. package/dist/types/utils/logger.d.ts +11 -10
  119. package/dist/types/utils/simple_zod_to_json.d.ts +5 -4
  120. package/dist/types/version.d.ts +1 -1
  121. package/dist/web/agents/base_agent.js +94 -33
  122. package/dist/web/agents/callback_context.js +4 -1
  123. package/dist/web/agents/content_processor_utils.js +25 -9
  124. package/dist/web/agents/functions.js +83 -29
  125. package/dist/web/agents/llm_agent.js +117 -54
  126. package/dist/web/agents/loop_agent.js +2 -1
  127. package/dist/web/agents/parallel_agent.js +3 -4
  128. package/dist/web/artifacts/gcs_artifact_service.js +25 -17
  129. package/dist/web/artifacts/in_memory_artifact_service.js +18 -4
  130. package/dist/web/auth/auth_handler.js +3 -1
  131. package/dist/web/code_executors/base_code_executor.js +3 -1
  132. package/dist/web/code_executors/built_in_code_executor.js +7 -3
  133. package/dist/web/code_executors/code_executor_context.js +5 -5
  134. package/dist/web/common.js +3 -1
  135. package/dist/web/events/event.js +1 -3
  136. package/dist/web/index.js +1 -1
  137. package/dist/web/index.js.map +4 -4
  138. package/dist/web/memory/in_memory_memory_service.js +3 -1
  139. package/dist/web/models/base_llm.js +8 -4
  140. package/dist/web/models/gemini_llm_connection.js +1 -0
  141. package/dist/web/models/google_llm.js +8 -4
  142. package/dist/web/plugins/base_plugin.js +12 -0
  143. package/dist/web/plugins/logging_plugin.js +55 -14
  144. package/dist/web/plugins/plugin_manager.js +56 -24
  145. package/dist/web/plugins/security_plugin.js +1 -1
  146. package/dist/web/runner/runner.js +159 -108
  147. package/dist/web/sessions/in_memory_session_service.js +41 -15
  148. package/dist/web/telemetry/google_cloud.js +7 -9
  149. package/dist/web/telemetry/setup.js +23 -9
  150. package/dist/web/telemetry/tracing.js +37 -15
  151. package/dist/web/tools/agent_tool.js +8 -4
  152. package/dist/web/tools/base_tool.js +4 -2
  153. package/dist/web/tools/forwarding_artifact_service.js +1 -1
  154. package/dist/web/tools/function_tool.js +1 -2
  155. package/dist/web/tools/google_search_tool.js +2 -5
  156. package/dist/web/tools/long_running_tool.js +3 -1
  157. package/dist/web/tools/mcp/mcp_session_manager.js +22 -12
  158. package/dist/web/tools/mcp/mcp_tool.js +1 -3
  159. package/dist/web/tools/mcp/mcp_toolset.js +1 -1
  160. package/dist/web/utils/env_aware_utils.js +1 -1
  161. package/dist/web/utils/gemini_schema_util.js +9 -4
  162. package/dist/web/utils/logger.js +43 -2
  163. package/dist/web/utils/simple_zod_to_json.js +102 -155
  164. package/dist/web/utils/variant_utils.js +1 -1
  165. package/dist/web/version.js +1 -1
  166. package/package.json +4 -2
@@ -5,7 +5,6 @@
5
5
  */
6
6
  var _a, _b;
7
7
  import { Type } from "@google/genai";
8
- import { ZodObject } from "zod";
9
8
  import { isZodObject, zodObjectToSchema } from "../utils/simple_zod_to_json.js";
10
9
  import { BaseTool } from "./base_tool.js";
11
10
  function toSchema(parameters) {
@@ -60,7 +59,7 @@ class FunctionTool extends (_b = BaseTool, _a = FUNCTION_TOOL_SIGNATURE_SYMBOL,
60
59
  async runAsync(req) {
61
60
  try {
62
61
  let validatedArgs = req.args;
63
- if (this.parameters instanceof ZodObject) {
62
+ if (isZodObject(this.parameters)) {
64
63
  validatedArgs = this.parameters.parse(req.args);
65
64
  }
66
65
  return await this.execute(
@@ -4,18 +4,15 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { isGemini1Model, isGeminiModel } from "../utils/model_name.js";
7
- import {
8
- BaseTool
9
- } from "./base_tool.js";
7
+ import { BaseTool } from "./base_tool.js";
10
8
  class GoogleSearchTool extends BaseTool {
11
9
  constructor() {
12
10
  super({ name: "google_search", description: "Google Search Tool" });
13
11
  }
14
- runAsync(request) {
12
+ runAsync() {
15
13
  return Promise.resolve();
16
14
  }
17
15
  async processLlmRequest({
18
- toolContext,
19
16
  llmRequest
20
17
  }) {
21
18
  if (!llmRequest.model) {
@@ -22,7 +22,9 @@ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
22
22
  * Copyright 2025 Google LLC
23
23
  * SPDX-License-Identifier: Apache-2.0
24
24
  */
25
- import { FunctionTool } from "./function_tool.js";
25
+ import {
26
+ FunctionTool
27
+ } from "./function_tool.js";
26
28
  const LONG_RUNNING_INSTRUCTION = "\n\nNOTE: This is a long-running operation. Do not call this tool again if it has already returned some intermediate or pending status.";
27
29
  class LongRunningFunctionTool extends FunctionTool {
28
30
  /**
@@ -4,13 +4,18 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  import { Client } from "@modelcontextprotocol/sdk/client/index.js";
7
- import { StdioClientTransport } from "@modelcontextprotocol/sdk/client/stdio.js";
8
- import { StreamableHTTPClientTransport } from "@modelcontextprotocol/sdk/client/streamableHttp.js";
7
+ import {
8
+ StdioClientTransport
9
+ } from "@modelcontextprotocol/sdk/client/stdio.js";
10
+ import {
11
+ StreamableHTTPClientTransport
12
+ } from "@modelcontextprotocol/sdk/client/streamableHttp.js";
9
13
  class MCPSessionManager {
10
14
  constructor(connectionParams) {
11
15
  this.connectionParams = connectionParams;
12
16
  }
13
17
  async createSession() {
18
+ var _a;
14
19
  const client = new Client({ name: "MCPClient", version: "1.0.0" });
15
20
  switch (this.connectionParams.type) {
16
21
  case "StdioConnectionParams":
@@ -18,20 +23,25 @@ class MCPSessionManager {
18
23
  new StdioClientTransport(this.connectionParams.serverParams)
19
24
  );
20
25
  break;
21
- case "StreamableHTTPConnectionParams":
22
- const transportOptions = this.connectionParams.header ? {
23
- requestInit: {
26
+ case "StreamableHTTPConnectionParams": {
27
+ const options = (_a = this.connectionParams.transportOptions) != null ? _a : {};
28
+ if (!options.requestInit && this.connectionParams.header !== void 0) {
29
+ options.requestInit = {
24
30
  headers: this.connectionParams.header
25
- }
26
- } : void 0;
27
- await client.connect(new StreamableHTTPClientTransport(
28
- new URL(this.connectionParams.url),
29
- transportOptions
30
- ));
31
+ };
32
+ }
33
+ await client.connect(
34
+ new StreamableHTTPClientTransport(
35
+ new URL(this.connectionParams.url),
36
+ options
37
+ )
38
+ );
31
39
  break;
32
- default:
40
+ }
41
+ default: {
33
42
  const _exhaustiveCheck = this.connectionParams;
34
43
  break;
44
+ }
35
45
  }
36
46
  return client;
37
47
  }
@@ -12,8 +12,7 @@ class MCPTool extends BaseTool {
12
12
  this.mcpSessionManager = mcpSessionManager;
13
13
  }
14
14
  _getDeclaration() {
15
- let declaration;
16
- declaration = {
15
+ return {
17
16
  name: this.mcpTool.name,
18
17
  description: this.mcpTool.description,
19
18
  parameters: toGeminiSchema(this.mcpTool.inputSchema),
@@ -21,7 +20,6 @@ class MCPTool extends BaseTool {
21
20
  // https://modelcontextprotocol.io/specification/2025-06-18/server/tools#tool-result
22
21
  response: toGeminiSchema(this.mcpTool.outputSchema)
23
22
  };
24
- return declaration;
25
23
  }
26
24
  async runAsync(request) {
27
25
  const session = await this.mcpSessionManager.createSession();
@@ -12,7 +12,7 @@ class MCPToolset extends BaseToolset {
12
12
  super(toolFilter);
13
13
  this.mcpSessionManager = new MCPSessionManager(connectionParams);
14
14
  }
15
- async getTools(context) {
15
+ async getTools() {
16
16
  const session = await this.mcpSessionManager.createSession();
17
17
  const listResult = await session.listTools();
18
18
  logger.debug("number of tools: ".concat(listResult.tools.length));
@@ -36,7 +36,7 @@ function base64Decode(data) {
36
36
  function isBase64Encoded(data) {
37
37
  try {
38
38
  return base64Encode(base64Decode(data)) === data;
39
- } catch (e) {
39
+ } catch (_e) {
40
40
  return false;
41
41
  }
42
42
  }
@@ -5,9 +5,9 @@
5
5
  */
6
6
  import { Type } from "@google/genai";
7
7
  import { z } from "zod";
8
- const MCPToolSchema = z.object({
8
+ const MCPToolSchemaObject = z.object({
9
9
  type: z.literal("object"),
10
- properties: z.record(z.unknown()).optional(),
10
+ properties: z.record(z.string(), z.unknown()).optional(),
11
11
  required: z.string().array().optional()
12
12
  });
13
13
  function toGeminiType(mcpType) {
@@ -52,12 +52,17 @@ function toGeminiSchema(mcpSchema) {
52
52
  }
53
53
  }
54
54
  const geminiType = toGeminiType(mcp.type);
55
- const geminiSchema = { type: geminiType, description: mcp.description };
55
+ const geminiSchema = {
56
+ type: geminiType,
57
+ description: mcp.description
58
+ };
56
59
  if (geminiType === Type.OBJECT) {
57
60
  geminiSchema.properties = {};
58
61
  if (mcp.properties) {
59
62
  for (const name in mcp.properties) {
60
- geminiSchema.properties[name] = recursiveConvert(mcp.properties[name]);
63
+ geminiSchema.properties[name] = recursiveConvert(
64
+ mcp.properties[name]
65
+ );
61
66
  }
62
67
  }
63
68
  geminiSchema.required = mcp.required;
@@ -61,6 +61,18 @@ class SimpleLogger {
61
61
  console.error(getColoredPrefix(3 /* ERROR */), ...args);
62
62
  }
63
63
  }
64
+ class NoOpLogger {
65
+ log(_level, ..._args) {
66
+ }
67
+ debug(..._args) {
68
+ }
69
+ info(..._args) {
70
+ }
71
+ warn(..._args) {
72
+ }
73
+ error(..._args) {
74
+ }
75
+ }
64
76
  const LOG_LEVEL_STR = {
65
77
  [0 /* DEBUG */]: "DEBUG",
66
78
  [1 /* INFO */]: "INFO",
@@ -81,9 +93,38 @@ const RESET_COLOR = "\x1B[0m";
81
93
  function getColoredPrefix(level) {
82
94
  return "".concat(CONSOLE_COLOR_MAP[level], "[ADK ").concat(LOG_LEVEL_STR[level], "]:").concat(RESET_COLOR);
83
95
  }
84
- const logger = new SimpleLogger();
96
+ let currentLogger = new SimpleLogger();
97
+ function setLogger(customLogger) {
98
+ currentLogger = customLogger != null ? customLogger : new NoOpLogger();
99
+ }
100
+ function getLogger() {
101
+ return currentLogger;
102
+ }
103
+ function resetLogger() {
104
+ currentLogger = new SimpleLogger();
105
+ }
106
+ const logger = {
107
+ log(level, ...args) {
108
+ currentLogger.log(level, ...args);
109
+ },
110
+ debug(...args) {
111
+ currentLogger.debug(...args);
112
+ },
113
+ info(...args) {
114
+ currentLogger.info(...args);
115
+ },
116
+ warn(...args) {
117
+ currentLogger.warn(...args);
118
+ },
119
+ error(...args) {
120
+ currentLogger.error(...args);
121
+ }
122
+ };
85
123
  export {
86
124
  LogLevel,
125
+ getLogger,
87
126
  logger,
88
- setLogLevel
127
+ resetLogger,
128
+ setLogLevel,
129
+ setLogger
89
130
  };
@@ -1,172 +1,119 @@
1
- var __defProp = Object.defineProperty;
2
- var __getOwnPropSymbols = Object.getOwnPropertySymbols;
3
- var __hasOwnProp = Object.prototype.hasOwnProperty;
4
- var __propIsEnum = Object.prototype.propertyIsEnumerable;
5
- var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
6
- var __spreadValues = (a, b) => {
7
- for (var prop in b || (b = {}))
8
- if (__hasOwnProp.call(b, prop))
9
- __defNormalProp(a, prop, b[prop]);
10
- if (__getOwnPropSymbols)
11
- for (var prop of __getOwnPropSymbols(b)) {
12
- if (__propIsEnum.call(b, prop))
13
- __defNormalProp(a, prop, b[prop]);
14
- }
15
- return a;
16
- };
17
1
  /**
18
2
  * @license
19
3
  * Copyright 2025 Google LLC
20
4
  * SPDX-License-Identifier: Apache-2.0
21
5
  */
22
6
  import { Type } from "@google/genai";
23
- import { z } from "zod";
24
- function isZodObject(obj) {
25
- var _a;
26
- return obj !== null && typeof obj === "object" && ((_a = obj._def) == null ? void 0 : _a.typeName) === "ZodObject";
7
+ import {
8
+ zodToJsonSchema as toJSONSchemaV3
9
+ } from "zod-to-json-schema";
10
+ import { toJSONSchema as toJSONSchemaV4 } from "zod/v4";
11
+ function isZodSchema(obj) {
12
+ return obj !== null && typeof obj === "object" && "parse" in obj && typeof obj.parse === "function" && "safeParse" in obj && typeof obj.safeParse === "function";
13
+ }
14
+ function isZodV3Schema(obj) {
15
+ return isZodSchema(obj) && !("_zod" in obj);
27
16
  }
28
- function parseZodType(zodType) {
29
- const def = zodType._def;
30
- if (!def) {
31
- return {};
17
+ function isZodV4Schema(obj) {
18
+ return isZodSchema(obj) && "_zod" in obj;
19
+ }
20
+ function getZodTypeName(schema) {
21
+ var _a, _b;
22
+ const schemaAny = schema;
23
+ if ((_a = schemaAny._def) == null ? void 0 : _a.typeName) {
24
+ return schemaAny._def.typeName;
32
25
  }
33
- const description = def.description;
34
- const result = {};
35
- if (description) result.description = description;
36
- const returnResult = (result2) => {
37
- if (result2.description === void 0) {
38
- delete result2.description;
39
- }
40
- return result2;
41
- };
42
- switch (def.typeName) {
43
- case z.ZodFirstPartyTypeKind.ZodString:
44
- result.type = Type.STRING;
45
- for (const check of def.checks || []) {
46
- if (check.kind === "min")
47
- result.minLength = check.value.toString();
48
- else if (check.kind === "max")
49
- result.maxLength = check.value.toString();
50
- else if (check.kind === "email")
51
- result.format = "email";
52
- else if (check.kind === "uuid")
53
- result.format = "uuid";
54
- else if (check.kind === "url")
55
- result.format = "uri";
56
- else if (check.kind === "regex")
57
- result.pattern = check.regex.source;
58
- }
59
- return returnResult(result);
60
- case z.ZodFirstPartyTypeKind.ZodNumber:
61
- result.type = Type.NUMBER;
62
- for (const check of def.checks || []) {
63
- if (check.kind === "min")
64
- result.minimum = check.value;
65
- else if (check.kind === "max")
66
- result.maximum = check.value;
67
- else if (check.kind === "int")
68
- result.type = Type.INTEGER;
69
- }
70
- return returnResult(result);
71
- case z.ZodFirstPartyTypeKind.ZodBoolean:
72
- result.type = Type.BOOLEAN;
73
- return returnResult(result);
74
- case z.ZodFirstPartyTypeKind.ZodArray:
75
- result.type = Type.ARRAY;
76
- result.items = parseZodType(def.type);
77
- if (def.minLength) result.minItems = def.minLength.value.toString();
78
- if (def.maxLength) result.maxItems = def.maxLength.value.toString();
79
- return returnResult(result);
80
- case z.ZodFirstPartyTypeKind.ZodObject: {
81
- const nestedSchema = zodObjectToSchema(zodType);
82
- return nestedSchema;
83
- }
84
- case z.ZodFirstPartyTypeKind.ZodLiteral:
85
- const literalType = typeof def.value;
86
- result.enum = [def.value.toString()];
87
- if (literalType === "string") {
88
- result.type = Type.STRING;
89
- } else if (literalType === "number") {
90
- result.type = Type.NUMBER;
91
- } else if (literalType === "boolean") {
92
- result.type = Type.BOOLEAN;
93
- } else if (def.value === null) {
94
- result.type = Type.NULL;
95
- } else {
96
- throw new Error("Unsupported ZodLiteral value type: ".concat(literalType));
97
- }
98
- return returnResult(result);
99
- case z.ZodFirstPartyTypeKind.ZodEnum:
100
- result.type = Type.STRING;
101
- result.enum = def.values;
102
- return returnResult(result);
103
- case z.ZodFirstPartyTypeKind.ZodNativeEnum:
104
- result.type = Type.STRING;
105
- result.enum = Object.values(def.values);
106
- return returnResult(result);
107
- case z.ZodFirstPartyTypeKind.ZodUnion:
108
- result.anyOf = def.options.map(parseZodType);
109
- return returnResult(result);
110
- case z.ZodFirstPartyTypeKind.ZodOptional:
111
- return parseZodType(def.innerType);
112
- case z.ZodFirstPartyTypeKind.ZodNullable:
113
- const nullableInner = parseZodType(def.innerType);
114
- return nullableInner ? returnResult(__spreadValues({
115
- anyOf: [nullableInner, { type: Type.NULL }]
116
- }, description && { description })) : returnResult(__spreadValues({ type: Type.NULL }, description && { description }));
117
- case z.ZodFirstPartyTypeKind.ZodDefault:
118
- const defaultInner = parseZodType(def.innerType);
119
- if (defaultInner) defaultInner.default = def.defaultValue();
120
- return defaultInner;
121
- case z.ZodFirstPartyTypeKind.ZodBranded:
122
- return parseZodType(def.type);
123
- case z.ZodFirstPartyTypeKind.ZodReadonly:
124
- return parseZodType(def.innerType);
125
- case z.ZodFirstPartyTypeKind.ZodNull:
126
- result.type = Type.NULL;
127
- return returnResult(result);
128
- case z.ZodFirstPartyTypeKind.ZodAny:
129
- case z.ZodFirstPartyTypeKind.ZodUnknown:
130
- return returnResult(__spreadValues({}, description && { description }));
131
- default:
132
- throw new Error("Unsupported Zod type: ".concat(def.typeName));
26
+ const zod4Type = (_b = schemaAny._def) == null ? void 0 : _b.type;
27
+ if (typeof zod4Type === "string" && zod4Type) {
28
+ return "Zod" + zod4Type.charAt(0).toUpperCase() + zod4Type.slice(1);
133
29
  }
30
+ return void 0;
31
+ }
32
+ function isZodObject(obj) {
33
+ return isZodSchema(obj) && getZodTypeName(obj) === "ZodObject";
134
34
  }
135
35
  function zodObjectToSchema(schema) {
136
- if (schema._def.typeName !== z.ZodFirstPartyTypeKind.ZodObject) {
137
- throw new Error("Expected a ZodObject");
36
+ if (!isZodObject(schema)) {
37
+ throw new Error("Expected a Zod Object");
138
38
  }
139
- const shape = schema.shape;
140
- const properties = {};
141
- const required = [];
142
- for (const key in shape) {
143
- const fieldSchema = shape[key];
144
- const parsedField = parseZodType(fieldSchema);
145
- if (parsedField) {
146
- properties[key] = parsedField;
147
- }
148
- let currentSchema = fieldSchema;
149
- let isOptional = false;
150
- while (currentSchema._def.typeName === z.ZodFirstPartyTypeKind.ZodOptional || currentSchema._def.typeName === z.ZodFirstPartyTypeKind.ZodDefault) {
151
- isOptional = true;
152
- currentSchema = currentSchema._def.innerType;
153
- }
154
- if (!isOptional) {
155
- required.push(key);
156
- }
39
+ if (isZodV4Schema(schema)) {
40
+ return toJSONSchemaV4(schema, {
41
+ target: "openapi-3.0",
42
+ io: "input",
43
+ override: (ctx) => {
44
+ var _a;
45
+ const { jsonSchema } = ctx;
46
+ if (jsonSchema.additionalProperties !== void 0) {
47
+ delete jsonSchema.additionalProperties;
48
+ }
49
+ if (jsonSchema.readOnly !== void 0) {
50
+ delete jsonSchema.readOnly;
51
+ }
52
+ if (jsonSchema.maxItems !== void 0) {
53
+ jsonSchema.maxItems = jsonSchema.maxItems.toString();
54
+ }
55
+ if (jsonSchema.format === "email" || jsonSchema.format === "uuid") {
56
+ delete jsonSchema.pattern;
57
+ }
58
+ if (jsonSchema.minItems !== void 0) {
59
+ jsonSchema.minItems = jsonSchema.minItems.toString();
60
+ }
61
+ if (jsonSchema.minLength !== void 0) {
62
+ jsonSchema.minLength = jsonSchema.minLength.toString();
63
+ }
64
+ if (jsonSchema.maxLength !== void 0) {
65
+ jsonSchema.maxLength = jsonSchema.maxLength.toString();
66
+ }
67
+ if (((_a = jsonSchema.enum) == null ? void 0 : _a.length) === 1 && jsonSchema.enum[0] === null) {
68
+ jsonSchema.type = Type.NULL;
69
+ delete jsonSchema.enum;
70
+ }
71
+ if (jsonSchema.type !== void 0) {
72
+ jsonSchema.type = jsonSchema.type.toUpperCase();
73
+ }
74
+ }
75
+ });
157
76
  }
158
- const catchall = schema._def.catchall;
159
- let additionalProperties = false;
160
- if (catchall && catchall._def.typeName !== z.ZodFirstPartyTypeKind.ZodNever) {
161
- additionalProperties = parseZodType(catchall) || true;
162
- } else {
163
- additionalProperties = schema._def.unknownKeys === "passthrough";
77
+ if (isZodV3Schema(schema)) {
78
+ return toJSONSchemaV3(schema, {
79
+ target: "openApi3",
80
+ emailStrategy: "format:email",
81
+ postProcess: (jsonSchema) => {
82
+ var _a, _b, _c, _d, _e, _f, _g;
83
+ if (!jsonSchema) {
84
+ return;
85
+ }
86
+ if (jsonSchema.additionalProperties !== void 0) {
87
+ delete jsonSchema.additionalProperties;
88
+ }
89
+ if (jsonSchema.maxItems !== void 0) {
90
+ jsonSchema.maxItems = (_a = jsonSchema.maxItems) == null ? void 0 : _a.toString();
91
+ }
92
+ if (jsonSchema.minItems !== void 0) {
93
+ jsonSchema.minItems = (_b = jsonSchema.minItems) == null ? void 0 : _b.toString();
94
+ }
95
+ if (jsonSchema.minLength !== void 0) {
96
+ jsonSchema.minLength = (_c = jsonSchema.minLength) == null ? void 0 : _c.toString();
97
+ }
98
+ if (jsonSchema.maxLength !== void 0) {
99
+ jsonSchema.maxLength = (_d = jsonSchema.maxLength) == null ? void 0 : _d.toString();
100
+ }
101
+ if (((_e = jsonSchema.enum) == null ? void 0 : _e.length) === 1 && jsonSchema.enum[0] === "null") {
102
+ jsonSchema.type = Type.NULL;
103
+ delete jsonSchema.enum;
104
+ }
105
+ if (jsonSchema.type === "integer" && jsonSchema.format !== "int64") {
106
+ (_f = jsonSchema.minimum) != null ? _f : jsonSchema.minimum = Number.MIN_SAFE_INTEGER;
107
+ (_g = jsonSchema.maximum) != null ? _g : jsonSchema.maximum = Number.MAX_SAFE_INTEGER;
108
+ }
109
+ if (jsonSchema.type !== void 0) {
110
+ jsonSchema.type = jsonSchema.type.toUpperCase();
111
+ }
112
+ return jsonSchema;
113
+ }
114
+ });
164
115
  }
165
- return __spreadValues({
166
- type: Type.OBJECT,
167
- properties,
168
- required: required.length > 0 ? required : []
169
- }, schema._def.description ? { description: schema._def.description } : {});
116
+ throw new Error("Unsupported Zod schema version.");
170
117
  }
171
118
  export {
172
119
  isZodObject,
@@ -16,7 +16,7 @@ function getBooleanEnvVar(envVar) {
16
16
  return false;
17
17
  }
18
18
  const envVarValue = (process.env[envVar] || "").toLowerCase();
19
- return ["true", "1"].includes(envVar.toLowerCase());
19
+ return ["true", "1"].includes(envVarValue);
20
20
  }
21
21
  export {
22
22
  GoogleLLMVariant,
@@ -3,7 +3,7 @@
3
3
  * Copyright 2025 Google LLC
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
- const version = "0.2.5";
6
+ const version = "0.3.0";
7
7
  export {
8
8
  version
9
9
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@google/adk",
3
- "version": "0.2.5",
3
+ "version": "0.3.0",
4
4
  "description": "Google ADK JS",
5
5
  "author": "Google",
6
6
  "license": "Apache-2.0",
@@ -30,6 +30,7 @@
30
30
  "scripts": {
31
31
  "clean": "rm -rf dist",
32
32
  "clean:all": "npm run clean && rm -rf node_modules",
33
+ "rebuild": "npm run clean:all && npm install && npm run build",
33
34
  "build": "tsc --emitDeclarationOnly && node ./build.js",
34
35
  "build:bundle": "tsc --emitDeclarationOnly && node ./build.js --bundle",
35
36
  "build:watch": "concurrently \"tsc --noEmit --watch --preserveWatchOutput\" \"node ./build.js --watch\"",
@@ -43,7 +44,8 @@
43
44
  "@modelcontextprotocol/sdk": "^1.24.0",
44
45
  "google-auth-library": "^10.3.0",
45
46
  "lodash-es": "^4.17.23",
46
- "zod": "3.25.76"
47
+ "zod": "^4.2.1",
48
+ "zod-to-json-schema": "^3.25.1"
47
49
  },
48
50
  "devDependencies": {
49
51
  "@types/lodash-es": "^4.17.12",