@machina.ai/cell-cli-core 1.19.4-rc3 → 1.22.5-rc1

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 (504) hide show
  1. package/dist/index.d.ts +1 -1
  2. package/dist/index.js +1 -1
  3. package/dist/index.js.map +1 -1
  4. package/dist/package.json +1 -1
  5. package/dist/src/agents/delegate-to-agent-tool.d.ts +19 -0
  6. package/dist/src/agents/delegate-to-agent-tool.js +111 -0
  7. package/dist/src/agents/delegate-to-agent-tool.js.map +1 -0
  8. package/dist/src/agents/delegate-to-agent-tool.test.d.ts +6 -0
  9. package/dist/src/agents/delegate-to-agent-tool.test.js +133 -0
  10. package/dist/src/agents/delegate-to-agent-tool.test.js.map +1 -0
  11. package/dist/src/agents/executor.js +12 -17
  12. package/dist/src/agents/executor.js.map +1 -1
  13. package/dist/src/agents/executor.test.js +8 -9
  14. package/dist/src/agents/executor.test.js.map +1 -1
  15. package/dist/src/agents/registry.d.ts +15 -0
  16. package/dist/src/agents/registry.js +58 -2
  17. package/dist/src/agents/registry.js.map +1 -1
  18. package/dist/src/agents/registry.test.js +61 -0
  19. package/dist/src/agents/registry.test.js.map +1 -1
  20. package/dist/src/availability/errorClassification.d.ts +7 -0
  21. package/dist/src/availability/errorClassification.js +20 -0
  22. package/dist/src/availability/errorClassification.js.map +1 -0
  23. package/dist/src/availability/modelAvailabilityService.d.ts +2 -1
  24. package/dist/src/availability/modelAvailabilityService.js +5 -2
  25. package/dist/src/availability/modelAvailabilityService.js.map +1 -1
  26. package/dist/src/availability/modelAvailabilityService.test.js +3 -3
  27. package/dist/src/availability/modelAvailabilityService.test.js.map +1 -1
  28. package/dist/src/availability/modelPolicy.d.ts +8 -1
  29. package/dist/src/availability/policyCatalog.d.ts +4 -1
  30. package/dist/src/availability/policyCatalog.js +8 -9
  31. package/dist/src/availability/policyCatalog.js.map +1 -1
  32. package/dist/src/availability/policyCatalog.test.js +2 -2
  33. package/dist/src/availability/policyCatalog.test.js.map +1 -1
  34. package/dist/src/availability/policyHelpers.d.ts +51 -0
  35. package/dist/src/availability/policyHelpers.js +145 -0
  36. package/dist/src/availability/policyHelpers.js.map +1 -0
  37. package/dist/src/availability/policyHelpers.test.d.ts +6 -0
  38. package/dist/src/availability/policyHelpers.test.js +172 -0
  39. package/dist/src/availability/policyHelpers.test.js.map +1 -0
  40. package/dist/src/availability/testUtils.d.ts +10 -0
  41. package/dist/src/availability/testUtils.js +22 -0
  42. package/dist/src/availability/testUtils.js.map +1 -0
  43. package/dist/src/code_assist/experiments/client_metadata.js +3 -2
  44. package/dist/src/code_assist/experiments/client_metadata.js.map +1 -1
  45. package/dist/src/code_assist/experiments/client_metadata.test.js +7 -10
  46. package/dist/src/code_assist/experiments/client_metadata.test.js.map +1 -1
  47. package/dist/src/code_assist/experiments/experiments.js +2 -2
  48. package/dist/src/code_assist/experiments/experiments.js.map +1 -1
  49. package/dist/src/code_assist/oauth2.d.ts +2 -0
  50. package/dist/src/code_assist/oauth2.js +41 -15
  51. package/dist/src/code_assist/oauth2.js.map +1 -1
  52. package/dist/src/code_assist/oauth2.test.js +114 -7
  53. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  54. package/dist/src/code_assist/server.d.ts +2 -1
  55. package/dist/src/code_assist/server.js +7 -4
  56. package/dist/src/code_assist/server.js.map +1 -1
  57. package/dist/src/code_assist/server.test.js +24 -0
  58. package/dist/src/code_assist/server.test.js.map +1 -1
  59. package/dist/src/code_assist/types.d.ts +14 -0
  60. package/dist/src/commands/init.d.ts +7 -0
  61. package/dist/src/commands/init.js +53 -0
  62. package/dist/src/commands/init.js.map +1 -0
  63. package/dist/src/commands/init.test.d.ts +6 -0
  64. package/dist/src/commands/init.test.js +25 -0
  65. package/dist/src/commands/init.test.js.map +1 -0
  66. package/dist/src/commands/restore.d.ts +9 -0
  67. package/dist/src/commands/restore.js +46 -0
  68. package/dist/src/commands/restore.js.map +1 -0
  69. package/dist/src/commands/restore.test.d.ts +6 -0
  70. package/dist/src/commands/restore.test.js +137 -0
  71. package/dist/src/commands/restore.test.js.map +1 -0
  72. package/dist/src/commands/types.d.ts +41 -0
  73. package/dist/src/commands/types.js +7 -0
  74. package/dist/src/commands/types.js.map +1 -0
  75. package/dist/src/config/config.d.ts +43 -3
  76. package/dist/src/config/config.js +182 -29
  77. package/dist/src/config/config.js.map +1 -1
  78. package/dist/src/config/config.test.js +217 -9
  79. package/dist/src/config/config.test.js.map +1 -1
  80. package/dist/src/config/defaultModelConfigs.js +21 -0
  81. package/dist/src/config/defaultModelConfigs.js.map +1 -1
  82. package/dist/src/config/models.d.ts +33 -11
  83. package/dist/src/config/models.js +82 -24
  84. package/dist/src/config/models.js.map +1 -1
  85. package/dist/src/config/models.test.js +70 -76
  86. package/dist/src/config/models.test.js.map +1 -1
  87. package/dist/src/confirmation-bus/message-bus.js +1 -0
  88. package/dist/src/confirmation-bus/message-bus.js.map +1 -1
  89. package/dist/src/confirmation-bus/types.d.ts +4 -0
  90. package/dist/src/core/AuthenticatedContentGenerator.js +4 -4
  91. package/dist/src/core/AuthenticatedContentGenerator.js.map +1 -1
  92. package/dist/src/core/baseLlmClient.d.ts +3 -1
  93. package/dist/src/core/baseLlmClient.js +40 -3
  94. package/dist/src/core/baseLlmClient.js.map +1 -1
  95. package/dist/src/core/baseLlmClient.test.js +184 -7
  96. package/dist/src/core/baseLlmClient.test.js.map +1 -1
  97. package/dist/src/core/client.js +52 -51
  98. package/dist/src/core/client.js.map +1 -1
  99. package/dist/src/core/client.test.js +178 -6
  100. package/dist/src/core/client.test.js.map +1 -1
  101. package/dist/src/core/contentGenerator.js +5 -3
  102. package/dist/src/core/contentGenerator.js.map +1 -1
  103. package/dist/src/core/contentGenerator.test.js +29 -22
  104. package/dist/src/core/contentGenerator.test.js.map +1 -1
  105. package/dist/src/core/coreToolHookTriggers.d.ts +55 -0
  106. package/dist/src/core/coreToolHookTriggers.js +244 -0
  107. package/dist/src/core/coreToolHookTriggers.js.map +1 -0
  108. package/dist/src/core/coreToolScheduler.d.ts +1 -1
  109. package/dist/src/core/coreToolScheduler.js +87 -36
  110. package/dist/src/core/coreToolScheduler.js.map +1 -1
  111. package/dist/src/core/coreToolScheduler.test.js +201 -38
  112. package/dist/src/core/coreToolScheduler.test.js.map +1 -1
  113. package/dist/src/core/geminiChat.js +144 -41
  114. package/dist/src/core/geminiChat.js.map +1 -1
  115. package/dist/src/core/geminiChat.test.js +251 -192
  116. package/dist/src/core/geminiChat.test.js.map +1 -1
  117. package/dist/src/core/geminiChatHookTriggers.d.ts +64 -0
  118. package/dist/src/core/geminiChatHookTriggers.js +136 -0
  119. package/dist/src/core/geminiChatHookTriggers.js.map +1 -0
  120. package/dist/src/core/geminiChat_network_retry.test.d.ts +6 -0
  121. package/dist/src/core/geminiChat_network_retry.test.js +198 -0
  122. package/dist/src/core/geminiChat_network_retry.test.js.map +1 -0
  123. package/dist/src/core/logger.js.map +1 -1
  124. package/dist/src/core/loggingContentGenerator.js +9 -4
  125. package/dist/src/core/loggingContentGenerator.js.map +1 -1
  126. package/dist/src/core/nonInteractiveToolExecutor.test.js +4 -5
  127. package/dist/src/core/nonInteractiveToolExecutor.test.js.map +1 -1
  128. package/dist/src/core/prompts.js +50 -29
  129. package/dist/src/core/prompts.js.map +1 -1
  130. package/dist/src/core/prompts.test.js +19 -8
  131. package/dist/src/core/prompts.test.js.map +1 -1
  132. package/dist/src/core/sessionHookTriggers.d.ts +28 -0
  133. package/dist/src/core/sessionHookTriggers.js +68 -0
  134. package/dist/src/core/sessionHookTriggers.js.map +1 -0
  135. package/dist/src/core/turn.d.ts +1 -0
  136. package/dist/src/core/turn.js +1 -1
  137. package/dist/src/core/turn.js.map +1 -1
  138. package/dist/src/fallback/handler.js +82 -69
  139. package/dist/src/fallback/handler.js.map +1 -1
  140. package/dist/src/fallback/handler.test.js +186 -170
  141. package/dist/src/fallback/handler.test.js.map +1 -1
  142. package/dist/src/fallback/types.d.ts +8 -0
  143. package/dist/src/generated/git-commit.d.ts +2 -2
  144. package/dist/src/generated/git-commit.js +2 -2
  145. package/dist/src/hooks/hookEventHandler.js +70 -12
  146. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  147. package/dist/src/hooks/hookEventHandler.test.js +8 -1
  148. package/dist/src/hooks/hookEventHandler.test.js.map +1 -1
  149. package/dist/src/hooks/hookRegistry.d.ts +0 -7
  150. package/dist/src/hooks/hookRegistry.js +8 -21
  151. package/dist/src/hooks/hookRegistry.js.map +1 -1
  152. package/dist/src/hooks/hookRegistry.test.js +2 -7
  153. package/dist/src/hooks/hookRegistry.test.js.map +1 -1
  154. package/dist/src/hooks/hookRunner.js +19 -3
  155. package/dist/src/hooks/hookRunner.js.map +1 -1
  156. package/dist/src/hooks/hookRunner.test.js +2 -1
  157. package/dist/src/hooks/hookRunner.test.js.map +1 -1
  158. package/dist/src/hooks/hookSystem.d.ts +0 -8
  159. package/dist/src/hooks/hookSystem.js +0 -18
  160. package/dist/src/hooks/hookSystem.js.map +1 -1
  161. package/dist/src/hooks/hookSystem.test.js +124 -18
  162. package/dist/src/hooks/hookSystem.test.js.map +1 -1
  163. package/dist/src/hooks/index.d.ts +3 -1
  164. package/dist/src/hooks/index.js +3 -0
  165. package/dist/src/hooks/index.js.map +1 -1
  166. package/dist/src/hooks/types.d.ts +1 -2
  167. package/dist/src/hooks/types.js +0 -1
  168. package/dist/src/hooks/types.js.map +1 -1
  169. package/dist/src/ide/detect-ide.test.js +32 -1
  170. package/dist/src/ide/detect-ide.test.js.map +1 -1
  171. package/dist/src/ide/ide-client.js +5 -3
  172. package/dist/src/ide/ide-client.js.map +1 -1
  173. package/dist/src/ide/ide-client.test.js +17 -0
  174. package/dist/src/ide/ide-client.test.js.map +1 -1
  175. package/dist/src/ide/ide-installer.test.js +1 -1
  176. package/dist/src/ide/ide-installer.test.js.map +1 -1
  177. package/dist/src/index.d.ts +10 -0
  178. package/dist/src/index.js +10 -0
  179. package/dist/src/index.js.map +1 -1
  180. package/dist/src/mcp/auth-provider.d.ts +16 -0
  181. package/dist/src/mcp/auth-provider.js +7 -0
  182. package/dist/src/mcp/auth-provider.js.map +1 -0
  183. package/dist/src/mcp/google-auth-provider.d.ts +10 -2
  184. package/dist/src/mcp/google-auth-provider.js +28 -0
  185. package/dist/src/mcp/google-auth-provider.js.map +1 -1
  186. package/dist/src/mcp/google-auth-provider.test.js +45 -0
  187. package/dist/src/mcp/google-auth-provider.test.js.map +1 -1
  188. package/dist/src/mcp/mcpLauncher.js +6 -3
  189. package/dist/src/mcp/mcpLauncher.js.map +1 -1
  190. package/dist/src/mcp/oauth-provider.js.map +1 -1
  191. package/dist/src/mcp/sa-impersonation-provider.d.ts +2 -2
  192. package/dist/src/mcp/sa-impersonation-provider.js.map +1 -1
  193. package/dist/src/mcp/token-storage/hybrid-token-storage.js +1 -1
  194. package/dist/src/mcp/token-storage/hybrid-token-storage.js.map +1 -1
  195. package/dist/src/output/json-formatter.d.ts +2 -2
  196. package/dist/src/output/json-formatter.js +6 -3
  197. package/dist/src/output/json-formatter.js.map +1 -1
  198. package/dist/src/output/json-formatter.test.js +37 -9
  199. package/dist/src/output/json-formatter.test.js.map +1 -1
  200. package/dist/src/output/stream-json-formatter.js +6 -0
  201. package/dist/src/output/stream-json-formatter.js.map +1 -1
  202. package/dist/src/output/stream-json-formatter.test.js +98 -100
  203. package/dist/src/output/stream-json-formatter.test.js.map +1 -1
  204. package/dist/src/output/types.d.ts +3 -0
  205. package/dist/src/output/types.js.map +1 -1
  206. package/dist/src/policy/config.js +97 -11
  207. package/dist/src/policy/config.js.map +1 -1
  208. package/dist/src/policy/persistence.test.d.ts +6 -0
  209. package/dist/src/policy/persistence.test.js +154 -0
  210. package/dist/src/policy/persistence.test.js.map +1 -0
  211. package/dist/src/policy/policies/agent.toml +31 -0
  212. package/dist/src/policy/policies/read-only.toml +5 -0
  213. package/dist/src/policy/policy-engine.d.ts +10 -1
  214. package/dist/src/policy/policy-engine.js +79 -5
  215. package/dist/src/policy/policy-engine.js.map +1 -1
  216. package/dist/src/policy/policy-engine.test.js +26 -2
  217. package/dist/src/policy/policy-engine.test.js.map +1 -1
  218. package/dist/src/policy/policy-updater.test.d.ts +6 -0
  219. package/dist/src/policy/policy-updater.test.js +116 -0
  220. package/dist/src/policy/policy-updater.test.js.map +1 -0
  221. package/dist/src/policy/shell-safety.test.d.ts +6 -0
  222. package/dist/src/policy/shell-safety.test.js +75 -0
  223. package/dist/src/policy/shell-safety.test.js.map +1 -0
  224. package/dist/src/policy/toml-loader.d.ts +11 -5
  225. package/dist/src/policy/toml-loader.js +38 -23
  226. package/dist/src/policy/toml-loader.js.map +1 -1
  227. package/dist/src/policy/toml-loader.test.js +28 -7
  228. package/dist/src/policy/toml-loader.test.js.map +1 -1
  229. package/dist/src/policy/types.d.ts +15 -0
  230. package/dist/src/resources/resource-registry.d.ts +30 -0
  231. package/dist/src/resources/resource-registry.js +57 -0
  232. package/dist/src/resources/resource-registry.js.map +1 -0
  233. package/dist/src/resources/resource-registry.test.d.ts +6 -0
  234. package/dist/src/resources/resource-registry.test.js +54 -0
  235. package/dist/src/resources/resource-registry.test.js.map +1 -0
  236. package/dist/src/routing/modelRouterService.js +0 -15
  237. package/dist/src/routing/modelRouterService.js.map +1 -1
  238. package/dist/src/routing/modelRouterService.test.js +0 -62
  239. package/dist/src/routing/modelRouterService.test.js.map +1 -1
  240. package/dist/src/routing/strategies/classifierStrategy.js +10 -21
  241. package/dist/src/routing/strategies/classifierStrategy.js.map +1 -1
  242. package/dist/src/routing/strategies/classifierStrategy.test.js +2 -1
  243. package/dist/src/routing/strategies/classifierStrategy.test.js.map +1 -1
  244. package/dist/src/routing/strategies/fallbackStrategy.js +23 -12
  245. package/dist/src/routing/strategies/fallbackStrategy.js.map +1 -1
  246. package/dist/src/routing/strategies/fallbackStrategy.test.js +69 -39
  247. package/dist/src/routing/strategies/fallbackStrategy.test.js.map +1 -1
  248. package/dist/src/routing/strategies/overrideStrategy.js +4 -3
  249. package/dist/src/routing/strategies/overrideStrategy.js.map +1 -1
  250. package/dist/src/safety/checker-runner.js +17 -6
  251. package/dist/src/safety/checker-runner.js.map +1 -1
  252. package/dist/src/services/chatCompressionService.js +17 -3
  253. package/dist/src/services/chatCompressionService.js.map +1 -1
  254. package/dist/src/services/chatCompressionService.test.js +9 -0
  255. package/dist/src/services/chatCompressionService.test.js.map +1 -1
  256. package/dist/src/services/chatRecordingService.d.ts +14 -0
  257. package/dist/src/services/chatRecordingService.js +37 -0
  258. package/dist/src/services/chatRecordingService.js.map +1 -1
  259. package/dist/src/services/contextManager.d.ts +35 -0
  260. package/dist/src/services/contextManager.js +68 -0
  261. package/dist/src/services/contextManager.js.map +1 -0
  262. package/dist/src/services/contextManager.test.d.ts +6 -0
  263. package/dist/src/services/contextManager.test.js +105 -0
  264. package/dist/src/services/contextManager.test.js.map +1 -0
  265. package/dist/src/services/fileSystemService.d.ts +0 -9
  266. package/dist/src/services/fileSystemService.js +0 -11
  267. package/dist/src/services/fileSystemService.js.map +1 -1
  268. package/dist/src/services/gitService.js +5 -0
  269. package/dist/src/services/gitService.js.map +1 -1
  270. package/dist/src/services/gitService.test.js +28 -0
  271. package/dist/src/services/gitService.test.js.map +1 -1
  272. package/dist/src/services/loopDetectionService.js +3 -3
  273. package/dist/src/services/loopDetectionService.js.map +1 -1
  274. package/dist/src/services/modelConfig.golden.test.js +32 -0
  275. package/dist/src/services/modelConfig.golden.test.js.map +1 -1
  276. package/dist/src/services/modelConfigService.d.ts +3 -0
  277. package/dist/src/services/modelConfigService.js +3 -2
  278. package/dist/src/services/modelConfigService.js.map +1 -1
  279. package/dist/src/services/modelConfigService.test.js +110 -0
  280. package/dist/src/services/modelConfigService.test.js.map +1 -1
  281. package/dist/src/services/modelConfigServiceTestUtils.d.ts +10 -0
  282. package/dist/src/services/modelConfigServiceTestUtils.js +17 -0
  283. package/dist/src/services/modelConfigServiceTestUtils.js.map +1 -0
  284. package/dist/src/services/sessionSummaryService.d.ts +28 -0
  285. package/dist/src/services/sessionSummaryService.js +131 -0
  286. package/dist/src/services/sessionSummaryService.js.map +1 -0
  287. package/dist/src/services/sessionSummaryService.test.d.ts +6 -0
  288. package/dist/src/services/sessionSummaryService.test.js +785 -0
  289. package/dist/src/services/sessionSummaryService.test.js.map +1 -0
  290. package/dist/src/services/sessionSummaryUtils.d.ts +16 -0
  291. package/dist/src/services/sessionSummaryUtils.js +129 -0
  292. package/dist/src/services/sessionSummaryUtils.js.map +1 -0
  293. package/dist/src/services/sessionSummaryUtils.test.d.ts +6 -0
  294. package/dist/src/services/sessionSummaryUtils.test.js +137 -0
  295. package/dist/src/services/sessionSummaryUtils.test.js.map +1 -0
  296. package/dist/src/services/shellExecutionService.js +56 -22
  297. package/dist/src/services/shellExecutionService.js.map +1 -1
  298. package/dist/src/services/shellExecutionService.test.js +137 -5
  299. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  300. package/dist/src/services/test-data/resolved-aliases-retry.golden.json +238 -0
  301. package/dist/src/services/test-data/resolved-aliases.golden.json +16 -0
  302. package/dist/src/telemetry/activity-detector.test.js.map +1 -1
  303. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +1 -0
  304. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +28 -5
  305. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  306. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +67 -1
  307. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  308. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +1 -0
  309. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +3 -1
  310. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  311. package/dist/src/telemetry/config.js +2 -0
  312. package/dist/src/telemetry/config.js.map +1 -1
  313. package/dist/src/telemetry/config.test.js +25 -0
  314. package/dist/src/telemetry/config.test.js.map +1 -1
  315. package/dist/src/telemetry/gcp-exporters.d.ts +4 -3
  316. package/dist/src/telemetry/gcp-exporters.js +8 -4
  317. package/dist/src/telemetry/gcp-exporters.js.map +1 -1
  318. package/dist/src/telemetry/index.d.ts +2 -1
  319. package/dist/src/telemetry/index.js +2 -1
  320. package/dist/src/telemetry/index.js.map +1 -1
  321. package/dist/src/telemetry/loggers.d.ts +2 -1
  322. package/dist/src/telemetry/loggers.js +345 -338
  323. package/dist/src/telemetry/loggers.js.map +1 -1
  324. package/dist/src/telemetry/loggers.test.js +195 -18
  325. package/dist/src/telemetry/loggers.test.js.map +1 -1
  326. package/dist/src/telemetry/metrics.test.js.map +1 -1
  327. package/dist/src/telemetry/sdk.d.ts +9 -2
  328. package/dist/src/telemetry/sdk.js +143 -17
  329. package/dist/src/telemetry/sdk.js.map +1 -1
  330. package/dist/src/telemetry/sdk.test.js +130 -28
  331. package/dist/src/telemetry/sdk.test.js.map +1 -1
  332. package/dist/src/telemetry/startupProfiler.d.ts +51 -0
  333. package/dist/src/telemetry/startupProfiler.js +170 -0
  334. package/dist/src/telemetry/startupProfiler.js.map +1 -0
  335. package/dist/src/telemetry/startupProfiler.test.d.ts +6 -0
  336. package/dist/src/telemetry/startupProfiler.test.js +289 -0
  337. package/dist/src/telemetry/startupProfiler.test.js.map +1 -0
  338. package/dist/src/telemetry/telemetry.test.js +10 -3
  339. package/dist/src/telemetry/telemetry.test.js.map +1 -1
  340. package/dist/src/telemetry/trace.js +2 -2
  341. package/dist/src/telemetry/trace.js.map +1 -1
  342. package/dist/src/telemetry/types.d.ts +37 -10
  343. package/dist/src/telemetry/types.js +82 -17
  344. package/dist/src/telemetry/types.js.map +1 -1
  345. package/dist/src/telemetry/uiTelemetry.d.ts +1 -0
  346. package/dist/src/telemetry/uiTelemetry.js +2 -0
  347. package/dist/src/telemetry/uiTelemetry.js.map +1 -1
  348. package/dist/src/telemetry/uiTelemetry.test.js +4 -0
  349. package/dist/src/telemetry/uiTelemetry.test.js.map +1 -1
  350. package/dist/src/test-utils/mock-message-bus.js.map +1 -1
  351. package/dist/src/tools/confirmation-policy.test.d.ts +6 -0
  352. package/dist/src/tools/confirmation-policy.test.js +152 -0
  353. package/dist/src/tools/confirmation-policy.test.js.map +1 -0
  354. package/dist/src/tools/edit.js +5 -0
  355. package/dist/src/tools/edit.js.map +1 -1
  356. package/dist/src/tools/edit.test.js.map +1 -1
  357. package/dist/src/tools/grep.js.map +1 -1
  358. package/dist/src/tools/mcp-client-manager.d.ts +3 -1
  359. package/dist/src/tools/mcp-client-manager.js +30 -4
  360. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  361. package/dist/src/tools/mcp-client-manager.test.js +38 -10
  362. package/dist/src/tools/mcp-client-manager.test.js.map +1 -1
  363. package/dist/src/tools/mcp-client.d.ts +40 -3
  364. package/dist/src/tools/mcp-client.js +437 -174
  365. package/dist/src/tools/mcp-client.js.map +1 -1
  366. package/dist/src/tools/mcp-client.test.js +695 -28
  367. package/dist/src/tools/mcp-client.test.js.map +1 -1
  368. package/dist/src/tools/mcp-tool.js +13 -0
  369. package/dist/src/tools/mcp-tool.js.map +1 -1
  370. package/dist/src/tools/mcp-tool.test.js +25 -0
  371. package/dist/src/tools/mcp-tool.test.js.map +1 -1
  372. package/dist/src/tools/memoryTool.js +1 -0
  373. package/dist/src/tools/memoryTool.js.map +1 -1
  374. package/dist/src/tools/modifiable-tool.js.map +1 -1
  375. package/dist/src/tools/modifiable-tool.test.js +22 -13
  376. package/dist/src/tools/modifiable-tool.test.js.map +1 -1
  377. package/dist/src/tools/read-file.js +1 -1
  378. package/dist/src/tools/read-file.js.map +1 -1
  379. package/dist/src/tools/read-file.test.js.map +1 -1
  380. package/dist/src/tools/read-many-files.js +6 -4
  381. package/dist/src/tools/read-many-files.js.map +1 -1
  382. package/dist/src/tools/read-many-files.test.js +1 -1
  383. package/dist/src/tools/read-many-files.test.js.map +1 -1
  384. package/dist/src/tools/shell.d.ts +2 -1
  385. package/dist/src/tools/shell.js +58 -4
  386. package/dist/src/tools/shell.js.map +1 -1
  387. package/dist/src/tools/shell.test.js +25 -5
  388. package/dist/src/tools/shell.test.js.map +1 -1
  389. package/dist/src/tools/smart-edit.js +6 -1
  390. package/dist/src/tools/smart-edit.js.map +1 -1
  391. package/dist/src/tools/smart-edit.test.js.map +1 -1
  392. package/dist/src/tools/tool-names.d.ts +2 -0
  393. package/dist/src/tools/tool-names.js +2 -0
  394. package/dist/src/tools/tool-names.js.map +1 -1
  395. package/dist/src/tools/tools.d.ts +19 -0
  396. package/dist/src/tools/tools.js +29 -8
  397. package/dist/src/tools/tools.js.map +1 -1
  398. package/dist/src/tools/web-fetch.js +18 -5
  399. package/dist/src/tools/web-fetch.js.map +1 -1
  400. package/dist/src/tools/web-fetch.test.js +1 -0
  401. package/dist/src/tools/web-fetch.test.js.map +1 -1
  402. package/dist/src/tools/write-file.js +5 -0
  403. package/dist/src/tools/write-file.js.map +1 -1
  404. package/dist/src/tools/write-file.test.js.map +1 -1
  405. package/dist/src/utils/bfsFileSearch.d.ts +8 -0
  406. package/dist/src/utils/bfsFileSearch.js +63 -23
  407. package/dist/src/utils/bfsFileSearch.js.map +1 -1
  408. package/dist/src/utils/bfsFileSearch.test.js +65 -1
  409. package/dist/src/utils/bfsFileSearch.test.js.map +1 -1
  410. package/dist/src/utils/checkpointUtils.d.ts +82 -0
  411. package/dist/src/utils/checkpointUtils.js +117 -0
  412. package/dist/src/utils/checkpointUtils.js.map +1 -0
  413. package/dist/src/utils/checkpointUtils.test.d.ts +6 -0
  414. package/dist/src/utils/checkpointUtils.test.js +229 -0
  415. package/dist/src/utils/checkpointUtils.test.js.map +1 -0
  416. package/dist/src/utils/debugLogger.d.ts +3 -0
  417. package/dist/src/utils/debugLogger.js +27 -0
  418. package/dist/src/utils/debugLogger.js.map +1 -1
  419. package/dist/src/utils/editCorrector.test.js +4 -0
  420. package/dist/src/utils/editCorrector.test.js.map +1 -1
  421. package/dist/src/utils/editor.d.ts +9 -1
  422. package/dist/src/utils/editor.js +23 -14
  423. package/dist/src/utils/editor.js.map +1 -1
  424. package/dist/src/utils/errors.d.ts +8 -0
  425. package/dist/src/utils/errors.js +39 -2
  426. package/dist/src/utils/errors.js.map +1 -1
  427. package/dist/src/utils/errors.test.d.ts +6 -0
  428. package/dist/src/utils/errors.test.js +155 -0
  429. package/dist/src/utils/errors.test.js.map +1 -0
  430. package/dist/src/utils/exitCodes.d.ts +12 -0
  431. package/dist/src/utils/exitCodes.js +13 -0
  432. package/dist/src/utils/exitCodes.js.map +1 -0
  433. package/dist/src/utils/extensionLoader.d.ts +2 -2
  434. package/dist/src/utils/extensionLoader.js +5 -6
  435. package/dist/src/utils/extensionLoader.js.map +1 -1
  436. package/dist/src/utils/extensionLoader.test.js +11 -0
  437. package/dist/src/utils/extensionLoader.test.js.map +1 -1
  438. package/dist/src/utils/fetch.d.ts +1 -1
  439. package/dist/src/utils/fetch.js +3 -3
  440. package/dist/src/utils/fetch.js.map +1 -1
  441. package/dist/src/utils/fileUtils.test.js +15 -0
  442. package/dist/src/utils/fileUtils.test.js.map +1 -1
  443. package/dist/src/utils/filesearch/crawlCache.js.map +1 -1
  444. package/dist/src/utils/filesearch/fileSearch.js.map +1 -1
  445. package/dist/src/utils/flashFallback.test.js +1 -1
  446. package/dist/src/utils/flashFallback.test.js.map +1 -1
  447. package/dist/src/utils/googleErrors.js +31 -18
  448. package/dist/src/utils/googleErrors.js.map +1 -1
  449. package/dist/src/utils/googleErrors.test.js +10 -2
  450. package/dist/src/utils/googleErrors.test.js.map +1 -1
  451. package/dist/src/utils/googleQuotaErrors.d.ts +3 -3
  452. package/dist/src/utils/googleQuotaErrors.js +32 -6
  453. package/dist/src/utils/googleQuotaErrors.js.map +1 -1
  454. package/dist/src/utils/googleQuotaErrors.test.js +94 -2
  455. package/dist/src/utils/googleQuotaErrors.test.js.map +1 -1
  456. package/dist/src/utils/memoryDiscovery.d.ts +5 -0
  457. package/dist/src/utils/memoryDiscovery.js +7 -3
  458. package/dist/src/utils/memoryDiscovery.js.map +1 -1
  459. package/dist/src/utils/memoryDiscovery.test.js +28 -0
  460. package/dist/src/utils/memoryDiscovery.test.js.map +1 -1
  461. package/dist/src/utils/nextSpeakerChecker.test.js +4 -0
  462. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -1
  463. package/dist/src/utils/pathCorrector.js +12 -2
  464. package/dist/src/utils/pathCorrector.js.map +1 -1
  465. package/dist/src/utils/pathCorrector.test.js +6 -2
  466. package/dist/src/utils/pathCorrector.test.js.map +1 -1
  467. package/dist/src/utils/retry.d.ts +11 -0
  468. package/dist/src/utils/retry.js +54 -13
  469. package/dist/src/utils/retry.js.map +1 -1
  470. package/dist/src/utils/retry.test.js +170 -10
  471. package/dist/src/utils/retry.test.js.map +1 -1
  472. package/dist/src/utils/shell-permissions.d.ts +52 -0
  473. package/dist/src/utils/shell-permissions.js +188 -0
  474. package/dist/src/utils/shell-permissions.js.map +1 -0
  475. package/dist/src/utils/shell-permissions.test.d.ts +6 -0
  476. package/dist/src/utils/shell-permissions.test.js +347 -0
  477. package/dist/src/utils/shell-permissions.test.js.map +1 -0
  478. package/dist/src/utils/shell-utils.d.ts +10 -47
  479. package/dist/src/utils/shell-utils.js +1 -182
  480. package/dist/src/utils/shell-utils.js.map +1 -1
  481. package/dist/src/utils/shell-utils.test.js +1 -288
  482. package/dist/src/utils/shell-utils.test.js.map +1 -1
  483. package/dist/src/utils/stdio.d.ts +2 -2
  484. package/dist/src/utils/stdio.js +2 -2
  485. package/dist/src/utils/stdio.js.map +1 -1
  486. package/dist/src/utils/stdio.test.js +5 -5
  487. package/dist/src/utils/stdio.test.js.map +1 -1
  488. package/dist/src/utils/terminalSerializer.test.js +17 -0
  489. package/dist/src/utils/terminalSerializer.test.js.map +1 -1
  490. package/dist/src/utils/tokenCalculation.d.ts +19 -0
  491. package/dist/src/utils/tokenCalculation.js +70 -0
  492. package/dist/src/utils/tokenCalculation.js.map +1 -0
  493. package/dist/src/utils/tokenCalculation.test.d.ts +6 -0
  494. package/dist/src/utils/tokenCalculation.test.js +78 -0
  495. package/dist/src/utils/tokenCalculation.test.js.map +1 -0
  496. package/dist/src/utils/tool-utils.js.map +1 -1
  497. package/dist/src/utils/version.d.ts +6 -0
  498. package/dist/src/utils/version.js +15 -0
  499. package/dist/src/utils/version.js.map +1 -0
  500. package/dist/src/utils/version.test.d.ts +6 -0
  501. package/dist/src/utils/version.test.js +39 -0
  502. package/dist/src/utils/version.test.js.map +1 -0
  503. package/dist/tsconfig.tsbuildinfo +1 -1
  504. package/package.json +1 -1
