@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.
- package/dist/google-gemini-cli-core-0.21.0-nightly.20251202.2d935b379.tgz +0 -0
- package/dist/src/code_assist/oauth2.d.ts +2 -0
- package/dist/src/code_assist/oauth2.js +28 -12
- package/dist/src/code_assist/oauth2.js.map +1 -1
- package/dist/src/code_assist/oauth2.test.js +40 -2
- package/dist/src/code_assist/oauth2.test.js.map +1 -1
- package/dist/src/commands/restore.d.ts +19 -0
- package/dist/src/commands/restore.js +45 -0
- package/dist/src/commands/restore.js.map +1 -0
- package/dist/src/commands/restore.test.d.ts +6 -0
- package/dist/src/commands/restore.test.js +136 -0
- package/dist/src/commands/restore.test.js.map +1 -0
- package/dist/src/commands/types.d.ts +41 -0
- package/dist/src/commands/types.js +7 -0
- package/dist/src/commands/types.js.map +1 -0
- package/dist/src/config/config.d.ts +17 -2
- package/dist/src/config/config.js +28 -0
- package/dist/src/config/config.js.map +1 -1
- package/dist/src/core/client.js +2 -1
- package/dist/src/core/client.js.map +1 -1
- package/dist/src/core/client.test.js +23 -0
- package/dist/src/core/client.test.js.map +1 -1
- package/dist/src/core/geminiChat.test.js +4 -0
- package/dist/src/core/geminiChat.test.js.map +1 -1
- package/dist/src/core/sessionHookTriggers.d.ts +28 -0
- package/dist/src/core/sessionHookTriggers.js +68 -0
- package/dist/src/core/sessionHookTriggers.js.map +1 -0
- package/dist/src/generated/git-commit.d.ts +2 -2
- package/dist/src/generated/git-commit.js +2 -2
- package/dist/src/hooks/hookEventHandler.js +51 -0
- package/dist/src/hooks/hookEventHandler.js.map +1 -1
- package/dist/src/hooks/hookRegistry.js +8 -1
- package/dist/src/hooks/hookRegistry.js.map +1 -1
- package/dist/src/hooks/hookRegistry.test.js +1 -0
- package/dist/src/hooks/hookRegistry.test.js.map +1 -1
- package/dist/src/hooks/hookRunner.js +12 -2
- package/dist/src/hooks/hookRunner.js.map +1 -1
- package/dist/src/hooks/hookSystem.test.js +124 -0
- package/dist/src/hooks/hookSystem.test.js.map +1 -1
- package/dist/src/hooks/index.d.ts +3 -1
- package/dist/src/hooks/index.js +3 -0
- package/dist/src/hooks/index.js.map +1 -1
- package/dist/src/hooks/types.d.ts +1 -2
- package/dist/src/hooks/types.js +0 -1
- package/dist/src/hooks/types.js.map +1 -1
- package/dist/src/index.d.ts +2 -0
- package/dist/src/index.js +2 -0
- package/dist/src/index.js.map +1 -1
- package/dist/src/output/json-formatter.d.ts +2 -2
- package/dist/src/output/json-formatter.js +6 -3
- package/dist/src/output/json-formatter.js.map +1 -1
- package/dist/src/output/json-formatter.test.js +35 -9
- package/dist/src/output/json-formatter.test.js.map +1 -1
- package/dist/src/output/types.d.ts +1 -0
- package/dist/src/output/types.js.map +1 -1
- package/dist/src/services/chatCompressionService.js +12 -0
- package/dist/src/services/chatCompressionService.js.map +1 -1
- package/dist/src/services/chatCompressionService.test.js +2 -0
- package/dist/src/services/chatCompressionService.test.js.map +1 -1
- package/dist/src/services/shellExecutionService.js +5 -18
- package/dist/src/services/shellExecutionService.js.map +1 -1
- package/dist/src/services/shellExecutionService.test.js +29 -2
- package/dist/src/services/shellExecutionService.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.d.ts +1 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js +20 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js +49 -0
- package/dist/src/telemetry/clearcut-logger/clearcut-logger.test.js.map +1 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.d.ts +1 -0
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js +3 -1
- package/dist/src/telemetry/clearcut-logger/event-metadata-key.js.map +1 -1
- package/dist/src/telemetry/config.js +2 -0
- package/dist/src/telemetry/config.js.map +1 -1
- package/dist/src/telemetry/config.test.js +25 -0
- package/dist/src/telemetry/config.test.js.map +1 -1
- package/dist/src/telemetry/gcp-exporters.d.ts +4 -3
- package/dist/src/telemetry/gcp-exporters.js +7 -4
- package/dist/src/telemetry/gcp-exporters.js.map +1 -1
- package/dist/src/telemetry/index.d.ts +1 -1
- package/dist/src/telemetry/index.js +1 -1
- package/dist/src/telemetry/index.js.map +1 -1
- package/dist/src/telemetry/loggers.js +335 -335
- package/dist/src/telemetry/loggers.js.map +1 -1
- package/dist/src/telemetry/loggers.test.js +15 -0
- package/dist/src/telemetry/loggers.test.js.map +1 -1
- package/dist/src/telemetry/sdk.d.ts +9 -2
- package/dist/src/telemetry/sdk.js +126 -16
- package/dist/src/telemetry/sdk.js.map +1 -1
- package/dist/src/telemetry/sdk.test.js +111 -28
- package/dist/src/telemetry/sdk.test.js.map +1 -1
- package/dist/src/telemetry/startupProfiler.test.js +4 -0
- package/dist/src/telemetry/startupProfiler.test.js.map +1 -1
- package/dist/src/telemetry/telemetry.test.js +10 -3
- package/dist/src/telemetry/telemetry.test.js.map +1 -1
- package/dist/src/tools/mcp-client-manager.js +15 -4
- package/dist/src/tools/mcp-client-manager.js.map +1 -1
- package/dist/src/tools/mcp-client.d.ts +17 -2
- package/dist/src/tools/mcp-client.js +319 -166
- package/dist/src/tools/mcp-client.js.map +1 -1
- package/dist/src/tools/mcp-client.test.js +466 -26
- package/dist/src/tools/mcp-client.test.js.map +1 -1
- package/dist/src/tools/modifiable-tool.test.js +22 -13
- package/dist/src/tools/modifiable-tool.test.js.map +1 -1
- package/dist/src/utils/debugLogger.d.ts +3 -0
- package/dist/src/utils/debugLogger.js +27 -0
- package/dist/src/utils/debugLogger.js.map +1 -1
- package/dist/src/utils/editCorrector.test.js +4 -0
- package/dist/src/utils/editCorrector.test.js.map +1 -1
- package/dist/src/utils/editor.d.ts +9 -1
- package/dist/src/utils/editor.js +23 -14
- package/dist/src/utils/editor.js.map +1 -1
- package/dist/src/utils/errors.d.ts +8 -0
- package/dist/src/utils/errors.js +32 -0
- package/dist/src/utils/errors.js.map +1 -1
- package/dist/src/utils/errors.test.d.ts +6 -0
- package/dist/src/utils/errors.test.js +36 -0
- package/dist/src/utils/errors.test.js.map +1 -0
- package/dist/src/utils/nextSpeakerChecker.test.js +4 -0
- package/dist/src/utils/nextSpeakerChecker.test.js.map +1 -1
- package/dist/src/utils/retry.js +38 -5
- package/dist/src/utils/retry.js.map +1 -1
- package/dist/src/utils/retry.test.js +35 -4
- package/dist/src/utils/retry.test.js.map +1 -1
- package/dist/src/utils/terminalSerializer.test.js +17 -0
- package/dist/src/utils/terminalSerializer.test.js.map +1 -1
- package/dist/tsconfig.tsbuildinfo +1 -1
- 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 {
|
|
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
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
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
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
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
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
}
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
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
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
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
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
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
|
-
|
|
104
|
-
|
|
105
|
-
|
|
106
|
-
|
|
107
|
-
|
|
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
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
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
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
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
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
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
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
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
|
-
|
|
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
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
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
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
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
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
223
|
-
|
|
224
|
-
|
|
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
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
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
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
|
|
245
|
-
|
|
246
|
-
|
|
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
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
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
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
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
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
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
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
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
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
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
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
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
|
-
|
|
334
|
-
|
|
335
|
-
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
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
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
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
|
-
|
|
357
|
-
|
|
358
|
-
|
|
359
|
-
|
|
360
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
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
|
-
|
|
368
|
-
|
|
369
|
-
|
|
370
|
-
|
|
371
|
-
|
|
372
|
-
|
|
373
|
-
|
|
374
|
-
|
|
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
|
-
|
|
379
|
-
|
|
380
|
-
|
|
381
|
-
|
|
382
|
-
|
|
383
|
-
|
|
384
|
-
|
|
385
|
-
|
|
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
|
-
|
|
390
|
-
|
|
391
|
-
|
|
392
|
-
|
|
393
|
-
|
|
394
|
-
|
|
395
|
-
|
|
396
|
-
|
|
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
|
-
|
|
401
|
-
|
|
402
|
-
|
|
403
|
-
|
|
404
|
-
|
|
405
|
-
|
|
406
|
-
|
|
407
|
-
|
|
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
|
-
|
|
412
|
-
|
|
413
|
-
|
|
414
|
-
|
|
415
|
-
|
|
416
|
-
|
|
417
|
-
|
|
418
|
-
|
|
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
|
-
|
|
423
|
-
|
|
424
|
-
|
|
425
|
-
|
|
426
|
-
|
|
427
|
-
|
|
428
|
-
|
|
429
|
-
|
|
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
|
-
|
|
434
|
-
|
|
435
|
-
|
|
436
|
-
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
440
|
-
|
|
441
|
-
|
|
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
|
-
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
449
|
-
|
|
450
|
-
|
|
451
|
-
|
|
452
|
-
|
|
453
|
-
|
|
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
|
-
|
|
458
|
-
|
|
459
|
-
|
|
460
|
-
|
|
461
|
-
|
|
462
|
-
|
|
463
|
-
|
|
464
|
-
|
|
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
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
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
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
|
|
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
|