@google/gemini-cli-core 0.21.0-nightly.20251203.533a3fb31 → 0.21.0-nightly.20251205.f4f2bcbd9

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 (127) hide show
  1. package/dist/google-gemini-cli-core-0.21.0-nightly.20251202.2d935b379.tgz +0 -0
  2. package/dist/src/code_assist/oauth2.d.ts +2 -0
  3. package/dist/src/code_assist/oauth2.js +28 -12
  4. package/dist/src/code_assist/oauth2.js.map +1 -1
  5. package/dist/src/code_assist/oauth2.test.js +40 -2
  6. package/dist/src/code_assist/oauth2.test.js.map +1 -1
  7. package/dist/src/commands/restore.d.ts +19 -0
  8. package/dist/src/commands/restore.js +45 -0
  9. package/dist/src/commands/restore.js.map +1 -0
  10. package/dist/src/commands/restore.test.d.ts +6 -0
  11. package/dist/src/commands/restore.test.js +136 -0
  12. package/dist/src/commands/restore.test.js.map +1 -0
  13. package/dist/src/commands/types.d.ts +41 -0
  14. package/dist/src/commands/types.js +7 -0
  15. package/dist/src/commands/types.js.map +1 -0
  16. package/dist/src/config/config.d.ts +17 -2
  17. package/dist/src/config/config.js +28 -0
  18. package/dist/src/config/config.js.map +1 -1
  19. package/dist/src/core/client.js +2 -1
  20. package/dist/src/core/client.js.map +1 -1
  21. package/dist/src/core/client.test.js +23 -0
  22. package/dist/src/core/client.test.js.map +1 -1
  23. package/dist/src/core/geminiChat.test.js +4 -0
  24. package/dist/src/core/geminiChat.test.js.map +1 -1
  25. package/dist/src/core/sessionHookTriggers.d.ts +28 -0
  26. package/dist/src/core/sessionHookTriggers.js +68 -0
  27. package/dist/src/core/sessionHookTriggers.js.map +1 -0
  28. package/dist/src/generated/git-commit.d.ts +2 -2
  29. package/dist/src/generated/git-commit.js +2 -2
  30. package/dist/src/hooks/hookEventHandler.js +51 -0
  31. package/dist/src/hooks/hookEventHandler.js.map +1 -1
  32. package/dist/src/hooks/hookRegistry.js +8 -1
  33. package/dist/src/hooks/hookRegistry.js.map +1 -1
  34. package/dist/src/hooks/hookRegistry.test.js +1 -0
  35. package/dist/src/hooks/hookRegistry.test.js.map +1 -1
  36. package/dist/src/hooks/hookRunner.js +12 -2
  37. package/dist/src/hooks/hookRunner.js.map +1 -1
  38. package/dist/src/hooks/hookSystem.test.js +124 -0
  39. package/dist/src/hooks/hookSystem.test.js.map +1 -1
  40. package/dist/src/hooks/index.d.ts +3 -1
  41. package/dist/src/hooks/index.js +3 -0
  42. package/dist/src/hooks/index.js.map +1 -1
  43. package/dist/src/hooks/types.d.ts +1 -2
  44. package/dist/src/hooks/types.js +0 -1
  45. package/dist/src/hooks/types.js.map +1 -1
  46. package/dist/src/index.d.ts +2 -0
  47. package/dist/src/index.js +2 -0
  48. package/dist/src/index.js.map +1 -1
  49. package/dist/src/output/json-formatter.d.ts +2 -2
  50. package/dist/src/output/json-formatter.js +6 -3
  51. package/dist/src/output/json-formatter.js.map +1 -1
  52. package/dist/src/output/json-formatter.test.js +35 -9
  53. package/dist/src/output/json-formatter.test.js.map +1 -1
  54. package/dist/src/output/types.d.ts +1 -0
  55. package/dist/src/output/types.js.map +1 -1
  56. package/dist/src/services/chatCompressionService.js +12 -0
  57. package/dist/src/services/chatCompressionService.js.map +1 -1
  58. package/dist/src/services/chatCompressionService.test.js +2 -0
  59. package/dist/src/services/chatCompressionService.test.js.map +1 -1
  60. package/dist/src/services/shellExecutionService.js +5 -18
  61. package/dist/src/services/shellExecutionService.js.map +1 -1
  62. package/dist/src/services/shellExecutionService.test.js +29 -2
  63. package/dist/src/services/shellExecutionService.test.js.map +1 -1
  64. package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +1 -0
  65. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +20 -0
  66. package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
  67. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +49 -0
  68. package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
  69. package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +1 -0
  70. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +3 -1
  71. package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
  72. package/dist/src/telemetry/config.js +2 -0
  73. package/dist/src/telemetry/config.js.map +1 -1
  74. package/dist/src/telemetry/config.test.js +25 -0
  75. package/dist/src/telemetry/config.test.js.map +1 -1
  76. package/dist/src/telemetry/gcp-exporters.d.ts +4 -3
  77. package/dist/src/telemetry/gcp-exporters.js +7 -4
  78. package/dist/src/telemetry/gcp-exporters.js.map +1 -1
  79. package/dist/src/telemetry/index.d.ts +1 -1
  80. package/dist/src/telemetry/index.js +1 -1
  81. package/dist/src/telemetry/index.js.map +1 -1
  82. package/dist/src/telemetry/loggers.js +335 -335
  83. package/dist/src/telemetry/loggers.js.map +1 -1
  84. package/dist/src/telemetry/loggers.test.js +15 -0
  85. package/dist/src/telemetry/loggers.test.js.map +1 -1
  86. package/dist/src/telemetry/sdk.d.ts +9 -2
  87. package/dist/src/telemetry/sdk.js +126 -16
  88. package/dist/src/telemetry/sdk.js.map +1 -1
  89. package/dist/src/telemetry/sdk.test.js +111 -28
  90. package/dist/src/telemetry/sdk.test.js.map +1 -1
  91. package/dist/src/telemetry/startupProfiler.test.js +4 -0
  92. package/dist/src/telemetry/startupProfiler.test.js.map +1 -1
  93. package/dist/src/telemetry/telemetry.test.js +10 -3
  94. package/dist/src/telemetry/telemetry.test.js.map +1 -1
  95. package/dist/src/tools/mcp-client-manager.js +15 -4
  96. package/dist/src/tools/mcp-client-manager.js.map +1 -1
  97. package/dist/src/tools/mcp-client.d.ts +17 -2
  98. package/dist/src/tools/mcp-client.js +319 -166
  99. package/dist/src/tools/mcp-client.js.map +1 -1
  100. package/dist/src/tools/mcp-client.test.js +466 -26
  101. package/dist/src/tools/mcp-client.test.js.map +1 -1
  102. package/dist/src/tools/modifiable-tool.test.js +22 -13
  103. package/dist/src/tools/modifiable-tool.test.js.map +1 -1
  104. package/dist/src/utils/debugLogger.d.ts +3 -0
  105. package/dist/src/utils/debugLogger.js +27 -0
  106. package/dist/src/utils/debugLogger.js.map +1 -1
  107. package/dist/src/utils/editCorrector.test.js +4 -0
  108. package/dist/src/utils/editCorrector.test.js.map +1 -1
  109. package/dist/src/utils/editor.d.ts +9 -1
  110. package/dist/src/utils/editor.js +23 -14
  111. package/dist/src/utils/editor.js.map +1 -1
  112. package/dist/src/utils/errors.d.ts +8 -0
  113. package/dist/src/utils/errors.js +32 -0
  114. package/dist/src/utils/errors.js.map +1 -1
  115. package/dist/src/utils/errors.test.d.ts +6 -0
  116. package/dist/src/utils/errors.test.js +36 -0
  117. package/dist/src/utils/errors.test.js.map +1 -0
  118. package/dist/src/utils/nextSpeakerChecker.test.js +4 -0
  119. package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -1
  120. package/dist/src/utils/retry.js +38 -5
  121. package/dist/src/utils/retry.js.map +1 -1
  122. package/dist/src/utils/retry.test.js +35 -4
  123. package/dist/src/utils/retry.test.js.map +1 -1
  124. package/dist/src/utils/terminalSerializer.test.js +17 -0
  125. package/dist/src/utils/terminalSerializer.test.js.map +1 -1
  126. package/dist/tsconfig.tsbuildinfo +1 -1
  127. 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,93 +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
