@office-ai/aioncli-core 0.1.1-8.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (564) hide show
  1. package/dist/.last_build +0 -0
  2. package/dist/index.d.ts +7 -0
  3. package/dist/index.js +8 -0
  4. package/dist/index.js.map +1 -0
  5. package/dist/src/__mocks__/fs/promises.d.ts +11 -0
  6. package/dist/src/__mocks__/fs/promises.js +17 -0
  7. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  8. package/dist/src/code_assist/codeAssist.d.ts +9 -0
  9. package/dist/src/code_assist/codeAssist.js +19 -0
  10. package/dist/src/code_assist/codeAssist.js.map +1 -0
  11. package/dist/src/code_assist/converter.d.ts +70 -0
  12. package/dist/src/code_assist/converter.js +126 -0
  13. package/dist/src/code_assist/converter.js.map +1 -0
  14. package/dist/src/code_assist/converter.test.d.ts +6 -0
  15. package/dist/src/code_assist/converter.test.js +279 -0
  16. package/dist/src/code_assist/converter.test.js.map +1 -0
  17. package/dist/src/code_assist/oauth2.d.ts +24 -0
  18. package/dist/src/code_assist/oauth2.js +373 -0
  19. package/dist/src/code_assist/oauth2.js.map +1 -0
  20. package/dist/src/code_assist/oauth2.test.d.ts +6 -0
  21. package/dist/src/code_assist/oauth2.test.js +334 -0
  22. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  23. package/dist/src/code_assist/server.d.ts +37 -0
  24. package/dist/src/code_assist/server.js +125 -0
  25. package/dist/src/code_assist/server.js.map +1 -0
  26. package/dist/src/code_assist/server.test.d.ts +6 -0
  27. package/dist/src/code_assist/server.test.js +134 -0
  28. package/dist/src/code_assist/server.test.js.map +1 -0
  29. package/dist/src/code_assist/setup.d.ts +20 -0
  30. package/dist/src/code_assist/setup.js +70 -0
  31. package/dist/src/code_assist/setup.js.map +1 -0
  32. package/dist/src/code_assist/setup.test.d.ts +6 -0
  33. package/dist/src/code_assist/setup.test.js +65 -0
  34. package/dist/src/code_assist/setup.test.js.map +1 -0
  35. package/dist/src/code_assist/types.d.ts +148 -0
  36. package/dist/src/code_assist/types.js +46 -0
  37. package/dist/src/code_assist/types.js.map +1 -0
  38. package/dist/src/config/config.d.ts +272 -0
  39. package/dist/src/config/config.js +554 -0
  40. package/dist/src/config/config.js.map +1 -0
  41. package/dist/src/config/config.test.d.ts +6 -0
  42. package/dist/src/config/config.test.js +365 -0
  43. package/dist/src/config/config.test.js.map +1 -0
  44. package/dist/src/config/flashFallback.test.d.ts +6 -0
  45. package/dist/src/config/flashFallback.test.js +87 -0
  46. package/dist/src/config/flashFallback.test.js.map +1 -0
  47. package/dist/src/config/models.d.ts +9 -0
  48. package/dist/src/config/models.js +10 -0
  49. package/dist/src/config/models.js.map +1 -0
  50. package/dist/src/core/client.d.ts +61 -0
  51. package/dist/src/core/client.js +485 -0
  52. package/dist/src/core/client.js.map +1 -0
  53. package/dist/src/core/client.test.d.ts +6 -0
  54. package/dist/src/core/client.test.js +1008 -0
  55. package/dist/src/core/client.test.js.map +1 -0
  56. package/dist/src/core/contentGenerator.d.ts +45 -0
  57. package/dist/src/core/contentGenerator.js +85 -0
  58. package/dist/src/core/contentGenerator.js.map +1 -0
  59. package/dist/src/core/contentGenerator.test.d.ts +6 -0
  60. package/dist/src/core/contentGenerator.test.js +100 -0
  61. package/dist/src/core/contentGenerator.test.js.map +1 -0
  62. package/dist/src/core/coreToolScheduler.d.ts +117 -0
  63. package/dist/src/core/coreToolScheduler.js +530 -0
  64. package/dist/src/core/coreToolScheduler.js.map +1 -0
  65. package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
  66. package/dist/src/core/coreToolScheduler.test.js +625 -0
  67. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  68. package/dist/src/core/geminiChat.d.ts +118 -0
  69. package/dist/src/core/geminiChat.js +509 -0
  70. package/dist/src/core/geminiChat.js.map +1 -0
  71. package/dist/src/core/geminiChat.test.d.ts +6 -0
  72. package/dist/src/core/geminiChat.test.js +424 -0
  73. package/dist/src/core/geminiChat.test.js.map +1 -0
  74. package/dist/src/core/geminiRequest.d.ts +13 -0
  75. package/dist/src/core/geminiRequest.js +10 -0
  76. package/dist/src/core/geminiRequest.js.map +1 -0
  77. package/dist/src/core/logger.d.ts +37 -0
  78. package/dist/src/core/logger.js +273 -0
  79. package/dist/src/core/logger.js.map +1 -0
  80. package/dist/src/core/logger.test.d.ts +6 -0
  81. package/dist/src/core/logger.test.js +467 -0
  82. package/dist/src/core/logger.test.js.map +1 -0
  83. package/dist/src/core/loggingContentGenerator.d.ts +24 -0
  84. package/dist/src/core/loggingContentGenerator.js +89 -0
  85. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  86. package/dist/src/core/modelCheck.d.ts +14 -0
  87. package/dist/src/core/modelCheck.js +62 -0
  88. package/dist/src/core/modelCheck.js.map +1 -0
  89. package/dist/src/core/nonInteractiveToolExecutor.d.ts +12 -0
  90. package/dist/src/core/nonInteractiveToolExecutor.js +124 -0
  91. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  92. package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  93. package/dist/src/core/nonInteractiveToolExecutor.test.js +165 -0
  94. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -0
  95. package/dist/src/core/openaiContentGenerator.d.ts +77 -0
  96. package/dist/src/core/openaiContentGenerator.js +1395 -0
  97. package/dist/src/core/openaiContentGenerator.js.map +1 -0
  98. package/dist/src/core/openaiContentGenerator.test.d.ts +6 -0
  99. package/dist/src/core/openaiContentGenerator.test.js +1904 -0
  100. package/dist/src/core/openaiContentGenerator.test.js.map +1 -0
  101. package/dist/src/core/prompts.d.ts +12 -0
  102. package/dist/src/core/prompts.js +359 -0
  103. package/dist/src/core/prompts.js.map +1 -0
  104. package/dist/src/core/prompts.test.d.ts +6 -0
  105. package/dist/src/core/prompts.test.js +214 -0
  106. package/dist/src/core/prompts.test.js.map +1 -0
  107. package/dist/src/core/subagent.d.ts +230 -0
  108. package/dist/src/core/subagent.js +447 -0
  109. package/dist/src/core/subagent.js.map +1 -0
  110. package/dist/src/core/subagent.test.d.ts +6 -0
  111. package/dist/src/core/subagent.test.js +515 -0
  112. package/dist/src/core/subagent.test.js.map +1 -0
  113. package/dist/src/core/tokenLimits.d.ts +10 -0
  114. package/dist/src/core/tokenLimits.js +28 -0
  115. package/dist/src/core/tokenLimits.js.map +1 -0
  116. package/dist/src/core/turn.d.ts +114 -0
  117. package/dist/src/core/turn.js +143 -0
  118. package/dist/src/core/turn.js.map +1 -0
  119. package/dist/src/core/turn.test.d.ts +6 -0
  120. package/dist/src/core/turn.test.js +369 -0
  121. package/dist/src/core/turn.test.js.map +1 -0
  122. package/dist/src/ide/detect-ide.d.ts +10 -0
  123. package/dist/src/ide/detect-ide.js +27 -0
  124. package/dist/src/ide/detect-ide.js.map +1 -0
  125. package/dist/src/ide/ide-client.d.ts +56 -0
  126. package/dist/src/ide/ide-client.js +268 -0
  127. package/dist/src/ide/ide-client.js.map +1 -0
  128. package/dist/src/ide/ide-installer.d.ts +14 -0
  129. package/dist/src/ide/ide-installer.js +109 -0
  130. package/dist/src/ide/ide-installer.js.map +1 -0
  131. package/dist/src/ide/ide-installer.test.d.ts +6 -0
  132. package/dist/src/ide/ide-installer.test.js +55 -0
  133. package/dist/src/ide/ide-installer.test.js.map +1 -0
  134. package/dist/src/ide/ideContext.d.ts +374 -0
  135. package/dist/src/ide/ideContext.js +147 -0
  136. package/dist/src/ide/ideContext.js.map +1 -0
  137. package/dist/src/ide/ideContext.test.d.ts +6 -0
  138. package/dist/src/ide/ideContext.test.js +265 -0
  139. package/dist/src/ide/ideContext.test.js.map +1 -0
  140. package/dist/src/index.d.ts +68 -0
  141. package/dist/src/index.js +78 -0
  142. package/dist/src/index.js.map +1 -0
  143. package/dist/src/index.test.d.ts +6 -0
  144. package/dist/src/index.test.js +12 -0
  145. package/dist/src/index.test.js.map +1 -0
  146. package/dist/src/mcp/google-auth-provider.d.ts +23 -0
  147. package/dist/src/mcp/google-auth-provider.js +63 -0
  148. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  149. package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  150. package/dist/src/mcp/google-auth-provider.test.js +54 -0
  151. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  152. package/dist/src/mcp/oauth-provider.d.ts +147 -0
  153. package/dist/src/mcp/oauth-provider.js +484 -0
  154. package/dist/src/mcp/oauth-provider.js.map +1 -0
  155. package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
  156. package/dist/src/mcp/oauth-provider.test.js +602 -0
  157. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  158. package/dist/src/mcp/oauth-token-storage.d.ts +83 -0
  159. package/dist/src/mcp/oauth-token-storage.js +151 -0
  160. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  161. package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  162. package/dist/src/mcp/oauth-token-storage.test.js +205 -0
  163. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  164. package/dist/src/mcp/oauth-utils.d.ts +109 -0
  165. package/dist/src/mcp/oauth-utils.js +183 -0
  166. package/dist/src/mcp/oauth-utils.js.map +1 -0
  167. package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
  168. package/dist/src/mcp/oauth-utils.test.js +144 -0
  169. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  170. package/dist/src/prompts/mcp-prompts.d.ts +8 -0
  171. package/dist/src/prompts/mcp-prompts.js +13 -0
  172. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  173. package/dist/src/prompts/prompt-registry.d.ts +34 -0
  174. package/dist/src/prompts/prompt-registry.js +63 -0
  175. package/dist/src/prompts/prompt-registry.js.map +1 -0
  176. package/dist/src/services/fileDiscoveryService.d.ts +35 -0
  177. package/dist/src/services/fileDiscoveryService.js +91 -0
  178. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  179. package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  180. package/dist/src/services/fileDiscoveryService.test.js +143 -0
  181. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  182. package/dist/src/services/gitService.d.ts +21 -0
  183. package/dist/src/services/gitService.js +101 -0
  184. package/dist/src/services/gitService.js.map +1 -0
  185. package/dist/src/services/gitService.test.d.ts +6 -0
  186. package/dist/src/services/gitService.test.js +209 -0
  187. package/dist/src/services/gitService.test.js.map +1 -0
  188. package/dist/src/services/loopDetectionService.d.ts +97 -0
  189. package/dist/src/services/loopDetectionService.js +340 -0
  190. package/dist/src/services/loopDetectionService.js.map +1 -0
  191. package/dist/src/services/loopDetectionService.test.d.ts +6 -0
  192. package/dist/src/services/loopDetectionService.test.js +484 -0
  193. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  194. package/dist/src/services/shellExecutionService.d.ts +70 -0
  195. package/dist/src/services/shellExecutionService.js +175 -0
  196. package/dist/src/services/shellExecutionService.js.map +1 -0
  197. package/dist/src/services/shellExecutionService.test.d.ts +6 -0
  198. package/dist/src/services/shellExecutionService.test.js +272 -0
  199. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  200. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +65 -0
  201. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +652 -0
  202. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  203. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +6 -0
  204. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +186 -0
  205. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  206. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +59 -0
  207. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +159 -0
  208. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  209. package/dist/src/telemetry/constants.d.ts +23 -0
  210. package/dist/src/telemetry/constants.js +24 -0
  211. package/dist/src/telemetry/constants.js.map +1 -0
  212. package/dist/src/telemetry/file-exporters.d.ts +28 -0
  213. package/dist/src/telemetry/file-exporters.js +62 -0
  214. package/dist/src/telemetry/file-exporters.js.map +1 -0
  215. package/dist/src/telemetry/index.d.ts +18 -0
  216. package/dist/src/telemetry/index.js +20 -0
  217. package/dist/src/telemetry/index.js.map +1 -0
  218. package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
  219. package/dist/src/telemetry/integration.test.circular.js +53 -0
  220. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  221. package/dist/src/telemetry/loggers.d.ts +18 -0
  222. package/dist/src/telemetry/loggers.js +268 -0
  223. package/dist/src/telemetry/loggers.js.map +1 -0
  224. package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  225. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  226. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  227. package/dist/src/telemetry/loggers.test.d.ts +6 -0
  228. package/dist/src/telemetry/loggers.test.js +568 -0
  229. package/dist/src/telemetry/loggers.test.js.map +1 -0
  230. package/dist/src/telemetry/metrics.d.ts +20 -0
  231. package/dist/src/telemetry/metrics.js +150 -0
  232. package/dist/src/telemetry/metrics.js.map +1 -0
  233. package/dist/src/telemetry/metrics.test.d.ts +6 -0
  234. package/dist/src/telemetry/metrics.test.js +212 -0
  235. package/dist/src/telemetry/metrics.test.js.map +1 -0
  236. package/dist/src/telemetry/sdk.d.ts +9 -0
  237. package/dist/src/telemetry/sdk.js +127 -0
  238. package/dist/src/telemetry/sdk.js.map +1 -0
  239. package/dist/src/telemetry/telemetry.test.d.ts +6 -0
  240. package/dist/src/telemetry/telemetry.test.js +50 -0
  241. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  242. package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
  243. package/dist/src/telemetry/tool-call-decision.js +29 -0
  244. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  245. package/dist/src/telemetry/types.d.ts +145 -0
  246. package/dist/src/telemetry/types.js +267 -0
  247. package/dist/src/telemetry/types.js.map +1 -0
  248. package/dist/src/telemetry/uiTelemetry.d.ts +71 -0
  249. package/dist/src/telemetry/uiTelemetry.js +140 -0
  250. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  251. package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  252. package/dist/src/telemetry/uiTelemetry.test.js +518 -0
  253. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  254. package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  255. package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
  256. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  257. package/dist/src/test-utils/tools.d.ts +23 -0
  258. package/dist/src/test-utils/tools.js +41 -0
  259. package/dist/src/test-utils/tools.js.map +1 -0
  260. package/dist/src/tools/diffOptions.d.ts +9 -0
  261. package/dist/src/tools/diffOptions.js +38 -0
  262. package/dist/src/tools/diffOptions.js.map +1 -0
  263. package/dist/src/tools/diffOptions.test.d.ts +6 -0
  264. package/dist/src/tools/diffOptions.test.js +119 -0
  265. package/dist/src/tools/diffOptions.test.js.map +1 -0
  266. package/dist/src/tools/edit.d.ts +55 -0
  267. package/dist/src/tools/edit.js +398 -0
  268. package/dist/src/tools/edit.js.map +1 -0
  269. package/dist/src/tools/edit.test.d.ts +6 -0
  270. package/dist/src/tools/edit.test.js +681 -0
  271. package/dist/src/tools/edit.test.js.map +1 -0
  272. package/dist/src/tools/glob.d.ts +51 -0
  273. package/dist/src/tools/glob.js +226 -0
  274. package/dist/src/tools/glob.js.map +1 -0
  275. package/dist/src/tools/glob.test.d.ts +6 -0
  276. package/dist/src/tools/glob.test.js +330 -0
  277. package/dist/src/tools/glob.test.js.map +1 -0
  278. package/dist/src/tools/grep.d.ts +46 -0
  279. package/dist/src/tools/grep.js +503 -0
  280. package/dist/src/tools/grep.js.map +1 -0
  281. package/dist/src/tools/grep.test.d.ts +6 -0
  282. package/dist/src/tools/grep.test.js +272 -0
  283. package/dist/src/tools/grep.test.js.map +1 -0
  284. package/dist/src/tools/ls.d.ts +86 -0
  285. package/dist/src/tools/ls.js +224 -0
  286. package/dist/src/tools/ls.js.map +1 -0
  287. package/dist/src/tools/ls.test.d.ts +6 -0
  288. package/dist/src/tools/ls.test.js +356 -0
  289. package/dist/src/tools/ls.test.js.map +1 -0
  290. package/dist/src/tools/mcp-client.d.ts +149 -0
  291. package/dist/src/tools/mcp-client.js +844 -0
  292. package/dist/src/tools/mcp-client.js.map +1 -0
  293. package/dist/src/tools/mcp-client.test.d.ts +6 -0
  294. package/dist/src/tools/mcp-client.test.js +643 -0
  295. package/dist/src/tools/mcp-client.test.js.map +1 -0
  296. package/dist/src/tools/mcp-tool.d.ts +29 -0
  297. package/dist/src/tools/mcp-tool.js +202 -0
  298. package/dist/src/tools/mcp-tool.js.map +1 -0
  299. package/dist/src/tools/mcp-tool.test.d.ts +6 -0
  300. package/dist/src/tools/mcp-tool.test.js +501 -0
  301. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  302. package/dist/src/tools/memoryTool.d.ts +43 -0
  303. package/dist/src/tools/memoryTool.js +290 -0
  304. package/dist/src/tools/memoryTool.js.map +1 -0
  305. package/dist/src/tools/memoryTool.test.d.ts +6 -0
  306. package/dist/src/tools/memoryTool.test.js +266 -0
  307. package/dist/src/tools/memoryTool.test.js.map +1 -0
  308. package/dist/src/tools/modifiable-tool.d.ts +32 -0
  309. package/dist/src/tools/modifiable-tool.js +88 -0
  310. package/dist/src/tools/modifiable-tool.js.map +1 -0
  311. package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
  312. package/dist/src/tools/modifiable-tool.test.js +193 -0
  313. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  314. package/dist/src/tools/read-file.d.ts +34 -0
  315. package/dist/src/tools/read-file.js +152 -0
  316. package/dist/src/tools/read-file.js.map +1 -0
  317. package/dist/src/tools/read-file.test.d.ts +6 -0
  318. package/dist/src/tools/read-file.test.js +300 -0
  319. package/dist/src/tools/read-file.test.js.map +1 -0
  320. package/dist/src/tools/read-many-files.d.ts +61 -0
  321. package/dist/src/tools/read-many-files.js +421 -0
  322. package/dist/src/tools/read-many-files.js.map +1 -0
  323. package/dist/src/tools/read-many-files.test.d.ts +6 -0
  324. package/dist/src/tools/read-many-files.test.js +455 -0
  325. package/dist/src/tools/read-many-files.test.js.map +1 -0
  326. package/dist/src/tools/shell.d.ts +23 -0
  327. package/dist/src/tools/shell.js +313 -0
  328. package/dist/src/tools/shell.js.map +1 -0
  329. package/dist/src/tools/shell.test.d.ts +6 -0
  330. package/dist/src/tools/shell.test.js +321 -0
  331. package/dist/src/tools/shell.test.js.map +1 -0
  332. package/dist/src/tools/tool-error.d.ts +26 -0
  333. package/dist/src/tools/tool-error.js +31 -0
  334. package/dist/src/tools/tool-error.js.map +1 -0
  335. package/dist/src/tools/tool-registry.d.ts +85 -0
  336. package/dist/src/tools/tool-registry.js +390 -0
  337. package/dist/src/tools/tool-registry.js.map +1 -0
  338. package/dist/src/tools/tool-registry.test.d.ts +6 -0
  339. package/dist/src/tools/tool-registry.test.js +417 -0
  340. package/dist/src/tools/tool-registry.test.js.map +1 -0
  341. package/dist/src/tools/tools.d.ts +328 -0
  342. package/dist/src/tools/tools.js +281 -0
  343. package/dist/src/tools/tools.js.map +1 -0
  344. package/dist/src/tools/tools.test.d.ts +6 -0
  345. package/dist/src/tools/tools.test.js +117 -0
  346. package/dist/src/tools/tools.test.js.map +1 -0
  347. package/dist/src/tools/web-fetch.d.ts +29 -0
  348. package/dist/src/tools/web-fetch.js +246 -0
  349. package/dist/src/tools/web-fetch.js.map +1 -0
  350. package/dist/src/tools/web-fetch.test.d.ts +6 -0
  351. package/dist/src/tools/web-fetch.test.js +71 -0
  352. package/dist/src/tools/web-fetch.test.js.map +1 -0
  353. package/dist/src/tools/web-search.d.ts +49 -0
  354. package/dist/src/tools/web-search.js +120 -0
  355. package/dist/src/tools/web-search.js.map +1 -0
  356. package/dist/src/tools/write-file.d.ts +46 -0
  357. package/dist/src/tools/write-file.js +321 -0
  358. package/dist/src/tools/write-file.js.map +1 -0
  359. package/dist/src/tools/write-file.test.d.ts +6 -0
  360. package/dist/src/tools/write-file.test.js +572 -0
  361. package/dist/src/tools/write-file.test.js.map +1 -0
  362. package/dist/src/utils/LruCache.d.ts +13 -0
  363. package/dist/src/utils/LruCache.js +38 -0
  364. package/dist/src/utils/LruCache.js.map +1 -0
  365. package/dist/src/utils/bfsFileSearch.d.ts +24 -0
  366. package/dist/src/utils/bfsFileSearch.js +89 -0
  367. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  368. package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
  369. package/dist/src/utils/bfsFileSearch.test.js +163 -0
  370. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  371. package/dist/src/utils/browser.d.ts +13 -0
  372. package/dist/src/utils/browser.js +49 -0
  373. package/dist/src/utils/browser.js.map +1 -0
  374. package/dist/src/utils/editCorrector.d.ts +53 -0
  375. package/dist/src/utils/editCorrector.js +546 -0
  376. package/dist/src/utils/editCorrector.js.map +1 -0
  377. package/dist/src/utils/editCorrector.test.d.ts +6 -0
  378. package/dist/src/utils/editCorrector.test.js +564 -0
  379. package/dist/src/utils/editCorrector.test.js.map +1 -0
  380. package/dist/src/utils/editor.d.ts +28 -0
  381. package/dist/src/utils/editor.js +186 -0
  382. package/dist/src/utils/editor.js.map +1 -0
  383. package/dist/src/utils/editor.test.d.ts +6 -0
  384. package/dist/src/utils/editor.test.js +445 -0
  385. package/dist/src/utils/editor.test.js.map +1 -0
  386. package/dist/src/utils/environmentContext.d.ts +21 -0
  387. package/dist/src/utils/environmentContext.js +90 -0
  388. package/dist/src/utils/environmentContext.js.map +1 -0
  389. package/dist/src/utils/environmentContext.test.d.ts +6 -0
  390. package/dist/src/utils/environmentContext.test.js +139 -0
  391. package/dist/src/utils/environmentContext.test.js.map +1 -0
  392. package/dist/src/utils/errorReporting.d.ts +14 -0
  393. package/dist/src/utils/errorReporting.js +88 -0
  394. package/dist/src/utils/errorReporting.js.map +1 -0
  395. package/dist/src/utils/errorReporting.test.d.ts +6 -0
  396. package/dist/src/utils/errorReporting.test.js +130 -0
  397. package/dist/src/utils/errorReporting.test.js.map +1 -0
  398. package/dist/src/utils/errors.d.ts +14 -0
  399. package/dist/src/utils/errors.js +54 -0
  400. package/dist/src/utils/errors.js.map +1 -0
  401. package/dist/src/utils/fetch.d.ts +11 -0
  402. package/dist/src/utils/fetch.js +51 -0
  403. package/dist/src/utils/fetch.js.map +1 -0
  404. package/dist/src/utils/fileUtils.d.ts +56 -0
  405. package/dist/src/utils/fileUtils.js +314 -0
  406. package/dist/src/utils/fileUtils.js.map +1 -0
  407. package/dist/src/utils/fileUtils.test.d.ts +6 -0
  408. package/dist/src/utils/fileUtils.test.js +363 -0
  409. package/dist/src/utils/fileUtils.test.js.map +1 -0
  410. package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  411. package/dist/src/utils/filesearch/crawlCache.js +57 -0
  412. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  413. package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  414. package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
  415. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  416. package/dist/src/utils/filesearch/fileSearch.d.ts +81 -0
  417. package/dist/src/utils/filesearch/fileSearch.js +241 -0
  418. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  419. package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  420. package/dist/src/utils/filesearch/fileSearch.test.js +654 -0
  421. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  422. package/dist/src/utils/filesearch/ignore.d.ts +35 -0
  423. package/dist/src/utils/filesearch/ignore.js +81 -0
  424. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  425. package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  426. package/dist/src/utils/filesearch/ignore.test.js +57 -0
  427. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  428. package/dist/src/utils/filesearch/result-cache.d.ts +34 -0
  429. package/dist/src/utils/filesearch/result-cache.js +61 -0
  430. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  431. package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  432. package/dist/src/utils/filesearch/result-cache.test.js +47 -0
  433. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  434. package/dist/src/utils/flashFallback.integration.test.d.ts +6 -0
  435. package/dist/src/utils/flashFallback.integration.test.js +118 -0
  436. package/dist/src/utils/flashFallback.integration.test.js.map +1 -0
  437. package/dist/src/utils/formatters.d.ts +6 -0
  438. package/dist/src/utils/formatters.js +16 -0
  439. package/dist/src/utils/formatters.js.map +1 -0
  440. package/dist/src/utils/generateContentResponseUtilities.d.ts +14 -0
  441. package/dist/src/utils/generateContentResponseUtilities.js +92 -0
  442. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  443. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  444. package/dist/src/utils/generateContentResponseUtilities.test.js +273 -0
  445. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  446. package/dist/src/utils/getFolderStructure.d.ts +31 -0
  447. package/dist/src/utils/getFolderStructure.js +246 -0
  448. package/dist/src/utils/getFolderStructure.js.map +1 -0
  449. package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
  450. package/dist/src/utils/getFolderStructure.test.js +282 -0
  451. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  452. package/dist/src/utils/gitIgnoreParser.d.ts +20 -0
  453. package/dist/src/utils/gitIgnoreParser.js +61 -0
  454. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  455. package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  456. package/dist/src/utils/gitIgnoreParser.test.js +154 -0
  457. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  458. package/dist/src/utils/gitUtils.d.ts +17 -0
  459. package/dist/src/utils/gitUtils.js +61 -0
  460. package/dist/src/utils/gitUtils.js.map +1 -0
  461. package/dist/src/utils/memoryDiscovery.d.ts +15 -0
  462. package/dist/src/utils/memoryDiscovery.js +219 -0
  463. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  464. package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  465. package/dist/src/utils/memoryDiscovery.test.js +181 -0
  466. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  467. package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
  468. package/dist/src/utils/memoryImportProcessor.js +300 -0
  469. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  470. package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  471. package/dist/src/utils/memoryImportProcessor.test.js +715 -0
  472. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  473. package/dist/src/utils/messageInspectors.d.ts +8 -0
  474. package/dist/src/utils/messageInspectors.js +16 -0
  475. package/dist/src/utils/messageInspectors.js.map +1 -0
  476. package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  477. package/dist/src/utils/nextSpeakerChecker.js +92 -0
  478. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  479. package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  480. package/dist/src/utils/nextSpeakerChecker.test.js +168 -0
  481. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  482. package/dist/src/utils/partUtils.d.ts +14 -0
  483. package/dist/src/utils/partUtils.js +65 -0
  484. package/dist/src/utils/partUtils.js.map +1 -0
  485. package/dist/src/utils/partUtils.test.d.ts +6 -0
  486. package/dist/src/utils/partUtils.test.js +130 -0
  487. package/dist/src/utils/partUtils.test.js.map +1 -0
  488. package/dist/src/utils/paths.d.ts +68 -0
  489. package/dist/src/utils/paths.js +170 -0
  490. package/dist/src/utils/paths.js.map +1 -0
  491. package/dist/src/utils/paths.test.d.ts +6 -0
  492. package/dist/src/utils/paths.test.js +153 -0
  493. package/dist/src/utils/paths.test.js.map +1 -0
  494. package/dist/src/utils/quotaErrorDetection.d.ts +22 -0
  495. package/dist/src/utils/quotaErrorDetection.js +65 -0
  496. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  497. package/dist/src/utils/retry.d.ts +30 -0
  498. package/dist/src/utils/retry.js +276 -0
  499. package/dist/src/utils/retry.js.map +1 -0
  500. package/dist/src/utils/retry.test.d.ts +6 -0
  501. package/dist/src/utils/retry.test.js +322 -0
  502. package/dist/src/utils/retry.test.js.map +1 -0
  503. package/dist/src/utils/safeJsonStringify.d.ts +13 -0
  504. package/dist/src/utils/safeJsonStringify.js +25 -0
  505. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  506. package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  507. package/dist/src/utils/safeJsonStringify.test.js +61 -0
  508. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  509. package/dist/src/utils/schemaValidator.d.ts +22 -0
  510. package/dist/src/utils/schemaValidator.js +65 -0
  511. package/dist/src/utils/schemaValidator.js.map +1 -0
  512. package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
  513. package/dist/src/utils/secure-browser-launcher.js +164 -0
  514. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  515. package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  516. package/dist/src/utils/secure-browser-launcher.test.js +149 -0
  517. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  518. package/dist/src/utils/session.d.ts +6 -0
  519. package/dist/src/utils/session.js +8 -0
  520. package/dist/src/utils/session.js.map +1 -0
  521. package/dist/src/utils/shell-utils.d.ts +78 -0
  522. package/dist/src/utils/shell-utils.js +306 -0
  523. package/dist/src/utils/shell-utils.js.map +1 -0
  524. package/dist/src/utils/shell-utils.test.d.ts +6 -0
  525. package/dist/src/utils/shell-utils.test.js +200 -0
  526. package/dist/src/utils/shell-utils.test.js.map +1 -0
  527. package/dist/src/utils/summarizer.d.ts +25 -0
  528. package/dist/src/utils/summarizer.js +51 -0
  529. package/dist/src/utils/summarizer.js.map +1 -0
  530. package/dist/src/utils/summarizer.test.d.ts +6 -0
  531. package/dist/src/utils/summarizer.test.js +131 -0
  532. package/dist/src/utils/summarizer.test.js.map +1 -0
  533. package/dist/src/utils/systemEncoding.d.ts +40 -0
  534. package/dist/src/utils/systemEncoding.js +149 -0
  535. package/dist/src/utils/systemEncoding.js.map +1 -0
  536. package/dist/src/utils/systemEncoding.test.d.ts +6 -0
  537. package/dist/src/utils/systemEncoding.test.js +368 -0
  538. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  539. package/dist/src/utils/testUtils.d.ts +29 -0
  540. package/dist/src/utils/testUtils.js +70 -0
  541. package/dist/src/utils/testUtils.js.map +1 -0
  542. package/dist/src/utils/textUtils.d.ts +13 -0
  543. package/dist/src/utils/textUtils.js +28 -0
  544. package/dist/src/utils/textUtils.js.map +1 -0
  545. package/dist/src/utils/user_account.d.ts +9 -0
  546. package/dist/src/utils/user_account.js +99 -0
  547. package/dist/src/utils/user_account.js.map +1 -0
  548. package/dist/src/utils/user_account.test.d.ts +6 -0
  549. package/dist/src/utils/user_account.test.js +153 -0
  550. package/dist/src/utils/user_account.test.js.map +1 -0
  551. package/dist/src/utils/user_id.d.ts +11 -0
  552. package/dist/src/utils/user_id.js +49 -0
  553. package/dist/src/utils/user_id.js.map +1 -0
  554. package/dist/src/utils/user_id.test.d.ts +6 -0
  555. package/dist/src/utils/user_id.test.js +21 -0
  556. package/dist/src/utils/user_id.test.js.map +1 -0
  557. package/dist/src/utils/workspaceContext.d.ts +51 -0
  558. package/dist/src/utils/workspaceContext.js +139 -0
  559. package/dist/src/utils/workspaceContext.js.map +1 -0
  560. package/dist/src/utils/workspaceContext.test.d.ts +6 -0
  561. package/dist/src/utils/workspaceContext.test.js +209 -0
  562. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  563. package/dist/tsconfig.tsbuildinfo +1 -0
  564. package/package.json +76 -0