@@ -7,30 +7,30 @@ import { logs } from '@opentelemetry/api-logs';
7
7
  import { SERVICE_NAME } from './constants.js';
8
8
  import { EVENT_API_ERROR, EVENT_API_RESPONSE, EVENT_TOOL_CALL, } from './types.js';
9
9
  import { recordApiErrorMetrics, recordToolCallMetrics, recordChatCompressionMetrics, recordFileOperationMetric, recordInvalidChunk, recordContentRetry, recordContentRetryFailure, recordModelRoutingMetrics, recordModelSlashCommand, getConventionAttributes, recordTokenUsageMetrics, recordApiResponseMetrics, recordAgentRunMetrics, recordRecoveryAttemptMetrics, recordLinesChanged, recordHookCallMetrics, } from './metrics.js';
10
- import { isTelemetrySdkInitialized } from './sdk.js';
10
+ import { bufferTelemetryEvent } from './sdk.js';
11
11
  import { uiTelemetryService } from './uiTelemetry.js';
12
12
  import { ClearcutLogger } from './clearcut-logger/clearcut-logger.js';
13
13
  export function logCliConfiguration(config, event) {
14
14
  ClearcutLogger.getInstance(config)?.logStartSessionEvent(event);
15
- if (!isTelemetrySdkInitialized())
16
- return;
17
- const logger = logs.getLogger(SERVICE_NAME);
18
- const logRecord = {
19
- body: event.toLogBody(),
20
- attributes: event.toOpenTelemetryAttributes(config),
21
- };
22
- logger.emit(logRecord);
15
+ bufferTelemetryEvent(() => {
16
+ const logger = logs.getLogger(SERVICE_NAME);
17
+ const logRecord = {
18
+ body: event.toLogBody(),
19
+ attributes: event.toOpenTelemetryAttributes(config),
20
+ };
21
+ logger.emit(logRecord);
22
+ });
23
23
  }