- logger.emit(event.toLogRecord(config));
107
- logger.emit(event.toSemanticLogRecord(config));
103
+ bufferTelemetryEvent(() => {
104
+ const logger = logs.getLogger(SERVICE_NAME);
105
+ logger.emit(event.toLogRecord(config));
106
+ logger.emit(event.toSemanticLogRecord(config));
107
+ });
108
108
  }
109
109
  export function logFlashFallback(config, event) {
110
110
  ClearcutLogger.getInstance(config)?.logFlashFallbackEvent();
111
- if (!isTelemetrySdkInitialized())
112
- return;
113
- const logger = logs.getLogger(SERVICE_NAME);
114
- const logRecord = {
115
- body: event.toLogBody(),
116
- attributes: event.toOpenTelemetryAttributes(config),
117
- };
118
- 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
+ });
119
119
  }
120
120
  export function logRipgrepFallback(config, event) {
121
121
  ClearcutLogger.getInstance(config)?.logRipgrepFallbackEvent();
122
- if (!isTelemetrySdkInitialized())
123
- return;
124
- const logger = logs.getLogger(SERVICE_NAME);
125
- const logRecord = {
126
- body: event.toLogBody(),
127
- attributes: event.toOpenTelemetryAttributes(config),
128
- };
129
- 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
+ });
130
130
  }
