@jsonstudio/rcc 0.90.190 → 0.90.248

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 (47) hide show
  1. package/dist/build-info.js +2 -2
  2. package/dist/modules/pipeline/utils/colored-logger.d.ts +5 -6
  3. package/dist/modules/pipeline/utils/colored-logger.js +21 -27
  4. package/dist/modules/pipeline/utils/colored-logger.js.map +1 -1
  5. package/dist/modules/pipeline/utils/debug-logger.d.ts +5 -5
  6. package/dist/modules/pipeline/utils/debug-logger.js +75 -55
  7. package/dist/modules/pipeline/utils/debug-logger.js.map +1 -1
  8. package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js +3 -13
  9. package/dist/providers/core/runtime/vercel-ai-sdk/openai-sdk-transport.js.map +1 -1
  10. package/dist/server/handlers/handler-response-utils.js +50 -2
  11. package/dist/server/handlers/handler-response-utils.js.map +1 -1
  12. package/dist/server/handlers/handler-utils.js +10 -4
  13. package/dist/server/handlers/handler-utils.js.map +1 -1
  14. package/dist/server/handlers/logging.js +6 -7
  15. package/dist/server/handlers/logging.js.map +1 -1
  16. package/dist/server/handlers/types.d.ts +8 -0
  17. package/dist/server/runtime/http-server/colored-logger.js +1 -1
  18. package/dist/server/runtime/http-server/colored-logger.js.map +1 -1
  19. package/dist/server/runtime/http-server/executor/env-config.js +1 -2
  20. package/dist/server/runtime/http-server/executor/env-config.js.map +1 -1
  21. package/dist/server/runtime/http-server/executor/provider-response-converter.js +81 -0
  22. package/dist/server/runtime/http-server/executor/provider-response-converter.js.map +1 -1
  23. package/dist/server/runtime/http-server/executor/usage-logger.d.ts +4 -0
  24. package/dist/server/runtime/http-server/executor/usage-logger.js +19 -2
  25. package/dist/server/runtime/http-server/executor/usage-logger.js.map +1 -1
  26. package/dist/server/runtime/http-server/http-server-runtime-setup.js +4 -3
  27. package/dist/server/runtime/http-server/http-server-runtime-setup.js.map +1 -1
  28. package/dist/server/runtime/http-server/request-executor.js +158 -8
  29. package/dist/server/runtime/http-server/request-executor.js.map +1 -1
  30. package/dist/server/runtime/http-server/stage-timing-defaults.d.ts +2 -0
  31. package/dist/server/runtime/http-server/stage-timing-defaults.js +17 -0
  32. package/dist/server/runtime/http-server/stage-timing-defaults.js.map +1 -0
  33. package/dist/server/utils/request-id-manager.js +2 -0
  34. package/dist/server/utils/request-id-manager.js.map +1 -1
  35. package/dist/server/utils/request-log-color.d.ts +13 -0
  36. package/dist/server/utils/request-log-color.js +97 -0
  37. package/dist/server/utils/request-log-color.js.map +1 -0
  38. package/dist/server/utils/stage-logger.d.ts +5 -0
  39. package/dist/server/utils/stage-logger.js +299 -8
  40. package/dist/server/utils/stage-logger.js.map +1 -1
  41. package/dist/utils/session-log-color.d.ts +1 -0
  42. package/dist/utils/session-log-color.js +29 -0
  43. package/dist/utils/session-log-color.js.map +1 -0
  44. package/dist/utils/snapshot-writer.js +11 -2
  45. package/dist/utils/snapshot-writer.js.map +1 -1
  46. package/package.json +2 -2
  47. package/scripts/install-global.sh +3 -3