@@ -0,0 +1,844 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { Client } from '@modelcontextprotocol/sdk/client/index.js';
7
+ import { StdioClientTransport } from '@modelcontextprotocol/sdk/client/stdio.js';
8
+ import { SSEClientTransport, } from '@modelcontextprotocol/sdk/client/sse.js';
9
+ import { StreamableHTTPClientTransport, } from '@modelcontextprotocol/sdk/client/streamableHttp.js';
10
+ import { ListPromptsResultSchema, GetPromptResultSchema, ListRootsRequestSchema, } from '@modelcontextprotocol/sdk/types.js';
11
+ import { parse } from 'shell-quote';
12
+ import { AuthProviderType } from '../config/config.js';
13
+ import { GoogleCredentialProvider } from '../mcp/google-auth-provider.js';
14
+ import { DiscoveredMCPTool } from './mcp-tool.js';
15
+ import { mcpToTool } from '@google/genai';
16
+ import { MCPOAuthProvider } from '../mcp/oauth-provider.js';
17
+ import { OAuthUtils } from '../mcp/oauth-utils.js';
18
+ import { MCPOAuthTokenStorage } from '../mcp/oauth-token-storage.js';
19
+ import { getErrorMessage } from '../utils/errors.js';
20
+ import { basename } from 'node:path';
21
+ import { pathToFileURL } from 'node:url';
22
+ export const MCP_DEFAULT_TIMEOUT_MSEC = 10 * 60 * 1000; // default to 10 minutes
23
+ /**
24
+ * Enum representing the connection status of an MCP server
25
+ */
26
+ export var MCPServerStatus;
27
+ (function (MCPServerStatus) {
28
+ /** Server is disconnected or experiencing errors */
29
+ MCPServerStatus["DISCONNECTED"] = "disconnected";
30
+ /** Server is in the process of connecting */
31
+ MCPServerStatus["CONNECTING"] = "connecting";
32
+ /** Server is connected and ready to use */
33
+ MCPServerStatus["CONNECTED"] = "connected";
34
+ })(MCPServerStatus || (MCPServerStatus = {}));
35
+ /**
36
+ * Enum representing the overall MCP discovery state
37
+ */
38
+ export var MCPDiscoveryState;
39
+ (function (MCPDiscoveryState) {
40
+ /** Discovery has not started yet */
41
+ MCPDiscoveryState["NOT_STARTED"] = "not_started";
42
+ /** Discovery is currently in progress */
43
+ MCPDiscoveryState["IN_PROGRESS"] = "in_progress";
44
+ /** Discovery has completed (with or without errors) */
45
+ MCPDiscoveryState["COMPLETED"] = "completed";
46
+ })(MCPDiscoveryState || (MCPDiscoveryState = {}));
47
+ /**
48
+ * Map to track the status of each MCP server within the core package
49
+ */
50
+ const serverStatuses = new Map();
51
+ /**
52
+ * Track the overall MCP discovery state
53
+ */
54
+ let mcpDiscoveryState = MCPDiscoveryState.NOT_STARTED;
55
+ /**
56
+ * Map to track which MCP servers have been discovered to require OAuth
57
+ */
58
+ export const mcpServerRequiresOAuth = new Map();
59
+ const statusChangeListeners = [];
60
+ /**
61
+ * Add a listener for MCP server status changes
62
+ */
63
+ export function addMCPStatusChangeListener(listener) {
64
+ statusChangeListeners.push(listener);
65
+ }
66
+ /**
67
+ * Remove a listener for MCP server status changes
68
+ */
69
+ export function removeMCPStatusChangeListener(listener) {
70
+ const index = statusChangeListeners.indexOf(listener);
71
+ if (index !== -1) {
72
+ statusChangeListeners.splice(index, 1);
73
+ }
74
+ }
75
+ /**
76
+ * Update the status of an MCP server
77
+ */
78
+ function updateMCPServerStatus(serverName, status) {
79
+ serverStatuses.set(serverName, status);
80
+ // Notify all listeners
81
+ for (const listener of statusChangeListeners) {
82
+ listener(serverName, status);
83
+ }
84
+ }
85
+ /**
86
+ * Get the current status of an MCP server
87
+ */
88
+ export function getMCPServerStatus(serverName) {
89
+ return serverStatuses.get(serverName) || MCPServerStatus.DISCONNECTED;
90
+ }
91
+ /**
92
+ * Get all MCP server statuses
93
+ */
94
+ export function getAllMCPServerStatuses() {
95
+ return new Map(serverStatuses);
96
+ }
97
+ /**
98
+ * Get the current MCP discovery state
99
+ */
100
+ export function getMCPDiscoveryState() {
101
+ return mcpDiscoveryState;
102
+ }
103
+ /**
104
+ * Extract WWW-Authenticate header from error message string.
105
+ * This is a more robust approach than regex matching.
106
+ *
107
+ * @param errorString The error message string
108
+ * @returns The www-authenticate header value if found, null otherwise
109
+ */
110
+ function extractWWWAuthenticateHeader(errorString) {
111
+ // Try multiple patterns to extract the header
112
+ const patterns = [
113
+ /www-authenticate:\s*([^\n\r]+)/i,
114
+ /WWW-Authenticate:\s*([^\n\r]+)/i,
115
+ /"www-authenticate":\s*"([^"]+)"/i,
116
+ /'www-authenticate':\s*'([^']+)'/i,
117
+ ];
118
+ for (const pattern of patterns) {
119
+ const match = errorString.match(pattern);
120
+ if (match) {
121
+ return match[1].trim();
122
+ }
123
+ }
124
+ return null;
125
+ }
126
+ /**
127
+ * Handle automatic OAuth discovery and authentication for a server.
128
+ *
129
+ * @param mcpServerName The name of the MCP server
130
+ * @param mcpServerConfig The MCP server configuration
131
+ * @param wwwAuthenticate The www-authenticate header value
132
+ * @returns True if OAuth was successfully configured and authenticated, false otherwise
133
+ */
134
+ async function handleAutomaticOAuth(mcpServerName, mcpServerConfig, wwwAuthenticate) {
135
+ try {
136
+ console.log(`🔐 '${mcpServerName}' requires OAuth authentication`);
137
+ // Always try to parse the resource metadata URI from the www-authenticate header
138
+ let oauthConfig;
139
+ const resourceMetadataUri = OAuthUtils.parseWWWAuthenticateHeader(wwwAuthenticate);
140
+ if (resourceMetadataUri) {
141
+ oauthConfig = await OAuthUtils.discoverOAuthConfig(resourceMetadataUri);
142
+ }
143
+ else if (mcpServerConfig.url) {
144
+ // Fallback: try to discover OAuth config from the base URL for SSE
145
+ const sseUrl = new URL(mcpServerConfig.url);
146
+ const baseUrl = `${sseUrl.protocol}//${sseUrl.host}`;
147
+ oauthConfig = await OAuthUtils.discoverOAuthConfig(baseUrl);
148
+ }
149
+ else if (mcpServerConfig.httpUrl) {
150
+ // Fallback: try to discover OAuth config from the base URL for HTTP
151
+ const httpUrl = new URL(mcpServerConfig.httpUrl);
152
+ const baseUrl = `${httpUrl.protocol}//${httpUrl.host}`;
153
+ oauthConfig = await OAuthUtils.discoverOAuthConfig(baseUrl);
154
+ }
155
+ if (!oauthConfig) {
156
+ console.error(`❌ Could not configure OAuth for '${mcpServerName}' - please authenticate manually with /mcp auth ${mcpServerName}`);
157
+ return false;
158
+ }
159
+ // OAuth configuration discovered - proceed with authentication
160
+ // Create OAuth configuration for authentication
161
+ const oauthAuthConfig = {
162
+ enabled: true,
163
+ authorizationUrl: oauthConfig.authorizationUrl,
164
+ tokenUrl: oauthConfig.tokenUrl,
165
+ scopes: oauthConfig.scopes || [],
166
+ };
167
+ // Perform OAuth authentication
168
+ console.log(`Starting OAuth authentication for server '${mcpServerName}'...`);
169
+ await MCPOAuthProvider.authenticate(mcpServerName, oauthAuthConfig);
170
+ console.log(`OAuth authentication successful for server '${mcpServerName}'`);
171
+ return true;
172
+ }
173
+ catch (error) {
174
+ console.error(`Failed to handle automatic OAuth for server '${mcpServerName}': ${getErrorMessage(error)}`);
175
+ return false;
176
+ }
177
+ }
178
+ /**
179
+ * Create a transport with OAuth token for the given server configuration.
180
+ *
181
+ * @param mcpServerName The name of the MCP server
182
+ * @param mcpServerConfig The MCP server configuration
183
+ * @param accessToken The OAuth access token
184
+ * @returns The transport with OAuth token, or null if creation fails
185
+ */
186
+ async function createTransportWithOAuth(mcpServerName, mcpServerConfig, accessToken) {
187
+ try {
188
+ if (mcpServerConfig.httpUrl) {
189
+ // Create HTTP transport with OAuth token
190
+ const oauthTransportOptions = {
191
+ requestInit: {
192
+ headers: {
193
+ ...mcpServerConfig.headers,
194
+ Authorization: `Bearer ${accessToken}`,
195
+ },
196
+ },
197
+ };
198
+ return new StreamableHTTPClientTransport(new URL(mcpServerConfig.httpUrl), oauthTransportOptions);
199
+ }
200
+ else if (mcpServerConfig.url) {
201
+ // Create SSE transport with OAuth token in Authorization header
202
+ return new SSEClientTransport(new URL(mcpServerConfig.url), {
203
+ requestInit: {
204
+ headers: {
205
+ ...mcpServerConfig.headers,
206
+ Authorization: `Bearer ${accessToken}`,
207
+ },
208
+ },
209
+ });
210
+ }
211
+ return null;
212
+ }
213
+ catch (error) {
214
+ console.error(`Failed to create OAuth transport for server '${mcpServerName}': ${getErrorMessage(error)}`);
215
+ return null;
216
+ }
217
+ }
218
+ /**
219
+ * Discovers tools from all configured MCP servers and registers them with the tool registry.
220
+ * It orchestrates the connection and discovery process for each server defined in the
221
+ * configuration, as well as any server specified via a command-line argument.
222
+ *
223
+ * @param mcpServers A record of named MCP server configurations.
224
+ * @param mcpServerCommand An optional command string for a dynamically specified MCP server.
225
+ * @param toolRegistry The central registry where discovered tools will be registered.
226
+ * @returns A promise that resolves when the discovery process has been attempted for all servers.
227
+ */
228
+ export async function discoverMcpTools(mcpServers, mcpServerCommand, toolRegistry, promptRegistry, debugMode, workspaceContext) {
229
+ mcpDiscoveryState = MCPDiscoveryState.IN_PROGRESS;
230
+ try {
231
+ mcpServers = populateMcpServerCommand(mcpServers, mcpServerCommand);
232
+ const discoveryPromises = Object.entries(mcpServers).map(([mcpServerName, mcpServerConfig]) => connectAndDiscover(mcpServerName, mcpServerConfig, toolRegistry, promptRegistry, debugMode, workspaceContext));
233
+ await Promise.all(discoveryPromises);
234
+ }
235
+ finally {
236
+ mcpDiscoveryState = MCPDiscoveryState.COMPLETED;
237
+ }
238
+ }
239
+ /** Visible for Testing */
240
+ export function populateMcpServerCommand(mcpServers, mcpServerCommand) {
241
+ if (mcpServerCommand) {
242
+ const cmd = mcpServerCommand;
243
+ const args = parse(cmd, process.env);
244
+ if (args.some((arg) => typeof arg !== 'string')) {
245
+ throw new Error('failed to parse mcpServerCommand: ' + cmd);
246
+ }
247
+ // use generic server name 'mcp'
248
+ mcpServers['mcp'] = {
249
+ command: args[0],
250
+ args: args.slice(1),
251
+ };
252
+ }
253
+ return mcpServers;
254
+ }
255
+ /**
256
+ * Connects to an MCP server and discovers available tools, registering them with the tool registry.
257
+ * This function handles the complete lifecycle of connecting to a server, discovering tools,
258
+ * and cleaning up resources if no tools are found.
259
+ *
260
+ * @param mcpServerName The name identifier for this MCP server
261
+ * @param mcpServerConfig Configuration object containing connection details
262
+ * @param toolRegistry The registry to register discovered tools with
263
+ * @returns Promise that resolves when discovery is complete
264
+ */
265
+ export async function connectAndDiscover(mcpServerName, mcpServerConfig, toolRegistry, promptRegistry, debugMode, workspaceContext) {
266
+ updateMCPServerStatus(mcpServerName, MCPServerStatus.CONNECTING);
267
+ let mcpClient;
268
+ try {
269
+ mcpClient = await connectToMcpServer(mcpServerName, mcpServerConfig, debugMode, workspaceContext);
270
+ mcpClient.onerror = (error) => {
271
+ console.error(`MCP ERROR (${mcpServerName}):`, error.toString());
272
+ updateMCPServerStatus(mcpServerName, MCPServerStatus.DISCONNECTED);
273
+ };
274
+ // Attempt to discover both prompts and tools
275
+ const prompts = await discoverPrompts(mcpServerName, mcpClient, promptRegistry);
276
+ const tools = await discoverTools(mcpServerName, mcpServerConfig, mcpClient);
277
+ // If we have neither prompts nor tools, it's a failed discovery
278
+ if (prompts.length === 0 && tools.length === 0) {
279
+ throw new Error('No prompts or tools found on the server.');
280
+ }
281
+ // If we found anything, the server is connected
282
+ updateMCPServerStatus(mcpServerName, MCPServerStatus.CONNECTED);
283
+ // Register any discovered tools
284
+ for (const tool of tools) {
285
+ toolRegistry.registerTool(tool);
286
+ }
287
+ }
288
+ catch (error) {
289
+ if (mcpClient) {
290
+ mcpClient.close();
291
+ }
292
+ console.error(`Error connecting to MCP server '${mcpServerName}': ${getErrorMessage(error)}`);
293
+ updateMCPServerStatus(mcpServerName, MCPServerStatus.DISCONNECTED);
294
+ }
295
+ }
296
+ /**
297
+ * Recursively validates that a JSON schema and all its nested properties and
298
+ * items have a `type` defined.
299
+ *
300
+ * @param schema The JSON schema to validate.
301
+ * @returns `true` if the schema is valid, `false` otherwise.
302
+ *
303
+ * @visiblefortesting
304
+ */
305
+ export function hasValidTypes(schema) {
306
+ if (typeof schema !== 'object' || schema === null) {
307
+ // Not a schema object we can validate, or not a schema at all.
308
+ // Treat as valid as it has no properties to be invalid.
309
+ return true;
310
+ }
311
+ const s = schema;
312
+ if (!s.type) {
313
+ // These keywords contain an array of schemas that should be validated.
314
+ //
315
+ // If no top level type was given, then they must each have a type.
316
+ let hasSubSchema = false;
317
+ const schemaArrayKeywords = ['anyOf', 'allOf', 'oneOf'];
318
+ for (const keyword of schemaArrayKeywords) {
319
+ const subSchemas = s[keyword];
320
+ if (Array.isArray(subSchemas)) {
321
+ hasSubSchema = true;
322
+ for (const subSchema of subSchemas) {
323
+ if (!hasValidTypes(subSchema)) {
324
+ return false;
325
+ }
326
+ }
327
+ }
328
+ }
329
+ // If the node itself is missing a type and had no subschemas, then it isn't valid.
330
+ if (!hasSubSchema)
331
+ return false;
332
+ }
333
+ if (s.type === 'object' && s.properties) {
334
+ if (typeof s.properties === 'object' && s.properties !== null) {
335
+ for (const prop of Object.values(s.properties)) {
336
+ if (!hasValidTypes(prop)) {
337
+ return false;
338
+ }
339
+ }
340
+ }
341
+ }
342
+ if (s.type === 'array' && s.items) {
343
+ if (!hasValidTypes(s.items)) {
344
+ return false;
345
+ }
346
+ }
347
+ return true;
348
+ }
349
+ /**
350
+ * Discovers and sanitizes tools from a connected MCP client.
351
+ * It retrieves function declarations from the client, filters out disabled tools,
352
+ * generates valid names for them, and wraps them in `DiscoveredMCPTool` instances.
353
+ *
354
+ * @param mcpServerName The name of the MCP server.
355
+ * @param mcpServerConfig The configuration for the MCP server.
356
+ * @param mcpClient The active MCP client instance.
357
+ * @returns A promise that resolves to an array of discovered and enabled tools.
358
+ * @throws An error if no enabled tools are found or if the server provides invalid function declarations.
359
+ */
360
+ export async function discoverTools(mcpServerName, mcpServerConfig, mcpClient) {
361
+ try {
362
+ const mcpCallableTool = mcpToTool(mcpClient);
363
+ const tool = await mcpCallableTool.tool();
364
+ if (!Array.isArray(tool.functionDeclarations)) {
365
+ // This is a valid case for a prompt-only server
366
+ return [];
367
+ }
368
+ const discoveredTools = [];
369
+ for (const funcDecl of tool.functionDeclarations) {
370
+ try {
371
+ if (!isEnabled(funcDecl, mcpServerName, mcpServerConfig)) {
372
+ continue;
373
+ }
374
+ if (!hasValidTypes(funcDecl.parametersJsonSchema)) {
375
+ console.warn(`Skipping tool '${funcDecl.name}' from MCP server '${mcpServerName}' ` +
376
+ `because it has missing types in its parameter schema. Please file an ` +
377
+ `issue with the owner of the MCP server.`);
378
+ continue;
379
+ }
380
+ discoveredTools.push(new DiscoveredMCPTool(mcpCallableTool, mcpServerName, funcDecl.name, funcDecl.description ?? '', funcDecl.parametersJsonSchema ?? { type: 'object', properties: {} }, mcpServerConfig.timeout ?? MCP_DEFAULT_TIMEOUT_MSEC, mcpServerConfig.trust));
381
+ }
382
+ catch (error) {
383
+ console.error(`Error discovering tool: '${funcDecl.name}' from MCP server '${mcpServerName}': ${error.message}`);
384
+ }
385
+ }
386
+ return discoveredTools;
387
+ }
388
+ catch (error) {
389
+ if (error instanceof Error &&
390
+ !error.message?.includes('Method not found')) {
391
+ console.error(`Error discovering tools from ${mcpServerName}: ${getErrorMessage(error)}`);
392
+ }
393
+ return [];
394
+ }
395
+ }
396
+ /**
397
+ * Discovers and logs prompts from a connected MCP client.
398
+ * It retrieves prompt declarations from the client and logs their names.
399
+ *
400
+ * @param mcpServerName The name of the MCP server.
401
+ * @param mcpClient The active MCP client instance.
402
+ */
403
+ export async function discoverPrompts(mcpServerName, mcpClient, promptRegistry) {
404
+ try {
405
+ // Only request prompts if the server supports them.
406
+ if (mcpClient.getServerCapabilities()?.prompts == null)
407
+ return [];
408
+ const response = await mcpClient.request({ method: 'prompts/list', params: {} }, ListPromptsResultSchema);
409
+ for (const prompt of response.prompts) {
410
+ promptRegistry.registerPrompt({
411
+ ...prompt,
412
+ serverName: mcpServerName,
413
+ invoke: (params) => invokeMcpPrompt(mcpServerName, mcpClient, prompt.name, params),
414
+ });
415
+ }
416
+ return response.prompts;
417
+ }
418
+ catch (error) {
419
+ // It's okay if this fails, not all servers will have prompts.
420
+ // Don't log an error if the method is not found, which is a common case.
421
+ if (error instanceof Error &&
422
+ !error.message?.includes('Method not found')) {
423
+ console.error(`Error discovering prompts from ${mcpServerName}: ${getErrorMessage(error)}`);
424
+ }
425
+ return [];
426
+ }
427
+ }
428
+ /**
429
+ * Invokes a prompt on a connected MCP client.
430
+ *
431
+ * @param mcpServerName The name of the MCP server.
432
+ * @param mcpClient The active MCP client instance.
433
+ * @param promptName The name of the prompt to invoke.
434
+ * @param promptParams The parameters to pass to the prompt.
435
+ * @returns A promise that resolves to the result of the prompt invocation.
436
+ */
437
+ export async function invokeMcpPrompt(mcpServerName, mcpClient, promptName, promptParams) {
438
+ try {
439
+ const response = await mcpClient.request({
440
+ method: 'prompts/get',
441
+ params: {
442
+ name: promptName,
443
+ arguments: promptParams,
444
+ },
445
+ }, GetPromptResultSchema);
446
+ return response;
447
+ }
448
+ catch (error) {
449
+ if (error instanceof Error &&
450
+ !error.message?.includes('Method not found')) {
451
+ console.error(`Error invoking prompt '${promptName}' from ${mcpServerName} ${promptParams}: ${getErrorMessage(error)}`);
452
+ }
453
+ throw error;
454
+ }
455
+ }
456
+ /**
457
+ * Creates and connects an MCP client to a server based on the provided configuration.
458
+ * It determines the appropriate transport (Stdio, SSE, or Streamable HTTP) and
459
+ * establishes a connection. It also applies a patch to handle request timeouts.
460
+ *
461
+ * @param mcpServerName The name of the MCP server, used for logging and identification.
462
+ * @param mcpServerConfig The configuration specifying how to connect to the server.
463
+ * @returns A promise that resolves to a connected MCP `Client` instance.
464
+ * @throws An error if the connection fails or the configuration is invalid.
465
+ */
466
+ export async function connectToMcpServer(mcpServerName, mcpServerConfig, debugMode, workspaceContext) {
467
+ const mcpClient = new Client({
468
+ name: 'gemini-cli-mcp-client',
469
+ version: '0.0.1',
470
+ });
471
+ mcpClient.registerCapabilities({
472
+ roots: {},
473
+ });
474
+ mcpClient.setRequestHandler(ListRootsRequestSchema, async () => {
475
+ const roots = [];
476
+ for (const dir of workspaceContext.getDirectories()) {
477
+ roots.push({
478
+ uri: pathToFileURL(dir).toString(),
479
+ name: basename(dir),
480
+ });
481
+ }
482
+ return {
483
+ roots,
484
+ };
485
+ });
486
+ // patch Client.callTool to use request timeout as genai McpCallTool.callTool does not do it
487
+ // TODO: remove this hack once GenAI SDK does callTool with request options
488
+ if ('callTool' in mcpClient) {
489
+ const origCallTool = mcpClient.callTool.bind(mcpClient);
490
+ mcpClient.callTool = function (params, resultSchema, options) {
491
+ return origCallTool(params, resultSchema, {
492
+ ...options,
493
+ timeout: mcpServerConfig.timeout ?? MCP_DEFAULT_TIMEOUT_MSEC,
494
+ });
495
+ };
496
+ }
497
+ try {
498
+ const transport = await createTransport(mcpServerName, mcpServerConfig, debugMode);
499
+ try {
500
+ await mcpClient.connect(transport, {
501
+ timeout: mcpServerConfig.timeout ?? MCP_DEFAULT_TIMEOUT_MSEC,
502
+ });
503
+ return mcpClient;
504
+ }
505
+ catch (error) {
506
+ await transport.close();
507
+ throw error;
508
+ }
509
+ }
510
+ catch (error) {
511
+ // Check if this is a 401 error that might indicate OAuth is required
512
+ const errorString = String(error);
513
+ if (errorString.includes('401') &&
514
+ (mcpServerConfig.httpUrl || mcpServerConfig.url)) {
515
+ mcpServerRequiresOAuth.set(mcpServerName, true);
516
+ // Only trigger automatic OAuth discovery for HTTP servers or when OAuth is explicitly configured
517
+ // For SSE servers, we should not trigger new OAuth flows automatically
518
+ const shouldTriggerOAuth = mcpServerConfig.httpUrl || mcpServerConfig.oauth?.enabled;
519
+ if (!shouldTriggerOAuth) {
520
+ // For SSE servers without explicit OAuth config, if a token was found but rejected, report it accurately.
521
+ const credentials = await MCPOAuthTokenStorage.getToken(mcpServerName);
522
+ if (credentials) {
523
+ const hasStoredTokens = await MCPOAuthProvider.getValidToken(mcpServerName, {
524
+ // Pass client ID if available
525
+ clientId: credentials.clientId,
526
+ });
527
+ if (hasStoredTokens) {
528
+ console.log(`Stored OAuth token for SSE server '${mcpServerName}' was rejected. ` +
529
+ `Please re-authenticate using: /mcp auth ${mcpServerName}`);
530
+ }
531
+ else {
532
+ console.log(`401 error received for SSE server '${mcpServerName}' without OAuth configuration. ` +
533
+ `Please authenticate using: /mcp auth ${mcpServerName}`);
534
+ }
535
+ }
536
+ throw new Error(`401 error received for SSE server '${mcpServerName}' without OAuth configuration. ` +
537
+ `Please authenticate using: /mcp auth ${mcpServerName}`);
538
+ }
539
+ // Try to extract www-authenticate header from the error
540
+ let wwwAuthenticate = extractWWWAuthenticateHeader(errorString);
541
+ // If we didn't get the header from the error string, try to get it from the server
542
+ if (!wwwAuthenticate && mcpServerConfig.url) {
543
+ console.log(`No www-authenticate header in error, trying to fetch it from server...`);
544
+ try {
545
+ const response = await fetch(mcpServerConfig.url, {
546
+ method: 'HEAD',
547
+ headers: {
548
+ Accept: 'text/event-stream',
549
+ },
550
+ signal: AbortSignal.timeout(5000),
551
+ });
552
+ if (response.status === 401) {
553
+ wwwAuthenticate = response.headers.get('www-authenticate');
554
+ if (wwwAuthenticate) {
555
+ console.log(`Found www-authenticate header from server: ${wwwAuthenticate}`);
556
+ }
557
+ }
558
+ }
559
+ catch (fetchError) {
560
+ console.debug(`Failed to fetch www-authenticate header: ${getErrorMessage(fetchError)}`);
561
+ }
562
+ }
563
+ if (wwwAuthenticate) {
564
+ console.log(`Received 401 with www-authenticate header: ${wwwAuthenticate}`);
565
+ // Try automatic OAuth discovery and authentication
566
+ const oauthSuccess = await handleAutomaticOAuth(mcpServerName, mcpServerConfig, wwwAuthenticate);
567
+ if (oauthSuccess) {
568
+ // Retry connection with OAuth token
569
+ console.log(`Retrying connection to '${mcpServerName}' with OAuth token...`);
570
+ // Get the valid token - we need to create a proper OAuth config
571
+ // The token should already be available from the authentication process
572
+ const credentials = await MCPOAuthTokenStorage.getToken(mcpServerName);
573
+ if (credentials) {
574
+ const accessToken = await MCPOAuthProvider.getValidToken(mcpServerName, {
575
+ // Pass client ID if available
576
+ clientId: credentials.clientId,
577
+ });
578
+ if (accessToken) {
579
+ // Create transport with OAuth token
580
+ const oauthTransport = await createTransportWithOAuth(mcpServerName, mcpServerConfig, accessToken);
581
+ if (oauthTransport) {
582
+ try {
583
+ await mcpClient.connect(oauthTransport, {
584
+ timeout: mcpServerConfig.timeout ?? MCP_DEFAULT_TIMEOUT_MSEC,
585
+ });
586
+ // Connection successful with OAuth
587
+ return mcpClient;
588
+ }
589
+ catch (retryError) {
590
+ console.error(`Failed to connect with OAuth token: ${getErrorMessage(retryError)}`);
591
+ throw retryError;
592
+ }
593
+ }
594
+ else {
595
+ console.error(`Failed to create OAuth transport for server '${mcpServerName}'`);
596
+ throw new Error(`Failed to create OAuth transport for server '${mcpServerName}'`);
597
+ }
598
+ }
599
+ else {
600
+ console.error(`Failed to get OAuth token for server '${mcpServerName}'`);
601
+ throw new Error(`Failed to get OAuth token for server '${mcpServerName}'`);
602
+ }
603
+ }
604
+ else {
605
+ console.error(`Failed to get credentials for server '${mcpServerName}' after successful OAuth authentication`);
606
+ throw new Error(`Failed to get credentials for server '${mcpServerName}' after successful OAuth authentication`);
607
+ }
608
+ }
609
+ else {
610
+ console.error(`Failed to handle automatic OAuth for server '${mcpServerName}'`);
611
+ throw new Error(`Failed to handle automatic OAuth for server '${mcpServerName}'`);
612
+ }
613
+ }
614
+ else {
615
+ // No www-authenticate header found, but we got a 401
616
+ // Only try OAuth discovery for HTTP servers or when OAuth is explicitly configured
617
+ // For SSE servers, we should not trigger new OAuth flows automatically
618
+ const shouldTryDiscovery = mcpServerConfig.httpUrl || mcpServerConfig.oauth?.enabled;
619
+ if (!shouldTryDiscovery) {
620
+ const credentials = await MCPOAuthTokenStorage.getToken(mcpServerName);
621
+ if (credentials) {
622
+ const hasStoredTokens = await MCPOAuthProvider.getValidToken(mcpServerName, {
623
+ // Pass client ID if available
624
+ clientId: credentials.clientId,
625
+ });
626
+ if (hasStoredTokens) {
627
+ console.log(`Stored OAuth token for SSE server '${mcpServerName}' was rejected. ` +
628
+ `Please re-authenticate using: /mcp auth ${mcpServerName}`);
629
+ }
630
+ else {
631
+ console.log(`401 error received for SSE server '${mcpServerName}' without OAuth configuration. ` +
632
+ `Please authenticate using: /mcp auth ${mcpServerName}`);
633
+ }
634
+ }
635
+ throw new Error(`401 error received for SSE server '${mcpServerName}' without OAuth configuration. ` +
636
+ `Please authenticate using: /mcp auth ${mcpServerName}`);
637
+ }
638
+ // For SSE servers, try to discover OAuth configuration from the base URL
639
+ console.log(`🔍 Attempting OAuth discovery for '${mcpServerName}'...`);
640
+ if (mcpServerConfig.url) {
641
+ const sseUrl = new URL(mcpServerConfig.url);
642
+ const baseUrl = `${sseUrl.protocol}//${sseUrl.host}`;
643
+ try {
644
+ // Try to discover OAuth configuration from the base URL
645
+ const oauthConfig = await OAuthUtils.discoverOAuthConfig(baseUrl);
646
+ if (oauthConfig) {
647
+ console.log(`Discovered OAuth configuration from base URL for server '${mcpServerName}'`);
648
+ // Create OAuth configuration for authentication
649
+ const oauthAuthConfig = {
650
+ enabled: true,
651
+ authorizationUrl: oauthConfig.authorizationUrl,
652
+ tokenUrl: oauthConfig.tokenUrl,
653
+ scopes: oauthConfig.scopes || [],
654
+ };
655
+ // Perform OAuth authentication
656
+ console.log(`Starting OAuth authentication for server '${mcpServerName}'...`);
657
+ await MCPOAuthProvider.authenticate(mcpServerName, oauthAuthConfig);
658
+ // Retry connection with OAuth token
659
+ const credentials = await MCPOAuthTokenStorage.getToken(mcpServerName);
660
+ if (credentials) {
661
+ const accessToken = await MCPOAuthProvider.getValidToken(mcpServerName, {
662
+ // Pass client ID if available
663
+ clientId: credentials.clientId,
664
+ });
665
+ if (accessToken) {
666
+ // Create transport with OAuth token
667
+ const oauthTransport = await createTransportWithOAuth(mcpServerName, mcpServerConfig, accessToken);
668
+ if (oauthTransport) {
669
+ try {
670
+ await mcpClient.connect(oauthTransport, {
671
+ timeout: mcpServerConfig.timeout ?? MCP_DEFAULT_TIMEOUT_MSEC,
672
+ });
673
+ // Connection successful with OAuth
674
+ return mcpClient;
675
+ }
676
+ catch (retryError) {
677
+ console.error(`Failed to connect with OAuth token: ${getErrorMessage(retryError)}`);
678
+ throw retryError;
679
+ }
680
+ }
681
+ else {
682
+ console.error(`Failed to create OAuth transport for server '${mcpServerName}'`);
683
+ throw new Error(`Failed to create OAuth transport for server '${mcpServerName}'`);
684
+ }
685
+ }
686
+ else {
687
+ console.error(`Failed to get OAuth token for server '${mcpServerName}'`);
688
+ throw new Error(`Failed to get OAuth token for server '${mcpServerName}'`);
689
+ }
690
+ }
691
+ else {
692
+ console.error(`Failed to get stored credentials for server '${mcpServerName}'`);
693
+ throw new Error(`Failed to get stored credentials for server '${mcpServerName}'`);
694
+ }
695
+ }
696
+ else {
697
+ console.error(`❌ Could not configure OAuth for '${mcpServerName}' - please authenticate manually with /mcp auth ${mcpServerName}`);
698
+ throw new Error(`OAuth configuration failed for '${mcpServerName}'. Please authenticate manually with /mcp auth ${mcpServerName}`);
699
+ }
700
+ }
701
+ catch (discoveryError) {
702
+ console.error(`❌ OAuth discovery failed for '${mcpServerName}' - please authenticate manually with /mcp auth ${mcpServerName}`);
703
+ throw discoveryError;
704
+ }
705
+ }
706
+ else {
707
+ console.error(`❌ '${mcpServerName}' requires authentication but no OAuth configuration found`);
708
+ throw new Error(`MCP server '${mcpServerName}' requires authentication. Please configure OAuth or check server settings.`);
709
+ }
710
+ }
711
+ }
712
+ else {
713
+ // Handle other connection errors
714
+ // Create a concise error message
715
+ const errorMessage = error.message || String(error);
716
+ const isNetworkError = errorMessage.includes('ENOTFOUND') ||
717
+ errorMessage.includes('ECONNREFUSED');
718
+ let conciseError;
719
+ if (isNetworkError) {
720
+ conciseError = `Cannot connect to '${mcpServerName}' - server may be down or URL incorrect`;
721
+ }
722
+ else {
723
+ conciseError = `Connection failed for '${mcpServerName}': ${errorMessage}`;
724
+ }
725
+ if (process.env.SANDBOX) {
726
+ conciseError += ` (check sandbox availability)`;
727
+ }
728
+ throw new Error(conciseError);
729
+ }
730
+ }
731
+ }
732
+ /** Visible for Testing */
733
+ export async function createTransport(mcpServerName, mcpServerConfig, debugMode) {
734
+ if (mcpServerConfig.authProviderType === AuthProviderType.GOOGLE_CREDENTIALS) {
735
+ const provider = new GoogleCredentialProvider(mcpServerConfig);
736
+ const transportOptions = {
737
+ authProvider: provider,
738
+ };
739
+ if (mcpServerConfig.httpUrl) {
740
+ return new StreamableHTTPClientTransport(new URL(mcpServerConfig.httpUrl), transportOptions);
741
+ }
742
+ else if (mcpServerConfig.url) {
743
+ return new SSEClientTransport(new URL(mcpServerConfig.url), transportOptions);
744
+ }
745
+ throw new Error('No URL configured for Google Credentials MCP server');
746
+ }
747
+ // Check if we have OAuth configuration or stored tokens
748
+ let accessToken = null;
749
+ let hasOAuthConfig = mcpServerConfig.oauth?.enabled;
750
+ if (hasOAuthConfig && mcpServerConfig.oauth) {
751
+ accessToken = await MCPOAuthProvider.getValidToken(mcpServerName, mcpServerConfig.oauth);
752
+ if (!accessToken) {
753
+ console.error(`MCP server '${mcpServerName}' requires OAuth authentication. ` +
754
+ `Please authenticate using the /mcp auth command.`);
755
+ throw new Error(`MCP server '${mcpServerName}' requires OAuth authentication. ` +
756
+ `Please authenticate using the /mcp auth command.`);
757
+ }
758
+ }
759
+ else {
760
+ // Check if we have stored OAuth tokens for this server (from previous authentication)
761
+ const credentials = await MCPOAuthTokenStorage.getToken(mcpServerName);
762
+ if (credentials) {
763
+ accessToken = await MCPOAuthProvider.getValidToken(mcpServerName, {
764
+ // Pass client ID if available
765
+ clientId: credentials.clientId,
766
+ });
767
+ if (accessToken) {
768
+ hasOAuthConfig = true;
769
+ console.log(`Found stored OAuth token for server '${mcpServerName}'`);
770
+ }
771
+ }
772
+ }
773
+ if (mcpServerConfig.httpUrl) {
774
+ const transportOptions = {};
775
+ // Set up headers with OAuth token if available
776
+ if (hasOAuthConfig && accessToken) {
777
+ transportOptions.requestInit = {
778
+ headers: {
779
+ ...mcpServerConfig.headers,
780
+ Authorization: `Bearer ${accessToken}`,
781
+ },
782
+ };
783
+ }
784
+ else if (mcpServerConfig.headers) {
785
+ transportOptions.requestInit = {
786
+ headers: mcpServerConfig.headers,
787
+ };
788
+ }
789
+ return new StreamableHTTPClientTransport(new URL(mcpServerConfig.httpUrl), transportOptions);
790
+ }
791
+ if (mcpServerConfig.url) {
792
+ const transportOptions = {};
793
+ // Set up headers with OAuth token if available
794
+ if (hasOAuthConfig && accessToken) {
795
+ transportOptions.requestInit = {
796
+ headers: {
797
+ ...mcpServerConfig.headers,
798
+ Authorization: `Bearer ${accessToken}`,
799
+ },
800
+ };
801
+ }
802
+ else if (mcpServerConfig.headers) {
803
+ transportOptions.requestInit = {
804
+ headers: mcpServerConfig.headers,
805
+ };
806
+ }
807
+ return new SSEClientTransport(new URL(mcpServerConfig.url), transportOptions);
808
+ }
809
+ if (mcpServerConfig.command) {
810
+ const transport = new StdioClientTransport({
811
+ command: mcpServerConfig.command,
812
+ args: mcpServerConfig.args || [],
813
+ env: {
814
+ ...process.env,
815
+ ...(mcpServerConfig.env || {}),
816
+ },
817
+ cwd: mcpServerConfig.cwd,
818
+ stderr: 'pipe',
819
+ });
820
+ if (debugMode) {
821
+ transport.stderr.on('data', (data) => {
822
+ const stderrStr = data.toString().trim();
823
+ console.debug(`[DEBUG] [MCP STDERR (${mcpServerName})]: `, stderrStr);
824
+ });
825
+ }
826
+ return transport;
827
+ }
828
+ throw new Error(`Invalid configuration: missing httpUrl (for Streamable HTTP), url (for SSE), and command (for stdio).`);
829
+ }
830
+ /** Visible for testing */
831
+ export function isEnabled(funcDecl, mcpServerName, mcpServerConfig) {
832
+ if (!funcDecl.name) {
833
+ console.warn(`Discovered a function declaration without a name from MCP server '${mcpServerName}'. Skipping.`);
834
+ return false;
835
+ }
836
+ const { includeTools, excludeTools } = mcpServerConfig;
837
+ // excludeTools takes precedence over includeTools
838
+ if (excludeTools && excludeTools.includes(funcDecl.name)) {
839
+ return false;
840
+ }
841
+ return (!includeTools ||
842
+ includeTools.some((tool) => tool === funcDecl.name || tool.startsWith(`${funcDecl.name}(`)));
843
+ }
844
+ //# sourceMappingURL=mcp-client.js.map