131
131
  export function logApiError(config, event) {
132
132
  const uiEvent = {
@@ -136,24 +136,24 @@ export function logApiError(config, event) {
136
136
  };
137
137
  uiTelemetryService.addEvent(uiEvent);
138
138
  ClearcutLogger.getInstance(config)?.logApiErrorEvent(event);
139
- if (!isTelemetrySdkInitialized())
140
- return;
141
- const logger = logs.getLogger(SERVICE_NAME);
142
- logger.emit(event.toLogRecord(config));
143
- logger.emit(event.toSemanticLogRecord(config));
144
- recordApiErrorMetrics(config, event.duration_ms, {
145
- model: event.model,
146
- status_code: event.status_code,
147
- error_type: event.error_type,
148
- });
149
- // Record GenAI operation duration for errors
150
- recordApiResponseMetrics(config, event.duration_ms, {
151
- model: event.model,
152
- status_code: event.status_code,
153
- genAiAttributes: {
154
- ...getConventionAttributes(event),
155
- 'error.type': event.error_type || 'unknown',
156
- },
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
+ });
157
157
  });
158
158
  }
159
159
  export function logApiResponse(config, event) {
@@ -164,97 +164,97 @@ export function logApiResponse(config, event) {
164
164
  };
165
165
  uiTelemetryService.addEvent(uiEvent);
166
166
  ClearcutLogger.getInstance(config)?.logApiResponseEvent(event);
167
- if (!isTelemetrySdkInitialized())
168
- return;
169
- const logger = logs.getLogger(SERVICE_NAME);
170
- logger.emit(event.toLogRecord(config));
171
- logger.emit(event.toSemanticLogRecord(config));
172
- const conventionAttributes = getConventionAttributes(event);
173
- recordApiResponseMetrics(config, event.duration_ms, {
174
- model: event.model,
175
- status_code: event.status_code,
176
- genAiAttributes: conventionAttributes,
177
- });
178
- const tokenUsageData = [
179
- { count: event.usage.input_token_count, type: 'input' },
180
- { count: event.usage.output_token_count, type: 'output' },
181
- { count: event.usage.cached_content_token_count, type: 'cache' },
182
- { count: event.usage.thoughts_token_count, type: 'thought' },
183
- { count: event.usage.tool_token_count, type: 'tool' },
184
- ];
185
- for (const { count, type } of tokenUsageData) {
186
- 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, {
187
173
  model: event.model,
188
- type,
174
+ status_code: event.status_code,
189
175
  genAiAttributes: conventionAttributes,
190
176
  });
191
- }
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
+ });
192
192
  }
