@stainlessdev/xray-core 0.6.0 → 0.7.0

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/internal.cjs CHANGED
@@ -22,6 +22,7 @@ var internal_exports = {};
22
22
  __export(internal_exports, {
23
23
  LimitedBuffer: () => LimitedBuffer,
24
24
  bindContextToObject: () => bindContextToObject,
25
+ generateRequestId: () => generateRequestId,
25
26
  getXrayContextFromObject: () => getXrayContextFromObject,
26
27
  headerTokenList: () => headerTokenList,
27
28
  headerValuesFromFetchHeaders: () => headerValuesFromFetchHeaders,
@@ -34,7 +35,10 @@ __export(internal_exports, {
34
35
  setCaptureOverride: () => setCaptureOverride,
35
36
  setContextRequestId: () => setContextRequestId,
36
37
  setContextRoute: () => setContextRoute,
37
- setRedactionOverride: () => setRedactionOverride
38
+ setRedactionOverride: () => setRedactionOverride,
39
+ uuidv7: () => uuidv7,
40
+ uuidv7base48: () => uuidv7base48,
41
+ uuidv7base62: () => uuidv7base62
38
42
  });
39
43
  module.exports = __toCommonJS(internal_exports);
40
44
 
@@ -391,6 +395,133 @@ function logWithLevel(logger, level, threshold, message, fields) {
391
395
  }
392
396
  }
393
397
 
398
+ // src/uuid/base48.ts
399
+ var base48AlphabetLex = "256789BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz";
400
+ var base48Zero = base48AlphabetLex.charAt(0);
401
+ var maxChunkBytes = 32;
402
+ var chunkToEncodedLength = /* @__PURE__ */ new Map();
403
+ var encodedLengthToChunk = /* @__PURE__ */ new Map();
404
+ for (let size = 1; size <= maxChunkBytes; size += 1) {
405
+ const encodedLength = Math.ceil(size * 8 / Math.log2(48));
406
+ chunkToEncodedLength.set(size, encodedLength);
407
+ encodedLengthToChunk.set(encodedLength, size);
408
+ }
409
+ var maxEncodedChunk = chunkToEncodedLength.get(maxChunkBytes);
410
+ function encodeChunk(bytes, size) {
411
+ let value = 0n;
412
+ for (const byte of bytes) {
413
+ value = value << 8n | BigInt(byte);
414
+ }
415
+ let encoded = "";
416
+ if (value === 0n) {
417
+ encoded = base48Zero;
418
+ } else {
419
+ while (value > 0n) {
420
+ const mod = value % 48n;
421
+ encoded = base48AlphabetLex[Number(mod)] + encoded;
422
+ value /= 48n;
423
+ }
424
+ }
425
+ const targetLength = chunkToEncodedLength.get(size);
426
+ if (!targetLength) {
427
+ throw new Error(`base48: unsupported chunk size ${size}`);
428
+ }
429
+ return encoded.padStart(targetLength, base48Zero);
430
+ }
431
+ function encodeBase48Lex(buffer) {
432
+ if (buffer.length === 0) {
433
+ return "";
434
+ }
435
+ let result = "";
436
+ for (let offset = 0; offset < buffer.length; ) {
437
+ const remaining = buffer.length - offset;
438
+ const size = remaining >= maxChunkBytes ? maxChunkBytes : remaining;
439
+ result += encodeChunk(buffer.slice(offset, offset + size), size);
440
+ offset += size;
441
+ }
442
+ return result;
443
+ }
444
+
445
+ // src/uuid/base62.ts
446
+ var base62AlphabetLex = "0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz";
447
+ var base62Zero = base62AlphabetLex.charAt(0);
448
+ var maxChunkBytes2 = 32;
449
+ var chunkToEncodedLength2 = /* @__PURE__ */ new Map();
450
+ var encodedLengthToChunk2 = /* @__PURE__ */ new Map();
451
+ for (let size = 1; size <= maxChunkBytes2; size += 1) {
452
+ const encodedLength = Math.ceil(size * 8 / Math.log2(62));
453
+ chunkToEncodedLength2.set(size, encodedLength);
454
+ encodedLengthToChunk2.set(encodedLength, size);
455
+ }
456
+ var maxEncodedChunk2 = chunkToEncodedLength2.get(maxChunkBytes2);
457
+ function encodeChunk2(bytes, size) {
458
+ let value = 0n;
459
+ for (const byte of bytes) {
460
+ value = value << 8n | BigInt(byte);
461
+ }
462
+ let encoded = "";
463
+ if (value === 0n) {
464
+ encoded = base62Zero;
465
+ } else {
466
+ while (value > 0n) {
467
+ const mod = value % 62n;
468
+ encoded = base62AlphabetLex[Number(mod)] + encoded;
469
+ value /= 62n;
470
+ }
471
+ }
472
+ const targetLength = chunkToEncodedLength2.get(size);
473
+ if (!targetLength) {
474
+ throw new Error(`base62: unsupported chunk size ${size}`);
475
+ }
476
+ return encoded.padStart(targetLength, base62Zero);
477
+ }
478
+ function encodeBase62Lex(buffer) {
479
+ if (buffer.length === 0) {
480
+ return "";
481
+ }
482
+ let result = "";
483
+ for (let offset = 0; offset < buffer.length; ) {
484
+ const remaining = buffer.length - offset;
485
+ const size = remaining >= maxChunkBytes2 ? maxChunkBytes2 : remaining;
486
+ result += encodeChunk2(buffer.slice(offset, offset + size), size);
487
+ offset += size;
488
+ }
489
+ return result;
490
+ }
491
+
492
+ // src/uuid/index.ts
493
+ var requestIdPrefix = "req_";
494
+ function uuidv7Bytes() {
495
+ const bytes = new Uint8Array(16);
496
+ crypto.getRandomValues(bytes);
497
+ const timestamp = BigInt(Date.now());
498
+ bytes[0] = Number(timestamp >> 40n & 0xffn);
499
+ bytes[1] = Number(timestamp >> 32n & 0xffn);
500
+ bytes[2] = Number(timestamp >> 24n & 0xffn);
501
+ bytes[3] = Number(timestamp >> 16n & 0xffn);
502
+ bytes[4] = Number(timestamp >> 8n & 0xffn);
503
+ bytes[5] = Number(timestamp & 0xffn);
504
+ const byte6 = bytes[6] ?? 0;
505
+ const byte8 = bytes[8] ?? 0;
506
+ bytes[6] = byte6 & 15 | 112;
507
+ bytes[8] = byte8 & 63 | 128;
508
+ return bytes;
509
+ }
510
+ function uuidv7() {
511
+ const bytes = uuidv7Bytes();
512
+ const hex = Array.from(bytes, (b) => b.toString(16).padStart(2, "0"));
513
+ return `${hex.slice(0, 4).join("")}-${hex.slice(4, 6).join("")}-${hex.slice(6, 8).join("")}-${hex.slice(8, 10).join("")}-${hex.slice(10).join("")}`;
514
+ }
515
+ function uuidv7base62() {
516
+ return encodeBase62Lex(uuidv7Bytes());
517
+ }
518
+ function uuidv7base48() {
519
+ return encodeBase48Lex(uuidv7Bytes());
520
+ }
521
+ function generateRequestId() {
522
+ return `${requestIdPrefix}${uuidv7base48()}`;
523
+ }
524
+
394
525
  // src/internal.ts
395
526
  function bindContextToObject(target, ctx) {
396
527
  const state = getContextState(ctx);
@@ -436,6 +567,7 @@ function setRedactionOverride(ctx, redaction) {
436
567
  0 && (module.exports = {
437
568
  LimitedBuffer,
438
569
  bindContextToObject,
570
+ generateRequestId,
439
571
  getXrayContextFromObject,
440
572
  headerTokenList,
441
573
  headerValuesFromFetchHeaders,
@@ -448,6 +580,9 @@ function setRedactionOverride(ctx, redaction) {
448
580
  setCaptureOverride,
449
581
  setContextRequestId,
450
582
  setContextRoute,
451
- setRedactionOverride
583
+ setRedactionOverride,
584
+ uuidv7,
585
+ uuidv7base48,
586
+ uuidv7base62
452
587
  });
453
588
  //# sourceMappingURL=internal.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/internal.ts","../src/state.ts","../src/limited_buffer.ts","../src/headers.ts","../src/websocket.ts","../src/encoding.ts","../src/request_log.ts","../src/logger.ts"],"sourcesContent":["import type { CaptureConfig, RedactionConfig } from './config';\nimport type { XrayContext } from './types';\nimport { bindObject, getContextFromObject, getContextState } from './state';\n\nexport { LimitedBuffer } from './limited_buffer';\nexport {\n headerValuesFromFetchHeaders,\n headerValuesFromFetchHeadersWithLimit,\n headerValuesFromNodeHeaders,\n headerTokenList,\n} from './headers';\nexport { isWebsocketUpgrade, isWebsocketUpgradeFetch } from './websocket';\nexport { makeCapturedBody } from './request_log';\nexport { logWithLevel } from './logger';\n\nexport function bindContextToObject(target: object, ctx: XrayContext): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n bindObject(target, state);\n}\n\nexport function getXrayContextFromObject(target: unknown): XrayContext | undefined {\n return getContextFromObject(target);\n}\n\nexport function setContextRoute(ctx: XrayContext, route: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n const normalized =\n state.config.route.normalize && state.config.route.normalizer\n ? state.config.route.normalizer(route)\n : route;\n state.request.route = normalized;\n}\n\nexport function setContextRequestId(ctx: XrayContext, requestId: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n state.request.requestId = requestId;\n state.context.requestId = requestId;\n}\n\nexport function setCaptureOverride(\n ctx: XrayContext,\n capture: Partial<CaptureConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !capture) {\n return;\n }\n state.captureOverride = capture;\n}\n\nexport function setRedactionOverride(\n ctx: XrayContext,\n redaction: Partial<RedactionConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !redaction) {\n return;\n }\n state.redactionOverride = redaction;\n}\n","import type { Span } from '@opentelemetry/api';\nimport type { AttributeValue, NormalizedRequest, XrayContext } from './types';\nimport type { CaptureConfig, RedactionConfig, ResolvedXrayConfig } from './config';\n\nexport type RequestState = {\n request: NormalizedRequest;\n config: ResolvedXrayConfig;\n span?: Span;\n context: XrayContext;\n attributes: Record<string, AttributeValue>;\n events: Array<{ name: string; attributes?: Record<string, AttributeValue> }>;\n userId?: string;\n sessionId?: string;\n error?: unknown;\n captureOverride?: Partial<CaptureConfig>;\n redactionOverride?: Partial<RedactionConfig>;\n};\n\nconst contextMap = new WeakMap<XrayContext, RequestState>();\nconst objectMap = new WeakMap<object, RequestState>();\n\nexport function bindContext(ctx: XrayContext, state: RequestState): void {\n contextMap.set(ctx, state);\n}\n\nexport function getContextState(ctx: XrayContext): RequestState | undefined {\n return contextMap.get(ctx);\n}\n\nexport function bindObject(target: object, state: RequestState): void {\n objectMap.set(target, state);\n}\n\nexport function getContextFromObject(target: unknown): XrayContext | undefined {\n const state = getStateFromObject(target);\n return state?.context;\n}\n\nexport function getStateFromObject(target: unknown): RequestState | undefined {\n if (!target || typeof target !== 'object') {\n return undefined;\n }\n if (objectMap.has(target)) {\n return objectMap.get(target);\n }\n\n const fallback = findNestedTarget(target as Record<string, unknown>);\n if (fallback && objectMap.has(fallback)) {\n return objectMap.get(fallback);\n }\n return undefined;\n}\n\nfunction findNestedTarget(obj: Record<string, unknown>): object | null {\n if (obj.raw && typeof obj.raw === 'object') {\n return obj.raw as object;\n }\n if (obj.req && typeof obj.req === 'object') {\n const req = obj.req as Record<string, unknown>;\n if (req.raw && typeof req.raw === 'object') {\n return req.raw as object;\n }\n return req as object;\n }\n if (obj.request && typeof obj.request === 'object') {\n const request = obj.request as Record<string, unknown>;\n if (request.raw && typeof request.raw === 'object') {\n return request.raw as object;\n }\n return request as object;\n }\n return null;\n}\n","export class LimitedBuffer {\n private buffer: Uint8Array;\n private length: number;\n private readonly limit: number;\n private truncatedFlag: boolean;\n private total: number;\n\n constructor(limit: number) {\n const normalized = Number.isFinite(limit) ? Math.max(0, limit) : 0;\n const initialCap = Math.min(normalized, 32 * 1024);\n this.buffer = new Uint8Array(initialCap);\n this.length = 0;\n this.limit = normalized;\n this.truncatedFlag = false;\n this.total = 0;\n }\n\n bytes(): Uint8Array {\n return this.buffer.slice(0, this.length);\n }\n\n capturedBytes(): number {\n return this.length;\n }\n\n totalBytes(): number {\n return this.total;\n }\n\n truncated(): boolean {\n return this.truncatedFlag;\n }\n\n write(chunk: Uint8Array): void {\n if (!chunk || chunk.length === 0) {\n return;\n }\n\n this.total += chunk.length;\n if (this.limit <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const remaining = this.limit - this.length;\n if (remaining <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const toCopy = Math.min(remaining, chunk.length);\n this.ensureCapacity(this.length + toCopy);\n this.buffer.set(chunk.subarray(0, toCopy), this.length);\n this.length += toCopy;\n if (toCopy < chunk.length) {\n this.truncatedFlag = true;\n }\n }\n\n private ensureCapacity(size: number): void {\n if (this.buffer.length >= size) {\n return;\n }\n\n let nextSize = this.buffer.length;\n if (nextSize === 0) {\n nextSize = 1;\n }\n while (nextSize < size) {\n nextSize *= 2;\n }\n if (nextSize > this.limit) {\n nextSize = this.limit;\n }\n const next = new Uint8Array(nextSize);\n next.set(this.buffer.subarray(0, this.length));\n this.buffer = next;\n }\n}\n","export type HeaderCapture = {\n headers: Record<string, string | string[]>;\n truncated: boolean;\n};\n\nexport function headerValuesFromNodeHeaders(\n headers: Record<string, string | string[] | number | undefined>,\n): Record<string, string | string[]> {\n const result: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n if (value == null) {\n continue;\n }\n const name = key.trim();\n if (!name) {\n continue;\n }\n if (Array.isArray(value)) {\n const entries = value.map((item) => `${item}`);\n if (entries.length > 0) {\n result[name] = entries.length === 1 ? entries[0]! : entries;\n }\n } else {\n result[name] = `${value}`;\n }\n }\n return Object.keys(result).length === 0 ? {} : result;\n}\n\nexport function headerValuesFromFetchHeaders(headers: Headers): Record<string, string | string[]> {\n return headerValuesFromFetchHeadersWithLimit(headers, Number.POSITIVE_INFINITY).headers;\n}\n\nexport function headerValuesFromFetchHeadersWithLimit(\n headers: Headers,\n maxBytes: number,\n): HeaderCapture {\n const result: Record<string, string | string[]> = {};\n let truncated = false;\n let remaining = Number.isFinite(maxBytes) ? Math.max(0, maxBytes) : Number.POSITIVE_INFINITY;\n const setCookie = getSetCookie(headers);\n if (setCookie) {\n const values = takeHeaderValues('set-cookie', setCookie, remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result['set-cookie'] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n }\n\n headers.forEach((value, key) => {\n const name = key.trim();\n if (!name) {\n return;\n }\n if (name.toLowerCase() === 'set-cookie' && setCookie) {\n return;\n }\n const values = takeHeaderValues(name, [value], remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result[name] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n });\n\n return {\n headers: Object.keys(result).length === 0 ? {} : result,\n truncated,\n };\n}\n\nexport function headerTokenList(values: string[] | string | undefined): string[] {\n if (!values) {\n return [];\n }\n if (Array.isArray(values)) {\n return splitTokens(values);\n }\n return splitTokens([values]);\n}\n\nfunction splitTokens(values: string[]): string[] {\n const tokens: string[] = [];\n for (const value of values) {\n if (!value) {\n continue;\n }\n for (const part of value.split(',')) {\n const trimmed = part.trim();\n if (trimmed) {\n tokens.push(trimmed);\n }\n }\n }\n return tokens;\n}\n\nfunction getSetCookie(headers: Headers): string[] | null {\n const maybe = headers as Headers & { getSetCookie?: () => string[] };\n if (typeof maybe.getSetCookie === 'function') {\n const values = maybe.getSetCookie();\n return values.length > 0 ? values : null;\n }\n return null;\n}\n\nfunction takeHeaderValues(\n name: string,\n values: string[],\n remaining: number,\n): { values: string[]; remaining: number; truncated: boolean } {\n if (remaining <= 0) {\n return { remaining: 0, truncated: true, values: [] };\n }\n\n const taken: string[] = [];\n let used = 0;\n for (const value of values) {\n if (!value) {\n continue;\n }\n const size = name.length + value.length;\n if (used + size > remaining) {\n return { remaining: Math.max(0, remaining - used), truncated: true, values: taken };\n }\n used += size;\n taken.push(value);\n }\n\n return { remaining: Math.max(0, remaining - used), truncated: false, values: taken };\n}\n","import { headerTokenList } from './headers';\n\ntype HeaderValues = Record<string, string | string[]>;\n\nexport function isWebsocketUpgrade(\n statusCode: number,\n requestHeaders: HeaderValues | undefined,\n responseHeaders: HeaderValues | undefined,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasToken(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasToken(requestHeaders, 'upgrade', 'websocket');\n}\n\nexport function isWebsocketUpgradeFetch(\n statusCode: number,\n requestHeaders: Headers,\n responseHeaders: Headers,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasTokenFetch(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasTokenFetch(requestHeaders, 'upgrade', 'websocket');\n}\n\nfunction headerHasToken(headers: HeaderValues | undefined, name: string, token: string): boolean {\n if (!headers) {\n return false;\n }\n const values = headers[name] ?? headers[name.toLowerCase()] ?? headers[name.toUpperCase()];\n if (!values) {\n return false;\n }\n const tokens = headerTokenList(values);\n return tokens.some((value) => value.toLowerCase() === token.toLowerCase());\n}\n\nfunction headerHasTokenFetch(headers: Headers, name: string, token: string): boolean {\n const value = headers.get(name);\n if (!value) {\n return false;\n }\n return value.split(',').some((part) => part.trim().toLowerCase() === token.toLowerCase());\n}\n","const utf8Decoder =\n typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8', { fatal: true }) : null;\nconst utf8DecoderLenient = typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8') : null;\nconst maybeBuffer = (\n globalThis as typeof globalThis & {\n Buffer?: { from(data: Uint8Array): { toString(encoding?: string): string } };\n }\n).Buffer;\n\nexport function encodeBase64(bytes: Uint8Array): string {\n if (maybeBuffer) {\n return maybeBuffer.from(bytes).toString('base64');\n }\n let binary = '';\n for (let i = 0; i < bytes.length; i += 1) {\n const byte = bytes[i];\n if (byte === undefined) {\n continue;\n }\n binary += String.fromCharCode(byte);\n }\n if (typeof btoa !== 'undefined') {\n return btoa(binary);\n }\n return '';\n}\n\nexport function isValidUtf8(bytes: Uint8Array): boolean {\n if (!utf8Decoder) {\n return false;\n }\n try {\n utf8Decoder.decode(bytes);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function decodeUtf8(bytes: Uint8Array): string {\n if (utf8DecoderLenient) {\n return utf8DecoderLenient.decode(bytes);\n }\n if (maybeBuffer) {\n return maybeBuffer.from(bytes).toString('utf8');\n }\n return '';\n}\n","import type { CapturedBody } from './types';\nimport { decodeUtf8, encodeBase64, isValidUtf8 } from './encoding';\n\n// eslint-disable-next-line no-control-regex\nconst controlChars = /[\\x00-\\x1F\\x7F]/g;\n\nexport function sanitizeLogString(value: string): string {\n if (!value) {\n return value;\n }\n return value.replace(controlChars, '');\n}\n\nexport function sanitizeHeaderValues(\n headers: Record<string, string | string[]> | undefined,\n): Record<string, string | string[]> | undefined {\n if (!headers) {\n return undefined;\n }\n\n const sanitized: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n const name = sanitizeLogString(key);\n if (Array.isArray(value)) {\n sanitized[name] = value.map((entry) => sanitizeLogString(entry));\n } else {\n sanitized[name] = sanitizeLogString(value);\n }\n }\n return sanitized;\n}\n\nexport function makeCapturedBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64',\n): CapturedBody | undefined {\n if (!bytes) {\n return undefined;\n }\n\n if (mode === 'base64') {\n return {\n bytes: totalBytes,\n encoding: 'base64',\n truncated,\n value: encodeBase64(bytes),\n };\n }\n\n if (isValidUtf8(bytes)) {\n return {\n bytes: totalBytes,\n encoding: 'utf8',\n truncated,\n value: decodeUtf8(bytes),\n };\n }\n\n return {\n bytes: totalBytes,\n encoding: 'base64',\n truncated,\n value: encodeBase64(bytes),\n };\n}\n","import type { Logger, LogLevel } from './types';\n\nconst logLevelOrder: Record<LogLevel, number> = {\n debug: 10,\n info: 20,\n warn: 30,\n error: 40,\n};\n\nexport function logWithLevel(\n logger: Logger,\n level: LogLevel,\n threshold: LogLevel,\n message: string,\n fields?: Record<string, unknown>,\n): void {\n if (logLevelOrder[level] < logLevelOrder[threshold]) {\n return;\n }\n\n const fn =\n logger[level] ?? logger.warn ?? logger.info ?? logger.debug ?? logger.error ?? console.log;\n\n try {\n fn.call(logger, message, fields);\n } catch {\n // Logging should never disrupt instrumentation.\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../src/internal.ts","../src/state.ts","../src/limited_buffer.ts","../src/headers.ts","../src/websocket.ts","../src/encoding.ts","../src/request_log.ts","../src/logger.ts","../src/uuid/base48.ts","../src/uuid/base62.ts","../src/uuid/index.ts"],"sourcesContent":["import type { CaptureConfig, RedactionConfig } from './config';\nimport type { XrayContext } from './types';\nimport { bindObject, getContextFromObject, getContextState } from './state';\n\nexport { LimitedBuffer } from './limited_buffer';\nexport {\n headerValuesFromFetchHeaders,\n headerValuesFromFetchHeadersWithLimit,\n headerValuesFromNodeHeaders,\n headerTokenList,\n} from './headers';\nexport { isWebsocketUpgrade, isWebsocketUpgradeFetch } from './websocket';\nexport { makeCapturedBody } from './request_log';\nexport { logWithLevel } from './logger';\nexport { generateRequestId, uuidv7, uuidv7base48, uuidv7base62 } from './uuid';\n\nexport function bindContextToObject(target: object, ctx: XrayContext): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n bindObject(target, state);\n}\n\nexport function getXrayContextFromObject(target: unknown): XrayContext | undefined {\n return getContextFromObject(target);\n}\n\nexport function setContextRoute(ctx: XrayContext, route: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n const normalized =\n state.config.route.normalize && state.config.route.normalizer\n ? state.config.route.normalizer(route)\n : route;\n state.request.route = normalized;\n}\n\nexport function setContextRequestId(ctx: XrayContext, requestId: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n state.request.requestId = requestId;\n state.context.requestId = requestId;\n}\n\nexport function setCaptureOverride(\n ctx: XrayContext,\n capture: Partial<CaptureConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !capture) {\n return;\n }\n state.captureOverride = capture;\n}\n\nexport function setRedactionOverride(\n ctx: XrayContext,\n redaction: Partial<RedactionConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !redaction) {\n return;\n }\n state.redactionOverride = redaction;\n}\n","import type { Span } from '@opentelemetry/api';\nimport type { AttributeValue, NormalizedRequest, XrayContext } from './types';\nimport type { CaptureConfig, RedactionConfig, ResolvedXrayConfig } from './config';\n\nexport type RequestState = {\n request: NormalizedRequest;\n config: ResolvedXrayConfig;\n span?: Span;\n context: XrayContext;\n attributes: Record<string, AttributeValue>;\n events: Array<{ name: string; attributes?: Record<string, AttributeValue> }>;\n userId?: string;\n sessionId?: string;\n error?: unknown;\n captureOverride?: Partial<CaptureConfig>;\n redactionOverride?: Partial<RedactionConfig>;\n};\n\nconst contextMap = new WeakMap<XrayContext, RequestState>();\nconst objectMap = new WeakMap<object, RequestState>();\n\nexport function bindContext(ctx: XrayContext, state: RequestState): void {\n contextMap.set(ctx, state);\n}\n\nexport function getContextState(ctx: XrayContext): RequestState | undefined {\n return contextMap.get(ctx);\n}\n\nexport function bindObject(target: object, state: RequestState): void {\n objectMap.set(target, state);\n}\n\nexport function getContextFromObject(target: unknown): XrayContext | undefined {\n const state = getStateFromObject(target);\n return state?.context;\n}\n\nexport function getStateFromObject(target: unknown): RequestState | undefined {\n if (!target || typeof target !== 'object') {\n return undefined;\n }\n if (objectMap.has(target)) {\n return objectMap.get(target);\n }\n\n const fallback = findNestedTarget(target as Record<string, unknown>);\n if (fallback && objectMap.has(fallback)) {\n return objectMap.get(fallback);\n }\n return undefined;\n}\n\nfunction findNestedTarget(obj: Record<string, unknown>): object | null {\n if (obj.raw && typeof obj.raw === 'object') {\n return obj.raw as object;\n }\n if (obj.req && typeof obj.req === 'object') {\n const req = obj.req as Record<string, unknown>;\n if (req.raw && typeof req.raw === 'object') {\n return req.raw as object;\n }\n return req as object;\n }\n if (obj.request && typeof obj.request === 'object') {\n const request = obj.request as Record<string, unknown>;\n if (request.raw && typeof request.raw === 'object') {\n return request.raw as object;\n }\n return request as object;\n }\n return null;\n}\n","export class LimitedBuffer {\n private buffer: Uint8Array;\n private length: number;\n private readonly limit: number;\n private truncatedFlag: boolean;\n private total: number;\n\n constructor(limit: number) {\n const normalized = Number.isFinite(limit) ? Math.max(0, limit) : 0;\n const initialCap = Math.min(normalized, 32 * 1024);\n this.buffer = new Uint8Array(initialCap);\n this.length = 0;\n this.limit = normalized;\n this.truncatedFlag = false;\n this.total = 0;\n }\n\n bytes(): Uint8Array {\n return this.buffer.slice(0, this.length);\n }\n\n capturedBytes(): number {\n return this.length;\n }\n\n totalBytes(): number {\n return this.total;\n }\n\n truncated(): boolean {\n return this.truncatedFlag;\n }\n\n write(chunk: Uint8Array): void {\n if (!chunk || chunk.length === 0) {\n return;\n }\n\n this.total += chunk.length;\n if (this.limit <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const remaining = this.limit - this.length;\n if (remaining <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const toCopy = Math.min(remaining, chunk.length);\n this.ensureCapacity(this.length + toCopy);\n this.buffer.set(chunk.subarray(0, toCopy), this.length);\n this.length += toCopy;\n if (toCopy < chunk.length) {\n this.truncatedFlag = true;\n }\n }\n\n private ensureCapacity(size: number): void {\n if (this.buffer.length >= size) {\n return;\n }\n\n let nextSize = this.buffer.length;\n if (nextSize === 0) {\n nextSize = 1;\n }\n while (nextSize < size) {\n nextSize *= 2;\n }\n if (nextSize > this.limit) {\n nextSize = this.limit;\n }\n const next = new Uint8Array(nextSize);\n next.set(this.buffer.subarray(0, this.length));\n this.buffer = next;\n }\n}\n","export type HeaderCapture = {\n headers: Record<string, string | string[]>;\n truncated: boolean;\n};\n\nexport function headerValuesFromNodeHeaders(\n headers: Record<string, string | string[] | number | undefined>,\n): Record<string, string | string[]> {\n const result: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n if (value == null) {\n continue;\n }\n const name = key.trim();\n if (!name) {\n continue;\n }\n if (Array.isArray(value)) {\n const entries = value.map((item) => `${item}`);\n if (entries.length > 0) {\n result[name] = entries.length === 1 ? entries[0]! : entries;\n }\n } else {\n result[name] = `${value}`;\n }\n }\n return Object.keys(result).length === 0 ? {} : result;\n}\n\nexport function headerValuesFromFetchHeaders(headers: Headers): Record<string, string | string[]> {\n return headerValuesFromFetchHeadersWithLimit(headers, Number.POSITIVE_INFINITY).headers;\n}\n\nexport function headerValuesFromFetchHeadersWithLimit(\n headers: Headers,\n maxBytes: number,\n): HeaderCapture {\n const result: Record<string, string | string[]> = {};\n let truncated = false;\n let remaining = Number.isFinite(maxBytes) ? Math.max(0, maxBytes) : Number.POSITIVE_INFINITY;\n const setCookie = getSetCookie(headers);\n if (setCookie) {\n const values = takeHeaderValues('set-cookie', setCookie, remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result['set-cookie'] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n }\n\n headers.forEach((value, key) => {\n const name = key.trim();\n if (!name) {\n return;\n }\n if (name.toLowerCase() === 'set-cookie' && setCookie) {\n return;\n }\n const values = takeHeaderValues(name, [value], remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result[name] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n });\n\n return {\n headers: Object.keys(result).length === 0 ? {} : result,\n truncated,\n };\n}\n\nexport function headerTokenList(values: string[] | string | undefined): string[] {\n if (!values) {\n return [];\n }\n if (Array.isArray(values)) {\n return splitTokens(values);\n }\n return splitTokens([values]);\n}\n\nfunction splitTokens(values: string[]): string[] {\n const tokens: string[] = [];\n for (const value of values) {\n if (!value) {\n continue;\n }\n for (const part of value.split(',')) {\n const trimmed = part.trim();\n if (trimmed) {\n tokens.push(trimmed);\n }\n }\n }\n return tokens;\n}\n\nfunction getSetCookie(headers: Headers): string[] | null {\n const maybe = headers as Headers & { getSetCookie?: () => string[] };\n if (typeof maybe.getSetCookie === 'function') {\n const values = maybe.getSetCookie();\n return values.length > 0 ? values : null;\n }\n return null;\n}\n\nfunction takeHeaderValues(\n name: string,\n values: string[],\n remaining: number,\n): { values: string[]; remaining: number; truncated: boolean } {\n if (remaining <= 0) {\n return { remaining: 0, truncated: true, values: [] };\n }\n\n const taken: string[] = [];\n let used = 0;\n for (const value of values) {\n if (!value) {\n continue;\n }\n const size = name.length + value.length;\n if (used + size > remaining) {\n return { remaining: Math.max(0, remaining - used), truncated: true, values: taken };\n }\n used += size;\n taken.push(value);\n }\n\n return { remaining: Math.max(0, remaining - used), truncated: false, values: taken };\n}\n","import { headerTokenList } from './headers';\n\ntype HeaderValues = Record<string, string | string[]>;\n\nexport function isWebsocketUpgrade(\n statusCode: number,\n requestHeaders: HeaderValues | undefined,\n responseHeaders: HeaderValues | undefined,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasToken(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasToken(requestHeaders, 'upgrade', 'websocket');\n}\n\nexport function isWebsocketUpgradeFetch(\n statusCode: number,\n requestHeaders: Headers,\n responseHeaders: Headers,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasTokenFetch(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasTokenFetch(requestHeaders, 'upgrade', 'websocket');\n}\n\nfunction headerHasToken(headers: HeaderValues | undefined, name: string, token: string): boolean {\n if (!headers) {\n return false;\n }\n const values = headers[name] ?? headers[name.toLowerCase()] ?? headers[name.toUpperCase()];\n if (!values) {\n return false;\n }\n const tokens = headerTokenList(values);\n return tokens.some((value) => value.toLowerCase() === token.toLowerCase());\n}\n\nfunction headerHasTokenFetch(headers: Headers, name: string, token: string): boolean {\n const value = headers.get(name);\n if (!value) {\n return false;\n }\n return value.split(',').some((part) => part.trim().toLowerCase() === token.toLowerCase());\n}\n","const utf8Decoder =\n typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8', { fatal: true }) : null;\nconst utf8DecoderLenient = typeof TextDecoder !== 'undefined' ? new TextDecoder('utf-8') : null;\nconst maybeBuffer = (\n globalThis as typeof globalThis & {\n Buffer?: { from(data: Uint8Array): { toString(encoding?: string): string } };\n }\n).Buffer;\n\nexport function encodeBase64(bytes: Uint8Array): string {\n if (maybeBuffer) {\n return maybeBuffer.from(bytes).toString('base64');\n }\n let binary = '';\n for (let i = 0; i < bytes.length; i += 1) {\n const byte = bytes[i];\n if (byte === undefined) {\n continue;\n }\n binary += String.fromCharCode(byte);\n }\n if (typeof btoa !== 'undefined') {\n return btoa(binary);\n }\n return '';\n}\n\nexport function isValidUtf8(bytes: Uint8Array): boolean {\n if (!utf8Decoder) {\n return false;\n }\n try {\n utf8Decoder.decode(bytes);\n return true;\n } catch {\n return false;\n }\n}\n\nexport function decodeUtf8(bytes: Uint8Array): string {\n if (utf8DecoderLenient) {\n return utf8DecoderLenient.decode(bytes);\n }\n if (maybeBuffer) {\n return maybeBuffer.from(bytes).toString('utf8');\n }\n return '';\n}\n","import type { CapturedBody } from './types';\nimport { decodeUtf8, encodeBase64, isValidUtf8 } from './encoding';\n\n// eslint-disable-next-line no-control-regex\nconst controlChars = /[\\x00-\\x1F\\x7F]/g;\n\nexport function sanitizeLogString(value: string): string {\n if (!value) {\n return value;\n }\n return value.replace(controlChars, '');\n}\n\nexport function sanitizeHeaderValues(\n headers: Record<string, string | string[]> | undefined,\n): Record<string, string | string[]> | undefined {\n if (!headers) {\n return undefined;\n }\n\n const sanitized: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n const name = sanitizeLogString(key);\n if (Array.isArray(value)) {\n sanitized[name] = value.map((entry) => sanitizeLogString(entry));\n } else {\n sanitized[name] = sanitizeLogString(value);\n }\n }\n return sanitized;\n}\n\nexport function makeCapturedBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64',\n): CapturedBody | undefined {\n if (!bytes) {\n return undefined;\n }\n\n if (mode === 'base64') {\n return {\n bytes: totalBytes,\n encoding: 'base64',\n truncated,\n value: encodeBase64(bytes),\n };\n }\n\n if (isValidUtf8(bytes)) {\n return {\n bytes: totalBytes,\n encoding: 'utf8',\n truncated,\n value: decodeUtf8(bytes),\n };\n }\n\n return {\n bytes: totalBytes,\n encoding: 'base64',\n truncated,\n value: encodeBase64(bytes),\n };\n}\n","import type { Logger, LogLevel } from './types';\n\nconst logLevelOrder: Record<LogLevel, number> = {\n debug: 10,\n info: 20,\n warn: 30,\n error: 40,\n};\n\nexport function logWithLevel(\n logger: Logger,\n level: LogLevel,\n threshold: LogLevel,\n message: string,\n fields?: Record<string, unknown>,\n): void {\n if (logLevelOrder[level] < logLevelOrder[threshold]) {\n return;\n }\n\n const fn =\n logger[level] ?? logger.warn ?? logger.info ?? logger.debug ?? logger.error ?? console.log;\n\n try {\n fn.call(logger, message, fields);\n } catch {\n // Logging should never disrupt instrumentation.\n }\n}\n","/**\n * Base48 encoding with a vowel-free alphabet to reduce the risk of generating\n * profanity-like substrings in time-ordered identifiers while staying compact.\n * Digits that are commonly read as vowels (0, 1, 3, 4) are excluded to avoid\n * leetspeak-style false positives. The alphabet is ordered by ASCII to preserve\n * lexicographic ordering of fixed-length encodings.\n */\nconst base48AlphabetLex = '256789BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz';\nconst base48Zero = base48AlphabetLex.charAt(0);\nconst base48Regex = /^[256789BCDFGHJKLMNPQRSTVWXYZbcdfghjklmnpqrstvwxyz]*$/;\n\nconst maxChunkBytes = 32;\nconst chunkToEncodedLength = new Map<number, number>();\nconst encodedLengthToChunk = new Map<number, number>();\n\nfor (let size = 1; size <= maxChunkBytes; size += 1) {\n const encodedLength = Math.ceil((size * 8) / Math.log2(48));\n chunkToEncodedLength.set(size, encodedLength);\n encodedLengthToChunk.set(encodedLength, size);\n}\n\nconst maxEncodedChunk = chunkToEncodedLength.get(maxChunkBytes)!;\n\nfunction encodeChunk(bytes: Uint8Array, size: number): string {\n let value = 0n;\n for (const byte of bytes) {\n value = (value << 8n) | BigInt(byte);\n }\n\n let encoded = '';\n if (value === 0n) {\n encoded = base48Zero;\n } else {\n while (value > 0n) {\n const mod = value % 48n;\n encoded = base48AlphabetLex[Number(mod)] + encoded;\n value /= 48n;\n }\n }\n\n const targetLength = chunkToEncodedLength.get(size);\n if (!targetLength) {\n throw new Error(`base48: unsupported chunk size ${size}`);\n }\n return encoded.padStart(targetLength, base48Zero);\n}\n\nfunction decodeChunk(value: string, size: number): Uint8Array {\n let n = 0n;\n for (const char of value) {\n const index = base48AlphabetLex.indexOf(char);\n if (index === -1) {\n throw new Error('base48: invalid character');\n }\n n = n * 48n + BigInt(index);\n }\n\n const maxValue = 2n ** BigInt(size * 8) - 1n;\n if (n > maxValue) {\n throw new Error('base48: invalid length');\n }\n\n const buffer = new Uint8Array(size);\n for (let i = size - 1; i >= 0; i -= 1) {\n buffer[i] = Number(n & 0xffn);\n n >>= 8n;\n }\n return buffer;\n}\n\nexport function encodeBase48Lex(buffer: Uint8Array): string {\n if (buffer.length === 0) {\n return '';\n }\n\n let result = '';\n for (let offset = 0; offset < buffer.length; ) {\n const remaining = buffer.length - offset;\n const size = remaining >= maxChunkBytes ? maxChunkBytes : remaining;\n result += encodeChunk(buffer.slice(offset, offset + size), size);\n offset += size;\n }\n return result;\n}\n\nexport function decodeBase48Lex(value: string): Uint8Array {\n if (!value) {\n return new Uint8Array();\n }\n if (!base48Regex.test(value)) {\n throw new Error('base48: invalid string');\n }\n\n let totalBytes = 0;\n for (let offset = 0; offset < value.length; ) {\n const remaining = value.length - offset;\n const chunkLength = remaining >= maxEncodedChunk ? maxEncodedChunk : remaining;\n const size = encodedLengthToChunk.get(chunkLength);\n if (!size) {\n throw new Error('base48: invalid length');\n }\n totalBytes += size;\n offset += chunkLength;\n }\n\n const result = new Uint8Array(totalBytes);\n let cursor = 0;\n for (let offset = 0; offset < value.length; ) {\n const remaining = value.length - offset;\n const chunkLength = remaining >= maxEncodedChunk ? maxEncodedChunk : remaining;\n const size = encodedLengthToChunk.get(chunkLength);\n if (!size) {\n throw new Error('base48: invalid length');\n }\n const chunk = decodeChunk(value.slice(offset, offset + chunkLength), size);\n result.set(chunk, cursor);\n cursor += size;\n offset += chunkLength;\n }\n return result;\n}\n","const base62AlphabetLex = '0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz';\nconst base62Zero = base62AlphabetLex.charAt(0);\nconst base62Regex = /^[0-9A-Za-z]*$/;\n\nconst maxChunkBytes = 32;\nconst chunkToEncodedLength = new Map<number, number>();\nconst encodedLengthToChunk = new Map<number, number>();\n\nfor (let size = 1; size <= maxChunkBytes; size += 1) {\n const encodedLength = Math.ceil((size * 8) / Math.log2(62));\n chunkToEncodedLength.set(size, encodedLength);\n encodedLengthToChunk.set(encodedLength, size);\n}\n\nconst maxEncodedChunk = chunkToEncodedLength.get(maxChunkBytes)!;\n\nfunction encodeChunk(bytes: Uint8Array, size: number): string {\n let value = 0n;\n for (const byte of bytes) {\n value = (value << 8n) | BigInt(byte);\n }\n\n let encoded = '';\n if (value === 0n) {\n encoded = base62Zero;\n } else {\n while (value > 0n) {\n const mod = value % 62n;\n encoded = base62AlphabetLex[Number(mod)] + encoded;\n value /= 62n;\n }\n }\n\n const targetLength = chunkToEncodedLength.get(size);\n if (!targetLength) {\n throw new Error(`base62: unsupported chunk size ${size}`);\n }\n return encoded.padStart(targetLength, base62Zero);\n}\n\nfunction decodeChunk(value: string, size: number): Uint8Array {\n let n = 0n;\n for (const char of value) {\n const index = base62AlphabetLex.indexOf(char);\n if (index === -1) {\n throw new Error('base62: invalid character');\n }\n n = n * 62n + BigInt(index);\n }\n\n const maxValue = 2n ** BigInt(size * 8) - 1n;\n if (n > maxValue) {\n throw new Error('base62: invalid length');\n }\n\n const buffer = new Uint8Array(size);\n for (let i = size - 1; i >= 0; i -= 1) {\n buffer[i] = Number(n & 0xffn);\n n >>= 8n;\n }\n return buffer;\n}\n\nexport function encodeBase62Lex(buffer: Uint8Array): string {\n if (buffer.length === 0) {\n return '';\n }\n\n let result = '';\n for (let offset = 0; offset < buffer.length; ) {\n const remaining = buffer.length - offset;\n const size = remaining >= maxChunkBytes ? maxChunkBytes : remaining;\n result += encodeChunk(buffer.slice(offset, offset + size), size);\n offset += size;\n }\n return result;\n}\n\nexport function decodeBase62Lex(value: string): Uint8Array {\n if (!value) {\n return new Uint8Array();\n }\n if (!base62Regex.test(value)) {\n throw new Error('base62: invalid string');\n }\n\n let totalBytes = 0;\n for (let offset = 0; offset < value.length; ) {\n const remaining = value.length - offset;\n const chunkLength = remaining >= maxEncodedChunk ? maxEncodedChunk : remaining;\n const size = encodedLengthToChunk.get(chunkLength);\n if (!size) {\n throw new Error('base62: invalid length');\n }\n totalBytes += size;\n offset += chunkLength;\n }\n\n const result = new Uint8Array(totalBytes);\n let cursor = 0;\n for (let offset = 0; offset < value.length; ) {\n const remaining = value.length - offset;\n const chunkLength = remaining >= maxEncodedChunk ? maxEncodedChunk : remaining;\n const size = encodedLengthToChunk.get(chunkLength);\n if (!size) {\n throw new Error('base62: invalid length');\n }\n const chunk = decodeChunk(value.slice(offset, offset + chunkLength), size);\n result.set(chunk, cursor);\n cursor += size;\n offset += chunkLength;\n }\n return result;\n}\n","import { encodeBase48Lex } from './base48';\nimport { encodeBase62Lex } from './base62';\n\nconst requestIdPrefix = 'req_';\n\nfunction uuidv7Bytes(): Uint8Array {\n const bytes = new Uint8Array(16);\n crypto.getRandomValues(bytes);\n\n // Encode timestamp in first 48 bits\n const timestamp = BigInt(Date.now());\n bytes[0] = Number((timestamp >> 40n) & 0xffn);\n bytes[1] = Number((timestamp >> 32n) & 0xffn);\n bytes[2] = Number((timestamp >> 24n) & 0xffn);\n bytes[3] = Number((timestamp >> 16n) & 0xffn);\n bytes[4] = Number((timestamp >> 8n) & 0xffn);\n bytes[5] = Number(timestamp & 0xffn);\n\n // Set version (7) and variant (RFC 4122)\n const byte6 = bytes[6] ?? 0;\n const byte8 = bytes[8] ?? 0;\n bytes[6] = (byte6 & 0x0f) | 0x70;\n bytes[8] = (byte8 & 0x3f) | 0x80;\n\n return bytes;\n}\n\n/**\n * Generates a UUIDv7 string.\n * Uses crypto.getRandomValues which is available in all modern JS runtimes\n * (browsers, Node.js 15+, Deno, Bun, Cloudflare Workers, Vercel Edge, etc.)\n */\nexport function uuidv7(): string {\n const bytes = uuidv7Bytes();\n const hex = Array.from(bytes, (b) => b.toString(16).padStart(2, '0'));\n return `${hex.slice(0, 4).join('')}-${hex.slice(4, 6).join('')}-${hex.slice(6, 8).join('')}-${hex.slice(8, 10).join('')}-${hex.slice(10).join('')}`;\n}\n\nexport function uuidv7base62(): string {\n return encodeBase62Lex(uuidv7Bytes());\n}\n\nexport function uuidv7base48(): string {\n return encodeBase48Lex(uuidv7Bytes());\n}\n\nexport function generateRequestId(): string {\n return `${requestIdPrefix}${uuidv7base48()}`;\n}\n"],"mappings":"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","names":["maxChunkBytes","chunkToEncodedLength","encodedLengthToChunk","maxEncodedChunk","encodeChunk","maxChunkBytes","encodeChunk"]}
@@ -1,4 +1,4 @@
1
- import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-CB9CGfc5.cjs';
1
+ import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-Z1nirh-F.cjs';
2
2
  import '@opentelemetry/sdk-trace-base';
3
3
 
4
4
  declare function makeCapturedBody(bytes: Uint8Array | undefined, totalBytes: number, truncated: boolean, mode: 'text' | 'base64'): CapturedBody | undefined;
@@ -33,6 +33,16 @@ declare function isWebsocketUpgradeFetch(statusCode: number, requestHeaders: Hea
33
33
 
34
34
  declare function logWithLevel(logger: Logger, level: LogLevel, threshold: LogLevel, message: string, fields?: Record<string, unknown>): void;
35
35
 
36
+ /**
37
+ * Generates a UUIDv7 string.
38
+ * Uses crypto.getRandomValues which is available in all modern JS runtimes
39
+ * (browsers, Node.js 15+, Deno, Bun, Cloudflare Workers, Vercel Edge, etc.)
40
+ */
41
+ declare function uuidv7(): string;
42
+ declare function uuidv7base62(): string;
43
+ declare function uuidv7base48(): string;
44
+ declare function generateRequestId(): string;
45
+
36
46
  declare function bindContextToObject(target: object, ctx: XrayContext): void;
37
47
  declare function getXrayContextFromObject(target: unknown): XrayContext | undefined;
38
48
  declare function setContextRoute(ctx: XrayContext, route: string): void;
@@ -40,4 +50,4 @@ declare function setContextRequestId(ctx: XrayContext, requestId: string): void;
40
50
  declare function setCaptureOverride(ctx: XrayContext, capture: Partial<CaptureConfig> | undefined): void;
41
51
  declare function setRedactionOverride(ctx: XrayContext, redaction: Partial<RedactionConfig> | undefined): void;
42
52
 
43
- export { LimitedBuffer, bindContextToObject, getXrayContextFromObject, headerTokenList, headerValuesFromFetchHeaders, headerValuesFromFetchHeadersWithLimit, headerValuesFromNodeHeaders, isWebsocketUpgrade, isWebsocketUpgradeFetch, logWithLevel, makeCapturedBody, setCaptureOverride, setContextRequestId, setContextRoute, setRedactionOverride };
53
+ export { LimitedBuffer, bindContextToObject, generateRequestId, getXrayContextFromObject, headerTokenList, headerValuesFromFetchHeaders, headerValuesFromFetchHeadersWithLimit, headerValuesFromNodeHeaders, isWebsocketUpgrade, isWebsocketUpgradeFetch, logWithLevel, makeCapturedBody, setCaptureOverride, setContextRequestId, setContextRoute, setRedactionOverride, uuidv7, uuidv7base48, uuidv7base62 };
@@ -1,4 +1,4 @@
1
- import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-CB9CGfc5.js';
1
+ import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-Z1nirh-F.js';
2
2
  import '@opentelemetry/sdk-trace-base';
3
3
 
4
4
  declare function makeCapturedBody(bytes: Uint8Array | undefined, totalBytes: number, truncated: boolean, mode: 'text' | 'base64'): CapturedBody | undefined;
@@ -33,6 +33,16 @@ declare function isWebsocketUpgradeFetch(statusCode: number, requestHeaders: Hea
33
33
 
34
34
  declare function logWithLevel(logger: Logger, level: LogLevel, threshold: LogLevel, message: string, fields?: Record<string, unknown>): void;
35
35
 
36
+ /**
37
+ * Generates a UUIDv7 string.
38
+ * Uses crypto.getRandomValues which is available in all modern JS runtimes
39
+ * (browsers, Node.js 15+, Deno, Bun, Cloudflare Workers, Vercel Edge, etc.)
40
+ */
41
+ declare function uuidv7(): string;
42
+ declare function uuidv7base62(): string;
43
+ declare function uuidv7base48(): string;
44
+ declare function generateRequestId(): string;
45
+
36
46
  declare function bindContextToObject(target: object, ctx: XrayContext): void;
37
47
  declare function getXrayContextFromObject(target: unknown): XrayContext | undefined;
38
48
  declare function setContextRoute(ctx: XrayContext, route: string): void;
@@ -40,4 +50,4 @@ declare function setContextRequestId(ctx: XrayContext, requestId: string): void;
40
50
  declare function setCaptureOverride(ctx: XrayContext, capture: Partial<CaptureConfig> | undefined): void;
41
51
  declare function setRedactionOverride(ctx: XrayContext, redaction: Partial<RedactionConfig> | undefined): void;
42
52
 
43
- export { LimitedBuffer, bindContextToObject, getXrayContextFromObject, headerTokenList, headerValuesFromFetchHeaders, headerValuesFromFetchHeadersWithLimit, headerValuesFromNodeHeaders, isWebsocketUpgrade, isWebsocketUpgradeFetch, logWithLevel, makeCapturedBody, setCaptureOverride, setContextRequestId, setContextRoute, setRedactionOverride };
53
+ export { LimitedBuffer, bindContextToObject, generateRequestId, getXrayContextFromObject, headerTokenList, headerValuesFromFetchHeaders, headerValuesFromFetchHeadersWithLimit, headerValuesFromNodeHeaders, isWebsocketUpgrade, isWebsocketUpgradeFetch, logWithLevel, makeCapturedBody, setCaptureOverride, setContextRequestId, setContextRoute, setRedactionOverride, uuidv7, uuidv7base48, uuidv7base62 };
package/dist/internal.js CHANGED
@@ -1,10 +1,14 @@
1
1
  import {
2
2
  bindObject,
3
+ generateRequestId,
3
4
  getContextFromObject,
4
5
  getContextState,
5
6
  logWithLevel,
6
- makeCapturedBody
7
- } from "./chunk-XI5E6C7G.js";
7
+ makeCapturedBody,
8
+ uuidv7,
9
+ uuidv7base48,
10
+ uuidv7base62
11
+ } from "./chunk-3ILKJJIG.js";
8
12
 
9
13
  // src/limited_buffer.ts
10
14
  var LimitedBuffer = class {
@@ -267,6 +271,7 @@ function setRedactionOverride(ctx, redaction) {
267
271
  export {
268
272
  LimitedBuffer,
269
273
  bindContextToObject,
274
+ generateRequestId,
270
275
  getXrayContextFromObject,
271
276
  headerTokenList,
272
277
  headerValuesFromFetchHeaders,
@@ -279,6 +284,9 @@ export {
279
284
  setCaptureOverride,
280
285
  setContextRequestId,
281
286
  setContextRoute,
282
- setRedactionOverride
287
+ setRedactionOverride,
288
+ uuidv7,
289
+ uuidv7base48,
290
+ uuidv7base62
283
291
  };
284
292
  //# sourceMappingURL=internal.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/limited_buffer.ts","../src/headers.ts","../src/websocket.ts","../src/internal.ts"],"sourcesContent":["export class LimitedBuffer {\n private buffer: Uint8Array;\n private length: number;\n private readonly limit: number;\n private truncatedFlag: boolean;\n private total: number;\n\n constructor(limit: number) {\n const normalized = Number.isFinite(limit) ? Math.max(0, limit) : 0;\n const initialCap = Math.min(normalized, 32 * 1024);\n this.buffer = new Uint8Array(initialCap);\n this.length = 0;\n this.limit = normalized;\n this.truncatedFlag = false;\n this.total = 0;\n }\n\n bytes(): Uint8Array {\n return this.buffer.slice(0, this.length);\n }\n\n capturedBytes(): number {\n return this.length;\n }\n\n totalBytes(): number {\n return this.total;\n }\n\n truncated(): boolean {\n return this.truncatedFlag;\n }\n\n write(chunk: Uint8Array): void {\n if (!chunk || chunk.length === 0) {\n return;\n }\n\n this.total += chunk.length;\n if (this.limit <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const remaining = this.limit - this.length;\n if (remaining <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const toCopy = Math.min(remaining, chunk.length);\n this.ensureCapacity(this.length + toCopy);\n this.buffer.set(chunk.subarray(0, toCopy), this.length);\n this.length += toCopy;\n if (toCopy < chunk.length) {\n this.truncatedFlag = true;\n }\n }\n\n private ensureCapacity(size: number): void {\n if (this.buffer.length >= size) {\n return;\n }\n\n let nextSize = this.buffer.length;\n if (nextSize === 0) {\n nextSize = 1;\n }\n while (nextSize < size) {\n nextSize *= 2;\n }\n if (nextSize > this.limit) {\n nextSize = this.limit;\n }\n const next = new Uint8Array(nextSize);\n next.set(this.buffer.subarray(0, this.length));\n this.buffer = next;\n }\n}\n","export type HeaderCapture = {\n headers: Record<string, string | string[]>;\n truncated: boolean;\n};\n\nexport function headerValuesFromNodeHeaders(\n headers: Record<string, string | string[] | number | undefined>,\n): Record<string, string | string[]> {\n const result: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n if (value == null) {\n continue;\n }\n const name = key.trim();\n if (!name) {\n continue;\n }\n if (Array.isArray(value)) {\n const entries = value.map((item) => `${item}`);\n if (entries.length > 0) {\n result[name] = entries.length === 1 ? entries[0]! : entries;\n }\n } else {\n result[name] = `${value}`;\n }\n }\n return Object.keys(result).length === 0 ? {} : result;\n}\n\nexport function headerValuesFromFetchHeaders(headers: Headers): Record<string, string | string[]> {\n return headerValuesFromFetchHeadersWithLimit(headers, Number.POSITIVE_INFINITY).headers;\n}\n\nexport function headerValuesFromFetchHeadersWithLimit(\n headers: Headers,\n maxBytes: number,\n): HeaderCapture {\n const result: Record<string, string | string[]> = {};\n let truncated = false;\n let remaining = Number.isFinite(maxBytes) ? Math.max(0, maxBytes) : Number.POSITIVE_INFINITY;\n const setCookie = getSetCookie(headers);\n if (setCookie) {\n const values = takeHeaderValues('set-cookie', setCookie, remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result['set-cookie'] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n }\n\n headers.forEach((value, key) => {\n const name = key.trim();\n if (!name) {\n return;\n }\n if (name.toLowerCase() === 'set-cookie' && setCookie) {\n return;\n }\n const values = takeHeaderValues(name, [value], remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result[name] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n });\n\n return {\n headers: Object.keys(result).length === 0 ? {} : result,\n truncated,\n };\n}\n\nexport function headerTokenList(values: string[] | string | undefined): string[] {\n if (!values) {\n return [];\n }\n if (Array.isArray(values)) {\n return splitTokens(values);\n }\n return splitTokens([values]);\n}\n\nfunction splitTokens(values: string[]): string[] {\n const tokens: string[] = [];\n for (const value of values) {\n if (!value) {\n continue;\n }\n for (const part of value.split(',')) {\n const trimmed = part.trim();\n if (trimmed) {\n tokens.push(trimmed);\n }\n }\n }\n return tokens;\n}\n\nfunction getSetCookie(headers: Headers): string[] | null {\n const maybe = headers as Headers & { getSetCookie?: () => string[] };\n if (typeof maybe.getSetCookie === 'function') {\n const values = maybe.getSetCookie();\n return values.length > 0 ? values : null;\n }\n return null;\n}\n\nfunction takeHeaderValues(\n name: string,\n values: string[],\n remaining: number,\n): { values: string[]; remaining: number; truncated: boolean } {\n if (remaining <= 0) {\n return { remaining: 0, truncated: true, values: [] };\n }\n\n const taken: string[] = [];\n let used = 0;\n for (const value of values) {\n if (!value) {\n continue;\n }\n const size = name.length + value.length;\n if (used + size > remaining) {\n return { remaining: Math.max(0, remaining - used), truncated: true, values: taken };\n }\n used += size;\n taken.push(value);\n }\n\n return { remaining: Math.max(0, remaining - used), truncated: false, values: taken };\n}\n","import { headerTokenList } from './headers';\n\ntype HeaderValues = Record<string, string | string[]>;\n\nexport function isWebsocketUpgrade(\n statusCode: number,\n requestHeaders: HeaderValues | undefined,\n responseHeaders: HeaderValues | undefined,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasToken(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasToken(requestHeaders, 'upgrade', 'websocket');\n}\n\nexport function isWebsocketUpgradeFetch(\n statusCode: number,\n requestHeaders: Headers,\n responseHeaders: Headers,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasTokenFetch(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasTokenFetch(requestHeaders, 'upgrade', 'websocket');\n}\n\nfunction headerHasToken(headers: HeaderValues | undefined, name: string, token: string): boolean {\n if (!headers) {\n return false;\n }\n const values = headers[name] ?? headers[name.toLowerCase()] ?? headers[name.toUpperCase()];\n if (!values) {\n return false;\n }\n const tokens = headerTokenList(values);\n return tokens.some((value) => value.toLowerCase() === token.toLowerCase());\n}\n\nfunction headerHasTokenFetch(headers: Headers, name: string, token: string): boolean {\n const value = headers.get(name);\n if (!value) {\n return false;\n }\n return value.split(',').some((part) => part.trim().toLowerCase() === token.toLowerCase());\n}\n","import type { CaptureConfig, RedactionConfig } from './config';\nimport type { XrayContext } from './types';\nimport { bindObject, getContextFromObject, getContextState } from './state';\n\nexport { LimitedBuffer } from './limited_buffer';\nexport {\n headerValuesFromFetchHeaders,\n headerValuesFromFetchHeadersWithLimit,\n headerValuesFromNodeHeaders,\n headerTokenList,\n} from './headers';\nexport { isWebsocketUpgrade, isWebsocketUpgradeFetch } from './websocket';\nexport { makeCapturedBody } from './request_log';\nexport { logWithLevel } from './logger';\n\nexport function bindContextToObject(target: object, ctx: XrayContext): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n bindObject(target, state);\n}\n\nexport function getXrayContextFromObject(target: unknown): XrayContext | undefined {\n return getContextFromObject(target);\n}\n\nexport function setContextRoute(ctx: XrayContext, route: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n const normalized =\n state.config.route.normalize && state.config.route.normalizer\n ? state.config.route.normalizer(route)\n : route;\n state.request.route = normalized;\n}\n\nexport function setContextRequestId(ctx: XrayContext, requestId: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n state.request.requestId = requestId;\n state.context.requestId = requestId;\n}\n\nexport function setCaptureOverride(\n ctx: XrayContext,\n capture: Partial<CaptureConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !capture) {\n return;\n }\n state.captureOverride = capture;\n}\n\nexport function setRedactionOverride(\n ctx: XrayContext,\n redaction: Partial<RedactionConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !redaction) {\n return;\n }\n state.redactionOverride = redaction;\n}\n"],"mappings":";;;;;;;;;AAAO,IAAM,gBAAN,MAAoB;AAAA,EAOzB,YAAY,OAAe;AACzB,UAAM,aAAa,OAAO,SAAS,KAAK,IAAI,KAAK,IAAI,GAAG,KAAK,IAAI;AACjE,UAAM,aAAa,KAAK,IAAI,YAAY,KAAK,IAAI;AACjD,SAAK,SAAS,IAAI,WAAW,UAAU;AACvC,SAAK,SAAS;AACd,SAAK,QAAQ;AACb,SAAK,gBAAgB;AACrB,SAAK,QAAQ;AAAA,EACf;AAAA,EAEA,QAAoB;AAClB,WAAO,KAAK,OAAO,MAAM,GAAG,KAAK,MAAM;AAAA,EACzC;AAAA,EAEA,gBAAwB;AACtB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,aAAqB;AACnB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,YAAqB;AACnB,WAAO,KAAK;AAAA,EACd;AAAA,EAEA,MAAM,OAAyB;AAC7B,QAAI,CAAC,SAAS,MAAM,WAAW,GAAG;AAChC;AAAA,IACF;AAEA,SAAK,SAAS,MAAM;AACpB,QAAI,KAAK,SAAS,GAAG;AACnB,WAAK,gBAAgB;AACrB;AAAA,IACF;AAEA,UAAM,YAAY,KAAK,QAAQ,KAAK;AACpC,QAAI,aAAa,GAAG;AAClB,WAAK,gBAAgB;AACrB;AAAA,IACF;AAEA,UAAM,SAAS,KAAK,IAAI,WAAW,MAAM,MAAM;AAC/C,SAAK,eAAe,KAAK,SAAS,MAAM;AACxC,SAAK,OAAO,IAAI,MAAM,SAAS,GAAG,MAAM,GAAG,KAAK,MAAM;AACtD,SAAK,UAAU;AACf,QAAI,SAAS,MAAM,QAAQ;AACzB,WAAK,gBAAgB;AAAA,IACvB;AAAA,EACF;AAAA,EAEQ,eAAe,MAAoB;AACzC,QAAI,KAAK,OAAO,UAAU,MAAM;AAC9B;AAAA,IACF;AAEA,QAAI,WAAW,KAAK,OAAO;AAC3B,QAAI,aAAa,GAAG;AAClB,iBAAW;AAAA,IACb;AACA,WAAO,WAAW,MAAM;AACtB,kBAAY;AAAA,IACd;AACA,QAAI,WAAW,KAAK,OAAO;AACzB,iBAAW,KAAK;AAAA,IAClB;AACA,UAAM,OAAO,IAAI,WAAW,QAAQ;AACpC,SAAK,IAAI,KAAK,OAAO,SAAS,GAAG,KAAK,MAAM,CAAC;AAC7C,SAAK,SAAS;AAAA,EAChB;AACF;;;ACzEO,SAAS,4BACd,SACmC;AACnC,QAAM,SAA4C,CAAC;AACnD,aAAW,CAAC,KAAK,KAAK,KAAK,OAAO,QAAQ,OAAO,GAAG;AAClD,QAAI,SAAS,MAAM;AACjB;AAAA,IACF;AACA,UAAM,OAAO,IAAI,KAAK;AACtB,QAAI,CAAC,MAAM;AACT;AAAA,IACF;AACA,QAAI,MAAM,QAAQ,KAAK,GAAG;AACxB,YAAM,UAAU,MAAM,IAAI,CAAC,SAAS,GAAG,IAAI,EAAE;AAC7C,UAAI,QAAQ,SAAS,GAAG;AACtB,eAAO,IAAI,IAAI,QAAQ,WAAW,IAAI,QAAQ,CAAC,IAAK;AAAA,MACtD;AAAA,IACF,OAAO;AACL,aAAO,IAAI,IAAI,GAAG,KAAK;AAAA,IACzB;AAAA,EACF;AACA,SAAO,OAAO,KAAK,MAAM,EAAE,WAAW,IAAI,CAAC,IAAI;AACjD;AAEO,SAAS,6BAA6B,SAAqD;AAChG,SAAO,sCAAsC,SAAS,OAAO,iBAAiB,EAAE;AAClF;AAEO,SAAS,sCACd,SACA,UACe;AACf,QAAM,SAA4C,CAAC;AACnD,MAAI,YAAY;AAChB,MAAI,YAAY,OAAO,SAAS,QAAQ,IAAI,KAAK,IAAI,GAAG,QAAQ,IAAI,OAAO;AAC3E,QAAM,YAAY,aAAa,OAAO;AACtC,MAAI,WAAW;AACb,UAAM,SAAS,iBAAiB,cAAc,WAAW,SAAS;AAClE,gBAAY,OAAO;AACnB,QAAI,OAAO,WAAW;AACpB,kBAAY;AAAA,IACd;AACA,QAAI,OAAO,OAAO,SAAS,GAAG;AAC5B,aAAO,YAAY,IAAI,OAAO,OAAO,WAAW,IAAI,OAAO,OAAO,CAAC,IAAK,OAAO;AAAA,IACjF;AAAA,EACF;AAEA,UAAQ,QAAQ,CAAC,OAAO,QAAQ;AAC9B,UAAM,OAAO,IAAI,KAAK;AACtB,QAAI,CAAC,MAAM;AACT;AAAA,IACF;AACA,QAAI,KAAK,YAAY,MAAM,gBAAgB,WAAW;AACpD;AAAA,IACF;AACA,UAAM,SAAS,iBAAiB,MAAM,CAAC,KAAK,GAAG,SAAS;AACxD,gBAAY,OAAO;AACnB,QAAI,OAAO,WAAW;AACpB,kBAAY;AAAA,IACd;AACA,QAAI,OAAO,OAAO,SAAS,GAAG;AAC5B,aAAO,IAAI,IAAI,OAAO,OAAO,WAAW,IAAI,OAAO,OAAO,CAAC,IAAK,OAAO;AAAA,IACzE;AAAA,EACF,CAAC;AAED,SAAO;AAAA,IACL,SAAS,OAAO,KAAK,MAAM,EAAE,WAAW,IAAI,CAAC,IAAI;AAAA,IACjD;AAAA,EACF;AACF;AAEO,SAAS,gBAAgB,QAAiD;AAC/E,MAAI,CAAC,QAAQ;AACX,WAAO,CAAC;AAAA,EACV;AACA,MAAI,MAAM,QAAQ,MAAM,GAAG;AACzB,WAAO,YAAY,MAAM;AAAA,EAC3B;AACA,SAAO,YAAY,CAAC,MAAM,CAAC;AAC7B;AAEA,SAAS,YAAY,QAA4B;AAC/C,QAAM,SAAmB,CAAC;AAC1B,aAAW,SAAS,QAAQ;AAC1B,QAAI,CAAC,OAAO;AACV;AAAA,IACF;AACA,eAAW,QAAQ,MAAM,MAAM,GAAG,GAAG;AACnC,YAAM,UAAU,KAAK,KAAK;AAC1B,UAAI,SAAS;AACX,eAAO,KAAK,OAAO;AAAA,MACrB;AAAA,IACF;AAAA,EACF;AACA,SAAO;AACT;AAEA,SAAS,aAAa,SAAmC;AACvD,QAAM,QAAQ;AACd,MAAI,OAAO,MAAM,iBAAiB,YAAY;AAC5C,UAAM,SAAS,MAAM,aAAa;AAClC,WAAO,OAAO,SAAS,IAAI,SAAS;AAAA,EACtC;AACA,SAAO;AACT;AAEA,SAAS,iBACP,MACA,QACA,WAC6D;AAC7D,MAAI,aAAa,GAAG;AAClB,WAAO,EAAE,WAAW,GAAG,WAAW,MAAM,QAAQ,CAAC,EAAE;AAAA,EACrD;AAEA,QAAM,QAAkB,CAAC;AACzB,MAAI,OAAO;AACX,aAAW,SAAS,QAAQ;AAC1B,QAAI,CAAC,OAAO;AACV;AAAA,IACF;AACA,UAAM,OAAO,KAAK,SAAS,MAAM;AACjC,QAAI,OAAO,OAAO,WAAW;AAC3B,aAAO,EAAE,WAAW,KAAK,IAAI,GAAG,YAAY,IAAI,GAAG,WAAW,MAAM,QAAQ,MAAM;AAAA,IACpF;AACA,YAAQ;AACR,UAAM,KAAK,KAAK;AAAA,EAClB;AAEA,SAAO,EAAE,WAAW,KAAK,IAAI,GAAG,YAAY,IAAI,GAAG,WAAW,OAAO,QAAQ,MAAM;AACrF;;;ACnIO,SAAS,mBACd,YACA,gBACA,iBACS;AACT,MAAI,eAAe,KAAK;AACtB,WAAO;AAAA,EACT;AAEA,MAAI,eAAe,iBAAiB,WAAW,WAAW,GAAG;AAC3D,WAAO;AAAA,EACT;AACA,SAAO,eAAe,gBAAgB,WAAW,WAAW;AAC9D;AAEO,SAAS,wBACd,YACA,gBACA,iBACS;AACT,MAAI,eAAe,KAAK;AACtB,WAAO;AAAA,EACT;AAEA,MAAI,oBAAoB,iBAAiB,WAAW,WAAW,GAAG;AAChE,WAAO;AAAA,EACT;AACA,SAAO,oBAAoB,gBAAgB,WAAW,WAAW;AACnE;AAEA,SAAS,eAAe,SAAmC,MAAc,OAAwB;AAC/F,MAAI,CAAC,SAAS;AACZ,WAAO;AAAA,EACT;AACA,QAAM,SAAS,QAAQ,IAAI,KAAK,QAAQ,KAAK,YAAY,CAAC,KAAK,QAAQ,KAAK,YAAY,CAAC;AACzF,MAAI,CAAC,QAAQ;AACX,WAAO;AAAA,EACT;AACA,QAAM,SAAS,gBAAgB,MAAM;AACrC,SAAO,OAAO,KAAK,CAAC,UAAU,MAAM,YAAY,MAAM,MAAM,YAAY,CAAC;AAC3E;AAEA,SAAS,oBAAoB,SAAkB,MAAc,OAAwB;AACnF,QAAM,QAAQ,QAAQ,IAAI,IAAI;AAC9B,MAAI,CAAC,OAAO;AACV,WAAO;AAAA,EACT;AACA,SAAO,MAAM,MAAM,GAAG,EAAE,KAAK,CAAC,SAAS,KAAK,KAAK,EAAE,YAAY,MAAM,MAAM,YAAY,CAAC;AAC1F;;;ACrCO,SAAS,oBAAoB,QAAgB,KAAwB;AAC1E,QAAM,QAAQ,gBAAgB,GAAG;AACjC,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AACA,aAAW,QAAQ,KAAK;AAC1B;AAEO,SAAS,yBAAyB,QAA0C;AACjF,SAAO,qBAAqB,MAAM;AACpC;AAEO,SAAS,gBAAgB,KAAkB,OAAqB;AACrE,QAAM,QAAQ,gBAAgB,GAAG;AACjC,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AACA,QAAM,aACJ,MAAM,OAAO,MAAM,aAAa,MAAM,OAAO,MAAM,aAC/C,MAAM,OAAO,MAAM,WAAW,KAAK,IACnC;AACN,QAAM,QAAQ,QAAQ;AACxB;AAEO,SAAS,oBAAoB,KAAkB,WAAyB;AAC7E,QAAM,QAAQ,gBAAgB,GAAG;AACjC,MAAI,CAAC,OAAO;AACV;AAAA,EACF;AACA,QAAM,QAAQ,YAAY;AAC1B,QAAM,QAAQ,YAAY;AAC5B;AAEO,SAAS,mBACd,KACA,SACM;AACN,QAAM,QAAQ,gBAAgB,GAAG;AACjC,MAAI,CAAC,SAAS,CAAC,SAAS;AACtB;AAAA,EACF;AACA,QAAM,kBAAkB;AAC1B;AAEO,SAAS,qBACd,KACA,WACM;AACN,QAAM,QAAQ,gBAAgB,GAAG;AACjC,MAAI,CAAC,SAAS,CAAC,WAAW;AACxB;AAAA,EACF;AACA,QAAM,oBAAoB;AAC5B;","names":[]}
1
+ {"version":3,"sources":["../src/limited_buffer.ts","../src/headers.ts","../src/websocket.ts","../src/internal.ts"],"sourcesContent":["export class LimitedBuffer {\n private buffer: Uint8Array;\n private length: number;\n private readonly limit: number;\n private truncatedFlag: boolean;\n private total: number;\n\n constructor(limit: number) {\n const normalized = Number.isFinite(limit) ? Math.max(0, limit) : 0;\n const initialCap = Math.min(normalized, 32 * 1024);\n this.buffer = new Uint8Array(initialCap);\n this.length = 0;\n this.limit = normalized;\n this.truncatedFlag = false;\n this.total = 0;\n }\n\n bytes(): Uint8Array {\n return this.buffer.slice(0, this.length);\n }\n\n capturedBytes(): number {\n return this.length;\n }\n\n totalBytes(): number {\n return this.total;\n }\n\n truncated(): boolean {\n return this.truncatedFlag;\n }\n\n write(chunk: Uint8Array): void {\n if (!chunk || chunk.length === 0) {\n return;\n }\n\n this.total += chunk.length;\n if (this.limit <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const remaining = this.limit - this.length;\n if (remaining <= 0) {\n this.truncatedFlag = true;\n return;\n }\n\n const toCopy = Math.min(remaining, chunk.length);\n this.ensureCapacity(this.length + toCopy);\n this.buffer.set(chunk.subarray(0, toCopy), this.length);\n this.length += toCopy;\n if (toCopy < chunk.length) {\n this.truncatedFlag = true;\n }\n }\n\n private ensureCapacity(size: number): void {\n if (this.buffer.length >= size) {\n return;\n }\n\n let nextSize = this.buffer.length;\n if (nextSize === 0) {\n nextSize = 1;\n }\n while (nextSize < size) {\n nextSize *= 2;\n }\n if (nextSize > this.limit) {\n nextSize = this.limit;\n }\n const next = new Uint8Array(nextSize);\n next.set(this.buffer.subarray(0, this.length));\n this.buffer = next;\n }\n}\n","export type HeaderCapture = {\n headers: Record<string, string | string[]>;\n truncated: boolean;\n};\n\nexport function headerValuesFromNodeHeaders(\n headers: Record<string, string | string[] | number | undefined>,\n): Record<string, string | string[]> {\n const result: Record<string, string | string[]> = {};\n for (const [key, value] of Object.entries(headers)) {\n if (value == null) {\n continue;\n }\n const name = key.trim();\n if (!name) {\n continue;\n }\n if (Array.isArray(value)) {\n const entries = value.map((item) => `${item}`);\n if (entries.length > 0) {\n result[name] = entries.length === 1 ? entries[0]! : entries;\n }\n } else {\n result[name] = `${value}`;\n }\n }\n return Object.keys(result).length === 0 ? {} : result;\n}\n\nexport function headerValuesFromFetchHeaders(headers: Headers): Record<string, string | string[]> {\n return headerValuesFromFetchHeadersWithLimit(headers, Number.POSITIVE_INFINITY).headers;\n}\n\nexport function headerValuesFromFetchHeadersWithLimit(\n headers: Headers,\n maxBytes: number,\n): HeaderCapture {\n const result: Record<string, string | string[]> = {};\n let truncated = false;\n let remaining = Number.isFinite(maxBytes) ? Math.max(0, maxBytes) : Number.POSITIVE_INFINITY;\n const setCookie = getSetCookie(headers);\n if (setCookie) {\n const values = takeHeaderValues('set-cookie', setCookie, remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result['set-cookie'] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n }\n\n headers.forEach((value, key) => {\n const name = key.trim();\n if (!name) {\n return;\n }\n if (name.toLowerCase() === 'set-cookie' && setCookie) {\n return;\n }\n const values = takeHeaderValues(name, [value], remaining);\n remaining = values.remaining;\n if (values.truncated) {\n truncated = true;\n }\n if (values.values.length > 0) {\n result[name] = values.values.length === 1 ? values.values[0]! : values.values;\n }\n });\n\n return {\n headers: Object.keys(result).length === 0 ? {} : result,\n truncated,\n };\n}\n\nexport function headerTokenList(values: string[] | string | undefined): string[] {\n if (!values) {\n return [];\n }\n if (Array.isArray(values)) {\n return splitTokens(values);\n }\n return splitTokens([values]);\n}\n\nfunction splitTokens(values: string[]): string[] {\n const tokens: string[] = [];\n for (const value of values) {\n if (!value) {\n continue;\n }\n for (const part of value.split(',')) {\n const trimmed = part.trim();\n if (trimmed) {\n tokens.push(trimmed);\n }\n }\n }\n return tokens;\n}\n\nfunction getSetCookie(headers: Headers): string[] | null {\n const maybe = headers as Headers & { getSetCookie?: () => string[] };\n if (typeof maybe.getSetCookie === 'function') {\n const values = maybe.getSetCookie();\n return values.length > 0 ? values : null;\n }\n return null;\n}\n\nfunction takeHeaderValues(\n name: string,\n values: string[],\n remaining: number,\n): { values: string[]; remaining: number; truncated: boolean } {\n if (remaining <= 0) {\n return { remaining: 0, truncated: true, values: [] };\n }\n\n const taken: string[] = [];\n let used = 0;\n for (const value of values) {\n if (!value) {\n continue;\n }\n const size = name.length + value.length;\n if (used + size > remaining) {\n return { remaining: Math.max(0, remaining - used), truncated: true, values: taken };\n }\n used += size;\n taken.push(value);\n }\n\n return { remaining: Math.max(0, remaining - used), truncated: false, values: taken };\n}\n","import { headerTokenList } from './headers';\n\ntype HeaderValues = Record<string, string | string[]>;\n\nexport function isWebsocketUpgrade(\n statusCode: number,\n requestHeaders: HeaderValues | undefined,\n responseHeaders: HeaderValues | undefined,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasToken(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasToken(requestHeaders, 'upgrade', 'websocket');\n}\n\nexport function isWebsocketUpgradeFetch(\n statusCode: number,\n requestHeaders: Headers,\n responseHeaders: Headers,\n): boolean {\n if (statusCode !== 101) {\n return false;\n }\n\n if (headerHasTokenFetch(responseHeaders, 'upgrade', 'websocket')) {\n return true;\n }\n return headerHasTokenFetch(requestHeaders, 'upgrade', 'websocket');\n}\n\nfunction headerHasToken(headers: HeaderValues | undefined, name: string, token: string): boolean {\n if (!headers) {\n return false;\n }\n const values = headers[name] ?? headers[name.toLowerCase()] ?? headers[name.toUpperCase()];\n if (!values) {\n return false;\n }\n const tokens = headerTokenList(values);\n return tokens.some((value) => value.toLowerCase() === token.toLowerCase());\n}\n\nfunction headerHasTokenFetch(headers: Headers, name: string, token: string): boolean {\n const value = headers.get(name);\n if (!value) {\n return false;\n }\n return value.split(',').some((part) => part.trim().toLowerCase() === token.toLowerCase());\n}\n","import type { CaptureConfig, RedactionConfig } from './config';\nimport type { XrayContext } from './types';\nimport { bindObject, getContextFromObject, getContextState } from './state';\n\nexport { LimitedBuffer } from './limited_buffer';\nexport {\n headerValuesFromFetchHeaders,\n headerValuesFromFetchHeadersWithLimit,\n headerValuesFromNodeHeaders,\n headerTokenList,\n} from './headers';\nexport { isWebsocketUpgrade, isWebsocketUpgradeFetch } from './websocket';\nexport { makeCapturedBody } from './request_log';\nexport { logWithLevel } from './logger';\nexport { generateRequestId, uuidv7, uuidv7base48, uuidv7base62 } from './uuid';\n\nexport function bindContextToObject(target: object, ctx: XrayContext): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n bindObject(target, state);\n}\n\nexport function getXrayContextFromObject(target: unknown): XrayContext | undefined {\n return getContextFromObject(target);\n}\n\nexport function setContextRoute(ctx: XrayContext, route: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n const normalized =\n state.config.route.normalize && state.config.route.normalizer\n ? state.config.route.normalizer(route)\n : route;\n state.request.route = normalized;\n}\n\nexport function setContextRequestId(ctx: XrayContext, requestId: string): void {\n const state = getContextState(ctx);\n if (!state) {\n return;\n }\n state.request.requestId = requestId;\n state.context.requestId = requestId;\n}\n\nexport function setCaptureOverride(\n ctx: XrayContext,\n capture: Partial<CaptureConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !capture) {\n return;\n }\n state.captureOverride = capture;\n}\n\nexport function setRedactionOverride(\n ctx: XrayContext,\n redaction: Partial<RedactionConfig> | undefined,\n): void {\n const state = getContextState(ctx);\n if (!state || !redaction) {\n return;\n }\n state.redactionOverride = redaction;\n}\n"],"mappings":"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","names":[]}
@@ -21,17 +21,10 @@ interface RedactionConfig {
21
21
  }
22
22
  interface RequestIdConfig {
23
23
  /**
24
- * Incoming request header name to read request IDs from. Set or overwrite
25
- * this header in your own middleware before X-ray runs if you don't want to
26
- * trust client-supplied IDs. This is normalized to lowercase during
27
- * configuration.
24
+ * Response header name to read request IDs from. This is normalized to
25
+ * lowercase during configuration.
28
26
  */
29
27
  header: string;
30
- /**
31
- * Generate a UUIDv7 when no request ID is present on the request or header.
32
- * When disabled and no ID is found, X-ray uses an empty string.
33
- */
34
- generate: boolean;
35
28
  }
36
29
  interface RouteConfig {
37
30
  normalize: boolean;
@@ -48,9 +41,8 @@ interface XrayConfig {
48
41
  capture?: Partial<CaptureConfig>;
49
42
  redaction?: Partial<RedactionConfig>;
50
43
  /**
51
- * Request ID resolution settings. The header is read from incoming request headers.
52
- * Set or overwrite that header before X-ray runs if you don't want to trust
53
- * client-supplied IDs.
44
+ * Request ID resolution settings. The header is read from response headers at
45
+ * the end of the request.
54
46
  */
55
47
  requestId?: Partial<RequestIdConfig>;
56
48
  route?: Partial<RouteConfig>;
@@ -133,10 +125,8 @@ interface NormalizedRequest {
133
125
  headers: Record<string, string | string[]>;
134
126
  body?: CapturedBody;
135
127
  /**
136
- * Optional explicit request ID. If omitted, X-ray reads from incoming request
137
- * headers (and generates a UUIDv7 if enabled). When generation is disabled
138
- * and no ID is found, X-ray uses an empty string. Set or overwrite that
139
- * header before X-ray runs if you don't want to trust client-supplied IDs.
128
+ * Optional explicit request ID. If omitted, X-ray reads from response headers
129
+ * when the span is closed (and generates a UUIDv7 if none is present).
140
130
  */
141
131
  requestId?: string;
142
132
  remoteAddress?: string;
@@ -21,17 +21,10 @@ interface RedactionConfig {
21
21
  }
22
22
  interface RequestIdConfig {
23
23
  /**
24
- * Incoming request header name to read request IDs from. Set or overwrite
25
- * this header in your own middleware before X-ray runs if you don't want to
26
- * trust client-supplied IDs. This is normalized to lowercase during
27
- * configuration.
24
+ * Response header name to read request IDs from. This is normalized to
25
+ * lowercase during configuration.
28
26
  */
29
27
  header: string;
30
- /**
31
- * Generate a UUIDv7 when no request ID is present on the request or header.
32
- * When disabled and no ID is found, X-ray uses an empty string.
33
- */
34
- generate: boolean;
35
28
  }
36
29
  interface RouteConfig {
37
30
  normalize: boolean;
@@ -48,9 +41,8 @@ interface XrayConfig {
48
41
  capture?: Partial<CaptureConfig>;
49
42
  redaction?: Partial<RedactionConfig>;
50
43
  /**
51
- * Request ID resolution settings. The header is read from incoming request headers.
52
- * Set or overwrite that header before X-ray runs if you don't want to trust
53
- * client-supplied IDs.
44
+ * Request ID resolution settings. The header is read from response headers at
45
+ * the end of the request.
54
46
  */
55
47
  requestId?: Partial<RequestIdConfig>;
56
48
  route?: Partial<RouteConfig>;
@@ -133,10 +125,8 @@ interface NormalizedRequest {
133
125
  headers: Record<string, string | string[]>;
134
126
  body?: CapturedBody;
135
127
  /**
136
- * Optional explicit request ID. If omitted, X-ray reads from incoming request
137
- * headers (and generates a UUIDv7 if enabled). When generation is disabled
138
- * and no ID is found, X-ray uses an empty string. Set or overwrite that
139
- * header before X-ray runs if you don't want to trust client-supplied IDs.
128
+ * Optional explicit request ID. If omitted, X-ray reads from response headers
129
+ * when the span is closed (and generates a UUIDv7 if none is present).
140
130
  */
141
131
  requestId?: string;
142
132
  remoteAddress?: string;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@stainlessdev/xray-core",
3
- "version": "0.6.0",
3
+ "version": "0.7.0",
4
4
  "description": "Core instrumentation for Stainless X-ray request logging",
5
5
  "files": [
6
6
  "dist"