@google/gemini-cli-core 0.0.3-preview.4

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 (669) hide show
  1. package/LICENSE +202 -0
  2. package/README.md +310 -0
  3. package/dist/.last_build +0 -0
  4. package/dist/google-gemini-cli-core-0.3.0-preview.3.tgz +0 -0
  5. package/dist/index.d.ts +12 -0
  6. package/dist/index.js +13 -0
  7. package/dist/index.js.map +1 -0
  8. package/dist/src/__mocks__/fs/promises.d.ts +11 -0
  9. package/dist/src/__mocks__/fs/promises.js +17 -0
  10. package/dist/src/__mocks__/fs/promises.js.map +1 -0
  11. package/dist/src/code_assist/codeAssist.d.ts +10 -0
  12. package/dist/src/code_assist/codeAssist.js +19 -0
  13. package/dist/src/code_assist/codeAssist.js.map +1 -0
  14. package/dist/src/code_assist/converter.d.ts +72 -0
  15. package/dist/src/code_assist/converter.js +159 -0
  16. package/dist/src/code_assist/converter.js.map +1 -0
  17. package/dist/src/code_assist/converter.test.d.ts +6 -0
  18. package/dist/src/code_assist/converter.test.js +362 -0
  19. package/dist/src/code_assist/converter.test.js.map +1 -0
  20. package/dist/src/code_assist/oauth2.d.ts +22 -0
  21. package/dist/src/code_assist/oauth2.js +353 -0
  22. package/dist/src/code_assist/oauth2.js.map +1 -0
  23. package/dist/src/code_assist/oauth2.test.d.ts +6 -0
  24. package/dist/src/code_assist/oauth2.test.js +427 -0
  25. package/dist/src/code_assist/oauth2.test.js.map +1 -0
  26. package/dist/src/code_assist/server.d.ts +37 -0
  27. package/dist/src/code_assist/server.js +125 -0
  28. package/dist/src/code_assist/server.js.map +1 -0
  29. package/dist/src/code_assist/server.test.d.ts +6 -0
  30. package/dist/src/code_assist/server.test.js +134 -0
  31. package/dist/src/code_assist/server.test.js.map +1 -0
  32. package/dist/src/code_assist/setup.d.ts +20 -0
  33. package/dist/src/code_assist/setup.js +101 -0
  34. package/dist/src/code_assist/setup.js.map +1 -0
  35. package/dist/src/code_assist/setup.test.d.ts +6 -0
  36. package/dist/src/code_assist/setup.test.js +171 -0
  37. package/dist/src/code_assist/setup.test.js.map +1 -0
  38. package/dist/src/code_assist/types.d.ts +148 -0
  39. package/dist/src/code_assist/types.js +46 -0
  40. package/dist/src/code_assist/types.js.map +1 -0
  41. package/dist/src/config/config.d.ts +318 -0
  42. package/dist/src/config/config.js +633 -0
  43. package/dist/src/config/config.js.map +1 -0
  44. package/dist/src/config/config.test.d.ts +6 -0
  45. package/dist/src/config/config.test.js +585 -0
  46. package/dist/src/config/config.test.js.map +1 -0
  47. package/dist/src/config/flashFallback.test.d.ts +6 -0
  48. package/dist/src/config/flashFallback.test.js +87 -0
  49. package/dist/src/config/flashFallback.test.js.map +1 -0
  50. package/dist/src/config/models.d.ts +9 -0
  51. package/dist/src/config/models.js +10 -0
  52. package/dist/src/config/models.js.map +1 -0
  53. package/dist/src/config/storage.d.ts +32 -0
  54. package/dist/src/config/storage.js +90 -0
  55. package/dist/src/config/storage.js.map +1 -0
  56. package/dist/src/config/storage.test.d.ts +6 -0
  57. package/dist/src/config/storage.test.js +43 -0
  58. package/dist/src/config/storage.test.js.map +1 -0
  59. package/dist/src/core/client.d.ts +65 -0
  60. package/dist/src/core/client.js +689 -0
  61. package/dist/src/core/client.js.map +1 -0
  62. package/dist/src/core/client.test.d.ts +6 -0
  63. package/dist/src/core/client.test.js +1857 -0
  64. package/dist/src/core/client.test.js.map +1 -0
  65. package/dist/src/core/contentGenerator.d.ts +33 -0
  66. package/dist/src/core/contentGenerator.js +80 -0
  67. package/dist/src/core/contentGenerator.js.map +1 -0
  68. package/dist/src/core/contentGenerator.test.d.ts +6 -0
  69. package/dist/src/core/contentGenerator.test.js +124 -0
  70. package/dist/src/core/contentGenerator.test.js.map +1 -0
  71. package/dist/src/core/coreToolScheduler.d.ts +126 -0
  72. package/dist/src/core/coreToolScheduler.js +605 -0
  73. package/dist/src/core/coreToolScheduler.js.map +1 -0
  74. package/dist/src/core/coreToolScheduler.test.d.ts +6 -0
  75. package/dist/src/core/coreToolScheduler.test.js +923 -0
  76. package/dist/src/core/coreToolScheduler.test.js.map +1 -0
  77. package/dist/src/core/geminiChat.d.ts +122 -0
  78. package/dist/src/core/geminiChat.js +547 -0
  79. package/dist/src/core/geminiChat.js.map +1 -0
  80. package/dist/src/core/geminiChat.test.d.ts +6 -0
  81. package/dist/src/core/geminiChat.test.js +875 -0
  82. package/dist/src/core/geminiChat.test.js.map +1 -0
  83. package/dist/src/core/geminiRequest.d.ts +13 -0
  84. package/dist/src/core/geminiRequest.js +11 -0
  85. package/dist/src/core/geminiRequest.js.map +1 -0
  86. package/dist/src/core/logger.d.ts +60 -0
  87. package/dist/src/core/logger.js +360 -0
  88. package/dist/src/core/logger.js.map +1 -0
  89. package/dist/src/core/logger.test.d.ts +6 -0
  90. package/dist/src/core/logger.test.js +534 -0
  91. package/dist/src/core/logger.test.js.map +1 -0
  92. package/dist/src/core/loggingContentGenerator.d.ts +25 -0
  93. package/dist/src/core/loggingContentGenerator.js +97 -0
  94. package/dist/src/core/loggingContentGenerator.js.map +1 -0
  95. package/dist/src/core/nonInteractiveToolExecutor.d.ts +10 -0
  96. package/dist/src/core/nonInteractiveToolExecutor.js +24 -0
  97. package/dist/src/core/nonInteractiveToolExecutor.js.map +1 -0
  98. package/dist/src/core/nonInteractiveToolExecutor.test.d.ts +6 -0
  99. package/dist/src/core/nonInteractiveToolExecutor.test.js +236 -0
  100. package/dist/src/core/nonInteractiveToolExecutor.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 +236 -0
  108. package/dist/src/core/subagent.js +485 -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 +520 -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 +125 -0
  117. package/dist/src/core/turn.js +154 -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 +388 -0
  121. package/dist/src/core/turn.test.js.map +1 -0
  122. package/dist/src/generated/git-commit.d.ts +7 -0
  123. package/dist/src/generated/git-commit.js +10 -0
  124. package/dist/src/generated/git-commit.js.map +1 -0
  125. package/dist/src/ide/constants.d.ts +6 -0
  126. package/dist/src/ide/constants.js +7 -0
  127. package/dist/src/ide/constants.js.map +1 -0
  128. package/dist/src/ide/detect-ide.d.ts +25 -0
  129. package/dist/src/ide/detect-ide.js +104 -0
  130. package/dist/src/ide/detect-ide.js.map +1 -0
  131. package/dist/src/ide/detect-ide.test.d.ts +6 -0
  132. package/dist/src/ide/detect-ide.test.js +109 -0
  133. package/dist/src/ide/detect-ide.test.js.map +1 -0
  134. package/dist/src/ide/ide-client.d.ts +67 -0
  135. package/dist/src/ide/ide-client.js +418 -0
  136. package/dist/src/ide/ide-client.js.map +1 -0
  137. package/dist/src/ide/ide-client.test.d.ts +6 -0
  138. package/dist/src/ide/ide-client.test.js +155 -0
  139. package/dist/src/ide/ide-client.test.js.map +1 -0
  140. package/dist/src/ide/ide-installer.d.ts +14 -0
  141. package/dist/src/ide/ide-installer.js +107 -0
  142. package/dist/src/ide/ide-installer.js.map +1 -0
  143. package/dist/src/ide/ide-installer.test.d.ts +6 -0
  144. package/dist/src/ide/ide-installer.test.js +113 -0
  145. package/dist/src/ide/ide-installer.test.js.map +1 -0
  146. package/dist/src/ide/ideContext.d.ts +374 -0
  147. package/dist/src/ide/ideContext.js +147 -0
  148. package/dist/src/ide/ideContext.js.map +1 -0
  149. package/dist/src/ide/ideContext.test.d.ts +6 -0
  150. package/dist/src/ide/ideContext.test.js +265 -0
  151. package/dist/src/ide/ideContext.test.js.map +1 -0
  152. package/dist/src/ide/process-utils.d.ts +22 -0
  153. package/dist/src/ide/process-utils.js +153 -0
  154. package/dist/src/ide/process-utils.js.map +1 -0
  155. package/dist/src/ide/process-utils.test.d.ts +6 -0
  156. package/dist/src/ide/process-utils.test.js +72 -0
  157. package/dist/src/ide/process-utils.test.js.map +1 -0
  158. package/dist/src/index.d.ts +81 -0
  159. package/dist/src/index.js +90 -0
  160. package/dist/src/index.js.map +1 -0
  161. package/dist/src/index.test.d.ts +6 -0
  162. package/dist/src/index.test.js +12 -0
  163. package/dist/src/index.test.js.map +1 -0
  164. package/dist/src/mcp/google-auth-provider.d.ts +23 -0
  165. package/dist/src/mcp/google-auth-provider.js +72 -0
  166. package/dist/src/mcp/google-auth-provider.js.map +1 -0
  167. package/dist/src/mcp/google-auth-provider.test.d.ts +6 -0
  168. package/dist/src/mcp/google-auth-provider.test.js +89 -0
  169. package/dist/src/mcp/google-auth-provider.test.js.map +1 -0
  170. package/dist/src/mcp/oauth-provider.d.ts +146 -0
  171. package/dist/src/mcp/oauth-provider.js +601 -0
  172. package/dist/src/mcp/oauth-provider.js.map +1 -0
  173. package/dist/src/mcp/oauth-provider.test.d.ts +6 -0
  174. package/dist/src/mcp/oauth-provider.test.js +672 -0
  175. package/dist/src/mcp/oauth-provider.test.js.map +1 -0
  176. package/dist/src/mcp/oauth-token-storage.d.ts +61 -0
  177. package/dist/src/mcp/oauth-token-storage.js +148 -0
  178. package/dist/src/mcp/oauth-token-storage.js.map +1 -0
  179. package/dist/src/mcp/oauth-token-storage.test.d.ts +6 -0
  180. package/dist/src/mcp/oauth-token-storage.test.js +206 -0
  181. package/dist/src/mcp/oauth-token-storage.test.js.map +1 -0
  182. package/dist/src/mcp/oauth-utils.d.ts +119 -0
  183. package/dist/src/mcp/oauth-utils.js +235 -0
  184. package/dist/src/mcp/oauth-utils.js.map +1 -0
  185. package/dist/src/mcp/oauth-utils.test.d.ts +6 -0
  186. package/dist/src/mcp/oauth-utils.test.js +199 -0
  187. package/dist/src/mcp/oauth-utils.test.js.map +1 -0
  188. package/dist/src/mcp/token-storage/base-token-storage.d.ts +19 -0
  189. package/dist/src/mcp/token-storage/base-token-storage.js +36 -0
  190. package/dist/src/mcp/token-storage/base-token-storage.js.map +1 -0
  191. package/dist/src/mcp/token-storage/base-token-storage.test.d.ts +6 -0
  192. package/dist/src/mcp/token-storage/base-token-storage.test.js +160 -0
  193. package/dist/src/mcp/token-storage/base-token-storage.test.js.map +1 -0
  194. package/dist/src/mcp/token-storage/types.d.ts +34 -0
  195. package/dist/src/mcp/token-storage/types.js +7 -0
  196. package/dist/src/mcp/token-storage/types.js.map +1 -0
  197. package/dist/src/mocks/msw.d.ts +6 -0
  198. package/dist/src/mocks/msw.js +8 -0
  199. package/dist/src/mocks/msw.js.map +1 -0
  200. package/dist/src/prompts/mcp-prompts.d.ts +8 -0
  201. package/dist/src/prompts/mcp-prompts.js +13 -0
  202. package/dist/src/prompts/mcp-prompts.js.map +1 -0
  203. package/dist/src/prompts/prompt-registry.d.ts +34 -0
  204. package/dist/src/prompts/prompt-registry.js +63 -0
  205. package/dist/src/prompts/prompt-registry.js.map +1 -0
  206. package/dist/src/services/chatRecordingService.d.ts +150 -0
  207. package/dist/src/services/chatRecordingService.js +321 -0
  208. package/dist/src/services/chatRecordingService.js.map +1 -0
  209. package/dist/src/services/chatRecordingService.test.d.ts +6 -0
  210. package/dist/src/services/chatRecordingService.test.js +290 -0
  211. package/dist/src/services/chatRecordingService.test.js.map +1 -0
  212. package/dist/src/services/fileDiscoveryService.d.ts +35 -0
  213. package/dist/src/services/fileDiscoveryService.js +91 -0
  214. package/dist/src/services/fileDiscoveryService.js.map +1 -0
  215. package/dist/src/services/fileDiscoveryService.test.d.ts +6 -0
  216. package/dist/src/services/fileDiscoveryService.test.js +143 -0
  217. package/dist/src/services/fileDiscoveryService.test.js.map +1 -0
  218. package/dist/src/services/fileSystemService.d.ts +31 -0
  219. package/dist/src/services/fileSystemService.js +18 -0
  220. package/dist/src/services/fileSystemService.js.map +1 -0
  221. package/dist/src/services/fileSystemService.test.d.ts +6 -0
  222. package/dist/src/services/fileSystemService.test.js +41 -0
  223. package/dist/src/services/fileSystemService.test.js.map +1 -0
  224. package/dist/src/services/gitService.d.ts +23 -0
  225. package/dist/src/services/gitService.js +110 -0
  226. package/dist/src/services/gitService.js.map +1 -0
  227. package/dist/src/services/gitService.test.d.ts +6 -0
  228. package/dist/src/services/gitService.test.js +212 -0
  229. package/dist/src/services/gitService.test.js.map +1 -0
  230. package/dist/src/services/loopDetectionService.d.ts +98 -0
  231. package/dist/src/services/loopDetectionService.js +363 -0
  232. package/dist/src/services/loopDetectionService.js.map +1 -0
  233. package/dist/src/services/loopDetectionService.test.d.ts +6 -0
  234. package/dist/src/services/loopDetectionService.test.js +558 -0
  235. package/dist/src/services/loopDetectionService.test.js.map +1 -0
  236. package/dist/src/services/shellExecutionService.d.ts +68 -0
  237. package/dist/src/services/shellExecutionService.js +332 -0
  238. package/dist/src/services/shellExecutionService.js.map +1 -0
  239. package/dist/src/services/shellExecutionService.test.d.ts +6 -0
  240. package/dist/src/services/shellExecutionService.test.js +517 -0
  241. package/dist/src/services/shellExecutionService.test.js.map +1 -0
  242. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +121 -0
  243. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +773 -0
  244. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -0
  245. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.d.ts +17 -0
  246. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +407 -0
  247. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -0
  248. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +90 -0
  249. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +229 -0
  250. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -0
  251. package/dist/src/telemetry/constants.d.ts +32 -0
  252. package/dist/src/telemetry/constants.js +33 -0
  253. package/dist/src/telemetry/constants.js.map +1 -0
  254. package/dist/src/telemetry/file-exporters.d.ts +29 -0
  255. package/dist/src/telemetry/file-exporters.js +62 -0
  256. package/dist/src/telemetry/file-exporters.js.map +1 -0
  257. package/dist/src/telemetry/index.d.ts +21 -0
  258. package/dist/src/telemetry/index.js +21 -0
  259. package/dist/src/telemetry/index.js.map +1 -0
  260. package/dist/src/telemetry/integration.test.circular.d.ts +6 -0
  261. package/dist/src/telemetry/integration.test.circular.js +54 -0
  262. package/dist/src/telemetry/integration.test.circular.js.map +1 -0
  263. package/dist/src/telemetry/loggers.d.ts +26 -0
  264. package/dist/src/telemetry/loggers.js +404 -0
  265. package/dist/src/telemetry/loggers.js.map +1 -0
  266. package/dist/src/telemetry/loggers.test.circular.d.ts +6 -0
  267. package/dist/src/telemetry/loggers.test.circular.js +107 -0
  268. package/dist/src/telemetry/loggers.test.circular.js.map +1 -0
  269. package/dist/src/telemetry/loggers.test.d.ts +6 -0
  270. package/dist/src/telemetry/loggers.test.js +658 -0
  271. package/dist/src/telemetry/loggers.test.js.map +1 -0
  272. package/dist/src/telemetry/metrics.d.ts +36 -0
  273. package/dist/src/telemetry/metrics.js +208 -0
  274. package/dist/src/telemetry/metrics.js.map +1 -0
  275. package/dist/src/telemetry/metrics.test.d.ts +6 -0
  276. package/dist/src/telemetry/metrics.test.js +242 -0
  277. package/dist/src/telemetry/metrics.test.js.map +1 -0
  278. package/dist/src/telemetry/sdk.d.ts +9 -0
  279. package/dist/src/telemetry/sdk.js +163 -0
  280. package/dist/src/telemetry/sdk.js.map +1 -0
  281. package/dist/src/telemetry/sdk.test.d.ts +6 -0
  282. package/dist/src/telemetry/sdk.test.js +82 -0
  283. package/dist/src/telemetry/sdk.test.js.map +1 -0
  284. package/dist/src/telemetry/telemetry-utils.d.ts +6 -0
  285. package/dist/src/telemetry/telemetry-utils.js +14 -0
  286. package/dist/src/telemetry/telemetry-utils.js.map +1 -0
  287. package/dist/src/telemetry/telemetry-utils.test.d.ts +6 -0
  288. package/dist/src/telemetry/telemetry-utils.test.js +40 -0
  289. package/dist/src/telemetry/telemetry-utils.test.js.map +1 -0
  290. package/dist/src/telemetry/telemetry.test.d.ts +6 -0
  291. package/dist/src/telemetry/telemetry.test.js +50 -0
  292. package/dist/src/telemetry/telemetry.test.js.map +1 -0
  293. package/dist/src/telemetry/tool-call-decision.d.ts +13 -0
  294. package/dist/src/telemetry/tool-call-decision.js +29 -0
  295. package/dist/src/telemetry/tool-call-decision.js.map +1 -0
  296. package/dist/src/telemetry/types.d.ts +220 -0
  297. package/dist/src/telemetry/types.js +383 -0
  298. package/dist/src/telemetry/types.js.map +1 -0
  299. package/dist/src/telemetry/uiTelemetry.d.ts +75 -0
  300. package/dist/src/telemetry/uiTelemetry.js +153 -0
  301. package/dist/src/telemetry/uiTelemetry.js.map +1 -0
  302. package/dist/src/telemetry/uiTelemetry.test.d.ts +6 -0
  303. package/dist/src/telemetry/uiTelemetry.test.js +558 -0
  304. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -0
  305. package/dist/src/test-utils/config.d.ts +17 -0
  306. package/dist/src/test-utils/config.js +32 -0
  307. package/dist/src/test-utils/config.js.map +1 -0
  308. package/dist/src/test-utils/mockWorkspaceContext.d.ts +13 -0
  309. package/dist/src/test-utils/mockWorkspaceContext.js +24 -0
  310. package/dist/src/test-utils/mockWorkspaceContext.js.map +1 -0
  311. package/dist/src/test-utils/tools.d.ts +45 -0
  312. package/dist/src/test-utils/tools.js +105 -0
  313. package/dist/src/test-utils/tools.js.map +1 -0
  314. package/dist/src/tools/diffOptions.d.ts +9 -0
  315. package/dist/src/tools/diffOptions.js +38 -0
  316. package/dist/src/tools/diffOptions.js.map +1 -0
  317. package/dist/src/tools/diffOptions.test.d.ts +6 -0
  318. package/dist/src/tools/diffOptions.test.js +119 -0
  319. package/dist/src/tools/diffOptions.test.js.map +1 -0
  320. package/dist/src/tools/edit.d.ts +56 -0
  321. package/dist/src/tools/edit.js +423 -0
  322. package/dist/src/tools/edit.js.map +1 -0
  323. package/dist/src/tools/edit.test.d.ts +6 -0
  324. package/dist/src/tools/edit.test.js +713 -0
  325. package/dist/src/tools/edit.test.js.map +1 -0
  326. package/dist/src/tools/glob.d.ts +52 -0
  327. package/dist/src/tools/glob.js +236 -0
  328. package/dist/src/tools/glob.js.map +1 -0
  329. package/dist/src/tools/glob.test.d.ts +6 -0
  330. package/dist/src/tools/glob.test.js +375 -0
  331. package/dist/src/tools/glob.test.js.map +1 -0
  332. package/dist/src/tools/grep.d.ts +47 -0
  333. package/dist/src/tools/grep.js +517 -0
  334. package/dist/src/tools/grep.js.map +1 -0
  335. package/dist/src/tools/grep.test.d.ts +6 -0
  336. package/dist/src/tools/grep.test.js +295 -0
  337. package/dist/src/tools/grep.test.js.map +1 -0
  338. package/dist/src/tools/ls.d.ts +68 -0
  339. package/dist/src/tools/ls.js +227 -0
  340. package/dist/src/tools/ls.js.map +1 -0
  341. package/dist/src/tools/ls.test.d.ts +6 -0
  342. package/dist/src/tools/ls.test.js +389 -0
  343. package/dist/src/tools/ls.test.js.map +1 -0
  344. package/dist/src/tools/mcp-client-manager.d.ts +38 -0
  345. package/dist/src/tools/mcp-client-manager.js +74 -0
  346. package/dist/src/tools/mcp-client-manager.js.map +1 -0
  347. package/dist/src/tools/mcp-client-manager.test.d.ts +6 -0
  348. package/dist/src/tools/mcp-client-manager.test.js +39 -0
  349. package/dist/src/tools/mcp-client-manager.test.js.map +1 -0
  350. package/dist/src/tools/mcp-client.d.ts +199 -0
  351. package/dist/src/tools/mcp-client.js +995 -0
  352. package/dist/src/tools/mcp-client.js.map +1 -0
  353. package/dist/src/tools/mcp-client.test.d.ts +6 -0
  354. package/dist/src/tools/mcp-client.test.js +454 -0
  355. package/dist/src/tools/mcp-client.test.js.map +1 -0
  356. package/dist/src/tools/mcp-tool.d.ts +23 -0
  357. package/dist/src/tools/mcp-tool.js +240 -0
  358. package/dist/src/tools/mcp-tool.js.map +1 -0
  359. package/dist/src/tools/mcp-tool.test.d.ts +6 -0
  360. package/dist/src/tools/mcp-tool.test.js +576 -0
  361. package/dist/src/tools/mcp-tool.test.js.map +1 -0
  362. package/dist/src/tools/memoryTool.d.ts +40 -0
  363. package/dist/src/tools/memoryTool.js +296 -0
  364. package/dist/src/tools/memoryTool.js.map +1 -0
  365. package/dist/src/tools/memoryTool.test.d.ts +6 -0
  366. package/dist/src/tools/memoryTool.test.js +298 -0
  367. package/dist/src/tools/memoryTool.test.js.map +1 -0
  368. package/dist/src/tools/modifiable-tool.d.ts +32 -0
  369. package/dist/src/tools/modifiable-tool.js +88 -0
  370. package/dist/src/tools/modifiable-tool.js.map +1 -0
  371. package/dist/src/tools/modifiable-tool.test.d.ts +6 -0
  372. package/dist/src/tools/modifiable-tool.test.js +193 -0
  373. package/dist/src/tools/modifiable-tool.test.js.map +1 -0
  374. package/dist/src/tools/read-file.d.ts +35 -0
  375. package/dist/src/tools/read-file.js +127 -0
  376. package/dist/src/tools/read-file.js.map +1 -0
  377. package/dist/src/tools/read-file.test.d.ts +6 -0
  378. package/dist/src/tools/read-file.test.js +311 -0
  379. package/dist/src/tools/read-file.test.js.map +1 -0
  380. package/dist/src/tools/read-many-files.d.ts +60 -0
  381. package/dist/src/tools/read-many-files.js +414 -0
  382. package/dist/src/tools/read-many-files.js.map +1 -0
  383. package/dist/src/tools/read-many-files.test.d.ts +6 -0
  384. package/dist/src/tools/read-many-files.test.js +565 -0
  385. package/dist/src/tools/read-many-files.test.js.map +1 -0
  386. package/dist/src/tools/ripGrep.d.ts +47 -0
  387. package/dist/src/tools/ripGrep.js +368 -0
  388. package/dist/src/tools/ripGrep.js.map +1 -0
  389. package/dist/src/tools/ripGrep.test.d.ts +6 -0
  390. package/dist/src/tools/ripGrep.test.js +874 -0
  391. package/dist/src/tools/ripGrep.test.js.map +1 -0
  392. package/dist/src/tools/shell.d.ts +22 -0
  393. package/dist/src/tools/shell.js +320 -0
  394. package/dist/src/tools/shell.js.map +1 -0
  395. package/dist/src/tools/shell.test.d.ts +6 -0
  396. package/dist/src/tools/shell.test.js +336 -0
  397. package/dist/src/tools/shell.test.js.map +1 -0
  398. package/dist/src/tools/tool-error.d.ts +43 -0
  399. package/dist/src/tools/tool-error.js +58 -0
  400. package/dist/src/tools/tool-error.js.map +1 -0
  401. package/dist/src/tools/tool-registry.d.ts +86 -0
  402. package/dist/src/tools/tool-registry.js +369 -0
  403. package/dist/src/tools/tool-registry.js.map +1 -0
  404. package/dist/src/tools/tool-registry.test.d.ts +6 -0
  405. package/dist/src/tools/tool-registry.test.js +332 -0
  406. package/dist/src/tools/tool-registry.test.js.map +1 -0
  407. package/dist/src/tools/tools.d.ts +274 -0
  408. package/dist/src/tools/tools.js +250 -0
  409. package/dist/src/tools/tools.js.map +1 -0
  410. package/dist/src/tools/tools.test.d.ts +6 -0
  411. package/dist/src/tools/tools.test.js +205 -0
  412. package/dist/src/tools/tools.test.js.map +1 -0
  413. package/dist/src/tools/web-fetch.d.ts +27 -0
  414. package/dist/src/tools/web-fetch.js +243 -0
  415. package/dist/src/tools/web-fetch.js.map +1 -0
  416. package/dist/src/tools/web-fetch.test.d.ts +6 -0
  417. package/dist/src/tools/web-fetch.test.js +114 -0
  418. package/dist/src/tools/web-fetch.test.js.map +1 -0
  419. package/dist/src/tools/web-search.d.ts +49 -0
  420. package/dist/src/tools/web-search.js +137 -0
  421. package/dist/src/tools/web-search.js.map +1 -0
  422. package/dist/src/tools/web-search.test.d.ts +6 -0
  423. package/dist/src/tools/web-search.test.js +207 -0
  424. package/dist/src/tools/web-search.test.js.map +1 -0
  425. package/dist/src/tools/write-file.d.ts +52 -0
  426. package/dist/src/tools/write-file.js +314 -0
  427. package/dist/src/tools/write-file.js.map +1 -0
  428. package/dist/src/tools/write-file.test.d.ts +6 -0
  429. package/dist/src/tools/write-file.test.js +531 -0
  430. package/dist/src/tools/write-file.test.js.map +1 -0
  431. package/dist/src/utils/LruCache.d.ts +13 -0
  432. package/dist/src/utils/LruCache.js +38 -0
  433. package/dist/src/utils/LruCache.js.map +1 -0
  434. package/dist/src/utils/bfsFileSearch.d.ts +24 -0
  435. package/dist/src/utils/bfsFileSearch.js +89 -0
  436. package/dist/src/utils/bfsFileSearch.js.map +1 -0
  437. package/dist/src/utils/bfsFileSearch.test.d.ts +6 -0
  438. package/dist/src/utils/bfsFileSearch.test.js +163 -0
  439. package/dist/src/utils/bfsFileSearch.test.js.map +1 -0
  440. package/dist/src/utils/browser.d.ts +13 -0
  441. package/dist/src/utils/browser.js +50 -0
  442. package/dist/src/utils/browser.js.map +1 -0
  443. package/dist/src/utils/editCorrector.d.ts +53 -0
  444. package/dist/src/utils/editCorrector.js +545 -0
  445. package/dist/src/utils/editCorrector.js.map +1 -0
  446. package/dist/src/utils/editCorrector.test.d.ts +6 -0
  447. package/dist/src/utils/editCorrector.test.js +564 -0
  448. package/dist/src/utils/editCorrector.test.js.map +1 -0
  449. package/dist/src/utils/editor.d.ts +28 -0
  450. package/dist/src/utils/editor.js +186 -0
  451. package/dist/src/utils/editor.js.map +1 -0
  452. package/dist/src/utils/editor.test.d.ts +6 -0
  453. package/dist/src/utils/editor.test.js +445 -0
  454. package/dist/src/utils/editor.test.js.map +1 -0
  455. package/dist/src/utils/environmentContext.d.ts +21 -0
  456. package/dist/src/utils/environmentContext.js +90 -0
  457. package/dist/src/utils/environmentContext.js.map +1 -0
  458. package/dist/src/utils/environmentContext.test.d.ts +6 -0
  459. package/dist/src/utils/environmentContext.test.js +140 -0
  460. package/dist/src/utils/environmentContext.test.js.map +1 -0
  461. package/dist/src/utils/errorParsing.d.ts +8 -0
  462. package/dist/src/utils/errorParsing.js +93 -0
  463. package/dist/src/utils/errorParsing.js.map +1 -0
  464. package/dist/src/utils/errorParsing.test.d.ts +6 -0
  465. package/dist/src/utils/errorParsing.test.js +172 -0
  466. package/dist/src/utils/errorParsing.test.js.map +1 -0
  467. package/dist/src/utils/errorReporting.d.ts +14 -0
  468. package/dist/src/utils/errorReporting.js +88 -0
  469. package/dist/src/utils/errorReporting.js.map +1 -0
  470. package/dist/src/utils/errorReporting.test.d.ts +6 -0
  471. package/dist/src/utils/errorReporting.test.js +130 -0
  472. package/dist/src/utils/errorReporting.test.js.map +1 -0
  473. package/dist/src/utils/errors.d.ts +33 -0
  474. package/dist/src/utils/errors.js +86 -0
  475. package/dist/src/utils/errors.js.map +1 -0
  476. package/dist/src/utils/fetch.d.ts +11 -0
  477. package/dist/src/utils/fetch.js +51 -0
  478. package/dist/src/utils/fetch.js.map +1 -0
  479. package/dist/src/utils/fileUtils.d.ts +52 -0
  480. package/dist/src/utils/fileUtils.js +283 -0
  481. package/dist/src/utils/fileUtils.js.map +1 -0
  482. package/dist/src/utils/fileUtils.test.d.ts +6 -0
  483. package/dist/src/utils/fileUtils.test.js +364 -0
  484. package/dist/src/utils/fileUtils.test.js.map +1 -0
  485. package/dist/src/utils/filesearch/crawlCache.d.ts +25 -0
  486. package/dist/src/utils/filesearch/crawlCache.js +57 -0
  487. package/dist/src/utils/filesearch/crawlCache.js.map +1 -0
  488. package/dist/src/utils/filesearch/crawlCache.test.d.ts +6 -0
  489. package/dist/src/utils/filesearch/crawlCache.test.js +103 -0
  490. package/dist/src/utils/filesearch/crawlCache.test.js.map +1 -0
  491. package/dist/src/utils/filesearch/crawler.d.ts +15 -0
  492. package/dist/src/utils/filesearch/crawler.js +50 -0
  493. package/dist/src/utils/filesearch/crawler.js.map +1 -0
  494. package/dist/src/utils/filesearch/crawler.test.d.ts +6 -0
  495. package/dist/src/utils/filesearch/crawler.test.js +468 -0
  496. package/dist/src/utils/filesearch/crawler.test.js.map +1 -0
  497. package/dist/src/utils/filesearch/fileSearch.d.ts +38 -0
  498. package/dist/src/utils/filesearch/fileSearch.js +191 -0
  499. package/dist/src/utils/filesearch/fileSearch.js.map +1 -0
  500. package/dist/src/utils/filesearch/fileSearch.test.d.ts +6 -0
  501. package/dist/src/utils/filesearch/fileSearch.test.js +642 -0
  502. package/dist/src/utils/filesearch/fileSearch.test.js.map +1 -0
  503. package/dist/src/utils/filesearch/ignore.d.ts +42 -0
  504. package/dist/src/utils/filesearch/ignore.js +106 -0
  505. package/dist/src/utils/filesearch/ignore.js.map +1 -0
  506. package/dist/src/utils/filesearch/ignore.test.d.ts +6 -0
  507. package/dist/src/utils/filesearch/ignore.test.js +144 -0
  508. package/dist/src/utils/filesearch/ignore.test.js.map +1 -0
  509. package/dist/src/utils/filesearch/result-cache.d.ts +33 -0
  510. package/dist/src/utils/filesearch/result-cache.js +59 -0
  511. package/dist/src/utils/filesearch/result-cache.js.map +1 -0
  512. package/dist/src/utils/filesearch/result-cache.test.d.ts +6 -0
  513. package/dist/src/utils/filesearch/result-cache.test.js +46 -0
  514. package/dist/src/utils/filesearch/result-cache.test.js.map +1 -0
  515. package/dist/src/utils/flashFallback.integration.test.d.ts +6 -0
  516. package/dist/src/utils/flashFallback.integration.test.js +118 -0
  517. package/dist/src/utils/flashFallback.integration.test.js.map +1 -0
  518. package/dist/src/utils/formatters.d.ts +6 -0
  519. package/dist/src/utils/formatters.js +16 -0
  520. package/dist/src/utils/formatters.js.map +1 -0
  521. package/dist/src/utils/generateContentResponseUtilities.d.ts +13 -0
  522. package/dist/src/utils/generateContentResponseUtilities.js +80 -0
  523. package/dist/src/utils/generateContentResponseUtilities.js.map +1 -0
  524. package/dist/src/utils/generateContentResponseUtilities.test.d.ts +6 -0
  525. package/dist/src/utils/generateContentResponseUtilities.test.js +235 -0
  526. package/dist/src/utils/generateContentResponseUtilities.test.js.map +1 -0
  527. package/dist/src/utils/getFolderStructure.d.ts +31 -0
  528. package/dist/src/utils/getFolderStructure.js +246 -0
  529. package/dist/src/utils/getFolderStructure.js.map +1 -0
  530. package/dist/src/utils/getFolderStructure.test.d.ts +6 -0
  531. package/dist/src/utils/getFolderStructure.test.js +282 -0
  532. package/dist/src/utils/getFolderStructure.test.js.map +1 -0
  533. package/dist/src/utils/getPty.d.ts +19 -0
  534. package/dist/src/utils/getPty.js +23 -0
  535. package/dist/src/utils/getPty.js.map +1 -0
  536. package/dist/src/utils/gitIgnoreParser.d.ts +20 -0
  537. package/dist/src/utils/gitIgnoreParser.js +61 -0
  538. package/dist/src/utils/gitIgnoreParser.js.map +1 -0
  539. package/dist/src/utils/gitIgnoreParser.test.d.ts +6 -0
  540. package/dist/src/utils/gitIgnoreParser.test.js +154 -0
  541. package/dist/src/utils/gitIgnoreParser.test.js.map +1 -0
  542. package/dist/src/utils/gitUtils.d.ts +17 -0
  543. package/dist/src/utils/gitUtils.js +61 -0
  544. package/dist/src/utils/gitUtils.js.map +1 -0
  545. package/dist/src/utils/ignorePatterns.d.ts +103 -0
  546. package/dist/src/utils/ignorePatterns.js +220 -0
  547. package/dist/src/utils/ignorePatterns.js.map +1 -0
  548. package/dist/src/utils/ignorePatterns.test.d.ts +6 -0
  549. package/dist/src/utils/ignorePatterns.test.js +250 -0
  550. package/dist/src/utils/ignorePatterns.test.js.map +1 -0
  551. package/dist/src/utils/installationManager.d.ts +16 -0
  552. package/dist/src/utils/installationManager.js +50 -0
  553. package/dist/src/utils/installationManager.js.map +1 -0
  554. package/dist/src/utils/installationManager.test.d.ts +6 -0
  555. package/dist/src/utils/installationManager.test.js +83 -0
  556. package/dist/src/utils/installationManager.test.js.map +1 -0
  557. package/dist/src/utils/language-detection.d.ts +6 -0
  558. package/dist/src/utils/language-detection.js +101 -0
  559. package/dist/src/utils/language-detection.js.map +1 -0
  560. package/dist/src/utils/memoryDiscovery.d.ts +15 -0
  561. package/dist/src/utils/memoryDiscovery.js +253 -0
  562. package/dist/src/utils/memoryDiscovery.js.map +1 -0
  563. package/dist/src/utils/memoryDiscovery.test.d.ts +6 -0
  564. package/dist/src/utils/memoryDiscovery.test.js +219 -0
  565. package/dist/src/utils/memoryDiscovery.test.js.map +1 -0
  566. package/dist/src/utils/memoryImportProcessor.d.ts +42 -0
  567. package/dist/src/utils/memoryImportProcessor.js +296 -0
  568. package/dist/src/utils/memoryImportProcessor.js.map +1 -0
  569. package/dist/src/utils/memoryImportProcessor.test.d.ts +6 -0
  570. package/dist/src/utils/memoryImportProcessor.test.js +573 -0
  571. package/dist/src/utils/memoryImportProcessor.test.js.map +1 -0
  572. package/dist/src/utils/messageInspectors.d.ts +8 -0
  573. package/dist/src/utils/messageInspectors.js +16 -0
  574. package/dist/src/utils/messageInspectors.js.map +1 -0
  575. package/dist/src/utils/nextSpeakerChecker.d.ts +12 -0
  576. package/dist/src/utils/nextSpeakerChecker.js +91 -0
  577. package/dist/src/utils/nextSpeakerChecker.js.map +1 -0
  578. package/dist/src/utils/nextSpeakerChecker.test.d.ts +6 -0
  579. package/dist/src/utils/nextSpeakerChecker.test.js +168 -0
  580. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -0
  581. package/dist/src/utils/partUtils.d.ts +35 -0
  582. package/dist/src/utils/partUtils.js +133 -0
  583. package/dist/src/utils/partUtils.js.map +1 -0
  584. package/dist/src/utils/partUtils.test.d.ts +6 -0
  585. package/dist/src/utils/partUtils.test.js +241 -0
  586. package/dist/src/utils/partUtils.test.js.map +1 -0
  587. package/dist/src/utils/pathReader.d.ts +17 -0
  588. package/dist/src/utils/pathReader.js +92 -0
  589. package/dist/src/utils/pathReader.js.map +1 -0
  590. package/dist/src/utils/pathReader.test.d.ts +6 -0
  591. package/dist/src/utils/pathReader.test.js +363 -0
  592. package/dist/src/utils/pathReader.test.js.map +1 -0
  593. package/dist/src/utils/paths.d.ts +58 -0
  594. package/dist/src/utils/paths.js +159 -0
  595. package/dist/src/utils/paths.js.map +1 -0
  596. package/dist/src/utils/paths.test.d.ts +6 -0
  597. package/dist/src/utils/paths.test.js +225 -0
  598. package/dist/src/utils/paths.test.js.map +1 -0
  599. package/dist/src/utils/quotaErrorDetection.d.ts +18 -0
  600. package/dist/src/utils/quotaErrorDetection.js +65 -0
  601. package/dist/src/utils/quotaErrorDetection.js.map +1 -0
  602. package/dist/src/utils/retry.d.ts +30 -0
  603. package/dist/src/utils/retry.js +276 -0
  604. package/dist/src/utils/retry.js.map +1 -0
  605. package/dist/src/utils/retry.test.d.ts +6 -0
  606. package/dist/src/utils/retry.test.js +325 -0
  607. package/dist/src/utils/retry.test.js.map +1 -0
  608. package/dist/src/utils/safeJsonStringify.d.ts +13 -0
  609. package/dist/src/utils/safeJsonStringify.js +25 -0
  610. package/dist/src/utils/safeJsonStringify.js.map +1 -0
  611. package/dist/src/utils/safeJsonStringify.test.d.ts +6 -0
  612. package/dist/src/utils/safeJsonStringify.test.js +61 -0
  613. package/dist/src/utils/safeJsonStringify.test.js.map +1 -0
  614. package/dist/src/utils/schemaValidator.d.ts +15 -0
  615. package/dist/src/utils/schemaValidator.js +38 -0
  616. package/dist/src/utils/schemaValidator.js.map +1 -0
  617. package/dist/src/utils/secure-browser-launcher.d.ts +23 -0
  618. package/dist/src/utils/secure-browser-launcher.js +165 -0
  619. package/dist/src/utils/secure-browser-launcher.js.map +1 -0
  620. package/dist/src/utils/secure-browser-launcher.test.d.ts +6 -0
  621. package/dist/src/utils/secure-browser-launcher.test.js +149 -0
  622. package/dist/src/utils/secure-browser-launcher.test.js.map +1 -0
  623. package/dist/src/utils/session.d.ts +6 -0
  624. package/dist/src/utils/session.js +8 -0
  625. package/dist/src/utils/session.js.map +1 -0
  626. package/dist/src/utils/shell-utils.d.ts +117 -0
  627. package/dist/src/utils/shell-utils.js +370 -0
  628. package/dist/src/utils/shell-utils.js.map +1 -0
  629. package/dist/src/utils/shell-utils.test.d.ts +6 -0
  630. package/dist/src/utils/shell-utils.test.js +332 -0
  631. package/dist/src/utils/shell-utils.test.js.map +1 -0
  632. package/dist/src/utils/summarizer.d.ts +25 -0
  633. package/dist/src/utils/summarizer.js +51 -0
  634. package/dist/src/utils/summarizer.js.map +1 -0
  635. package/dist/src/utils/summarizer.test.d.ts +6 -0
  636. package/dist/src/utils/summarizer.test.js +131 -0
  637. package/dist/src/utils/summarizer.test.js.map +1 -0
  638. package/dist/src/utils/systemEncoding.d.ts +40 -0
  639. package/dist/src/utils/systemEncoding.js +149 -0
  640. package/dist/src/utils/systemEncoding.js.map +1 -0
  641. package/dist/src/utils/systemEncoding.test.d.ts +6 -0
  642. package/dist/src/utils/systemEncoding.test.js +368 -0
  643. package/dist/src/utils/systemEncoding.test.js.map +1 -0
  644. package/dist/src/utils/testUtils.d.ts +29 -0
  645. package/dist/src/utils/testUtils.js +70 -0
  646. package/dist/src/utils/testUtils.js.map +1 -0
  647. package/dist/src/utils/textUtils.d.ts +13 -0
  648. package/dist/src/utils/textUtils.js +28 -0
  649. package/dist/src/utils/textUtils.js.map +1 -0
  650. package/dist/src/utils/tool-utils.d.ts +19 -0
  651. package/dist/src/utils/tool-utils.js +58 -0
  652. package/dist/src/utils/tool-utils.js.map +1 -0
  653. package/dist/src/utils/tool-utils.test.d.ts +6 -0
  654. package/dist/src/utils/tool-utils.test.js +61 -0
  655. package/dist/src/utils/tool-utils.test.js.map +1 -0
  656. package/dist/src/utils/userAccountManager.d.ts +20 -0
  657. package/dist/src/utils/userAccountManager.js +114 -0
  658. package/dist/src/utils/userAccountManager.js.map +1 -0
  659. package/dist/src/utils/userAccountManager.test.d.ts +6 -0
  660. package/dist/src/utils/userAccountManager.test.js +223 -0
  661. package/dist/src/utils/userAccountManager.test.js.map +1 -0
  662. package/dist/src/utils/workspaceContext.d.ts +66 -0
  663. package/dist/src/utils/workspaceContext.js +171 -0
  664. package/dist/src/utils/workspaceContext.js.map +1 -0
  665. package/dist/src/utils/workspaceContext.test.d.ts +6 -0
  666. package/dist/src/utils/workspaceContext.test.js +318 -0
  667. package/dist/src/utils/workspaceContext.test.js.map +1 -0
  668. package/dist/tsconfig.tsbuildinfo +1 -0
  669. package/package.json +85 -0