24
24
  export function logUserPrompt(config, event) {
25
25
  ClearcutLogger.getInstance(config)?.logNewPromptEvent(event);
26
- if (!isTelemetrySdkInitialized())
27
- return;
28
- const logger = logs.getLogger(SERVICE_NAME);
29
- const logRecord = {
30
- body: event.toLogBody(),
31
- attributes: event.toOpenTelemetryAttributes(config),
32
- };
33
- logger.emit(logRecord);
26
+ bufferTelemetryEvent(() => {
27
+ const logger = logs.getLogger(SERVICE_NAME);
28
+ const logRecord = {
29
+ body: event.toLogBody(),
30
+ attributes: event.toOpenTelemetryAttributes(config),
31
+ };
32
+ logger.emit(logRecord);
33
+ });
34
34
  }
35
35
  export function logToolCall(config, event) {
36
36
  const uiEvent = {
@@ -40,96 +40,93 @@ export function logToolCall(config, event) {
40
40
  };
41
41
  uiTelemetryService.addEvent(uiEvent);
42
42
  ClearcutLogger.getInstance(config)?.logToolCallEvent(event);
43
- if (!isTelemetrySdkInitialized())
44
- return;
45
- const logger = logs.getLogger(SERVICE_NAME);
46
- const logRecord = {
47
- body: event.toLogBody(),
48
- attributes: event.toOpenTelemetryAttributes(config),
49
- };
50
- logger.emit(logRecord);
51
- recordToolCallMetrics(config, event.duration_ms, {
52
- function_name: event.function_name,
53
- success: event.success,
54
- decision: event.decision,
55
- tool_type: event.tool_type,
56
- });
57
- if (event.metadata) {
58
- const added = event.metadata['model_added_lines'];
59
- if (typeof added === 'number' && added > 0) {
60
- recordLinesChanged(config, added, 'added', {
61
- function_name: event.function_name,
62
- });
63
- }
64
- const removed = event.metadata['model_removed_lines'];
65
- if (typeof removed === 'number' && removed > 0) {
66
- recordLinesChanged(config, removed, 'removed', {
67
- function_name: event.function_name,
68
- });
43
+ bufferTelemetryEvent(() => {
44
+ const logger = logs.getLogger(SERVICE_NAME);
45
+ const logRecord = {
46
+ body: event.toLogBody(),
47
+ attributes: event.toOpenTelemetryAttributes(config),
48
+ };
49
+ logger.emit(logRecord);
50
+ recordToolCallMetrics(config, event.duration_ms, {
51
+ function_name: event.function_name,
52
+ success: event.success,
53
+ decision: event.decision,
54
+ tool_type: event.tool_type,
55
+ });
56
+ if (event.metadata) {
57
+ const added = event.metadata['model_added_lines'];
58
+ if (typeof added === 'number' && added > 0) {
59
+ recordLinesChanged(config, added, 'added', {
60
+ function_name: event.function_name,
61
+ });
62
+ }
63
+ const removed = event.metadata['model_removed_lines'];
64
+ if (typeof removed === 'number' && removed > 0) {
65
+ recordLinesChanged(config, removed, 'removed', {
66
+ function_name: event.function_name,
67
+ });
68
+ }
69
69
  }
70
- }
70
+ });
71
71
  }
72
72
  export function logToolOutputTruncated(config, event) {
73
73
  ClearcutLogger.getInstance(config)?.logToolOutputTruncatedEvent(event);
74
- if (!isTelemetrySdkInitialized())
75
- return;
76
- const logger = logs.getLogger(SERVICE_NAME);
77
- const logRecord = {
78
- body: event.toLogBody(),
79
- attributes: event.toOpenTelemetryAttributes(config),
80
- };
81
- logger.emit(logRecord);
74
+ bufferTelemetryEvent(() => {
75
+ const logger = logs.getLogger(SERVICE_NAME);
76
+ const logRecord = {
77
+ body: event.toLogBody(),
78
+ attributes: event.toOpenTelemetryAttributes(config),
79
+ };
80
+ logger.emit(logRecord);
81
+ });
82
82
  }
83
83
  export function logFileOperation(config, event) {
84
84
  ClearcutLogger.getInstance(config)?.logFileOperationEvent(event);
85
- if (!isTelemetrySdkInitialized())
86
- return;
87
- const logger = logs.getLogger(SERVICE_NAME);
88
- const logRecord = {
89
- body: event.toLogBody(),
90
- attributes: event.toOpenTelemetryAttributes(config),
91
- };
92
- logger.emit(logRecord);
93
- recordFileOperationMetric(config, {
94
- operation: event.operation,
95
- lines: event.lines,
96
- mimetype: event.mimetype,
97
- extension: event.extension,
98
- programming_language: event.programming_language,
85
+ bufferTelemetryEvent(() => {
86
+ const logger = logs.getLogger(SERVICE_NAME);
87
+ const logRecord = {
88
+ body: event.toLogBody(),
89
+ attributes: event.toOpenTelemetryAttributes(config),
90
+ };
91
+ logger.emit(logRecord);
92
+ recordFileOperationMetric(config, {
93
+ operation: event.operation,
94
+ lines: event.lines,
95
+ mimetype: event.mimetype,
96
+ extension: event.extension,
97
+ programming_language: event.programming_language,
98
+ });
99
99
  });
100
100
  }
101
101
  export function logApiRequest(config, event) {
102
102
  ClearcutLogger.getInstance(config)?.logApiRequestEvent(event);
103
- if (!isTelemetrySdkInitialized())
104
- return;
105
- const logger = logs.getLogger(SERVICE_NAME);
106
- const logRecord = {
107
- body: event.toLogBody(),
108
- attributes: event.toOpenTelemetryAttributes(config),
109
- };
110
- logger.emit(logRecord);
103
+ bufferTelemetryEvent(() => {
104
+ const logger = logs.getLogger(SERVICE_NAME);
105
+ logger.emit(event.toLogRecord(config));
106
+ logger.emit(event.toSemanticLogRecord(config));
107
+ });
111
108
  }
112
109
  export function logFlashFallback(config, event) {
113
110
  ClearcutLogger.getInstance(config)?.logFlashFallbackEvent();
114
- if (!isTelemetrySdkInitialized())
115
- return;
116
- const logger = logs.getLogger(SERVICE_NAME);
117
- const logRecord = {
118
- body: event.toLogBody(),
119
- attributes: event.toOpenTelemetryAttributes(config),
120
- };
121
- logger.emit(logRecord);
111
+ bufferTelemetryEvent(() => {
112
+ const logger = logs.getLogger(SERVICE_NAME);
113
+ const logRecord = {
114
+ body: event.toLogBody(),
115
+ attributes: event.toOpenTelemetryAttributes(config),
116
+ };
117
+ logger.emit(logRecord);
118
+ });
122
119
  }
123
120
  export function logRipgrepFallback(config, event) {
124
121
  ClearcutLogger.getInstance(config)?.logRipgrepFallbackEvent();
125
- if (!isTelemetrySdkInitialized())
126
- return;
127
- const logger = logs.getLogger(SERVICE_NAME);
128
- const logRecord = {
129
- body: event.toLogBody(),
130
- attributes: event.toOpenTelemetryAttributes(config),
131
- };
132
- logger.emit(logRecord);
122
+ bufferTelemetryEvent(() => {
123
+ const logger = logs.getLogger(SERVICE_NAME);
124
+ const logRecord = {
125
+ body: event.toLogBody(),
126
+ attributes: event.toOpenTelemetryAttributes(config),
127
+ };
128
+ logger.emit(logRecord);
129
+ });
133
130
  }
134
131
  export function logApiError(config, event) {
135
132
  const uiEvent = {
@@ -139,24 +136,24 @@ export function logApiError(config, event) {
139
136
  };
140
137
  uiTelemetryService.addEvent(uiEvent);
141
138
  ClearcutLogger.getInstance(config)?.logApiErrorEvent(event);
142
- if (!isTelemetrySdkInitialized())
143
- return;
144
- const logger = logs.getLogger(SERVICE_NAME);
145
- logger.emit(event.toLogRecord(config));
146
- logger.emit(event.toSemanticLogRecord(config));
147
- recordApiErrorMetrics(config, event.duration_ms, {
148
- model: event.model,
149
- status_code: event.status_code,
150
- error_type: event.error_type,
151
- });
152
- // Record GenAI operation duration for errors
153
- recordApiResponseMetrics(config, event.duration_ms, {
154
- model: event.model,
155
- status_code: event.status_code,
156
- genAiAttributes: {
157
- ...getConventionAttributes(event),
158
- 'error.type': event.error_type || 'unknown',
159
- },
139
+ bufferTelemetryEvent(() => {
140
+ const logger = logs.getLogger(SERVICE_NAME);
141
+ logger.emit(event.toLogRecord(config));
142
+ logger.emit(event.toSemanticLogRecord(config));
143
+ recordApiErrorMetrics(config, event.duration_ms, {
144
+ model: event.model,
145
+ status_code: event.status_code,
146
+ error_type: event.error_type,
147
+ });
148
+ // Record GenAI operation duration for errors
149
+ recordApiResponseMetrics(config, event.duration_ms, {
150
+ model: event.model,
151
+ status_code: event.status_code,
152
+ genAiAttributes: {
153
+ ...getConventionAttributes(event),
154
+ 'error.type': event.error_type || 'unknown',
155
+ },
156
+ });
160
157
  });
161
158
  }
162
159
  export function logApiResponse(config, event) {
@@ -167,97 +164,97 @@ export function logApiResponse(config, event) {
167
164
  };
168
165
  uiTelemetryService.addEvent(uiEvent);
169
166
  ClearcutLogger.getInstance(config)?.logApiResponseEvent(event);
170
- if (!isTelemetrySdkInitialized())
171
- return;
172
- const logger = logs.getLogger(SERVICE_NAME);
173
- logger.emit(event.toLogRecord(config));
174
- logger.emit(event.toSemanticLogRecord(config));
175
- const conventionAttributes = getConventionAttributes(event);
176
- recordApiResponseMetrics(config, event.duration_ms, {
177
- model: event.model,
178
- status_code: event.status_code,
179
- genAiAttributes: conventionAttributes,
180
- });
181
- const tokenUsageData = [
182
- { count: event.usage.input_token_count, type: 'input' },
183
- { count: event.usage.output_token_count, type: 'output' },
184
- { count: event.usage.cached_content_token_count, type: 'cache' },
185
- { count: event.usage.thoughts_token_count, type: 'thought' },
186
- { count: event.usage.tool_token_count, type: 'tool' },
187
- ];
188
- for (const { count, type } of tokenUsageData) {
189
- recordTokenUsageMetrics(config, count, {
167
+ bufferTelemetryEvent(() => {
168
+ const logger = logs.getLogger(SERVICE_NAME);
169
+ logger.emit(event.toLogRecord(config));
170
+ logger.emit(event.toSemanticLogRecord(config));
171
+ const conventionAttributes = getConventionAttributes(event);
172
+ recordApiResponseMetrics(config, event.duration_ms, {
190
173
  model: event.model,
191
- type,
174
+ status_code: event.status_code,
192
175
  genAiAttributes: conventionAttributes,
193
176
  });
194
- }
177
+ const tokenUsageData = [
178
+ { count: event.usage.input_token_count, type: 'input' },
179
+ { count: event.usage.output_token_count, type: 'output' },
180
+ { count: event.usage.cached_content_token_count, type: 'cache' },
181
+ { count: event.usage.thoughts_token_count, type: 'thought' },
182
+ { count: event.usage.tool_token_count, type: 'tool' },
183
+ ];
184
+ for (const { count, type } of tokenUsageData) {
185
+ recordTokenUsageMetrics(config, count, {
186
+ model: event.model,
187
+ type,
188
+ genAiAttributes: conventionAttributes,
189
+ });
190
+ }
191
+ });
195
192
  }
196
193
  export function logLoopDetected(config, event) {
197
194
  ClearcutLogger.getInstance(config)?.logLoopDetectedEvent(event);
198
- if (!isTelemetrySdkInitialized())
199
- return;
200
- const logger = logs.getLogger(SERVICE_NAME);
201
- const logRecord = {
202
- body: event.toLogBody(),
203
- attributes: event.toOpenTelemetryAttributes(config),
204
- };
205
- logger.emit(logRecord);
195
+ bufferTelemetryEvent(() => {
196
+ const logger = logs.getLogger(SERVICE_NAME);
197
+ const logRecord = {
198
+ body: event.toLogBody(),
199
+ attributes: event.toOpenTelemetryAttributes(config),
200
+ };
201
+ logger.emit(logRecord);
202
+ });
206
203
  }
207
204
  export function logLoopDetectionDisabled(config, event) {
208
205
  ClearcutLogger.getInstance(config)?.logLoopDetectionDisabledEvent();
209
- if (!isTelemetrySdkInitialized())
210
- return;
211
- const logger = logs.getLogger(SERVICE_NAME);
212
- const logRecord = {
213
- body: event.toLogBody(),
214
- attributes: event.toOpenTelemetryAttributes(config),
215
- };
216
- logger.emit(logRecord);
206
+ bufferTelemetryEvent(() => {
207
+ const logger = logs.getLogger(SERVICE_NAME);
208
+ const logRecord = {
209
+ body: event.toLogBody(),
210
+ attributes: event.toOpenTelemetryAttributes(config),
211
+ };
212
+ logger.emit(logRecord);
213
+ });
217
214
  }
218
215
  export function logNextSpeakerCheck(config, event) {
219
216
  ClearcutLogger.getInstance(config)?.logNextSpeakerCheck(event);
220
- if (!isTelemetrySdkInitialized())
221
- return;
222
- const logger = logs.getLogger(SERVICE_NAME);
223
- const logRecord = {
224
- body: event.toLogBody(),
225
- attributes: event.toOpenTelemetryAttributes(config),
226
- };
227
- logger.emit(logRecord);
217
+ bufferTelemetryEvent(() => {
218
+ const logger = logs.getLogger(SERVICE_NAME);
219
+ const logRecord = {
220
+ body: event.toLogBody(),
221
+ attributes: event.toOpenTelemetryAttributes(config),
222
+ };
223
+ logger.emit(logRecord);
224
+ });
228
225
  }
229
226
  export function logSlashCommand(config, event) {
230
227
  ClearcutLogger.getInstance(config)?.logSlashCommandEvent(event);
231
- if (!isTelemetrySdkInitialized())
232
- return;
233
- const logger = logs.getLogger(SERVICE_NAME);
234
- const logRecord = {
235
- body: event.toLogBody(),
236
- attributes: event.toOpenTelemetryAttributes(config),
237
- };
238
- logger.emit(logRecord);
228
+ bufferTelemetryEvent(() => {
229
+ const logger = logs.getLogger(SERVICE_NAME);
230
+ const logRecord = {
231
+ body: event.toLogBody(),
232
+ attributes: event.toOpenTelemetryAttributes(config),
233
+ };
234
+ logger.emit(logRecord);
235
+ });
239
236
  }
240
237
  export function logIdeConnection(config, event) {
241
238
  ClearcutLogger.getInstance(config)?.logIdeConnectionEvent(event);
242
- if (!isTelemetrySdkInitialized())
243
- return;
244
- const logger = logs.getLogger(SERVICE_NAME);
245
- const logRecord = {
246
- body: event.toLogBody(),
247
- attributes: event.toOpenTelemetryAttributes(config),
248
- };
249
- logger.emit(logRecord);
239
+ bufferTelemetryEvent(() => {
240
+ const logger = logs.getLogger(SERVICE_NAME);
241
+ const logRecord = {
242
+ body: event.toLogBody(),
243
+ attributes: event.toOpenTelemetryAttributes(config),
244
+ };
245
+ logger.emit(logRecord);
246
+ });
250
247
  }
251
248
  export function logConversationFinishedEvent(config, event) {
252
249
  ClearcutLogger.getInstance(config)?.logConversationFinishedEvent(event);
253
- if (!isTelemetrySdkInitialized())
254
- return;
255
- const logger = logs.getLogger(SERVICE_NAME);
256
- const logRecord = {
257
- body: event.toLogBody(),
258
- attributes: event.toOpenTelemetryAttributes(config),
259
- };
260
- logger.emit(logRecord);
250
+ bufferTelemetryEvent(() => {
251
+ const logger = logs.getLogger(SERVICE_NAME);
252
+ const logRecord = {
253
+ body: event.toLogBody(),
254
+ attributes: event.toOpenTelemetryAttributes(config),
255
+ };
256
+ logger.emit(logRecord);
257
+ });
261
258
  }
262
259
  export function logChatCompression(config, event) {
263
260
  ClearcutLogger.getInstance(config)?.logChatCompressionEvent(event);
@@ -274,218 +271,228 @@ export function logChatCompression(config, event) {
274
271
  }
275
272
  export function logMalformedJsonResponse(config, event) {
276
273
  ClearcutLogger.getInstance(config)?.logMalformedJsonResponseEvent(event);
277
- if (!isTelemetrySdkInitialized())
278
- return;
279
- const logger = logs.getLogger(SERVICE_NAME);
280
- const logRecord = {
281
- body: event.toLogBody(),
282
- attributes: event.toOpenTelemetryAttributes(config),
283
- };
284
- logger.emit(logRecord);
274
+ bufferTelemetryEvent(() => {
275
+ const logger = logs.getLogger(SERVICE_NAME);
276
+ const logRecord = {
277
+ body: event.toLogBody(),
278
+ attributes: event.toOpenTelemetryAttributes(config),
279
+ };
280
+ logger.emit(logRecord);
281
+ });
285
282
  }
286
283
  export function logInvalidChunk(config, event) {
287
284
  ClearcutLogger.getInstance(config)?.logInvalidChunkEvent(event);
288
- if (!isTelemetrySdkInitialized())
289
- return;
290
- const logger = logs.getLogger(SERVICE_NAME);
291
- const logRecord = {
292
- body: event.toLogBody(),
293
- attributes: event.toOpenTelemetryAttributes(config),
294
- };
295
- logger.emit(logRecord);
296
- recordInvalidChunk(config);
285
+ bufferTelemetryEvent(() => {
286
+ const logger = logs.getLogger(SERVICE_NAME);
287
+ const logRecord = {
288
+ body: event.toLogBody(),
289
+ attributes: event.toOpenTelemetryAttributes(config),
290
+ };
291
+ logger.emit(logRecord);
292
+ recordInvalidChunk(config);
293
+ });
297
294
  }
298
295
  export function logContentRetry(config, event) {
299
296
  ClearcutLogger.getInstance(config)?.logContentRetryEvent(event);
300
- if (!isTelemetrySdkInitialized())
301
- return;
302
- const logger = logs.getLogger(SERVICE_NAME);
303
- const logRecord = {
304
- body: event.toLogBody(),
305
- attributes: event.toOpenTelemetryAttributes(config),
306
- };
307
- logger.emit(logRecord);
308
- recordContentRetry(config);
297
+ bufferTelemetryEvent(() => {
298
+ const logger = logs.getLogger(SERVICE_NAME);
299
+ const logRecord = {
300
+ body: event.toLogBody(),
301
+ attributes: event.toOpenTelemetryAttributes(config),
302
+ };
303
+ logger.emit(logRecord);
304
+ recordContentRetry(config);
305
+ });
309
306
  }
310
307
  export function logContentRetryFailure(config, event) {
311
308
  ClearcutLogger.getInstance(config)?.logContentRetryFailureEvent(event);
312
- if (!isTelemetrySdkInitialized())
313
- return;
314
- const logger = logs.getLogger(SERVICE_NAME);
315
- const logRecord = {
316
- body: event.toLogBody(),
317
- attributes: event.toOpenTelemetryAttributes(config),
318
- };
319
- logger.emit(logRecord);
320
- recordContentRetryFailure(config);
309
+ bufferTelemetryEvent(() => {
310
+ const logger = logs.getLogger(SERVICE_NAME);
311
+ const logRecord = {
312
+ body: event.toLogBody(),
313
+ attributes: event.toOpenTelemetryAttributes(config),
314
+ };
315
+ logger.emit(logRecord);
316
+ recordContentRetryFailure(config);
317
+ });
321
318
  }
322
319
  export function logModelRouting(config, event) {
323
320
  ClearcutLogger.getInstance(config)?.logModelRoutingEvent(event);
324
- if (!isTelemetrySdkInitialized())
325
- return;
326
- const logger = logs.getLogger(SERVICE_NAME);
327
- const logRecord = {
328
- body: event.toLogBody(),
329
- attributes: event.toOpenTelemetryAttributes(config),
330
- };
331
- logger.emit(logRecord);
332
- recordModelRoutingMetrics(config, event);
321
+ bufferTelemetryEvent(() => {
322
+ const logger = logs.getLogger(SERVICE_NAME);
323
+ const logRecord = {
324
+ body: event.toLogBody(),
325
+ attributes: event.toOpenTelemetryAttributes(config),
326
+ };
327
+ logger.emit(logRecord);
328
+ recordModelRoutingMetrics(config, event);
329
+ });
333
330
  }
334
331
  export function logModelSlashCommand(config, event) {
335
332
  ClearcutLogger.getInstance(config)?.logModelSlashCommandEvent(event);
336
- if (!isTelemetrySdkInitialized())
337
- return;
338
- const logger = logs.getLogger(SERVICE_NAME);
339
- const logRecord = {
340
- body: event.toLogBody(),
341
- attributes: event.toOpenTelemetryAttributes(config),
342
- };
343
- logger.emit(logRecord);
344
- recordModelSlashCommand(config, event);
333
+ bufferTelemetryEvent(() => {
334
+ const logger = logs.getLogger(SERVICE_NAME);
335
+ const logRecord = {
336
+ body: event.toLogBody(),
337
+ attributes: event.toOpenTelemetryAttributes(config),
338
+ };
339
+ logger.emit(logRecord);
340
+ recordModelSlashCommand(config, event);
341
+ });
345
342
  }
346
343
  export async function logExtensionInstallEvent(config, event) {
347
344
  await ClearcutLogger.getInstance(config)?.logExtensionInstallEvent(event);
348
- if (!isTelemetrySdkInitialized())
349
- return;
350
- const logger = logs.getLogger(SERVICE_NAME);
351
- const logRecord = {
352
- body: event.toLogBody(),
353
- attributes: event.toOpenTelemetryAttributes(config),
354
- };
355
- logger.emit(logRecord);
345
+ bufferTelemetryEvent(() => {
346
+ const logger = logs.getLogger(SERVICE_NAME);
347
+ const logRecord = {
348
+ body: event.toLogBody(),
349
+ attributes: event.toOpenTelemetryAttributes(config),
350
+ };
351
+ logger.emit(logRecord);
352
+ });
356
353
  }
357
354
  export async function logExtensionUninstall(config, event) {
358
355
  await ClearcutLogger.getInstance(config)?.logExtensionUninstallEvent(event);
359
- if (!isTelemetrySdkInitialized())
360
- return;
361
- const logger = logs.getLogger(SERVICE_NAME);
362
- const logRecord = {
363
- body: event.toLogBody(),
364
- attributes: event.toOpenTelemetryAttributes(config),
365
- };
366
- logger.emit(logRecord);
356
+ bufferTelemetryEvent(() => {
357
+ const logger = logs.getLogger(SERVICE_NAME);
358
+ const logRecord = {
359
+ body: event.toLogBody(),
360
+ attributes: event.toOpenTelemetryAttributes(config),
361
+ };
362
+ logger.emit(logRecord);
363
+ });
367
364
  }
368
365
  export async function logExtensionUpdateEvent(config, event) {
369
366
  await ClearcutLogger.getInstance(config)?.logExtensionUpdateEvent(event);
370
- if (!isTelemetrySdkInitialized())
371
- return;
372
- const logger = logs.getLogger(SERVICE_NAME);
373
- const logRecord = {
374
- body: event.toLogBody(),
375
- attributes: event.toOpenTelemetryAttributes(config),
376
- };
377
- logger.emit(logRecord);
367
+ bufferTelemetryEvent(() => {
368
+ const logger = logs.getLogger(SERVICE_NAME);
369
+ const logRecord = {
370
+ body: event.toLogBody(),
371
+ attributes: event.toOpenTelemetryAttributes(config),
372
+ };
373
+ logger.emit(logRecord);
374
+ });
378
375
  }
379
376
  export async function logExtensionEnable(config, event) {
380
377
  await ClearcutLogger.getInstance(config)?.logExtensionEnableEvent(event);
381
- if (!isTelemetrySdkInitialized())
382
- return;
383
- const logger = logs.getLogger(SERVICE_NAME);
384
- const logRecord = {
385
- body: event.toLogBody(),
386
- attributes: event.toOpenTelemetryAttributes(config),
387
- };
388
- logger.emit(logRecord);
378
+ bufferTelemetryEvent(() => {
379
+ const logger = logs.getLogger(SERVICE_NAME);
380
+ const logRecord = {
381
+ body: event.toLogBody(),
382
+ attributes: event.toOpenTelemetryAttributes(config),
383
+ };
384
+ logger.emit(logRecord);
385
+ });
389
386
  }
390
387
  export async function logExtensionDisable(config, event) {
391
388
  await ClearcutLogger.getInstance(config)?.logExtensionDisableEvent(event);
392
- if (!isTelemetrySdkInitialized())
393
- return;
394
- const logger = logs.getLogger(SERVICE_NAME);
395
- const logRecord = {
396
- body: event.toLogBody(),
397
- attributes: event.toOpenTelemetryAttributes(config),
398
- };
399
- logger.emit(logRecord);
389
+ bufferTelemetryEvent(() => {
390
+ const logger = logs.getLogger(SERVICE_NAME);
391
+ const logRecord = {
392
+ body: event.toLogBody(),
393
+ attributes: event.toOpenTelemetryAttributes(config),
394
+ };
395
+ logger.emit(logRecord);
396
+ });
400
397
  }
401
398
  export function logSmartEditStrategy(config, event) {
402
399
  ClearcutLogger.getInstance(config)?.logSmartEditStrategyEvent(event);
403
- if (!isTelemetrySdkInitialized())
404
- return;
405
- const logger = logs.getLogger(SERVICE_NAME);
406
- const logRecord = {
407
- body: event.toLogBody(),
408
- attributes: event.toOpenTelemetryAttributes(config),
409
- };
410
- logger.emit(logRecord);
400
+ bufferTelemetryEvent(() => {
401
+ const logger = logs.getLogger(SERVICE_NAME);
402
+ const logRecord = {
403
+ body: event.toLogBody(),
404
+ attributes: event.toOpenTelemetryAttributes(config),
405
+ };
406
+ logger.emit(logRecord);
407
+ });
411
408
  }
412
409
  export function logSmartEditCorrectionEvent(config, event) {
413
410
  ClearcutLogger.getInstance(config)?.logSmartEditCorrectionEvent(event);
414
- if (!isTelemetrySdkInitialized())
415
- return;
416
- const logger = logs.getLogger(SERVICE_NAME);
417
- const logRecord = {
418
- body: event.toLogBody(),
419
- attributes: event.toOpenTelemetryAttributes(config),
420
- };
421
- logger.emit(logRecord);
411
+ bufferTelemetryEvent(() => {
412
+ const logger = logs.getLogger(SERVICE_NAME);
413
+ const logRecord = {
414
+ body: event.toLogBody(),
415
+ attributes: event.toOpenTelemetryAttributes(config),
416
+ };
417
+ logger.emit(logRecord);
418
+ });
422
419
  }
423
420
  export function logAgentStart(config, event) {
424
421
  ClearcutLogger.getInstance(config)?.logAgentStartEvent(event);
425
- if (!isTelemetrySdkInitialized())
426
- return;
427
- const logger = logs.getLogger(SERVICE_NAME);
428
- const logRecord = {
429
- body: event.toLogBody(),
430
- attributes: event.toOpenTelemetryAttributes(config),
431
- };
432
- logger.emit(logRecord);
422
+ bufferTelemetryEvent(() => {
423
+ const logger = logs.getLogger(SERVICE_NAME);
424
+ const logRecord = {
425
+ body: event.toLogBody(),
426
+ attributes: event.toOpenTelemetryAttributes(config),
427
+ };
428
+ logger.emit(logRecord);
429
+ });
433
430
  }
434
431
  export function logAgentFinish(config, event) {
435
432
  ClearcutLogger.getInstance(config)?.logAgentFinishEvent(event);
436
- if (!isTelemetrySdkInitialized())
437
- return;
438
- const logger = logs.getLogger(SERVICE_NAME);
439
- const logRecord = {
440
- body: event.toLogBody(),
441
- attributes: event.toOpenTelemetryAttributes(config),
442
- };
443
- logger.emit(logRecord);
444
- recordAgentRunMetrics(config, event);
433
+ bufferTelemetryEvent(() => {
434
+ const logger = logs.getLogger(SERVICE_NAME);
435
+ const logRecord = {
436
+ body: event.toLogBody(),
437
+ attributes: event.toOpenTelemetryAttributes(config),
438
+ };
439
+ logger.emit(logRecord);
440
+ recordAgentRunMetrics(config, event);
441
+ });
445
442
  }
446
443
  export function logRecoveryAttempt(config, event) {
447
444
  ClearcutLogger.getInstance(config)?.logRecoveryAttemptEvent(event);
448
- if (!isTelemetrySdkInitialized())
449
- return;
450
- const logger = logs.getLogger(SERVICE_NAME);
451
- const logRecord = {
452
- body: event.toLogBody(),
453
- attributes: event.toOpenTelemetryAttributes(config),
454
- };
455
- logger.emit(logRecord);
456
- recordRecoveryAttemptMetrics(config, event);
445
+ bufferTelemetryEvent(() => {
446
+ const logger = logs.getLogger(SERVICE_NAME);
447
+ const logRecord = {
448
+ body: event.toLogBody(),
449
+ attributes: event.toOpenTelemetryAttributes(config),
450
+ };
451
+ logger.emit(logRecord);
452
+ recordRecoveryAttemptMetrics(config, event);
453
+ });
457
454
  }
458
455
  export function logWebFetchFallbackAttempt(config, event) {
459
456
  ClearcutLogger.getInstance(config)?.logWebFetchFallbackAttemptEvent(event);
460
- if (!isTelemetrySdkInitialized())
461
- return;
462
- const logger = logs.getLogger(SERVICE_NAME);
463
- const logRecord = {
464
- body: event.toLogBody(),
465
- attributes: event.toOpenTelemetryAttributes(config),
466
- };
467
- logger.emit(logRecord);
457
+ bufferTelemetryEvent(() => {
458
+ const logger = logs.getLogger(SERVICE_NAME);
459
+ const logRecord = {
460
+ body: event.toLogBody(),
461
+ attributes: event.toOpenTelemetryAttributes(config),
462
+ };
463
+ logger.emit(logRecord);
464
+ });
468
465
  }
469
466
  export function logLlmLoopCheck(config, event) {
470
467
  ClearcutLogger.getInstance(config)?.logLlmLoopCheckEvent(event);
471
- if (!isTelemetrySdkInitialized())
472
- return;
473
- const logger = logs.getLogger(SERVICE_NAME);
474
- const logRecord = {
475
- body: event.toLogBody(),
476
- attributes: event.toOpenTelemetryAttributes(config),
477
- };
478
- logger.emit(logRecord);
468
+ bufferTelemetryEvent(() => {
469
+ const logger = logs.getLogger(SERVICE_NAME);
470
+ const logRecord = {
471
+ body: event.toLogBody(),
472
+ attributes: event.toOpenTelemetryAttributes(config),
473
+ };
474
+ logger.emit(logRecord);
475
+ });
479
476
  }
480
477
  export function logHookCall(config, event) {
481
- if (!isTelemetrySdkInitialized())
482
- return;
483
- const logger = logs.getLogger(SERVICE_NAME);
484
- const logRecord = {
485
- body: event.toLogBody(),
486
- attributes: event.toOpenTelemetryAttributes(config),
487
- };
488
- logger.emit(logRecord);
489
- recordHookCallMetrics(config, event.hook_event_name, event.hook_name, event.duration_ms, event.success);
478
+ bufferTelemetryEvent(() => {
479
+ const logger = logs.getLogger(SERVICE_NAME);
480
+ const logRecord = {
481
+ body: event.toLogBody(),
482
+ attributes: event.toOpenTelemetryAttributes(config),
483
+ };
484
+ logger.emit(logRecord);
485
+ recordHookCallMetrics(config, event.hook_event_name, event.hook_name, event.duration_ms, event.success);
486
+ });
487
+ }
488
+ export function logStartupStats(config, event) {
489
+ bufferTelemetryEvent(() => {
490
+ const logger = logs.getLogger(SERVICE_NAME);
491
+ const logRecord = {
492
+ body: event.toLogBody(),
493
+ attributes: event.toOpenTelemetryAttributes(config),
494
+ };
495
+ logger.emit(logRecord);
496
+ });
490
497
  }
491
498
  //# sourceMappingURL=loggers.js.map