@stainlessdev/xray-core 0.3.0 → 0.3.1-dev.ae29cd0

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/index.js CHANGED
@@ -1,10 +1,11 @@
1
1
  import {
2
2
  bindContext,
3
+ encodeBase64,
3
4
  getContextState,
4
5
  logWithLevel,
5
6
  sanitizeHeaderValues,
6
7
  sanitizeLogString
7
- } from "./chunk-SQHI5JZH.js";
8
+ } from "./chunk-XI5E6C7G.js";
8
9
 
9
10
  // src/route.ts
10
11
  function normalizeRoutePattern(route) {
@@ -122,8 +123,7 @@ var defaultExporterBase = {
122
123
  endpointUrl: DEFAULT_ENDPOINT_URL,
123
124
  headers: {},
124
125
  timeoutMs: 5e3,
125
- spanProcessor: "batch",
126
- sampler: { type: "ratio", ratio: 1 }
126
+ spanProcessor: "batch"
127
127
  };
128
128
  var XrayConfigError = class extends Error {
129
129
  constructor(code, message) {
@@ -214,24 +214,15 @@ function normalizeRoute(cfg) {
214
214
  }
215
215
  function normalizeExporter(endpointUrl, cfg) {
216
216
  const resolvedEndpoint = normalizeExporterEndpoint(cfg?.endpointUrl ?? endpointUrl);
217
- const enabled = cfg?.enabled ?? true;
217
+ const rawHeaders = cfg?.headers ?? defaultExporterBase.headers ?? {};
218
+ const parsed = applyEndpointAuth(resolvedEndpoint, rawHeaders);
218
219
  const exporter = {
219
220
  ...defaultExporterBase,
220
- ...cfg,
221
- enabled,
222
- endpointUrl: resolvedEndpoint,
223
- headers: cfg?.headers ?? defaultExporterBase.headers,
221
+ endpointUrl: parsed.endpointUrl,
222
+ headers: parsed.headers,
224
223
  timeoutMs: cfg?.timeoutMs ?? defaultExporterBase.timeoutMs,
225
- spanProcessor: cfg?.spanProcessor ?? defaultExporterBase.spanProcessor,
226
- sampler: cfg?.sampler ?? defaultExporterBase.sampler
224
+ spanProcessor: cfg?.spanProcessor ?? defaultExporterBase.spanProcessor
227
225
  };
228
- if (exporter.sampler.type === "ratio") {
229
- const ratio = exporter.sampler.ratio ?? 1;
230
- if (!Number.isFinite(ratio) || ratio < 0 || ratio > 1) {
231
- throw new XrayConfigError("INVALID_EXPORTER", "sampler.ratio must be between 0 and 1");
232
- }
233
- exporter.sampler = { type: "ratio", ratio };
234
- }
235
226
  return exporter;
236
227
  }
237
228
  function normalizeExporterEndpoint(endpointUrl) {
@@ -250,6 +241,69 @@ function normalizeStringList(values) {
250
241
  }
251
242
  return values.map((entry) => entry.trim()).filter(Boolean);
252
243
  }
244
+ var textEncoder = typeof TextEncoder !== "undefined" ? new TextEncoder() : null;
245
+ var maybeBuffer = globalThis.Buffer;
246
+ function applyEndpointAuth(endpointUrl, headers) {
247
+ const resolvedHeaders = headers ?? {};
248
+ let url;
249
+ try {
250
+ url = new URL(endpointUrl);
251
+ } catch {
252
+ return { endpointUrl, headers: resolvedHeaders };
253
+ }
254
+ const username = decodeUserInfo(url.username);
255
+ const password = decodeUserInfo(url.password);
256
+ if (!username && !password) {
257
+ return { endpointUrl, headers: resolvedHeaders };
258
+ }
259
+ url.username = "";
260
+ url.password = "";
261
+ const sanitizedUrl = url.toString();
262
+ if (hasAuthorizationHeader(resolvedHeaders)) {
263
+ return { endpointUrl: sanitizedUrl, headers: resolvedHeaders };
264
+ }
265
+ const authorization = encodeBasicAuth(username, password);
266
+ if (!authorization) {
267
+ return { endpointUrl: sanitizedUrl, headers: resolvedHeaders };
268
+ }
269
+ return {
270
+ endpointUrl: sanitizedUrl,
271
+ headers: {
272
+ ...resolvedHeaders,
273
+ Authorization: authorization
274
+ }
275
+ };
276
+ }
277
+ function decodeUserInfo(value) {
278
+ if (!value) {
279
+ return value;
280
+ }
281
+ try {
282
+ return decodeURIComponent(value);
283
+ } catch {
284
+ return value;
285
+ }
286
+ }
287
+ function hasAuthorizationHeader(headers) {
288
+ return Object.keys(headers).some((key) => key.toLowerCase() === "authorization");
289
+ }
290
+ function encodeBasicAuth(username, password) {
291
+ const raw = `${username}:${password}`;
292
+ let bytes;
293
+ if (textEncoder) {
294
+ bytes = textEncoder.encode(raw);
295
+ } else if (maybeBuffer) {
296
+ bytes = maybeBuffer.from(raw, "utf8");
297
+ }
298
+ if (!bytes) {
299
+ return void 0;
300
+ }
301
+ const encoded = encodeBase64(bytes);
302
+ if (!encoded) {
303
+ return void 0;
304
+ }
305
+ return `Basic ${encoded}`;
306
+ }
253
307
 
254
308
  // src/header_redaction.ts
255
309
  var headerNameCompactor = /[-_.]/g;
@@ -701,12 +755,10 @@ import {
701
755
  } from "@opentelemetry/api";
702
756
  import { ExportResultCode } from "@opentelemetry/core";
703
757
  import {
704
- AlwaysOffSampler,
705
758
  AlwaysOnSampler,
706
759
  BasicTracerProvider,
707
760
  BatchSpanProcessor,
708
- SimpleSpanProcessor,
709
- TraceIdRatioBasedSampler
761
+ SimpleSpanProcessor
710
762
  } from "@opentelemetry/sdk-trace-base";
711
763
  import { resourceFromAttributes } from "@opentelemetry/resources";
712
764
  import {
@@ -718,9 +770,6 @@ import {
718
770
  import { JsonTraceSerializer, ProtobufTraceSerializer } from "@opentelemetry/otlp-transformer";
719
771
  var defaultAttributeCountLimit = 128;
720
772
  function createTracerProvider(config) {
721
- if (!config.exporter.enabled || !config.exporter.endpointUrl) {
722
- return null;
723
- }
724
773
  if (config.exporter.endpointUrl.startsWith("http://")) {
725
774
  diag.warn("xray: OTLP endpoint uses plaintext HTTP");
726
775
  }
@@ -734,9 +783,10 @@ function createTracerProvider(config) {
734
783
  const exporter = new FetchSpanExporter({
735
784
  endpointUrl: config.exporter.endpointUrl,
736
785
  headers: config.exporter.headers ?? {},
737
- timeoutMillis: config.exporter.timeoutMs
786
+ timeoutMillis: config.exporter.timeoutMs,
787
+ logger: config.logger,
788
+ logLevel: config.logLevel
738
789
  });
739
- const sampler = createSampler(config);
740
790
  const spanProcessor = createSpanProcessor(config.exporter.spanProcessor, exporter);
741
791
  const dropProcessor = new DropFilterSpanProcessor(spanProcessor);
742
792
  const provider = new BasicTracerProvider({
@@ -746,7 +796,7 @@ function createTracerProvider(config) {
746
796
  attributeValueLengthLimit
747
797
  },
748
798
  resource,
749
- sampler,
799
+ sampler: new AlwaysOnSampler(),
750
800
  spanLimits: {
751
801
  attributeCountLimit: defaultAttributeCountLimit,
752
802
  attributePerEventCountLimit: defaultAttributeCountLimit,
@@ -801,6 +851,8 @@ var FetchSpanExporter = class {
801
851
  this.headers = { ...options.headers };
802
852
  this.timeoutMillis = options.timeoutMillis;
803
853
  this.isShutdown = false;
854
+ this.logger = options.logger;
855
+ this.logLevel = options.logLevel;
804
856
  const protobufSerializer = ProtobufTraceSerializer && typeof ProtobufTraceSerializer.serializeRequest === "function" ? ProtobufTraceSerializer : null;
805
857
  this.serializer = protobufSerializer ?? JsonTraceSerializer;
806
858
  this.contentType = protobufSerializer ? "application/x-protobuf" : "application/json";
@@ -812,6 +864,9 @@ var FetchSpanExporter = class {
812
864
  }
813
865
  const payload = this.serializer.serializeRequest(spans);
814
866
  if (!payload) {
867
+ logWithLevel(this.logger, "warn", this.logLevel, "xray: OTLP export failed", {
868
+ error: "OTLP export failed: empty payload"
869
+ });
815
870
  resultCallback({
816
871
  code: ExportResultCode.FAILED,
817
872
  error: new Error("OTLP export failed: empty payload")
@@ -847,6 +902,9 @@ var FetchSpanExporter = class {
847
902
  if (timeout) {
848
903
  clearTimeout(timeout);
849
904
  }
905
+ logWithLevel(this.logger, "warn", this.logLevel, "xray: OTLP export failed", {
906
+ error: err instanceof Error ? err.message : String(err)
907
+ });
850
908
  diag.error("OTLP export failed", err);
851
909
  resultCallback({ code: ExportResultCode.FAILED, error: err });
852
910
  });
@@ -869,19 +927,9 @@ function createSpanProcessor(mode, exporter) {
869
927
  exportTimeoutMillis: 3e4
870
928
  });
871
929
  }
872
- function createSampler(config) {
873
- const sampler = config.exporter.sampler;
874
- if (sampler.type === "always_off") {
875
- return new AlwaysOffSampler();
876
- }
877
- if (sampler.type === "ratio") {
878
- return new TraceIdRatioBasedSampler(sampler.ratio ?? 1);
879
- }
880
- return new AlwaysOnSampler();
881
- }
882
930
  function sdkVersion() {
883
931
  if (true) {
884
- return "0.2.0";
932
+ return "0.3.1";
885
933
  }
886
934
  return "unknown";
887
935
  }
@@ -912,14 +960,21 @@ function uuidv7() {
912
960
  // src/emitter.ts
913
961
  function createEmitter(config) {
914
962
  const resolved = normalizeConfig(config);
963
+ logWithLevel(resolved.logger, "info", resolved.logLevel, "xray: emitter configured", {
964
+ serviceName: resolved.serviceName,
965
+ environment: resolved.environment,
966
+ version: resolved.version,
967
+ exporterEndpoint: resolved.exporter.endpointUrl,
968
+ spanProcessor: resolved.exporter.spanProcessor
969
+ });
915
970
  const tracerProvider = createTracerProvider(resolved);
916
- const tracer = tracerProvider ? tracerFromProvider(tracerProvider) : null;
971
+ const tracer = tracerFromProvider(tracerProvider);
917
972
  return {
918
973
  config: resolved,
919
974
  startRequest: (req) => startRequest(resolved, tracer, req),
920
975
  endRequest: (ctx, res, err) => endRequest(resolved, ctx, res, err),
921
- flush: () => tracerProvider ? tracerProvider.forceFlush() : Promise.resolve(),
922
- shutdown: () => tracerProvider ? tracerProvider.shutdown() : Promise.resolve()
976
+ flush: () => tracerProvider.forceFlush(),
977
+ shutdown: () => tracerProvider.shutdown()
923
978
  };
924
979
  }
925
980
  function startRequest(config, tracer, req) {
@@ -930,7 +985,7 @@ function startRequest(config, tracer, req) {
930
985
  if (req.route && config.route.normalize) {
931
986
  req.route = config.route.normalizer ? config.route.normalizer(req.route) : normalizeRoutePattern(req.route);
932
987
  }
933
- const span = tracer ? spanFromTracer(tracer, spanNameFromRequest(req)) : void 0;
988
+ const span = spanFromTracer(tracer, spanNameFromRequest(req));
934
989
  const context = {
935
990
  requestId,
936
991
  traceId: span?.spanContext().traceId,
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/route.ts","../src/config.ts","../src/header_redaction.ts","../src/redaction.ts","../src/attrkey.ts","../src/attributes.ts","../src/otel.ts","../src/uuid.ts","../src/emitter.ts"],"sourcesContent":["export function normalizeRoutePattern(route: string): string {\n if (!route) {\n return '/';\n }\n\n const cleaned = stripQueryAndFragment(route).trim();\n if (!cleaned) {\n return '/';\n }\n\n const withoutMethod = stripMethodPrefix(cleaned);\n const leading = withoutMethod.startsWith('/') ? withoutMethod : `/${withoutMethod}`;\n const segments = leading.split('/').filter(Boolean);\n if (segments.length === 0) {\n return '/';\n }\n\n const normalized = segments.map(normalizeRouteSegment).join('/');\n return `/${normalized}`;\n}\n\nfunction stripMethodPrefix(value: string): string {\n if (!/^[A-Z]+\\s+\\//.test(value)) {\n return value;\n }\n const spaceIndex = value.search(/\\s+/);\n if (spaceIndex < 0) {\n return value;\n }\n return value.slice(spaceIndex).trim();\n}\n\nfunction stripQueryAndFragment(value: string): string {\n const hashIndex = value.indexOf('#');\n const beforeHash = hashIndex >= 0 ? value.slice(0, hashIndex) : value;\n const queryIndex = beforeHash.indexOf('?');\n return queryIndex >= 0 ? beforeHash.slice(0, queryIndex) : beforeHash;\n}\n\nfunction normalizeRouteSegment(segment: string): string {\n if (segment === '*') {\n return '{wildcard}';\n }\n\n const param = extractRouteParam(segment);\n if (param) {\n return `{${param}}`;\n }\n\n return segment;\n}\n\nfunction extractRouteParam(segment: string): string | null {\n if (!segment) {\n return null;\n }\n\n if (segment.startsWith('[') && segment.endsWith(']')) {\n return normalizeNextParam(segment);\n }\n\n if (segment.startsWith('{') && segment.endsWith('}')) {\n const inner = segment.slice(1, -1);\n const trimmed = stripParamDecorators(inner);\n return extractParamName(trimmed);\n }\n\n if (segment.startsWith(':') || segment.startsWith('$')) {\n return extractParamName(segment.slice(1));\n }\n\n return null;\n}\n\nfunction normalizeNextParam(segment: string): string | null {\n let inner = segment.slice(1, -1);\n if (inner.startsWith('[') && inner.endsWith(']')) {\n inner = inner.slice(1, -1);\n }\n if (inner.startsWith('...')) {\n inner = inner.slice(3);\n }\n return extractParamName(inner);\n}\n\nfunction stripParamDecorators(value: string): string {\n let trimmed = value.trim();\n if (!trimmed) {\n return trimmed;\n }\n if (trimmed.endsWith('...')) {\n trimmed = trimmed.slice(0, -3);\n }\n return trimmed.replace(/[?*+]+$/, '');\n}\n\nfunction extractParamName(value: string): string | null {\n if (!value) {\n return null;\n }\n const match = value.match(/^[A-Za-z0-9_-]+/);\n return match?.[0] ?? null;\n}\n","import { normalizeRoutePattern } from './route';\nimport type { Logger, LogLevel } from './types';\n\nexport interface ExporterConfig {\n enabled: boolean;\n endpointUrl?: string;\n headers?: Record<string, string>;\n timeoutMs: number;\n spanProcessor: 'simple' | 'batch';\n sampler: { type: 'always_on' | 'always_off' | 'ratio'; ratio?: number };\n}\n\nexport interface CaptureConfig {\n requestHeaders: boolean;\n responseHeaders: boolean;\n requestBody: 'none' | 'text' | 'base64';\n responseBody: 'none' | 'text' | 'base64';\n maxBodyBytes: number;\n}\n\nexport interface RedactionConfig {\n headers: string[];\n queryParams: string[];\n bodyJsonPaths: string[];\n replacement: string;\n}\n\nexport interface RequestIdConfig {\n header: string;\n generate: boolean;\n}\n\nexport interface RouteConfig {\n normalize: boolean;\n normalizer?: (path: string) => string;\n}\n\nexport interface XrayConfig {\n serviceName: string;\n environment?: string;\n version?: string;\n logger?: Logger;\n logLevel?: LogLevel;\n endpointUrl?: string;\n exporter?: Partial<ExporterConfig>;\n capture?: Partial<CaptureConfig>;\n redaction?: Partial<RedactionConfig>;\n requestId?: Partial<RequestIdConfig>;\n route?: Partial<RouteConfig>;\n}\n\nexport interface ResolvedXrayConfig {\n serviceName: string;\n environment?: string;\n version?: string;\n logger: Logger;\n logLevel: LogLevel;\n exporter: ExporterConfig;\n capture: CaptureConfig;\n redaction: RedactionConfig;\n requestId: RequestIdConfig;\n route: RouteConfig;\n}\n\nconst defaultCapture: CaptureConfig = {\n requestHeaders: true,\n responseHeaders: true,\n requestBody: 'none',\n responseBody: 'none',\n maxBodyBytes: 65536,\n};\n\nconst defaultRedaction: RedactionConfig = {\n headers: ['authorization', 'cookie', 'set-cookie', 'x-api-key'],\n queryParams: [],\n bodyJsonPaths: [],\n replacement: '[REDACTED]',\n};\n\nconst defaultRequestId: RequestIdConfig = {\n header: 'x-request-id',\n generate: true,\n};\n\nconst defaultRoute: RouteConfig = {\n normalize: true,\n normalizer: normalizeRoutePattern,\n};\n\nconst DEFAULT_ENDPOINT_URL = 'http://localhost:4318';\n\nconst defaultExporterBase: Omit<ExporterConfig, 'enabled'> = {\n endpointUrl: DEFAULT_ENDPOINT_URL,\n headers: {},\n timeoutMs: 5000,\n spanProcessor: 'batch',\n sampler: { type: 'ratio', ratio: 1.0 },\n};\n\nexport class XrayConfigError extends Error {\n code: 'INVALID_CONFIG' | 'INVALID_EXPORTER' | 'INVALID_REDACTION';\n\n constructor(code: XrayConfigError['code'], message: string) {\n super(message);\n this.code = code;\n }\n}\n\nexport function normalizeConfig(config: XrayConfig): ResolvedXrayConfig {\n if (!config || !config.serviceName || !config.serviceName.trim()) {\n throw new XrayConfigError('INVALID_CONFIG', 'serviceName is required');\n }\n\n const logger = config.logger ?? console;\n const logLevel = config.logLevel ?? 'warn';\n\n const capture = normalizeCapture(config.capture);\n const redaction = normalizeRedaction(config.redaction);\n const requestId = normalizeRequestId(config.requestId);\n const route = normalizeRoute(config.route);\n const exporter = normalizeExporter(config.endpointUrl, config.exporter);\n\n return {\n serviceName: config.serviceName.trim(),\n environment: config.environment?.trim() || undefined,\n version: config.version?.trim() || undefined,\n logger,\n logLevel,\n exporter,\n capture,\n redaction,\n requestId,\n route,\n };\n}\n\nfunction normalizeCapture(cfg?: Partial<CaptureConfig>): CaptureConfig {\n const capture: CaptureConfig = {\n ...defaultCapture,\n ...cfg,\n };\n\n if (!['none', 'text', 'base64'].includes(capture.requestBody)) {\n throw new XrayConfigError(\n 'INVALID_CONFIG',\n 'capture.requestBody must be none, text, or base64',\n );\n }\n if (!['none', 'text', 'base64'].includes(capture.responseBody)) {\n throw new XrayConfigError(\n 'INVALID_CONFIG',\n 'capture.responseBody must be none, text, or base64',\n );\n }\n if (!Number.isFinite(capture.maxBodyBytes) || capture.maxBodyBytes < 0) {\n throw new XrayConfigError('INVALID_CONFIG', 'capture.maxBodyBytes must be >= 0');\n }\n\n return capture;\n}\n\nfunction normalizeRedaction(cfg?: Partial<RedactionConfig>): RedactionConfig {\n const redaction: RedactionConfig = {\n ...defaultRedaction,\n ...cfg,\n };\n\n redaction.headers = normalizeStringList(redaction.headers);\n redaction.queryParams = normalizeStringList(redaction.queryParams);\n redaction.bodyJsonPaths = normalizeStringList(redaction.bodyJsonPaths);\n redaction.replacement = redaction.replacement || defaultRedaction.replacement;\n\n if (!redaction.replacement) {\n throw new XrayConfigError('INVALID_REDACTION', 'redaction.replacement must be non-empty');\n }\n\n return redaction;\n}\n\nfunction normalizeRequestId(cfg?: Partial<RequestIdConfig>): RequestIdConfig {\n const requestId: RequestIdConfig = {\n ...defaultRequestId,\n ...cfg,\n };\n\n requestId.header = requestId.header.trim().toLowerCase();\n if (!requestId.header) {\n throw new XrayConfigError('INVALID_CONFIG', 'requestId.header must be non-empty');\n }\n\n return requestId;\n}\n\nfunction normalizeRoute(cfg?: Partial<RouteConfig>): RouteConfig {\n const route: RouteConfig = {\n ...defaultRoute,\n ...cfg,\n };\n\n if (route.normalize && !route.normalizer) {\n route.normalizer = normalizeRoutePattern;\n }\n\n return route;\n}\n\nfunction normalizeExporter(\n endpointUrl: string | undefined,\n cfg?: Partial<ExporterConfig>,\n): ExporterConfig {\n const resolvedEndpoint = normalizeExporterEndpoint(cfg?.endpointUrl ?? endpointUrl);\n const enabled = cfg?.enabled ?? true;\n const exporter: ExporterConfig = {\n ...defaultExporterBase,\n ...cfg,\n enabled,\n endpointUrl: resolvedEndpoint,\n headers: cfg?.headers ?? defaultExporterBase.headers,\n timeoutMs: cfg?.timeoutMs ?? defaultExporterBase.timeoutMs,\n spanProcessor: cfg?.spanProcessor ?? defaultExporterBase.spanProcessor,\n sampler: cfg?.sampler ?? defaultExporterBase.sampler,\n };\n\n if (exporter.sampler.type === 'ratio') {\n const ratio = exporter.sampler.ratio ?? 1;\n if (!Number.isFinite(ratio) || ratio < 0 || ratio > 1) {\n throw new XrayConfigError('INVALID_EXPORTER', 'sampler.ratio must be between 0 and 1');\n }\n exporter.sampler = { type: 'ratio', ratio };\n }\n\n return exporter;\n}\n\nfunction normalizeExporterEndpoint(endpointUrl: string | undefined): string {\n const envUrl =\n typeof process !== 'undefined' ? process.env?.['STAINLESS_XRAY_ENDPOINT_URL'] : undefined;\n const resolved = endpointUrl ?? envUrl ?? DEFAULT_ENDPOINT_URL;\n const trimmed = resolved.trim();\n const withoutTrailingSlash = trimmed.endsWith('/') ? trimmed.slice(0, -1) : trimmed;\n if (withoutTrailingSlash.endsWith('/v1/traces')) {\n return withoutTrailingSlash;\n }\n return `${withoutTrailingSlash}/v1/traces`;\n}\n\nfunction normalizeStringList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim()).filter(Boolean);\n}\n","const headerNameCompactor = /[-_.]/g;\nconst headerTokenSplitter = /[-_.]/;\n\ntype HeaderRedactionMatcher = {\n exactSensitive: Set<string>;\n keywordTokens: Set<string>;\n keywordCompacted: string[];\n};\n\nconst defaultHeaderMatcher = newHeaderRedactionMatcher(\n defaultSensitiveHeaderNames(),\n defaultSensitiveKeywords(),\n);\n\nexport function authSchemePrefix(value: string): string {\n if (!value) {\n return '';\n }\n\n const lower = value.toLowerCase();\n if (lower.startsWith('basic')) {\n return value.slice(0, 'basic'.length);\n }\n if (lower.startsWith('bearer')) {\n return value.slice(0, 'bearer'.length);\n }\n if (lower.startsWith('digest')) {\n return value.slice(0, 'digest'.length);\n }\n if (lower.startsWith('negotiate')) {\n return value.slice(0, 'negotiate'.length);\n }\n return '';\n}\n\nexport function redactCookieValue(value: string, replacement: string): string {\n if (!value) {\n return replacement;\n }\n\n const parts = value.split(';');\n const redacted: string[] = [];\n\n for (const part of parts) {\n const segment = part.trim();\n if (!segment) {\n redacted.push(replacement);\n continue;\n }\n const idx = segment.indexOf('=');\n if (idx <= 0) {\n redacted.push(replacement);\n continue;\n }\n const name = segment.slice(0, idx);\n if (!name) {\n redacted.push(replacement);\n continue;\n }\n redacted.push(`${name}=${replacement}`);\n }\n\n return redacted.join('; ');\n}\n\nexport function redactSetCookieValue(value: string, replacement: string): string {\n if (!value) {\n return replacement;\n }\n\n const parts = value.split(';');\n const first = parts.shift() ?? '';\n const idx = first.indexOf('=');\n if (idx <= 0) {\n return replacement;\n }\n const name = first.slice(0, idx);\n if (!name) {\n return replacement;\n }\n\n const redacted = `${name}=${replacement}`;\n if (parts.length === 0) {\n return redacted;\n }\n return `${redacted};${parts.join(';')}`;\n}\n\nexport function isSensitiveHeaderName(key: string): boolean {\n return isSensitiveNormalized(defaultHeaderMatcher, normalizeHeaderName(key));\n}\n\nfunction addSensitiveHeaderNames(target: Set<string>, headers: string[]): void {\n for (const header of headers) {\n const normalized = normalizeHeaderName(header);\n if (normalized) {\n target.add(normalized);\n }\n }\n}\n\nfunction buildKeywordSets(keywords: string[]): { compacted: string[]; tokens: Set<string> } {\n const tokens = new Set<string>();\n const compacted = new Set<string>();\n\n for (const keyword of keywords) {\n const normalized = normalizeHeaderName(keyword);\n if (!normalized) {\n continue;\n }\n const compactedKeyword = compactNormalizedHeaderName(normalized);\n if (compactedKeyword) {\n compacted.add(compactedKeyword);\n }\n if (!normalized.includes('-') && !normalized.includes('_') && !normalized.includes('.')) {\n tokens.add(normalized);\n }\n }\n\n return {\n compacted: Array.from(compacted).sort(),\n tokens,\n };\n}\n\nfunction compactNormalizedHeaderName(normalized: string): string {\n if (!normalized) {\n return '';\n }\n return normalized.replace(headerNameCompactor, '');\n}\n\nfunction defaultSensitiveHeaderNames(): string[] {\n return [\n 'authorization',\n 'cookie',\n 'proxy-authenticate',\n 'proxy-authorization',\n 'set-cookie',\n 'www-authenticate',\n ];\n}\n\nfunction defaultSensitiveKeywords(): string[] {\n return [\n 'api-key',\n 'api_key',\n 'apikey',\n 'auth',\n 'authenticate',\n 'authorization',\n 'credential',\n 'password',\n 'passwd',\n 'private-key',\n 'private_key',\n 'privatekey',\n 'secret',\n 'session',\n 'sessionid',\n 'signature',\n 'token',\n ];\n}\n\nfunction headerNameTokens(name: string): string[] {\n if (!name) {\n return [];\n }\n return name.split(headerTokenSplitter).filter(Boolean);\n}\n\nfunction hasKeywordToken(tokens: string[], keywordTokens: Set<string>): boolean {\n for (const token of tokens) {\n if (keywordTokens.has(token)) {\n return true;\n }\n }\n return false;\n}\n\nfunction isExactMatch(normalized: string, exactSensitive: Set<string>): boolean {\n return exactSensitive.has(normalized);\n}\n\nfunction isSensitiveNormalized(matcher: HeaderRedactionMatcher, normalized: string): boolean {\n if (!normalized) {\n return false;\n }\n if (isExactMatch(normalized, matcher.exactSensitive)) {\n return true;\n }\n if (hasKeywordToken(headerNameTokens(normalized), matcher.keywordTokens)) {\n return true;\n }\n return matchesCompacted(normalized, matcher.keywordCompacted);\n}\n\nfunction matchesCompacted(normalized: string, keywordCompacted: string[]): boolean {\n if (keywordCompacted.length === 0) {\n return false;\n }\n const compacted = compactNormalizedHeaderName(normalized);\n if (!compacted) {\n return false;\n }\n return keywordCompacted.some((keyword) => compacted.includes(keyword));\n}\n\nfunction newHeaderRedactionMatcher(names: string[], keywords: string[]): HeaderRedactionMatcher {\n const exactSensitive = new Set<string>();\n addSensitiveHeaderNames(exactSensitive, names);\n const { compacted, tokens } = buildKeywordSets(keywords);\n return {\n exactSensitive,\n keywordCompacted: compacted,\n keywordTokens: tokens,\n };\n}\n\nfunction normalizeHeaderName(name: string): string {\n return name.trim().toLowerCase();\n}\n","import type { CapturedBody, RequestLog } from './types';\nimport { authSchemePrefix, redactCookieValue, redactSetCookieValue } from './header_redaction';\n\nexport function applyRedaction(\n config: {\n headers: string[];\n queryParams: string[];\n bodyJsonPaths: string[];\n replacement: string;\n },\n log: RequestLog,\n): RequestLog {\n const redacted = { ...log };\n\n if (redacted.requestHeaders) {\n redacted.requestHeaders = redactHeaders(redacted.requestHeaders, config);\n }\n if (redacted.responseHeaders) {\n redacted.responseHeaders = redactHeaders(redacted.responseHeaders, config);\n }\n\n redacted.url = redactUrl(redacted.url, config);\n\n if (redacted.requestBody) {\n redacted.requestBody = redactBody(redacted.requestBody, redacted.requestHeaders, config);\n }\n if (redacted.responseBody) {\n redacted.responseBody = redactBody(redacted.responseBody, redacted.responseHeaders, config);\n }\n\n return redacted;\n}\n\nfunction redactHeaders(\n headers: Record<string, string | string[]>,\n config: { headers: string[]; replacement: string },\n): Record<string, string | string[]> {\n const list = new Set(config.headers.map((name) => name.toLowerCase()));\n const result: Record<string, string | string[]> = {};\n\n for (const [name, value] of Object.entries(headers)) {\n const lower = name.toLowerCase();\n if (!list.has(lower)) {\n result[name] = value;\n continue;\n }\n\n const redactValue = (entry: string) => redactHeaderValue(lower, entry, config.replacement);\n if (Array.isArray(value)) {\n result[name] = value.map(redactValue);\n } else {\n result[name] = redactValue(value);\n }\n }\n\n return result;\n}\n\nfunction redactHeaderValue(name: string, value: string, replacement: string): string {\n switch (name) {\n case 'authorization':\n case 'proxy-authorization': {\n const scheme = authSchemePrefix(value);\n if (!scheme) {\n return replacement;\n }\n return `${scheme} ${replacement}`;\n }\n case 'cookie':\n return redactCookieValue(value, replacement);\n case 'set-cookie':\n return redactSetCookieValue(value, replacement);\n default:\n return replacement;\n }\n}\n\nfunction redactUrl(value: string, config: { queryParams: string[]; replacement: string }): string {\n if (!value || config.queryParams.length === 0) {\n return value;\n }\n\n try {\n const parsed = new URL(value);\n const params = parsed.searchParams;\n if (!params || params.size === 0) {\n return value;\n }\n\n const redact = new Set(config.queryParams.map((key) => key.toLowerCase()));\n const next = new URLSearchParams();\n params.forEach((val, key) => {\n if (redact.has(key.toLowerCase())) {\n next.append(key, config.replacement);\n } else {\n next.append(key, val);\n }\n });\n parsed.search = next.toString();\n return parsed.toString();\n } catch {\n return value;\n }\n}\n\nfunction redactBody(\n body: CapturedBody,\n headers: Record<string, string | string[]> | undefined,\n config: { bodyJsonPaths: string[]; replacement: string },\n): CapturedBody {\n if (config.bodyJsonPaths.length === 0) {\n return body;\n }\n if (!body.value || body.encoding !== 'utf8') {\n return body;\n }\n if (!isJsonContentType(headers)) {\n return body;\n }\n\n let parsed: unknown;\n try {\n parsed = JSON.parse(body.value);\n } catch {\n return body;\n }\n\n for (const path of config.bodyJsonPaths) {\n const segments = parseJsonPath(path);\n if (!segments) {\n continue;\n }\n redactJsonPath(parsed, segments, config.replacement);\n }\n\n const next = { ...body };\n next.value = JSON.stringify(parsed);\n return next;\n}\n\nfunction isJsonContentType(headers?: Record<string, string | string[]>): boolean {\n if (!headers) {\n return false;\n }\n const contentType = headers['content-type'] || headers['Content-Type'];\n const value = Array.isArray(contentType) ? contentType[0] : contentType;\n if (!value) {\n return false;\n }\n const normalized = value.split(';')[0];\n if (!normalized) {\n return false;\n }\n const trimmed = normalized.trim().toLowerCase();\n return trimmed === 'application/json' || trimmed.endsWith('+json');\n}\n\ntype JsonPathSegment = string | number;\n\nfunction parseJsonPath(path: string): JsonPathSegment[] | null {\n const trimmed = path.trim();\n if (!trimmed) {\n return null;\n }\n\n const normalized = trimmed.startsWith('$.') ? trimmed.slice(2) : trimmed;\n if (!normalized) {\n return null;\n }\n\n const segments: JsonPathSegment[] = [];\n const parts = normalized.split('.');\n for (const part of parts) {\n if (!part) {\n continue;\n }\n let cursor = part;\n const bracketIndex = cursor.indexOf('[');\n if (bracketIndex === -1) {\n segments.push(cursor);\n continue;\n }\n\n const name = cursor.slice(0, bracketIndex);\n if (name) {\n segments.push(name);\n }\n cursor = cursor.slice(bracketIndex);\n const matches = cursor.match(/\\[(\\d+)\\]/g);\n if (!matches) {\n continue;\n }\n for (const match of matches) {\n const indexValue = match.slice(1, -1);\n const index = Number.parseInt(indexValue, 10);\n if (Number.isFinite(index)) {\n segments.push(index);\n }\n }\n }\n\n return segments.length > 0 ? segments : null;\n}\n\nfunction redactJsonPath(value: unknown, segments: JsonPathSegment[], replacement: string): void {\n if (!value || segments.length === 0) {\n return;\n }\n\n let current: unknown = value;\n for (let i = 0; i < segments.length; i += 1) {\n const segment = segments[i];\n if (segment === undefined) {\n return;\n }\n const isLast = i === segments.length - 1;\n\n if (typeof segment === 'number') {\n if (!Array.isArray(current) || segment < 0 || segment >= current.length) {\n return;\n }\n if (isLast) {\n current[segment] = replacement;\n return;\n }\n current = current[segment];\n continue;\n }\n\n if (!current || typeof current !== 'object') {\n return;\n }\n const record = current as Record<string, unknown>;\n if (!(segment in record)) {\n return;\n }\n if (isLast) {\n record[segment] = replacement;\n return;\n }\n current = record[segment];\n }\n}\n","export const AttributeKeyPrefixRequestHeader = 'http.request.header.';\nexport const AttributeKeyPrefixResponseHeader = 'http.response.header.';\nexport const AttributeKeyRequestBody = 'http.request.body';\nexport const AttributeKeyRequestBodyEncoding = 'http.request.body.encoding';\nexport const AttributeKeyRequestBodyTruncated = 'http.request.body.truncated';\nexport const AttributeKeyRequestID = 'http.request.id';\nexport const AttributeKeyResponseBody = 'http.response.body';\nexport const AttributeKeyResponseBodyEncoding = 'http.response.body.encoding';\nexport const AttributeKeyResponseBodyTruncated = 'http.response.body.truncated';\nexport const AttributeKeySpanDrop = 'stainlessxray.internal.drop';\nexport const AttributeKeyXrayCaptureErrorCode = 'xray.capture_error_code';\nexport const AttributeKeyXrayErrorThrown = 'xray.error_thrown';\nexport const AttributeKeyXrayHeadersTruncated = 'xray.headers_truncated';\nexport const AttributeKeyXrayInvalidResponse = 'xray.invalid_response';\nexport const AttributeKeyXrayRequestBodyCaptureFailed = 'xray.request_body_capture_failed';\nexport const AttributeKeyXrayRequestBodyTruncated = 'xray.request_body_truncated';\nexport const AttributeKeyXrayResponseBodyCaptureFailed = 'xray.response_body_capture_failed';\nexport const AttributeKeyXrayResponseBodyTruncated = 'xray.response_body_truncated';\n","import type { Span } from '@opentelemetry/api';\nimport type { CapturedBody } from './types';\nimport {\n AttributeKeyRequestBody,\n AttributeKeyRequestBodyEncoding,\n AttributeKeyRequestBodyTruncated,\n AttributeKeyRequestID,\n AttributeKeyResponseBody,\n AttributeKeyResponseBodyEncoding,\n AttributeKeyResponseBodyTruncated,\n} from './attrkey';\n\nconst attributeKeyEndUserId = 'enduser.id';\nconst attributeKeyHttpRequestBodySize = 'http.request.body.size';\nconst attributeKeyHttpRequestMethod = 'http.request.method';\nconst attributeKeyHttpResponseBodySize = 'http.response.body.size';\nconst attributeKeyHttpResponseStatusCode = 'http.response.status_code';\nconst attributeKeyHttpRoute = 'http.route';\nconst attributeKeyUrlPath = 'url.path';\nconst attributeKeyUrlFull = 'url.full';\n\nexport function setHeaderAttributes(\n span: Span,\n headers: Record<string, string | string[]> | undefined,\n prefix: string,\n): void {\n if (!headers) {\n return;\n }\n const keys = Object.keys(headers).sort((a, b) => a.toLowerCase().localeCompare(b.toLowerCase()));\n for (const key of keys) {\n const values = headers[key];\n if (!values || (Array.isArray(values) && values.length === 0)) {\n continue;\n }\n span.setAttribute(prefix + key.toLowerCase(), Array.isArray(values) ? values : [values]);\n }\n}\n\nexport function setRequestAttributes(\n span: Span,\n method: string,\n urlFull: string | undefined,\n): void {\n span.setAttribute(attributeKeyHttpRequestMethod, method);\n if (urlFull) {\n span.setAttribute(attributeKeyUrlFull, urlFull);\n const path = extractPath(urlFull);\n if (path) {\n span.setAttribute(attributeKeyUrlPath, path);\n }\n }\n}\n\nfunction extractPath(url: string): string | undefined {\n try {\n return new URL(url).pathname;\n } catch {\n // If not a full URL, try to extract path directly\n const match = url.match(/^[^?#]*/);\n return match?.[0] || undefined;\n }\n}\n\nexport function setRequestBodyAttributes(span: Span, body: CapturedBody): void {\n if (!body.value) {\n return;\n }\n span.setAttribute(AttributeKeyRequestBody, body.value);\n span.setAttribute(AttributeKeyRequestBodyEncoding, body.encoding);\n if (body.truncated) {\n span.setAttribute(AttributeKeyRequestBodyTruncated, true);\n }\n}\n\nexport function setRequestBodySizeAttribute(span: Span, size: number): void {\n span.setAttribute(attributeKeyHttpRequestBodySize, size);\n}\n\nexport function setResponseBodyAttributes(span: Span, body: CapturedBody): void {\n if (!body.value) {\n return;\n }\n span.setAttribute(AttributeKeyResponseBody, body.value);\n span.setAttribute(AttributeKeyResponseBodyEncoding, body.encoding);\n if (body.truncated) {\n span.setAttribute(AttributeKeyResponseBodyTruncated, true);\n }\n}\n\nexport function setResponseBodySizeAttribute(span: Span, size: number): void {\n span.setAttribute(attributeKeyHttpResponseBodySize, size);\n}\n\nexport function setResponseStatusAttribute(span: Span, statusCode: number): void {\n span.setAttribute(attributeKeyHttpResponseStatusCode, statusCode);\n}\n\nexport function setRouteAttribute(span: Span, route: string | undefined): void {\n if (route) {\n span.setAttribute(attributeKeyHttpRoute, route);\n }\n}\n\nexport function setUserIdAttribute(span: Span, userId: string): void {\n span.setAttribute(attributeKeyEndUserId, userId);\n}\n\nexport function setRequestIdAttribute(span: Span, requestId: string): void {\n span.setAttribute(AttributeKeyRequestID, requestId);\n}\n","import {\n diag,\n ROOT_CONTEXT,\n SpanKind,\n SpanStatusCode,\n type Context,\n type Span,\n type Tracer,\n} from '@opentelemetry/api';\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core';\nimport {\n AlwaysOffSampler,\n AlwaysOnSampler,\n BasicTracerProvider,\n BatchSpanProcessor,\n type ReadableSpan,\n SimpleSpanProcessor,\n type Span as SDKSpan,\n type SpanExporter,\n type SpanProcessor,\n TraceIdRatioBasedSampler,\n} from '@opentelemetry/sdk-trace-base';\nimport { resourceFromAttributes } from '@opentelemetry/resources';\nimport {\n ATTR_SERVICE_NAME,\n ATTR_TELEMETRY_SDK_LANGUAGE,\n ATTR_TELEMETRY_SDK_NAME,\n ATTR_TELEMETRY_SDK_VERSION,\n} from '@opentelemetry/semantic-conventions';\nimport { JsonTraceSerializer, ProtobufTraceSerializer } from '@opentelemetry/otlp-transformer';\nimport { AttributeKeySpanDrop } from './attrkey';\nimport type { ResolvedXrayConfig } from './config';\n\nconst defaultAttributeCountLimit = 128;\n\nexport interface TracerProviderLike {\n forceFlush: () => Promise<void>;\n getTracer: (name: string, version?: string) => Tracer;\n shutdown: () => Promise<void>;\n}\n\nexport function createTracerProvider(config: ResolvedXrayConfig): TracerProviderLike | null {\n if (!config.exporter.enabled || !config.exporter.endpointUrl) {\n return null;\n }\n\n if (config.exporter.endpointUrl.startsWith('http://')) {\n diag.warn('xray: OTLP endpoint uses plaintext HTTP');\n }\n\n const attributeValueLengthLimit = Math.max(1, Math.ceil((config.capture.maxBodyBytes * 4) / 3));\n\n const resource = resourceFromAttributes({\n [ATTR_SERVICE_NAME]: config.serviceName,\n [ATTR_TELEMETRY_SDK_LANGUAGE]: isNodeRuntime() ? 'nodejs' : 'webjs',\n [ATTR_TELEMETRY_SDK_NAME]: 'stainless-xray',\n [ATTR_TELEMETRY_SDK_VERSION]: sdkVersion(),\n });\n\n const exporter = new FetchSpanExporter({\n endpointUrl: config.exporter.endpointUrl,\n headers: config.exporter.headers ?? {},\n timeoutMillis: config.exporter.timeoutMs,\n });\n\n const sampler = createSampler(config);\n const spanProcessor = createSpanProcessor(config.exporter.spanProcessor, exporter);\n const dropProcessor = new DropFilterSpanProcessor(spanProcessor);\n\n const provider = new BasicTracerProvider({\n forceFlushTimeoutMillis: 30_000,\n generalLimits: {\n attributeCountLimit: defaultAttributeCountLimit,\n attributeValueLengthLimit,\n },\n resource,\n sampler,\n spanLimits: {\n attributeCountLimit: defaultAttributeCountLimit,\n attributePerEventCountLimit: defaultAttributeCountLimit,\n attributePerLinkCountLimit: defaultAttributeCountLimit,\n attributeValueLengthLimit,\n eventCountLimit: defaultAttributeCountLimit,\n linkCountLimit: defaultAttributeCountLimit,\n },\n spanProcessors: [dropProcessor],\n });\n\n return provider;\n}\n\nexport function tracerFromProvider(provider: TracerProviderLike): Tracer {\n return provider.getTracer('stainless-xray');\n}\n\nexport function spanFromTracer(tracer: Pick<Tracer, 'startSpan'>, name: string): Span {\n return tracer.startSpan(name, { kind: SpanKind.SERVER }, ROOT_CONTEXT);\n}\n\nexport function spanStatusFromError(span: Span, err: unknown): void {\n if (err instanceof Error) {\n span.recordException(err);\n } else if (typeof err === 'string') {\n span.recordException(err);\n } else {\n span.recordException({ message: String(err) });\n }\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n\nclass DropFilterSpanProcessor implements SpanProcessor {\n private readonly next: SpanProcessor;\n\n constructor(next: SpanProcessor) {\n this.next = next;\n }\n\n forceFlush(): Promise<void> {\n return this.next.forceFlush();\n }\n\n onEnd(span: ReadableSpan): void {\n if (span.attributes[AttributeKeySpanDrop] === true) {\n return;\n }\n this.next.onEnd(span);\n }\n\n onStart(span: SDKSpan, parentContext: Context): void {\n this.next.onStart(span, parentContext);\n }\n\n shutdown(): Promise<void> {\n return this.next.shutdown();\n }\n}\n\nclass FetchSpanExporter implements SpanExporter {\n private readonly endpointUrl: string;\n private readonly headers: Record<string, string>;\n private readonly timeoutMillis: number;\n private isShutdown: boolean;\n private readonly serializer: {\n serializeRequest: (spans: ReadableSpan[]) => Uint8Array | undefined;\n };\n private readonly contentType: string;\n\n constructor(options: {\n endpointUrl: string;\n headers: Record<string, string>;\n timeoutMillis: number;\n }) {\n this.endpointUrl = options.endpointUrl;\n this.headers = { ...options.headers };\n this.timeoutMillis = options.timeoutMillis;\n this.isShutdown = false;\n const protobufSerializer =\n ProtobufTraceSerializer && typeof ProtobufTraceSerializer.serializeRequest === 'function'\n ? ProtobufTraceSerializer\n : null;\n this.serializer = protobufSerializer ?? JsonTraceSerializer;\n this.contentType = protobufSerializer ? 'application/x-protobuf' : 'application/json';\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.isShutdown) {\n resultCallback({ code: ExportResultCode.FAILED });\n return;\n }\n\n const payload = this.serializer.serializeRequest(spans);\n if (!payload) {\n resultCallback({\n code: ExportResultCode.FAILED,\n error: new Error('OTLP export failed: empty payload'),\n });\n return;\n }\n const headers = {\n ...this.headers,\n 'Content-Type': this.contentType,\n };\n\n const controller = typeof AbortController !== 'undefined' ? new AbortController() : null;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n if (controller) {\n timeout = setTimeout(() => controller.abort(), this.timeoutMillis);\n }\n\n const doExport = async (): Promise<void> => {\n const response = await fetch(this.endpointUrl, {\n method: 'POST',\n headers,\n body: payload as unknown as BodyInit,\n signal: controller?.signal,\n });\n\n if (!response.ok) {\n throw new Error(`OTLP export failed: ${response.status}`);\n }\n };\n\n doExport()\n .then(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n resultCallback({ code: ExportResultCode.SUCCESS });\n })\n .catch((err) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n diag.error('OTLP export failed', err);\n resultCallback({ code: ExportResultCode.FAILED, error: err });\n });\n }\n\n async forceFlush(): Promise<void> {\n return;\n }\n\n async shutdown(): Promise<void> {\n this.isShutdown = true;\n }\n}\n\nfunction createSpanProcessor(mode: 'simple' | 'batch', exporter: SpanExporter): SpanProcessor {\n if (mode === 'simple') {\n return new SimpleSpanProcessor(exporter);\n }\n\n return new BatchSpanProcessor(exporter, {\n maxQueueSize: 2048,\n maxExportBatchSize: 512,\n scheduledDelayMillis: 5_000,\n exportTimeoutMillis: 30_000,\n });\n}\n\nfunction createSampler(config: ResolvedXrayConfig) {\n const sampler = config.exporter.sampler;\n if (sampler.type === 'always_off') {\n return new AlwaysOffSampler();\n }\n if (sampler.type === 'ratio') {\n return new TraceIdRatioBasedSampler(sampler.ratio ?? 1);\n }\n return new AlwaysOnSampler();\n}\n\nfunction sdkVersion(): string {\n if (typeof __XRAY_VERSION__ !== 'undefined') {\n return __XRAY_VERSION__;\n }\n return 'unknown';\n}\n\nfunction isNodeRuntime(): boolean {\n const maybeProcess = (\n globalThis as typeof globalThis & {\n process?: { versions?: { node?: string } };\n }\n ).process;\n return !!maybeProcess?.versions?.node;\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 = 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 // Format as UUID string\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","import type { XrayConfig, ResolvedXrayConfig, CaptureConfig, RedactionConfig } from './config';\nimport { normalizeConfig } from './config';\nimport { logWithLevel } from './logger';\nimport { applyRedaction } from './redaction';\nimport { makeCapturedBody, sanitizeHeaderValues, sanitizeLogString } from './request_log';\nimport {\n setHeaderAttributes,\n setRequestAttributes,\n setRequestBodyAttributes,\n setRequestBodySizeAttribute,\n setRequestIdAttribute,\n setResponseBodyAttributes,\n setResponseBodySizeAttribute,\n setResponseStatusAttribute,\n setRouteAttribute,\n setUserIdAttribute,\n} from './attributes';\nimport {\n createTracerProvider,\n spanFromTracer,\n spanStatusFromError,\n tracerFromProvider,\n} from './otel';\nimport { normalizeRoutePattern } from './route';\nimport { uuidv7 } from './uuid';\nimport { bindContext, getContextState, type RequestState } from './state';\nimport type {\n AttributeValue,\n NormalizedRequest,\n NormalizedResponse,\n RequestLog,\n XrayContext,\n XrayEmitter,\n} from './types';\n\nexport function createEmitter(config: XrayConfig): XrayEmitter {\n const resolved = normalizeConfig(config);\n const tracerProvider = createTracerProvider(resolved);\n const tracer = tracerProvider ? tracerFromProvider(tracerProvider) : null;\n\n return {\n config: resolved,\n startRequest: (req) => startRequest(resolved, tracer, req),\n endRequest: (ctx, res, err) => endRequest(resolved, ctx, res, err),\n flush: () => (tracerProvider ? tracerProvider.forceFlush() : Promise.resolve()),\n shutdown: () => (tracerProvider ? tracerProvider.shutdown() : Promise.resolve()),\n };\n}\n\nfunction startRequest(\n config: ResolvedXrayConfig,\n tracer: ReturnType<typeof tracerFromProvider> | null,\n req: NormalizedRequest,\n): XrayContext {\n const startTimeMs = Number.isFinite(req.startTimeMs) ? req.startTimeMs : Date.now();\n req.startTimeMs = startTimeMs;\n\n const requestId = resolveRequestId(config, req.requestId, req.headers);\n req.requestId = requestId;\n\n if (req.route && config.route.normalize) {\n req.route = config.route.normalizer\n ? config.route.normalizer(req.route)\n : normalizeRoutePattern(req.route);\n }\n\n const span = tracer ? spanFromTracer(tracer, spanNameFromRequest(req)) : undefined;\n const context: XrayContext = {\n requestId,\n traceId: span?.spanContext().traceId,\n spanId: span?.spanContext().spanId,\n setUserId: (id) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.userId = id;\n if (span && id) {\n try {\n setUserIdAttribute(span, id);\n } catch {\n // Ignore span attribute errors.\n }\n }\n },\n setSessionId: (id) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.sessionId = id;\n },\n setAttribute: (key, value) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.attributes[key] = value;\n if (span) {\n try {\n span.setAttribute(key, value as AttributeValue);\n } catch {\n // Ignore span attribute errors.\n }\n }\n },\n addEvent: (name, attributes) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.events.push({ name, attributes });\n if (span) {\n try {\n span.addEvent(name, attributes as Record<string, AttributeValue> | undefined);\n } catch {\n // Ignore span event errors.\n }\n }\n },\n setError: (err) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.error = err;\n if (span) {\n try {\n spanStatusFromError(span, err);\n } catch {\n // Ignore span errors.\n }\n }\n },\n };\n\n const state: RequestState = {\n request: req,\n config,\n span,\n context,\n attributes: {},\n events: [],\n };\n\n bindContext(context, state);\n return context;\n}\n\nfunction endRequest(\n config: ResolvedXrayConfig,\n ctx: XrayContext,\n res: NormalizedResponse,\n err?: unknown,\n): RequestLog {\n const state = getContextState(ctx);\n const endTimeMs = Number.isFinite(res.endTimeMs) ? res.endTimeMs : Date.now();\n res.endTimeMs = endTimeMs;\n\n if (!state) {\n const fallbackLog: RequestLog = {\n requestId: ctx.requestId,\n serviceName: config.serviceName,\n method: res.statusCode ? 'UNKNOWN' : 'UNKNOWN',\n url: '',\n durationMs: 0,\n statusCode: res.statusCode,\n timestamp: new Date(endTimeMs).toISOString(),\n };\n return fallbackLog;\n }\n\n const request = state.request;\n const capture = resolveCapture(config.capture, state.captureOverride);\n const redaction = resolveRedaction(config.redaction, state.redactionOverride);\n\n const route = request.route;\n const url = sanitizeLogString(request.url);\n const log: RequestLog = {\n requestId: request.requestId ?? ctx.requestId,\n traceId: state.span?.spanContext().traceId,\n spanId: state.span?.spanContext().spanId,\n serviceName: config.serviceName,\n method: request.method,\n url: url,\n route: route,\n statusCode: res.statusCode,\n durationMs: Math.max(0, endTimeMs - request.startTimeMs),\n requestHeaders: capture.requestHeaders ? sanitizeHeaderValues(request.headers) : undefined,\n responseHeaders: capture.responseHeaders ? sanitizeHeaderValues(res.headers) : undefined,\n requestBody: capture.requestBody === 'none' ? undefined : request.body,\n responseBody: capture.responseBody === 'none' ? undefined : res.body,\n userId: state.userId ?? undefined,\n sessionId: state.sessionId ?? undefined,\n error: buildError(err ?? state.error),\n attributes: Object.keys(state.attributes).length > 0 ? { ...state.attributes } : undefined,\n timestamp: new Date(endTimeMs).toISOString(),\n };\n\n const redacted = applyRedaction(redaction, log);\n if (redacted.route && config.route.normalize) {\n const normalized = config.route.normalizer\n ? config.route.normalizer(redacted.route)\n : normalizeRoutePattern(redacted.route);\n redacted.route = normalized;\n }\n const span = state.span;\n if (span) {\n try {\n setRequestAttributes(span, request.method, redacted.url);\n setRequestIdAttribute(span, redacted.requestId);\n span.setAttribute('service.name', config.serviceName);\n if (redacted.statusCode != null) {\n setResponseStatusAttribute(span, redacted.statusCode);\n }\n if (redacted.route) {\n setRouteAttribute(span, redacted.route);\n span.updateName(`${request.method} ${redacted.route}`);\n } else {\n span.updateName(spanNameFromRequest(request));\n }\n if (redacted.requestHeaders) {\n setHeaderAttributes(span, redacted.requestHeaders, 'http.request.header.');\n }\n if (redacted.responseHeaders) {\n setHeaderAttributes(span, redacted.responseHeaders, 'http.response.header.');\n }\n if (redacted.requestBody) {\n setRequestBodyAttributes(span, redacted.requestBody);\n setRequestBodySizeAttribute(span, redacted.requestBody.bytes);\n }\n if (redacted.responseBody) {\n setResponseBodyAttributes(span, redacted.responseBody);\n setResponseBodySizeAttribute(span, redacted.responseBody.bytes);\n }\n if (state.userId) {\n setUserIdAttribute(span, state.userId);\n }\n if (err ?? state.error) {\n spanStatusFromError(span, err ?? state.error);\n }\n span.end();\n } catch (spanErr) {\n logWithLevel(config.logger, 'warn', config.logLevel, 'xray: span finalize failed', {\n error: spanErr instanceof Error ? spanErr.message : String(spanErr),\n });\n }\n }\n\n return redacted;\n}\n\nfunction resolveRequestId(\n config: ResolvedXrayConfig,\n requestId: string | undefined,\n headers: Record<string, string | string[]>,\n): string {\n if (requestId) {\n return requestId;\n }\n const headerName = config.requestId.header.toLowerCase();\n const headerValue = headers[headerName];\n if (headerValue) {\n const value = Array.isArray(headerValue) ? headerValue[0] : headerValue;\n if (value && value.trim()) {\n return value.trim();\n }\n }\n if (!config.requestId.generate) {\n return uuidv7();\n }\n return uuidv7();\n}\n\nfunction resolveCapture(base: CaptureConfig, override?: Partial<CaptureConfig>): CaptureConfig {\n if (!override) {\n return base;\n }\n return {\n ...base,\n ...override,\n };\n}\n\nfunction resolveRedaction(\n base: RedactionConfig,\n override?: Partial<RedactionConfig>,\n): RedactionConfig {\n const merged: RedactionConfig = {\n ...base,\n ...override,\n };\n\n merged.headers = normalizeLowercaseList(merged.headers);\n merged.queryParams = normalizeLowercaseList(merged.queryParams);\n merged.bodyJsonPaths = normalizeList(merged.bodyJsonPaths);\n merged.replacement = merged.replacement || base.replacement;\n\n return merged;\n}\n\nfunction normalizeLowercaseList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim().toLowerCase()).filter(Boolean);\n}\n\nfunction normalizeList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim()).filter(Boolean);\n}\n\nfunction buildError(err?: unknown): RequestLog['error'] {\n if (!err) {\n return undefined;\n }\n if (err instanceof Error) {\n return {\n message: err.message || 'Error',\n type: err.name || 'Error',\n stack: err.stack,\n };\n }\n return {\n message: String(err),\n };\n}\n\nfunction spanNameFromRequest(req: NormalizedRequest): string {\n const method = req.method || 'GET';\n if (req.route) {\n return `${method} ${req.route}`;\n }\n const path = safePath(req.url);\n return `${method} ${path}`;\n}\n\nfunction safePath(url: string): string {\n try {\n const parsed = new URL(url);\n return parsed.pathname || '/';\n } catch {\n const rawPath = url.split('?')[0] || '/';\n return rawPath || '/';\n }\n}\n\nexport function captureBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64' | 'none',\n): ReturnType<typeof makeCapturedBody> {\n if (mode === 'none') {\n return undefined;\n }\n return makeCapturedBody(bytes, totalBytes, truncated, mode === 'text' ? 'text' : 'base64');\n}\n\nexport function captureResponseBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64' | 'none',\n): ReturnType<typeof makeCapturedBody> {\n if (mode === 'none') {\n return undefined;\n }\n return makeCapturedBody(bytes, totalBytes, truncated, mode === 'text' ? 'text' : 'base64');\n}\n"],"mappings":"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","names":["state"]}
1
+ {"version":3,"sources":["../src/route.ts","../src/config.ts","../src/header_redaction.ts","../src/redaction.ts","../src/attrkey.ts","../src/attributes.ts","../src/otel.ts","../src/uuid.ts","../src/emitter.ts"],"sourcesContent":["export function normalizeRoutePattern(route: string): string {\n if (!route) {\n return '/';\n }\n\n const cleaned = stripQueryAndFragment(route).trim();\n if (!cleaned) {\n return '/';\n }\n\n const withoutMethod = stripMethodPrefix(cleaned);\n const leading = withoutMethod.startsWith('/') ? withoutMethod : `/${withoutMethod}`;\n const segments = leading.split('/').filter(Boolean);\n if (segments.length === 0) {\n return '/';\n }\n\n const normalized = segments.map(normalizeRouteSegment).join('/');\n return `/${normalized}`;\n}\n\nfunction stripMethodPrefix(value: string): string {\n if (!/^[A-Z]+\\s+\\//.test(value)) {\n return value;\n }\n const spaceIndex = value.search(/\\s+/);\n if (spaceIndex < 0) {\n return value;\n }\n return value.slice(spaceIndex).trim();\n}\n\nfunction stripQueryAndFragment(value: string): string {\n const hashIndex = value.indexOf('#');\n const beforeHash = hashIndex >= 0 ? value.slice(0, hashIndex) : value;\n const queryIndex = beforeHash.indexOf('?');\n return queryIndex >= 0 ? beforeHash.slice(0, queryIndex) : beforeHash;\n}\n\nfunction normalizeRouteSegment(segment: string): string {\n if (segment === '*') {\n return '{wildcard}';\n }\n\n const param = extractRouteParam(segment);\n if (param) {\n return `{${param}}`;\n }\n\n return segment;\n}\n\nfunction extractRouteParam(segment: string): string | null {\n if (!segment) {\n return null;\n }\n\n if (segment.startsWith('[') && segment.endsWith(']')) {\n return normalizeNextParam(segment);\n }\n\n if (segment.startsWith('{') && segment.endsWith('}')) {\n const inner = segment.slice(1, -1);\n const trimmed = stripParamDecorators(inner);\n return extractParamName(trimmed);\n }\n\n if (segment.startsWith(':') || segment.startsWith('$')) {\n return extractParamName(segment.slice(1));\n }\n\n return null;\n}\n\nfunction normalizeNextParam(segment: string): string | null {\n let inner = segment.slice(1, -1);\n if (inner.startsWith('[') && inner.endsWith(']')) {\n inner = inner.slice(1, -1);\n }\n if (inner.startsWith('...')) {\n inner = inner.slice(3);\n }\n return extractParamName(inner);\n}\n\nfunction stripParamDecorators(value: string): string {\n let trimmed = value.trim();\n if (!trimmed) {\n return trimmed;\n }\n if (trimmed.endsWith('...')) {\n trimmed = trimmed.slice(0, -3);\n }\n return trimmed.replace(/[?*+]+$/, '');\n}\n\nfunction extractParamName(value: string): string | null {\n if (!value) {\n return null;\n }\n const match = value.match(/^[A-Za-z0-9_-]+/);\n return match?.[0] ?? null;\n}\n","import { encodeBase64 } from './encoding';\nimport { normalizeRoutePattern } from './route';\nimport type { Logger, LogLevel } from './types';\n\nexport interface ExporterConfig {\n endpointUrl: string;\n headers?: Record<string, string>;\n timeoutMs: number;\n spanProcessor: 'simple' | 'batch';\n}\n\nexport interface CaptureConfig {\n requestHeaders: boolean;\n responseHeaders: boolean;\n requestBody: 'none' | 'text' | 'base64';\n responseBody: 'none' | 'text' | 'base64';\n maxBodyBytes: number;\n}\n\nexport interface RedactionConfig {\n headers: string[];\n queryParams: string[];\n bodyJsonPaths: string[];\n replacement: string;\n}\n\nexport interface RequestIdConfig {\n header: string;\n generate: boolean;\n}\n\nexport interface RouteConfig {\n normalize: boolean;\n normalizer?: (path: string) => string;\n}\n\nexport interface XrayConfig {\n serviceName: string;\n environment?: string;\n version?: string;\n logger?: Logger;\n logLevel?: LogLevel;\n endpointUrl?: string;\n exporter?: Partial<ExporterConfig>;\n capture?: Partial<CaptureConfig>;\n redaction?: Partial<RedactionConfig>;\n requestId?: Partial<RequestIdConfig>;\n route?: Partial<RouteConfig>;\n}\n\nexport interface ResolvedXrayConfig {\n serviceName: string;\n environment?: string;\n version?: string;\n logger: Logger;\n logLevel: LogLevel;\n exporter: ExporterConfig;\n capture: CaptureConfig;\n redaction: RedactionConfig;\n requestId: RequestIdConfig;\n route: RouteConfig;\n}\n\nconst defaultCapture: CaptureConfig = {\n requestHeaders: true,\n responseHeaders: true,\n requestBody: 'none',\n responseBody: 'none',\n maxBodyBytes: 65536,\n};\n\nconst defaultRedaction: RedactionConfig = {\n headers: ['authorization', 'cookie', 'set-cookie', 'x-api-key'],\n queryParams: [],\n bodyJsonPaths: [],\n replacement: '[REDACTED]',\n};\n\nconst defaultRequestId: RequestIdConfig = {\n header: 'x-request-id',\n generate: true,\n};\n\nconst defaultRoute: RouteConfig = {\n normalize: true,\n normalizer: normalizeRoutePattern,\n};\n\nconst DEFAULT_ENDPOINT_URL = 'http://localhost:4318';\n\nconst defaultExporterBase: ExporterConfig = {\n endpointUrl: DEFAULT_ENDPOINT_URL,\n headers: {},\n timeoutMs: 5000,\n spanProcessor: 'batch',\n};\n\nexport class XrayConfigError extends Error {\n code: 'INVALID_CONFIG' | 'INVALID_REDACTION';\n\n constructor(code: XrayConfigError['code'], message: string) {\n super(message);\n this.code = code;\n }\n}\n\nexport function normalizeConfig(config: XrayConfig): ResolvedXrayConfig {\n if (!config || !config.serviceName || !config.serviceName.trim()) {\n throw new XrayConfigError('INVALID_CONFIG', 'serviceName is required');\n }\n\n const logger = config.logger ?? console;\n const logLevel = config.logLevel ?? 'warn';\n\n const capture = normalizeCapture(config.capture);\n const redaction = normalizeRedaction(config.redaction);\n const requestId = normalizeRequestId(config.requestId);\n const route = normalizeRoute(config.route);\n const exporter = normalizeExporter(config.endpointUrl, config.exporter);\n\n return {\n serviceName: config.serviceName.trim(),\n environment: config.environment?.trim() || undefined,\n version: config.version?.trim() || undefined,\n logger,\n logLevel,\n exporter,\n capture,\n redaction,\n requestId,\n route,\n };\n}\n\nfunction normalizeCapture(cfg?: Partial<CaptureConfig>): CaptureConfig {\n const capture: CaptureConfig = {\n ...defaultCapture,\n ...cfg,\n };\n\n if (!['none', 'text', 'base64'].includes(capture.requestBody)) {\n throw new XrayConfigError(\n 'INVALID_CONFIG',\n 'capture.requestBody must be none, text, or base64',\n );\n }\n if (!['none', 'text', 'base64'].includes(capture.responseBody)) {\n throw new XrayConfigError(\n 'INVALID_CONFIG',\n 'capture.responseBody must be none, text, or base64',\n );\n }\n if (!Number.isFinite(capture.maxBodyBytes) || capture.maxBodyBytes < 0) {\n throw new XrayConfigError('INVALID_CONFIG', 'capture.maxBodyBytes must be >= 0');\n }\n\n return capture;\n}\n\nfunction normalizeRedaction(cfg?: Partial<RedactionConfig>): RedactionConfig {\n const redaction: RedactionConfig = {\n ...defaultRedaction,\n ...cfg,\n };\n\n redaction.headers = normalizeStringList(redaction.headers);\n redaction.queryParams = normalizeStringList(redaction.queryParams);\n redaction.bodyJsonPaths = normalizeStringList(redaction.bodyJsonPaths);\n redaction.replacement = redaction.replacement || defaultRedaction.replacement;\n\n if (!redaction.replacement) {\n throw new XrayConfigError('INVALID_REDACTION', 'redaction.replacement must be non-empty');\n }\n\n return redaction;\n}\n\nfunction normalizeRequestId(cfg?: Partial<RequestIdConfig>): RequestIdConfig {\n const requestId: RequestIdConfig = {\n ...defaultRequestId,\n ...cfg,\n };\n\n requestId.header = requestId.header.trim().toLowerCase();\n if (!requestId.header) {\n throw new XrayConfigError('INVALID_CONFIG', 'requestId.header must be non-empty');\n }\n\n return requestId;\n}\n\nfunction normalizeRoute(cfg?: Partial<RouteConfig>): RouteConfig {\n const route: RouteConfig = {\n ...defaultRoute,\n ...cfg,\n };\n\n if (route.normalize && !route.normalizer) {\n route.normalizer = normalizeRoutePattern;\n }\n\n return route;\n}\n\nfunction normalizeExporter(\n endpointUrl: string | undefined,\n cfg?: Partial<ExporterConfig>,\n): ExporterConfig {\n const resolvedEndpoint = normalizeExporterEndpoint(cfg?.endpointUrl ?? endpointUrl);\n const rawHeaders = cfg?.headers ?? defaultExporterBase.headers ?? {};\n const parsed = applyEndpointAuth(resolvedEndpoint, rawHeaders);\n const exporter: ExporterConfig = {\n ...defaultExporterBase,\n endpointUrl: parsed.endpointUrl,\n headers: parsed.headers,\n timeoutMs: cfg?.timeoutMs ?? defaultExporterBase.timeoutMs,\n spanProcessor: cfg?.spanProcessor ?? defaultExporterBase.spanProcessor,\n };\n\n return exporter;\n}\n\nfunction normalizeExporterEndpoint(endpointUrl: string | undefined): string {\n const envUrl =\n typeof process !== 'undefined' ? process.env?.['STAINLESS_XRAY_ENDPOINT_URL'] : undefined;\n const resolved = endpointUrl ?? envUrl ?? DEFAULT_ENDPOINT_URL;\n const trimmed = resolved.trim();\n const withoutTrailingSlash = trimmed.endsWith('/') ? trimmed.slice(0, -1) : trimmed;\n if (withoutTrailingSlash.endsWith('/v1/traces')) {\n return withoutTrailingSlash;\n }\n return `${withoutTrailingSlash}/v1/traces`;\n}\n\nfunction normalizeStringList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim()).filter(Boolean);\n}\n\nconst textEncoder = typeof TextEncoder !== 'undefined' ? new TextEncoder() : null;\nconst maybeBuffer = (\n globalThis as typeof globalThis & {\n Buffer?: { from(data: string, encoding?: string): Uint8Array };\n }\n).Buffer;\n\nfunction applyEndpointAuth(\n endpointUrl: string,\n headers: Record<string, string> | undefined,\n): { endpointUrl: string; headers: Record<string, string> } {\n const resolvedHeaders = headers ?? {};\n let url: URL;\n try {\n url = new URL(endpointUrl);\n } catch {\n return { endpointUrl, headers: resolvedHeaders };\n }\n\n const username = decodeUserInfo(url.username);\n const password = decodeUserInfo(url.password);\n if (!username && !password) {\n return { endpointUrl, headers: resolvedHeaders };\n }\n\n url.username = '';\n url.password = '';\n const sanitizedUrl = url.toString();\n\n if (hasAuthorizationHeader(resolvedHeaders)) {\n return { endpointUrl: sanitizedUrl, headers: resolvedHeaders };\n }\n\n const authorization = encodeBasicAuth(username, password);\n if (!authorization) {\n return { endpointUrl: sanitizedUrl, headers: resolvedHeaders };\n }\n\n return {\n endpointUrl: sanitizedUrl,\n headers: {\n ...resolvedHeaders,\n Authorization: authorization,\n },\n };\n}\n\nfunction decodeUserInfo(value: string): string {\n if (!value) {\n return value;\n }\n try {\n return decodeURIComponent(value);\n } catch {\n return value;\n }\n}\n\nfunction hasAuthorizationHeader(headers: Record<string, string>): boolean {\n return Object.keys(headers).some((key) => key.toLowerCase() === 'authorization');\n}\n\nfunction encodeBasicAuth(username: string, password: string): string | undefined {\n const raw = `${username}:${password}`;\n let bytes: Uint8Array | undefined;\n if (textEncoder) {\n bytes = textEncoder.encode(raw);\n } else if (maybeBuffer) {\n bytes = maybeBuffer.from(raw, 'utf8');\n }\n if (!bytes) {\n return undefined;\n }\n const encoded = encodeBase64(bytes);\n if (!encoded) {\n return undefined;\n }\n return `Basic ${encoded}`;\n}\n","const headerNameCompactor = /[-_.]/g;\nconst headerTokenSplitter = /[-_.]/;\n\ntype HeaderRedactionMatcher = {\n exactSensitive: Set<string>;\n keywordTokens: Set<string>;\n keywordCompacted: string[];\n};\n\nconst defaultHeaderMatcher = newHeaderRedactionMatcher(\n defaultSensitiveHeaderNames(),\n defaultSensitiveKeywords(),\n);\n\nexport function authSchemePrefix(value: string): string {\n if (!value) {\n return '';\n }\n\n const lower = value.toLowerCase();\n if (lower.startsWith('basic')) {\n return value.slice(0, 'basic'.length);\n }\n if (lower.startsWith('bearer')) {\n return value.slice(0, 'bearer'.length);\n }\n if (lower.startsWith('digest')) {\n return value.slice(0, 'digest'.length);\n }\n if (lower.startsWith('negotiate')) {\n return value.slice(0, 'negotiate'.length);\n }\n return '';\n}\n\nexport function redactCookieValue(value: string, replacement: string): string {\n if (!value) {\n return replacement;\n }\n\n const parts = value.split(';');\n const redacted: string[] = [];\n\n for (const part of parts) {\n const segment = part.trim();\n if (!segment) {\n redacted.push(replacement);\n continue;\n }\n const idx = segment.indexOf('=');\n if (idx <= 0) {\n redacted.push(replacement);\n continue;\n }\n const name = segment.slice(0, idx);\n if (!name) {\n redacted.push(replacement);\n continue;\n }\n redacted.push(`${name}=${replacement}`);\n }\n\n return redacted.join('; ');\n}\n\nexport function redactSetCookieValue(value: string, replacement: string): string {\n if (!value) {\n return replacement;\n }\n\n const parts = value.split(';');\n const first = parts.shift() ?? '';\n const idx = first.indexOf('=');\n if (idx <= 0) {\n return replacement;\n }\n const name = first.slice(0, idx);\n if (!name) {\n return replacement;\n }\n\n const redacted = `${name}=${replacement}`;\n if (parts.length === 0) {\n return redacted;\n }\n return `${redacted};${parts.join(';')}`;\n}\n\nexport function isSensitiveHeaderName(key: string): boolean {\n return isSensitiveNormalized(defaultHeaderMatcher, normalizeHeaderName(key));\n}\n\nfunction addSensitiveHeaderNames(target: Set<string>, headers: string[]): void {\n for (const header of headers) {\n const normalized = normalizeHeaderName(header);\n if (normalized) {\n target.add(normalized);\n }\n }\n}\n\nfunction buildKeywordSets(keywords: string[]): { compacted: string[]; tokens: Set<string> } {\n const tokens = new Set<string>();\n const compacted = new Set<string>();\n\n for (const keyword of keywords) {\n const normalized = normalizeHeaderName(keyword);\n if (!normalized) {\n continue;\n }\n const compactedKeyword = compactNormalizedHeaderName(normalized);\n if (compactedKeyword) {\n compacted.add(compactedKeyword);\n }\n if (!normalized.includes('-') && !normalized.includes('_') && !normalized.includes('.')) {\n tokens.add(normalized);\n }\n }\n\n return {\n compacted: Array.from(compacted).sort(),\n tokens,\n };\n}\n\nfunction compactNormalizedHeaderName(normalized: string): string {\n if (!normalized) {\n return '';\n }\n return normalized.replace(headerNameCompactor, '');\n}\n\nfunction defaultSensitiveHeaderNames(): string[] {\n return [\n 'authorization',\n 'cookie',\n 'proxy-authenticate',\n 'proxy-authorization',\n 'set-cookie',\n 'www-authenticate',\n ];\n}\n\nfunction defaultSensitiveKeywords(): string[] {\n return [\n 'api-key',\n 'api_key',\n 'apikey',\n 'auth',\n 'authenticate',\n 'authorization',\n 'credential',\n 'password',\n 'passwd',\n 'private-key',\n 'private_key',\n 'privatekey',\n 'secret',\n 'session',\n 'sessionid',\n 'signature',\n 'token',\n ];\n}\n\nfunction headerNameTokens(name: string): string[] {\n if (!name) {\n return [];\n }\n return name.split(headerTokenSplitter).filter(Boolean);\n}\n\nfunction hasKeywordToken(tokens: string[], keywordTokens: Set<string>): boolean {\n for (const token of tokens) {\n if (keywordTokens.has(token)) {\n return true;\n }\n }\n return false;\n}\n\nfunction isExactMatch(normalized: string, exactSensitive: Set<string>): boolean {\n return exactSensitive.has(normalized);\n}\n\nfunction isSensitiveNormalized(matcher: HeaderRedactionMatcher, normalized: string): boolean {\n if (!normalized) {\n return false;\n }\n if (isExactMatch(normalized, matcher.exactSensitive)) {\n return true;\n }\n if (hasKeywordToken(headerNameTokens(normalized), matcher.keywordTokens)) {\n return true;\n }\n return matchesCompacted(normalized, matcher.keywordCompacted);\n}\n\nfunction matchesCompacted(normalized: string, keywordCompacted: string[]): boolean {\n if (keywordCompacted.length === 0) {\n return false;\n }\n const compacted = compactNormalizedHeaderName(normalized);\n if (!compacted) {\n return false;\n }\n return keywordCompacted.some((keyword) => compacted.includes(keyword));\n}\n\nfunction newHeaderRedactionMatcher(names: string[], keywords: string[]): HeaderRedactionMatcher {\n const exactSensitive = new Set<string>();\n addSensitiveHeaderNames(exactSensitive, names);\n const { compacted, tokens } = buildKeywordSets(keywords);\n return {\n exactSensitive,\n keywordCompacted: compacted,\n keywordTokens: tokens,\n };\n}\n\nfunction normalizeHeaderName(name: string): string {\n return name.trim().toLowerCase();\n}\n","import type { CapturedBody, RequestLog } from './types';\nimport { authSchemePrefix, redactCookieValue, redactSetCookieValue } from './header_redaction';\n\nexport function applyRedaction(\n config: {\n headers: string[];\n queryParams: string[];\n bodyJsonPaths: string[];\n replacement: string;\n },\n log: RequestLog,\n): RequestLog {\n const redacted = { ...log };\n\n if (redacted.requestHeaders) {\n redacted.requestHeaders = redactHeaders(redacted.requestHeaders, config);\n }\n if (redacted.responseHeaders) {\n redacted.responseHeaders = redactHeaders(redacted.responseHeaders, config);\n }\n\n redacted.url = redactUrl(redacted.url, config);\n\n if (redacted.requestBody) {\n redacted.requestBody = redactBody(redacted.requestBody, redacted.requestHeaders, config);\n }\n if (redacted.responseBody) {\n redacted.responseBody = redactBody(redacted.responseBody, redacted.responseHeaders, config);\n }\n\n return redacted;\n}\n\nfunction redactHeaders(\n headers: Record<string, string | string[]>,\n config: { headers: string[]; replacement: string },\n): Record<string, string | string[]> {\n const list = new Set(config.headers.map((name) => name.toLowerCase()));\n const result: Record<string, string | string[]> = {};\n\n for (const [name, value] of Object.entries(headers)) {\n const lower = name.toLowerCase();\n if (!list.has(lower)) {\n result[name] = value;\n continue;\n }\n\n const redactValue = (entry: string) => redactHeaderValue(lower, entry, config.replacement);\n if (Array.isArray(value)) {\n result[name] = value.map(redactValue);\n } else {\n result[name] = redactValue(value);\n }\n }\n\n return result;\n}\n\nfunction redactHeaderValue(name: string, value: string, replacement: string): string {\n switch (name) {\n case 'authorization':\n case 'proxy-authorization': {\n const scheme = authSchemePrefix(value);\n if (!scheme) {\n return replacement;\n }\n return `${scheme} ${replacement}`;\n }\n case 'cookie':\n return redactCookieValue(value, replacement);\n case 'set-cookie':\n return redactSetCookieValue(value, replacement);\n default:\n return replacement;\n }\n}\n\nfunction redactUrl(value: string, config: { queryParams: string[]; replacement: string }): string {\n if (!value || config.queryParams.length === 0) {\n return value;\n }\n\n try {\n const parsed = new URL(value);\n const params = parsed.searchParams;\n if (!params || params.size === 0) {\n return value;\n }\n\n const redact = new Set(config.queryParams.map((key) => key.toLowerCase()));\n const next = new URLSearchParams();\n params.forEach((val, key) => {\n if (redact.has(key.toLowerCase())) {\n next.append(key, config.replacement);\n } else {\n next.append(key, val);\n }\n });\n parsed.search = next.toString();\n return parsed.toString();\n } catch {\n return value;\n }\n}\n\nfunction redactBody(\n body: CapturedBody,\n headers: Record<string, string | string[]> | undefined,\n config: { bodyJsonPaths: string[]; replacement: string },\n): CapturedBody {\n if (config.bodyJsonPaths.length === 0) {\n return body;\n }\n if (!body.value || body.encoding !== 'utf8') {\n return body;\n }\n if (!isJsonContentType(headers)) {\n return body;\n }\n\n let parsed: unknown;\n try {\n parsed = JSON.parse(body.value);\n } catch {\n return body;\n }\n\n for (const path of config.bodyJsonPaths) {\n const segments = parseJsonPath(path);\n if (!segments) {\n continue;\n }\n redactJsonPath(parsed, segments, config.replacement);\n }\n\n const next = { ...body };\n next.value = JSON.stringify(parsed);\n return next;\n}\n\nfunction isJsonContentType(headers?: Record<string, string | string[]>): boolean {\n if (!headers) {\n return false;\n }\n const contentType = headers['content-type'] || headers['Content-Type'];\n const value = Array.isArray(contentType) ? contentType[0] : contentType;\n if (!value) {\n return false;\n }\n const normalized = value.split(';')[0];\n if (!normalized) {\n return false;\n }\n const trimmed = normalized.trim().toLowerCase();\n return trimmed === 'application/json' || trimmed.endsWith('+json');\n}\n\ntype JsonPathSegment = string | number;\n\nfunction parseJsonPath(path: string): JsonPathSegment[] | null {\n const trimmed = path.trim();\n if (!trimmed) {\n return null;\n }\n\n const normalized = trimmed.startsWith('$.') ? trimmed.slice(2) : trimmed;\n if (!normalized) {\n return null;\n }\n\n const segments: JsonPathSegment[] = [];\n const parts = normalized.split('.');\n for (const part of parts) {\n if (!part) {\n continue;\n }\n let cursor = part;\n const bracketIndex = cursor.indexOf('[');\n if (bracketIndex === -1) {\n segments.push(cursor);\n continue;\n }\n\n const name = cursor.slice(0, bracketIndex);\n if (name) {\n segments.push(name);\n }\n cursor = cursor.slice(bracketIndex);\n const matches = cursor.match(/\\[(\\d+)\\]/g);\n if (!matches) {\n continue;\n }\n for (const match of matches) {\n const indexValue = match.slice(1, -1);\n const index = Number.parseInt(indexValue, 10);\n if (Number.isFinite(index)) {\n segments.push(index);\n }\n }\n }\n\n return segments.length > 0 ? segments : null;\n}\n\nfunction redactJsonPath(value: unknown, segments: JsonPathSegment[], replacement: string): void {\n if (!value || segments.length === 0) {\n return;\n }\n\n let current: unknown = value;\n for (let i = 0; i < segments.length; i += 1) {\n const segment = segments[i];\n if (segment === undefined) {\n return;\n }\n const isLast = i === segments.length - 1;\n\n if (typeof segment === 'number') {\n if (!Array.isArray(current) || segment < 0 || segment >= current.length) {\n return;\n }\n if (isLast) {\n current[segment] = replacement;\n return;\n }\n current = current[segment];\n continue;\n }\n\n if (!current || typeof current !== 'object') {\n return;\n }\n const record = current as Record<string, unknown>;\n if (!(segment in record)) {\n return;\n }\n if (isLast) {\n record[segment] = replacement;\n return;\n }\n current = record[segment];\n }\n}\n","export const AttributeKeyPrefixRequestHeader = 'http.request.header.';\nexport const AttributeKeyPrefixResponseHeader = 'http.response.header.';\nexport const AttributeKeyRequestBody = 'http.request.body';\nexport const AttributeKeyRequestBodyEncoding = 'http.request.body.encoding';\nexport const AttributeKeyRequestBodyTruncated = 'http.request.body.truncated';\nexport const AttributeKeyRequestID = 'http.request.id';\nexport const AttributeKeyResponseBody = 'http.response.body';\nexport const AttributeKeyResponseBodyEncoding = 'http.response.body.encoding';\nexport const AttributeKeyResponseBodyTruncated = 'http.response.body.truncated';\nexport const AttributeKeySpanDrop = 'stainlessxray.internal.drop';\nexport const AttributeKeyXrayCaptureErrorCode = 'xray.capture_error_code';\nexport const AttributeKeyXrayErrorThrown = 'xray.error_thrown';\nexport const AttributeKeyXrayHeadersTruncated = 'xray.headers_truncated';\nexport const AttributeKeyXrayInvalidResponse = 'xray.invalid_response';\nexport const AttributeKeyXrayRequestBodyCaptureFailed = 'xray.request_body_capture_failed';\nexport const AttributeKeyXrayRequestBodyTruncated = 'xray.request_body_truncated';\nexport const AttributeKeyXrayResponseBodyCaptureFailed = 'xray.response_body_capture_failed';\nexport const AttributeKeyXrayResponseBodyTruncated = 'xray.response_body_truncated';\n","import type { Span } from '@opentelemetry/api';\nimport type { CapturedBody } from './types';\nimport {\n AttributeKeyRequestBody,\n AttributeKeyRequestBodyEncoding,\n AttributeKeyRequestBodyTruncated,\n AttributeKeyRequestID,\n AttributeKeyResponseBody,\n AttributeKeyResponseBodyEncoding,\n AttributeKeyResponseBodyTruncated,\n} from './attrkey';\n\nconst attributeKeyEndUserId = 'enduser.id';\nconst attributeKeyHttpRequestBodySize = 'http.request.body.size';\nconst attributeKeyHttpRequestMethod = 'http.request.method';\nconst attributeKeyHttpResponseBodySize = 'http.response.body.size';\nconst attributeKeyHttpResponseStatusCode = 'http.response.status_code';\nconst attributeKeyHttpRoute = 'http.route';\nconst attributeKeyUrlPath = 'url.path';\nconst attributeKeyUrlFull = 'url.full';\n\nexport function setHeaderAttributes(\n span: Span,\n headers: Record<string, string | string[]> | undefined,\n prefix: string,\n): void {\n if (!headers) {\n return;\n }\n const keys = Object.keys(headers).sort((a, b) => a.toLowerCase().localeCompare(b.toLowerCase()));\n for (const key of keys) {\n const values = headers[key];\n if (!values || (Array.isArray(values) && values.length === 0)) {\n continue;\n }\n span.setAttribute(prefix + key.toLowerCase(), Array.isArray(values) ? values : [values]);\n }\n}\n\nexport function setRequestAttributes(\n span: Span,\n method: string,\n urlFull: string | undefined,\n): void {\n span.setAttribute(attributeKeyHttpRequestMethod, method);\n if (urlFull) {\n span.setAttribute(attributeKeyUrlFull, urlFull);\n const path = extractPath(urlFull);\n if (path) {\n span.setAttribute(attributeKeyUrlPath, path);\n }\n }\n}\n\nfunction extractPath(url: string): string | undefined {\n try {\n return new URL(url).pathname;\n } catch {\n // If not a full URL, try to extract path directly\n const match = url.match(/^[^?#]*/);\n return match?.[0] || undefined;\n }\n}\n\nexport function setRequestBodyAttributes(span: Span, body: CapturedBody): void {\n if (!body.value) {\n return;\n }\n span.setAttribute(AttributeKeyRequestBody, body.value);\n span.setAttribute(AttributeKeyRequestBodyEncoding, body.encoding);\n if (body.truncated) {\n span.setAttribute(AttributeKeyRequestBodyTruncated, true);\n }\n}\n\nexport function setRequestBodySizeAttribute(span: Span, size: number): void {\n span.setAttribute(attributeKeyHttpRequestBodySize, size);\n}\n\nexport function setResponseBodyAttributes(span: Span, body: CapturedBody): void {\n if (!body.value) {\n return;\n }\n span.setAttribute(AttributeKeyResponseBody, body.value);\n span.setAttribute(AttributeKeyResponseBodyEncoding, body.encoding);\n if (body.truncated) {\n span.setAttribute(AttributeKeyResponseBodyTruncated, true);\n }\n}\n\nexport function setResponseBodySizeAttribute(span: Span, size: number): void {\n span.setAttribute(attributeKeyHttpResponseBodySize, size);\n}\n\nexport function setResponseStatusAttribute(span: Span, statusCode: number): void {\n span.setAttribute(attributeKeyHttpResponseStatusCode, statusCode);\n}\n\nexport function setRouteAttribute(span: Span, route: string | undefined): void {\n if (route) {\n span.setAttribute(attributeKeyHttpRoute, route);\n }\n}\n\nexport function setUserIdAttribute(span: Span, userId: string): void {\n span.setAttribute(attributeKeyEndUserId, userId);\n}\n\nexport function setRequestIdAttribute(span: Span, requestId: string): void {\n span.setAttribute(AttributeKeyRequestID, requestId);\n}\n","import {\n diag,\n ROOT_CONTEXT,\n SpanKind,\n SpanStatusCode,\n type Context,\n type Span,\n type Tracer,\n} from '@opentelemetry/api';\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core';\nimport {\n AlwaysOnSampler,\n BasicTracerProvider,\n BatchSpanProcessor,\n type ReadableSpan,\n SimpleSpanProcessor,\n type Span as SDKSpan,\n type SpanExporter,\n type SpanProcessor,\n} from '@opentelemetry/sdk-trace-base';\nimport { resourceFromAttributes } from '@opentelemetry/resources';\nimport {\n ATTR_SERVICE_NAME,\n ATTR_TELEMETRY_SDK_LANGUAGE,\n ATTR_TELEMETRY_SDK_NAME,\n ATTR_TELEMETRY_SDK_VERSION,\n} from '@opentelemetry/semantic-conventions';\nimport { JsonTraceSerializer, ProtobufTraceSerializer } from '@opentelemetry/otlp-transformer';\nimport { AttributeKeySpanDrop } from './attrkey';\nimport type { ResolvedXrayConfig } from './config';\nimport { logWithLevel } from './logger';\n\nconst defaultAttributeCountLimit = 128;\n\nexport interface TracerProviderLike {\n forceFlush: () => Promise<void>;\n getTracer: (name: string, version?: string) => Tracer;\n shutdown: () => Promise<void>;\n}\n\nexport function createTracerProvider(config: ResolvedXrayConfig): TracerProviderLike {\n if (config.exporter.endpointUrl.startsWith('http://')) {\n diag.warn('xray: OTLP endpoint uses plaintext HTTP');\n }\n\n const attributeValueLengthLimit = Math.max(1, Math.ceil((config.capture.maxBodyBytes * 4) / 3));\n\n const resource = resourceFromAttributes({\n [ATTR_SERVICE_NAME]: config.serviceName,\n [ATTR_TELEMETRY_SDK_LANGUAGE]: isNodeRuntime() ? 'nodejs' : 'webjs',\n [ATTR_TELEMETRY_SDK_NAME]: 'stainless-xray',\n [ATTR_TELEMETRY_SDK_VERSION]: sdkVersion(),\n });\n\n const exporter = new FetchSpanExporter({\n endpointUrl: config.exporter.endpointUrl,\n headers: config.exporter.headers ?? {},\n timeoutMillis: config.exporter.timeoutMs,\n logger: config.logger,\n logLevel: config.logLevel,\n });\n\n const spanProcessor = createSpanProcessor(config.exporter.spanProcessor, exporter);\n const dropProcessor = new DropFilterSpanProcessor(spanProcessor);\n\n const provider = new BasicTracerProvider({\n forceFlushTimeoutMillis: 30_000,\n generalLimits: {\n attributeCountLimit: defaultAttributeCountLimit,\n attributeValueLengthLimit,\n },\n resource,\n sampler: new AlwaysOnSampler(),\n spanLimits: {\n attributeCountLimit: defaultAttributeCountLimit,\n attributePerEventCountLimit: defaultAttributeCountLimit,\n attributePerLinkCountLimit: defaultAttributeCountLimit,\n attributeValueLengthLimit,\n eventCountLimit: defaultAttributeCountLimit,\n linkCountLimit: defaultAttributeCountLimit,\n },\n spanProcessors: [dropProcessor],\n });\n\n return provider;\n}\n\nexport function tracerFromProvider(provider: TracerProviderLike): Tracer {\n return provider.getTracer('stainless-xray');\n}\n\nexport function spanFromTracer(tracer: Pick<Tracer, 'startSpan'>, name: string): Span {\n return tracer.startSpan(name, { kind: SpanKind.SERVER }, ROOT_CONTEXT);\n}\n\nexport function spanStatusFromError(span: Span, err: unknown): void {\n if (err instanceof Error) {\n span.recordException(err);\n } else if (typeof err === 'string') {\n span.recordException(err);\n } else {\n span.recordException({ message: String(err) });\n }\n span.setStatus({ code: SpanStatusCode.ERROR });\n}\n\nclass DropFilterSpanProcessor implements SpanProcessor {\n private readonly next: SpanProcessor;\n\n constructor(next: SpanProcessor) {\n this.next = next;\n }\n\n forceFlush(): Promise<void> {\n return this.next.forceFlush();\n }\n\n onEnd(span: ReadableSpan): void {\n if (span.attributes[AttributeKeySpanDrop] === true) {\n return;\n }\n this.next.onEnd(span);\n }\n\n onStart(span: SDKSpan, parentContext: Context): void {\n this.next.onStart(span, parentContext);\n }\n\n shutdown(): Promise<void> {\n return this.next.shutdown();\n }\n}\n\nclass FetchSpanExporter implements SpanExporter {\n private readonly endpointUrl: string;\n private readonly headers: Record<string, string>;\n private readonly timeoutMillis: number;\n private isShutdown: boolean;\n private readonly logger: ResolvedXrayConfig['logger'];\n private readonly logLevel: ResolvedXrayConfig['logLevel'];\n private readonly serializer: {\n serializeRequest: (spans: ReadableSpan[]) => Uint8Array | undefined;\n };\n private readonly contentType: string;\n\n constructor(options: {\n endpointUrl: string;\n headers: Record<string, string>;\n timeoutMillis: number;\n logger: ResolvedXrayConfig['logger'];\n logLevel: ResolvedXrayConfig['logLevel'];\n }) {\n this.endpointUrl = options.endpointUrl;\n this.headers = { ...options.headers };\n this.timeoutMillis = options.timeoutMillis;\n this.isShutdown = false;\n this.logger = options.logger;\n this.logLevel = options.logLevel;\n const protobufSerializer =\n ProtobufTraceSerializer && typeof ProtobufTraceSerializer.serializeRequest === 'function'\n ? ProtobufTraceSerializer\n : null;\n this.serializer = protobufSerializer ?? JsonTraceSerializer;\n this.contentType = protobufSerializer ? 'application/x-protobuf' : 'application/json';\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.isShutdown) {\n resultCallback({ code: ExportResultCode.FAILED });\n return;\n }\n\n const payload = this.serializer.serializeRequest(spans);\n if (!payload) {\n logWithLevel(this.logger, 'warn', this.logLevel, 'xray: OTLP export failed', {\n error: 'OTLP export failed: empty payload',\n });\n resultCallback({\n code: ExportResultCode.FAILED,\n error: new Error('OTLP export failed: empty payload'),\n });\n return;\n }\n const headers = {\n ...this.headers,\n 'Content-Type': this.contentType,\n };\n\n const controller = typeof AbortController !== 'undefined' ? new AbortController() : null;\n let timeout: ReturnType<typeof setTimeout> | undefined;\n if (controller) {\n timeout = setTimeout(() => controller.abort(), this.timeoutMillis);\n }\n\n const doExport = async (): Promise<void> => {\n const response = await fetch(this.endpointUrl, {\n method: 'POST',\n headers,\n body: payload as unknown as BodyInit,\n signal: controller?.signal,\n });\n\n if (!response.ok) {\n throw new Error(`OTLP export failed: ${response.status}`);\n }\n };\n\n doExport()\n .then(() => {\n if (timeout) {\n clearTimeout(timeout);\n }\n resultCallback({ code: ExportResultCode.SUCCESS });\n })\n .catch((err) => {\n if (timeout) {\n clearTimeout(timeout);\n }\n logWithLevel(this.logger, 'warn', this.logLevel, 'xray: OTLP export failed', {\n error: err instanceof Error ? err.message : String(err),\n });\n diag.error('OTLP export failed', err);\n resultCallback({ code: ExportResultCode.FAILED, error: err });\n });\n }\n\n async forceFlush(): Promise<void> {\n return;\n }\n\n async shutdown(): Promise<void> {\n this.isShutdown = true;\n }\n}\n\nfunction createSpanProcessor(mode: 'simple' | 'batch', exporter: SpanExporter): SpanProcessor {\n if (mode === 'simple') {\n return new SimpleSpanProcessor(exporter);\n }\n\n return new BatchSpanProcessor(exporter, {\n maxQueueSize: 2048,\n maxExportBatchSize: 512,\n scheduledDelayMillis: 5_000,\n exportTimeoutMillis: 30_000,\n });\n}\n\nfunction sdkVersion(): string {\n if (typeof __XRAY_VERSION__ !== 'undefined') {\n return __XRAY_VERSION__;\n }\n return 'unknown';\n}\n\nfunction isNodeRuntime(): boolean {\n const maybeProcess = (\n globalThis as typeof globalThis & {\n process?: { versions?: { node?: string } };\n }\n ).process;\n return !!maybeProcess?.versions?.node;\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 = 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 // Format as UUID string\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","import type { XrayConfig, ResolvedXrayConfig, CaptureConfig, RedactionConfig } from './config';\nimport { normalizeConfig } from './config';\nimport { logWithLevel } from './logger';\nimport { applyRedaction } from './redaction';\nimport { makeCapturedBody, sanitizeHeaderValues, sanitizeLogString } from './request_log';\nimport {\n setHeaderAttributes,\n setRequestAttributes,\n setRequestBodyAttributes,\n setRequestBodySizeAttribute,\n setRequestIdAttribute,\n setResponseBodyAttributes,\n setResponseBodySizeAttribute,\n setResponseStatusAttribute,\n setRouteAttribute,\n setUserIdAttribute,\n} from './attributes';\nimport {\n createTracerProvider,\n spanFromTracer,\n spanStatusFromError,\n tracerFromProvider,\n} from './otel';\nimport { normalizeRoutePattern } from './route';\nimport { uuidv7 } from './uuid';\nimport { bindContext, getContextState, type RequestState } from './state';\nimport type {\n AttributeValue,\n NormalizedRequest,\n NormalizedResponse,\n RequestLog,\n XrayContext,\n XrayEmitter,\n} from './types';\n\nexport function createEmitter(config: XrayConfig): XrayEmitter {\n const resolved = normalizeConfig(config);\n logWithLevel(resolved.logger, 'info', resolved.logLevel, 'xray: emitter configured', {\n serviceName: resolved.serviceName,\n environment: resolved.environment,\n version: resolved.version,\n exporterEndpoint: resolved.exporter.endpointUrl,\n spanProcessor: resolved.exporter.spanProcessor,\n });\n const tracerProvider = createTracerProvider(resolved);\n const tracer = tracerFromProvider(tracerProvider);\n\n return {\n config: resolved,\n startRequest: (req) => startRequest(resolved, tracer, req),\n endRequest: (ctx, res, err) => endRequest(resolved, ctx, res, err),\n flush: () => tracerProvider.forceFlush(),\n shutdown: () => tracerProvider.shutdown(),\n };\n}\n\nfunction startRequest(\n config: ResolvedXrayConfig,\n tracer: ReturnType<typeof tracerFromProvider>,\n req: NormalizedRequest,\n): XrayContext {\n const startTimeMs = Number.isFinite(req.startTimeMs) ? req.startTimeMs : Date.now();\n req.startTimeMs = startTimeMs;\n\n const requestId = resolveRequestId(config, req.requestId, req.headers);\n req.requestId = requestId;\n\n if (req.route && config.route.normalize) {\n req.route = config.route.normalizer\n ? config.route.normalizer(req.route)\n : normalizeRoutePattern(req.route);\n }\n\n const span = spanFromTracer(tracer, spanNameFromRequest(req));\n const context: XrayContext = {\n requestId,\n traceId: span?.spanContext().traceId,\n spanId: span?.spanContext().spanId,\n setUserId: (id) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.userId = id;\n if (span && id) {\n try {\n setUserIdAttribute(span, id);\n } catch {\n // Ignore span attribute errors.\n }\n }\n },\n setSessionId: (id) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.sessionId = id;\n },\n setAttribute: (key, value) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.attributes[key] = value;\n if (span) {\n try {\n span.setAttribute(key, value as AttributeValue);\n } catch {\n // Ignore span attribute errors.\n }\n }\n },\n addEvent: (name, attributes) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.events.push({ name, attributes });\n if (span) {\n try {\n span.addEvent(name, attributes as Record<string, AttributeValue> | undefined);\n } catch {\n // Ignore span event errors.\n }\n }\n },\n setError: (err) => {\n const state = getContextState(context);\n if (!state) {\n return;\n }\n state.error = err;\n if (span) {\n try {\n spanStatusFromError(span, err);\n } catch {\n // Ignore span errors.\n }\n }\n },\n };\n\n const state: RequestState = {\n request: req,\n config,\n span,\n context,\n attributes: {},\n events: [],\n };\n\n bindContext(context, state);\n return context;\n}\n\nfunction endRequest(\n config: ResolvedXrayConfig,\n ctx: XrayContext,\n res: NormalizedResponse,\n err?: unknown,\n): RequestLog {\n const state = getContextState(ctx);\n const endTimeMs = Number.isFinite(res.endTimeMs) ? res.endTimeMs : Date.now();\n res.endTimeMs = endTimeMs;\n\n if (!state) {\n const fallbackLog: RequestLog = {\n requestId: ctx.requestId,\n serviceName: config.serviceName,\n method: res.statusCode ? 'UNKNOWN' : 'UNKNOWN',\n url: '',\n durationMs: 0,\n statusCode: res.statusCode,\n timestamp: new Date(endTimeMs).toISOString(),\n };\n return fallbackLog;\n }\n\n const request = state.request;\n const capture = resolveCapture(config.capture, state.captureOverride);\n const redaction = resolveRedaction(config.redaction, state.redactionOverride);\n\n const route = request.route;\n const url = sanitizeLogString(request.url);\n const log: RequestLog = {\n requestId: request.requestId ?? ctx.requestId,\n traceId: state.span?.spanContext().traceId,\n spanId: state.span?.spanContext().spanId,\n serviceName: config.serviceName,\n method: request.method,\n url: url,\n route: route,\n statusCode: res.statusCode,\n durationMs: Math.max(0, endTimeMs - request.startTimeMs),\n requestHeaders: capture.requestHeaders ? sanitizeHeaderValues(request.headers) : undefined,\n responseHeaders: capture.responseHeaders ? sanitizeHeaderValues(res.headers) : undefined,\n requestBody: capture.requestBody === 'none' ? undefined : request.body,\n responseBody: capture.responseBody === 'none' ? undefined : res.body,\n userId: state.userId ?? undefined,\n sessionId: state.sessionId ?? undefined,\n error: buildError(err ?? state.error),\n attributes: Object.keys(state.attributes).length > 0 ? { ...state.attributes } : undefined,\n timestamp: new Date(endTimeMs).toISOString(),\n };\n\n const redacted = applyRedaction(redaction, log);\n if (redacted.route && config.route.normalize) {\n const normalized = config.route.normalizer\n ? config.route.normalizer(redacted.route)\n : normalizeRoutePattern(redacted.route);\n redacted.route = normalized;\n }\n const span = state.span;\n if (span) {\n try {\n setRequestAttributes(span, request.method, redacted.url);\n setRequestIdAttribute(span, redacted.requestId);\n span.setAttribute('service.name', config.serviceName);\n if (redacted.statusCode != null) {\n setResponseStatusAttribute(span, redacted.statusCode);\n }\n if (redacted.route) {\n setRouteAttribute(span, redacted.route);\n span.updateName(`${request.method} ${redacted.route}`);\n } else {\n span.updateName(spanNameFromRequest(request));\n }\n if (redacted.requestHeaders) {\n setHeaderAttributes(span, redacted.requestHeaders, 'http.request.header.');\n }\n if (redacted.responseHeaders) {\n setHeaderAttributes(span, redacted.responseHeaders, 'http.response.header.');\n }\n if (redacted.requestBody) {\n setRequestBodyAttributes(span, redacted.requestBody);\n setRequestBodySizeAttribute(span, redacted.requestBody.bytes);\n }\n if (redacted.responseBody) {\n setResponseBodyAttributes(span, redacted.responseBody);\n setResponseBodySizeAttribute(span, redacted.responseBody.bytes);\n }\n if (state.userId) {\n setUserIdAttribute(span, state.userId);\n }\n if (err ?? state.error) {\n spanStatusFromError(span, err ?? state.error);\n }\n span.end();\n } catch (spanErr) {\n logWithLevel(config.logger, 'warn', config.logLevel, 'xray: span finalize failed', {\n error: spanErr instanceof Error ? spanErr.message : String(spanErr),\n });\n }\n }\n\n return redacted;\n}\n\nfunction resolveRequestId(\n config: ResolvedXrayConfig,\n requestId: string | undefined,\n headers: Record<string, string | string[]>,\n): string {\n if (requestId) {\n return requestId;\n }\n const headerName = config.requestId.header.toLowerCase();\n const headerValue = headers[headerName];\n if (headerValue) {\n const value = Array.isArray(headerValue) ? headerValue[0] : headerValue;\n if (value && value.trim()) {\n return value.trim();\n }\n }\n if (!config.requestId.generate) {\n return uuidv7();\n }\n return uuidv7();\n}\n\nfunction resolveCapture(base: CaptureConfig, override?: Partial<CaptureConfig>): CaptureConfig {\n if (!override) {\n return base;\n }\n return {\n ...base,\n ...override,\n };\n}\n\nfunction resolveRedaction(\n base: RedactionConfig,\n override?: Partial<RedactionConfig>,\n): RedactionConfig {\n const merged: RedactionConfig = {\n ...base,\n ...override,\n };\n\n merged.headers = normalizeLowercaseList(merged.headers);\n merged.queryParams = normalizeLowercaseList(merged.queryParams);\n merged.bodyJsonPaths = normalizeList(merged.bodyJsonPaths);\n merged.replacement = merged.replacement || base.replacement;\n\n return merged;\n}\n\nfunction normalizeLowercaseList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim().toLowerCase()).filter(Boolean);\n}\n\nfunction normalizeList(values: string[] | undefined): string[] {\n if (!values) {\n return [];\n }\n return values.map((entry) => entry.trim()).filter(Boolean);\n}\n\nfunction buildError(err?: unknown): RequestLog['error'] {\n if (!err) {\n return undefined;\n }\n if (err instanceof Error) {\n return {\n message: err.message || 'Error',\n type: err.name || 'Error',\n stack: err.stack,\n };\n }\n return {\n message: String(err),\n };\n}\n\nfunction spanNameFromRequest(req: NormalizedRequest): string {\n const method = req.method || 'GET';\n if (req.route) {\n return `${method} ${req.route}`;\n }\n const path = safePath(req.url);\n return `${method} ${path}`;\n}\n\nfunction safePath(url: string): string {\n try {\n const parsed = new URL(url);\n return parsed.pathname || '/';\n } catch {\n const rawPath = url.split('?')[0] || '/';\n return rawPath || '/';\n }\n}\n\nexport function captureBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64' | 'none',\n): ReturnType<typeof makeCapturedBody> {\n if (mode === 'none') {\n return undefined;\n }\n return makeCapturedBody(bytes, totalBytes, truncated, mode === 'text' ? 'text' : 'base64');\n}\n\nexport function captureResponseBody(\n bytes: Uint8Array | undefined,\n totalBytes: number,\n truncated: boolean,\n mode: 'text' | 'base64' | 'none',\n): ReturnType<typeof makeCapturedBody> {\n if (mode === 'none') {\n return undefined;\n }\n return makeCapturedBody(bytes, totalBytes, truncated, mode === 'text' ? 'text' : 'base64');\n}\n"],"mappings":"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","names":["state"]}
@@ -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-D3Vzw_TA.cjs';
1
+ import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-f9NNWwCi.cjs';
2
2
 
3
3
  declare function makeCapturedBody(bytes: Uint8Array | undefined, totalBytes: number, truncated: boolean, mode: 'text' | 'base64'): CapturedBody | undefined;
4
4
 
@@ -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-D3Vzw_TA.js';
1
+ import { C as CapturedBody, b as Logger, L as LogLevel, d as XrayContext, e as CaptureConfig, f as RedactionConfig } from './types-f9NNWwCi.js';
2
2
 
3
3
  declare function makeCapturedBody(bytes: Uint8Array | undefined, totalBytes: number, truncated: boolean, mode: 'text' | 'base64'): CapturedBody | undefined;
4
4
 
package/dist/internal.js CHANGED
@@ -4,7 +4,7 @@ import {
4
4
  getContextState,
5
5
  logWithLevel,
6
6
  makeCapturedBody
7
- } from "./chunk-SQHI5JZH.js";
7
+ } from "./chunk-XI5E6C7G.js";
8
8
 
9
9
  // src/limited_buffer.ts
10
10
  var LimitedBuffer = class {