193
193
  export function logLoopDetected(config, event) {
194
194
  ClearcutLogger.getInstance(config)?.logLoopDetectedEvent(event);
195
- if (!isTelemetrySdkInitialized())
196
- return;
197
- const logger = logs.getLogger(SERVICE_NAME);
198
- const logRecord = {
199
- body: event.toLogBody(),
200
- attributes: event.toOpenTelemetryAttributes(config),
201
- };
202
- 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
+ });
203
203
  }
204
204
  export function logLoopDetectionDisabled(config, event) {
205
205
  ClearcutLogger.getInstance(config)?.logLoopDetectionDisabledEvent();
206
- if (!isTelemetrySdkInitialized())
207
- return;
208
- const logger = logs.getLogger(SERVICE_NAME);
209
- const logRecord = {
210
- body: event.toLogBody(),
211
- attributes: event.toOpenTelemetryAttributes(config),
212
- };
213
- 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
+ });
214
214
  }
215
215
  export function logNextSpeakerCheck(config, event) {
216
216
  ClearcutLogger.getInstance(config)?.logNextSpeakerCheck(event);
217
- if (!isTelemetrySdkInitialized())
218
- return;
219
- const logger = logs.getLogger(SERVICE_NAME);
220
- const logRecord = {
221
- body: event.toLogBody(),
222
- attributes: event.toOpenTelemetryAttributes(config),
223
- };
224
- 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
+ });
225
225
  }
226
226
  export function logSlashCommand(config, event) {
227
227
  ClearcutLogger.getInstance(config)?.logSlashCommandEvent(event);
228
- if (!isTelemetrySdkInitialized())
229
- return;
230
- const logger = logs.getLogger(SERVICE_NAME);
231
- const logRecord = {
232
- body: event.toLogBody(),
233
- attributes: event.toOpenTelemetryAttributes(config),
234
- };
235
- 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
+ });
236
236
  }
237
237
  export function logIdeConnection(config, event) {
238
238
  ClearcutLogger.getInstance(config)?.logIdeConnectionEvent(event);
239
- if (!isTelemetrySdkInitialized())
240
- return;
241
- const logger = logs.getLogger(SERVICE_NAME);
242
- const logRecord = {
243
- body: event.toLogBody(),
244
- attributes: event.toOpenTelemetryAttributes(config),
245
- };
246
- 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
+ });
247
247
  }
248
248
  export function logConversationFinishedEvent(config, event) {
249
249
  ClearcutLogger.getInstance(config)?.logConversationFinishedEvent(event);
250
- if (!isTelemetrySdkInitialized())
251
- return;
252
- const logger = logs.getLogger(SERVICE_NAME);
253
- const logRecord = {
254
- body: event.toLogBody(),
255
- attributes: event.toOpenTelemetryAttributes(config),
256
- };
257
- 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
+ });
258
258
  }
259
259
  export function logChatCompression(config, event) {
260
260
  ClearcutLogger.getInstance(config)?.logChatCompressionEvent(event);
@@ -271,218 +271,218 @@ export function logChatCompression(config, event) {
271
271
  }
272
272
  export function logMalformedJsonResponse(config, event) {
273
273
  ClearcutLogger.getInstance(config)?.logMalformedJsonResponseEvent(event);
274
- if (!isTelemetrySdkInitialized())
275
- return;
276
- const logger = logs.getLogger(SERVICE_NAME);
277
- const logRecord = {
278
- body: event.toLogBody(),
279
- attributes: event.toOpenTelemetryAttributes(config),
280
- };
281
- 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
+ });
282
282
  }
283
283
  export function logInvalidChunk(config, event) {
284
284
  ClearcutLogger.getInstance(config)?.logInvalidChunkEvent(event);
285
- if (!isTelemetrySdkInitialized())
286
- return;
287
- const logger = logs.getLogger(SERVICE_NAME);
288
- const logRecord = {
289
- body: event.toLogBody(),
290
- attributes: event.toOpenTelemetryAttributes(config),
291
- };
292
- logger.emit(logRecord);
293
- 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
+ });
294
294
  }
