@google/gemini-cli-core 0.31.0-preview.2 → 0.32.0-preview.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (312) hide show
  1. package/dist/docs/changelogs/index.md +22 -0
  2. package/dist/docs/changelogs/latest.md +307 -352
  3. package/dist/docs/changelogs/preview.md +391 -293
  4. package/dist/docs/cli/plan-mode.md +29 -7
  5. package/dist/docs/cli/settings.md +15 -6
  6. package/dist/docs/cli/telemetry.md +39 -11
  7. package/dist/docs/extensions/reference.md +36 -0
  8. package/dist/docs/get-started/installation.md +1 -1
  9. package/dist/docs/local-development.md +49 -43
  10. package/dist/docs/reference/configuration.md +32 -0
  11. package/dist/docs/reference/keyboard-shortcuts.md +6 -6
  12. package/dist/docs/reference/policy-engine.md +4 -3
  13. package/dist/docs/resources/faq.md +13 -0
  14. package/dist/docs/resources/tos-privacy.md +6 -0
  15. package/dist/docs/resources/uninstall.md +1 -10
  16. package/dist/docs/tools/mcp-server.md +22 -0
  17. package/dist/src/agents/a2a-client-manager.d.ts +7 -6
  18. package/dist/src/agents/a2a-client-manager.js +8 -9
  19. package/dist/src/agents/a2a-client-manager.js.map +1 -1
  20. package/dist/src/agents/a2a-client-manager.test.js +45 -31
  21. package/dist/src/agents/a2a-client-manager.test.js.map +1 -1
  22. package/dist/src/agents/a2aUtils.d.ts +25 -7
  23. package/dist/src/agents/a2aUtils.js +165 -58
  24. package/dist/src/agents/a2aUtils.js.map +1 -1
  25. package/dist/src/agents/a2aUtils.test.js +170 -27
  26. package/dist/src/agents/a2aUtils.test.js.map +1 -1
  27. package/dist/src/agents/generalist-agent.js +1 -2
  28. package/dist/src/agents/generalist-agent.js.map +1 -1
  29. package/dist/src/agents/registry.test.js +4 -2
  30. package/dist/src/agents/registry.test.js.map +1 -1
  31. package/dist/src/agents/remote-invocation.d.ts +2 -1
  32. package/dist/src/agents/remote-invocation.js +41 -22
  33. package/dist/src/agents/remote-invocation.js.map +1 -1
  34. package/dist/src/agents/remote-invocation.test.js +196 -56
  35. package/dist/src/agents/remote-invocation.test.js.map +1 -1
  36. package/dist/src/agents/subagent-tool-wrapper.js +1 -1
  37. package/dist/src/agents/subagent-tool-wrapper.test.js +1 -1
  38. package/dist/src/agents/subagent-tool.js +15 -2
  39. package/dist/src/agents/subagent-tool.js.map +1 -1
  40. package/dist/src/agents/subagent-tool.test.js +31 -0
  41. package/dist/src/agents/subagent-tool.test.js.map +1 -1
  42. package/dist/src/billing/billing.d.ts +80 -0
  43. package/dist/src/billing/billing.js +127 -0
  44. package/dist/src/billing/billing.js.map +1 -0
  45. package/dist/src/billing/billing.test.d.ts +6 -0
  46. package/dist/src/billing/billing.test.js +182 -0
  47. package/dist/src/billing/billing.test.js.map +1 -0
  48. package/dist/src/billing/index.d.ts +6 -0
  49. package/dist/src/billing/index.js +7 -0
  50. package/dist/src/billing/index.js.map +1 -0
  51. package/dist/src/code_assist/codeAssist.js +1 -1
  52. package/dist/src/code_assist/codeAssist.js.map +1 -1
  53. package/dist/src/code_assist/codeAssist.test.js +2 -2
  54. package/dist/src/code_assist/codeAssist.test.js.map +1 -1
  55. package/dist/src/code_assist/converter.d.ts +9 -4
  56. package/dist/src/code_assist/converter.js +17 -2
  57. package/dist/src/code_assist/converter.js.map +1 -1
  58. package/dist/src/code_assist/converter.test.js.map +1 -1
  59. package/dist/src/code_assist/oauth2.js +6 -3
  60. package/dist/src/code_assist/oauth2.js.map +1 -1
  61. package/dist/src/code_assist/oauth2.test.js +1 -0
  62. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  63. package/dist/src/code_assist/server.d.ts +9 -4
  64. package/dist/src/code_assist/server.js +86 -5
  65. package/dist/src/code_assist/server.js.map +1 -1
  66. package/dist/src/code_assist/server.test.js +11 -0
  67. package/dist/src/code_assist/server.test.js.map +1 -1
  68. package/dist/src/code_assist/setup.d.ts +2 -1
  69. package/dist/src/code_assist/setup.js +15 -4
  70. package/dist/src/code_assist/setup.js.map +1 -1
  71. package/dist/src/code_assist/types.d.ts +33 -10
  72. package/dist/src/code_assist/types.js.map +1 -1
  73. package/dist/src/config/config.d.ts +50 -4
  74. package/dist/src/config/config.js +77 -3
  75. package/dist/src/config/config.js.map +1 -1
  76. package/dist/src/config/config.test.js +151 -1
  77. package/dist/src/config/config.test.js.map +1 -1
  78. package/dist/src/config/storage.d.ts +1 -0
  79. package/dist/src/config/storage.js +4 -1
  80. package/dist/src/config/storage.js.map +1 -1
  81. package/dist/src/core/contentGenerator.d.ts +3 -2
  82. package/dist/src/core/contentGenerator.js +9 -2
  83. package/dist/src/core/contentGenerator.js.map +1 -1
  84. package/dist/src/core/coreToolScheduler.js +2 -1
  85. package/dist/src/core/coreToolScheduler.js.map +1 -1
  86. package/dist/src/core/coreToolScheduler.test.js +21 -2
  87. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  88. package/dist/src/core/fakeContentGenerator.d.ts +2 -1
  89. package/dist/src/core/fakeContentGenerator.js +1 -0
  90. package/dist/src/core/fakeContentGenerator.js.map +1 -1
  91. package/dist/src/core/geminiChat.js +6 -2
  92. package/dist/src/core/geminiChat.js.map +1 -1
  93. package/dist/src/core/geminiChat.test.js +34 -0
  94. package/dist/src/core/geminiChat.test.js.map +1 -1
  95. package/dist/src/core/localLiteRtLmClient.d.ts +24 -0
  96. package/dist/src/core/localLiteRtLmClient.js +77 -0
  97. package/dist/src/core/localLiteRtLmClient.js.map +1 -0
  98. package/dist/src/core/localLiteRtLmClient.test.d.ts +6 -0
  99. package/dist/src/core/localLiteRtLmClient.test.js +87 -0
  100. package/dist/src/core/localLiteRtLmClient.test.js.map +1 -0
  101. package/dist/src/core/loggingContentGenerator.d.ts +2 -1
  102. package/dist/src/core/loggingContentGenerator.js +39 -17
  103. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  104. package/dist/src/core/loggingContentGenerator.test.js +122 -5
  105. package/dist/src/core/loggingContentGenerator.test.js.map +1 -1
  106. package/dist/src/core/prompts.test.js +1 -1
  107. package/dist/src/core/prompts.test.js.map +1 -1
  108. package/dist/src/fallback/handler.js +2 -0
  109. package/dist/src/fallback/handler.js.map +1 -1
  110. package/dist/src/fallback/types.d.ts +1 -1
  111. package/dist/src/generated/git-commit.d.ts +2 -2
  112. package/dist/src/generated/git-commit.js +2 -2
  113. package/dist/src/index.d.ts +5 -0
  114. package/dist/src/index.js +5 -0
  115. package/dist/src/index.js.map +1 -1
  116. package/dist/src/policy/config.d.ts +18 -6
  117. package/dist/src/policy/config.js +51 -14
  118. package/dist/src/policy/config.js.map +1 -1
  119. package/dist/src/policy/config.test.js +26 -26
  120. package/dist/src/policy/config.test.js.map +1 -1
  121. package/dist/src/policy/persistence.test.js +9 -14
  122. package/dist/src/policy/persistence.test.js.map +1 -1
  123. package/dist/src/policy/policies/plan.toml +1 -1
  124. package/dist/src/policy/policy-engine.d.ts +8 -0
  125. package/dist/src/policy/policy-engine.js +12 -0
  126. package/dist/src/policy/policy-engine.js.map +1 -1
  127. package/dist/src/policy/policy-engine.test.js +93 -0
  128. package/dist/src/policy/policy-engine.test.js.map +1 -1
  129. package/dist/src/policy/policy-updater.test.js +1 -1
  130. package/dist/src/policy/policy-updater.test.js.map +1 -1
  131. package/dist/src/policy/toml-loader.d.ts +1 -1
  132. package/dist/src/policy/toml-loader.js +4 -2
  133. package/dist/src/policy/toml-loader.js.map +1 -1
  134. package/dist/src/policy/toml-loader.test.js +15 -12
  135. package/dist/src/policy/toml-loader.test.js.map +1 -1
  136. package/dist/src/policy/workspace-policy.test.js +10 -10
  137. package/dist/src/prompts/snippets.js +43 -27
  138. package/dist/src/prompts/snippets.js.map +1 -1
  139. package/dist/src/routing/modelRouterService.js +19 -11
  140. package/dist/src/routing/modelRouterService.js.map +1 -1
  141. package/dist/src/routing/modelRouterService.test.js +38 -1
  142. package/dist/src/routing/modelRouterService.test.js.map +1 -1
  143. package/dist/src/routing/routingStrategy.d.ts +3 -2
  144. package/dist/src/routing/strategies/classifierStrategy.d.ts +2 -1
  145. package/dist/src/routing/strategies/classifierStrategy.js +1 -1
  146. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
  147. package/dist/src/routing/strategies/classifierStrategy.test.js +15 -13
  148. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -1
  149. package/dist/src/routing/strategies/compositeStrategy.d.ts +2 -1
  150. package/dist/src/routing/strategies/compositeStrategy.js +3 -3
  151. package/dist/src/routing/strategies/compositeStrategy.js.map +1 -1
  152. package/dist/src/routing/strategies/compositeStrategy.test.js +10 -8
  153. package/dist/src/routing/strategies/compositeStrategy.test.js.map +1 -1
  154. package/dist/src/routing/strategies/defaultStrategy.d.ts +2 -1
  155. package/dist/src/routing/strategies/defaultStrategy.js +1 -1
  156. package/dist/src/routing/strategies/defaultStrategy.js.map +1 -1
  157. package/dist/src/routing/strategies/defaultStrategy.test.js +8 -4
  158. package/dist/src/routing/strategies/defaultStrategy.test.js.map +1 -1
  159. package/dist/src/routing/strategies/fallbackStrategy.d.ts +2 -1
  160. package/dist/src/routing/strategies/fallbackStrategy.js +1 -1
  161. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -1
  162. package/dist/src/routing/strategies/fallbackStrategy.test.js +6 -5
  163. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -1
  164. package/dist/src/routing/strategies/gemmaClassifierStrategy.d.ts +14 -0
  165. package/dist/src/routing/strategies/gemmaClassifierStrategy.js +182 -0
  166. package/dist/src/routing/strategies/gemmaClassifierStrategy.js.map +1 -0
  167. package/dist/src/routing/strategies/gemmaClassifierStrategy.test.d.ts +6 -0
  168. package/dist/src/routing/strategies/gemmaClassifierStrategy.test.js +218 -0
  169. package/dist/src/routing/strategies/gemmaClassifierStrategy.test.js.map +1 -0
  170. package/dist/src/routing/strategies/numericalClassifierStrategy.d.ts +2 -1
  171. package/dist/src/routing/strategies/numericalClassifierStrategy.js +1 -1
  172. package/dist/src/routing/strategies/numericalClassifierStrategy.js.map +1 -1
  173. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js +24 -22
  174. package/dist/src/routing/strategies/numericalClassifierStrategy.test.js.map +1 -1
  175. package/dist/src/routing/strategies/overrideStrategy.d.ts +2 -1
  176. package/dist/src/routing/strategies/overrideStrategy.js +1 -1
  177. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -1
  178. package/dist/src/routing/strategies/overrideStrategy.test.js +5 -4
  179. package/dist/src/routing/strategies/overrideStrategy.test.js.map +1 -1
  180. package/dist/src/scheduler/scheduler.d.ts +1 -0
  181. package/dist/src/scheduler/scheduler.js +18 -7
  182. package/dist/src/scheduler/scheduler.js.map +1 -1
  183. package/dist/src/scheduler/scheduler.test.js +19 -1
  184. package/dist/src/scheduler/scheduler.test.js.map +1 -1
  185. package/dist/src/scheduler/scheduler_parallel.test.js +94 -3
  186. package/dist/src/scheduler/scheduler_parallel.test.js.map +1 -1
  187. package/dist/src/scheduler/tool-executor.js +21 -12
  188. package/dist/src/scheduler/tool-executor.js.map +1 -1
  189. package/dist/src/scheduler/tool-executor.test.js +54 -0
  190. package/dist/src/scheduler/tool-executor.test.js.map +1 -1
  191. package/dist/src/services/trackerService.d.ts +49 -0
  192. package/dist/src/services/trackerService.js +172 -0
  193. package/dist/src/services/trackerService.js.map +1 -0
  194. package/dist/src/services/trackerService.test.d.ts +6 -0
  195. package/dist/src/services/trackerService.test.js +117 -0
  196. package/dist/src/services/trackerService.test.js.map +1 -0
  197. package/dist/src/services/trackerTypes.d.ts +51 -0
  198. package/dist/src/services/trackerTypes.js +33 -0
  199. package/dist/src/services/trackerTypes.js.map +1 -0
  200. package/dist/src/telemetry/billingEvents.d.ts +75 -0
  201. package/dist/src/telemetry/billingEvents.js +181 -0
  202. package/dist/src/telemetry/billingEvents.js.map +1 -0
  203. package/dist/src/telemetry/billingEvents.test.d.ts +6 -0
  204. package/dist/src/telemetry/billingEvents.test.js +139 -0
  205. package/dist/src/telemetry/billingEvents.test.js.map +1 -0
  206. package/dist/src/telemetry/conseca-logger.test.js +1 -0
  207. package/dist/src/telemetry/conseca-logger.test.js.map +1 -1
  208. package/dist/src/telemetry/constants.d.ts +25 -0
  209. package/dist/src/telemetry/constants.js +29 -0
  210. package/dist/src/telemetry/constants.js.map +1 -1
  211. package/dist/src/telemetry/index.d.ts +3 -1
  212. package/dist/src/telemetry/index.js +5 -1
  213. package/dist/src/telemetry/index.js.map +1 -1
  214. package/dist/src/telemetry/loggers.d.ts +2 -0
  215. package/dist/src/telemetry/loggers.js +10 -0
  216. package/dist/src/telemetry/loggers.js.map +1 -1
  217. package/dist/src/telemetry/loggers.test.js +16 -0
  218. package/dist/src/telemetry/loggers.test.js.map +1 -1
  219. package/dist/src/telemetry/metrics.d.ts +28 -0
  220. package/dist/src/telemetry/metrics.js +40 -0
  221. package/dist/src/telemetry/metrics.js.map +1 -1
  222. package/dist/src/telemetry/sanitize.test.js +1 -0
  223. package/dist/src/telemetry/sanitize.test.js.map +1 -1
  224. package/dist/src/telemetry/sdk.test.js +1 -0
  225. package/dist/src/telemetry/sdk.test.js.map +1 -1
  226. package/dist/src/telemetry/telemetryAttributes.js +2 -0
  227. package/dist/src/telemetry/telemetryAttributes.js.map +1 -1
  228. package/dist/src/telemetry/trace.d.ts +2 -1
  229. package/dist/src/telemetry/trace.js +13 -18
  230. package/dist/src/telemetry/trace.js.map +1 -1
  231. package/dist/src/telemetry/trace.test.d.ts +6 -0
  232. package/dist/src/telemetry/trace.test.js +116 -0
  233. package/dist/src/telemetry/trace.test.js.map +1 -0
  234. package/dist/src/tools/confirmation-policy.test.js +1 -0
  235. package/dist/src/tools/confirmation-policy.test.js.map +1 -1
  236. package/dist/src/tools/definitions/model-family-sets/default-legacy.js +2 -2
  237. package/dist/src/tools/definitions/model-family-sets/default-legacy.js.map +1 -1
  238. package/dist/src/tools/definitions/model-family-sets/gemini-3.js +3 -3
  239. package/dist/src/tools/definitions/model-family-sets/gemini-3.js.map +1 -1
  240. package/dist/src/tools/grep-utils.d.ts +1 -1
  241. package/dist/src/tools/grep-utils.js +4 -4
  242. package/dist/src/tools/grep-utils.js.map +1 -1
  243. package/dist/src/tools/grep.d.ts +1 -1
  244. package/dist/src/tools/grep.js +9 -9
  245. package/dist/src/tools/grep.js.map +1 -1
  246. package/dist/src/tools/grep.test.js +8 -5
  247. package/dist/src/tools/grep.test.js.map +1 -1
  248. package/dist/src/tools/line-endings.test.js +3 -11
  249. package/dist/src/tools/line-endings.test.js.map +1 -1
  250. package/dist/src/tools/mcp-client-manager.d.ts +25 -0
  251. package/dist/src/tools/mcp-client-manager.js +66 -3
  252. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  253. package/dist/src/tools/mcp-client-manager.test.js +47 -0
  254. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  255. package/dist/src/tools/mcp-client.d.ts +20 -9
  256. package/dist/src/tools/mcp-client.js +50 -46
  257. package/dist/src/tools/mcp-client.js.map +1 -1
  258. package/dist/src/tools/mcp-client.test.js +96 -84
  259. package/dist/src/tools/mcp-client.test.js.map +1 -1
  260. package/dist/src/tools/mcp-tool.d.ts +3 -3
  261. package/dist/src/tools/mcp-tool.js +1 -0
  262. package/dist/src/tools/mcp-tool.js.map +1 -1
  263. package/dist/src/tools/ripGrep.d.ts +1 -1
  264. package/dist/src/tools/ripGrep.js +7 -7
  265. package/dist/src/tools/ripGrep.js.map +1 -1
  266. package/dist/src/tools/ripGrep.test.js +10 -7
  267. package/dist/src/tools/ripGrep.test.js.map +1 -1
  268. package/dist/src/tools/tools.d.ts +1 -0
  269. package/dist/src/tools/tools.js +1 -0
  270. package/dist/src/tools/tools.js.map +1 -1
  271. package/dist/src/tools/write-file.js +4 -17
  272. package/dist/src/tools/write-file.js.map +1 -1
  273. package/dist/src/tools/write-file.test.js +29 -83
  274. package/dist/src/tools/write-file.test.js.map +1 -1
  275. package/dist/src/utils/editCorrector.d.ts +1 -42
  276. package/dist/src/utils/editCorrector.js +9 -461
  277. package/dist/src/utils/editCorrector.js.map +1 -1
  278. package/dist/src/utils/editCorrector.test.js +17 -421
  279. package/dist/src/utils/editCorrector.test.js.map +1 -1
  280. package/dist/src/utils/envExpansion.js.map +1 -1
  281. package/dist/src/utils/errors.js +7 -0
  282. package/dist/src/utils/errors.js.map +1 -1
  283. package/dist/src/utils/errors_timeout.test.d.ts +6 -0
  284. package/dist/src/utils/errors_timeout.test.js +40 -0
  285. package/dist/src/utils/errors_timeout.test.js.map +1 -0
  286. package/dist/src/utils/extensionLoader.js +35 -0
  287. package/dist/src/utils/extensionLoader.js.map +1 -1
  288. package/dist/src/utils/extensionLoader.test.js +36 -0
  289. package/dist/src/utils/extensionLoader.test.js.map +1 -1
  290. package/dist/src/utils/fetch.js +13 -2
  291. package/dist/src/utils/fetch.js.map +1 -1
  292. package/dist/src/utils/fileUtils.js +0 -1
  293. package/dist/src/utils/fileUtils.js.map +1 -1
  294. package/dist/src/utils/fileUtils.test.js +0 -1
  295. package/dist/src/utils/fileUtils.test.js.map +1 -1
  296. package/dist/src/utils/flashFallback.test.js +24 -0
  297. package/dist/src/utils/flashFallback.test.js.map +1 -1
  298. package/dist/src/utils/googleErrors.d.ts +2 -2
  299. package/dist/src/utils/googleQuotaErrors.d.ts +3 -1
  300. package/dist/src/utils/googleQuotaErrors.js +22 -12
  301. package/dist/src/utils/googleQuotaErrors.js.map +1 -1
  302. package/dist/src/utils/googleQuotaErrors.test.js +33 -1
  303. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
  304. package/dist/src/utils/retry.js +4 -2
  305. package/dist/src/utils/retry.js.map +1 -1
  306. package/dist/src/utils/retry.test.js +20 -0
  307. package/dist/src/utils/retry.test.js.map +1 -1
  308. package/dist/src/utils/schemaValidator.js +0 -1
  309. package/dist/src/utils/schemaValidator.js.map +1 -1
  310. package/dist/tsconfig.tsbuildinfo +1 -1
  311. package/package.json +1 -1
  312. package/dist/google-gemini-cli-core-0.31.0-preview.1.tgz +0 -0
