@jsonstudio/rcc 0.90.190 → 0.90.247
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/build-info.js +2 -2
- package/dist/modules/pipeline/utils/colored-logger.d.ts +5 -6
- package/dist/modules/pipeline/utils/colored-logger.js +21 -27
- package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
- package/dist/modules/pipeline/utils/debug-logger.d.ts +5 -5
- package/dist/modules/pipeline/utils/debug-logger.js +75 -55
- package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
- package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js +3 -13
- package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js.map +1 -1
- package/dist/server/handlers/handler-response-utils.js +50 -2
- package/dist/server/handlers/handler-response-utils.js.map +1 -1
- package/dist/server/handlers/handler-utils.js +10 -4
- package/dist/server/handlers/handler-utils.js.map +1 -1
- package/dist/server/handlers/logging.js +6 -7
- package/dist/server/handlers/logging.js.map +1 -1
- package/dist/server/handlers/types.d.ts +8 -0
- package/dist/server/runtime/http-server/colored-logger.js +1 -1
- package/dist/server/runtime/http-server/colored-logger.js.map +1 -1
- package/dist/server/runtime/http-server/executor/provider-response-converter.js +81 -0
- package/dist/server/runtime/http-server/executor/provider-response-converter.js.map +1 -1
- package/dist/server/runtime/http-server/executor/usage-logger.d.ts +4 -0
- package/dist/server/runtime/http-server/executor/usage-logger.js +19 -2
- package/dist/server/runtime/http-server/executor/usage-logger.js.map +1 -1
- package/dist/server/runtime/http-server/http-server-runtime-setup.js +4 -3
- package/dist/server/runtime/http-server/http-server-runtime-setup.js.map +1 -1
- package/dist/server/runtime/http-server/request-executor.js +158 -8
- package/dist/server/runtime/http-server/request-executor.js.map +1 -1
- package/dist/server/runtime/http-server/stage-timing-defaults.d.ts +2 -0
- package/dist/server/runtime/http-server/stage-timing-defaults.js +17 -0
- package/dist/server/runtime/http-server/stage-timing-defaults.js.map +1 -0
- package/dist/server/utils/request-id-manager.js +2 -0
- package/dist/server/utils/request-id-manager.js.map +1 -1
- package/dist/server/utils/request-log-color.d.ts +13 -0
- package/dist/server/utils/request-log-color.js +97 -0
- package/dist/server/utils/request-log-color.js.map +1 -0
- package/dist/server/utils/stage-logger.d.ts +5 -0
- package/dist/server/utils/stage-logger.js +299 -8
- package/dist/server/utils/stage-logger.js.map +1 -1
- package/dist/utils/session-log-color.d.ts +1 -0
- package/dist/utils/session-log-color.js +29 -0
- package/dist/utils/session-log-color.js.map +1 -0
- package/dist/utils/snapshot-writer.js +11 -2
- package/dist/utils/snapshot-writer.js.map +1 -1
- package/package.json +2 -2
- package/scripts/install-global.sh +3 -3
|
@@ -1,11 +1,13 @@
|
|
|
1
1
|
import { Readable, PassThrough } from 'node:stream';
|
|
2
|
-
import { logPipelineStage } from '../utils/stage-logger.js';
|
|
2
|
+
import { formatRequestTimingSummary, logPipelineStage } from '../utils/stage-logger.js';
|
|
3
|
+
import { logUsageSummary } from '../runtime/http-server/executor/usage-logger.js';
|
|
3
4
|
import { DEFAULT_TIMEOUTS } from '../../constants/index.js';
|
|
4
5
|
import { stripInternalKeysDeep } from '../../utils/strip-internal-keys.js';
|
|
5
6
|
import { isSnapshotsEnabled, writeServerSnapshot } from '../../utils/snapshot-writer.js';
|
|
6
7
|
import { resolveEffectiveRequestId } from '../utils/request-id-manager.js';
|
|
7
8
|
import { buildInfo } from '../../build-info.js';
|
|
8
9
|
import { deriveFinishReason, STREAM_LOG_FINISH_REASON_KEY } from '../utils/finish-reason.js';
|
|
10
|
+
import { colorizeRequestLog } from '../utils/request-log-color.js';
|
|
9
11
|
const BLOCKED_HEADERS = new Set(['content-length', 'transfer-encoding', 'connection', 'content-encoding']);
|
|
10
12
|
const SHOULD_LOG_HTTP_EVENTS = buildInfo.mode !== 'release'
|
|
11
13
|
|| process.env.ROUTECODEX_HTTP_LOG_VERBOSE === '1';
|
|
@@ -22,7 +24,9 @@ function logStreamRequestComplete(endpoint, requestLabel, status, finishReason)
|
|
|
22
24
|
}
|
|
23
25
|
const targetEndpoint = endpoint && endpoint.trim() ? endpoint.trim() : '/unknown';
|
|
24
26
|
const finishReasonLabel = finishReason ? `, finish_reason=${finishReason}` : '';
|
|
25
|
-
|
|
27
|
+
const timingSuffix = formatRequestTimingSummary(requestLabel);
|
|
28
|
+
const line = `✅ [${targetEndpoint}] ${formatTimestamp()} request ${requestLabel} completed (status=${status}${finishReasonLabel})${timingSuffix}`;
|
|
29
|
+
console.log(colorizeRequestLog(line, requestLabel));
|
|
26
30
|
}
|
|
27
31
|
function trackSseFinishReason(tracker, chunk) {
|
|
28
32
|
const text = extractChunkText(chunk);
|
|
@@ -141,8 +145,42 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
141
145
|
? options.entryEndpoint.trim()
|
|
142
146
|
: undefined;
|
|
143
147
|
const captureClientResponse = shouldCaptureClientStreamSnapshots();
|
|
148
|
+
const responseStartedAtMs = Date.now();
|
|
149
|
+
let responseCompletedLogged = false;
|
|
150
|
+
const logResponseCompleted = (details) => {
|
|
151
|
+
if (responseCompletedLogged) {
|
|
152
|
+
return;
|
|
153
|
+
}
|
|
154
|
+
responseCompletedLogged = true;
|
|
155
|
+
const elapsedMs = Date.now() - responseStartedAtMs;
|
|
156
|
+
logPipelineStage('response.completed', requestLabel, {
|
|
157
|
+
elapsedMs,
|
|
158
|
+
...(details ?? {})
|
|
159
|
+
});
|
|
160
|
+
const usageLogInfo = result.usageLogInfo;
|
|
161
|
+
if (usageLogInfo) {
|
|
162
|
+
logPipelineStage('request.usage_log.start', requestLabel, {
|
|
163
|
+
providerKey: usageLogInfo.providerKey
|
|
164
|
+
});
|
|
165
|
+
logUsageSummary(requestLabel, {
|
|
166
|
+
providerKey: usageLogInfo.providerKey,
|
|
167
|
+
model: usageLogInfo.model,
|
|
168
|
+
usage: usageLogInfo.usage,
|
|
169
|
+
latencyMs: Date.now() - usageLogInfo.requestStartedAtMs,
|
|
170
|
+
sessionId: usageLogInfo.sessionId,
|
|
171
|
+
conversationId: usageLogInfo.conversationId
|
|
172
|
+
});
|
|
173
|
+
logPipelineStage('request.usage_log.completed', requestLabel, {
|
|
174
|
+
providerKey: usageLogInfo.providerKey
|
|
175
|
+
});
|
|
176
|
+
formatRequestTimingSummary(requestLabel, { terminal: true });
|
|
177
|
+
return;
|
|
178
|
+
}
|
|
179
|
+
formatRequestTimingSummary(requestLabel, { terminal: true });
|
|
180
|
+
};
|
|
144
181
|
if (forceSSE && !expectsStream) {
|
|
145
182
|
logPipelineStage('response.sse.missing', requestLabel, { status });
|
|
183
|
+
logResponseCompleted({ status: 502, mode: 'sse', reason: 'missing_stream' });
|
|
146
184
|
if (captureClientResponse) {
|
|
147
185
|
void writeServerSnapshot({
|
|
148
186
|
phase: 'client-response.error',
|
|
@@ -160,6 +198,7 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
160
198
|
const stream = toNodeReadable(streamSource);
|
|
161
199
|
if (!stream) {
|
|
162
200
|
logPipelineStage('response.sse.missing', requestLabel, {});
|
|
201
|
+
logResponseCompleted({ status: 502, mode: 'sse', reason: 'missing_stream' });
|
|
163
202
|
if (captureClientResponse) {
|
|
164
203
|
void writeServerSnapshot({
|
|
165
204
|
phase: 'client-response.error',
|
|
@@ -195,6 +234,7 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
195
234
|
let eventCount = 0;
|
|
196
235
|
let ended = false;
|
|
197
236
|
let completedLogged = false;
|
|
237
|
+
let cleanupLogged = false;
|
|
198
238
|
const finishTracker = {
|
|
199
239
|
buffer: '',
|
|
200
240
|
finishReason: body && typeof body === 'object' && typeof body[STREAM_LOG_FINISH_REASON_KEY] === 'string'
|
|
@@ -298,6 +338,10 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
298
338
|
keepaliveTimer.unref?.();
|
|
299
339
|
}
|
|
300
340
|
const cleanup = () => {
|
|
341
|
+
if (cleanupLogged) {
|
|
342
|
+
return;
|
|
343
|
+
}
|
|
344
|
+
cleanupLogged = true;
|
|
301
345
|
clearTimers();
|
|
302
346
|
try {
|
|
303
347
|
stream.destroy?.();
|
|
@@ -306,11 +350,13 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
306
350
|
/* ignore cleanup errors */
|
|
307
351
|
}
|
|
308
352
|
logPipelineStage('response.sse.stream.end', requestLabel, { events: eventCount, status });
|
|
353
|
+
logResponseCompleted({ status, mode: 'sse', events: eventCount });
|
|
309
354
|
};
|
|
310
355
|
stream.on('error', (error) => {
|
|
311
356
|
ended = true;
|
|
312
357
|
clearTimers();
|
|
313
358
|
logPipelineStage('response.sse.stream.error', requestLabel, { message: error.message });
|
|
359
|
+
logResponseCompleted({ status: 500, mode: 'sse', reason: 'stream_error' });
|
|
314
360
|
try {
|
|
315
361
|
const payload = {
|
|
316
362
|
type: 'error',
|
|
@@ -364,6 +410,7 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
364
410
|
}
|
|
365
411
|
res.status(status).end();
|
|
366
412
|
logPipelineStage('response.json.completed', requestLabel, { status });
|
|
413
|
+
logResponseCompleted({ status, mode: 'json', empty: true });
|
|
367
414
|
return;
|
|
368
415
|
}
|
|
369
416
|
logPipelineStage('response.json.write', requestLabel, { status });
|
|
@@ -380,6 +427,7 @@ export function sendPipelineResponse(res, result, requestId, options) {
|
|
|
380
427
|
}
|
|
381
428
|
res.status(status).json(sanitized);
|
|
382
429
|
logPipelineStage('response.json.completed', requestLabel, { status });
|
|
430
|
+
logResponseCompleted({ status, mode: 'json' });
|
|
383
431
|
}
|
|
384
432
|
function applyHeaders(res, headers, omitContentType) {
|
|
385
433
|
if (!headers) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-response-utils.js","sourceRoot":"","sources":["../../../src/server/handlers/handler-response-utils.ts"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"handler-response-utils.js","sourceRoot":"","sources":["../../../src/server/handlers/handler-response-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -4,8 +4,10 @@ import { buildInfo } from '../../build-info.js';
|
|
|
4
4
|
import { reportRouteError } from '../../error-handling/route-error-hub.js';
|
|
5
5
|
// import { runtimeFlags } from '../../runtime/runtime-flags.js';
|
|
6
6
|
import { formatErrorForConsole } from '../../utils/log-helpers.js';
|
|
7
|
+
import { colorizeRequestLog } from '../utils/request-log-color.js';
|
|
7
8
|
import { deriveFinishReason } from '../utils/finish-reason.js';
|
|
8
9
|
import { isSnapshotsEnabled, writeServerSnapshot } from '../../utils/snapshot-writer.js';
|
|
10
|
+
import { formatRequestTimingSummary } from '../utils/stage-logger.js';
|
|
9
11
|
import { generateRequestIdentifiers, resolveEffectiveRequestId } from '../utils/request-id-manager.js';
|
|
10
12
|
export { hasSsePayload, sendPipelineResponse } from './handler-response-utils.js';
|
|
11
13
|
const CLIENT_HEADER_DENYLIST = new Set([
|
|
@@ -72,16 +74,19 @@ export function logRequestComplete(endpoint, requestId, status, body) {
|
|
|
72
74
|
const timestamp = formatTimestamp();
|
|
73
75
|
const finishReason = deriveFinishReason(body);
|
|
74
76
|
const finishReasonLabel = finishReason ? `, finish_reason=${finishReason}` : '';
|
|
75
|
-
|
|
77
|
+
const timingSuffix = formatRequestTimingSummary(resolvedId, { terminal: true });
|
|
78
|
+
const line = `✅ [${endpoint}] ${timestamp} request ${resolvedId} completed (status=${status}${finishReasonLabel})${timingSuffix}`;
|
|
79
|
+
console.log(colorizeRequestLog(line, resolvedId));
|
|
76
80
|
}
|
|
77
81
|
export function logRequestError(endpoint, requestId, error) {
|
|
78
82
|
const resolvedId = formatRequestId(requestId);
|
|
79
83
|
const formatted = formatErrorForConsole(error);
|
|
80
84
|
const rawMeta = extractRawErrorMeta(error);
|
|
81
85
|
const summary = rawMeta?.rawErrorSnippet ?? formatted.text;
|
|
82
|
-
const chalkError = typeof chalk?.redBright === 'function' ? chalk.redBright : (value) => value;
|
|
83
86
|
const timestamp = formatTimestamp();
|
|
84
|
-
|
|
87
|
+
const timingSuffix = formatRequestTimingSummary(resolvedId, { terminal: true });
|
|
88
|
+
const line = `❌ [${endpoint}] ${timestamp} request ${resolvedId} failed: ${summary}${timingSuffix}`;
|
|
89
|
+
console.error(colorizeRequestLog(line, resolvedId) || line);
|
|
85
90
|
if (rawMeta && shouldLogHttpErrorMeta()) {
|
|
86
91
|
const payload = {
|
|
87
92
|
requestId: resolvedId,
|
|
@@ -89,7 +94,8 @@ export function logRequestError(endpoint, requestId, error) {
|
|
|
89
94
|
rawError: rawMeta.rawError,
|
|
90
95
|
rawErrorSnippet: rawMeta.rawErrorSnippet ?? summary
|
|
91
96
|
};
|
|
92
|
-
|
|
97
|
+
const metaLine = `[http.error.meta] ${JSON.stringify(payload)}`;
|
|
98
|
+
console.error(colorizeRequestLog(metaLine, resolvedId) || metaLine);
|
|
93
99
|
}
|
|
94
100
|
}
|
|
95
101
|
function extractRawErrorMeta(error) {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"handler-utils.js","sourceRoot":"","sources":["../../../src/server/handlers/handler-utils.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,cAAc,EAAE,MAAM,+BAA+B,CAAC;AAC/D,OAAO,EAAE,SAAS,EAAE,MAAM,qBAAqB,CAAC;AAEhD,OAAO,EAAE,gBAAgB,EAAE,MAAM,yCAAyC,CAAC;AAC3E,iEAAiE;AACjE,OAAO,EAAE,qBAAqB,EAAE,MAAM,4BAA4B,CAAC;AACnE,OAAO,EAAE,kBAAkB,EAAE,MAAM,2BAA2B,CAAC;AAC/D,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,EAAE,MAAM,gCAAgC,CAAC;AACzF,OAAO,EACL,0BAA0B,EAC1B,yBAAyB,EAC1B,MAAM,gCAAgC,CAAC;AACxC,OAAO,EAAE,aAAa,EAAE,oBAAoB,EAAwB,MAAM,6BAA6B,CAAC;AAExG,MAAM,sBAAsB,GAAG,IAAI,GAAG,CAAC;IACrC,MAAM;IACN,YAAY;IACZ,gBAAgB;IAChB,iBAAiB;IACjB,eAAe;IACf,qBAAqB;IACrB,WAAW;IACX,sBAAsB;IACtB,qBAAqB;IACrB,SAAS;IACT,QAAQ;IACR,SAAS;IACT,IAAI;CACL,CAAC,CAAC;AAIH,MAAM,sBAAsB,GAAG,SAAS,CAAC,IAAI,KAAK,SAAS;OACtD,OAAO,CAAC,GAAG,CAAC,2BAA2B,KAAK,GAAG,CAAC;AAErD,SAAS,kBAAkB,CAAC,KAAyB,EAAE,QAAiB;IACtE,IAAI,CAAC,KAAK,EAAE,CAAC;QACX,OAAO,QAAQ,CAAC;IAClB,CAAC;IACD,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC,WAAW,EAAE,CAAC;IAC9C,IAAI,UAAU,KAAK,GAAG,IAAI,UAAU,KAAK,MAAM,IAAI,UAAU,KAAK,KAAK,IAAI,UAAU,KAAK,IAAI,EAAE,CAAC;QAC/F,OAAO,IAAI,CAAC;IACd,CAAC;IACD,IAAI,UAAU,KAAK,GAAG,IAAI,UAAU,KAAK,OAAO,IAAI,UAAU,KAAK,IAAI,IAAI,UAAU,KAAK,KAAK,EAAE,CAAC;QAChG,OAAO,KAAK,CAAC;IACf,CAAC;IACD,OAAO,QAAQ,CAAC;AAClB,CAAC;AAED,SAAS,sBAAsB;IAC7B,OAAO,kBAAkB,CACvB,OAAO,CAAC,GAAG,CAAC,8BAA8B;WACrC,OAAO,CAAC,GAAG,CAAC,uBAAuB;WACnC,OAAO,CAAC,GAAG,CAAC,wBAAwB;WACpC,OAAO,CAAC,GAAG,CAAC,iBAAiB,EAClC,KAAK,CACN,CAAC;AACJ,CAAC;AAED,SAAS,eAAe,CAAC,KAAc;IACrC,OAAO,yBAAyB,CAAC,KAAK,CAAC,CAAC;AAC1C,CAAC;AAED,SAAS,eAAe;IACtB,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,KAAK,GAAG,MAAM,CAAC,GAAG,CAAC,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IACtD,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC1D,MAAM,OAAO,GAAG,MAAM,CAAC,GAAG,CAAC,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;IAC1D,OAAO,GAAG,KAAK,IAAI,OAAO,IAAI,OAAO,EAAE,CAAC;AAC1C,CAAC;AAED,MAAM,UAAU,sBAAsB,CACpC,SAAmB,EACnB,IAAsE;IAEtE,OAAO,0BAA0B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;AACrD,CAAC;AAED,MAAM,UAAU,aAAa,CAC3B,SAAmB,EACnB,IAAsE;IAEtE,OAAO,0BAA0B,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC,iBAAiB,CAAC;AACvE,CAAC;AAED,MAAM,UAAU,eAAe,CAAC,QAAgB,EAAE,SAAiB,EAAE,IAAqB;IACxF,wEAAwE;IACxE,OAAO;AACT,CAAC;AAED,MAAM,UAAU,kBAAkB,CAAC,QAAgB,EAAE,SAAiB,EAAE,MAAc,EAAE,IAAc;IACpG,IAAI,CAAC,sBAAsB,EAAE,CAAC;QAC5B,OAAO;IACT,CAAC;IACD,MAAM,UAAU,GAAG,eAAe,CAAC,SAAS,CAAC,CAAC;IAC9C,MAAM,SAAS,GAAG,eAAe,EAAE,CAAC;IACpC,MAAM,YAAY,GAAG,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAC9C,MAAM,iBAAiB,GAAG,YAAY,CAAC,CAAC,CAAC,mBAAmB,YAAY,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC;IAChF,
|
|
1
|
+
{"version":3,"file":"handler-utils.js","sourceRoot":"","sources":["../../../src/server/handlers/handler-utils.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +1,5 @@
|
|
|
1
|
-
import chalk from 'chalk';
|
|
2
1
|
import { resolveEffectiveRequestId } from '../utils/request-id-manager.js';
|
|
3
|
-
|
|
4
|
-
const chalkError = typeof chalk?.redBright === 'function' ? chalk.redBright : (value) => value;
|
|
2
|
+
import { colorizeRequestLog } from '../utils/request-log-color.js';
|
|
5
3
|
export function logRequestStart(endpoint, requestId, meta) {
|
|
6
4
|
void endpoint;
|
|
7
5
|
void requestId;
|
|
@@ -10,19 +8,20 @@ export function logRequestStart(endpoint, requestId, meta) {
|
|
|
10
8
|
export function logRequestComplete(endpoint, requestId, status, meta) {
|
|
11
9
|
const suffix = formatMeta(meta);
|
|
12
10
|
const label = deriveRequestLabel(requestId, meta);
|
|
13
|
-
const
|
|
11
|
+
const prefix = status >= 400 ? '❌' : '✅';
|
|
12
|
+
const text = `${prefix} [${endpoint}] request ${label} completed (status=${status})${suffix}`;
|
|
14
13
|
if (status >= 400) {
|
|
15
|
-
console.error(
|
|
14
|
+
console.error(colorizeRequestLog(text, label));
|
|
16
15
|
return;
|
|
17
16
|
}
|
|
18
|
-
console.log(
|
|
17
|
+
console.log(colorizeRequestLog(text, label));
|
|
19
18
|
}
|
|
20
19
|
export function logRequestError(endpoint, requestId, error, meta) {
|
|
21
20
|
const resolvedId = deriveRequestLabel(requestId, meta);
|
|
22
21
|
const message = error instanceof Error ? error.message : String(error ?? 'Unknown error');
|
|
23
22
|
const suffix = formatMeta(meta);
|
|
24
23
|
const text = `❌ [${endpoint}] request ${resolvedId} failed: ${message}${suffix}`;
|
|
25
|
-
console.error(
|
|
24
|
+
console.error(colorizeRequestLog(text, resolvedId));
|
|
26
25
|
}
|
|
27
26
|
const HIDDEN_META_KEYS = new Set([
|
|
28
27
|
'internalRequestId',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/server/handlers/logging.ts"],"names":[],"mappings":"AAAA,OAAO,
|
|
1
|
+
{"version":3,"file":"logging.js","sourceRoot":"","sources":["../../../src/server/handlers/logging.ts"],"names":[],"mappings":"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"}
|
|
@@ -13,6 +13,14 @@ export interface PipelineExecutionResult {
|
|
|
13
13
|
status?: number;
|
|
14
14
|
headers?: Record<string, string>;
|
|
15
15
|
body?: unknown;
|
|
16
|
+
usageLogInfo?: {
|
|
17
|
+
providerKey?: string;
|
|
18
|
+
model?: string;
|
|
19
|
+
usage?: Record<string, unknown>;
|
|
20
|
+
requestStartedAtMs: number;
|
|
21
|
+
sessionId?: unknown;
|
|
22
|
+
conversationId?: unknown;
|
|
23
|
+
};
|
|
16
24
|
}
|
|
17
25
|
export interface HandlerContext {
|
|
18
26
|
executePipeline: ((input: PipelineExecutionInput) => Promise<PipelineExecutionResult>) | null;
|
|
@@ -4,7 +4,7 @@ import { createRequire } from 'module';
|
|
|
4
4
|
// modules/ tree using a module-local require,避免依赖全局 require 造成路径错误。
|
|
5
5
|
const localRequire = createRequire(import.meta.url);
|
|
6
6
|
export function createServerColoredLogger() {
|
|
7
|
-
const isDev =
|
|
7
|
+
const isDev = true;
|
|
8
8
|
try {
|
|
9
9
|
// In test environment (jest), we cannot use localRequire to load ESM modules
|
|
10
10
|
// Fallback to static import if possible or return dummy logger for tests
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"colored-logger.js","sourceRoot":"","sources":["../../../../src/server/runtime/http-server/colored-logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAEvC,kFAAkF;AAClF,8EAA8E;AAC9E,oEAAoE;AAEpE,MAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAEpD,MAAM,UAAU,yBAAyB;IACvC,MAAM,KAAK,GAAG,
|
|
1
|
+
{"version":3,"file":"colored-logger.js","sourceRoot":"","sources":["../../../../src/server/runtime/http-server/colored-logger.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,aAAa,EAAE,MAAM,QAAQ,CAAC;AAEvC,kFAAkF;AAClF,8EAA8E;AAC9E,oEAAoE;AAEpE,MAAM,YAAY,GAAG,aAAa,CAAC,MAAM,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;AAEpD,MAAM,UAAU,yBAAyB;IACvC,MAAM,KAAK,GAAG,IAAI,CAAC;IAEnB,IAAI,CAAC;QACH,6EAA6E;QAC7E,yEAAyE;QACzE,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,MAAM,EAAE,CAAC;YACpC,OAAO;gBACL,GAAG,EAAE,GAAG,EAAE,GAAE,CAAC;gBACb,SAAS,EAAE,GAAG,EAAE,GAAE,CAAC;gBACnB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;gBAClB,kBAAkB,EAAE,GAAG,EAAE,GAAE,CAAC;gBAC5B,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;gBACd,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;aAChB,CAAC;QACJ,CAAC;QAED,8DAA8D;QAC9D,MAAM,GAAG,GAAG,YAAY,CAAC,mDAAmD,CAAC,CAAC;QAC9E,MAAM,SAAS,GAAG,GAA8B,CAAC;QACjD,MAAM,aAAa,GAAG,SAAS,CAAC,aAAa,IAAI,SAAS,CAAC,OAAO,IAAI,IAAI,CAAC;QAE3E,IAAI,OAAO,aAAa,KAAK,UAAU,EAAE,CAAC;YACxC,OAAO,IAAK,aAA8D,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;QACxF,CAAC;QAED,qGAAqG;QACrG,OAAO,CAAC,IAAI,CAAC,iHAAiH,CAAC,CAAC;IAClI,CAAC;IAAC,OAAO,GAAG,EAAE,CAAC;QACb,wEAAwE;QACxE,OAAO,CAAC,IAAI,CAAC,iHAAiH,EAAE,GAAG,CAAC,CAAC;IACvI,CAAC;IAED,yDAAyD;IACzD,OAAO;QACL,GAAG,EAAE,GAAG,EAAE,GAAE,CAAC;QACb,SAAS,EAAE,GAAG,EAAE,GAAE,CAAC;QACnB,QAAQ,EAAE,GAAG,EAAE,GAAE,CAAC;QAClB,kBAAkB,EAAE,GAAG,EAAE,GAAE,CAAC;QAC5B,IAAI,EAAE,GAAG,EAAE,GAAE,CAAC;QACd,KAAK,EAAE,GAAG,EAAE,GAAE,CAAC;KAChB,CAAC;AACJ,CAAC"}
|
|
@@ -8,6 +8,7 @@ import { extractSseWrapperError } from './sse-error-handler.js';
|
|
|
8
8
|
import { isRateLimitLikeError } from './request-retry-helpers.js';
|
|
9
9
|
import { extractUsageFromResult } from './usage-aggregator.js';
|
|
10
10
|
import { deriveFinishReason, STREAM_LOG_FINISH_REASON_KEY } from '../../../utils/finish-reason.js';
|
|
11
|
+
import { logPipelineStage } from '../../../utils/stage-logger.js';
|
|
11
12
|
const FOLLOWUP_SESSION_HEADER_KEYS = new Set([
|
|
12
13
|
'sessionid',
|
|
13
14
|
'conversationid',
|
|
@@ -236,10 +237,23 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
236
237
|
if (!serverToolsEnabled) {
|
|
237
238
|
adapterContext.serverToolsDisabled = true;
|
|
238
239
|
}
|
|
240
|
+
logPipelineStage('convert.snapshot_recorder.start', options.requestId, {
|
|
241
|
+
entryEndpoint: options.entryEndpoint || entry,
|
|
242
|
+
providerProtocol: options.providerProtocol
|
|
243
|
+
});
|
|
239
244
|
const stageRecorder = await bridgeCreateSnapshotRecorder(adapterContext, typeof adapterContext.entryEndpoint === 'string'
|
|
240
245
|
? adapterContext.entryEndpoint
|
|
241
246
|
: options.entryEndpoint || entry);
|
|
247
|
+
logPipelineStage('convert.snapshot_recorder.completed', options.requestId, {
|
|
248
|
+
entryEndpoint: options.entryEndpoint || entry,
|
|
249
|
+
providerProtocol: options.providerProtocol
|
|
250
|
+
});
|
|
242
251
|
const providerInvoker = async (invokeOptions) => {
|
|
252
|
+
logPipelineStage('convert.provider_invoke.start', invokeOptions.requestId, {
|
|
253
|
+
providerKey: invokeOptions.providerKey,
|
|
254
|
+
providerProtocol: invokeOptions.providerProtocol,
|
|
255
|
+
routeHint: invokeOptions.routeHint
|
|
256
|
+
});
|
|
243
257
|
if (invokeOptions.routeHint) {
|
|
244
258
|
const carrier = invokeOptions.payload;
|
|
245
259
|
const existingMeta = carrier.metadata && typeof carrier.metadata === 'object'
|
|
@@ -254,18 +268,42 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
254
268
|
if (!runtimeKey) {
|
|
255
269
|
throw new Error(`Runtime for provider ${invokeOptions.providerKey} not initialized`);
|
|
256
270
|
}
|
|
271
|
+
logPipelineStage('convert.provider_invoke.runtime_resolved', invokeOptions.requestId, {
|
|
272
|
+
providerKey: invokeOptions.providerKey,
|
|
273
|
+
runtimeKey
|
|
274
|
+
});
|
|
257
275
|
const handle = deps.runtimeManager.getHandleByRuntimeKey(runtimeKey);
|
|
258
276
|
if (!handle) {
|
|
259
277
|
throw new Error(`Provider runtime ${runtimeKey} not found`);
|
|
260
278
|
}
|
|
279
|
+
logPipelineStage('convert.provider_invoke.send.start', invokeOptions.requestId, {
|
|
280
|
+
providerKey: invokeOptions.providerKey,
|
|
281
|
+
runtimeKey
|
|
282
|
+
});
|
|
261
283
|
const providerResponse = await handle.instance.processIncoming(invokeOptions.payload);
|
|
284
|
+
logPipelineStage('convert.provider_invoke.send.completed', invokeOptions.requestId, {
|
|
285
|
+
providerKey: invokeOptions.providerKey,
|
|
286
|
+
runtimeKey
|
|
287
|
+
});
|
|
262
288
|
const normalized = normalizeProviderResponse(providerResponse);
|
|
289
|
+
logPipelineStage('convert.provider_invoke.normalize.completed', invokeOptions.requestId, {
|
|
290
|
+
providerKey: invokeOptions.providerKey,
|
|
291
|
+
runtimeKey,
|
|
292
|
+
status: normalized.status
|
|
293
|
+
});
|
|
263
294
|
const bodyPayload = normalized.body && typeof normalized.body === 'object'
|
|
264
295
|
? normalized.body
|
|
265
296
|
: normalized;
|
|
297
|
+
logPipelineStage('convert.provider_invoke.completed', invokeOptions.requestId, {
|
|
298
|
+
providerKey: invokeOptions.providerKey,
|
|
299
|
+
runtimeKey
|
|
300
|
+
});
|
|
266
301
|
return { providerResponse: bodyPayload };
|
|
267
302
|
};
|
|
268
303
|
const reenterPipeline = async (reenterOpts) => {
|
|
304
|
+
logPipelineStage('convert.reenter.start', reenterOpts.requestId, {
|
|
305
|
+
entryEndpoint: reenterOpts.entryEndpoint || options.entryEndpoint || entry
|
|
306
|
+
});
|
|
269
307
|
const nestedEntry = reenterOpts.entryEndpoint || options.entryEndpoint || entry;
|
|
270
308
|
const nestedExtra = asRecord(reenterOpts.metadata) ?? {};
|
|
271
309
|
const buildNestedMetadata = (extra, resolvedEntry) => {
|
|
@@ -309,12 +347,19 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
309
347
|
metadata: nestedMetadata
|
|
310
348
|
};
|
|
311
349
|
const nestedResult = await deps.executeNested(nestedInput);
|
|
350
|
+
logPipelineStage('convert.reenter.completed', reenterOpts.requestId, {
|
|
351
|
+
entryEndpoint: nestedEntry,
|
|
352
|
+
status: nestedResult.status
|
|
353
|
+
});
|
|
312
354
|
const nestedBody = nestedResult.body && typeof nestedResult.body === 'object'
|
|
313
355
|
? nestedResult.body
|
|
314
356
|
: undefined;
|
|
315
357
|
return { body: nestedBody };
|
|
316
358
|
};
|
|
317
359
|
const clientInjectDispatch = async (injectOpts) => {
|
|
360
|
+
logPipelineStage('convert.client_inject.start', injectOpts.requestId, {
|
|
361
|
+
entryEndpoint: injectOpts.entryEndpoint || options.entryEndpoint || entry
|
|
362
|
+
});
|
|
318
363
|
const nestedEntry = injectOpts.entryEndpoint || options.entryEndpoint || entry;
|
|
319
364
|
const nestedExtra = asRecord(injectOpts.metadata) ?? {};
|
|
320
365
|
const nestedMetadata = (() => {
|
|
@@ -356,10 +401,24 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
356
401
|
requestId: injectOpts.requestId
|
|
357
402
|
});
|
|
358
403
|
if (injectResult.clientInjectOnlyHandled) {
|
|
404
|
+
logPipelineStage('convert.client_inject.completed', injectOpts.requestId, {
|
|
405
|
+
entryEndpoint: nestedEntry,
|
|
406
|
+
handled: true
|
|
407
|
+
});
|
|
359
408
|
return { ok: true };
|
|
360
409
|
}
|
|
410
|
+
logPipelineStage('convert.client_inject.completed', injectOpts.requestId, {
|
|
411
|
+
entryEndpoint: nestedEntry,
|
|
412
|
+
handled: false,
|
|
413
|
+
reason: 'client_inject_not_handled'
|
|
414
|
+
});
|
|
361
415
|
return { ok: false, reason: 'client_inject_not_handled' };
|
|
362
416
|
};
|
|
417
|
+
logPipelineStage('convert.bridge.start', options.requestId, {
|
|
418
|
+
entryEndpoint: options.entryEndpoint || entry,
|
|
419
|
+
providerProtocol: options.providerProtocol,
|
|
420
|
+
wantsStream: options.wantsStream
|
|
421
|
+
});
|
|
363
422
|
const converted = await bridgeConvertProviderResponse({
|
|
364
423
|
providerProtocol: options.providerProtocol,
|
|
365
424
|
providerResponse: body,
|
|
@@ -372,11 +431,21 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
372
431
|
reenterPipeline: serverToolsEnabled ? reenterPipeline : undefined,
|
|
373
432
|
clientInjectDispatch: serverToolsEnabled ? clientInjectDispatch : undefined
|
|
374
433
|
});
|
|
434
|
+
logPipelineStage('convert.bridge.completed', options.requestId, {
|
|
435
|
+
entryEndpoint: options.entryEndpoint || entry,
|
|
436
|
+
providerProtocol: options.providerProtocol,
|
|
437
|
+
hasSse: Boolean(converted.__sse_responses),
|
|
438
|
+
hasBody: converted.body !== undefined && converted.body !== null
|
|
439
|
+
});
|
|
375
440
|
if (converted.__sse_responses) {
|
|
376
441
|
const usage = converted.body
|
|
377
442
|
? extractUsageFromResult({ body: converted.body })
|
|
378
443
|
: undefined;
|
|
379
444
|
const finishReason = deriveFinishReason(converted.body);
|
|
445
|
+
logPipelineStage('convert.sse_wrapper_detected', options.requestId, {
|
|
446
|
+
hasUsage: Boolean(usage),
|
|
447
|
+
finishReason
|
|
448
|
+
});
|
|
380
449
|
const body = { __sse_responses: converted.__sse_responses };
|
|
381
450
|
if (usage) {
|
|
382
451
|
body.usage = usage;
|
|
@@ -447,11 +516,23 @@ export async function convertProviderResponseIfNeeded(options, deps) {
|
|
|
447
516
|
return options.response;
|
|
448
517
|
}
|
|
449
518
|
}
|
|
519
|
+
logPipelineStage('convert.bridge.error', options.requestId, {
|
|
520
|
+
code: errCode,
|
|
521
|
+
upstreamCode: upstreamCode || detailUpstreamCode,
|
|
522
|
+
reason: detailReason,
|
|
523
|
+
message
|
|
524
|
+
});
|
|
450
525
|
if (isVerboseErrorLoggingEnabled()) {
|
|
451
526
|
console.error('[RequestExecutor] Fatal conversion error, bubbling as HTTP error', error);
|
|
452
527
|
}
|
|
453
528
|
throw error;
|
|
454
529
|
}
|
|
530
|
+
logPipelineStage('convert.bridge.error', options.requestId, {
|
|
531
|
+
code: errCode,
|
|
532
|
+
upstreamCode: upstreamCode || detailUpstreamCode,
|
|
533
|
+
reason: detailReason,
|
|
534
|
+
message
|
|
535
|
+
});
|
|
455
536
|
if (isVerboseErrorLoggingEnabled()) {
|
|
456
537
|
console.error('[RequestExecutor] Failed to convert provider response via llmswitch-core', error);
|
|
457
538
|
}
|