295
295
  export function logContentRetry(config, event) {
296
296
  ClearcutLogger.getInstance(config)?.logContentRetryEvent(event);
297
- if (!isTelemetrySdkInitialized())
298
- return;
299
- const logger = logs.getLogger(SERVICE_NAME);
300
- const logRecord = {
301
- body: event.toLogBody(),
302
- attributes: event.toOpenTelemetryAttributes(config),
303
- };
304
- logger.emit(logRecord);
305
- 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
+ });
306
306
  }
307
307
  export function logContentRetryFailure(config, event) {
308
308
  ClearcutLogger.getInstance(config)?.logContentRetryFailureEvent(event);
309
- if (!isTelemetrySdkInitialized())
310
- return;
311
- const logger = logs.getLogger(SERVICE_NAME);
312
- const logRecord = {
313
- body: event.toLogBody(),
314
- attributes: event.toOpenTelemetryAttributes(config),
315
- };
316
- logger.emit(logRecord);
317
- 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
+ });
318
318
  }
319
319
  export function logModelRouting(config, event) {
320
320
  ClearcutLogger.getInstance(config)?.logModelRoutingEvent(event);
321
- if (!isTelemetrySdkInitialized())
322
- return;
323
- const logger = logs.getLogger(SERVICE_NAME);
324
- const logRecord = {
325
- body: event.toLogBody(),
326
- attributes: event.toOpenTelemetryAttributes(config),
327
- };
328
- logger.emit(logRecord);
329
- 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
+ });
330
330
  }
331
331
  export function logModelSlashCommand(config, event) {
332
332
  ClearcutLogger.getInstance(config)?.logModelSlashCommandEvent(event);
333
- if (!isTelemetrySdkInitialized())
334
- return;
335
- const logger = logs.getLogger(SERVICE_NAME);
336
- const logRecord = {
337
- body: event.toLogBody(),
338
- attributes: event.toOpenTelemetryAttributes(config),
339
- };
340
- logger.emit(logRecord);
341
- 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
+ });
342
342
  }
343
343
  export async function logExtensionInstallEvent(config, event) {
344
344
  await ClearcutLogger.getInstance(config)?.logExtensionInstallEvent(event);
345
- if (!isTelemetrySdkInitialized())
346
- return;
347
- const logger = logs.getLogger(SERVICE_NAME);
348
- const logRecord = {
349
- body: event.toLogBody(),
350
- attributes: event.toOpenTelemetryAttributes(config),
351
- };
352
- 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
+ });
353
353
  }
354
354
  export async function logExtensionUninstall(config, event) {
355
355
  await ClearcutLogger.getInstance(config)?.logExtensionUninstallEvent(event);
356
- if (!isTelemetrySdkInitialized())
357
- return;
358
- const logger = logs.getLogger(SERVICE_NAME);
359
- const logRecord = {
360
- body: event.toLogBody(),
361
- attributes: event.toOpenTelemetryAttributes(config),
362
- };
363
- 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
+ });
364
364
  }
365
365
  export async function logExtensionUpdateEvent(config, event) {
366
366
  await ClearcutLogger.getInstance(config)?.logExtensionUpdateEvent(event);
367
- if (!isTelemetrySdkInitialized())
368
- return;
369
- const logger = logs.getLogger(SERVICE_NAME);
370
- const logRecord = {
371
- body: event.toLogBody(),
372
- attributes: event.toOpenTelemetryAttributes(config),
373
- };
374
- 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
+ });
375
375
  }
376
376
  export async function logExtensionEnable(config, event) {
377
377
  await ClearcutLogger.getInstance(config)?.logExtensionEnableEvent(event);
378
- if (!isTelemetrySdkInitialized())
379
- return;
380
- const logger = logs.getLogger(SERVICE_NAME);
381
- const logRecord = {
382
- body: event.toLogBody(),
383
- attributes: event.toOpenTelemetryAttributes(config),
384
- };
385
- 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
+ });
386
386
  }