@@ -0,0 +1,181 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { getCommonAttributes } from './telemetryAttributes.js';
7
+ // ============================================================================
8
+ // Event: Overage Menu Shown
9
+ // ============================================================================
10
+ export const EVENT_OVERAGE_MENU_SHOWN = 'gemini_cli.overage_menu_shown';
11
+ export class OverageMenuShownEvent {
12
+ 'event.name';
13
+ 'event.timestamp';
14
+ model;
15
+ credit_balance;
16
+ overage_strategy;
17
+ constructor(model, creditBalance, overageStrategy) {
18
+ this['event.name'] = 'overage_menu_shown';
19
+ this['event.timestamp'] = new Date().toISOString();
20
+ this.model = model;
21
+ this.credit_balance = creditBalance;
22
+ this.overage_strategy = overageStrategy;
23
+ }
24
+ toOpenTelemetryAttributes(config) {
25
+ return {
26
+ ...getCommonAttributes(config),
27
+ 'event.name': EVENT_OVERAGE_MENU_SHOWN,
28
+ 'event.timestamp': this['event.timestamp'],
29
+ model: this.model,
30
+ credit_balance: this.credit_balance,
31
+ overage_strategy: this.overage_strategy,
32
+ };
33
+ }
34
+ toLogBody() {
35
+ return `Overage menu shown for model ${this.model} with ${this.credit_balance} credits available.`;
36
+ }
37
+ }
38
+ // ============================================================================
39
+ // Event: Overage Option Selected
40
+ // ============================================================================
41
+ export const EVENT_OVERAGE_OPTION_SELECTED = 'gemini_cli.overage_option_selected';
42
+ export class OverageOptionSelectedEvent {
43
+ 'event.name';
44
+ 'event.timestamp';
45
+ model;
46
+ selected_option;
47
+ credit_balance;
48
+ constructor(model, selectedOption, creditBalance) {
49
+ this['event.name'] = 'overage_option_selected';
50
+ this['event.timestamp'] = new Date().toISOString();
51
+ this.model = model;
52
+ this.selected_option = selectedOption;
53
+ this.credit_balance = creditBalance;
54
+ }
55
+ toOpenTelemetryAttributes(config) {
56
+ return {
57
+ ...getCommonAttributes(config),
58
+ 'event.name': EVENT_OVERAGE_OPTION_SELECTED,
59
+ 'event.timestamp': this['event.timestamp'],
60
+ model: this.model,
61
+ selected_option: this.selected_option,
62
+ credit_balance: this.credit_balance,
63
+ };
64
+ }
65
+ toLogBody() {
66
+ return `Overage option '${this.selected_option}' selected for model ${this.model}.`;
67
+ }
68
+ }
69
+ // ============================================================================
70
+ // Event: Empty Wallet Menu Shown
71
+ // ============================================================================
72
+ export const EVENT_EMPTY_WALLET_MENU_SHOWN = 'gemini_cli.empty_wallet_menu_shown';
73
+ export class EmptyWalletMenuShownEvent {
74
+ 'event.name';
75
+ 'event.timestamp';
76
+ model;
77
+ constructor(model) {
78
+ this['event.name'] = 'empty_wallet_menu_shown';
79
+ this['event.timestamp'] = new Date().toISOString();
80
+ this.model = model;
81
+ }
82
+ toOpenTelemetryAttributes(config) {
83
+ return {
84
+ ...getCommonAttributes(config),
85
+ 'event.name': EVENT_EMPTY_WALLET_MENU_SHOWN,
86
+ 'event.timestamp': this['event.timestamp'],
87
+ model: this.model,
88
+ };
89
+ }
90
+ toLogBody() {
91
+ return `Empty wallet menu shown for model ${this.model}.`;
92
+ }
93
+ }
94
+ // ============================================================================
95
+ // Event: Credit Purchase Click
96
+ // ============================================================================
97
+ export const EVENT_CREDIT_PURCHASE_CLICK = 'gemini_cli.credit_purchase_click';
98
+ export class CreditPurchaseClickEvent {
99
+ 'event.name';
100
+ 'event.timestamp';
101
+ source;
102
+ model;
103
+ constructor(source, model) {
104
+ this['event.name'] = 'credit_purchase_click';
105
+ this['event.timestamp'] = new Date().toISOString();
106
+ this.source = source;
107
+ this.model = model;
108
+ }
109
+ toOpenTelemetryAttributes(config) {
110
+ return {
111
+ ...getCommonAttributes(config),
112
+ 'event.name': EVENT_CREDIT_PURCHASE_CLICK,
113
+ 'event.timestamp': this['event.timestamp'],
114
+ source: this.source,
115
+ model: this.model,
116
+ };
117
+ }
118
+ toLogBody() {
119
+ return `Credit purchase clicked from ${this.source} for model ${this.model}.`;
120
+ }
121
+ }
122
+ // ============================================================================
123
+ // Event: Credits Used
124
+ // ============================================================================
125
+ export const EVENT_CREDITS_USED = 'gemini_cli.credits_used';
126
+ export class CreditsUsedEvent {
127
+ 'event.name';
128
+ 'event.timestamp';
129
+ model;
130
+ credits_consumed;
131
+ credits_remaining;
132
+ constructor(model, creditsConsumed, creditsRemaining) {
133
+ this['event.name'] = 'credits_used';
134
+ this['event.timestamp'] = new Date().toISOString();
135
+ this.model = model;
136
+ this.credits_consumed = creditsConsumed;
137
+ this.credits_remaining = creditsRemaining;
138
+ }
139
+ toOpenTelemetryAttributes(config) {
140
+ return {
141
+ ...getCommonAttributes(config),
142
+ 'event.name': EVENT_CREDITS_USED,
143
+ 'event.timestamp': this['event.timestamp'],
144
+ model: this.model,
145
+ credits_consumed: this.credits_consumed,
146
+ credits_remaining: this.credits_remaining,
147
+ };
148
+ }
149
+ toLogBody() {
150
+ return `${this.credits_consumed} credits consumed for model ${this.model}. ${this.credits_remaining} remaining.`;
151
+ }
152
+ }
153
+ // ============================================================================
154
+ // Event: API Key Updated (Auth Type Changed)
155
+ // ============================================================================
156
+ export const EVENT_API_KEY_UPDATED = 'gemini_cli.api_key_updated';
157
+ export class ApiKeyUpdatedEvent {
158
+ 'event.name';
159
+ 'event.timestamp';
160
+ previous_auth_type;
161
+ new_auth_type;
162
+ constructor(previousAuthType, newAuthType) {
163
+ this['event.name'] = 'api_key_updated';
164
+ this['event.timestamp'] = new Date().toISOString();
165
+ this.previous_auth_type = previousAuthType;
166
+ this.new_auth_type = newAuthType;
167
+ }
168
+ toOpenTelemetryAttributes(config) {
169
+ return {
170
+ ...getCommonAttributes(config),
171
+ 'event.name': EVENT_API_KEY_UPDATED,
172
+ 'event.timestamp': this['event.timestamp'],
173
+ previous_auth_type: this.previous_auth_type,
174
+ new_auth_type: this.new_auth_type,
175
+ };
176
+ }
177
+ toLogBody() {
178
+ return `Auth type changed from ${this.previous_auth_type} to ${this.new_auth_type}.`;
179
+ }
180
+ }
181
+ //# sourceMappingURL=billingEvents.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"billingEvents.js","sourceRoot":"","sources":["../../../src/telemetry/billingEvents.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ export {};
@@ -0,0 +1,139 @@
1
+ /**
2
+ * @license
3
+ * Copyright 2026 Google LLC
4
+ * SPDX-License-Identifier: Apache-2.0
5
+ */
6
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
7
+ import { makeFakeConfig } from '../test-utils/config.js';
8
+ import { OverageMenuShownEvent, OverageOptionSelectedEvent, EmptyWalletMenuShownEvent, CreditPurchaseClickEvent, CreditsUsedEvent, ApiKeyUpdatedEvent, EVENT_OVERAGE_MENU_SHOWN, EVENT_OVERAGE_OPTION_SELECTED, EVENT_EMPTY_WALLET_MENU_SHOWN, EVENT_CREDIT_PURCHASE_CLICK, EVENT_CREDITS_USED, EVENT_API_KEY_UPDATED, } from './billingEvents.js';
9
+ describe('billingEvents', () => {
10
+ const fakeConfig = makeFakeConfig();
11
+ beforeEach(() => {
12
+ vi.useFakeTimers();
13
+ vi.setSystemTime(new Date('2026-01-15T10:30:00.000Z'));
14
+ });
15
+ afterEach(() => {
16
+ vi.useRealTimers();
17
+ });
18
+ describe('OverageMenuShownEvent', () => {
19
+ it('should construct with correct properties', () => {
20
+ const event = new OverageMenuShownEvent('gemini-3-pro-preview', 500, 'ask');
21
+ expect(event['event.name']).toBe('overage_menu_shown');
22
+ expect(event.model).toBe('gemini-3-pro-preview');
23
+ expect(event.credit_balance).toBe(500);
24
+ expect(event.overage_strategy).toBe('ask');
25
+ });
26
+ it('should produce correct OpenTelemetry attributes', () => {
27
+ const event = new OverageMenuShownEvent('gemini-3-pro-preview', 500, 'ask');
28
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
29
+ expect(attrs['event.name']).toBe(EVENT_OVERAGE_MENU_SHOWN);
30
+ expect(attrs['model']).toBe('gemini-3-pro-preview');
31
+ expect(attrs['credit_balance']).toBe(500);
32
+ expect(attrs['overage_strategy']).toBe('ask');
33
+ });
34
+ it('should produce a human-readable log body', () => {
35
+ const event = new OverageMenuShownEvent('gemini-3-pro-preview', 500, 'ask');
36
+ expect(event.toLogBody()).toContain('gemini-3-pro-preview');
37
+ expect(event.toLogBody()).toContain('500');
38
+ });
39
+ });
40
+ describe('OverageOptionSelectedEvent', () => {
41
+ it('should construct with correct properties', () => {
42
+ const event = new OverageOptionSelectedEvent('gemini-3-pro-preview', 'use_credits', 100);
43
+ expect(event['event.name']).toBe('overage_option_selected');
44
+ expect(event.selected_option).toBe('use_credits');
45
+ expect(event.credit_balance).toBe(100);
46
+ });
47
+ it('should produce correct OpenTelemetry attributes', () => {
48
+ const event = new OverageOptionSelectedEvent('gemini-3-pro-preview', 'use_fallback', 200);
49
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
50
+ expect(attrs['event.name']).toBe(EVENT_OVERAGE_OPTION_SELECTED);
51
+ expect(attrs['selected_option']).toBe('use_fallback');
52
+ });
53
+ it('should produce a human-readable log body', () => {
54
+ const event = new OverageOptionSelectedEvent('gemini-3-pro-preview', 'manage', 100);
55
+ expect(event.toLogBody()).toContain('manage');
56
+ expect(event.toLogBody()).toContain('gemini-3-pro-preview');
57
+ });
58
+ });
59
+ describe('EmptyWalletMenuShownEvent', () => {
60
+ it('should construct with correct properties', () => {
61
+ const event = new EmptyWalletMenuShownEvent('gemini-3-pro-preview');
62
+ expect(event['event.name']).toBe('empty_wallet_menu_shown');
63
+ expect(event.model).toBe('gemini-3-pro-preview');
64
+ });
65
+ it('should produce correct OpenTelemetry attributes', () => {
66
+ const event = new EmptyWalletMenuShownEvent('gemini-3-pro-preview');
67
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
68
+ expect(attrs['event.name']).toBe(EVENT_EMPTY_WALLET_MENU_SHOWN);
69
+ expect(attrs['model']).toBe('gemini-3-pro-preview');
70
+ });
71
+ it('should produce a human-readable log body', () => {
72
+ const event = new EmptyWalletMenuShownEvent('gemini-3-pro-preview');
73
+ expect(event.toLogBody()).toContain('gemini-3-pro-preview');
74
+ });
75
+ });
76
+ describe('CreditPurchaseClickEvent', () => {
77
+ it('should construct with correct properties', () => {
78
+ const event = new CreditPurchaseClickEvent('empty_wallet_menu', 'gemini-3-pro-preview');
79
+ expect(event['event.name']).toBe('credit_purchase_click');
80
+ expect(event.source).toBe('empty_wallet_menu');
81
+ expect(event.model).toBe('gemini-3-pro-preview');
82
+ });
83
+ it('should produce correct OpenTelemetry attributes', () => {
84
+ const event = new CreditPurchaseClickEvent('overage_menu', 'gemini-3-pro-preview');
85
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
86
+ expect(attrs['event.name']).toBe(EVENT_CREDIT_PURCHASE_CLICK);
87
+ expect(attrs['source']).toBe('overage_menu');
88
+ });
89
+ it('should produce a human-readable log body', () => {
90
+ const event = new CreditPurchaseClickEvent('manage', 'gemini-3-pro-preview');
91
+ expect(event.toLogBody()).toContain('manage');
92
+ expect(event.toLogBody()).toContain('gemini-3-pro-preview');
93
+ });
94
+ });
95
+ describe('CreditsUsedEvent', () => {
96
+ it('should construct with correct properties', () => {
97
+ const event = new CreditsUsedEvent('gemini-3-pro-preview', 10, 490);
98
+ expect(event['event.name']).toBe('credits_used');
99
+ expect(event.credits_consumed).toBe(10);
100
+ expect(event.credits_remaining).toBe(490);
101
+ });
102
+ it('should produce correct OpenTelemetry attributes', () => {
103
+ const event = new CreditsUsedEvent('gemini-3-pro-preview', 10, 490);
104
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
105
+ expect(attrs['event.name']).toBe(EVENT_CREDITS_USED);
106
+ expect(attrs['credits_consumed']).toBe(10);
107
+ expect(attrs['credits_remaining']).toBe(490);
108
+ });
109
+ it('should produce a human-readable log body', () => {
110
+ const event = new CreditsUsedEvent('gemini-3-pro-preview', 10, 490);
111
+ const body = event.toLogBody();
112
+ expect(body).toContain('10');
113
+ expect(body).toContain('490');
114
+ expect(body).toContain('gemini-3-pro-preview');
115
+ });
116
+ });
117
+ describe('ApiKeyUpdatedEvent', () => {
118
+ it('should construct with correct properties', () => {
119
+ const event = new ApiKeyUpdatedEvent('google_login', 'api_key');
120
+ expect(event['event.name']).toBe('api_key_updated');
121
+ expect(event.previous_auth_type).toBe('google_login');
122
+ expect(event.new_auth_type).toBe('api_key');
123
+ });
124
+ it('should produce correct OpenTelemetry attributes', () => {
125
+ const event = new ApiKeyUpdatedEvent('google_login', 'api_key');
126
+ const attrs = event.toOpenTelemetryAttributes(fakeConfig);
127
+ expect(attrs['event.name']).toBe(EVENT_API_KEY_UPDATED);
128
+ expect(attrs['previous_auth_type']).toBe('google_login');
129
+ expect(attrs['new_auth_type']).toBe('api_key');
130
+ });
131
+ it('should produce a human-readable log body', () => {
132
+ const event = new ApiKeyUpdatedEvent('google_login', 'api_key');
133
+ const body = event.toLogBody();
134
+ expect(body).toContain('google_login');
135
+ expect(body).toContain('api_key');
136
+ });
137
+ });
138
+ });
139
+ //# sourceMappingURL=billingEvents.test.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"billingEvents.test.js","sourceRoot":"","sources":["../../../src/telemetry/billingEvents.test.ts"],"names":[],"mappings":"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"}
@@ -23,6 +23,7 @@ describe('conseca-logger', () => {
23
23
  getTelemetryLogPromptsEnabled: vi.fn().mockReturnValue(true),
24
24
  isInteractive: vi.fn().mockReturnValue(true),
25
25
  getExperiments: vi.fn().mockReturnValue({ experimentIds: [] }),
26
+ getContentGeneratorConfig: vi.fn().mockReturnValue({ authType: 'oauth' }),
26
27
  };
27
28
  mockLogger = {
28
29
  emit: vi.fn(),
@@ -1 +1 @@
1
- {"version":3,"file":"conseca-logger.test.js","sourceRoot":"","sources":["../../../src/telemetry/conseca-logger.test.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"conseca-logger.test.js","sourceRoot":"","sources":["../../../src/telemetry/conseca-logger.test.ts"],"names":[],"mappings":"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"}
@@ -4,3 +4,28 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  export declare const SERVICE_NAME = "gemini-cli";
7
+ export declare const SERVICE_DESCRIPTION = "Gemini CLI is an open-source AI agent that brings the power of Gemini directly into your terminal. It is designed to be a terminal-first, extensible, and powerful tool for developers, engineers, SREs, and beyond.";
8
+ export declare const GEN_AI_OPERATION_NAME = "gen_ai.operation.name";
9
+ export declare const GEN_AI_AGENT_NAME = "gen_ai.agent.name";
10
+ export declare const GEN_AI_AGENT_DESCRIPTION = "gen_ai.agent.description";
11
+ export declare const GEN_AI_INPUT_MESSAGES = "gen_ai.input.messages";
12
+ export declare const GEN_AI_OUTPUT_MESSAGES = "gen_ai.output.messages";
13
+ export declare const GEN_AI_REQUEST_MODEL = "gen_ai.request.model";
14
+ export declare const GEN_AI_RESPONSE_MODEL = "gen_ai.response.model";
15
+ export declare const GEN_AI_PROMPT_NAME = "gen_ai.prompt.name";
16
+ export declare const GEN_AI_TOOL_NAME = "gen_ai.tool.name";
17
+ export declare const GEN_AI_TOOL_CALL_ID = "gen_ai.tool.call_id";
18
+ export declare const GEN_AI_TOOL_DESCRIPTION = "gen_ai.tool.description";
19
+ export declare const GEN_AI_USAGE_INPUT_TOKENS = "gen_ai.usage.input_tokens";
20
+ export declare const GEN_AI_USAGE_OUTPUT_TOKENS = "gen_ai.usage.output_tokens";
21
+ export declare const GEN_AI_SYSTEM_INSTRUCTIONS = "gen_ai.system_instructions";
22
+ export declare const GEN_AI_TOOL_DEFINITIONS = "gen_ai.tool.definitions";
23
+ export declare const GEN_AI_CONVERSATION_ID = "gen_ai.conversation.id";
24
+ export declare enum GeminiCliOperation {
25
+ ToolCall = "tool_call",
26
+ LLMCall = "llm_call",
27
+ UserPrompt = "user_prompt",
28
+ SystemPrompt = "system_prompt",
29
+ AgentCall = "agent_call",
30
+ ScheduleToolCalls = "schedule_tool_calls"
31
+ }
@@ -4,4 +4,33 @@
4
4
  * SPDX-License-Identifier: Apache-2.0
5
5
  */
6
6
  export const SERVICE_NAME = 'gemini-cli';
7
+ export const SERVICE_DESCRIPTION = 'Gemini CLI is an open-source AI agent that brings the power of Gemini directly into your terminal. It is designed to be a terminal-first, extensible, and powerful tool for developers, engineers, SREs, and beyond.';
8
+ // Gemini CLI specific semantic conventions
9
+ // https://opentelemetry.io/docs/specs/semconv/registry/attributes/gen-ai/#genai-attributes
10
+ export const GEN_AI_OPERATION_NAME = 'gen_ai.operation.name';
11
+ export const GEN_AI_AGENT_NAME = 'gen_ai.agent.name';
12
+ export const GEN_AI_AGENT_DESCRIPTION = 'gen_ai.agent.description';
13
+ export const GEN_AI_INPUT_MESSAGES = 'gen_ai.input.messages';
14
+ export const GEN_AI_OUTPUT_MESSAGES = 'gen_ai.output.messages';
15
+ export const GEN_AI_REQUEST_MODEL = 'gen_ai.request.model';
16
+ export const GEN_AI_RESPONSE_MODEL = 'gen_ai.response.model';
17
+ export const GEN_AI_PROMPT_NAME = 'gen_ai.prompt.name';
18
+ export const GEN_AI_TOOL_NAME = 'gen_ai.tool.name';
19
+ export const GEN_AI_TOOL_CALL_ID = 'gen_ai.tool.call_id';
20
+ export const GEN_AI_TOOL_DESCRIPTION = 'gen_ai.tool.description';
21
+ export const GEN_AI_USAGE_INPUT_TOKENS = 'gen_ai.usage.input_tokens';
22
+ export const GEN_AI_USAGE_OUTPUT_TOKENS = 'gen_ai.usage.output_tokens';
23
+ export const GEN_AI_SYSTEM_INSTRUCTIONS = 'gen_ai.system_instructions';
24
+ export const GEN_AI_TOOL_DEFINITIONS = 'gen_ai.tool.definitions';
25
+ export const GEN_AI_CONVERSATION_ID = 'gen_ai.conversation.id';
26
+ // Gemini CLI specific operations
27
+ export var GeminiCliOperation;
28
+ (function (GeminiCliOperation) {
29
+ GeminiCliOperation["ToolCall"] = "tool_call";
30
+ GeminiCliOperation["LLMCall"] = "llm_call";
31
+ GeminiCliOperation["UserPrompt"] = "user_prompt";
32
+ GeminiCliOperation["SystemPrompt"] = "system_prompt";
33
+ GeminiCliOperation["AgentCall"] = "agent_call";
34
+ GeminiCliOperation["ScheduleToolCalls"] = "schedule_tool_calls";
35
+ })(GeminiCliOperation || (GeminiCliOperation = {}));
7
36
  //# sourceMappingURL=constants.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/telemetry/constants.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,CAAC,MAAM,YAAY,GAAG,YAAY,CAAC"}
1
+ {"version":3,"file":"constants.js","sourceRoot":"","sources":["../../../src/telemetry/constants.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,MAAM,CAAC,MAAM,YAAY,GAAG,YAAY,CAAC;AACzC,MAAM,CAAC,MAAM,mBAAmB,GAC9B,sNAAsN,CAAC;AAEzN,2CAA2C;AAC3C,2FAA2F;AAC3F,MAAM,CAAC,MAAM,qBAAqB,GAAG,uBAAuB,CAAC;AAC7D,MAAM,CAAC,MAAM,iBAAiB,GAAG,mBAAmB,CAAC;AACrD,MAAM,CAAC,MAAM,wBAAwB,GAAG,0BAA0B,CAAC;AACnE,MAAM,CAAC,MAAM,qBAAqB,GAAG,uBAAuB,CAAC;AAC7D,MAAM,CAAC,MAAM,sBAAsB,GAAG,wBAAwB,CAAC;AAC/D,MAAM,CAAC,MAAM,oBAAoB,GAAG,sBAAsB,CAAC;AAC3D,MAAM,CAAC,MAAM,qBAAqB,GAAG,uBAAuB,CAAC;AAC7D,MAAM,CAAC,MAAM,kBAAkB,GAAG,oBAAoB,CAAC;AACvD,MAAM,CAAC,MAAM,gBAAgB,GAAG,kBAAkB,CAAC;AACnD,MAAM,CAAC,MAAM,mBAAmB,GAAG,qBAAqB,CAAC;AACzD,MAAM,CAAC,MAAM,uBAAuB,GAAG,yBAAyB,CAAC;AACjE,MAAM,CAAC,MAAM,yBAAyB,GAAG,2BAA2B,CAAC;AACrE,MAAM,CAAC,MAAM,0BAA0B,GAAG,4BAA4B,CAAC;AACvE,MAAM,CAAC,MAAM,0BAA0B,GAAG,4BAA4B,CAAC;AACvE,MAAM,CAAC,MAAM,uBAAuB,GAAG,yBAAyB,CAAC;AACjE,MAAM,CAAC,MAAM,sBAAsB,GAAG,wBAAwB,CAAC;AAE/D,iCAAiC;AACjC,MAAM,CAAN,IAAY,kBAOX;AAPD,WAAY,kBAAkB;IAC5B,4CAAsB,CAAA;IACtB,0CAAoB,CAAA;IACpB,gDAA0B,CAAA;IAC1B,oDAA8B,CAAA;IAC9B,8CAAwB,CAAA;IACxB,+DAAyC,CAAA;AAC3C,CAAC,EAPW,kBAAkB,KAAlB,kBAAkB,QAO7B"}
@@ -23,6 +23,7 @@ export type { TelemetryEvent } from './types.js';
23
23
  export { SpanStatusCode, ValueType } from '@opentelemetry/api';
24
24
  export { SemanticAttributes } from '@opentelemetry/semantic-conventions';
25
25
  export * from './uiTelemetry.js';
26
+ export * from './billingEvents.js';
26
27
  export { MemoryMonitor, initializeMemoryMonitor, getMemoryMonitor, recordCurrentMemoryUsage, startGlobalMemoryMonitoring, stopGlobalMemoryMonitoring, } from './memory-monitor.js';
27
28
  export type { MemorySnapshot, ProcessMetrics } from './memory-monitor.js';
28
29
  export { HighWaterMarkTracker } from './high-water-mark-tracker.js';
@@ -30,6 +31,7 @@ export { RateLimiter } from './rate-limiter.js';
30
31
  export { ActivityType } from './activity-types.js';
31
32
  export { ActivityDetector, getActivityDetector, recordUserActivity, isUserActive, } from './activity-detector.js';
32
33
  export { ActivityMonitor, initializeActivityMonitor, getActivityMonitor, startGlobalActivityMonitoring, stopGlobalActivityMonitoring, } from './activity-monitor.js';
33
- export { recordToolCallMetrics, recordTokenUsageMetrics, recordApiResponseMetrics, recordApiErrorMetrics, recordFileOperationMetric, recordInvalidChunk, recordContentRetry, recordContentRetryFailure, recordModelRoutingMetrics, recordCustomTokenUsageMetrics, recordCustomApiResponseMetrics, recordExitFail, recordGenAiClientTokenUsage, recordGenAiClientOperationDuration, getConventionAttributes, recordStartupPerformance, recordMemoryUsage, recordCpuUsage, recordToolQueueDepth, recordToolExecutionBreakdown, recordTokenEfficiency, recordApiRequestBreakdown, recordPerformanceScore, recordPerformanceRegression, recordBaselineComparison, isPerformanceMonitoringActive, recordFlickerFrame, recordSlowRender, PerformanceMetricType, MemoryMetricType, ToolExecutionPhase, ApiRequestPhase, FileOperation, GenAiOperationName, GenAiProviderName, GenAiTokenType, } from './metrics.js';
34
+ export { recordToolCallMetrics, recordTokenUsageMetrics, recordApiResponseMetrics, recordApiErrorMetrics, recordFileOperationMetric, recordInvalidChunk, recordContentRetry, recordContentRetryFailure, recordModelRoutingMetrics, recordCustomTokenUsageMetrics, recordCustomApiResponseMetrics, recordExitFail, recordGenAiClientTokenUsage, recordGenAiClientOperationDuration, getConventionAttributes, recordStartupPerformance, recordMemoryUsage, recordCpuUsage, recordToolQueueDepth, recordToolExecutionBreakdown, recordTokenEfficiency, recordApiRequestBreakdown, recordPerformanceScore, recordPerformanceRegression, recordBaselineComparison, isPerformanceMonitoringActive, recordFlickerFrame, recordSlowRender, PerformanceMetricType, MemoryMetricType, ToolExecutionPhase, ApiRequestPhase, FileOperation, GenAiOperationName, GenAiProviderName, GenAiTokenType, recordOverageOptionSelected, recordCreditPurchaseClick, } from './metrics.js';
34
35
  export { runInDevTraceSpan, type SpanMetadata } from './trace.js';
35
36
  export { startupProfiler, StartupProfiler } from './startupProfiler.js';
37
+ export * from './constants.js';
@@ -22,6 +22,7 @@ export { makeSlashCommandEvent, makeChatCompressionEvent } from './types.js';
22
22
  export { SpanStatusCode, ValueType } from '@opentelemetry/api';
23
23
  export { SemanticAttributes } from '@opentelemetry/semantic-conventions';
24
24
  export * from './uiTelemetry.js';
25
+ export * from './billingEvents.js';
25
26
  export { MemoryMonitor, initializeMemoryMonitor, getMemoryMonitor, recordCurrentMemoryUsage, startGlobalMemoryMonitoring, stopGlobalMemoryMonitoring, } from './memory-monitor.js';
26
27
  export { HighWaterMarkTracker } from './high-water-mark-tracker.js';
27
28
  export { RateLimiter } from './rate-limiter.js';
@@ -40,7 +41,10 @@ recordStartupPerformance, recordMemoryUsage, recordCpuUsage, recordToolQueueDept
40
41
  // Performance monitoring types
41
42
  PerformanceMetricType, MemoryMetricType, ToolExecutionPhase, ApiRequestPhase, FileOperation,
42
43
  // OpenTelemetry Semantic Convention types
43
- GenAiOperationName, GenAiProviderName, GenAiTokenType, } from './metrics.js';
44
+ GenAiOperationName, GenAiProviderName, GenAiTokenType,
45
+ // Billing metrics functions
46
+ recordOverageOptionSelected, recordCreditPurchaseClick, } from './metrics.js';
44
47
  export { runInDevTraceSpan } from './trace.js';
45
48
  export { startupProfiler, StartupProfiler } from './startupProfiler.js';
49
+ export * from './constants.js';
46
50
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/telemetry/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/telemetry/index.ts"],"names":[],"mappings":"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"}
@@ -5,6 +5,7 @@
5
5
  */
6
6
  import type { Config } from '../config/config.js';
7
7
  import type { ApiErrorEvent, ApiRequestEvent, ApiResponseEvent, FileOperationEvent, IdeConnectionEvent, StartSessionEvent, ToolCallEvent, UserPromptEvent, FlashFallbackEvent, NextSpeakerCheckEvent, LoopDetectedEvent, LoopDetectionDisabledEvent, SlashCommandEvent, RewindEvent, ConversationFinishedEvent, ChatCompressionEvent, MalformedJsonResponseEvent, ContentRetryEvent, ContentRetryFailureEvent, RipgrepFallbackEvent, ToolOutputTruncatedEvent, ModelRoutingEvent, ExtensionDisableEvent, ExtensionEnableEvent, ExtensionUninstallEvent, ExtensionInstallEvent, ModelSlashCommandEvent, EditStrategyEvent, EditCorrectionEvent, AgentStartEvent, AgentFinishEvent, RecoveryAttemptEvent, WebFetchFallbackAttemptEvent, ExtensionUpdateEvent, ApprovalModeSwitchEvent, ApprovalModeDurationEvent, HookCallEvent, StartupStatsEvent, LlmLoopCheckEvent, PlanExecutionEvent, ToolOutputMaskingEvent, KeychainAvailabilityEvent, TokenStorageInitializationEvent } from './types.js';
8
+ import type { BillingTelemetryEvent } from './billingEvents.js';
8
9
  export declare function logCliConfiguration(config: Config, event: StartSessionEvent): void;
9
10
  export declare function logUserPrompt(config: Config, event: UserPromptEvent): void;
10
11
  export declare function logToolCall(config: Config, event: ToolCallEvent): void;
@@ -48,3 +49,4 @@ export declare function logHookCall(config: Config, event: HookCallEvent): void;
48
49
  export declare function logStartupStats(config: Config, event: StartupStatsEvent): void;
49
50
  export declare function logKeychainAvailability(config: Config, event: KeychainAvailabilityEvent): void;
50
51
  export declare function logTokenStorageInitialization(config: Config, event: TokenStorageInitializationEvent): void;
52
+ export declare function logBillingEvent(config: Config, event: BillingTelemetryEvent): void;
@@ -589,4 +589,14 @@ export function logTokenStorageInitialization(config, event) {
589
589
  recordTokenStorageInitialization(config, event);
590
590
  });
591
591
  }
592
+ export function logBillingEvent(config, event) {
593
+ bufferTelemetryEvent(() => {
594
+ const logger = logs.getLogger(SERVICE_NAME);
595
+ const logRecord = {
596
+ body: event.toLogBody(),
597
+ attributes: event.toOpenTelemetryAttributes(config),
598
+ };
599
+ logger.emit(logRecord);
600
+ });
601
+ }
592
602
  //# sourceMappingURL=loggers.js.map