@@ -0,0 +1,773 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2025 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { HttpsProxyAgent } from 'https-proxy-agent';
7
+ import { EventMetadataKey } from './event-metadata-key.js';
8
+ import { InstallationManager } from '../../utils/installationManager.js';
9
+ import { UserAccountManager } from '../../utils/userAccountManager.js';
10
+ import { safeJsonStringify } from '../../utils/safeJsonStringify.js';
11
+ import { FixedDeque } from 'mnemonist';
12
+ import { GIT_COMMIT_INFO, CLI_VERSION } from '../../generated/git-commit.js';
13
+ import { DetectedIde, detectIdeFromEnv } from '../../ide/detect-ide.js';
14
+ export var EventNames;
15
+ (function (EventNames) {
16
+ EventNames["START_SESSION"] = "start_session";
17
+ EventNames["NEW_PROMPT"] = "new_prompt";
18
+ EventNames["TOOL_CALL"] = "tool_call";
19
+ EventNames["FILE_OPERATION"] = "file_operation";
20
+ EventNames["API_REQUEST"] = "api_request";
21
+ EventNames["API_RESPONSE"] = "api_response";
22
+ EventNames["API_ERROR"] = "api_error";
23
+ EventNames["END_SESSION"] = "end_session";
24
+ EventNames["FLASH_FALLBACK"] = "flash_fallback";
25
+ EventNames["LOOP_DETECTED"] = "loop_detected";
26
+ EventNames["NEXT_SPEAKER_CHECK"] = "next_speaker_check";
27
+ EventNames["SLASH_COMMAND"] = "slash_command";
28
+ EventNames["MALFORMED_JSON_RESPONSE"] = "malformed_json_response";
29
+ EventNames["IDE_CONNECTION"] = "ide_connection";
30
+ EventNames["KITTY_SEQUENCE_OVERFLOW"] = "kitty_sequence_overflow";
31
+ EventNames["CHAT_COMPRESSION"] = "chat_compression";
32
+ EventNames["CONVERSATION_FINISHED"] = "conversation_finished";
33
+ EventNames["INVALID_CHUNK"] = "invalid_chunk";
34
+ EventNames["CONTENT_RETRY"] = "content_retry";
35
+ EventNames["CONTENT_RETRY_FAILURE"] = "content_retry_failure";
36
+ })(EventNames || (EventNames = {}));
37
+ /**
38
+ * Determine the surface that the user is currently using. Surface is effectively the
39
+ * distribution channel in which the user is using Gemini CLI. Gemini CLI comes bundled
40
+ * w/ Firebase Studio and Cloud Shell. Users that manually download themselves will
41
+ * likely be "SURFACE_NOT_SET".
42
+ *
43
+ * This is computed based upon a series of environment variables these distribution
44
+ * methods might have in their runtimes.
45
+ */
46
+ function determineSurface() {
47
+ if (process.env['SURFACE']) {
48
+ return process.env['SURFACE'];
49
+ }
50
+ else if (process.env['GITHUB_SHA']) {
51
+ return 'GitHub';
52
+ }
53
+ else if (process.env['TERM_PROGRAM'] === 'vscode') {
54
+ return detectIdeFromEnv() || DetectedIde.VSCode;
55
+ }
56
+ else {
57
+ return 'SURFACE_NOT_SET';
58
+ }
59
+ }
60
+ /**
61
+ * Clearcut URL to send logging events to.
62
+ */
63
+ const CLEARCUT_URL = 'https://play.googleapis.com/log?format=json&hasfast=true';
64
+ /**
65
+ * Interval in which buffered events are sent to clearcut.
66
+ */
67
+ const FLUSH_INTERVAL_MS = 1000 * 60;
68
+ /**
69
+ * Maximum amount of events to keep in memory. Events added after this amount
70
+ * are dropped until the next flush to clearcut, which happens periodically as
71
+ * defined by {@link FLUSH_INTERVAL_MS}.
72
+ */
73
+ const MAX_EVENTS = 1000;
74
+ /**
75
+ * Maximum events to retry after a failed clearcut flush
76
+ */
77
+ const MAX_RETRY_EVENTS = 100;
78
+ // Singleton class for batch posting log events to Clearcut. When a new event comes in, the elapsed time
79
+ // is checked and events are flushed to Clearcut if at least a minute has passed since the last flush.
80
+ export class ClearcutLogger {
81
+ static instance;
82
+ config;
83
+ sessionData = [];
84
+ promptId = '';
85
+ installationManager;
86
+ userAccountManager;
87
+ /**
88
+ * Queue of pending events that need to be flushed to the server. New events
89
+ * are added to this queue and then flushed on demand (via `flushToClearcut`)
90
+ */
91
+ events;
92
+ /**
93
+ * The last time that the events were successfully flushed to the server.
94
+ */
95
+ lastFlushTime = Date.now();
96
+ /**
97
+ * the value is true when there is a pending flush happening. This prevents
98
+ * concurrent flush operations.
99
+ */
100
+ flushing = false;
101
+ /**
102
+ * This value is true when a flush was requested during an ongoing flush.
103
+ */
104
+ pendingFlush = false;
105
+ constructor(config) {
106
+ this.config = config;
107
+ this.events = new FixedDeque(Array, MAX_EVENTS);
108
+ this.promptId = config?.getSessionId() ?? '';
109
+ this.installationManager = new InstallationManager();
110
+ this.userAccountManager = new UserAccountManager();
111
+ }
112
+ static getInstance(config) {
113
+ if (config === undefined || !config?.getUsageStatisticsEnabled())
114
+ return undefined;
115
+ if (!ClearcutLogger.instance) {
116
+ ClearcutLogger.instance = new ClearcutLogger(config);
117
+ }
118
+ return ClearcutLogger.instance;
119
+ }
120
+ /** For testing purposes only. */
121
+ static clearInstance() {
122
+ // @ts-expect-error - ClearcutLogger is a singleton, but we need to clear it for tests.
123
+ ClearcutLogger.instance = undefined;
124
+ }
125
+ enqueueLogEvent(event) {
126
+ try {
127
+ // Manually handle overflow for FixedDeque, which throws when full.
128
+ const wasAtCapacity = this.events.size >= MAX_EVENTS;
129
+ if (wasAtCapacity) {
130
+ this.events.shift(); // Evict oldest element to make space.
131
+ }
132
+ this.events.push([
133
+ {
134
+ event_time_ms: Date.now(),
135
+ source_extension_json: safeJsonStringify(event),
136
+ },
137
+ ]);
138
+ if (wasAtCapacity && this.config?.getDebugMode()) {
139
+ console.debug(`ClearcutLogger: Dropped old event to prevent memory leak (queue size: ${this.events.size})`);
140
+ }
141
+ }
142
+ catch (error) {
143
+ if (this.config?.getDebugMode()) {
144
+ console.error('ClearcutLogger: Failed to enqueue log event.', error);
145
+ }
146
+ }
147
+ }
148
+ createLogEvent(eventName, data = []) {
149
+ const email = this.userAccountManager.getCachedGoogleAccount();
150
+ if (eventName !== EventNames.START_SESSION) {
151
+ data.push(...this.sessionData);
152
+ }
153
+ const totalAccounts = this.userAccountManager.getLifetimeGoogleAccounts();
154
+ data = this.addDefaultFields(data, totalAccounts);
155
+ const logEvent = {
156
+ console_type: 'GEMINI_CLI',
157
+ application: 102, // GEMINI_CLI
158
+ event_name: eventName,
159
+ event_metadata: [data],
160
+ };
161
+ // Should log either email or install ID, not both. See go/cloudmill-1p-oss-instrumentation#define-sessionable-id
162
+ if (email) {
163
+ logEvent.client_email = email;
164
+ }
165
+ else {
166
+ logEvent.client_install_id = this.installationManager.getInstallationId();
167
+ }
168
+ return logEvent;
169
+ }
170
+ flushIfNeeded() {
171
+ if (Date.now() - this.lastFlushTime < FLUSH_INTERVAL_MS) {
172
+ return;
173
+ }
174
+ this.flushToClearcut().catch((error) => {
175
+ console.debug('Error flushing to Clearcut:', error);
176
+ });
177
+ }
178
+ async flushToClearcut() {
179
+ if (this.flushing) {
180
+ if (this.config?.getDebugMode()) {
181
+ console.debug('ClearcutLogger: Flush already in progress, marking pending flush.');
182
+ }
183
+ this.pendingFlush = true;
184
+ return Promise.resolve({});
185
+ }
186
+ this.flushing = true;
187
+ if (this.config?.getDebugMode()) {
188
+ console.log('Flushing log events to Clearcut.');
189
+ }
190
+ const eventsToSend = this.events.toArray();
191
+ this.events.clear();
192
+ const request = [
193
+ {
194
+ log_source_name: 'CONCORD',
195
+ request_time_ms: Date.now(),
196
+ log_event: eventsToSend,
197
+ },
198
+ ];
199
+ let result = {};
200
+ try {
201
+ const response = await fetch(CLEARCUT_URL, {
202
+ method: 'POST',
203
+ body: safeJsonStringify(request),
204
+ headers: {
205
+ 'Content-Type': 'application/json',
206
+ },
207
+ });
208
+ const responseBody = await response.text();
209
+ if (response.status >= 200 && response.status < 300) {
210
+ this.lastFlushTime = Date.now();
211
+ const nextRequestWaitMs = Number(JSON.parse(responseBody)[0]);
212
+ result = {
213
+ ...result,
214
+ nextRequestWaitMs,
215
+ };
216
+ }
217
+ else {
218
+ if (this.config?.getDebugMode()) {
219
+ console.error(`Error flushing log events: HTTP ${response.status}: ${response.statusText}`);
220
+ }
221
+ // Re-queue failed events for retry
222
+ this.requeueFailedEvents(eventsToSend);
223
+ }
224
+ }
225
+ catch (e) {
226
+ if (this.config?.getDebugMode()) {
227
+ console.error('Error flushing log events:', e);
228
+ }
229
+ // Re-queue failed events for retry
230
+ this.requeueFailedEvents(eventsToSend);
231
+ }
232
+ this.flushing = false;
233
+ // If a flush was requested while we were flushing, flush again
234
+ if (this.pendingFlush) {
235
+ this.pendingFlush = false;
236
+ // Fire and forget the pending flush
237
+ this.flushToClearcut().catch((error) => {
238
+ if (this.config?.getDebugMode()) {
239
+ console.debug('Error in pending flush to Clearcut:', error);
240
+ }
241
+ });
242
+ }
243
+ return result;
244
+ }
245
+ logStartSessionEvent(event) {
246
+ const data = [
247
+ {
248
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_MODEL,
249
+ value: event.model,
250
+ },
251
+ {
252
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_EMBEDDING_MODEL,
253
+ value: event.embedding_model,
254
+ },
255
+ {
256
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_SANDBOX,
257
+ value: event.sandbox_enabled.toString(),
258
+ },
259
+ {
260
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_CORE_TOOLS,
261
+ value: event.core_tools_enabled,
262
+ },
263
+ {
264
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_APPROVAL_MODE,
265
+ value: event.approval_mode,
266
+ },
267
+ {
268
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_API_KEY_ENABLED,
269
+ value: event.api_key_enabled.toString(),
270
+ },
271
+ {
272
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_VERTEX_API_ENABLED,
273
+ value: event.vertex_ai_enabled.toString(),
274
+ },
275
+ {
276
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_DEBUG_MODE_ENABLED,
277
+ value: event.debug_enabled.toString(),
278
+ },
279
+ {
280
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_VERTEX_API_ENABLED,
281
+ value: event.vertex_ai_enabled.toString(),
282
+ },
283
+ {
284
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_MCP_SERVERS,
285
+ value: event.mcp_servers,
286
+ },
287
+ {
288
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_VERTEX_API_ENABLED,
289
+ value: event.vertex_ai_enabled.toString(),
290
+ },
291
+ {
292
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_TELEMETRY_ENABLED,
293
+ value: event.telemetry_enabled.toString(),
294
+ },
295
+ {
296
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_TELEMETRY_LOG_USER_PROMPTS_ENABLED,
297
+ value: event.telemetry_log_user_prompts_enabled.toString(),
298
+ },
299
+ {
300
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_MCP_SERVERS_COUNT,
301
+ value: event.mcp_servers_count
302
+ ? event.mcp_servers_count.toString()
303
+ : '',
304
+ },
305
+ {
306
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_MCP_TOOLS_COUNT,
307
+ value: event.mcp_tools_count?.toString() ?? '',
308
+ },
309
+ {
310
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_START_SESSION_MCP_TOOLS,
311
+ value: event.mcp_tools ? event.mcp_tools : '',
312
+ },
313
+ ];
314
+ this.sessionData = data;
315
+ // Flush start event immediately
316
+ this.enqueueLogEvent(this.createLogEvent(EventNames.START_SESSION, data));
317
+ this.flushToClearcut().catch((error) => {
318
+ console.debug('Error flushing to Clearcut:', error);
319
+ });
320
+ }
321
+ logNewPromptEvent(event) {
322
+ this.promptId = event.prompt_id;
323
+ const data = [
324
+ {
325
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_USER_PROMPT_LENGTH,
326
+ value: JSON.stringify(event.prompt_length),
327
+ },
328
+ ];
329
+ this.enqueueLogEvent(this.createLogEvent(EventNames.NEW_PROMPT, data));
330
+ this.flushIfNeeded();
331
+ }
332
+ logToolCallEvent(event) {
333
+ const data = [
334
+ {
335
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_NAME,
336
+ value: JSON.stringify(event.function_name),
337
+ },
338
+ {
339
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_DECISION,
340
+ value: JSON.stringify(event.decision),
341
+ },
342
+ {
343
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_SUCCESS,
344
+ value: JSON.stringify(event.success),
345
+ },
346
+ {
347
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_DURATION_MS,
348
+ value: JSON.stringify(event.duration_ms),
349
+ },
350
+ {
351
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_ERROR_MESSAGE,
352
+ value: JSON.stringify(event.error),
353
+ },
354
+ {
355
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_ERROR_TYPE,
356
+ value: JSON.stringify(event.error_type),
357
+ },
358
+ {
359
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_TYPE,
360
+ value: JSON.stringify(event.tool_type),
361
+ },
362
+ ];
363
+ if (event.metadata) {
364
+ const metadataMapping = {
365
+ ai_added_lines: EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
366
+ ai_removed_lines: EventMetadataKey.GEMINI_CLI_AI_REMOVED_LINES,
367
+ user_added_lines: EventMetadataKey.GEMINI_CLI_USER_ADDED_LINES,
368
+ user_removed_lines: EventMetadataKey.GEMINI_CLI_USER_REMOVED_LINES,
369
+ };
370
+ for (const [key, gemini_cli_key] of Object.entries(metadataMapping)) {
371
+ if (event.metadata[key] !== undefined) {
372
+ data.push({
373
+ gemini_cli_key,
374
+ value: JSON.stringify(event.metadata[key]),
375
+ });
376
+ }
377
+ }
378
+ }
379
+ const logEvent = this.createLogEvent(EventNames.TOOL_CALL, data);
380
+ this.enqueueLogEvent(logEvent);
381
+ this.flushIfNeeded();
382
+ }
383
+ logFileOperationEvent(event) {
384
+ const data = [
385
+ {
386
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_TOOL_CALL_NAME,
387
+ value: JSON.stringify(event.tool_name),
388
+ },
389
+ {
390
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_FILE_OPERATION_TYPE,
391
+ value: JSON.stringify(event.operation),
392
+ },
393
+ {
394
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_FILE_OPERATION_LINES,
395
+ value: JSON.stringify(event.lines),
396
+ },
397
+ {
398
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_FILE_OPERATION_MIMETYPE,
399
+ value: JSON.stringify(event.mimetype),
400
+ },
401
+ {
402
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_FILE_OPERATION_EXTENSION,
403
+ value: JSON.stringify(event.extension),
404
+ },
405
+ ];
406
+ if (event.programming_language) {
407
+ data.push({
408
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_PROGRAMMING_LANGUAGE,
409
+ value: event.programming_language,
410
+ });
411
+ }
412
+ if (event.diff_stat) {
413
+ const metadataMapping = {
414
+ ai_added_lines: EventMetadataKey.GEMINI_CLI_AI_ADDED_LINES,
415
+ ai_removed_lines: EventMetadataKey.GEMINI_CLI_AI_REMOVED_LINES,
416
+ user_added_lines: EventMetadataKey.GEMINI_CLI_USER_ADDED_LINES,
417
+ user_removed_lines: EventMetadataKey.GEMINI_CLI_USER_REMOVED_LINES,
418
+ };
419
+ for (const [key, gemini_cli_key] of Object.entries(metadataMapping)) {
420
+ if (event.diff_stat[key] !== undefined) {
421
+ data.push({
422
+ gemini_cli_key,
423
+ value: JSON.stringify(event.diff_stat[key]),
424
+ });
425
+ }
426
+ }
427
+ }
428
+ const logEvent = this.createLogEvent(EventNames.FILE_OPERATION, data);
429
+ this.enqueueLogEvent(logEvent);
430
+ this.flushIfNeeded();
431
+ }
432
+ logApiRequestEvent(event) {
433
+ const data = [
434
+ {
435
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_REQUEST_MODEL,
436
+ value: JSON.stringify(event.model),
437
+ },
438
+ ];
439
+ this.enqueueLogEvent(this.createLogEvent(EventNames.API_REQUEST, data));
440
+ this.flushIfNeeded();
441
+ }
442
+ logApiResponseEvent(event) {
443
+ const data = [
444
+ {
445
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_MODEL,
446
+ value: JSON.stringify(event.model),
447
+ },
448
+ {
449
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_STATUS_CODE,
450
+ value: JSON.stringify(event.status_code),
451
+ },
452
+ {
453
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_DURATION_MS,
454
+ value: JSON.stringify(event.duration_ms),
455
+ },
456
+ {
457
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_ERROR_MESSAGE,
458
+ value: JSON.stringify(event.error),
459
+ },
460
+ {
461
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_INPUT_TOKEN_COUNT,
462
+ value: JSON.stringify(event.input_token_count),
463
+ },
464
+ {
465
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_OUTPUT_TOKEN_COUNT,
466
+ value: JSON.stringify(event.output_token_count),
467
+ },
468
+ {
469
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_CACHED_TOKEN_COUNT,
470
+ value: JSON.stringify(event.cached_content_token_count),
471
+ },
472
+ {
473
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_THINKING_TOKEN_COUNT,
474
+ value: JSON.stringify(event.thoughts_token_count),
475
+ },
476
+ {
477
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_RESPONSE_TOOL_TOKEN_COUNT,
478
+ value: JSON.stringify(event.tool_token_count),
479
+ },
480
+ ];
481
+ this.enqueueLogEvent(this.createLogEvent(EventNames.API_RESPONSE, data));
482
+ this.flushIfNeeded();
483
+ }
484
+ logApiErrorEvent(event) {
485
+ const data = [
486
+ {
487
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_ERROR_MODEL,
488
+ value: JSON.stringify(event.model),
489
+ },
490
+ {
491
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_ERROR_TYPE,
492
+ value: JSON.stringify(event.error_type),
493
+ },
494
+ {
495
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_ERROR_STATUS_CODE,
496
+ value: JSON.stringify(event.status_code),
497
+ },
498
+ {
499
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_API_ERROR_DURATION_MS,
500
+ value: JSON.stringify(event.duration_ms),
501
+ },
502
+ ];
503
+ this.enqueueLogEvent(this.createLogEvent(EventNames.API_ERROR, data));
504
+ this.flushIfNeeded();
505
+ }
506
+ logChatCompressionEvent(event) {
507
+ const data = [
508
+ {
509
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_COMPRESSION_TOKENS_BEFORE,
510
+ value: `${event.tokens_before}`,
511
+ },
512
+ {
513
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_COMPRESSION_TOKENS_AFTER,
514
+ value: `${event.tokens_after}`,
515
+ },
516
+ ];
517
+ this.enqueueLogEvent(this.createLogEvent(EventNames.CHAT_COMPRESSION, data));
518
+ }
519
+ logFlashFallbackEvent() {
520
+ this.enqueueLogEvent(this.createLogEvent(EventNames.FLASH_FALLBACK, []));
521
+ this.flushToClearcut().catch((error) => {
522
+ console.debug('Error flushing to Clearcut:', error);
523
+ });
524
+ }
525
+ logLoopDetectedEvent(event) {
526
+ const data = [
527
+ {
528
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_LOOP_DETECTED_TYPE,
529
+ value: JSON.stringify(event.loop_type),
530
+ },
531
+ ];
532
+ this.enqueueLogEvent(this.createLogEvent(EventNames.LOOP_DETECTED, data));
533
+ this.flushIfNeeded();
534
+ }
535
+ logNextSpeakerCheck(event) {
536
+ const data = [
537
+ {
538
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_RESPONSE_FINISH_REASON,
539
+ value: JSON.stringify(event.finish_reason),
540
+ },
541
+ {
542
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_NEXT_SPEAKER_CHECK_RESULT,
543
+ value: JSON.stringify(event.result),
544
+ },
545
+ ];
546
+ this.enqueueLogEvent(this.createLogEvent(EventNames.NEXT_SPEAKER_CHECK, data));
547
+ this.flushIfNeeded();
548
+ }
549
+ logSlashCommandEvent(event) {
550
+ const data = [
551
+ {
552
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SLASH_COMMAND_NAME,
553
+ value: JSON.stringify(event.command),
554
+ },
555
+ ];
556
+ if (event.subcommand) {
557
+ data.push({
558
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SLASH_COMMAND_SUBCOMMAND,
559
+ value: JSON.stringify(event.subcommand),
560
+ });
561
+ }
562
+ if (event.status) {
563
+ data.push({
564
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SLASH_COMMAND_STATUS,
565
+ value: JSON.stringify(event.status),
566
+ });
567
+ }
568
+ this.enqueueLogEvent(this.createLogEvent(EventNames.SLASH_COMMAND, data));
569
+ this.flushIfNeeded();
570
+ }
571
+ logMalformedJsonResponseEvent(event) {
572
+ const data = [
573
+ {
574
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_MALFORMED_JSON_RESPONSE_MODEL,
575
+ value: JSON.stringify(event.model),
576
+ },
577
+ ];
578
+ this.enqueueLogEvent(this.createLogEvent(EventNames.MALFORMED_JSON_RESPONSE, data));
579
+ this.flushIfNeeded();
580
+ }
581
+ logIdeConnectionEvent(event) {
582
+ const data = [
583
+ {
584
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_IDE_CONNECTION_TYPE,
585
+ value: JSON.stringify(event.connection_type),
586
+ },
587
+ ];
588
+ this.enqueueLogEvent(this.createLogEvent(EventNames.IDE_CONNECTION, data));
589
+ this.flushIfNeeded();
590
+ }
591
+ logConversationFinishedEvent(event) {
592
+ const data = [
593
+ {
594
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SESSION_ID,
595
+ value: this.config?.getSessionId() ?? '',
596
+ },
597
+ {
598
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONVERSATION_TURN_COUNT,
599
+ value: JSON.stringify(event.turnCount),
600
+ },
601
+ {
602
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_APPROVAL_MODE,
603
+ value: event.approvalMode,
604
+ },
605
+ ];
606
+ this.enqueueLogEvent(this.createLogEvent(EventNames.CONVERSATION_FINISHED, data));
607
+ this.flushIfNeeded();
608
+ }
609
+ logKittySequenceOverflowEvent(event) {
610
+ const data = [
611
+ {
612
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_KITTY_SEQUENCE_LENGTH,
613
+ value: event.sequence_length.toString(),
614
+ },
615
+ {
616
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_KITTY_TRUNCATED_SEQUENCE,
617
+ value: event.truncated_sequence,
618
+ },
619
+ ];
620
+ this.enqueueLogEvent(this.createLogEvent(EventNames.KITTY_SEQUENCE_OVERFLOW, data));
621
+ this.flushIfNeeded();
622
+ }
623
+ logEndSessionEvent() {
624
+ // Flush immediately on session end.
625
+ this.enqueueLogEvent(this.createLogEvent(EventNames.END_SESSION, []));
626
+ this.flushToClearcut().catch((error) => {
627
+ console.debug('Error flushing to Clearcut:', error);
628
+ });
629
+ }
630
+ logInvalidChunkEvent(event) {
631
+ const data = [];
632
+ if (event.error_message) {
633
+ data.push({
634
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_INVALID_CHUNK_ERROR_MESSAGE,
635
+ value: event.error_message,
636
+ });
637
+ }
638
+ this.enqueueLogEvent(this.createLogEvent(EventNames.INVALID_CHUNK, data));
639
+ this.flushIfNeeded();
640
+ }
641
+ logContentRetryEvent(event) {
642
+ const data = [
643
+ {
644
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_ATTEMPT_NUMBER,
645
+ value: String(event.attempt_number),
646
+ },
647
+ {
648
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_ERROR_TYPE,
649
+ value: event.error_type,
650
+ },
651
+ {
652
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_DELAY_MS,
653
+ value: String(event.retry_delay_ms),
654
+ },
655
+ ];
656
+ this.enqueueLogEvent(this.createLogEvent(EventNames.CONTENT_RETRY, data));
657
+ this.flushIfNeeded();
658
+ }
659
+ logContentRetryFailureEvent(event) {
660
+ const data = [
661
+ {
662
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_FAILURE_TOTAL_ATTEMPTS,
663
+ value: String(event.total_attempts),
664
+ },
665
+ {
666
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_FAILURE_FINAL_ERROR_TYPE,
667
+ value: event.final_error_type,
668
+ },
669
+ ];
670
+ if (event.total_duration_ms) {
671
+ data.push({
672
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_CONTENT_RETRY_FAILURE_TOTAL_DURATION_MS,
673
+ value: String(event.total_duration_ms),
674
+ });
675
+ }
676
+ this.enqueueLogEvent(this.createLogEvent(EventNames.CONTENT_RETRY_FAILURE, data));
677
+ this.flushIfNeeded();
678
+ }
679
+ /**
680
+ * Adds default fields to data, and returns a new data array. This fields
681
+ * should exist on all log events.
682
+ */
683
+ addDefaultFields(data, totalAccounts) {
684
+ const surface = determineSurface();
685
+ const defaultLogMetadata = [
686
+ {
687
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SESSION_ID,
688
+ value: this.config?.getSessionId() ?? '',
689
+ },
690
+ {
691
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_AUTH_TYPE,
692
+ value: JSON.stringify(this.config?.getContentGeneratorConfig()?.authType),
693
+ },
694
+ {
695
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_GOOGLE_ACCOUNTS_COUNT,
696
+ value: `${totalAccounts}`,
697
+ },
698
+ {
699
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_SURFACE,
700
+ value: surface,
701
+ },
702
+ {
703
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_VERSION,
704
+ value: CLI_VERSION,
705
+ },
706
+ {
707
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_GIT_COMMIT_HASH,
708
+ value: GIT_COMMIT_INFO,
709
+ },
710
+ {
711
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_PROMPT_ID,
712
+ value: this.promptId,
713
+ },
714
+ {
715
+ gemini_cli_key: EventMetadataKey.GEMINI_CLI_OS,
716
+ value: process.platform,
717
+ },
718
+ ];
719
+ return [...data, ...defaultLogMetadata];
720
+ }
721
+ getProxyAgent() {
722
+ const proxyUrl = this.config?.getProxy();
723
+ if (!proxyUrl)
724
+ return undefined;
725
+ // undici which is widely used in the repo can only support http & https proxy protocol,
726
+ // https://github.com/nodejs/undici/issues/2224
727
+ if (proxyUrl.startsWith('http')) {
728
+ return new HttpsProxyAgent(proxyUrl);
729
+ }
730
+ else {
731
+ throw new Error('Unsupported proxy type');
732
+ }
733
+ }
734
+ shutdown() {
735
+ this.logEndSessionEvent();
736
+ }
737
+ requeueFailedEvents(eventsToSend) {
738
+ // Add the events back to the front of the queue to be retried, but limit retry queue size
739
+ const eventsToRetry = eventsToSend.slice(-MAX_RETRY_EVENTS); // Keep only the most recent events
740
+ // Log a warning if we're dropping events
741
+ if (eventsToSend.length > MAX_RETRY_EVENTS && this.config?.getDebugMode()) {
742
+ console.warn(`ClearcutLogger: Dropping ${eventsToSend.length - MAX_RETRY_EVENTS} events due to retry queue limit. Total events: ${eventsToSend.length}, keeping: ${MAX_RETRY_EVENTS}`);
743
+ }
744
+ // Determine how many events can be re-queued
745
+ const availableSpace = MAX_EVENTS - this.events.size;
746
+ const numEventsToRequeue = Math.min(eventsToRetry.length, availableSpace);
747
+ if (numEventsToRequeue === 0) {
748
+ if (this.config?.getDebugMode()) {
749
+ console.debug(`ClearcutLogger: No events re-queued (queue size: ${this.events.size})`);
750
+ }
751
+ return;
752
+ }
753
+ // Get the most recent events to re-queue
754
+ const eventsToRequeue = eventsToRetry.slice(eventsToRetry.length - numEventsToRequeue);
755
+ // Prepend events to the front of the deque to be retried first.
756
+ // We iterate backwards to maintain the original order of the failed events.
757
+ for (let i = eventsToRequeue.length - 1; i >= 0; i--) {
758
+ this.events.unshift(eventsToRequeue[i]);
759
+ }
760
+ // Clear any potential overflow
761
+ while (this.events.size > MAX_EVENTS) {
762
+ this.events.pop();
763
+ }
764
+ if (this.config?.getDebugMode()) {
765
+ console.debug(`ClearcutLogger: Re-queued ${numEventsToRequeue} events for retry (queue size: ${this.events.size})`);
766
+ }
767
+ }
768
+ }
769
+ export const TEST_ONLY = {
770
+ MAX_RETRY_EVENTS,
771
+ MAX_EVENTS,
772
+ };
773
+ //# sourceMappingURL=clearcut-logger.js.map