387
387
  export async function logExtensionDisable(config, event) {
388
388
  await ClearcutLogger.getInstance(config)?.logExtensionDisableEvent(event);
389
- if (!isTelemetrySdkInitialized())
390
- return;
391
- const logger = logs.getLogger(SERVICE_NAME);
392
- const logRecord = {
393
- body: event.toLogBody(),
394
- attributes: event.toOpenTelemetryAttributes(config),
395
- };
396
- 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
+ });
397
397
  }
398
398
  export function logSmartEditStrategy(config, event) {
399
399
  ClearcutLogger.getInstance(config)?.logSmartEditStrategyEvent(event);
400
- if (!isTelemetrySdkInitialized())
401
- return;
402
- const logger = logs.getLogger(SERVICE_NAME);
403
- const logRecord = {
404
- body: event.toLogBody(),
405
- attributes: event.toOpenTelemetryAttributes(config),
406
- };
407
- 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
+ });
408
408
  }
409
409
  export function logSmartEditCorrectionEvent(config, event) {
410
410
  ClearcutLogger.getInstance(config)?.logSmartEditCorrectionEvent(event);
411
- if (!isTelemetrySdkInitialized())
412
- return;
413
- const logger = logs.getLogger(SERVICE_NAME);
414
- const logRecord = {
415
- body: event.toLogBody(),
416
- attributes: event.toOpenTelemetryAttributes(config),
417
- };
418
- 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
+ });
419
419
  }
420
420
  export function logAgentStart(config, event) {
421
421
  ClearcutLogger.getInstance(config)?.logAgentStartEvent(event);
422
- if (!isTelemetrySdkInitialized())
423
- return;
424
- const logger = logs.getLogger(SERVICE_NAME);
425
- const logRecord = {
426
- body: event.toLogBody(),
427
- attributes: event.toOpenTelemetryAttributes(config),
428
- };
429
- 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
+ });
430
430
  }
431
431
  export function logAgentFinish(config, event) {
432
432
  ClearcutLogger.getInstance(config)?.logAgentFinishEvent(event);
433
- if (!isTelemetrySdkInitialized())
434
- return;
435
- const logger = logs.getLogger(SERVICE_NAME);
436
- const logRecord = {
437
- body: event.toLogBody(),
438
- attributes: event.toOpenTelemetryAttributes(config),
439
- };
440
- logger.emit(logRecord);
441
- 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
+ });
442
442
  }
443
443
  export function logRecoveryAttempt(config, event) {
444
444
  ClearcutLogger.getInstance(config)?.logRecoveryAttemptEvent(event);
445
- if (!isTelemetrySdkInitialized())
446
- return;
447
- const logger = logs.getLogger(SERVICE_NAME);
448
- const logRecord = {
449
- body: event.toLogBody(),
450
- attributes: event.toOpenTelemetryAttributes(config),
451
- };
452
- logger.emit(logRecord);
453
- 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
+ });
454
454
  }
455
455
  export function logWebFetchFallbackAttempt(config, event) {
456
456
  ClearcutLogger.getInstance(config)?.logWebFetchFallbackAttemptEvent(event);
457
- if (!isTelemetrySdkInitialized())
458
- return;
459
- const logger = logs.getLogger(SERVICE_NAME);
460
- const logRecord = {
461
- body: event.toLogBody(),
462
- attributes: event.toOpenTelemetryAttributes(config),
463
- };
464
- 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
+ });
465
465
  }
466
466
  export function logLlmLoopCheck(config, event) {
467
467
  ClearcutLogger.getInstance(config)?.logLlmLoopCheckEvent(event);
468
- if (!isTelemetrySdkInitialized())
469
- return;
470
- const logger = logs.getLogger(SERVICE_NAME);
471
- const logRecord = {
472
- body: event.toLogBody(),
473
- attributes: event.toOpenTelemetryAttributes(config),
474
- };
475
- 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
+ });
476
476
  }
477
477
  export function logHookCall(config, event) {
478
- if (!isTelemetrySdkInitialized())
479
- return;
480
- const logger = logs.getLogger(SERVICE_NAME);
481
- const logRecord = {
482
- body: event.toLogBody(),
483
- attributes: event.toOpenTelemetryAttributes(config),
484
- };
485
- logger.emit(logRecord);
486
- 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
487
  }
488
488
  //# sourceMappingURL=loggers.js.map