@@ -1 +1 @@
1
- {"version":3,"file":"request-id-manager.js","sourceRoot":"","sources":["../../../src/server/utils/request-id-manager.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"request-id-manager.js","sourceRoot":"","sources":["../../../src/server/utils/request-id-manager.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,13 @@
1
+ export declare function resolveSessionLogColor(sessionId?: string): string;
2
+ export declare function registerRequestLogContext(requestId: string | undefined, context?: {
3
+ sessionId?: unknown;
4
+ conversationId?: unknown;
5
+ }): void;
6
+ export declare function resolveRequestLogColorToken(requestId?: string, context?: {
7
+ sessionId?: unknown;
8
+ conversationId?: unknown;
9
+ }): string | undefined;
10
+ export declare function colorizeRequestLog(text: string, requestId?: string, context?: {
11
+ sessionId?: unknown;
12
+ conversationId?: unknown;
13
+ }): string;
@@ -0,0 +1,97 @@
1
+ import { resolveEffectiveRequestId } from './request-id-manager.js';
2
+ import { resolveSessionAnsiColor } from '../../utils/session-log-color.js';
3
+ const ANSI_RESET = '\x1b[0m';
4
+ const ANSI_PATTERN = /\x1b\[[0-9;]*m/;
5
+ const REQUEST_LOG_CONTEXT_TTL_MS = 30 * 60 * 1000;
6
+ const REQUEST_LOG_CONTEXT_MAX = 4096;
7
+ const REQUEST_LOG_CONTEXT = new Map();
8
+ function isConsoleColorEnabled() {
9
+ if (String(process.env.NO_COLOR || '').trim()) {
10
+ return false;
11
+ }
12
+ const forceColor = String(process.env.FORCE_COLOR || '').trim();
13
+ if (forceColor === '0') {
14
+ return false;
15
+ }
16
+ if (forceColor.length > 0) {
17
+ return true;
18
+ }
19
+ return process.stdout?.isTTY === true || process.stderr?.isTTY === true;
20
+ }
21
+ function normalizeToken(value) {
22
+ if (typeof value !== 'string') {
23
+ return undefined;
24
+ }
25
+ const trimmed = value.trim();
26
+ return trimmed || undefined;
27
+ }
28
+ function normalizeRequestKey(requestId) {
29
+ const resolved = normalizeToken(resolveEffectiveRequestId(requestId));
30
+ if (!resolved || resolved === 'unknown' || resolved.includes('-unknown-')) {
31
+ return undefined;
32
+ }
33
+ const delimiterIndex = resolved.indexOf(':');
34
+ return delimiterIndex >= 0 ? resolved.slice(0, delimiterIndex) : resolved;
35
+ }
36
+ function resolveSessionKey(context) {
37
+ return normalizeToken(context?.sessionId) || normalizeToken(context?.conversationId);
38
+ }
39
+ function pruneExpiredContext(nowMs) {
40
+ for (const [key, record] of REQUEST_LOG_CONTEXT.entries()) {
41
+ if (record.expiresAtMs <= nowMs) {
42
+ REQUEST_LOG_CONTEXT.delete(key);
43
+ }
44
+ }
45
+ while (REQUEST_LOG_CONTEXT.size > REQUEST_LOG_CONTEXT_MAX) {
46
+ const oldestKey = REQUEST_LOG_CONTEXT.keys().next().value;
47
+ if (!oldestKey) {
48
+ break;
49
+ }
50
+ REQUEST_LOG_CONTEXT.delete(oldestKey);
51
+ }
52
+ }
53
+ export function resolveSessionLogColor(sessionId) {
54
+ return resolveSessionAnsiColor(sessionId) || '\x1b[36m';
55
+ }
56
+ export function registerRequestLogContext(requestId, context) {
57
+ const requestKey = normalizeRequestKey(requestId);
58
+ const sessionKey = resolveSessionKey(context);
59
+ if (!requestKey || !sessionKey) {
60
+ return;
61
+ }
62
+ const nowMs = Date.now();
63
+ REQUEST_LOG_CONTEXT.set(requestKey, {
64
+ sessionKey,
65
+ expiresAtMs: nowMs + REQUEST_LOG_CONTEXT_TTL_MS
66
+ });
67
+ pruneExpiredContext(nowMs);
68
+ }
69
+ export function resolveRequestLogColorToken(requestId, context) {
70
+ const explicitSessionKey = resolveSessionKey(context);
71
+ if (explicitSessionKey) {
72
+ return resolveSessionAnsiColor(explicitSessionKey);
73
+ }
74
+ const requestKey = normalizeRequestKey(requestId);
75
+ if (!requestKey) {
76
+ return undefined;
77
+ }
78
+ const record = REQUEST_LOG_CONTEXT.get(requestKey);
79
+ if (record && record.expiresAtMs > Date.now()) {
80
+ return resolveSessionAnsiColor(record.sessionKey);
81
+ }
82
+ if (record) {
83
+ REQUEST_LOG_CONTEXT.delete(requestKey);
84
+ }
85
+ return resolveSessionAnsiColor(requestKey);
86
+ }
87
+ export function colorizeRequestLog(text, requestId, context) {
88
+ if (!text || !isConsoleColorEnabled() || ANSI_PATTERN.test(text)) {
89
+ return text;
90
+ }
91
+ const color = resolveRequestLogColorToken(requestId, context);
92
+ if (!color) {
93
+ return text;
94
+ }
95
+ return `${color}${text}${ANSI_RESET}`;
96
+ }
97
+ //# sourceMappingURL=request-log-color.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"request-log-color.js","sourceRoot":"","sources":["../../../src/server/utils/request-log-color.ts"],"names":[],"mappings":"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"}
@@ -1,2 +1,7 @@
1
1
  export declare function isStageLoggingEnabled(): boolean;
2
2
  export declare function logPipelineStage(stage: string, requestId: string, details?: Record<string, unknown>): void;
3
+ export declare function formatRequestTimingSummary(requestId: string, options?: {
4
+ latencyMs?: number;
5
+ terminal?: boolean;
6
+ }): string;
7
+ export declare function rebindRequestTimingTimeline(fromRequestId: string, toRequestId: string): void;
@@ -3,6 +3,14 @@ const truthy = new Set(['1', 'true', 'yes']);
3
3
  const falsy = new Set(['0', 'false', 'no']);
4
4
  let cachedStageLoggingFlag = null;
5
5
  let cachedStageVerboseFlag = null;
6
+ let cachedStageTimingFlag = null;
7
+ let cachedStageTimingSummaryFlag = null;
8
+ const REQUEST_STAGE_TIMELINE_TTL_MS = 30 * 60 * 1000;
9
+ const REQUEST_STAGE_TIMELINE_MAX = 4096;
10
+ const REQUEST_STAGE_TIMELINES = new Map();
11
+ const REQUEST_SCOPE_STAGE_STARTS = new Map();
12
+ const REQUEST_SCOPE_STAGE_ELAPSED = new Map();
13
+ const REQUEST_SCOPE_STAGE_TOTAL_ELAPSED = new Map();
6
14
  const COLOR_RESET = '\x1b[0m';
7
15
  const COLOR_INFO = '\x1b[90m';
8
16
  const COLOR_START = '\x1b[36m';
@@ -45,12 +53,48 @@ function computeStageVerboseEnabled() {
45
53
  ?? process.env.ROUTECODEX_PIPELINE_LOG_VERBOSE
46
54
  ?? process.env.RCC_PIPELINE_LOG_VERBOSE, false);
47
55
  }
56
+ function computeStageTimingEnabled() {
57
+ const raw = process.env.ROUTECODEX_STAGE_TIMING
58
+ ?? process.env.RCC_STAGE_TIMING
59
+ ?? process.env.ROUTECODEX_DEBUG_STAGE_TIMING
60
+ ?? process.env.RCC_DEBUG_STAGE_TIMING;
61
+ if (raw !== undefined) {
62
+ return resolveBoolFromEnv(raw, false);
63
+ }
64
+ return false;
65
+ }
66
+ function computeStageTimingSummaryEnabled() {
67
+ return resolveBoolFromEnv(process.env.ROUTECODEX_STAGE_TIMING_SUMMARY
68
+ ?? process.env.RCC_STAGE_TIMING_SUMMARY, false);
69
+ }
70
+ function resolveRuntimeBuildMode() {
71
+ const raw = String(process.env.ROUTECODEX_BUILD_MODE ?? process.env.BUILD_MODE ?? '').trim().toLowerCase();
72
+ if (raw === 'release') {
73
+ return 'release';
74
+ }
75
+ if (raw === 'dev' || raw === 'development') {
76
+ return 'dev';
77
+ }
78
+ return buildInfo.mode === 'release' ? 'release' : 'dev';
79
+ }
48
80
  function isStageVerboseEnabled() {
49
81
  if (cachedStageVerboseFlag === null) {
50
82
  cachedStageVerboseFlag = computeStageVerboseEnabled();
51
83
  }
52
84
  return cachedStageVerboseFlag;
53
85
  }
86
+ function isStageTimingEnabled() {
87
+ if (cachedStageTimingFlag === null) {
88
+ cachedStageTimingFlag = computeStageTimingEnabled();
89
+ }
90
+ return cachedStageTimingFlag;
91
+ }
92
+ function isStageTimingSummaryEnabled() {
93
+ if (cachedStageTimingSummaryFlag === null) {
94
+ cachedStageTimingSummaryFlag = computeStageTimingSummaryEnabled();
95
+ }
96
+ return cachedStageTimingSummaryFlag;
97
+ }
54
98
  export function isStageLoggingEnabled() {
55
99
  if (cachedStageLoggingFlag === null) {
56
100
  cachedStageLoggingFlag = computeStageLoggingEnabled();
@@ -58,16 +102,38 @@ export function isStageLoggingEnabled() {
58
102
  return cachedStageLoggingFlag;
59
103
  }
60
104
  export function logPipelineStage(stage, requestId, details) {
61
- if (!isStageLoggingEnabled()) {
62
- return;
63
- }
105
+ const timingEnabled = isStageTimingEnabled();
106
+ const timingSummaryEnabled = isStageTimingSummaryEnabled();
64
107
  const { scope, action } = parseStage(stage);
65
108
  const level = detectStageLevel(stage);
109
+ const normalizedStage = stage.trim().toLowerCase();
110
+ const releaseSummaryStage = shouldLogReleaseSummaryStage(stage);
111
+ const releaseSummaryTrackedScope = shouldTrackReleaseSummaryScope(stage);
112
+ if ((timingEnabled || timingSummaryEnabled || releaseSummaryTrackedScope) && !REQUEST_STAGE_TIMELINES.has(requestId)) {
113
+ touchRequestStageTimeline(requestId);
114
+ }
115
+ if ((timingEnabled || releaseSummaryTrackedScope) && level === 'start') {
116
+ touchRequestStageTimeline(requestId);
117
+ markScopeStageStart(requestId, scope);
118
+ if (normalizedStage === 'response.dispatch.start') {
119
+ markScopeStageStart(requestId, 'response');
120
+ }
121
+ }
122
+ if (!isStageLoggingEnabled() && !releaseSummaryStage) {
123
+ return;
124
+ }
66
125
  const verbose = isStageVerboseEnabled();
67
- if (!shouldLogStage(stage, scope, level, verbose)) {
126
+ const explicitElapsedMs = (releaseSummaryTrackedScope
127
+ && (level === 'success' || level === 'error')
128
+ && typeof details?.elapsedMs === 'number'
129
+ && Number.isFinite(details.elapsedMs))
130
+ ? Math.max(0, details.elapsedMs)
131
+ : undefined;
132
+ const scopeElapsedMs = finalizeScopeStageElapsedMs(requestId, scope, level, explicitElapsedMs);
133
+ if (!shouldLogStage(stage, scope, level, verbose, timingEnabled, releaseSummaryStage)) {
68
134
  return;
69
135
  }
70
- const showDetail = verbose || level === 'error';
136
+ const showDetail = !releaseSummaryStage && (verbose || level === 'error');
71
137
  const providerLabel = showDetail && typeof details?.providerLabel === 'string' ? details?.providerLabel : undefined;
72
138
  const detailPayload = showDetail
73
139
  ? (providerLabel
@@ -78,19 +144,70 @@ export function logPipelineStage(stage, requestId, details) {
78
144
  })()
79
145
  : details)
80
146
  : undefined;
147
+ const timingLabel = timingEnabled
148
+ ? advanceRequestStageTimingLabel(requestId)
149
+ : releaseSummaryStage
150
+ ? formatReleaseSummaryTimingLabel((typeof details?.elapsedMs === 'number' ? details.elapsedMs : undefined)
151
+ ?? scopeElapsedMs
152
+ ?? peekRequestStageTimingStats(requestId)?.deltaMs)
153
+ : '';
81
154
  const suffix = detailPayload && Object.keys(detailPayload).length ? ` ${JSON.stringify(detailPayload)}` : '';
82
- const label = `[${scope}][${requestId}] ${action}`;
155
+ const label = `[${scope}][${requestId}] ${action}${timingLabel}`;
83
156
  const providerTag = providerLabel ? ` ${colorizeProviderLabel(level, providerLabel)}` : '';
84
157
  console.log(`${colorize(level, label)}${providerTag}${suffix}`);
158
+ if (isTerminalStage(stage) && !timingSummaryEnabled) {
159
+ clearRequestStageState(requestId);
160
+ }
85
161
  }
86
- function shouldLogStage(stage, scope, level, verbose) {
162
+ export function formatRequestTimingSummary(requestId, options) {
163
+ let label = '';
164
+ if (resolveRuntimeBuildMode() === 'release') {
165
+ label = formatReleaseUsageTimingSummary(requestId, options);
166
+ }
167
+ else if (isStageTimingSummaryEnabled()) {
168
+ label = peekRequestStageTimingLabel(requestId);
169
+ }
170
+ if (options?.terminal) {
171
+ clearRequestStageState(requestId);
172
+ }
173
+ return label;
174
+ }
175
+ export function rebindRequestTimingTimeline(fromRequestId, toRequestId) {
176
+ if (!fromRequestId || !toRequestId || fromRequestId === toRequestId) {
177
+ return;
178
+ }
179
+ const fromTimeline = REQUEST_STAGE_TIMELINES.get(fromRequestId);
180
+ if (!fromTimeline) {
181
+ return;
182
+ }
183
+ const existing = REQUEST_STAGE_TIMELINES.get(toRequestId);
184
+ if (!existing) {
185
+ REQUEST_STAGE_TIMELINES.set(toRequestId, { ...fromTimeline });
186
+ REQUEST_STAGE_TIMELINES.delete(fromRequestId);
187
+ return;
188
+ }
189
+ existing.startedAtMs = Math.min(existing.startedAtMs, fromTimeline.startedAtMs);
190
+ existing.lastAtMs = Math.max(existing.lastAtMs, fromTimeline.lastAtMs);
191
+ REQUEST_STAGE_TIMELINES.delete(fromRequestId);
192
+ }
193
+ function shouldLogStage(stage, scope, level, verbose, timingEnabled, releaseSummaryStage) {
87
194
  const normalizedScope = scope.trim().toLowerCase();
88
195
  const normalizedStage = stage.trim().toLowerCase();
196
+ if (releaseSummaryStage) {
197
+ return true;
198
+ }
199
+ // `response.sse.preview` is too noisy even in timing mode.
200
+ if (normalizedStage === 'response.sse.preview') {
201
+ return false;
202
+ }
89
203
  // HTTP handlers already emit one concise colored request-failed line.
90
- // Keep provider.send.error silent even in verbose mode to avoid duplicates.
204
+ // Keep provider.send.error silent even in timing mode to avoid duplicates.
91
205
  if (normalizedScope === 'provider.send' && normalizedStage.endsWith('.error')) {
92
206
  return false;
93
207
  }
208
+ if (timingEnabled) {
209
+ return true;
210
+ }
94
211
  if (verbose) {
95
212
  return true;
96
213
  }
@@ -152,4 +269,178 @@ function colorizeProviderLabel(level, label) {
152
269
  const color = level === 'error' ? COLOR_ERROR : COLOR_SUCCESS;
153
270
  return `${color}[${label}]${COLOR_RESET}`;
154
271
  }
272
+ function pruneRequestStageTimelines(nowMs) {
273
+ for (const [key, timeline] of REQUEST_STAGE_TIMELINES.entries()) {
274
+ if (nowMs - timeline.lastAtMs >= REQUEST_STAGE_TIMELINE_TTL_MS) {
275
+ REQUEST_STAGE_TIMELINES.delete(key);
276
+ }
277
+ }
278
+ while (REQUEST_STAGE_TIMELINES.size > REQUEST_STAGE_TIMELINE_MAX) {
279
+ const oldestKey = REQUEST_STAGE_TIMELINES.keys().next().value;
280
+ if (!oldestKey) {
281
+ break;
282
+ }
283
+ REQUEST_STAGE_TIMELINES.delete(oldestKey);
284
+ }
285
+ }
286
+ function scopeStageKey(requestId, scope) {
287
+ return `${requestId}::${scope.trim().toLowerCase()}`;
288
+ }
289
+ function markScopeStageStart(requestId, scope) {
290
+ if (!requestId || !scope) {
291
+ return;
292
+ }
293
+ REQUEST_SCOPE_STAGE_STARTS.set(scopeStageKey(requestId, scope), Date.now());
294
+ }
295
+ function finalizeScopeStageElapsedMs(requestId, scope, level, explicitElapsedMs) {
296
+ if (level !== 'success' && level !== 'error') {
297
+ return undefined;
298
+ }
299
+ const key = scopeStageKey(requestId, scope);
300
+ const startedAtMs = REQUEST_SCOPE_STAGE_STARTS.get(key);
301
+ if (startedAtMs === undefined && explicitElapsedMs === undefined) {
302
+ return undefined;
303
+ }
304
+ REQUEST_SCOPE_STAGE_STARTS.delete(key);
305
+ const elapsedMs = explicitElapsedMs ?? Math.max(0, Date.now() - (startedAtMs ?? Date.now()));
306
+ REQUEST_SCOPE_STAGE_ELAPSED.set(key, elapsedMs);
307
+ REQUEST_SCOPE_STAGE_TOTAL_ELAPSED.set(key, (REQUEST_SCOPE_STAGE_TOTAL_ELAPSED.get(key) ?? 0) + elapsedMs);
308
+ return elapsedMs;
309
+ }
310
+ function formatReleaseSummaryTimingLabel(elapsedMs) {
311
+ if (elapsedMs === undefined) {
312
+ return '';
313
+ }
314
+ return ` total=${formatDurationMs(elapsedMs)}`;
315
+ }
316
+ function shouldLogReleaseSummaryStage(stage) {
317
+ if (resolveRuntimeBuildMode() !== 'release') {
318
+ return false;
319
+ }
320
+ const normalized = stage.trim().toLowerCase();
321
+ return normalized === 'hub.completed'
322
+ || normalized === 'hub.response.completed'
323
+ || normalized === 'response.completed'
324
+ || normalized === 'provider.send.completed';
325
+ }
326
+ function shouldTrackReleaseSummaryScope(stage) {
327
+ if (resolveRuntimeBuildMode() !== 'release') {
328
+ return false;
329
+ }
330
+ const normalized = stage.trim().toLowerCase();
331
+ return normalized === 'hub.start'
332
+ || normalized === 'hub.completed'
333
+ || normalized === 'hub.response.start'
334
+ || normalized === 'hub.response.completed'
335
+ || normalized === 'response.dispatch.start'
336
+ || normalized === 'response.completed'
337
+ || normalized === 'provider.send.start'
338
+ || normalized === 'provider.send.completed';
339
+ }
340
+ function clearRequestStageState(requestId) {
341
+ REQUEST_STAGE_TIMELINES.delete(requestId);
342
+ for (const key of REQUEST_SCOPE_STAGE_STARTS.keys()) {
343
+ if (key.startsWith(`${requestId}::`)) {
344
+ REQUEST_SCOPE_STAGE_STARTS.delete(key);
345
+ }
346
+ }
347
+ for (const key of REQUEST_SCOPE_STAGE_ELAPSED.keys()) {
348
+ if (key.startsWith(`${requestId}::`)) {
349
+ REQUEST_SCOPE_STAGE_ELAPSED.delete(key);
350
+ }
351
+ }
352
+ for (const key of REQUEST_SCOPE_STAGE_TOTAL_ELAPSED.keys()) {
353
+ if (key.startsWith(`${requestId}::`)) {
354
+ REQUEST_SCOPE_STAGE_TOTAL_ELAPSED.delete(key);
355
+ }
356
+ }
357
+ }
358
+ function formatDurationMs(value) {
359
+ const rounded = Math.max(0, Math.round(value));
360
+ return `${rounded}ms`;
361
+ }
362
+ function touchRequestStageTimeline(requestId) {
363
+ const nowMs = Date.now();
364
+ pruneRequestStageTimelines(nowMs);
365
+ const existing = REQUEST_STAGE_TIMELINES.get(requestId);
366
+ if (!existing) {
367
+ REQUEST_STAGE_TIMELINES.set(requestId, {
368
+ startedAtMs: nowMs,
369
+ lastAtMs: nowMs
370
+ });
371
+ return;
372
+ }
373
+ existing.lastAtMs = nowMs;
374
+ }
375
+ function peekRequestStageTimingStats(requestId) {
376
+ const nowMs = Date.now();
377
+ pruneRequestStageTimelines(nowMs);
378
+ const existing = REQUEST_STAGE_TIMELINES.get(requestId);
379
+ if (!existing) {
380
+ return null;
381
+ }
382
+ return {
383
+ totalMs: nowMs - existing.startedAtMs,
384
+ deltaMs: nowMs - existing.lastAtMs
385
+ };
386
+ }
387
+ function advanceRequestStageTimingLabel(requestId) {
388
+ const nowMs = Date.now();
389
+ pruneRequestStageTimelines(nowMs);
390
+ const existing = REQUEST_STAGE_TIMELINES.get(requestId);
391
+ if (!existing) {
392
+ REQUEST_STAGE_TIMELINES.set(requestId, {
393
+ startedAtMs: nowMs,
394
+ lastAtMs: nowMs
395
+ });
396
+ return ' t+0ms Δ0ms';
397
+ }
398
+ const totalMs = nowMs - existing.startedAtMs;
399
+ const deltaMs = nowMs - existing.lastAtMs;
400
+ existing.lastAtMs = nowMs;
401
+ return ` t+${formatDurationMs(totalMs)} Δ${formatDurationMs(deltaMs)}`;
402
+ }
403
+ function peekRequestStageTimingLabel(requestId) {
404
+ const nowMs = Date.now();
405
+ pruneRequestStageTimelines(nowMs);
406
+ const existing = REQUEST_STAGE_TIMELINES.get(requestId);
407
+ if (!existing) {
408
+ return '';
409
+ }
410
+ const totalMs = nowMs - existing.startedAtMs;
411
+ const deltaMs = nowMs - existing.lastAtMs;
412
+ return ` t+${formatDurationMs(totalMs)} Δ${formatDurationMs(deltaMs)}`;
413
+ }
414
+ function readStoredScopeStageElapsedMs(requestId, scope) {
415
+ return REQUEST_SCOPE_STAGE_TOTAL_ELAPSED.get(scopeStageKey(requestId, scope))
416
+ ?? REQUEST_SCOPE_STAGE_ELAPSED.get(scopeStageKey(requestId, scope));
417
+ }
418
+ function formatReleaseUsageTimingSummary(requestId, options) {
419
+ const totalLatencyMs = typeof options?.latencyMs === 'number' && Number.isFinite(options.latencyMs)
420
+ ? Math.max(0, options.latencyMs)
421
+ : undefined;
422
+ const providerSendMs = readStoredScopeStageElapsedMs(requestId, 'provider.send') ?? 0;
423
+ const hubResponseMs = readStoredScopeStageElapsedMs(requestId, 'hub.response') ?? 0;
424
+ const responseMs = readStoredScopeStageElapsedMs(requestId, 'response') ?? 0;
425
+ const parts = [];
426
+ if (totalLatencyMs !== undefined) {
427
+ const requestInternalMs = Math.max(0, totalLatencyMs - providerSendMs - hubResponseMs - responseMs);
428
+ parts.push(`request.internal=${formatDurationMs(requestInternalMs)}`);
429
+ }
430
+ for (const scope of ['hub', 'provider.send', 'hub.response', 'response']) {
431
+ const elapsedMs = readStoredScopeStageElapsedMs(requestId, scope);
432
+ if (elapsedMs === undefined) {
433
+ continue;
434
+ }
435
+ parts.push(`${scope}=${formatDurationMs(elapsedMs)}`);
436
+ }
437
+ if (!parts.length) {
438
+ return '';
439
+ }
440
+ return ` timing={${parts.join(', ')}}`;
441
+ }
442
+ function isTerminalStage(stage) {
443
+ void stage;
444
+ return false;
445
+ }
155
446
  //# sourceMappingURL=stage-logger.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"stage-logger.js","sourceRoot":"","sources":["../../../src/server/utils/stage-logger.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"stage-logger.js","sourceRoot":"","sources":["../../../src/server/utils/stage-logger.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1 @@
1
+ export declare function resolveSessionAnsiColor(sessionId?: unknown): string | undefined;
@@ -0,0 +1,29 @@
1
+ const SESSION_COLOR_PALETTE = [
2
+ '\x1b[31m',
3
+ '\x1b[32m',
4
+ '\x1b[33m',
5
+ '\x1b[34m',
6
+ '\x1b[35m',
7
+ '\x1b[36m',
8
+ '\x1b[38;5;208m',
9
+ '\x1b[38;5;141m'
10
+ ];
11
+ function normalizeToken(value) {
12
+ if (typeof value !== 'string') {
13
+ return undefined;
14
+ }
15
+ const trimmed = value.trim();
16
+ return trimmed || undefined;
17
+ }
18
+ export function resolveSessionAnsiColor(sessionId) {
19
+ const normalized = normalizeToken(sessionId);
20
+ if (!normalized) {
21
+ return undefined;
22
+ }
23
+ let hash = 0;
24
+ for (let i = 0; i < normalized.length; i += 1) {
25
+ hash = ((hash * 31) + normalized.charCodeAt(i)) >>> 0;
26
+ }
27
+ return SESSION_COLOR_PALETTE[hash % SESSION_COLOR_PALETTE.length];
28
+ }
29
+ //# sourceMappingURL=session-log-color.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"session-log-color.js","sourceRoot":"","sources":["../../src/utils/session-log-color.ts"],"names":[],"mappings":"AAAA,MAAM,qBAAqB,GAAG;IAC5B,UAAU;IACV,UAAU;IACV,UAAU;IACV,UAAU;IACV,UAAU;IACV,UAAU;IACV,gBAAgB;IAChB,gBAAgB;CACR,CAAC;AAEX,SAAS,cAAc,CAAC,KAAc;IACpC,IAAI,OAAO,KAAK,KAAK,QAAQ,EAAE,CAAC;QAC9B,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,MAAM,OAAO,GAAG,KAAK,CAAC,IAAI,EAAE,CAAC;IAC7B,OAAO,OAAO,IAAI,SAAS,CAAC;AAC9B,CAAC;AAED,MAAM,UAAU,uBAAuB,CAAC,SAAmB;IACzD,MAAM,UAAU,GAAG,cAAc,CAAC,SAAS,CAAC,CAAC;IAC7C,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,OAAO,SAAS,CAAC;IACnB,CAAC;IACD,IAAI,IAAI,GAAG,CAAC,CAAC;IACb,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,UAAU,CAAC,MAAM,EAAE,CAAC,IAAI,CAAC,EAAE,CAAC;QAC9C,IAAI,GAAG,CAAC,CAAC,IAAI,GAAG,EAAE,CAAC,GAAG,UAAU,CAAC,UAAU,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACxD,CAAC;IACD,OAAO,qBAAqB,CAAC,IAAI,GAAG,qBAAqB,CAAC,MAAM,CAAC,CAAC;AACpE,CAAC"}
@@ -1,8 +1,8 @@
1
1
  import fsp from 'fs/promises';
2
2
  import os from 'os';
3
3
  import path from 'path';
4
- import { writeSnapshotViaHooks } from '../modules/llmswitch/bridge.js';
5
4
  import { runtimeFlags } from '../runtime/runtime-flags.js';
5
+ let snapshotHookWriterPromise = null;
6
6
  export function isSnapshotsEnabled() {
7
7
  // 优先使用运行时全局覆盖(由服务器根据 virtualRouter config 注入)
8
8
  try {
@@ -66,6 +66,14 @@ async function writeUniqueFile(dir, baseName, contents) {
66
66
  const fallback = `${stem}_${Date.now()}_${Math.random().toString(36).slice(2, 8)}${ext}`;
67
67
  await fsp.writeFile(path.join(dir, fallback), contents, 'utf-8');
68
68
  }
69
+ async function loadSnapshotHookWriter() {
70
+ if (!snapshotHookWriterPromise) {
71
+ snapshotHookWriterPromise = import('../modules/llmswitch/bridge.js')
72
+ .then((module) => (typeof module.writeSnapshotViaHooks === 'function' ? module.writeSnapshotViaHooks : null))
73
+ .catch(() => null);
74
+ }
75
+ return snapshotHookWriterPromise;
76
+ }
69
77
  export async function writeServerSnapshot(options) {
70
78
  if (!isSnapshotsEnabled()) {
71
79
  return; // default OFF
@@ -75,7 +83,8 @@ export async function writeServerSnapshot(options) {
75
83
  const providerKey = options.providerKey;
76
84
  // 1) 尝试通过 llmswitch-core hooks 写快照(供核心调试使用)
77
85
  try {
78
- await writeSnapshotViaHooks('server', {
86
+ const writeSnapshotViaHooks = await loadSnapshotHookWriter();
87
+ await writeSnapshotViaHooks?.('server', {
79
88
  endpoint,
80
89
  stage: String(options.phase),
81
90
  requestId: options.requestId,