iii-sdk 0.4.0 → 0.4.1
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.cjs +1 -1
- package/dist/index.d.cts +1 -1
- package/dist/index.d.mts +1 -1
- package/dist/index.mjs +1 -1
- package/dist/{otel-worker-gauges-CqtrGk4D.mjs → otel-worker-gauges-Dqf47JXh.mjs} +2 -2
- package/dist/{otel-worker-gauges-CqtrGk4D.mjs.map → otel-worker-gauges-Dqf47JXh.mjs.map} +1 -1
- package/dist/{otel-worker-gauges-bbMcoYx_.cjs → otel-worker-gauges-wK5b_eLY.cjs} +2 -2
- package/dist/{otel-worker-gauges-bbMcoYx_.cjs.map → otel-worker-gauges-wK5b_eLY.cjs.map} +1 -1
- package/dist/telemetry.cjs +1 -1
- package/dist/telemetry.d.cts +1 -1
- package/dist/telemetry.d.mts +1 -1
- package/dist/telemetry.mjs +1 -1
- package/dist/{utils-CSKJ2XjM.d.cts → utils-00Nf7BPL.d.cts} +2 -2
- package/dist/utils-00Nf7BPL.d.cts.map +1 -0
- package/dist/{utils-Dr4vNtCh.d.mts → utils-DGk5SQIG.d.mts} +2 -2
- package/dist/utils-DGk5SQIG.d.mts.map +1 -0
- package/package.json +1 -1
- package/dist/utils-CSKJ2XjM.d.cts.map +0 -1
- package/dist/utils-Dr4vNtCh.d.mts.map +0 -1
package/dist/index.cjs
CHANGED
|
@@ -25,7 +25,7 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
|
|
|
25
25
|
}) : target, mod));
|
|
26
26
|
|
|
27
27
|
//#endregion
|
|
28
|
-
const require_otel_worker_gauges = require('./otel-worker-gauges-
|
|
28
|
+
const require_otel_worker_gauges = require('./otel-worker-gauges-wK5b_eLY.cjs');
|
|
29
29
|
let __opentelemetry_api = require("@opentelemetry/api");
|
|
30
30
|
let node_module = require("node:module");
|
|
31
31
|
let node_os = require("node:os");
|
package/dist/index.d.cts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { S as StreamChannelRef, _ as ChannelReader, a as init, b as HttpAuthConfig, c as Channel, d as HttpResponse, f as ISdk, i as InitOptions, o as ApiRequest, s as ApiResponse, t as http, u as HttpRequest, v as ChannelWriter, x as HttpInvocationConfig } from "./utils-
|
|
1
|
+
import { S as StreamChannelRef, _ as ChannelReader, a as init, b as HttpAuthConfig, c as Channel, d as HttpResponse, f as ISdk, i as InitOptions, o as ApiRequest, s as ApiResponse, t as http, u as HttpRequest, v as ChannelWriter, x as HttpInvocationConfig } from "./utils-00Nf7BPL.cjs";
|
|
2
2
|
import { Span } from "@opentelemetry/api";
|
|
3
3
|
|
|
4
4
|
//#region src/logger.d.ts
|
package/dist/index.d.mts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { S as StreamChannelRef, _ as ChannelReader, a as init, b as HttpAuthConfig, c as Channel, d as HttpResponse, f as ISdk, i as InitOptions, o as ApiRequest, s as ApiResponse, t as http, u as HttpRequest, v as ChannelWriter, x as HttpInvocationConfig } from "./utils-
|
|
1
|
+
import { S as StreamChannelRef, _ as ChannelReader, a as init, b as HttpAuthConfig, c as Channel, d as HttpResponse, f as ISdk, i as InitOptions, o as ApiRequest, s as ApiResponse, t as http, u as HttpRequest, v as ChannelWriter, x as HttpInvocationConfig } from "./utils-DGk5SQIG.mjs";
|
|
2
2
|
import { Span } from "@opentelemetry/api";
|
|
3
3
|
|
|
4
4
|
//#region src/logger.d.ts
|
package/dist/index.mjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { A as EngineTriggers, C as injectBaggage, D as DEFAULT_BRIDGE_RECONNECTION_CONFIG, O as DEFAULT_INVOCATION_TIMEOUT_MS, _ as currentTraceId, a as isChannelRef, c as SpanKind$1, d as getMeter, f as getTracer, g as currentSpanId, h as withSpan, i as http, k as EngineFunctions, m as shutdownOtel, n as stopWorkerGauges, o as safeStringify, p as initOtel, s as SeverityNumber$1, t as registerWorkerGauges, u as getLogger, w as injectTraceparent, y as extractContext } from "./otel-worker-gauges-
|
|
1
|
+
import { A as EngineTriggers, C as injectBaggage, D as DEFAULT_BRIDGE_RECONNECTION_CONFIG, O as DEFAULT_INVOCATION_TIMEOUT_MS, _ as currentTraceId, a as isChannelRef, c as SpanKind$1, d as getMeter, f as getTracer, g as currentSpanId, h as withSpan, i as http, k as EngineFunctions, m as shutdownOtel, n as stopWorkerGauges, o as safeStringify, p as initOtel, s as SeverityNumber$1, t as registerWorkerGauges, u as getLogger, w as injectTraceparent, y as extractContext } from "./otel-worker-gauges-Dqf47JXh.mjs";
|
|
2
2
|
import { createRequire } from "node:module";
|
|
3
3
|
import { context } from "@opentelemetry/api";
|
|
4
4
|
import * as os from "node:os";
|
|
@@ -845,7 +845,7 @@ function safeStringify(value) {
|
|
|
845
845
|
const http = (callback) => {
|
|
846
846
|
return async (req) => {
|
|
847
847
|
const { response, ...request } = req;
|
|
848
|
-
|
|
848
|
+
return callback(request, {
|
|
849
849
|
status: (status_code) => response.sendMessage(JSON.stringify({
|
|
850
850
|
type: "set_status",
|
|
851
851
|
status_code
|
|
@@ -1074,4 +1074,4 @@ function stopWorkerGauges() {
|
|
|
1074
1074
|
|
|
1075
1075
|
//#endregion
|
|
1076
1076
|
export { EngineTriggers as A, injectBaggage as C, DEFAULT_BRIDGE_RECONNECTION_CONFIG as D, setBaggageEntry as E, DEFAULT_INVOCATION_TIMEOUT_MS as O, getBaggageEntry as S, removeBaggageEntry as T, currentTraceId as _, isChannelRef as a, extractTraceparent as b, SpanKind$1 as c, getMeter as d, getTracer as f, currentSpanId as g, withSpan as h, http as i, LogFunctions as j, EngineFunctions as k, SpanStatusCode$1 as l, shutdownOtel as m, stopWorkerGauges as n, safeStringify as o, initOtel as p, WorkerMetricsCollector as r, SeverityNumber$1 as s, registerWorkerGauges as t, getLogger as u, extractBaggage as v, injectTraceparent as w, getAllBaggage as x, extractContext as y };
|
|
1077
|
-
//# sourceMappingURL=otel-worker-gauges-
|
|
1077
|
+
//# sourceMappingURL=otel-worker-gauges-Dqf47JXh.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"otel-worker-gauges-CqtrGk4D.mjs","names":["DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig","DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig","metrics","carrier: Record<string, string>","entries: Record<string, string>","originalFetch: typeof globalThis.fetch | null","host: string | undefined","scheme: string | undefined","path: string | undefined","port: number | undefined","query: string | undefined","spanAttributes: Record<string, string | number>","tracer","carrier: Record<string, string>","sharedConnection: SharedEngineConnection | null","tracerProvider: NodeTracerProvider | null","meterProvider: MeterProvider | null","loggerProvider: LoggerProvider | null","tracer: Tracer | null","meter: Meter | null","logger: Logger | null","serviceName: string","resourceAttributes: Record<string, string>","noopSpan: Span","SpanKind","SpanStatusCode","metricsCollector: WorkerMetricsCollector | null","registeredMeter: Meter | null","registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null","registeredObservables: Observable[]","meter","metrics"],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/connection.ts","../src/telemetry-system/span-exporter.ts","../src/telemetry-system/metrics-exporter.ts","../src/telemetry-system/log-exporter.ts","../src/telemetry-system/context.ts","../src/telemetry-system/fetch-instrumentation.ts","../src/telemetry-system/index.ts","../src/utils.ts","../src/worker-metrics.ts","../src/otel-worker-gauges.ts"],"sourcesContent":["/**\n * Constants for the III module.\n */\n\n/** Engine function paths for internal operations */\nexport const EngineFunctions = {\n LIST_FUNCTIONS: 'engine::functions::list',\n LIST_WORKERS: 'engine::workers::list',\n REGISTER_WORKER: 'engine::workers::register',\n} as const\n\n/** Engine trigger types */\nexport const EngineTriggers = {\n FUNCTIONS_AVAILABLE: 'engine::functions-available',\n LOG: 'log',\n} as const\n\n/** Log function paths */\nexport const LogFunctions = {\n INFO: 'engine::log::info',\n WARN: 'engine::log::warn',\n ERROR: 'engine::log::error',\n DEBUG: 'engine::log::debug',\n} as const\n\n/** Connection state for the III WebSocket */\nexport type IIIConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface IIIReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Default invocation timeout in milliseconds */\nexport const DEFAULT_INVOCATION_TIMEOUT_MS = 30000\n","/**\n * Types, interfaces, and constants for the OpenTelemetry module.\n */\n\nimport type { Instrumentation } from '@opentelemetry/instrumentation'\n\n// Semantic convention constants for compatibility across versions\nexport const ATTR_SERVICE_VERSION = 'service.version'\nexport const ATTR_SERVICE_NAMESPACE = 'service.namespace'\nexport const ATTR_SERVICE_INSTANCE_ID = 'service.instance.id'\n\n/** Magic prefixes for binary frames over WebSocket */\nexport const PREFIX_TRACES = 'OTLP'\nexport const PREFIX_METRICS = 'MTRC'\nexport const PREFIX_LOGS = 'LOGS'\n\n/** Connection state for the shared WebSocket */\nexport type ConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface ReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Configuration for OpenTelemetry initialization. */\nexport interface OtelConfig {\n /** Whether OpenTelemetry export is enabled. Defaults to true. Set to false or OTEL_ENABLED=false/0/no/off to disable. */\n enabled?: boolean\n /** The service name to report. Defaults to OTEL_SERVICE_NAME or \"iii-node\". */\n serviceName?: string\n /** The service version to report. Defaults to SERVICE_VERSION env var or \"unknown\". */\n serviceVersion?: string\n /** The service namespace to report. Defaults to SERVICE_NAMESPACE env var. */\n serviceNamespace?: string\n /** The service instance ID to report. Defaults to SERVICE_INSTANCE_ID env var or auto-generated UUID. */\n serviceInstanceId?: string\n /** III Engine WebSocket URL. Defaults to III_BRIDGE_URL or \"ws://localhost:49134\". */\n engineWsUrl?: string\n /** OpenTelemetry instrumentations to register (e.g., PrismaInstrumentation). */\n instrumentations?: Instrumentation[]\n /** Whether OpenTelemetry metrics export is enabled. Defaults to true. Set to false or OTEL_METRICS_ENABLED=false/0/no/off to disable. */\n metricsEnabled?: boolean\n /** Metrics export interval in milliseconds. Defaults to 60000 (60 seconds). */\n metricsExportIntervalMs?: number\n /** Whether to auto-instrument globalThis.fetch calls. Defaults to true. Works on Node.js, Bun, and Deno. Set to false to disable. */\n fetchInstrumentationEnabled?: boolean\n /** Optional reconnection configuration for the WebSocket connection. */\n reconnectionConfig?: Partial<ReconnectionConfig>\n}\n\n/** Default configuration values for OpenTelemetry initialization. */\nexport const DEFAULT_OTEL_CONFIG = {\n enabled: true,\n serviceName: 'iii-node',\n serviceVersion: 'unknown',\n engineWsUrl: 'ws://localhost:49134',\n metricsEnabled: true,\n metricsExportIntervalMs: 60000,\n fetchInstrumentationEnabled: true,\n} as const satisfies Partial<OtelConfig>\n\n/** Parse a boolean environment variable, recognizing 'false', '0', 'no', 'off' as false. */\nexport function parseBoolEnv(value: string | undefined, defaultValue: boolean): boolean {\n if (value === undefined) return defaultValue\n const lower = value.toLowerCase()\n return lower !== 'false' && lower !== '0' && lower !== 'no' && lower !== 'off'\n}\n","/**\n * Shared WebSocket connection for OpenTelemetry exporters.\n */\n\nimport { WebSocket } from 'ws'\nimport { type ConnectionState, type ReconnectionConfig, DEFAULT_RECONNECTION_CONFIG } from './types'\n\n/**\n * Shared WebSocket connection for all OTEL exporters (traces, metrics, logs).\n * Uses a single connection with message prefixes to identify signal type.\n */\nexport class SharedEngineConnection {\n private static readonly MAX_PENDING_MESSAGES = 1000\n private ws: WebSocket | null = null\n private wsUrl: string\n private connecting = false\n private shuttingDown = false\n private pendingMessages: Array<{ frame: Buffer; callback?: (err?: Error) => void }> = []\n private reconnectAttempt = 0\n private reconnectTimeout: NodeJS.Timeout | null = null\n private config: ReconnectionConfig\n private state: ConnectionState = 'disconnected'\n private onConnectedCallbacks: Array<() => void> = []\n\n constructor(wsUrl: string, config: Partial<ReconnectionConfig> = {}) {\n this.wsUrl = wsUrl\n this.config = { ...DEFAULT_RECONNECTION_CONFIG, ...config }\n this.connect()\n }\n\n private connect(): void {\n if (this.connecting || (this.ws && this.ws.readyState === WebSocket.OPEN)) {\n return\n }\n\n this.connecting = true\n this.state = 'connecting'\n\n try {\n this.ws = new WebSocket(this.wsUrl)\n\n this.ws.on('open', () => {\n this.connecting = false\n this.state = 'connected'\n console.log(`[OTel] Connected to engine at ${this.wsUrl}`)\n\n // Reset reconnection state\n if (this.reconnectAttempt > 0) {\n console.log('[OTel] Successfully reconnected')\n }\n this.reconnectAttempt = 0\n\n // Clear any pending reconnect timer to prevent race conditions\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n // Flush pending messages\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n for (const { frame, callback } of pending) {\n this.ws?.send(frame, err => callback?.(err))\n }\n\n // Notify callbacks\n for (const cb of this.onConnectedCallbacks) {\n cb()\n }\n })\n\n this.ws.on('close', () => {\n this.connecting = false\n this.ws = null\n\n // Skip reconnection if we're shutting down intentionally\n if (this.shuttingDown) {\n this.state = 'disconnected'\n console.log('[OTel] Connection closed during shutdown')\n return\n }\n\n this.state = 'disconnected'\n console.log('[OTel] Disconnected from engine, will reconnect...')\n this.scheduleReconnect()\n })\n\n this.ws.on('error', err => {\n this.connecting = false\n\n // Skip error handling if we're shutting down intentionally\n if (this.shuttingDown) {\n return\n }\n\n console.error('[OTel] WebSocket error:', err.message)\n })\n } catch (err) {\n this.connecting = false\n console.error('[OTel] Connection failed:', err)\n this.scheduleReconnect()\n }\n }\n\n private scheduleReconnect(): void {\n if (this.config.maxRetries !== -1 && this.reconnectAttempt >= this.config.maxRetries) {\n this.state = 'failed'\n console.error(`[OTel] Max retries (${this.config.maxRetries}) reached, giving up`)\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const failedError = new Error('Connection failed after max retries')\n for (const { callback } of pending) {\n callback?.(failedError)\n }\n return\n }\n\n if (this.reconnectTimeout) {\n return // Already scheduled\n }\n\n const exponentialDelay =\n this.config.initialDelayMs * this.config.backoffMultiplier ** this.reconnectAttempt\n const cappedDelay = Math.min(exponentialDelay, this.config.maxDelayMs)\n const jitter = cappedDelay * this.config.jitterFactor * (2 * Math.random() - 1)\n const delay = Math.max(0, Math.floor(cappedDelay + jitter))\n\n this.state = 'reconnecting'\n console.log(`[OTel] Reconnecting in ${delay}ms (attempt ${this.reconnectAttempt + 1})...`)\n\n this.reconnectTimeout = setTimeout(() => {\n this.reconnectTimeout = null\n this.reconnectAttempt++\n this.connect()\n }, delay)\n }\n\n /**\n * Send a message with a signal prefix.\n */\n send(prefix: string, data: Uint8Array, callback?: (err?: Error) => void): void {\n const prefixBytes = Buffer.from(prefix, 'utf-8')\n const frame = Buffer.concat([prefixBytes, Buffer.from(data)])\n\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send(frame, callback)\n } else {\n // Queue for later with bounded size to prevent memory exhaustion\n if (this.pendingMessages.length >= SharedEngineConnection.MAX_PENDING_MESSAGES) {\n console.warn('[OTel] Pending message queue full, dropping oldest message')\n const dropped = this.pendingMessages.shift()\n dropped?.callback?.(new Error('Message dropped due to queue overflow'))\n }\n this.pendingMessages.push({ frame, callback })\n this.connect()\n }\n }\n\n /**\n * Register a callback to be called when connected.\n */\n onConnected(callback: () => void): void {\n this.onConnectedCallbacks.push(callback)\n if (this.state === 'connected') {\n callback()\n }\n }\n\n /**\n * Get the current connection state.\n */\n getState(): ConnectionState {\n return this.state\n }\n\n /**\n * Shutdown the connection.\n */\n async shutdown(): Promise<void> {\n // Set shutdown flag to prevent reconnection attempts\n this.shuttingDown = true\n\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const shutdownError = new Error('Connection shutdown before message could be sent')\n for (const { callback } of pending) {\n callback?.(shutdownError)\n }\n this.onConnectedCallbacks = []\n this.state = 'disconnected'\n }\n}\n","/**\n * Span exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { ReadableSpan, SpanExporter } from '@opentelemetry/sdk-trace-base'\nimport { JsonTraceSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_TRACES } from './types'\n\n/**\n * Span exporter using the shared WebSocket connection.\n */\nexport class EngineSpanExporter implements SpanExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n spans: ReadableSpan[]\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { spans, resultCallback } of pending) {\n this.sendExport(spans, resultCallback)\n }\n }\n\n private sendExport(spans: ReadableSpan[], resultCallback?: (result: ExportResult) => void): void {\n try {\n const serialized = JsonTraceSerializer.serializeRequest(spans)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_TRACES, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send spans:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting spans:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineSpanExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Spans export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ spans, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(spans, resultCallback)\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(spans, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op, spans are sent immediately\n }\n}\n","/**\n * Metrics exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { PushMetricExporter, ResourceMetrics } from '@opentelemetry/sdk-metrics'\nimport { JsonMetricsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_METRICS } from './types'\n\n/**\n * Metrics exporter using the shared WebSocket connection.\n */\nexport class EngineMetricsExporter implements PushMetricExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n metrics: ResourceMetrics\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { metrics, resultCallback } of pending) {\n this.sendExport(metrics, resultCallback)\n }\n }\n\n private sendExport(\n metricsData: ResourceMetrics,\n resultCallback?: (result: ExportResult) => void,\n ): void {\n try {\n const serialized = JsonMetricsSerializer.serializeRequest(metricsData)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_METRICS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send metrics:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting metrics:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(\n metricsData: ResourceMetrics,\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineMetricsExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Metrics export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ metrics: metricsData, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(metricsData, resultCallback)\n }\n\n export(metrics: ResourceMetrics, resultCallback: (result: ExportResult) => void): void {\n this.doExport(metrics, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op\n }\n}\n","/**\n * Log exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { LogRecordExporter, ReadableLogRecord } from '@opentelemetry/sdk-logs'\nimport { JsonLogsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_LOGS } from './types'\n\n/**\n * Log exporter using the shared WebSocket connection.\n */\nexport class EngineLogExporter implements LogRecordExporter {\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n logs: ReadableLogRecord[]\n callback: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { logs, callback } of pending) {\n this.doExport(logs, callback)\n }\n }\n\n private doExport(\n logs: ReadableLogRecord[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n this.pendingExports.push({ logs, callback: resultCallback })\n return\n }\n\n try {\n const serialized = JsonLogsSerializer.serializeRequest(logs)\n if (!serialized) {\n resultCallback({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_LOGS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send logs:', err.message)\n resultCallback({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting logs:', err)\n resultCallback({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n export(logs: ReadableLogRecord[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(logs, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n for (const { callback } of this.pendingExports) {\n callback({ code: ExportResultCode.FAILED, error: new Error('Exporter shutdown') })\n }\n this.pendingExports = []\n }\n}\n","/**\n * Trace context and baggage propagation utilities.\n */\n\nimport { trace, context, propagation, type Context } from '@opentelemetry/api'\n\n/**\n * Extract the current trace ID from the active span context.\n */\nexport function currentTraceId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.traceId && spanContext.traceId !== '00000000000000000000000000000000') {\n return spanContext.traceId\n }\n }\n return undefined\n}\n\n/**\n * Extract the current span ID from the active span context.\n */\nexport function currentSpanId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.spanId && spanContext.spanId !== '0000000000000000') {\n return spanContext.spanId\n }\n }\n return undefined\n}\n\n/**\n * Inject the current trace context into a W3C traceparent header string.\n */\nexport function injectTraceparent(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.traceparent\n}\n\n/**\n * Extract a trace context from a W3C traceparent header string.\n */\nexport function extractTraceparent(traceparent: string): Context {\n const carrier: Record<string, string> = { traceparent }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Inject the current baggage into a W3C baggage header string.\n */\nexport function injectBaggage(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.baggage\n}\n\n/**\n * Extract baggage from a W3C baggage header string.\n */\nexport function extractBaggage(baggage: string): Context {\n const carrier: Record<string, string> = { baggage }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Extract both trace context and baggage from their respective headers.\n */\nexport function extractContext(traceparent?: string, baggage?: string): Context {\n const carrier: Record<string, string> = {}\n if (traceparent) {\n carrier.traceparent = traceparent\n }\n if (baggage) {\n carrier.baggage = baggage\n }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Get a baggage entry from the current context.\n */\nexport function getBaggageEntry(key: string): string | undefined {\n const bag = propagation.getBaggage(context.active())\n return bag?.getEntry(key)?.value\n}\n\n/**\n * Set a baggage entry in the current context.\n */\nexport function setBaggageEntry(key: string, value: string): Context {\n let bag = propagation.getBaggage(context.active()) ?? propagation.createBaggage()\n bag = bag.setEntry(key, { value })\n return propagation.setBaggage(context.active(), bag)\n}\n\n/**\n * Remove a baggage entry from the current context.\n */\nexport function removeBaggageEntry(key: string): Context {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return context.active()\n }\n const newBag = bag.removeEntry(key)\n return propagation.setBaggage(context.active(), newBag)\n}\n\n/**\n * Get all baggage entries from the current context.\n */\nexport function getAllBaggage(): Record<string, string> {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return {}\n }\n const entries: Record<string, string> = {}\n for (const [key, entry] of bag.getAllEntries()) {\n entries[key] = entry.value\n }\n return entries\n}\n","/**\n * Global fetch auto-instrumentation for the III Node SDK.\n *\n * Patches globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n * Works on all runtimes (Bun, Node.js, Deno) unlike UndiciInstrumentation\n * which only works when fetch is backed by Node.js's undici.\n */\n\nimport { type Tracer, SpanKind, SpanStatusCode, context, propagation } from '@opentelemetry/api'\n\nconst textEncoder = new TextEncoder()\n\nfunction getBodyByteSize(body: unknown): number | undefined {\n if (body == null) return undefined\n if (typeof body === 'string') return textEncoder.encode(body).byteLength\n if (body instanceof ArrayBuffer) return body.byteLength\n if (ArrayBuffer.isView(body)) return body.byteLength\n if (body instanceof Blob) return body.size\n if (body instanceof URLSearchParams) return new TextEncoder().encode(body.toString()).byteLength\n return undefined\n}\n\nconst SAFE_REQUEST_HEADERS = ['content-type', 'accept'] as const\nconst SAFE_RESPONSE_HEADERS = ['content-type'] as const\n\nlet originalFetch: typeof globalThis.fetch | null = null\n\n/**\n * Patch globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n */\nexport function patchGlobalFetch(tracer: Tracer): void {\n if (originalFetch) return\n\n originalFetch = globalThis.fetch\n const capturedFetch = originalFetch\n\n globalThis.fetch = async (\n input: string | URL | Request,\n init?: RequestInit,\n ): Promise<Response> => {\n const url = input instanceof Request ? input.url : String(input)\n const method = (init?.method ?? (input instanceof Request ? input.method : 'GET')).toUpperCase()\n\n let host: string | undefined\n let scheme: string | undefined\n let path: string | undefined\n let port: number | undefined\n let query: string | undefined\n try {\n const parsed = new URL(url)\n host = parsed.hostname\n scheme = parsed.protocol.replace(':', '')\n path = parsed.pathname\n port = parsed.port ? parseInt(parsed.port, 10) : undefined\n query = parsed.search ? parsed.search.slice(1) : undefined\n } catch {\n // relative URL or invalid — skip host/scheme/path attributes\n }\n\n const spanAttributes: Record<string, string | number> = {\n 'http.request.method': method,\n 'url.full': url,\n }\n if (host) spanAttributes['server.address'] = host\n if (scheme) {\n spanAttributes['url.scheme'] = scheme\n spanAttributes['network.protocol.name'] = 'http'\n }\n if (path) spanAttributes['url.path'] = path\n if (port) spanAttributes['server.port'] = port\n if (query) spanAttributes['url.query'] = query\n\n const spanName = path ? `${method} ${path}` : method\n\n return tracer.startActiveSpan(\n spanName,\n { kind: SpanKind.CLIENT, attributes: spanAttributes },\n context.active(),\n async span => {\n try {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n\n const headers = new Headers(\n init?.headers ?? (input instanceof Request ? input.headers : undefined),\n )\n for (const [key, value] of Object.entries(carrier)) {\n headers.set(key, value)\n }\n\n for (const name of SAFE_REQUEST_HEADERS) {\n const value = headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.request.header.${name}`, value)\n }\n }\n\n const requestBody = init?.body ?? (input instanceof Request ? input.body : undefined)\n const requestBodySize = getBodyByteSize(requestBody)\n if (requestBodySize !== undefined) {\n span.setAttribute('http.request.body.size', requestBodySize)\n }\n\n const response = await capturedFetch(input, { ...init, headers })\n\n span.setAttribute('http.response.status_code', response.status)\n\n const contentLength = response.headers.get('content-length')\n if (contentLength !== null) {\n const size = parseInt(contentLength, 10)\n if (!Number.isNaN(size)) {\n span.setAttribute('http.response.body.size', size)\n }\n }\n\n for (const name of SAFE_RESPONSE_HEADERS) {\n const value = response.headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.response.header.${name}`, value)\n }\n }\n\n if (response.status >= 400) {\n span.setAttribute('error.type', String(response.status))\n span.setStatus({ code: SpanStatusCode.ERROR })\n } else {\n span.setStatus({ code: SpanStatusCode.OK })\n }\n\n return response\n } catch (error) {\n span.setAttribute('error.type', (error as Error).name ?? 'Error')\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n }\n}\n\n/**\n * Restore globalThis.fetch to its original implementation.\n */\nexport function unpatchGlobalFetch(): void {\n if (originalFetch) {\n globalThis.fetch = originalFetch\n originalFetch = null\n }\n}\n","/**\n * OpenTelemetry initialization for the III Node SDK.\n *\n * This module provides trace, metrics, and log export to the III Engine\n * via a shared WebSocket connection using OTLP JSON format.\n */\n\nimport { Resource } from '@opentelemetry/resources'\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions'\nimport { randomUUID } from 'node:crypto'\nimport {\n trace,\n context,\n propagation,\n SpanKind,\n SpanStatusCode,\n metrics,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n} from '@opentelemetry/api'\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base'\nimport { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics'\nimport {\n CompositePropagator,\n W3CBaggagePropagator,\n W3CTraceContextPropagator,\n} from '@opentelemetry/core'\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node'\nimport { registerInstrumentations } from '@opentelemetry/instrumentation'\nimport { LoggerProvider, BatchLogRecordProcessor } from '@opentelemetry/sdk-logs'\nimport { type Logger, SeverityNumber } from '@opentelemetry/api-logs'\n\nimport {\n type OtelConfig,\n DEFAULT_OTEL_CONFIG,\n parseBoolEnv,\n ATTR_SERVICE_VERSION,\n ATTR_SERVICE_NAMESPACE,\n ATTR_SERVICE_INSTANCE_ID,\n} from './types'\nimport { SharedEngineConnection } from './connection'\nimport { EngineSpanExporter, EngineMetricsExporter, EngineLogExporter } from './exporters'\nimport { extractTraceparent } from './context'\nimport { patchGlobalFetch, unpatchGlobalFetch } from './fetch-instrumentation'\n\n// Re-export everything from submodules\nexport * from './types'\nexport * from './context'\n\n// Module-level state\nlet sharedConnection: SharedEngineConnection | null = null\nlet tracerProvider: NodeTracerProvider | null = null\nlet meterProvider: MeterProvider | null = null\nlet loggerProvider: LoggerProvider | null = null\nlet tracer: Tracer | null = null\nlet meter: Meter | null = null\nlet logger: Logger | null = null\nlet serviceName: string = 'iii-node-iii'\n\n/**\n * Initialize OpenTelemetry with the given configuration.\n * This should be called once at application startup.\n */\nexport function initOtel(config: OtelConfig = {}): void {\n const enabled =\n config.enabled ?? parseBoolEnv(process.env.OTEL_ENABLED, DEFAULT_OTEL_CONFIG.enabled)\n\n if (!enabled) {\n console.debug(\n '[OTel] OpenTelemetry is disabled. To enable, remove OTEL_ENABLED=false or set enabled: true in config.',\n )\n return\n }\n\n // Configure service identity\n serviceName =\n config.serviceName ?? process.env.OTEL_SERVICE_NAME ?? DEFAULT_OTEL_CONFIG.serviceName\n const serviceVersion =\n config.serviceVersion ?? process.env.SERVICE_VERSION ?? DEFAULT_OTEL_CONFIG.serviceVersion\n const serviceNamespace = config.serviceNamespace ?? process.env.SERVICE_NAMESPACE\n const serviceInstanceId =\n config.serviceInstanceId ?? process.env.SERVICE_INSTANCE_ID ?? randomUUID()\n const engineWsUrl =\n config.engineWsUrl ?? process.env.III_BRIDGE_URL ?? DEFAULT_OTEL_CONFIG.engineWsUrl\n\n // Build resource attributes\n const resourceAttributes: Record<string, string> = {\n [ATTR_SERVICE_NAME]: serviceName,\n [ATTR_SERVICE_VERSION]: serviceVersion,\n [ATTR_SERVICE_INSTANCE_ID]: serviceInstanceId,\n }\n if (serviceNamespace) {\n resourceAttributes[ATTR_SERVICE_NAMESPACE] = serviceNamespace\n }\n const resource = new Resource(resourceAttributes)\n\n // Create shared WebSocket connection\n sharedConnection = new SharedEngineConnection(engineWsUrl, config.reconnectionConfig)\n\n // Initialize tracer\n const spanExporter = new EngineSpanExporter(sharedConnection)\n tracerProvider = new NodeTracerProvider({\n resource,\n spanProcessors: [new BatchSpanProcessor(spanExporter)],\n })\n\n // Register W3C Trace Context and Baggage propagators\n propagation.setGlobalPropagator(\n new CompositePropagator({\n propagators: [new W3CTraceContextPropagator(), new W3CBaggagePropagator()],\n }),\n )\n\n tracerProvider.register()\n tracer = trace.getTracer(serviceName)\n\n console.debug(`[OTel] Traces initialized: engine=${engineWsUrl}, service=${serviceName}`)\n\n // Initialize metrics (enabled by default, opt-out via config or env)\n const metricsEnabled =\n config.metricsEnabled ??\n parseBoolEnv(process.env.OTEL_METRICS_ENABLED, DEFAULT_OTEL_CONFIG.metricsEnabled)\n\n if (metricsEnabled) {\n const metricsExporter = new EngineMetricsExporter(sharedConnection)\n const exportIntervalMs =\n config.metricsExportIntervalMs ?? DEFAULT_OTEL_CONFIG.metricsExportIntervalMs\n\n const metricReader = new PeriodicExportingMetricReader({\n exporter: metricsExporter,\n exportIntervalMillis: exportIntervalMs,\n })\n\n meterProvider = new MeterProvider({\n resource,\n readers: [metricReader],\n })\n\n metrics.setGlobalMeterProvider(meterProvider)\n meter = meterProvider.getMeter(serviceName)\n\n console.debug(`[OTel] Metrics initialized: interval=${exportIntervalMs}ms`)\n }\n\n // Register user-provided instrumentations AFTER providers are set up\n const instrumentations = [...(config.instrumentations ?? [])]\n if (instrumentations.length > 0) {\n registerInstrumentations({\n instrumentations,\n tracerProvider,\n meterProvider: meterProvider ?? undefined,\n })\n console.debug(`[OTel] Instrumentations registered: ${instrumentations.length} total`)\n }\n\n // Patch global fetch for runtime-agnostic HTTP client tracing (works on Bun, Node.js, Deno)\n const fetchEnabled =\n config.fetchInstrumentationEnabled ?? DEFAULT_OTEL_CONFIG.fetchInstrumentationEnabled\n\n if (fetchEnabled) {\n patchGlobalFetch(tracer)\n console.debug('[OTel] Global fetch instrumentation enabled')\n }\n\n // Initialize logs (always enabled when OTEL is enabled)\n const logExporter = new EngineLogExporter(sharedConnection)\n loggerProvider = new LoggerProvider({ resource })\n loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter))\n logger = loggerProvider.getLogger(serviceName)\n\n console.debug('[OTel] Logs initialized')\n}\n\n/**\n * Shutdown OpenTelemetry, flushing any pending data.\n */\nexport async function shutdownOtel(): Promise<void> {\n if (tracerProvider) {\n await tracerProvider.forceFlush()\n await tracerProvider.shutdown()\n tracerProvider = null\n }\n\n if (meterProvider) {\n await meterProvider.forceFlush()\n await meterProvider.shutdown()\n meterProvider = null\n }\n\n if (loggerProvider) {\n await loggerProvider.forceFlush()\n await loggerProvider.shutdown()\n loggerProvider = null\n }\n\n if (sharedConnection) {\n await sharedConnection.shutdown()\n sharedConnection = null\n }\n\n unpatchGlobalFetch()\n\n tracer = null\n meter = null\n logger = null\n}\n\n/**\n * Get the OpenTelemetry tracer instance.\n */\nexport function getTracer(): Tracer | null {\n return tracer\n}\n\n/**\n * Get the OpenTelemetry meter instance.\n */\nexport function getMeter(): Meter | null {\n return meter\n}\n\n/**\n * Get the OpenTelemetry logger instance.\n */\nexport function getLogger(): Logger | null {\n return logger\n}\n\n/**\n * Start a new span with the given name and run the callback within it.\n */\nexport async function withSpan<T>(\n name: string,\n options: { kind?: SpanKind; traceparent?: string },\n fn: (span: Span) => Promise<T>,\n): Promise<T> {\n if (!tracer) {\n // Execute without span context when tracer is not initialized\n // Provide a no-op span to avoid runtime errors if fn calls span methods\n const noopSpan: Span = {\n spanContext: () => ({ traceId: '', spanId: '', traceFlags: 0 }),\n setAttribute: () => noopSpan,\n setAttributes: () => noopSpan,\n addEvent: () => noopSpan,\n addLink: () => noopSpan,\n setStatus: () => noopSpan,\n updateName: () => noopSpan,\n end: () => {},\n isRecording: () => false,\n recordException: () => {},\n addLinks: () => noopSpan,\n }\n return fn(noopSpan)\n }\n\n const parentContext = options.traceparent\n ? extractTraceparent(options.traceparent)\n : context.active()\n\n return tracer.startActiveSpan(\n name,\n { kind: options.kind ?? SpanKind.INTERNAL },\n parentContext,\n async span => {\n try {\n const result = await fn(span)\n span.setStatus({ code: SpanStatusCode.OK })\n return result\n } catch (error) {\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n}\n\n// Re-export OTEL types for convenience\nexport {\n SpanKind,\n SpanStatusCode,\n SeverityNumber,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n type Logger,\n}\n","import type { StreamChannelRef } from './iii-types'\nimport type { HttpRequest, HttpResponse, InternalHttpRequest } from './types'\n\n/**\n * Safely stringify a value, handling circular references, BigInt, and other edge cases.\n * Returns \"[unserializable]\" if serialization fails for any reason.\n */\nexport function safeStringify(value: unknown): string {\n const seen = new WeakSet<object>()\n\n try {\n return JSON.stringify(value, (_key, val) => {\n // Handle BigInt\n if (typeof val === 'bigint') {\n return val.toString()\n }\n\n // Handle circular references\n if (val !== null && typeof val === 'object') {\n if (seen.has(val)) {\n return '[Circular]'\n }\n seen.add(val)\n }\n\n return val\n })\n } catch {\n return '[unserializable]'\n }\n}\n\nexport const http = (callback: (req: HttpRequest, res: HttpResponse) => Promise<void>) => {\n return async (req: InternalHttpRequest) => {\n const { response, ...request } = req\n\n const httpResponse: HttpResponse = {\n status: (status_code: number) =>\n response.sendMessage(JSON.stringify({ type: 'set_status', status_code })),\n headers: (headers: Record<string, string>) =>\n response.sendMessage(JSON.stringify({ type: 'set_headers', headers })),\n stream: response.stream,\n close: () => response.close(),\n }\n\n await callback(request, httpResponse)\n }\n}\n\nexport const isChannelRef = (value: unknown): value is StreamChannelRef => {\n if (typeof value !== 'object' || value === null) return false\n const maybe = value as Partial<StreamChannelRef>\n return (\n typeof maybe.channel_id === 'string' &&\n typeof maybe.access_key === 'string' &&\n (maybe.direction === 'read' || maybe.direction === 'write')\n )\n}\n","/**\n * Worker metrics collection for the III Node SDK.\n *\n * Collects CPU, memory, and event loop metrics for worker health monitoring.\n * Uses the Node.js built-in `monitorEventLoopDelay` API for accurate\n * event loop lag measurements.\n */\n\nimport { type IntervalHistogram, monitorEventLoopDelay, performance } from 'node:perf_hooks'\n\n/**\n * Worker metrics data structure used internally for OTEL metric collection.\n */\nexport type WorkerMetrics = {\n memory_heap_used?: number\n memory_heap_total?: number\n memory_rss?: number\n memory_external?: number\n cpu_user_micros?: number\n cpu_system_micros?: number\n cpu_percent?: number\n event_loop_lag_ms?: number\n uptime_seconds?: number\n timestamp_ms: number\n runtime: string\n}\n\n/**\n * Configuration options for the WorkerMetricsCollector.\n */\nexport interface WorkerMetricsCollectorOptions {\n /**\n * Event loop delay histogram resolution in milliseconds.\n * Lower values provide more accurate measurements but use more resources.\n * @default 20\n */\n eventLoopResolutionMs?: number\n}\n\n/**\n * Collects worker resource metrics including CPU, memory, and event loop lag.\n *\n * Uses the Node.js `monitorEventLoopDelay` API for high-precision event loop\n * delay measurements instead of manual `setImmediate` timing.\n *\n * @example\n * ```typescript\n * const collector = new WorkerMetricsCollector()\n *\n * // Collect metrics periodically\n * setInterval(() => {\n * const metrics = collector.collect()\n * console.log('CPU:', metrics.cpu_percent, '%')\n * console.log('Event Loop Lag:', metrics.event_loop_lag_ms, 'ms')\n * }, 5000)\n *\n * // Clean up when done\n * collector.stopMonitoring()\n * ```\n */\nexport class WorkerMetricsCollector {\n private readonly startTime: number\n private lastCpuUsage: NodeJS.CpuUsage\n private lastCpuTime: number\n private eventLoopHistogram: IntervalHistogram | null = null\n\n /**\n * Creates a new WorkerMetricsCollector instance.\n *\n * @param options - Configuration options\n */\n constructor(options: WorkerMetricsCollectorOptions = {}) {\n this.startTime = Date.now()\n this.lastCpuUsage = process.cpuUsage()\n this.lastCpuTime = performance.now()\n this.startEventLoopMonitoring(options.eventLoopResolutionMs ?? 20)\n }\n\n /**\n * Starts the event loop delay histogram monitoring.\n *\n * @param resolutionMs - Histogram resolution in milliseconds\n */\n private startEventLoopMonitoring(resolutionMs: number): void {\n // Sanitize resolution: must be a positive finite number, minimum 1ms\n const safeResolutionMs =\n Number.isFinite(resolutionMs) && resolutionMs > 0 ? Math.max(1, Math.floor(resolutionMs)) : 20 // Default fallback\n\n this.eventLoopHistogram = monitorEventLoopDelay({ resolution: safeResolutionMs })\n this.eventLoopHistogram.enable()\n }\n\n /**\n * Stops the event loop monitoring and releases resources.\n * Should be called when the collector is no longer needed.\n */\n public stopMonitoring(): void {\n if (this.eventLoopHistogram) {\n this.eventLoopHistogram.disable()\n this.eventLoopHistogram = null\n }\n }\n\n /**\n * Collects current worker metrics.\n *\n * This method calculates CPU usage since the last collection,\n * reads memory usage, and gets event loop delay statistics.\n * The event loop histogram is reset after each collection for\n * accurate per-interval measurements.\n *\n * @returns Current worker metrics snapshot\n */\n collect(): WorkerMetrics {\n const memoryUsage = process.memoryUsage()\n const cpuUsage = process.cpuUsage()\n const now = performance.now()\n\n // Calculate CPU percentage since last collection\n const cpuDelta = {\n user: cpuUsage.user - this.lastCpuUsage.user,\n system: cpuUsage.system - this.lastCpuUsage.system,\n }\n const timeDelta = (now - this.lastCpuTime) * 1000 // Convert ms to microseconds\n const cpuPercent = timeDelta > 0 ? ((cpuDelta.user + cpuDelta.system) / timeDelta) * 100 : 0\n\n // Update state for next collection\n this.lastCpuUsage = cpuUsage\n this.lastCpuTime = now\n\n // Get event loop lag from histogram (in nanoseconds, convert to ms)\n let eventLoopLagMs = 0\n if (this.eventLoopHistogram) {\n // Mean is in nanoseconds, convert to milliseconds\n eventLoopLagMs = this.eventLoopHistogram.mean / 1_000_000\n // Reset histogram for next collection interval\n this.eventLoopHistogram.reset()\n }\n\n return {\n memory_heap_used: memoryUsage.heapUsed,\n memory_heap_total: memoryUsage.heapTotal,\n memory_rss: memoryUsage.rss,\n memory_external: memoryUsage.external,\n cpu_user_micros: cpuUsage.user,\n cpu_system_micros: cpuUsage.system,\n cpu_percent: Math.min(cpuPercent, 100), // Cap at 100%\n event_loop_lag_ms: eventLoopLagMs,\n uptime_seconds: Math.floor((Date.now() - this.startTime) / 1000),\n timestamp_ms: Date.now(),\n runtime: 'node',\n }\n }\n}\n","import type { Meter, BatchObservableResult, Observable } from '@opentelemetry/api'\nimport { WorkerMetricsCollector } from './worker-metrics'\n\nexport interface WorkerGaugesOptions {\n workerId: string\n workerName?: string\n}\n\nlet registeredGauges = false\nlet metricsCollector: WorkerMetricsCollector | null = null\nlet registeredMeter: Meter | null = null\nlet registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null = null\nlet registeredObservables: Observable[] = []\n\nexport function registerWorkerGauges(meter: Meter, options: WorkerGaugesOptions): void {\n if (registeredGauges) {\n return\n }\n\n const { workerId, workerName } = options\n const baseAttributes = {\n 'worker.id': workerId,\n ...(workerName && { 'worker.name': workerName }),\n }\n\n metricsCollector = new WorkerMetricsCollector()\n\n const memoryHeapUsed = meter.createObservableGauge('iii.worker.memory.heap_used', {\n description: 'Worker heap memory used in bytes',\n unit: 'bytes',\n })\n\n const memoryHeapTotal = meter.createObservableGauge('iii.worker.memory.heap_total', {\n description: 'Worker total heap memory in bytes',\n unit: 'bytes',\n })\n\n const memoryRss = meter.createObservableGauge('iii.worker.memory.rss', {\n description: 'Worker resident set size in bytes',\n unit: 'bytes',\n })\n\n const memoryExternal = meter.createObservableGauge('iii.worker.memory.external', {\n description: 'Worker external memory in bytes',\n unit: 'bytes',\n })\n\n const cpuPercent = meter.createObservableGauge('iii.worker.cpu.percent', {\n description: 'Worker CPU usage percentage',\n unit: '%',\n })\n\n const cpuUserMicros = meter.createObservableGauge('iii.worker.cpu.user_micros', {\n description: 'Worker CPU user time in microseconds',\n unit: 'us',\n })\n\n const cpuSystemMicros = meter.createObservableGauge('iii.worker.cpu.system_micros', {\n description: 'Worker CPU system time in microseconds',\n unit: 'us',\n })\n\n const eventLoopLag = meter.createObservableGauge('iii.worker.event_loop.lag_ms', {\n description: 'Worker event loop lag in milliseconds',\n unit: 'ms',\n })\n\n const uptimeSeconds = meter.createObservableGauge('iii.worker.uptime_seconds', {\n description: 'Worker uptime in seconds',\n unit: 's',\n })\n\n const batchCallback = (observableResult: BatchObservableResult) => {\n if (!metricsCollector) return\n\n const metrics = metricsCollector.collect()\n\n if (metrics.memory_heap_used !== undefined) {\n observableResult.observe(memoryHeapUsed, metrics.memory_heap_used, baseAttributes)\n }\n if (metrics.memory_heap_total !== undefined) {\n observableResult.observe(memoryHeapTotal, metrics.memory_heap_total, baseAttributes)\n }\n if (metrics.memory_rss !== undefined) {\n observableResult.observe(memoryRss, metrics.memory_rss, baseAttributes)\n }\n if (metrics.memory_external !== undefined) {\n observableResult.observe(memoryExternal, metrics.memory_external, baseAttributes)\n }\n if (metrics.cpu_percent !== undefined) {\n observableResult.observe(cpuPercent, metrics.cpu_percent, baseAttributes)\n }\n if (metrics.cpu_user_micros !== undefined) {\n observableResult.observe(cpuUserMicros, metrics.cpu_user_micros, baseAttributes)\n }\n if (metrics.cpu_system_micros !== undefined) {\n observableResult.observe(cpuSystemMicros, metrics.cpu_system_micros, baseAttributes)\n }\n if (metrics.event_loop_lag_ms !== undefined) {\n observableResult.observe(eventLoopLag, metrics.event_loop_lag_ms, baseAttributes)\n }\n if (metrics.uptime_seconds !== undefined) {\n observableResult.observe(uptimeSeconds, metrics.uptime_seconds, baseAttributes)\n }\n }\n\n meter.addBatchObservableCallback(batchCallback, [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ])\n\n registeredMeter = meter\n registeredBatchCallback = batchCallback\n registeredObservables = [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ]\n\n registeredGauges = true\n}\n\nexport function stopWorkerGauges(): void {\n // Remove the batch observable callback before stopping\n if (registeredMeter && registeredBatchCallback) {\n registeredMeter.removeBatchObservableCallback(registeredBatchCallback, registeredObservables)\n }\n\n if (metricsCollector) {\n metricsCollector.stopMonitoring()\n metricsCollector = null\n }\n\n registeredMeter = null\n registeredBatchCallback = null\n registeredObservables = []\n registeredGauges = false\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"otel-worker-gauges-Dqf47JXh.mjs","names":["DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig","DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig","metrics","carrier: Record<string, string>","entries: Record<string, string>","originalFetch: typeof globalThis.fetch | null","host: string | undefined","scheme: string | undefined","path: string | undefined","port: number | undefined","query: string | undefined","spanAttributes: Record<string, string | number>","tracer","carrier: Record<string, string>","sharedConnection: SharedEngineConnection | null","tracerProvider: NodeTracerProvider | null","meterProvider: MeterProvider | null","loggerProvider: LoggerProvider | null","tracer: Tracer | null","meter: Meter | null","logger: Logger | null","serviceName: string","resourceAttributes: Record<string, string>","noopSpan: Span","SpanKind","SpanStatusCode","metricsCollector: WorkerMetricsCollector | null","registeredMeter: Meter | null","registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null","registeredObservables: Observable[]","meter","metrics"],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/connection.ts","../src/telemetry-system/span-exporter.ts","../src/telemetry-system/metrics-exporter.ts","../src/telemetry-system/log-exporter.ts","../src/telemetry-system/context.ts","../src/telemetry-system/fetch-instrumentation.ts","../src/telemetry-system/index.ts","../src/utils.ts","../src/worker-metrics.ts","../src/otel-worker-gauges.ts"],"sourcesContent":["/**\n * Constants for the III module.\n */\n\n/** Engine function paths for internal operations */\nexport const EngineFunctions = {\n LIST_FUNCTIONS: 'engine::functions::list',\n LIST_WORKERS: 'engine::workers::list',\n REGISTER_WORKER: 'engine::workers::register',\n} as const\n\n/** Engine trigger types */\nexport const EngineTriggers = {\n FUNCTIONS_AVAILABLE: 'engine::functions-available',\n LOG: 'log',\n} as const\n\n/** Log function paths */\nexport const LogFunctions = {\n INFO: 'engine::log::info',\n WARN: 'engine::log::warn',\n ERROR: 'engine::log::error',\n DEBUG: 'engine::log::debug',\n} as const\n\n/** Connection state for the III WebSocket */\nexport type IIIConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface IIIReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Default invocation timeout in milliseconds */\nexport const DEFAULT_INVOCATION_TIMEOUT_MS = 30000\n","/**\n * Types, interfaces, and constants for the OpenTelemetry module.\n */\n\nimport type { Instrumentation } from '@opentelemetry/instrumentation'\n\n// Semantic convention constants for compatibility across versions\nexport const ATTR_SERVICE_VERSION = 'service.version'\nexport const ATTR_SERVICE_NAMESPACE = 'service.namespace'\nexport const ATTR_SERVICE_INSTANCE_ID = 'service.instance.id'\n\n/** Magic prefixes for binary frames over WebSocket */\nexport const PREFIX_TRACES = 'OTLP'\nexport const PREFIX_METRICS = 'MTRC'\nexport const PREFIX_LOGS = 'LOGS'\n\n/** Connection state for the shared WebSocket */\nexport type ConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface ReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Configuration for OpenTelemetry initialization. */\nexport interface OtelConfig {\n /** Whether OpenTelemetry export is enabled. Defaults to true. Set to false or OTEL_ENABLED=false/0/no/off to disable. */\n enabled?: boolean\n /** The service name to report. Defaults to OTEL_SERVICE_NAME or \"iii-node\". */\n serviceName?: string\n /** The service version to report. Defaults to SERVICE_VERSION env var or \"unknown\". */\n serviceVersion?: string\n /** The service namespace to report. Defaults to SERVICE_NAMESPACE env var. */\n serviceNamespace?: string\n /** The service instance ID to report. Defaults to SERVICE_INSTANCE_ID env var or auto-generated UUID. */\n serviceInstanceId?: string\n /** III Engine WebSocket URL. Defaults to III_BRIDGE_URL or \"ws://localhost:49134\". */\n engineWsUrl?: string\n /** OpenTelemetry instrumentations to register (e.g., PrismaInstrumentation). */\n instrumentations?: Instrumentation[]\n /** Whether OpenTelemetry metrics export is enabled. Defaults to true. Set to false or OTEL_METRICS_ENABLED=false/0/no/off to disable. */\n metricsEnabled?: boolean\n /** Metrics export interval in milliseconds. Defaults to 60000 (60 seconds). */\n metricsExportIntervalMs?: number\n /** Whether to auto-instrument globalThis.fetch calls. Defaults to true. Works on Node.js, Bun, and Deno. Set to false to disable. */\n fetchInstrumentationEnabled?: boolean\n /** Optional reconnection configuration for the WebSocket connection. */\n reconnectionConfig?: Partial<ReconnectionConfig>\n}\n\n/** Default configuration values for OpenTelemetry initialization. */\nexport const DEFAULT_OTEL_CONFIG = {\n enabled: true,\n serviceName: 'iii-node',\n serviceVersion: 'unknown',\n engineWsUrl: 'ws://localhost:49134',\n metricsEnabled: true,\n metricsExportIntervalMs: 60000,\n fetchInstrumentationEnabled: true,\n} as const satisfies Partial<OtelConfig>\n\n/** Parse a boolean environment variable, recognizing 'false', '0', 'no', 'off' as false. */\nexport function parseBoolEnv(value: string | undefined, defaultValue: boolean): boolean {\n if (value === undefined) return defaultValue\n const lower = value.toLowerCase()\n return lower !== 'false' && lower !== '0' && lower !== 'no' && lower !== 'off'\n}\n","/**\n * Shared WebSocket connection for OpenTelemetry exporters.\n */\n\nimport { WebSocket } from 'ws'\nimport { type ConnectionState, type ReconnectionConfig, DEFAULT_RECONNECTION_CONFIG } from './types'\n\n/**\n * Shared WebSocket connection for all OTEL exporters (traces, metrics, logs).\n * Uses a single connection with message prefixes to identify signal type.\n */\nexport class SharedEngineConnection {\n private static readonly MAX_PENDING_MESSAGES = 1000\n private ws: WebSocket | null = null\n private wsUrl: string\n private connecting = false\n private shuttingDown = false\n private pendingMessages: Array<{ frame: Buffer; callback?: (err?: Error) => void }> = []\n private reconnectAttempt = 0\n private reconnectTimeout: NodeJS.Timeout | null = null\n private config: ReconnectionConfig\n private state: ConnectionState = 'disconnected'\n private onConnectedCallbacks: Array<() => void> = []\n\n constructor(wsUrl: string, config: Partial<ReconnectionConfig> = {}) {\n this.wsUrl = wsUrl\n this.config = { ...DEFAULT_RECONNECTION_CONFIG, ...config }\n this.connect()\n }\n\n private connect(): void {\n if (this.connecting || (this.ws && this.ws.readyState === WebSocket.OPEN)) {\n return\n }\n\n this.connecting = true\n this.state = 'connecting'\n\n try {\n this.ws = new WebSocket(this.wsUrl)\n\n this.ws.on('open', () => {\n this.connecting = false\n this.state = 'connected'\n console.log(`[OTel] Connected to engine at ${this.wsUrl}`)\n\n // Reset reconnection state\n if (this.reconnectAttempt > 0) {\n console.log('[OTel] Successfully reconnected')\n }\n this.reconnectAttempt = 0\n\n // Clear any pending reconnect timer to prevent race conditions\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n // Flush pending messages\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n for (const { frame, callback } of pending) {\n this.ws?.send(frame, err => callback?.(err))\n }\n\n // Notify callbacks\n for (const cb of this.onConnectedCallbacks) {\n cb()\n }\n })\n\n this.ws.on('close', () => {\n this.connecting = false\n this.ws = null\n\n // Skip reconnection if we're shutting down intentionally\n if (this.shuttingDown) {\n this.state = 'disconnected'\n console.log('[OTel] Connection closed during shutdown')\n return\n }\n\n this.state = 'disconnected'\n console.log('[OTel] Disconnected from engine, will reconnect...')\n this.scheduleReconnect()\n })\n\n this.ws.on('error', err => {\n this.connecting = false\n\n // Skip error handling if we're shutting down intentionally\n if (this.shuttingDown) {\n return\n }\n\n console.error('[OTel] WebSocket error:', err.message)\n })\n } catch (err) {\n this.connecting = false\n console.error('[OTel] Connection failed:', err)\n this.scheduleReconnect()\n }\n }\n\n private scheduleReconnect(): void {\n if (this.config.maxRetries !== -1 && this.reconnectAttempt >= this.config.maxRetries) {\n this.state = 'failed'\n console.error(`[OTel] Max retries (${this.config.maxRetries}) reached, giving up`)\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const failedError = new Error('Connection failed after max retries')\n for (const { callback } of pending) {\n callback?.(failedError)\n }\n return\n }\n\n if (this.reconnectTimeout) {\n return // Already scheduled\n }\n\n const exponentialDelay =\n this.config.initialDelayMs * this.config.backoffMultiplier ** this.reconnectAttempt\n const cappedDelay = Math.min(exponentialDelay, this.config.maxDelayMs)\n const jitter = cappedDelay * this.config.jitterFactor * (2 * Math.random() - 1)\n const delay = Math.max(0, Math.floor(cappedDelay + jitter))\n\n this.state = 'reconnecting'\n console.log(`[OTel] Reconnecting in ${delay}ms (attempt ${this.reconnectAttempt + 1})...`)\n\n this.reconnectTimeout = setTimeout(() => {\n this.reconnectTimeout = null\n this.reconnectAttempt++\n this.connect()\n }, delay)\n }\n\n /**\n * Send a message with a signal prefix.\n */\n send(prefix: string, data: Uint8Array, callback?: (err?: Error) => void): void {\n const prefixBytes = Buffer.from(prefix, 'utf-8')\n const frame = Buffer.concat([prefixBytes, Buffer.from(data)])\n\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send(frame, callback)\n } else {\n // Queue for later with bounded size to prevent memory exhaustion\n if (this.pendingMessages.length >= SharedEngineConnection.MAX_PENDING_MESSAGES) {\n console.warn('[OTel] Pending message queue full, dropping oldest message')\n const dropped = this.pendingMessages.shift()\n dropped?.callback?.(new Error('Message dropped due to queue overflow'))\n }\n this.pendingMessages.push({ frame, callback })\n this.connect()\n }\n }\n\n /**\n * Register a callback to be called when connected.\n */\n onConnected(callback: () => void): void {\n this.onConnectedCallbacks.push(callback)\n if (this.state === 'connected') {\n callback()\n }\n }\n\n /**\n * Get the current connection state.\n */\n getState(): ConnectionState {\n return this.state\n }\n\n /**\n * Shutdown the connection.\n */\n async shutdown(): Promise<void> {\n // Set shutdown flag to prevent reconnection attempts\n this.shuttingDown = true\n\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const shutdownError = new Error('Connection shutdown before message could be sent')\n for (const { callback } of pending) {\n callback?.(shutdownError)\n }\n this.onConnectedCallbacks = []\n this.state = 'disconnected'\n }\n}\n","/**\n * Span exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { ReadableSpan, SpanExporter } from '@opentelemetry/sdk-trace-base'\nimport { JsonTraceSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_TRACES } from './types'\n\n/**\n * Span exporter using the shared WebSocket connection.\n */\nexport class EngineSpanExporter implements SpanExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n spans: ReadableSpan[]\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { spans, resultCallback } of pending) {\n this.sendExport(spans, resultCallback)\n }\n }\n\n private sendExport(spans: ReadableSpan[], resultCallback?: (result: ExportResult) => void): void {\n try {\n const serialized = JsonTraceSerializer.serializeRequest(spans)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_TRACES, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send spans:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting spans:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineSpanExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Spans export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ spans, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(spans, resultCallback)\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(spans, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op, spans are sent immediately\n }\n}\n","/**\n * Metrics exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { PushMetricExporter, ResourceMetrics } from '@opentelemetry/sdk-metrics'\nimport { JsonMetricsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_METRICS } from './types'\n\n/**\n * Metrics exporter using the shared WebSocket connection.\n */\nexport class EngineMetricsExporter implements PushMetricExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n metrics: ResourceMetrics\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { metrics, resultCallback } of pending) {\n this.sendExport(metrics, resultCallback)\n }\n }\n\n private sendExport(\n metricsData: ResourceMetrics,\n resultCallback?: (result: ExportResult) => void,\n ): void {\n try {\n const serialized = JsonMetricsSerializer.serializeRequest(metricsData)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_METRICS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send metrics:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting metrics:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(\n metricsData: ResourceMetrics,\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineMetricsExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Metrics export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ metrics: metricsData, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(metricsData, resultCallback)\n }\n\n export(metrics: ResourceMetrics, resultCallback: (result: ExportResult) => void): void {\n this.doExport(metrics, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op\n }\n}\n","/**\n * Log exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { LogRecordExporter, ReadableLogRecord } from '@opentelemetry/sdk-logs'\nimport { JsonLogsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_LOGS } from './types'\n\n/**\n * Log exporter using the shared WebSocket connection.\n */\nexport class EngineLogExporter implements LogRecordExporter {\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n logs: ReadableLogRecord[]\n callback: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { logs, callback } of pending) {\n this.doExport(logs, callback)\n }\n }\n\n private doExport(\n logs: ReadableLogRecord[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n this.pendingExports.push({ logs, callback: resultCallback })\n return\n }\n\n try {\n const serialized = JsonLogsSerializer.serializeRequest(logs)\n if (!serialized) {\n resultCallback({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_LOGS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send logs:', err.message)\n resultCallback({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting logs:', err)\n resultCallback({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n export(logs: ReadableLogRecord[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(logs, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n for (const { callback } of this.pendingExports) {\n callback({ code: ExportResultCode.FAILED, error: new Error('Exporter shutdown') })\n }\n this.pendingExports = []\n }\n}\n","/**\n * Trace context and baggage propagation utilities.\n */\n\nimport { trace, context, propagation, type Context } from '@opentelemetry/api'\n\n/**\n * Extract the current trace ID from the active span context.\n */\nexport function currentTraceId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.traceId && spanContext.traceId !== '00000000000000000000000000000000') {\n return spanContext.traceId\n }\n }\n return undefined\n}\n\n/**\n * Extract the current span ID from the active span context.\n */\nexport function currentSpanId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.spanId && spanContext.spanId !== '0000000000000000') {\n return spanContext.spanId\n }\n }\n return undefined\n}\n\n/**\n * Inject the current trace context into a W3C traceparent header string.\n */\nexport function injectTraceparent(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.traceparent\n}\n\n/**\n * Extract a trace context from a W3C traceparent header string.\n */\nexport function extractTraceparent(traceparent: string): Context {\n const carrier: Record<string, string> = { traceparent }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Inject the current baggage into a W3C baggage header string.\n */\nexport function injectBaggage(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.baggage\n}\n\n/**\n * Extract baggage from a W3C baggage header string.\n */\nexport function extractBaggage(baggage: string): Context {\n const carrier: Record<string, string> = { baggage }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Extract both trace context and baggage from their respective headers.\n */\nexport function extractContext(traceparent?: string, baggage?: string): Context {\n const carrier: Record<string, string> = {}\n if (traceparent) {\n carrier.traceparent = traceparent\n }\n if (baggage) {\n carrier.baggage = baggage\n }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Get a baggage entry from the current context.\n */\nexport function getBaggageEntry(key: string): string | undefined {\n const bag = propagation.getBaggage(context.active())\n return bag?.getEntry(key)?.value\n}\n\n/**\n * Set a baggage entry in the current context.\n */\nexport function setBaggageEntry(key: string, value: string): Context {\n let bag = propagation.getBaggage(context.active()) ?? propagation.createBaggage()\n bag = bag.setEntry(key, { value })\n return propagation.setBaggage(context.active(), bag)\n}\n\n/**\n * Remove a baggage entry from the current context.\n */\nexport function removeBaggageEntry(key: string): Context {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return context.active()\n }\n const newBag = bag.removeEntry(key)\n return propagation.setBaggage(context.active(), newBag)\n}\n\n/**\n * Get all baggage entries from the current context.\n */\nexport function getAllBaggage(): Record<string, string> {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return {}\n }\n const entries: Record<string, string> = {}\n for (const [key, entry] of bag.getAllEntries()) {\n entries[key] = entry.value\n }\n return entries\n}\n","/**\n * Global fetch auto-instrumentation for the III Node SDK.\n *\n * Patches globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n * Works on all runtimes (Bun, Node.js, Deno) unlike UndiciInstrumentation\n * which only works when fetch is backed by Node.js's undici.\n */\n\nimport { type Tracer, SpanKind, SpanStatusCode, context, propagation } from '@opentelemetry/api'\n\nconst textEncoder = new TextEncoder()\n\nfunction getBodyByteSize(body: unknown): number | undefined {\n if (body == null) return undefined\n if (typeof body === 'string') return textEncoder.encode(body).byteLength\n if (body instanceof ArrayBuffer) return body.byteLength\n if (ArrayBuffer.isView(body)) return body.byteLength\n if (body instanceof Blob) return body.size\n if (body instanceof URLSearchParams) return new TextEncoder().encode(body.toString()).byteLength\n return undefined\n}\n\nconst SAFE_REQUEST_HEADERS = ['content-type', 'accept'] as const\nconst SAFE_RESPONSE_HEADERS = ['content-type'] as const\n\nlet originalFetch: typeof globalThis.fetch | null = null\n\n/**\n * Patch globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n */\nexport function patchGlobalFetch(tracer: Tracer): void {\n if (originalFetch) return\n\n originalFetch = globalThis.fetch\n const capturedFetch = originalFetch\n\n globalThis.fetch = async (\n input: string | URL | Request,\n init?: RequestInit,\n ): Promise<Response> => {\n const url = input instanceof Request ? input.url : String(input)\n const method = (init?.method ?? (input instanceof Request ? input.method : 'GET')).toUpperCase()\n\n let host: string | undefined\n let scheme: string | undefined\n let path: string | undefined\n let port: number | undefined\n let query: string | undefined\n try {\n const parsed = new URL(url)\n host = parsed.hostname\n scheme = parsed.protocol.replace(':', '')\n path = parsed.pathname\n port = parsed.port ? parseInt(parsed.port, 10) : undefined\n query = parsed.search ? parsed.search.slice(1) : undefined\n } catch {\n // relative URL or invalid — skip host/scheme/path attributes\n }\n\n const spanAttributes: Record<string, string | number> = {\n 'http.request.method': method,\n 'url.full': url,\n }\n if (host) spanAttributes['server.address'] = host\n if (scheme) {\n spanAttributes['url.scheme'] = scheme\n spanAttributes['network.protocol.name'] = 'http'\n }\n if (path) spanAttributes['url.path'] = path\n if (port) spanAttributes['server.port'] = port\n if (query) spanAttributes['url.query'] = query\n\n const spanName = path ? `${method} ${path}` : method\n\n return tracer.startActiveSpan(\n spanName,\n { kind: SpanKind.CLIENT, attributes: spanAttributes },\n context.active(),\n async span => {\n try {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n\n const headers = new Headers(\n init?.headers ?? (input instanceof Request ? input.headers : undefined),\n )\n for (const [key, value] of Object.entries(carrier)) {\n headers.set(key, value)\n }\n\n for (const name of SAFE_REQUEST_HEADERS) {\n const value = headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.request.header.${name}`, value)\n }\n }\n\n const requestBody = init?.body ?? (input instanceof Request ? input.body : undefined)\n const requestBodySize = getBodyByteSize(requestBody)\n if (requestBodySize !== undefined) {\n span.setAttribute('http.request.body.size', requestBodySize)\n }\n\n const response = await capturedFetch(input, { ...init, headers })\n\n span.setAttribute('http.response.status_code', response.status)\n\n const contentLength = response.headers.get('content-length')\n if (contentLength !== null) {\n const size = parseInt(contentLength, 10)\n if (!Number.isNaN(size)) {\n span.setAttribute('http.response.body.size', size)\n }\n }\n\n for (const name of SAFE_RESPONSE_HEADERS) {\n const value = response.headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.response.header.${name}`, value)\n }\n }\n\n if (response.status >= 400) {\n span.setAttribute('error.type', String(response.status))\n span.setStatus({ code: SpanStatusCode.ERROR })\n } else {\n span.setStatus({ code: SpanStatusCode.OK })\n }\n\n return response\n } catch (error) {\n span.setAttribute('error.type', (error as Error).name ?? 'Error')\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n }\n}\n\n/**\n * Restore globalThis.fetch to its original implementation.\n */\nexport function unpatchGlobalFetch(): void {\n if (originalFetch) {\n globalThis.fetch = originalFetch\n originalFetch = null\n }\n}\n","/**\n * OpenTelemetry initialization for the III Node SDK.\n *\n * This module provides trace, metrics, and log export to the III Engine\n * via a shared WebSocket connection using OTLP JSON format.\n */\n\nimport { Resource } from '@opentelemetry/resources'\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions'\nimport { randomUUID } from 'node:crypto'\nimport {\n trace,\n context,\n propagation,\n SpanKind,\n SpanStatusCode,\n metrics,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n} from '@opentelemetry/api'\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base'\nimport { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics'\nimport {\n CompositePropagator,\n W3CBaggagePropagator,\n W3CTraceContextPropagator,\n} from '@opentelemetry/core'\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node'\nimport { registerInstrumentations } from '@opentelemetry/instrumentation'\nimport { LoggerProvider, BatchLogRecordProcessor } from '@opentelemetry/sdk-logs'\nimport { type Logger, SeverityNumber } from '@opentelemetry/api-logs'\n\nimport {\n type OtelConfig,\n DEFAULT_OTEL_CONFIG,\n parseBoolEnv,\n ATTR_SERVICE_VERSION,\n ATTR_SERVICE_NAMESPACE,\n ATTR_SERVICE_INSTANCE_ID,\n} from './types'\nimport { SharedEngineConnection } from './connection'\nimport { EngineSpanExporter, EngineMetricsExporter, EngineLogExporter } from './exporters'\nimport { extractTraceparent } from './context'\nimport { patchGlobalFetch, unpatchGlobalFetch } from './fetch-instrumentation'\n\n// Re-export everything from submodules\nexport * from './types'\nexport * from './context'\n\n// Module-level state\nlet sharedConnection: SharedEngineConnection | null = null\nlet tracerProvider: NodeTracerProvider | null = null\nlet meterProvider: MeterProvider | null = null\nlet loggerProvider: LoggerProvider | null = null\nlet tracer: Tracer | null = null\nlet meter: Meter | null = null\nlet logger: Logger | null = null\nlet serviceName: string = 'iii-node-iii'\n\n/**\n * Initialize OpenTelemetry with the given configuration.\n * This should be called once at application startup.\n */\nexport function initOtel(config: OtelConfig = {}): void {\n const enabled =\n config.enabled ?? parseBoolEnv(process.env.OTEL_ENABLED, DEFAULT_OTEL_CONFIG.enabled)\n\n if (!enabled) {\n console.debug(\n '[OTel] OpenTelemetry is disabled. To enable, remove OTEL_ENABLED=false or set enabled: true in config.',\n )\n return\n }\n\n // Configure service identity\n serviceName =\n config.serviceName ?? process.env.OTEL_SERVICE_NAME ?? DEFAULT_OTEL_CONFIG.serviceName\n const serviceVersion =\n config.serviceVersion ?? process.env.SERVICE_VERSION ?? DEFAULT_OTEL_CONFIG.serviceVersion\n const serviceNamespace = config.serviceNamespace ?? process.env.SERVICE_NAMESPACE\n const serviceInstanceId =\n config.serviceInstanceId ?? process.env.SERVICE_INSTANCE_ID ?? randomUUID()\n const engineWsUrl =\n config.engineWsUrl ?? process.env.III_BRIDGE_URL ?? DEFAULT_OTEL_CONFIG.engineWsUrl\n\n // Build resource attributes\n const resourceAttributes: Record<string, string> = {\n [ATTR_SERVICE_NAME]: serviceName,\n [ATTR_SERVICE_VERSION]: serviceVersion,\n [ATTR_SERVICE_INSTANCE_ID]: serviceInstanceId,\n }\n if (serviceNamespace) {\n resourceAttributes[ATTR_SERVICE_NAMESPACE] = serviceNamespace\n }\n const resource = new Resource(resourceAttributes)\n\n // Create shared WebSocket connection\n sharedConnection = new SharedEngineConnection(engineWsUrl, config.reconnectionConfig)\n\n // Initialize tracer\n const spanExporter = new EngineSpanExporter(sharedConnection)\n tracerProvider = new NodeTracerProvider({\n resource,\n spanProcessors: [new BatchSpanProcessor(spanExporter)],\n })\n\n // Register W3C Trace Context and Baggage propagators\n propagation.setGlobalPropagator(\n new CompositePropagator({\n propagators: [new W3CTraceContextPropagator(), new W3CBaggagePropagator()],\n }),\n )\n\n tracerProvider.register()\n tracer = trace.getTracer(serviceName)\n\n console.debug(`[OTel] Traces initialized: engine=${engineWsUrl}, service=${serviceName}`)\n\n // Initialize metrics (enabled by default, opt-out via config or env)\n const metricsEnabled =\n config.metricsEnabled ??\n parseBoolEnv(process.env.OTEL_METRICS_ENABLED, DEFAULT_OTEL_CONFIG.metricsEnabled)\n\n if (metricsEnabled) {\n const metricsExporter = new EngineMetricsExporter(sharedConnection)\n const exportIntervalMs =\n config.metricsExportIntervalMs ?? DEFAULT_OTEL_CONFIG.metricsExportIntervalMs\n\n const metricReader = new PeriodicExportingMetricReader({\n exporter: metricsExporter,\n exportIntervalMillis: exportIntervalMs,\n })\n\n meterProvider = new MeterProvider({\n resource,\n readers: [metricReader],\n })\n\n metrics.setGlobalMeterProvider(meterProvider)\n meter = meterProvider.getMeter(serviceName)\n\n console.debug(`[OTel] Metrics initialized: interval=${exportIntervalMs}ms`)\n }\n\n // Register user-provided instrumentations AFTER providers are set up\n const instrumentations = [...(config.instrumentations ?? [])]\n if (instrumentations.length > 0) {\n registerInstrumentations({\n instrumentations,\n tracerProvider,\n meterProvider: meterProvider ?? undefined,\n })\n console.debug(`[OTel] Instrumentations registered: ${instrumentations.length} total`)\n }\n\n // Patch global fetch for runtime-agnostic HTTP client tracing (works on Bun, Node.js, Deno)\n const fetchEnabled =\n config.fetchInstrumentationEnabled ?? DEFAULT_OTEL_CONFIG.fetchInstrumentationEnabled\n\n if (fetchEnabled) {\n patchGlobalFetch(tracer)\n console.debug('[OTel] Global fetch instrumentation enabled')\n }\n\n // Initialize logs (always enabled when OTEL is enabled)\n const logExporter = new EngineLogExporter(sharedConnection)\n loggerProvider = new LoggerProvider({ resource })\n loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter))\n logger = loggerProvider.getLogger(serviceName)\n\n console.debug('[OTel] Logs initialized')\n}\n\n/**\n * Shutdown OpenTelemetry, flushing any pending data.\n */\nexport async function shutdownOtel(): Promise<void> {\n if (tracerProvider) {\n await tracerProvider.forceFlush()\n await tracerProvider.shutdown()\n tracerProvider = null\n }\n\n if (meterProvider) {\n await meterProvider.forceFlush()\n await meterProvider.shutdown()\n meterProvider = null\n }\n\n if (loggerProvider) {\n await loggerProvider.forceFlush()\n await loggerProvider.shutdown()\n loggerProvider = null\n }\n\n if (sharedConnection) {\n await sharedConnection.shutdown()\n sharedConnection = null\n }\n\n unpatchGlobalFetch()\n\n tracer = null\n meter = null\n logger = null\n}\n\n/**\n * Get the OpenTelemetry tracer instance.\n */\nexport function getTracer(): Tracer | null {\n return tracer\n}\n\n/**\n * Get the OpenTelemetry meter instance.\n */\nexport function getMeter(): Meter | null {\n return meter\n}\n\n/**\n * Get the OpenTelemetry logger instance.\n */\nexport function getLogger(): Logger | null {\n return logger\n}\n\n/**\n * Start a new span with the given name and run the callback within it.\n */\nexport async function withSpan<T>(\n name: string,\n options: { kind?: SpanKind; traceparent?: string },\n fn: (span: Span) => Promise<T>,\n): Promise<T> {\n if (!tracer) {\n // Execute without span context when tracer is not initialized\n // Provide a no-op span to avoid runtime errors if fn calls span methods\n const noopSpan: Span = {\n spanContext: () => ({ traceId: '', spanId: '', traceFlags: 0 }),\n setAttribute: () => noopSpan,\n setAttributes: () => noopSpan,\n addEvent: () => noopSpan,\n addLink: () => noopSpan,\n setStatus: () => noopSpan,\n updateName: () => noopSpan,\n end: () => {},\n isRecording: () => false,\n recordException: () => {},\n addLinks: () => noopSpan,\n }\n return fn(noopSpan)\n }\n\n const parentContext = options.traceparent\n ? extractTraceparent(options.traceparent)\n : context.active()\n\n return tracer.startActiveSpan(\n name,\n { kind: options.kind ?? SpanKind.INTERNAL },\n parentContext,\n async span => {\n try {\n const result = await fn(span)\n span.setStatus({ code: SpanStatusCode.OK })\n return result\n } catch (error) {\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n}\n\n// Re-export OTEL types for convenience\nexport {\n SpanKind,\n SpanStatusCode,\n SeverityNumber,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n type Logger,\n}\n","import type { StreamChannelRef } from './iii-types'\nimport type { ApiResponse, HttpRequest, HttpResponse, InternalHttpRequest } from './types'\n\n/**\n * Safely stringify a value, handling circular references, BigInt, and other edge cases.\n * Returns \"[unserializable]\" if serialization fails for any reason.\n */\nexport function safeStringify(value: unknown): string {\n const seen = new WeakSet<object>()\n\n try {\n return JSON.stringify(value, (_key, val) => {\n // Handle BigInt\n if (typeof val === 'bigint') {\n return val.toString()\n }\n\n // Handle circular references\n if (val !== null && typeof val === 'object') {\n if (seen.has(val)) {\n return '[Circular]'\n }\n seen.add(val)\n }\n\n return val\n })\n } catch {\n return '[unserializable]'\n }\n}\n\nexport const http = (\n // biome-ignore lint/suspicious/noConfusingVoidType: void is necessary here\n callback: (req: HttpRequest, res: HttpResponse) => Promise<void | ApiResponse>,\n) => {\n return async (req: InternalHttpRequest) => {\n const { response, ...request } = req\n\n const httpResponse: HttpResponse = {\n status: (status_code: number) =>\n response.sendMessage(JSON.stringify({ type: 'set_status', status_code })),\n headers: (headers: Record<string, string>) =>\n response.sendMessage(JSON.stringify({ type: 'set_headers', headers })),\n stream: response.stream,\n close: () => response.close(),\n }\n\n return callback(request, httpResponse)\n }\n}\n\nexport const isChannelRef = (value: unknown): value is StreamChannelRef => {\n if (typeof value !== 'object' || value === null) return false\n const maybe = value as Partial<StreamChannelRef>\n return (\n typeof maybe.channel_id === 'string' &&\n typeof maybe.access_key === 'string' &&\n (maybe.direction === 'read' || maybe.direction === 'write')\n )\n}\n","/**\n * Worker metrics collection for the III Node SDK.\n *\n * Collects CPU, memory, and event loop metrics for worker health monitoring.\n * Uses the Node.js built-in `monitorEventLoopDelay` API for accurate\n * event loop lag measurements.\n */\n\nimport { type IntervalHistogram, monitorEventLoopDelay, performance } from 'node:perf_hooks'\n\n/**\n * Worker metrics data structure used internally for OTEL metric collection.\n */\nexport type WorkerMetrics = {\n memory_heap_used?: number\n memory_heap_total?: number\n memory_rss?: number\n memory_external?: number\n cpu_user_micros?: number\n cpu_system_micros?: number\n cpu_percent?: number\n event_loop_lag_ms?: number\n uptime_seconds?: number\n timestamp_ms: number\n runtime: string\n}\n\n/**\n * Configuration options for the WorkerMetricsCollector.\n */\nexport interface WorkerMetricsCollectorOptions {\n /**\n * Event loop delay histogram resolution in milliseconds.\n * Lower values provide more accurate measurements but use more resources.\n * @default 20\n */\n eventLoopResolutionMs?: number\n}\n\n/**\n * Collects worker resource metrics including CPU, memory, and event loop lag.\n *\n * Uses the Node.js `monitorEventLoopDelay` API for high-precision event loop\n * delay measurements instead of manual `setImmediate` timing.\n *\n * @example\n * ```typescript\n * const collector = new WorkerMetricsCollector()\n *\n * // Collect metrics periodically\n * setInterval(() => {\n * const metrics = collector.collect()\n * console.log('CPU:', metrics.cpu_percent, '%')\n * console.log('Event Loop Lag:', metrics.event_loop_lag_ms, 'ms')\n * }, 5000)\n *\n * // Clean up when done\n * collector.stopMonitoring()\n * ```\n */\nexport class WorkerMetricsCollector {\n private readonly startTime: number\n private lastCpuUsage: NodeJS.CpuUsage\n private lastCpuTime: number\n private eventLoopHistogram: IntervalHistogram | null = null\n\n /**\n * Creates a new WorkerMetricsCollector instance.\n *\n * @param options - Configuration options\n */\n constructor(options: WorkerMetricsCollectorOptions = {}) {\n this.startTime = Date.now()\n this.lastCpuUsage = process.cpuUsage()\n this.lastCpuTime = performance.now()\n this.startEventLoopMonitoring(options.eventLoopResolutionMs ?? 20)\n }\n\n /**\n * Starts the event loop delay histogram monitoring.\n *\n * @param resolutionMs - Histogram resolution in milliseconds\n */\n private startEventLoopMonitoring(resolutionMs: number): void {\n // Sanitize resolution: must be a positive finite number, minimum 1ms\n const safeResolutionMs =\n Number.isFinite(resolutionMs) && resolutionMs > 0 ? Math.max(1, Math.floor(resolutionMs)) : 20 // Default fallback\n\n this.eventLoopHistogram = monitorEventLoopDelay({ resolution: safeResolutionMs })\n this.eventLoopHistogram.enable()\n }\n\n /**\n * Stops the event loop monitoring and releases resources.\n * Should be called when the collector is no longer needed.\n */\n public stopMonitoring(): void {\n if (this.eventLoopHistogram) {\n this.eventLoopHistogram.disable()\n this.eventLoopHistogram = null\n }\n }\n\n /**\n * Collects current worker metrics.\n *\n * This method calculates CPU usage since the last collection,\n * reads memory usage, and gets event loop delay statistics.\n * The event loop histogram is reset after each collection for\n * accurate per-interval measurements.\n *\n * @returns Current worker metrics snapshot\n */\n collect(): WorkerMetrics {\n const memoryUsage = process.memoryUsage()\n const cpuUsage = process.cpuUsage()\n const now = performance.now()\n\n // Calculate CPU percentage since last collection\n const cpuDelta = {\n user: cpuUsage.user - this.lastCpuUsage.user,\n system: cpuUsage.system - this.lastCpuUsage.system,\n }\n const timeDelta = (now - this.lastCpuTime) * 1000 // Convert ms to microseconds\n const cpuPercent = timeDelta > 0 ? ((cpuDelta.user + cpuDelta.system) / timeDelta) * 100 : 0\n\n // Update state for next collection\n this.lastCpuUsage = cpuUsage\n this.lastCpuTime = now\n\n // Get event loop lag from histogram (in nanoseconds, convert to ms)\n let eventLoopLagMs = 0\n if (this.eventLoopHistogram) {\n // Mean is in nanoseconds, convert to milliseconds\n eventLoopLagMs = this.eventLoopHistogram.mean / 1_000_000\n // Reset histogram for next collection interval\n this.eventLoopHistogram.reset()\n }\n\n return {\n memory_heap_used: memoryUsage.heapUsed,\n memory_heap_total: memoryUsage.heapTotal,\n memory_rss: memoryUsage.rss,\n memory_external: memoryUsage.external,\n cpu_user_micros: cpuUsage.user,\n cpu_system_micros: cpuUsage.system,\n cpu_percent: Math.min(cpuPercent, 100), // Cap at 100%\n event_loop_lag_ms: eventLoopLagMs,\n uptime_seconds: Math.floor((Date.now() - this.startTime) / 1000),\n timestamp_ms: Date.now(),\n runtime: 'node',\n }\n }\n}\n","import type { Meter, BatchObservableResult, Observable } from '@opentelemetry/api'\nimport { WorkerMetricsCollector } from './worker-metrics'\n\nexport interface WorkerGaugesOptions {\n workerId: string\n workerName?: string\n}\n\nlet registeredGauges = false\nlet metricsCollector: WorkerMetricsCollector | null = null\nlet registeredMeter: Meter | null = null\nlet registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null = null\nlet registeredObservables: Observable[] = []\n\nexport function registerWorkerGauges(meter: Meter, options: WorkerGaugesOptions): void {\n if (registeredGauges) {\n return\n }\n\n const { workerId, workerName } = options\n const baseAttributes = {\n 'worker.id': workerId,\n ...(workerName && { 'worker.name': workerName }),\n }\n\n metricsCollector = new WorkerMetricsCollector()\n\n const memoryHeapUsed = meter.createObservableGauge('iii.worker.memory.heap_used', {\n description: 'Worker heap memory used in bytes',\n unit: 'bytes',\n })\n\n const memoryHeapTotal = meter.createObservableGauge('iii.worker.memory.heap_total', {\n description: 'Worker total heap memory in bytes',\n unit: 'bytes',\n })\n\n const memoryRss = meter.createObservableGauge('iii.worker.memory.rss', {\n description: 'Worker resident set size in bytes',\n unit: 'bytes',\n })\n\n const memoryExternal = meter.createObservableGauge('iii.worker.memory.external', {\n description: 'Worker external memory in bytes',\n unit: 'bytes',\n })\n\n const cpuPercent = meter.createObservableGauge('iii.worker.cpu.percent', {\n description: 'Worker CPU usage percentage',\n unit: '%',\n })\n\n const cpuUserMicros = meter.createObservableGauge('iii.worker.cpu.user_micros', {\n description: 'Worker CPU user time in microseconds',\n unit: 'us',\n })\n\n const cpuSystemMicros = meter.createObservableGauge('iii.worker.cpu.system_micros', {\n description: 'Worker CPU system time in microseconds',\n unit: 'us',\n })\n\n const eventLoopLag = meter.createObservableGauge('iii.worker.event_loop.lag_ms', {\n description: 'Worker event loop lag in milliseconds',\n unit: 'ms',\n })\n\n const uptimeSeconds = meter.createObservableGauge('iii.worker.uptime_seconds', {\n description: 'Worker uptime in seconds',\n unit: 's',\n })\n\n const batchCallback = (observableResult: BatchObservableResult) => {\n if (!metricsCollector) return\n\n const metrics = metricsCollector.collect()\n\n if (metrics.memory_heap_used !== undefined) {\n observableResult.observe(memoryHeapUsed, metrics.memory_heap_used, baseAttributes)\n }\n if (metrics.memory_heap_total !== undefined) {\n observableResult.observe(memoryHeapTotal, metrics.memory_heap_total, baseAttributes)\n }\n if (metrics.memory_rss !== undefined) {\n observableResult.observe(memoryRss, metrics.memory_rss, baseAttributes)\n }\n if (metrics.memory_external !== undefined) {\n observableResult.observe(memoryExternal, metrics.memory_external, baseAttributes)\n }\n if (metrics.cpu_percent !== undefined) {\n observableResult.observe(cpuPercent, metrics.cpu_percent, baseAttributes)\n }\n if (metrics.cpu_user_micros !== undefined) {\n observableResult.observe(cpuUserMicros, metrics.cpu_user_micros, baseAttributes)\n }\n if (metrics.cpu_system_micros !== undefined) {\n observableResult.observe(cpuSystemMicros, metrics.cpu_system_micros, baseAttributes)\n }\n if (metrics.event_loop_lag_ms !== undefined) {\n observableResult.observe(eventLoopLag, metrics.event_loop_lag_ms, baseAttributes)\n }\n if (metrics.uptime_seconds !== undefined) {\n observableResult.observe(uptimeSeconds, metrics.uptime_seconds, baseAttributes)\n }\n }\n\n meter.addBatchObservableCallback(batchCallback, [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ])\n\n registeredMeter = meter\n registeredBatchCallback = batchCallback\n registeredObservables = [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ]\n\n registeredGauges = true\n}\n\nexport function stopWorkerGauges(): void {\n // Remove the batch observable callback before stopping\n if (registeredMeter && registeredBatchCallback) {\n registeredMeter.removeBatchObservableCallback(registeredBatchCallback, registeredObservables)\n }\n\n if (metricsCollector) {\n metricsCollector.stopMonitoring()\n metricsCollector = null\n }\n\n registeredMeter = null\n registeredBatchCallback = null\n registeredObservables = []\n registeredGauges = false\n}\n"],"mappings":"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"}
|
|
@@ -846,7 +846,7 @@ function safeStringify(value) {
|
|
|
846
846
|
const http = (callback) => {
|
|
847
847
|
return async (req) => {
|
|
848
848
|
const { response, ...request } = req;
|
|
849
|
-
|
|
849
|
+
return callback(request, {
|
|
850
850
|
status: (status_code) => response.sendMessage(JSON.stringify({
|
|
851
851
|
type: "set_status",
|
|
852
852
|
status_code
|
|
@@ -1242,4 +1242,4 @@ Object.defineProperty(exports, 'withSpan', {
|
|
|
1242
1242
|
return withSpan;
|
|
1243
1243
|
}
|
|
1244
1244
|
});
|
|
1245
|
-
//# sourceMappingURL=otel-worker-gauges-
|
|
1245
|
+
//# sourceMappingURL=otel-worker-gauges-wK5b_eLY.cjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"otel-worker-gauges-bbMcoYx_.cjs","names":["DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig","DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig","WebSocket","JsonTraceSerializer","ExportResultCode","metrics","JsonMetricsSerializer","ExportResultCode","JsonLogsSerializer","ExportResultCode","trace","carrier: Record<string, string>","context","propagation","entries: Record<string, string>","originalFetch: typeof globalThis.fetch | null","host: string | undefined","scheme: string | undefined","path: string | undefined","port: number | undefined","query: string | undefined","spanAttributes: Record<string, string | number>","tracer","SpanKind","context","carrier: Record<string, string>","SpanStatusCode","sharedConnection: SharedEngineConnection | null","tracerProvider: NodeTracerProvider | null","meterProvider: MeterProvider | null","loggerProvider: LoggerProvider | null","tracer: Tracer | null","meter: Meter | null","logger: Logger | null","serviceName: string","resourceAttributes: Record<string, string>","ATTR_SERVICE_NAME","Resource","NodeTracerProvider","BatchSpanProcessor","CompositePropagator","W3CTraceContextPropagator","W3CBaggagePropagator","trace","MeterProvider","PeriodicExportingMetricReader","LoggerProvider","BatchLogRecordProcessor","noopSpan: Span","context","SpanKind","SpanStatusCode","performance","metricsCollector: WorkerMetricsCollector | null","registeredMeter: Meter | null","registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null","registeredObservables: Observable[]","meter","metrics"],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/connection.ts","../src/telemetry-system/span-exporter.ts","../src/telemetry-system/metrics-exporter.ts","../src/telemetry-system/log-exporter.ts","../src/telemetry-system/context.ts","../src/telemetry-system/fetch-instrumentation.ts","../src/telemetry-system/index.ts","../src/utils.ts","../src/worker-metrics.ts","../src/otel-worker-gauges.ts"],"sourcesContent":["/**\n * Constants for the III module.\n */\n\n/** Engine function paths for internal operations */\nexport const EngineFunctions = {\n LIST_FUNCTIONS: 'engine::functions::list',\n LIST_WORKERS: 'engine::workers::list',\n REGISTER_WORKER: 'engine::workers::register',\n} as const\n\n/** Engine trigger types */\nexport const EngineTriggers = {\n FUNCTIONS_AVAILABLE: 'engine::functions-available',\n LOG: 'log',\n} as const\n\n/** Log function paths */\nexport const LogFunctions = {\n INFO: 'engine::log::info',\n WARN: 'engine::log::warn',\n ERROR: 'engine::log::error',\n DEBUG: 'engine::log::debug',\n} as const\n\n/** Connection state for the III WebSocket */\nexport type IIIConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface IIIReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Default invocation timeout in milliseconds */\nexport const DEFAULT_INVOCATION_TIMEOUT_MS = 30000\n","/**\n * Types, interfaces, and constants for the OpenTelemetry module.\n */\n\nimport type { Instrumentation } from '@opentelemetry/instrumentation'\n\n// Semantic convention constants for compatibility across versions\nexport const ATTR_SERVICE_VERSION = 'service.version'\nexport const ATTR_SERVICE_NAMESPACE = 'service.namespace'\nexport const ATTR_SERVICE_INSTANCE_ID = 'service.instance.id'\n\n/** Magic prefixes for binary frames over WebSocket */\nexport const PREFIX_TRACES = 'OTLP'\nexport const PREFIX_METRICS = 'MTRC'\nexport const PREFIX_LOGS = 'LOGS'\n\n/** Connection state for the shared WebSocket */\nexport type ConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface ReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Configuration for OpenTelemetry initialization. */\nexport interface OtelConfig {\n /** Whether OpenTelemetry export is enabled. Defaults to true. Set to false or OTEL_ENABLED=false/0/no/off to disable. */\n enabled?: boolean\n /** The service name to report. Defaults to OTEL_SERVICE_NAME or \"iii-node\". */\n serviceName?: string\n /** The service version to report. Defaults to SERVICE_VERSION env var or \"unknown\". */\n serviceVersion?: string\n /** The service namespace to report. Defaults to SERVICE_NAMESPACE env var. */\n serviceNamespace?: string\n /** The service instance ID to report. Defaults to SERVICE_INSTANCE_ID env var or auto-generated UUID. */\n serviceInstanceId?: string\n /** III Engine WebSocket URL. Defaults to III_BRIDGE_URL or \"ws://localhost:49134\". */\n engineWsUrl?: string\n /** OpenTelemetry instrumentations to register (e.g., PrismaInstrumentation). */\n instrumentations?: Instrumentation[]\n /** Whether OpenTelemetry metrics export is enabled. Defaults to true. Set to false or OTEL_METRICS_ENABLED=false/0/no/off to disable. */\n metricsEnabled?: boolean\n /** Metrics export interval in milliseconds. Defaults to 60000 (60 seconds). */\n metricsExportIntervalMs?: number\n /** Whether to auto-instrument globalThis.fetch calls. Defaults to true. Works on Node.js, Bun, and Deno. Set to false to disable. */\n fetchInstrumentationEnabled?: boolean\n /** Optional reconnection configuration for the WebSocket connection. */\n reconnectionConfig?: Partial<ReconnectionConfig>\n}\n\n/** Default configuration values for OpenTelemetry initialization. */\nexport const DEFAULT_OTEL_CONFIG = {\n enabled: true,\n serviceName: 'iii-node',\n serviceVersion: 'unknown',\n engineWsUrl: 'ws://localhost:49134',\n metricsEnabled: true,\n metricsExportIntervalMs: 60000,\n fetchInstrumentationEnabled: true,\n} as const satisfies Partial<OtelConfig>\n\n/** Parse a boolean environment variable, recognizing 'false', '0', 'no', 'off' as false. */\nexport function parseBoolEnv(value: string | undefined, defaultValue: boolean): boolean {\n if (value === undefined) return defaultValue\n const lower = value.toLowerCase()\n return lower !== 'false' && lower !== '0' && lower !== 'no' && lower !== 'off'\n}\n","/**\n * Shared WebSocket connection for OpenTelemetry exporters.\n */\n\nimport { WebSocket } from 'ws'\nimport { type ConnectionState, type ReconnectionConfig, DEFAULT_RECONNECTION_CONFIG } from './types'\n\n/**\n * Shared WebSocket connection for all OTEL exporters (traces, metrics, logs).\n * Uses a single connection with message prefixes to identify signal type.\n */\nexport class SharedEngineConnection {\n private static readonly MAX_PENDING_MESSAGES = 1000\n private ws: WebSocket | null = null\n private wsUrl: string\n private connecting = false\n private shuttingDown = false\n private pendingMessages: Array<{ frame: Buffer; callback?: (err?: Error) => void }> = []\n private reconnectAttempt = 0\n private reconnectTimeout: NodeJS.Timeout | null = null\n private config: ReconnectionConfig\n private state: ConnectionState = 'disconnected'\n private onConnectedCallbacks: Array<() => void> = []\n\n constructor(wsUrl: string, config: Partial<ReconnectionConfig> = {}) {\n this.wsUrl = wsUrl\n this.config = { ...DEFAULT_RECONNECTION_CONFIG, ...config }\n this.connect()\n }\n\n private connect(): void {\n if (this.connecting || (this.ws && this.ws.readyState === WebSocket.OPEN)) {\n return\n }\n\n this.connecting = true\n this.state = 'connecting'\n\n try {\n this.ws = new WebSocket(this.wsUrl)\n\n this.ws.on('open', () => {\n this.connecting = false\n this.state = 'connected'\n console.log(`[OTel] Connected to engine at ${this.wsUrl}`)\n\n // Reset reconnection state\n if (this.reconnectAttempt > 0) {\n console.log('[OTel] Successfully reconnected')\n }\n this.reconnectAttempt = 0\n\n // Clear any pending reconnect timer to prevent race conditions\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n // Flush pending messages\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n for (const { frame, callback } of pending) {\n this.ws?.send(frame, err => callback?.(err))\n }\n\n // Notify callbacks\n for (const cb of this.onConnectedCallbacks) {\n cb()\n }\n })\n\n this.ws.on('close', () => {\n this.connecting = false\n this.ws = null\n\n // Skip reconnection if we're shutting down intentionally\n if (this.shuttingDown) {\n this.state = 'disconnected'\n console.log('[OTel] Connection closed during shutdown')\n return\n }\n\n this.state = 'disconnected'\n console.log('[OTel] Disconnected from engine, will reconnect...')\n this.scheduleReconnect()\n })\n\n this.ws.on('error', err => {\n this.connecting = false\n\n // Skip error handling if we're shutting down intentionally\n if (this.shuttingDown) {\n return\n }\n\n console.error('[OTel] WebSocket error:', err.message)\n })\n } catch (err) {\n this.connecting = false\n console.error('[OTel] Connection failed:', err)\n this.scheduleReconnect()\n }\n }\n\n private scheduleReconnect(): void {\n if (this.config.maxRetries !== -1 && this.reconnectAttempt >= this.config.maxRetries) {\n this.state = 'failed'\n console.error(`[OTel] Max retries (${this.config.maxRetries}) reached, giving up`)\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const failedError = new Error('Connection failed after max retries')\n for (const { callback } of pending) {\n callback?.(failedError)\n }\n return\n }\n\n if (this.reconnectTimeout) {\n return // Already scheduled\n }\n\n const exponentialDelay =\n this.config.initialDelayMs * this.config.backoffMultiplier ** this.reconnectAttempt\n const cappedDelay = Math.min(exponentialDelay, this.config.maxDelayMs)\n const jitter = cappedDelay * this.config.jitterFactor * (2 * Math.random() - 1)\n const delay = Math.max(0, Math.floor(cappedDelay + jitter))\n\n this.state = 'reconnecting'\n console.log(`[OTel] Reconnecting in ${delay}ms (attempt ${this.reconnectAttempt + 1})...`)\n\n this.reconnectTimeout = setTimeout(() => {\n this.reconnectTimeout = null\n this.reconnectAttempt++\n this.connect()\n }, delay)\n }\n\n /**\n * Send a message with a signal prefix.\n */\n send(prefix: string, data: Uint8Array, callback?: (err?: Error) => void): void {\n const prefixBytes = Buffer.from(prefix, 'utf-8')\n const frame = Buffer.concat([prefixBytes, Buffer.from(data)])\n\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send(frame, callback)\n } else {\n // Queue for later with bounded size to prevent memory exhaustion\n if (this.pendingMessages.length >= SharedEngineConnection.MAX_PENDING_MESSAGES) {\n console.warn('[OTel] Pending message queue full, dropping oldest message')\n const dropped = this.pendingMessages.shift()\n dropped?.callback?.(new Error('Message dropped due to queue overflow'))\n }\n this.pendingMessages.push({ frame, callback })\n this.connect()\n }\n }\n\n /**\n * Register a callback to be called when connected.\n */\n onConnected(callback: () => void): void {\n this.onConnectedCallbacks.push(callback)\n if (this.state === 'connected') {\n callback()\n }\n }\n\n /**\n * Get the current connection state.\n */\n getState(): ConnectionState {\n return this.state\n }\n\n /**\n * Shutdown the connection.\n */\n async shutdown(): Promise<void> {\n // Set shutdown flag to prevent reconnection attempts\n this.shuttingDown = true\n\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const shutdownError = new Error('Connection shutdown before message could be sent')\n for (const { callback } of pending) {\n callback?.(shutdownError)\n }\n this.onConnectedCallbacks = []\n this.state = 'disconnected'\n }\n}\n","/**\n * Span exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { ReadableSpan, SpanExporter } from '@opentelemetry/sdk-trace-base'\nimport { JsonTraceSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_TRACES } from './types'\n\n/**\n * Span exporter using the shared WebSocket connection.\n */\nexport class EngineSpanExporter implements SpanExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n spans: ReadableSpan[]\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { spans, resultCallback } of pending) {\n this.sendExport(spans, resultCallback)\n }\n }\n\n private sendExport(spans: ReadableSpan[], resultCallback?: (result: ExportResult) => void): void {\n try {\n const serialized = JsonTraceSerializer.serializeRequest(spans)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_TRACES, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send spans:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting spans:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineSpanExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Spans export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ spans, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(spans, resultCallback)\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(spans, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op, spans are sent immediately\n }\n}\n","/**\n * Metrics exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { PushMetricExporter, ResourceMetrics } from '@opentelemetry/sdk-metrics'\nimport { JsonMetricsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_METRICS } from './types'\n\n/**\n * Metrics exporter using the shared WebSocket connection.\n */\nexport class EngineMetricsExporter implements PushMetricExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n metrics: ResourceMetrics\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { metrics, resultCallback } of pending) {\n this.sendExport(metrics, resultCallback)\n }\n }\n\n private sendExport(\n metricsData: ResourceMetrics,\n resultCallback?: (result: ExportResult) => void,\n ): void {\n try {\n const serialized = JsonMetricsSerializer.serializeRequest(metricsData)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_METRICS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send metrics:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting metrics:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(\n metricsData: ResourceMetrics,\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineMetricsExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Metrics export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ metrics: metricsData, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(metricsData, resultCallback)\n }\n\n export(metrics: ResourceMetrics, resultCallback: (result: ExportResult) => void): void {\n this.doExport(metrics, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op\n }\n}\n","/**\n * Log exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { LogRecordExporter, ReadableLogRecord } from '@opentelemetry/sdk-logs'\nimport { JsonLogsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_LOGS } from './types'\n\n/**\n * Log exporter using the shared WebSocket connection.\n */\nexport class EngineLogExporter implements LogRecordExporter {\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n logs: ReadableLogRecord[]\n callback: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { logs, callback } of pending) {\n this.doExport(logs, callback)\n }\n }\n\n private doExport(\n logs: ReadableLogRecord[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n this.pendingExports.push({ logs, callback: resultCallback })\n return\n }\n\n try {\n const serialized = JsonLogsSerializer.serializeRequest(logs)\n if (!serialized) {\n resultCallback({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_LOGS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send logs:', err.message)\n resultCallback({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting logs:', err)\n resultCallback({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n export(logs: ReadableLogRecord[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(logs, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n for (const { callback } of this.pendingExports) {\n callback({ code: ExportResultCode.FAILED, error: new Error('Exporter shutdown') })\n }\n this.pendingExports = []\n }\n}\n","/**\n * Trace context and baggage propagation utilities.\n */\n\nimport { trace, context, propagation, type Context } from '@opentelemetry/api'\n\n/**\n * Extract the current trace ID from the active span context.\n */\nexport function currentTraceId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.traceId && spanContext.traceId !== '00000000000000000000000000000000') {\n return spanContext.traceId\n }\n }\n return undefined\n}\n\n/**\n * Extract the current span ID from the active span context.\n */\nexport function currentSpanId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.spanId && spanContext.spanId !== '0000000000000000') {\n return spanContext.spanId\n }\n }\n return undefined\n}\n\n/**\n * Inject the current trace context into a W3C traceparent header string.\n */\nexport function injectTraceparent(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.traceparent\n}\n\n/**\n * Extract a trace context from a W3C traceparent header string.\n */\nexport function extractTraceparent(traceparent: string): Context {\n const carrier: Record<string, string> = { traceparent }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Inject the current baggage into a W3C baggage header string.\n */\nexport function injectBaggage(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.baggage\n}\n\n/**\n * Extract baggage from a W3C baggage header string.\n */\nexport function extractBaggage(baggage: string): Context {\n const carrier: Record<string, string> = { baggage }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Extract both trace context and baggage from their respective headers.\n */\nexport function extractContext(traceparent?: string, baggage?: string): Context {\n const carrier: Record<string, string> = {}\n if (traceparent) {\n carrier.traceparent = traceparent\n }\n if (baggage) {\n carrier.baggage = baggage\n }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Get a baggage entry from the current context.\n */\nexport function getBaggageEntry(key: string): string | undefined {\n const bag = propagation.getBaggage(context.active())\n return bag?.getEntry(key)?.value\n}\n\n/**\n * Set a baggage entry in the current context.\n */\nexport function setBaggageEntry(key: string, value: string): Context {\n let bag = propagation.getBaggage(context.active()) ?? propagation.createBaggage()\n bag = bag.setEntry(key, { value })\n return propagation.setBaggage(context.active(), bag)\n}\n\n/**\n * Remove a baggage entry from the current context.\n */\nexport function removeBaggageEntry(key: string): Context {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return context.active()\n }\n const newBag = bag.removeEntry(key)\n return propagation.setBaggage(context.active(), newBag)\n}\n\n/**\n * Get all baggage entries from the current context.\n */\nexport function getAllBaggage(): Record<string, string> {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return {}\n }\n const entries: Record<string, string> = {}\n for (const [key, entry] of bag.getAllEntries()) {\n entries[key] = entry.value\n }\n return entries\n}\n","/**\n * Global fetch auto-instrumentation for the III Node SDK.\n *\n * Patches globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n * Works on all runtimes (Bun, Node.js, Deno) unlike UndiciInstrumentation\n * which only works when fetch is backed by Node.js's undici.\n */\n\nimport { type Tracer, SpanKind, SpanStatusCode, context, propagation } from '@opentelemetry/api'\n\nconst textEncoder = new TextEncoder()\n\nfunction getBodyByteSize(body: unknown): number | undefined {\n if (body == null) return undefined\n if (typeof body === 'string') return textEncoder.encode(body).byteLength\n if (body instanceof ArrayBuffer) return body.byteLength\n if (ArrayBuffer.isView(body)) return body.byteLength\n if (body instanceof Blob) return body.size\n if (body instanceof URLSearchParams) return new TextEncoder().encode(body.toString()).byteLength\n return undefined\n}\n\nconst SAFE_REQUEST_HEADERS = ['content-type', 'accept'] as const\nconst SAFE_RESPONSE_HEADERS = ['content-type'] as const\n\nlet originalFetch: typeof globalThis.fetch | null = null\n\n/**\n * Patch globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n */\nexport function patchGlobalFetch(tracer: Tracer): void {\n if (originalFetch) return\n\n originalFetch = globalThis.fetch\n const capturedFetch = originalFetch\n\n globalThis.fetch = async (\n input: string | URL | Request,\n init?: RequestInit,\n ): Promise<Response> => {\n const url = input instanceof Request ? input.url : String(input)\n const method = (init?.method ?? (input instanceof Request ? input.method : 'GET')).toUpperCase()\n\n let host: string | undefined\n let scheme: string | undefined\n let path: string | undefined\n let port: number | undefined\n let query: string | undefined\n try {\n const parsed = new URL(url)\n host = parsed.hostname\n scheme = parsed.protocol.replace(':', '')\n path = parsed.pathname\n port = parsed.port ? parseInt(parsed.port, 10) : undefined\n query = parsed.search ? parsed.search.slice(1) : undefined\n } catch {\n // relative URL or invalid — skip host/scheme/path attributes\n }\n\n const spanAttributes: Record<string, string | number> = {\n 'http.request.method': method,\n 'url.full': url,\n }\n if (host) spanAttributes['server.address'] = host\n if (scheme) {\n spanAttributes['url.scheme'] = scheme\n spanAttributes['network.protocol.name'] = 'http'\n }\n if (path) spanAttributes['url.path'] = path\n if (port) spanAttributes['server.port'] = port\n if (query) spanAttributes['url.query'] = query\n\n const spanName = path ? `${method} ${path}` : method\n\n return tracer.startActiveSpan(\n spanName,\n { kind: SpanKind.CLIENT, attributes: spanAttributes },\n context.active(),\n async span => {\n try {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n\n const headers = new Headers(\n init?.headers ?? (input instanceof Request ? input.headers : undefined),\n )\n for (const [key, value] of Object.entries(carrier)) {\n headers.set(key, value)\n }\n\n for (const name of SAFE_REQUEST_HEADERS) {\n const value = headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.request.header.${name}`, value)\n }\n }\n\n const requestBody = init?.body ?? (input instanceof Request ? input.body : undefined)\n const requestBodySize = getBodyByteSize(requestBody)\n if (requestBodySize !== undefined) {\n span.setAttribute('http.request.body.size', requestBodySize)\n }\n\n const response = await capturedFetch(input, { ...init, headers })\n\n span.setAttribute('http.response.status_code', response.status)\n\n const contentLength = response.headers.get('content-length')\n if (contentLength !== null) {\n const size = parseInt(contentLength, 10)\n if (!Number.isNaN(size)) {\n span.setAttribute('http.response.body.size', size)\n }\n }\n\n for (const name of SAFE_RESPONSE_HEADERS) {\n const value = response.headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.response.header.${name}`, value)\n }\n }\n\n if (response.status >= 400) {\n span.setAttribute('error.type', String(response.status))\n span.setStatus({ code: SpanStatusCode.ERROR })\n } else {\n span.setStatus({ code: SpanStatusCode.OK })\n }\n\n return response\n } catch (error) {\n span.setAttribute('error.type', (error as Error).name ?? 'Error')\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n }\n}\n\n/**\n * Restore globalThis.fetch to its original implementation.\n */\nexport function unpatchGlobalFetch(): void {\n if (originalFetch) {\n globalThis.fetch = originalFetch\n originalFetch = null\n }\n}\n","/**\n * OpenTelemetry initialization for the III Node SDK.\n *\n * This module provides trace, metrics, and log export to the III Engine\n * via a shared WebSocket connection using OTLP JSON format.\n */\n\nimport { Resource } from '@opentelemetry/resources'\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions'\nimport { randomUUID } from 'node:crypto'\nimport {\n trace,\n context,\n propagation,\n SpanKind,\n SpanStatusCode,\n metrics,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n} from '@opentelemetry/api'\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base'\nimport { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics'\nimport {\n CompositePropagator,\n W3CBaggagePropagator,\n W3CTraceContextPropagator,\n} from '@opentelemetry/core'\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node'\nimport { registerInstrumentations } from '@opentelemetry/instrumentation'\nimport { LoggerProvider, BatchLogRecordProcessor } from '@opentelemetry/sdk-logs'\nimport { type Logger, SeverityNumber } from '@opentelemetry/api-logs'\n\nimport {\n type OtelConfig,\n DEFAULT_OTEL_CONFIG,\n parseBoolEnv,\n ATTR_SERVICE_VERSION,\n ATTR_SERVICE_NAMESPACE,\n ATTR_SERVICE_INSTANCE_ID,\n} from './types'\nimport { SharedEngineConnection } from './connection'\nimport { EngineSpanExporter, EngineMetricsExporter, EngineLogExporter } from './exporters'\nimport { extractTraceparent } from './context'\nimport { patchGlobalFetch, unpatchGlobalFetch } from './fetch-instrumentation'\n\n// Re-export everything from submodules\nexport * from './types'\nexport * from './context'\n\n// Module-level state\nlet sharedConnection: SharedEngineConnection | null = null\nlet tracerProvider: NodeTracerProvider | null = null\nlet meterProvider: MeterProvider | null = null\nlet loggerProvider: LoggerProvider | null = null\nlet tracer: Tracer | null = null\nlet meter: Meter | null = null\nlet logger: Logger | null = null\nlet serviceName: string = 'iii-node-iii'\n\n/**\n * Initialize OpenTelemetry with the given configuration.\n * This should be called once at application startup.\n */\nexport function initOtel(config: OtelConfig = {}): void {\n const enabled =\n config.enabled ?? parseBoolEnv(process.env.OTEL_ENABLED, DEFAULT_OTEL_CONFIG.enabled)\n\n if (!enabled) {\n console.debug(\n '[OTel] OpenTelemetry is disabled. To enable, remove OTEL_ENABLED=false or set enabled: true in config.',\n )\n return\n }\n\n // Configure service identity\n serviceName =\n config.serviceName ?? process.env.OTEL_SERVICE_NAME ?? DEFAULT_OTEL_CONFIG.serviceName\n const serviceVersion =\n config.serviceVersion ?? process.env.SERVICE_VERSION ?? DEFAULT_OTEL_CONFIG.serviceVersion\n const serviceNamespace = config.serviceNamespace ?? process.env.SERVICE_NAMESPACE\n const serviceInstanceId =\n config.serviceInstanceId ?? process.env.SERVICE_INSTANCE_ID ?? randomUUID()\n const engineWsUrl =\n config.engineWsUrl ?? process.env.III_BRIDGE_URL ?? DEFAULT_OTEL_CONFIG.engineWsUrl\n\n // Build resource attributes\n const resourceAttributes: Record<string, string> = {\n [ATTR_SERVICE_NAME]: serviceName,\n [ATTR_SERVICE_VERSION]: serviceVersion,\n [ATTR_SERVICE_INSTANCE_ID]: serviceInstanceId,\n }\n if (serviceNamespace) {\n resourceAttributes[ATTR_SERVICE_NAMESPACE] = serviceNamespace\n }\n const resource = new Resource(resourceAttributes)\n\n // Create shared WebSocket connection\n sharedConnection = new SharedEngineConnection(engineWsUrl, config.reconnectionConfig)\n\n // Initialize tracer\n const spanExporter = new EngineSpanExporter(sharedConnection)\n tracerProvider = new NodeTracerProvider({\n resource,\n spanProcessors: [new BatchSpanProcessor(spanExporter)],\n })\n\n // Register W3C Trace Context and Baggage propagators\n propagation.setGlobalPropagator(\n new CompositePropagator({\n propagators: [new W3CTraceContextPropagator(), new W3CBaggagePropagator()],\n }),\n )\n\n tracerProvider.register()\n tracer = trace.getTracer(serviceName)\n\n console.debug(`[OTel] Traces initialized: engine=${engineWsUrl}, service=${serviceName}`)\n\n // Initialize metrics (enabled by default, opt-out via config or env)\n const metricsEnabled =\n config.metricsEnabled ??\n parseBoolEnv(process.env.OTEL_METRICS_ENABLED, DEFAULT_OTEL_CONFIG.metricsEnabled)\n\n if (metricsEnabled) {\n const metricsExporter = new EngineMetricsExporter(sharedConnection)\n const exportIntervalMs =\n config.metricsExportIntervalMs ?? DEFAULT_OTEL_CONFIG.metricsExportIntervalMs\n\n const metricReader = new PeriodicExportingMetricReader({\n exporter: metricsExporter,\n exportIntervalMillis: exportIntervalMs,\n })\n\n meterProvider = new MeterProvider({\n resource,\n readers: [metricReader],\n })\n\n metrics.setGlobalMeterProvider(meterProvider)\n meter = meterProvider.getMeter(serviceName)\n\n console.debug(`[OTel] Metrics initialized: interval=${exportIntervalMs}ms`)\n }\n\n // Register user-provided instrumentations AFTER providers are set up\n const instrumentations = [...(config.instrumentations ?? [])]\n if (instrumentations.length > 0) {\n registerInstrumentations({\n instrumentations,\n tracerProvider,\n meterProvider: meterProvider ?? undefined,\n })\n console.debug(`[OTel] Instrumentations registered: ${instrumentations.length} total`)\n }\n\n // Patch global fetch for runtime-agnostic HTTP client tracing (works on Bun, Node.js, Deno)\n const fetchEnabled =\n config.fetchInstrumentationEnabled ?? DEFAULT_OTEL_CONFIG.fetchInstrumentationEnabled\n\n if (fetchEnabled) {\n patchGlobalFetch(tracer)\n console.debug('[OTel] Global fetch instrumentation enabled')\n }\n\n // Initialize logs (always enabled when OTEL is enabled)\n const logExporter = new EngineLogExporter(sharedConnection)\n loggerProvider = new LoggerProvider({ resource })\n loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter))\n logger = loggerProvider.getLogger(serviceName)\n\n console.debug('[OTel] Logs initialized')\n}\n\n/**\n * Shutdown OpenTelemetry, flushing any pending data.\n */\nexport async function shutdownOtel(): Promise<void> {\n if (tracerProvider) {\n await tracerProvider.forceFlush()\n await tracerProvider.shutdown()\n tracerProvider = null\n }\n\n if (meterProvider) {\n await meterProvider.forceFlush()\n await meterProvider.shutdown()\n meterProvider = null\n }\n\n if (loggerProvider) {\n await loggerProvider.forceFlush()\n await loggerProvider.shutdown()\n loggerProvider = null\n }\n\n if (sharedConnection) {\n await sharedConnection.shutdown()\n sharedConnection = null\n }\n\n unpatchGlobalFetch()\n\n tracer = null\n meter = null\n logger = null\n}\n\n/**\n * Get the OpenTelemetry tracer instance.\n */\nexport function getTracer(): Tracer | null {\n return tracer\n}\n\n/**\n * Get the OpenTelemetry meter instance.\n */\nexport function getMeter(): Meter | null {\n return meter\n}\n\n/**\n * Get the OpenTelemetry logger instance.\n */\nexport function getLogger(): Logger | null {\n return logger\n}\n\n/**\n * Start a new span with the given name and run the callback within it.\n */\nexport async function withSpan<T>(\n name: string,\n options: { kind?: SpanKind; traceparent?: string },\n fn: (span: Span) => Promise<T>,\n): Promise<T> {\n if (!tracer) {\n // Execute without span context when tracer is not initialized\n // Provide a no-op span to avoid runtime errors if fn calls span methods\n const noopSpan: Span = {\n spanContext: () => ({ traceId: '', spanId: '', traceFlags: 0 }),\n setAttribute: () => noopSpan,\n setAttributes: () => noopSpan,\n addEvent: () => noopSpan,\n addLink: () => noopSpan,\n setStatus: () => noopSpan,\n updateName: () => noopSpan,\n end: () => {},\n isRecording: () => false,\n recordException: () => {},\n addLinks: () => noopSpan,\n }\n return fn(noopSpan)\n }\n\n const parentContext = options.traceparent\n ? extractTraceparent(options.traceparent)\n : context.active()\n\n return tracer.startActiveSpan(\n name,\n { kind: options.kind ?? SpanKind.INTERNAL },\n parentContext,\n async span => {\n try {\n const result = await fn(span)\n span.setStatus({ code: SpanStatusCode.OK })\n return result\n } catch (error) {\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n}\n\n// Re-export OTEL types for convenience\nexport {\n SpanKind,\n SpanStatusCode,\n SeverityNumber,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n type Logger,\n}\n","import type { StreamChannelRef } from './iii-types'\nimport type { HttpRequest, HttpResponse, InternalHttpRequest } from './types'\n\n/**\n * Safely stringify a value, handling circular references, BigInt, and other edge cases.\n * Returns \"[unserializable]\" if serialization fails for any reason.\n */\nexport function safeStringify(value: unknown): string {\n const seen = new WeakSet<object>()\n\n try {\n return JSON.stringify(value, (_key, val) => {\n // Handle BigInt\n if (typeof val === 'bigint') {\n return val.toString()\n }\n\n // Handle circular references\n if (val !== null && typeof val === 'object') {\n if (seen.has(val)) {\n return '[Circular]'\n }\n seen.add(val)\n }\n\n return val\n })\n } catch {\n return '[unserializable]'\n }\n}\n\nexport const http = (callback: (req: HttpRequest, res: HttpResponse) => Promise<void>) => {\n return async (req: InternalHttpRequest) => {\n const { response, ...request } = req\n\n const httpResponse: HttpResponse = {\n status: (status_code: number) =>\n response.sendMessage(JSON.stringify({ type: 'set_status', status_code })),\n headers: (headers: Record<string, string>) =>\n response.sendMessage(JSON.stringify({ type: 'set_headers', headers })),\n stream: response.stream,\n close: () => response.close(),\n }\n\n await callback(request, httpResponse)\n }\n}\n\nexport const isChannelRef = (value: unknown): value is StreamChannelRef => {\n if (typeof value !== 'object' || value === null) return false\n const maybe = value as Partial<StreamChannelRef>\n return (\n typeof maybe.channel_id === 'string' &&\n typeof maybe.access_key === 'string' &&\n (maybe.direction === 'read' || maybe.direction === 'write')\n )\n}\n","/**\n * Worker metrics collection for the III Node SDK.\n *\n * Collects CPU, memory, and event loop metrics for worker health monitoring.\n * Uses the Node.js built-in `monitorEventLoopDelay` API for accurate\n * event loop lag measurements.\n */\n\nimport { type IntervalHistogram, monitorEventLoopDelay, performance } from 'node:perf_hooks'\n\n/**\n * Worker metrics data structure used internally for OTEL metric collection.\n */\nexport type WorkerMetrics = {\n memory_heap_used?: number\n memory_heap_total?: number\n memory_rss?: number\n memory_external?: number\n cpu_user_micros?: number\n cpu_system_micros?: number\n cpu_percent?: number\n event_loop_lag_ms?: number\n uptime_seconds?: number\n timestamp_ms: number\n runtime: string\n}\n\n/**\n * Configuration options for the WorkerMetricsCollector.\n */\nexport interface WorkerMetricsCollectorOptions {\n /**\n * Event loop delay histogram resolution in milliseconds.\n * Lower values provide more accurate measurements but use more resources.\n * @default 20\n */\n eventLoopResolutionMs?: number\n}\n\n/**\n * Collects worker resource metrics including CPU, memory, and event loop lag.\n *\n * Uses the Node.js `monitorEventLoopDelay` API for high-precision event loop\n * delay measurements instead of manual `setImmediate` timing.\n *\n * @example\n * ```typescript\n * const collector = new WorkerMetricsCollector()\n *\n * // Collect metrics periodically\n * setInterval(() => {\n * const metrics = collector.collect()\n * console.log('CPU:', metrics.cpu_percent, '%')\n * console.log('Event Loop Lag:', metrics.event_loop_lag_ms, 'ms')\n * }, 5000)\n *\n * // Clean up when done\n * collector.stopMonitoring()\n * ```\n */\nexport class WorkerMetricsCollector {\n private readonly startTime: number\n private lastCpuUsage: NodeJS.CpuUsage\n private lastCpuTime: number\n private eventLoopHistogram: IntervalHistogram | null = null\n\n /**\n * Creates a new WorkerMetricsCollector instance.\n *\n * @param options - Configuration options\n */\n constructor(options: WorkerMetricsCollectorOptions = {}) {\n this.startTime = Date.now()\n this.lastCpuUsage = process.cpuUsage()\n this.lastCpuTime = performance.now()\n this.startEventLoopMonitoring(options.eventLoopResolutionMs ?? 20)\n }\n\n /**\n * Starts the event loop delay histogram monitoring.\n *\n * @param resolutionMs - Histogram resolution in milliseconds\n */\n private startEventLoopMonitoring(resolutionMs: number): void {\n // Sanitize resolution: must be a positive finite number, minimum 1ms\n const safeResolutionMs =\n Number.isFinite(resolutionMs) && resolutionMs > 0 ? Math.max(1, Math.floor(resolutionMs)) : 20 // Default fallback\n\n this.eventLoopHistogram = monitorEventLoopDelay({ resolution: safeResolutionMs })\n this.eventLoopHistogram.enable()\n }\n\n /**\n * Stops the event loop monitoring and releases resources.\n * Should be called when the collector is no longer needed.\n */\n public stopMonitoring(): void {\n if (this.eventLoopHistogram) {\n this.eventLoopHistogram.disable()\n this.eventLoopHistogram = null\n }\n }\n\n /**\n * Collects current worker metrics.\n *\n * This method calculates CPU usage since the last collection,\n * reads memory usage, and gets event loop delay statistics.\n * The event loop histogram is reset after each collection for\n * accurate per-interval measurements.\n *\n * @returns Current worker metrics snapshot\n */\n collect(): WorkerMetrics {\n const memoryUsage = process.memoryUsage()\n const cpuUsage = process.cpuUsage()\n const now = performance.now()\n\n // Calculate CPU percentage since last collection\n const cpuDelta = {\n user: cpuUsage.user - this.lastCpuUsage.user,\n system: cpuUsage.system - this.lastCpuUsage.system,\n }\n const timeDelta = (now - this.lastCpuTime) * 1000 // Convert ms to microseconds\n const cpuPercent = timeDelta > 0 ? ((cpuDelta.user + cpuDelta.system) / timeDelta) * 100 : 0\n\n // Update state for next collection\n this.lastCpuUsage = cpuUsage\n this.lastCpuTime = now\n\n // Get event loop lag from histogram (in nanoseconds, convert to ms)\n let eventLoopLagMs = 0\n if (this.eventLoopHistogram) {\n // Mean is in nanoseconds, convert to milliseconds\n eventLoopLagMs = this.eventLoopHistogram.mean / 1_000_000\n // Reset histogram for next collection interval\n this.eventLoopHistogram.reset()\n }\n\n return {\n memory_heap_used: memoryUsage.heapUsed,\n memory_heap_total: memoryUsage.heapTotal,\n memory_rss: memoryUsage.rss,\n memory_external: memoryUsage.external,\n cpu_user_micros: cpuUsage.user,\n cpu_system_micros: cpuUsage.system,\n cpu_percent: Math.min(cpuPercent, 100), // Cap at 100%\n event_loop_lag_ms: eventLoopLagMs,\n uptime_seconds: Math.floor((Date.now() - this.startTime) / 1000),\n timestamp_ms: Date.now(),\n runtime: 'node',\n }\n }\n}\n","import type { Meter, BatchObservableResult, Observable } from '@opentelemetry/api'\nimport { WorkerMetricsCollector } from './worker-metrics'\n\nexport interface WorkerGaugesOptions {\n workerId: string\n workerName?: string\n}\n\nlet registeredGauges = false\nlet metricsCollector: WorkerMetricsCollector | null = null\nlet registeredMeter: Meter | null = null\nlet registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null = null\nlet registeredObservables: Observable[] = []\n\nexport function registerWorkerGauges(meter: Meter, options: WorkerGaugesOptions): void {\n if (registeredGauges) {\n return\n }\n\n const { workerId, workerName } = options\n const baseAttributes = {\n 'worker.id': workerId,\n ...(workerName && { 'worker.name': workerName }),\n }\n\n metricsCollector = new WorkerMetricsCollector()\n\n const memoryHeapUsed = meter.createObservableGauge('iii.worker.memory.heap_used', {\n description: 'Worker heap memory used in bytes',\n unit: 'bytes',\n })\n\n const memoryHeapTotal = meter.createObservableGauge('iii.worker.memory.heap_total', {\n description: 'Worker total heap memory in bytes',\n unit: 'bytes',\n })\n\n const memoryRss = meter.createObservableGauge('iii.worker.memory.rss', {\n description: 'Worker resident set size in bytes',\n unit: 'bytes',\n })\n\n const memoryExternal = meter.createObservableGauge('iii.worker.memory.external', {\n description: 'Worker external memory in bytes',\n unit: 'bytes',\n })\n\n const cpuPercent = meter.createObservableGauge('iii.worker.cpu.percent', {\n description: 'Worker CPU usage percentage',\n unit: '%',\n })\n\n const cpuUserMicros = meter.createObservableGauge('iii.worker.cpu.user_micros', {\n description: 'Worker CPU user time in microseconds',\n unit: 'us',\n })\n\n const cpuSystemMicros = meter.createObservableGauge('iii.worker.cpu.system_micros', {\n description: 'Worker CPU system time in microseconds',\n unit: 'us',\n })\n\n const eventLoopLag = meter.createObservableGauge('iii.worker.event_loop.lag_ms', {\n description: 'Worker event loop lag in milliseconds',\n unit: 'ms',\n })\n\n const uptimeSeconds = meter.createObservableGauge('iii.worker.uptime_seconds', {\n description: 'Worker uptime in seconds',\n unit: 's',\n })\n\n const batchCallback = (observableResult: BatchObservableResult) => {\n if (!metricsCollector) return\n\n const metrics = metricsCollector.collect()\n\n if (metrics.memory_heap_used !== undefined) {\n observableResult.observe(memoryHeapUsed, metrics.memory_heap_used, baseAttributes)\n }\n if (metrics.memory_heap_total !== undefined) {\n observableResult.observe(memoryHeapTotal, metrics.memory_heap_total, baseAttributes)\n }\n if (metrics.memory_rss !== undefined) {\n observableResult.observe(memoryRss, metrics.memory_rss, baseAttributes)\n }\n if (metrics.memory_external !== undefined) {\n observableResult.observe(memoryExternal, metrics.memory_external, baseAttributes)\n }\n if (metrics.cpu_percent !== undefined) {\n observableResult.observe(cpuPercent, metrics.cpu_percent, baseAttributes)\n }\n if (metrics.cpu_user_micros !== undefined) {\n observableResult.observe(cpuUserMicros, metrics.cpu_user_micros, baseAttributes)\n }\n if (metrics.cpu_system_micros !== undefined) {\n observableResult.observe(cpuSystemMicros, metrics.cpu_system_micros, baseAttributes)\n }\n if (metrics.event_loop_lag_ms !== undefined) {\n observableResult.observe(eventLoopLag, metrics.event_loop_lag_ms, baseAttributes)\n }\n if (metrics.uptime_seconds !== undefined) {\n observableResult.observe(uptimeSeconds, metrics.uptime_seconds, baseAttributes)\n }\n }\n\n meter.addBatchObservableCallback(batchCallback, [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ])\n\n registeredMeter = meter\n registeredBatchCallback = batchCallback\n registeredObservables = [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ]\n\n registeredGauges = true\n}\n\nexport function stopWorkerGauges(): void {\n // Remove the batch observable callback before stopping\n if (registeredMeter && registeredBatchCallback) {\n registeredMeter.removeBatchObservableCallback(registeredBatchCallback, registeredObservables)\n }\n\n if (metricsCollector) {\n metricsCollector.stopMonitoring()\n metricsCollector = null\n }\n\n registeredMeter = null\n registeredBatchCallback = null\n registeredObservables = []\n registeredGauges = false\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"otel-worker-gauges-wK5b_eLY.cjs","names":["DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig","DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig","WebSocket","JsonTraceSerializer","ExportResultCode","metrics","JsonMetricsSerializer","ExportResultCode","JsonLogsSerializer","ExportResultCode","trace","carrier: Record<string, string>","context","propagation","entries: Record<string, string>","originalFetch: typeof globalThis.fetch | null","host: string | undefined","scheme: string | undefined","path: string | undefined","port: number | undefined","query: string | undefined","spanAttributes: Record<string, string | number>","tracer","SpanKind","context","carrier: Record<string, string>","SpanStatusCode","sharedConnection: SharedEngineConnection | null","tracerProvider: NodeTracerProvider | null","meterProvider: MeterProvider | null","loggerProvider: LoggerProvider | null","tracer: Tracer | null","meter: Meter | null","logger: Logger | null","serviceName: string","resourceAttributes: Record<string, string>","ATTR_SERVICE_NAME","Resource","NodeTracerProvider","BatchSpanProcessor","CompositePropagator","W3CTraceContextPropagator","W3CBaggagePropagator","trace","MeterProvider","PeriodicExportingMetricReader","LoggerProvider","BatchLogRecordProcessor","noopSpan: Span","context","SpanKind","SpanStatusCode","performance","metricsCollector: WorkerMetricsCollector | null","registeredMeter: Meter | null","registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null","registeredObservables: Observable[]","meter","metrics"],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/connection.ts","../src/telemetry-system/span-exporter.ts","../src/telemetry-system/metrics-exporter.ts","../src/telemetry-system/log-exporter.ts","../src/telemetry-system/context.ts","../src/telemetry-system/fetch-instrumentation.ts","../src/telemetry-system/index.ts","../src/utils.ts","../src/worker-metrics.ts","../src/otel-worker-gauges.ts"],"sourcesContent":["/**\n * Constants for the III module.\n */\n\n/** Engine function paths for internal operations */\nexport const EngineFunctions = {\n LIST_FUNCTIONS: 'engine::functions::list',\n LIST_WORKERS: 'engine::workers::list',\n REGISTER_WORKER: 'engine::workers::register',\n} as const\n\n/** Engine trigger types */\nexport const EngineTriggers = {\n FUNCTIONS_AVAILABLE: 'engine::functions-available',\n LOG: 'log',\n} as const\n\n/** Log function paths */\nexport const LogFunctions = {\n INFO: 'engine::log::info',\n WARN: 'engine::log::warn',\n ERROR: 'engine::log::error',\n DEBUG: 'engine::log::debug',\n} as const\n\n/** Connection state for the III WebSocket */\nexport type IIIConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface IIIReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_BRIDGE_RECONNECTION_CONFIG: IIIReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Default invocation timeout in milliseconds */\nexport const DEFAULT_INVOCATION_TIMEOUT_MS = 30000\n","/**\n * Types, interfaces, and constants for the OpenTelemetry module.\n */\n\nimport type { Instrumentation } from '@opentelemetry/instrumentation'\n\n// Semantic convention constants for compatibility across versions\nexport const ATTR_SERVICE_VERSION = 'service.version'\nexport const ATTR_SERVICE_NAMESPACE = 'service.namespace'\nexport const ATTR_SERVICE_INSTANCE_ID = 'service.instance.id'\n\n/** Magic prefixes for binary frames over WebSocket */\nexport const PREFIX_TRACES = 'OTLP'\nexport const PREFIX_METRICS = 'MTRC'\nexport const PREFIX_LOGS = 'LOGS'\n\n/** Connection state for the shared WebSocket */\nexport type ConnectionState =\n | 'disconnected'\n | 'connecting'\n | 'connected'\n | 'reconnecting'\n | 'failed'\n\n/** Configuration for WebSocket reconnection behavior */\nexport interface ReconnectionConfig {\n /** Starting delay in milliseconds (default: 1000ms) */\n initialDelayMs: number\n /** Maximum delay cap in milliseconds (default: 30000ms) */\n maxDelayMs: number\n /** Exponential backoff multiplier (default: 2) */\n backoffMultiplier: number\n /** Random jitter factor 0-1 (default: 0.3) */\n jitterFactor: number\n /** Maximum retry attempts, -1 for infinite (default: -1) */\n maxRetries: number\n}\n\n/** Default reconnection configuration */\nexport const DEFAULT_RECONNECTION_CONFIG: ReconnectionConfig = {\n initialDelayMs: 1000,\n maxDelayMs: 30000,\n backoffMultiplier: 2,\n jitterFactor: 0.3,\n maxRetries: -1,\n}\n\n/** Configuration for OpenTelemetry initialization. */\nexport interface OtelConfig {\n /** Whether OpenTelemetry export is enabled. Defaults to true. Set to false or OTEL_ENABLED=false/0/no/off to disable. */\n enabled?: boolean\n /** The service name to report. Defaults to OTEL_SERVICE_NAME or \"iii-node\". */\n serviceName?: string\n /** The service version to report. Defaults to SERVICE_VERSION env var or \"unknown\". */\n serviceVersion?: string\n /** The service namespace to report. Defaults to SERVICE_NAMESPACE env var. */\n serviceNamespace?: string\n /** The service instance ID to report. Defaults to SERVICE_INSTANCE_ID env var or auto-generated UUID. */\n serviceInstanceId?: string\n /** III Engine WebSocket URL. Defaults to III_BRIDGE_URL or \"ws://localhost:49134\". */\n engineWsUrl?: string\n /** OpenTelemetry instrumentations to register (e.g., PrismaInstrumentation). */\n instrumentations?: Instrumentation[]\n /** Whether OpenTelemetry metrics export is enabled. Defaults to true. Set to false or OTEL_METRICS_ENABLED=false/0/no/off to disable. */\n metricsEnabled?: boolean\n /** Metrics export interval in milliseconds. Defaults to 60000 (60 seconds). */\n metricsExportIntervalMs?: number\n /** Whether to auto-instrument globalThis.fetch calls. Defaults to true. Works on Node.js, Bun, and Deno. Set to false to disable. */\n fetchInstrumentationEnabled?: boolean\n /** Optional reconnection configuration for the WebSocket connection. */\n reconnectionConfig?: Partial<ReconnectionConfig>\n}\n\n/** Default configuration values for OpenTelemetry initialization. */\nexport const DEFAULT_OTEL_CONFIG = {\n enabled: true,\n serviceName: 'iii-node',\n serviceVersion: 'unknown',\n engineWsUrl: 'ws://localhost:49134',\n metricsEnabled: true,\n metricsExportIntervalMs: 60000,\n fetchInstrumentationEnabled: true,\n} as const satisfies Partial<OtelConfig>\n\n/** Parse a boolean environment variable, recognizing 'false', '0', 'no', 'off' as false. */\nexport function parseBoolEnv(value: string | undefined, defaultValue: boolean): boolean {\n if (value === undefined) return defaultValue\n const lower = value.toLowerCase()\n return lower !== 'false' && lower !== '0' && lower !== 'no' && lower !== 'off'\n}\n","/**\n * Shared WebSocket connection for OpenTelemetry exporters.\n */\n\nimport { WebSocket } from 'ws'\nimport { type ConnectionState, type ReconnectionConfig, DEFAULT_RECONNECTION_CONFIG } from './types'\n\n/**\n * Shared WebSocket connection for all OTEL exporters (traces, metrics, logs).\n * Uses a single connection with message prefixes to identify signal type.\n */\nexport class SharedEngineConnection {\n private static readonly MAX_PENDING_MESSAGES = 1000\n private ws: WebSocket | null = null\n private wsUrl: string\n private connecting = false\n private shuttingDown = false\n private pendingMessages: Array<{ frame: Buffer; callback?: (err?: Error) => void }> = []\n private reconnectAttempt = 0\n private reconnectTimeout: NodeJS.Timeout | null = null\n private config: ReconnectionConfig\n private state: ConnectionState = 'disconnected'\n private onConnectedCallbacks: Array<() => void> = []\n\n constructor(wsUrl: string, config: Partial<ReconnectionConfig> = {}) {\n this.wsUrl = wsUrl\n this.config = { ...DEFAULT_RECONNECTION_CONFIG, ...config }\n this.connect()\n }\n\n private connect(): void {\n if (this.connecting || (this.ws && this.ws.readyState === WebSocket.OPEN)) {\n return\n }\n\n this.connecting = true\n this.state = 'connecting'\n\n try {\n this.ws = new WebSocket(this.wsUrl)\n\n this.ws.on('open', () => {\n this.connecting = false\n this.state = 'connected'\n console.log(`[OTel] Connected to engine at ${this.wsUrl}`)\n\n // Reset reconnection state\n if (this.reconnectAttempt > 0) {\n console.log('[OTel] Successfully reconnected')\n }\n this.reconnectAttempt = 0\n\n // Clear any pending reconnect timer to prevent race conditions\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n // Flush pending messages\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n for (const { frame, callback } of pending) {\n this.ws?.send(frame, err => callback?.(err))\n }\n\n // Notify callbacks\n for (const cb of this.onConnectedCallbacks) {\n cb()\n }\n })\n\n this.ws.on('close', () => {\n this.connecting = false\n this.ws = null\n\n // Skip reconnection if we're shutting down intentionally\n if (this.shuttingDown) {\n this.state = 'disconnected'\n console.log('[OTel] Connection closed during shutdown')\n return\n }\n\n this.state = 'disconnected'\n console.log('[OTel] Disconnected from engine, will reconnect...')\n this.scheduleReconnect()\n })\n\n this.ws.on('error', err => {\n this.connecting = false\n\n // Skip error handling if we're shutting down intentionally\n if (this.shuttingDown) {\n return\n }\n\n console.error('[OTel] WebSocket error:', err.message)\n })\n } catch (err) {\n this.connecting = false\n console.error('[OTel] Connection failed:', err)\n this.scheduleReconnect()\n }\n }\n\n private scheduleReconnect(): void {\n if (this.config.maxRetries !== -1 && this.reconnectAttempt >= this.config.maxRetries) {\n this.state = 'failed'\n console.error(`[OTel] Max retries (${this.config.maxRetries}) reached, giving up`)\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const failedError = new Error('Connection failed after max retries')\n for (const { callback } of pending) {\n callback?.(failedError)\n }\n return\n }\n\n if (this.reconnectTimeout) {\n return // Already scheduled\n }\n\n const exponentialDelay =\n this.config.initialDelayMs * this.config.backoffMultiplier ** this.reconnectAttempt\n const cappedDelay = Math.min(exponentialDelay, this.config.maxDelayMs)\n const jitter = cappedDelay * this.config.jitterFactor * (2 * Math.random() - 1)\n const delay = Math.max(0, Math.floor(cappedDelay + jitter))\n\n this.state = 'reconnecting'\n console.log(`[OTel] Reconnecting in ${delay}ms (attempt ${this.reconnectAttempt + 1})...`)\n\n this.reconnectTimeout = setTimeout(() => {\n this.reconnectTimeout = null\n this.reconnectAttempt++\n this.connect()\n }, delay)\n }\n\n /**\n * Send a message with a signal prefix.\n */\n send(prefix: string, data: Uint8Array, callback?: (err?: Error) => void): void {\n const prefixBytes = Buffer.from(prefix, 'utf-8')\n const frame = Buffer.concat([prefixBytes, Buffer.from(data)])\n\n if (this.ws && this.ws.readyState === WebSocket.OPEN) {\n this.ws.send(frame, callback)\n } else {\n // Queue for later with bounded size to prevent memory exhaustion\n if (this.pendingMessages.length >= SharedEngineConnection.MAX_PENDING_MESSAGES) {\n console.warn('[OTel] Pending message queue full, dropping oldest message')\n const dropped = this.pendingMessages.shift()\n dropped?.callback?.(new Error('Message dropped due to queue overflow'))\n }\n this.pendingMessages.push({ frame, callback })\n this.connect()\n }\n }\n\n /**\n * Register a callback to be called when connected.\n */\n onConnected(callback: () => void): void {\n this.onConnectedCallbacks.push(callback)\n if (this.state === 'connected') {\n callback()\n }\n }\n\n /**\n * Get the current connection state.\n */\n getState(): ConnectionState {\n return this.state\n }\n\n /**\n * Shutdown the connection.\n */\n async shutdown(): Promise<void> {\n // Set shutdown flag to prevent reconnection attempts\n this.shuttingDown = true\n\n if (this.reconnectTimeout) {\n clearTimeout(this.reconnectTimeout)\n this.reconnectTimeout = null\n }\n\n if (this.ws) {\n this.ws.close()\n this.ws = null\n }\n\n // Notify pending message callbacks that they won't be delivered\n const pending = this.pendingMessages.splice(0, this.pendingMessages.length)\n const shutdownError = new Error('Connection shutdown before message could be sent')\n for (const { callback } of pending) {\n callback?.(shutdownError)\n }\n this.onConnectedCallbacks = []\n this.state = 'disconnected'\n }\n}\n","/**\n * Span exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { ReadableSpan, SpanExporter } from '@opentelemetry/sdk-trace-base'\nimport { JsonTraceSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_TRACES } from './types'\n\n/**\n * Span exporter using the shared WebSocket connection.\n */\nexport class EngineSpanExporter implements SpanExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n spans: ReadableSpan[]\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { spans, resultCallback } of pending) {\n this.sendExport(spans, resultCallback)\n }\n }\n\n private sendExport(spans: ReadableSpan[], resultCallback?: (result: ExportResult) => void): void {\n try {\n const serialized = JsonTraceSerializer.serializeRequest(spans)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_TRACES, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send spans:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting spans:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineSpanExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Spans export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ spans, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(spans, resultCallback)\n }\n\n export(spans: ReadableSpan[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(spans, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op, spans are sent immediately\n }\n}\n","/**\n * Metrics exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { PushMetricExporter, ResourceMetrics } from '@opentelemetry/sdk-metrics'\nimport { JsonMetricsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_METRICS } from './types'\n\n/**\n * Metrics exporter using the shared WebSocket connection.\n */\nexport class EngineMetricsExporter implements PushMetricExporter {\n private static readonly MAX_PENDING_EXPORTS = 100\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n metrics: ResourceMetrics\n resultCallback?: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { metrics, resultCallback } of pending) {\n this.sendExport(metrics, resultCallback)\n }\n }\n\n private sendExport(\n metricsData: ResourceMetrics,\n resultCallback?: (result: ExportResult) => void,\n ): void {\n try {\n const serialized = JsonMetricsSerializer.serializeRequest(metricsData)\n if (!serialized) {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_METRICS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send metrics:', err.message)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback?.({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting metrics:', err)\n resultCallback?.({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n private doExport(\n metricsData: ResourceMetrics,\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n if (this.pendingExports.length >= EngineMetricsExporter.MAX_PENDING_EXPORTS) {\n const dropped = this.pendingExports.shift()\n dropped?.resultCallback?.({\n code: ExportResultCode.FAILED,\n error: new Error('Queue overflow'),\n })\n console.warn('[OTel] Metrics export queue full, dropped oldest entry')\n }\n this.pendingExports.push({ metrics: metricsData, resultCallback })\n // Don't call resultCallback here - it will be called when actually sent or on shutdown\n return\n }\n\n this.sendExport(metricsData, resultCallback)\n }\n\n export(metrics: ResourceMetrics, resultCallback: (result: ExportResult) => void): void {\n this.doExport(metrics, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n const shutdownError = new Error('Exporter shutdown before export completed')\n for (const { resultCallback } of pending) {\n resultCallback?.({ code: ExportResultCode.FAILED, error: shutdownError })\n }\n }\n\n async forceFlush(): Promise<void> {\n // No-op\n }\n}\n","/**\n * Log exporter for the III Engine.\n */\n\nimport { ExportResultCode, type ExportResult } from '@opentelemetry/core'\nimport type { LogRecordExporter, ReadableLogRecord } from '@opentelemetry/sdk-logs'\nimport { JsonLogsSerializer } from '@opentelemetry/otlp-transformer'\n\nimport type { SharedEngineConnection } from './connection'\nimport { PREFIX_LOGS } from './types'\n\n/**\n * Log exporter using the shared WebSocket connection.\n */\nexport class EngineLogExporter implements LogRecordExporter {\n private connection: SharedEngineConnection\n private pendingExports: Array<{\n logs: ReadableLogRecord[]\n callback: (result: ExportResult) => void\n }> = []\n\n constructor(connection: SharedEngineConnection) {\n this.connection = connection\n this.connection.onConnected(() => this.flushPending())\n }\n\n private flushPending(): void {\n const pending = this.pendingExports.splice(0, this.pendingExports.length)\n for (const { logs, callback } of pending) {\n this.doExport(logs, callback)\n }\n }\n\n private doExport(\n logs: ReadableLogRecord[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (this.connection.getState() !== 'connected') {\n this.pendingExports.push({ logs, callback: resultCallback })\n return\n }\n\n try {\n const serialized = JsonLogsSerializer.serializeRequest(logs)\n if (!serialized) {\n resultCallback({ code: ExportResultCode.SUCCESS })\n return\n }\n\n this.connection.send(PREFIX_LOGS, serialized, err => {\n if (err) {\n console.error('[OTel] Failed to send logs:', err.message)\n resultCallback({ code: ExportResultCode.FAILED, error: err })\n } else {\n resultCallback({ code: ExportResultCode.SUCCESS })\n }\n })\n } catch (err) {\n console.error('[OTel] Error exporting logs:', err)\n resultCallback({ code: ExportResultCode.FAILED, error: err as Error })\n }\n }\n\n export(logs: ReadableLogRecord[], resultCallback: (result: ExportResult) => void): void {\n this.doExport(logs, resultCallback)\n }\n\n async shutdown(): Promise<void> {\n for (const { callback } of this.pendingExports) {\n callback({ code: ExportResultCode.FAILED, error: new Error('Exporter shutdown') })\n }\n this.pendingExports = []\n }\n}\n","/**\n * Trace context and baggage propagation utilities.\n */\n\nimport { trace, context, propagation, type Context } from '@opentelemetry/api'\n\n/**\n * Extract the current trace ID from the active span context.\n */\nexport function currentTraceId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.traceId && spanContext.traceId !== '00000000000000000000000000000000') {\n return spanContext.traceId\n }\n }\n return undefined\n}\n\n/**\n * Extract the current span ID from the active span context.\n */\nexport function currentSpanId(): string | undefined {\n const span = trace.getActiveSpan()\n if (span) {\n const spanContext = span.spanContext()\n if (spanContext.spanId && spanContext.spanId !== '0000000000000000') {\n return spanContext.spanId\n }\n }\n return undefined\n}\n\n/**\n * Inject the current trace context into a W3C traceparent header string.\n */\nexport function injectTraceparent(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.traceparent\n}\n\n/**\n * Extract a trace context from a W3C traceparent header string.\n */\nexport function extractTraceparent(traceparent: string): Context {\n const carrier: Record<string, string> = { traceparent }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Inject the current baggage into a W3C baggage header string.\n */\nexport function injectBaggage(): string | undefined {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n return carrier.baggage\n}\n\n/**\n * Extract baggage from a W3C baggage header string.\n */\nexport function extractBaggage(baggage: string): Context {\n const carrier: Record<string, string> = { baggage }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Extract both trace context and baggage from their respective headers.\n */\nexport function extractContext(traceparent?: string, baggage?: string): Context {\n const carrier: Record<string, string> = {}\n if (traceparent) {\n carrier.traceparent = traceparent\n }\n if (baggage) {\n carrier.baggage = baggage\n }\n return propagation.extract(context.active(), carrier)\n}\n\n/**\n * Get a baggage entry from the current context.\n */\nexport function getBaggageEntry(key: string): string | undefined {\n const bag = propagation.getBaggage(context.active())\n return bag?.getEntry(key)?.value\n}\n\n/**\n * Set a baggage entry in the current context.\n */\nexport function setBaggageEntry(key: string, value: string): Context {\n let bag = propagation.getBaggage(context.active()) ?? propagation.createBaggage()\n bag = bag.setEntry(key, { value })\n return propagation.setBaggage(context.active(), bag)\n}\n\n/**\n * Remove a baggage entry from the current context.\n */\nexport function removeBaggageEntry(key: string): Context {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return context.active()\n }\n const newBag = bag.removeEntry(key)\n return propagation.setBaggage(context.active(), newBag)\n}\n\n/**\n * Get all baggage entries from the current context.\n */\nexport function getAllBaggage(): Record<string, string> {\n const bag = propagation.getBaggage(context.active())\n if (!bag) {\n return {}\n }\n const entries: Record<string, string> = {}\n for (const [key, entry] of bag.getAllEntries()) {\n entries[key] = entry.value\n }\n return entries\n}\n","/**\n * Global fetch auto-instrumentation for the III Node SDK.\n *\n * Patches globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n * Works on all runtimes (Bun, Node.js, Deno) unlike UndiciInstrumentation\n * which only works when fetch is backed by Node.js's undici.\n */\n\nimport { type Tracer, SpanKind, SpanStatusCode, context, propagation } from '@opentelemetry/api'\n\nconst textEncoder = new TextEncoder()\n\nfunction getBodyByteSize(body: unknown): number | undefined {\n if (body == null) return undefined\n if (typeof body === 'string') return textEncoder.encode(body).byteLength\n if (body instanceof ArrayBuffer) return body.byteLength\n if (ArrayBuffer.isView(body)) return body.byteLength\n if (body instanceof Blob) return body.size\n if (body instanceof URLSearchParams) return new TextEncoder().encode(body.toString()).byteLength\n return undefined\n}\n\nconst SAFE_REQUEST_HEADERS = ['content-type', 'accept'] as const\nconst SAFE_RESPONSE_HEADERS = ['content-type'] as const\n\nlet originalFetch: typeof globalThis.fetch | null = null\n\n/**\n * Patch globalThis.fetch to create OTel CLIENT spans for every HTTP request.\n */\nexport function patchGlobalFetch(tracer: Tracer): void {\n if (originalFetch) return\n\n originalFetch = globalThis.fetch\n const capturedFetch = originalFetch\n\n globalThis.fetch = async (\n input: string | URL | Request,\n init?: RequestInit,\n ): Promise<Response> => {\n const url = input instanceof Request ? input.url : String(input)\n const method = (init?.method ?? (input instanceof Request ? input.method : 'GET')).toUpperCase()\n\n let host: string | undefined\n let scheme: string | undefined\n let path: string | undefined\n let port: number | undefined\n let query: string | undefined\n try {\n const parsed = new URL(url)\n host = parsed.hostname\n scheme = parsed.protocol.replace(':', '')\n path = parsed.pathname\n port = parsed.port ? parseInt(parsed.port, 10) : undefined\n query = parsed.search ? parsed.search.slice(1) : undefined\n } catch {\n // relative URL or invalid — skip host/scheme/path attributes\n }\n\n const spanAttributes: Record<string, string | number> = {\n 'http.request.method': method,\n 'url.full': url,\n }\n if (host) spanAttributes['server.address'] = host\n if (scheme) {\n spanAttributes['url.scheme'] = scheme\n spanAttributes['network.protocol.name'] = 'http'\n }\n if (path) spanAttributes['url.path'] = path\n if (port) spanAttributes['server.port'] = port\n if (query) spanAttributes['url.query'] = query\n\n const spanName = path ? `${method} ${path}` : method\n\n return tracer.startActiveSpan(\n spanName,\n { kind: SpanKind.CLIENT, attributes: spanAttributes },\n context.active(),\n async span => {\n try {\n const carrier: Record<string, string> = {}\n propagation.inject(context.active(), carrier)\n\n const headers = new Headers(\n init?.headers ?? (input instanceof Request ? input.headers : undefined),\n )\n for (const [key, value] of Object.entries(carrier)) {\n headers.set(key, value)\n }\n\n for (const name of SAFE_REQUEST_HEADERS) {\n const value = headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.request.header.${name}`, value)\n }\n }\n\n const requestBody = init?.body ?? (input instanceof Request ? input.body : undefined)\n const requestBodySize = getBodyByteSize(requestBody)\n if (requestBodySize !== undefined) {\n span.setAttribute('http.request.body.size', requestBodySize)\n }\n\n const response = await capturedFetch(input, { ...init, headers })\n\n span.setAttribute('http.response.status_code', response.status)\n\n const contentLength = response.headers.get('content-length')\n if (contentLength !== null) {\n const size = parseInt(contentLength, 10)\n if (!Number.isNaN(size)) {\n span.setAttribute('http.response.body.size', size)\n }\n }\n\n for (const name of SAFE_RESPONSE_HEADERS) {\n const value = response.headers.get(name)\n if (value !== null) {\n span.setAttribute(`http.response.header.${name}`, value)\n }\n }\n\n if (response.status >= 400) {\n span.setAttribute('error.type', String(response.status))\n span.setStatus({ code: SpanStatusCode.ERROR })\n } else {\n span.setStatus({ code: SpanStatusCode.OK })\n }\n\n return response\n } catch (error) {\n span.setAttribute('error.type', (error as Error).name ?? 'Error')\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n }\n}\n\n/**\n * Restore globalThis.fetch to its original implementation.\n */\nexport function unpatchGlobalFetch(): void {\n if (originalFetch) {\n globalThis.fetch = originalFetch\n originalFetch = null\n }\n}\n","/**\n * OpenTelemetry initialization for the III Node SDK.\n *\n * This module provides trace, metrics, and log export to the III Engine\n * via a shared WebSocket connection using OTLP JSON format.\n */\n\nimport { Resource } from '@opentelemetry/resources'\nimport { ATTR_SERVICE_NAME } from '@opentelemetry/semantic-conventions'\nimport { randomUUID } from 'node:crypto'\nimport {\n trace,\n context,\n propagation,\n SpanKind,\n SpanStatusCode,\n metrics,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n} from '@opentelemetry/api'\nimport { BatchSpanProcessor } from '@opentelemetry/sdk-trace-base'\nimport { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics'\nimport {\n CompositePropagator,\n W3CBaggagePropagator,\n W3CTraceContextPropagator,\n} from '@opentelemetry/core'\nimport { NodeTracerProvider } from '@opentelemetry/sdk-trace-node'\nimport { registerInstrumentations } from '@opentelemetry/instrumentation'\nimport { LoggerProvider, BatchLogRecordProcessor } from '@opentelemetry/sdk-logs'\nimport { type Logger, SeverityNumber } from '@opentelemetry/api-logs'\n\nimport {\n type OtelConfig,\n DEFAULT_OTEL_CONFIG,\n parseBoolEnv,\n ATTR_SERVICE_VERSION,\n ATTR_SERVICE_NAMESPACE,\n ATTR_SERVICE_INSTANCE_ID,\n} from './types'\nimport { SharedEngineConnection } from './connection'\nimport { EngineSpanExporter, EngineMetricsExporter, EngineLogExporter } from './exporters'\nimport { extractTraceparent } from './context'\nimport { patchGlobalFetch, unpatchGlobalFetch } from './fetch-instrumentation'\n\n// Re-export everything from submodules\nexport * from './types'\nexport * from './context'\n\n// Module-level state\nlet sharedConnection: SharedEngineConnection | null = null\nlet tracerProvider: NodeTracerProvider | null = null\nlet meterProvider: MeterProvider | null = null\nlet loggerProvider: LoggerProvider | null = null\nlet tracer: Tracer | null = null\nlet meter: Meter | null = null\nlet logger: Logger | null = null\nlet serviceName: string = 'iii-node-iii'\n\n/**\n * Initialize OpenTelemetry with the given configuration.\n * This should be called once at application startup.\n */\nexport function initOtel(config: OtelConfig = {}): void {\n const enabled =\n config.enabled ?? parseBoolEnv(process.env.OTEL_ENABLED, DEFAULT_OTEL_CONFIG.enabled)\n\n if (!enabled) {\n console.debug(\n '[OTel] OpenTelemetry is disabled. To enable, remove OTEL_ENABLED=false or set enabled: true in config.',\n )\n return\n }\n\n // Configure service identity\n serviceName =\n config.serviceName ?? process.env.OTEL_SERVICE_NAME ?? DEFAULT_OTEL_CONFIG.serviceName\n const serviceVersion =\n config.serviceVersion ?? process.env.SERVICE_VERSION ?? DEFAULT_OTEL_CONFIG.serviceVersion\n const serviceNamespace = config.serviceNamespace ?? process.env.SERVICE_NAMESPACE\n const serviceInstanceId =\n config.serviceInstanceId ?? process.env.SERVICE_INSTANCE_ID ?? randomUUID()\n const engineWsUrl =\n config.engineWsUrl ?? process.env.III_BRIDGE_URL ?? DEFAULT_OTEL_CONFIG.engineWsUrl\n\n // Build resource attributes\n const resourceAttributes: Record<string, string> = {\n [ATTR_SERVICE_NAME]: serviceName,\n [ATTR_SERVICE_VERSION]: serviceVersion,\n [ATTR_SERVICE_INSTANCE_ID]: serviceInstanceId,\n }\n if (serviceNamespace) {\n resourceAttributes[ATTR_SERVICE_NAMESPACE] = serviceNamespace\n }\n const resource = new Resource(resourceAttributes)\n\n // Create shared WebSocket connection\n sharedConnection = new SharedEngineConnection(engineWsUrl, config.reconnectionConfig)\n\n // Initialize tracer\n const spanExporter = new EngineSpanExporter(sharedConnection)\n tracerProvider = new NodeTracerProvider({\n resource,\n spanProcessors: [new BatchSpanProcessor(spanExporter)],\n })\n\n // Register W3C Trace Context and Baggage propagators\n propagation.setGlobalPropagator(\n new CompositePropagator({\n propagators: [new W3CTraceContextPropagator(), new W3CBaggagePropagator()],\n }),\n )\n\n tracerProvider.register()\n tracer = trace.getTracer(serviceName)\n\n console.debug(`[OTel] Traces initialized: engine=${engineWsUrl}, service=${serviceName}`)\n\n // Initialize metrics (enabled by default, opt-out via config or env)\n const metricsEnabled =\n config.metricsEnabled ??\n parseBoolEnv(process.env.OTEL_METRICS_ENABLED, DEFAULT_OTEL_CONFIG.metricsEnabled)\n\n if (metricsEnabled) {\n const metricsExporter = new EngineMetricsExporter(sharedConnection)\n const exportIntervalMs =\n config.metricsExportIntervalMs ?? DEFAULT_OTEL_CONFIG.metricsExportIntervalMs\n\n const metricReader = new PeriodicExportingMetricReader({\n exporter: metricsExporter,\n exportIntervalMillis: exportIntervalMs,\n })\n\n meterProvider = new MeterProvider({\n resource,\n readers: [metricReader],\n })\n\n metrics.setGlobalMeterProvider(meterProvider)\n meter = meterProvider.getMeter(serviceName)\n\n console.debug(`[OTel] Metrics initialized: interval=${exportIntervalMs}ms`)\n }\n\n // Register user-provided instrumentations AFTER providers are set up\n const instrumentations = [...(config.instrumentations ?? [])]\n if (instrumentations.length > 0) {\n registerInstrumentations({\n instrumentations,\n tracerProvider,\n meterProvider: meterProvider ?? undefined,\n })\n console.debug(`[OTel] Instrumentations registered: ${instrumentations.length} total`)\n }\n\n // Patch global fetch for runtime-agnostic HTTP client tracing (works on Bun, Node.js, Deno)\n const fetchEnabled =\n config.fetchInstrumentationEnabled ?? DEFAULT_OTEL_CONFIG.fetchInstrumentationEnabled\n\n if (fetchEnabled) {\n patchGlobalFetch(tracer)\n console.debug('[OTel] Global fetch instrumentation enabled')\n }\n\n // Initialize logs (always enabled when OTEL is enabled)\n const logExporter = new EngineLogExporter(sharedConnection)\n loggerProvider = new LoggerProvider({ resource })\n loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter))\n logger = loggerProvider.getLogger(serviceName)\n\n console.debug('[OTel] Logs initialized')\n}\n\n/**\n * Shutdown OpenTelemetry, flushing any pending data.\n */\nexport async function shutdownOtel(): Promise<void> {\n if (tracerProvider) {\n await tracerProvider.forceFlush()\n await tracerProvider.shutdown()\n tracerProvider = null\n }\n\n if (meterProvider) {\n await meterProvider.forceFlush()\n await meterProvider.shutdown()\n meterProvider = null\n }\n\n if (loggerProvider) {\n await loggerProvider.forceFlush()\n await loggerProvider.shutdown()\n loggerProvider = null\n }\n\n if (sharedConnection) {\n await sharedConnection.shutdown()\n sharedConnection = null\n }\n\n unpatchGlobalFetch()\n\n tracer = null\n meter = null\n logger = null\n}\n\n/**\n * Get the OpenTelemetry tracer instance.\n */\nexport function getTracer(): Tracer | null {\n return tracer\n}\n\n/**\n * Get the OpenTelemetry meter instance.\n */\nexport function getMeter(): Meter | null {\n return meter\n}\n\n/**\n * Get the OpenTelemetry logger instance.\n */\nexport function getLogger(): Logger | null {\n return logger\n}\n\n/**\n * Start a new span with the given name and run the callback within it.\n */\nexport async function withSpan<T>(\n name: string,\n options: { kind?: SpanKind; traceparent?: string },\n fn: (span: Span) => Promise<T>,\n): Promise<T> {\n if (!tracer) {\n // Execute without span context when tracer is not initialized\n // Provide a no-op span to avoid runtime errors if fn calls span methods\n const noopSpan: Span = {\n spanContext: () => ({ traceId: '', spanId: '', traceFlags: 0 }),\n setAttribute: () => noopSpan,\n setAttributes: () => noopSpan,\n addEvent: () => noopSpan,\n addLink: () => noopSpan,\n setStatus: () => noopSpan,\n updateName: () => noopSpan,\n end: () => {},\n isRecording: () => false,\n recordException: () => {},\n addLinks: () => noopSpan,\n }\n return fn(noopSpan)\n }\n\n const parentContext = options.traceparent\n ? extractTraceparent(options.traceparent)\n : context.active()\n\n return tracer.startActiveSpan(\n name,\n { kind: options.kind ?? SpanKind.INTERNAL },\n parentContext,\n async span => {\n try {\n const result = await fn(span)\n span.setStatus({ code: SpanStatusCode.OK })\n return result\n } catch (error) {\n span.setStatus({ code: SpanStatusCode.ERROR, message: (error as Error).message })\n span.recordException(error as Error)\n throw error\n } finally {\n span.end()\n }\n },\n )\n}\n\n// Re-export OTEL types for convenience\nexport {\n SpanKind,\n SpanStatusCode,\n SeverityNumber,\n type Span,\n type Context,\n type Tracer,\n type Meter,\n type Logger,\n}\n","import type { StreamChannelRef } from './iii-types'\nimport type { ApiResponse, HttpRequest, HttpResponse, InternalHttpRequest } from './types'\n\n/**\n * Safely stringify a value, handling circular references, BigInt, and other edge cases.\n * Returns \"[unserializable]\" if serialization fails for any reason.\n */\nexport function safeStringify(value: unknown): string {\n const seen = new WeakSet<object>()\n\n try {\n return JSON.stringify(value, (_key, val) => {\n // Handle BigInt\n if (typeof val === 'bigint') {\n return val.toString()\n }\n\n // Handle circular references\n if (val !== null && typeof val === 'object') {\n if (seen.has(val)) {\n return '[Circular]'\n }\n seen.add(val)\n }\n\n return val\n })\n } catch {\n return '[unserializable]'\n }\n}\n\nexport const http = (\n // biome-ignore lint/suspicious/noConfusingVoidType: void is necessary here\n callback: (req: HttpRequest, res: HttpResponse) => Promise<void | ApiResponse>,\n) => {\n return async (req: InternalHttpRequest) => {\n const { response, ...request } = req\n\n const httpResponse: HttpResponse = {\n status: (status_code: number) =>\n response.sendMessage(JSON.stringify({ type: 'set_status', status_code })),\n headers: (headers: Record<string, string>) =>\n response.sendMessage(JSON.stringify({ type: 'set_headers', headers })),\n stream: response.stream,\n close: () => response.close(),\n }\n\n return callback(request, httpResponse)\n }\n}\n\nexport const isChannelRef = (value: unknown): value is StreamChannelRef => {\n if (typeof value !== 'object' || value === null) return false\n const maybe = value as Partial<StreamChannelRef>\n return (\n typeof maybe.channel_id === 'string' &&\n typeof maybe.access_key === 'string' &&\n (maybe.direction === 'read' || maybe.direction === 'write')\n )\n}\n","/**\n * Worker metrics collection for the III Node SDK.\n *\n * Collects CPU, memory, and event loop metrics for worker health monitoring.\n * Uses the Node.js built-in `monitorEventLoopDelay` API for accurate\n * event loop lag measurements.\n */\n\nimport { type IntervalHistogram, monitorEventLoopDelay, performance } from 'node:perf_hooks'\n\n/**\n * Worker metrics data structure used internally for OTEL metric collection.\n */\nexport type WorkerMetrics = {\n memory_heap_used?: number\n memory_heap_total?: number\n memory_rss?: number\n memory_external?: number\n cpu_user_micros?: number\n cpu_system_micros?: number\n cpu_percent?: number\n event_loop_lag_ms?: number\n uptime_seconds?: number\n timestamp_ms: number\n runtime: string\n}\n\n/**\n * Configuration options for the WorkerMetricsCollector.\n */\nexport interface WorkerMetricsCollectorOptions {\n /**\n * Event loop delay histogram resolution in milliseconds.\n * Lower values provide more accurate measurements but use more resources.\n * @default 20\n */\n eventLoopResolutionMs?: number\n}\n\n/**\n * Collects worker resource metrics including CPU, memory, and event loop lag.\n *\n * Uses the Node.js `monitorEventLoopDelay` API for high-precision event loop\n * delay measurements instead of manual `setImmediate` timing.\n *\n * @example\n * ```typescript\n * const collector = new WorkerMetricsCollector()\n *\n * // Collect metrics periodically\n * setInterval(() => {\n * const metrics = collector.collect()\n * console.log('CPU:', metrics.cpu_percent, '%')\n * console.log('Event Loop Lag:', metrics.event_loop_lag_ms, 'ms')\n * }, 5000)\n *\n * // Clean up when done\n * collector.stopMonitoring()\n * ```\n */\nexport class WorkerMetricsCollector {\n private readonly startTime: number\n private lastCpuUsage: NodeJS.CpuUsage\n private lastCpuTime: number\n private eventLoopHistogram: IntervalHistogram | null = null\n\n /**\n * Creates a new WorkerMetricsCollector instance.\n *\n * @param options - Configuration options\n */\n constructor(options: WorkerMetricsCollectorOptions = {}) {\n this.startTime = Date.now()\n this.lastCpuUsage = process.cpuUsage()\n this.lastCpuTime = performance.now()\n this.startEventLoopMonitoring(options.eventLoopResolutionMs ?? 20)\n }\n\n /**\n * Starts the event loop delay histogram monitoring.\n *\n * @param resolutionMs - Histogram resolution in milliseconds\n */\n private startEventLoopMonitoring(resolutionMs: number): void {\n // Sanitize resolution: must be a positive finite number, minimum 1ms\n const safeResolutionMs =\n Number.isFinite(resolutionMs) && resolutionMs > 0 ? Math.max(1, Math.floor(resolutionMs)) : 20 // Default fallback\n\n this.eventLoopHistogram = monitorEventLoopDelay({ resolution: safeResolutionMs })\n this.eventLoopHistogram.enable()\n }\n\n /**\n * Stops the event loop monitoring and releases resources.\n * Should be called when the collector is no longer needed.\n */\n public stopMonitoring(): void {\n if (this.eventLoopHistogram) {\n this.eventLoopHistogram.disable()\n this.eventLoopHistogram = null\n }\n }\n\n /**\n * Collects current worker metrics.\n *\n * This method calculates CPU usage since the last collection,\n * reads memory usage, and gets event loop delay statistics.\n * The event loop histogram is reset after each collection for\n * accurate per-interval measurements.\n *\n * @returns Current worker metrics snapshot\n */\n collect(): WorkerMetrics {\n const memoryUsage = process.memoryUsage()\n const cpuUsage = process.cpuUsage()\n const now = performance.now()\n\n // Calculate CPU percentage since last collection\n const cpuDelta = {\n user: cpuUsage.user - this.lastCpuUsage.user,\n system: cpuUsage.system - this.lastCpuUsage.system,\n }\n const timeDelta = (now - this.lastCpuTime) * 1000 // Convert ms to microseconds\n const cpuPercent = timeDelta > 0 ? ((cpuDelta.user + cpuDelta.system) / timeDelta) * 100 : 0\n\n // Update state for next collection\n this.lastCpuUsage = cpuUsage\n this.lastCpuTime = now\n\n // Get event loop lag from histogram (in nanoseconds, convert to ms)\n let eventLoopLagMs = 0\n if (this.eventLoopHistogram) {\n // Mean is in nanoseconds, convert to milliseconds\n eventLoopLagMs = this.eventLoopHistogram.mean / 1_000_000\n // Reset histogram for next collection interval\n this.eventLoopHistogram.reset()\n }\n\n return {\n memory_heap_used: memoryUsage.heapUsed,\n memory_heap_total: memoryUsage.heapTotal,\n memory_rss: memoryUsage.rss,\n memory_external: memoryUsage.external,\n cpu_user_micros: cpuUsage.user,\n cpu_system_micros: cpuUsage.system,\n cpu_percent: Math.min(cpuPercent, 100), // Cap at 100%\n event_loop_lag_ms: eventLoopLagMs,\n uptime_seconds: Math.floor((Date.now() - this.startTime) / 1000),\n timestamp_ms: Date.now(),\n runtime: 'node',\n }\n }\n}\n","import type { Meter, BatchObservableResult, Observable } from '@opentelemetry/api'\nimport { WorkerMetricsCollector } from './worker-metrics'\n\nexport interface WorkerGaugesOptions {\n workerId: string\n workerName?: string\n}\n\nlet registeredGauges = false\nlet metricsCollector: WorkerMetricsCollector | null = null\nlet registeredMeter: Meter | null = null\nlet registeredBatchCallback: ((observableResult: BatchObservableResult) => void) | null = null\nlet registeredObservables: Observable[] = []\n\nexport function registerWorkerGauges(meter: Meter, options: WorkerGaugesOptions): void {\n if (registeredGauges) {\n return\n }\n\n const { workerId, workerName } = options\n const baseAttributes = {\n 'worker.id': workerId,\n ...(workerName && { 'worker.name': workerName }),\n }\n\n metricsCollector = new WorkerMetricsCollector()\n\n const memoryHeapUsed = meter.createObservableGauge('iii.worker.memory.heap_used', {\n description: 'Worker heap memory used in bytes',\n unit: 'bytes',\n })\n\n const memoryHeapTotal = meter.createObservableGauge('iii.worker.memory.heap_total', {\n description: 'Worker total heap memory in bytes',\n unit: 'bytes',\n })\n\n const memoryRss = meter.createObservableGauge('iii.worker.memory.rss', {\n description: 'Worker resident set size in bytes',\n unit: 'bytes',\n })\n\n const memoryExternal = meter.createObservableGauge('iii.worker.memory.external', {\n description: 'Worker external memory in bytes',\n unit: 'bytes',\n })\n\n const cpuPercent = meter.createObservableGauge('iii.worker.cpu.percent', {\n description: 'Worker CPU usage percentage',\n unit: '%',\n })\n\n const cpuUserMicros = meter.createObservableGauge('iii.worker.cpu.user_micros', {\n description: 'Worker CPU user time in microseconds',\n unit: 'us',\n })\n\n const cpuSystemMicros = meter.createObservableGauge('iii.worker.cpu.system_micros', {\n description: 'Worker CPU system time in microseconds',\n unit: 'us',\n })\n\n const eventLoopLag = meter.createObservableGauge('iii.worker.event_loop.lag_ms', {\n description: 'Worker event loop lag in milliseconds',\n unit: 'ms',\n })\n\n const uptimeSeconds = meter.createObservableGauge('iii.worker.uptime_seconds', {\n description: 'Worker uptime in seconds',\n unit: 's',\n })\n\n const batchCallback = (observableResult: BatchObservableResult) => {\n if (!metricsCollector) return\n\n const metrics = metricsCollector.collect()\n\n if (metrics.memory_heap_used !== undefined) {\n observableResult.observe(memoryHeapUsed, metrics.memory_heap_used, baseAttributes)\n }\n if (metrics.memory_heap_total !== undefined) {\n observableResult.observe(memoryHeapTotal, metrics.memory_heap_total, baseAttributes)\n }\n if (metrics.memory_rss !== undefined) {\n observableResult.observe(memoryRss, metrics.memory_rss, baseAttributes)\n }\n if (metrics.memory_external !== undefined) {\n observableResult.observe(memoryExternal, metrics.memory_external, baseAttributes)\n }\n if (metrics.cpu_percent !== undefined) {\n observableResult.observe(cpuPercent, metrics.cpu_percent, baseAttributes)\n }\n if (metrics.cpu_user_micros !== undefined) {\n observableResult.observe(cpuUserMicros, metrics.cpu_user_micros, baseAttributes)\n }\n if (metrics.cpu_system_micros !== undefined) {\n observableResult.observe(cpuSystemMicros, metrics.cpu_system_micros, baseAttributes)\n }\n if (metrics.event_loop_lag_ms !== undefined) {\n observableResult.observe(eventLoopLag, metrics.event_loop_lag_ms, baseAttributes)\n }\n if (metrics.uptime_seconds !== undefined) {\n observableResult.observe(uptimeSeconds, metrics.uptime_seconds, baseAttributes)\n }\n }\n\n meter.addBatchObservableCallback(batchCallback, [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ])\n\n registeredMeter = meter\n registeredBatchCallback = batchCallback\n registeredObservables = [\n memoryHeapUsed,\n memoryHeapTotal,\n memoryRss,\n memoryExternal,\n cpuPercent,\n cpuUserMicros,\n cpuSystemMicros,\n eventLoopLag,\n uptimeSeconds,\n ]\n\n registeredGauges = true\n}\n\nexport function stopWorkerGauges(): void {\n // Remove the batch observable callback before stopping\n if (registeredMeter && registeredBatchCallback) {\n registeredMeter.removeBatchObservableCallback(registeredBatchCallback, registeredObservables)\n }\n\n if (metricsCollector) {\n metricsCollector.stopMonitoring()\n metricsCollector = null\n }\n\n registeredMeter = null\n registeredBatchCallback = null\n registeredObservables = []\n registeredGauges = false\n}\n"],"mappings":"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"}
|
package/dist/telemetry.cjs
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
const require_otel_worker_gauges = require('./otel-worker-gauges-
|
|
1
|
+
const require_otel_worker_gauges = require('./otel-worker-gauges-wK5b_eLY.cjs');
|
|
2
2
|
const require_index = require('./index.cjs');
|
|
3
3
|
let __opentelemetry_api_logs = require("@opentelemetry/api-logs");
|
|
4
4
|
let __opentelemetry_api = require("@opentelemetry/api");
|
package/dist/telemetry.d.cts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { $ as IIIReconnectionConfig, A as getLogger, B as extractTraceparent, C as WorkerInfo, D as SeverityNumber, E as Meter, F as withSpan, G as removeBaggageEntry, H as getBaggageEntry, I as currentSpanId, J as DEFAULT_BRIDGE_RECONNECTION_CONFIG, K as setBaggageEntry, L as currentTraceId, M as getTracer, N as initOtel, O as Span, P as shutdownOtel, Q as IIIConnectionState, R as extractBaggage, T as Logger, U as injectBaggage, V as getAllBaggage, W as injectTraceparent, X as EngineFunctions, Y as DEFAULT_INVOCATION_TIMEOUT_MS, Z as EngineTriggers, et as LogFunctions, g as OtelLogEvent, h as LogSeverityLevel, j as getMeter, k as SpanStatusCode, l as FunctionsAvailableCallback, m as LogConfig, n as safeStringify, p as LogCallback, q as OtelConfig, r as ConnectionStateCallback, w as WorkerStatus, y as FunctionInfo, z as extractContext } from "./utils-
|
|
1
|
+
import { $ as IIIReconnectionConfig, A as getLogger, B as extractTraceparent, C as WorkerInfo, D as SeverityNumber, E as Meter, F as withSpan, G as removeBaggageEntry, H as getBaggageEntry, I as currentSpanId, J as DEFAULT_BRIDGE_RECONNECTION_CONFIG, K as setBaggageEntry, L as currentTraceId, M as getTracer, N as initOtel, O as Span, P as shutdownOtel, Q as IIIConnectionState, R as extractBaggage, T as Logger, U as injectBaggage, V as getAllBaggage, W as injectTraceparent, X as EngineFunctions, Y as DEFAULT_INVOCATION_TIMEOUT_MS, Z as EngineTriggers, et as LogFunctions, g as OtelLogEvent, h as LogSeverityLevel, j as getMeter, k as SpanStatusCode, l as FunctionsAvailableCallback, m as LogConfig, n as safeStringify, p as LogCallback, q as OtelConfig, r as ConnectionStateCallback, w as WorkerStatus, y as FunctionInfo, z as extractContext } from "./utils-00Nf7BPL.cjs";
|
|
2
2
|
import { Meter as Meter$1 } from "@opentelemetry/api";
|
|
3
3
|
|
|
4
4
|
//#region src/worker-metrics.d.ts
|
package/dist/telemetry.d.mts
CHANGED
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { $ as IIIReconnectionConfig, A as getLogger, B as extractTraceparent, C as WorkerInfo, D as SeverityNumber, E as Meter, F as withSpan, G as removeBaggageEntry, H as getBaggageEntry, I as currentSpanId, J as DEFAULT_BRIDGE_RECONNECTION_CONFIG, K as setBaggageEntry, L as currentTraceId, M as getTracer, N as initOtel, O as Span, P as shutdownOtel, Q as IIIConnectionState, R as extractBaggage, T as Logger, U as injectBaggage, V as getAllBaggage, W as injectTraceparent, X as EngineFunctions, Y as DEFAULT_INVOCATION_TIMEOUT_MS, Z as EngineTriggers, et as LogFunctions, g as OtelLogEvent, h as LogSeverityLevel, j as getMeter, k as SpanStatusCode, l as FunctionsAvailableCallback, m as LogConfig, n as safeStringify, p as LogCallback, q as OtelConfig, r as ConnectionStateCallback, w as WorkerStatus, y as FunctionInfo, z as extractContext } from "./utils-
|
|
1
|
+
import { $ as IIIReconnectionConfig, A as getLogger, B as extractTraceparent, C as WorkerInfo, D as SeverityNumber, E as Meter, F as withSpan, G as removeBaggageEntry, H as getBaggageEntry, I as currentSpanId, J as DEFAULT_BRIDGE_RECONNECTION_CONFIG, K as setBaggageEntry, L as currentTraceId, M as getTracer, N as initOtel, O as Span, P as shutdownOtel, Q as IIIConnectionState, R as extractBaggage, T as Logger, U as injectBaggage, V as getAllBaggage, W as injectTraceparent, X as EngineFunctions, Y as DEFAULT_INVOCATION_TIMEOUT_MS, Z as EngineTriggers, et as LogFunctions, g as OtelLogEvent, h as LogSeverityLevel, j as getMeter, k as SpanStatusCode, l as FunctionsAvailableCallback, m as LogConfig, n as safeStringify, p as LogCallback, q as OtelConfig, r as ConnectionStateCallback, w as WorkerStatus, y as FunctionInfo, z as extractContext } from "./utils-DGk5SQIG.mjs";
|
|
2
2
|
import { Meter as Meter$1 } from "@opentelemetry/api";
|
|
3
3
|
|
|
4
4
|
//#region src/worker-metrics.d.ts
|
package/dist/telemetry.mjs
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
import { A as EngineTriggers, C as injectBaggage, D as DEFAULT_BRIDGE_RECONNECTION_CONFIG, E as setBaggageEntry, O as DEFAULT_INVOCATION_TIMEOUT_MS, S as getBaggageEntry, T as removeBaggageEntry, _ as currentTraceId, b as extractTraceparent, d as getMeter, f as getTracer, g as currentSpanId, h as withSpan, j as LogFunctions, k as EngineFunctions, l as SpanStatusCode, m as shutdownOtel, n as stopWorkerGauges, o as safeStringify, p as initOtel, r as WorkerMetricsCollector, s as SeverityNumber, t as registerWorkerGauges, u as getLogger, v as extractBaggage, w as injectTraceparent, x as getAllBaggage, y as extractContext } from "./otel-worker-gauges-
|
|
1
|
+
import { A as EngineTriggers, C as injectBaggage, D as DEFAULT_BRIDGE_RECONNECTION_CONFIG, E as setBaggageEntry, O as DEFAULT_INVOCATION_TIMEOUT_MS, S as getBaggageEntry, T as removeBaggageEntry, _ as currentTraceId, b as extractTraceparent, d as getMeter, f as getTracer, g as currentSpanId, h as withSpan, j as LogFunctions, k as EngineFunctions, l as SpanStatusCode, m as shutdownOtel, n as stopWorkerGauges, o as safeStringify, p as initOtel, r as WorkerMetricsCollector, s as SeverityNumber, t as registerWorkerGauges, u as getLogger, v as extractBaggage, w as injectTraceparent, x as getAllBaggage, y as extractContext } from "./otel-worker-gauges-Dqf47JXh.mjs";
|
|
2
2
|
|
|
3
3
|
export { DEFAULT_BRIDGE_RECONNECTION_CONFIG, DEFAULT_INVOCATION_TIMEOUT_MS, EngineFunctions, EngineTriggers, LogFunctions, SeverityNumber, SpanStatusCode, WorkerMetricsCollector, currentSpanId, currentTraceId, extractBaggage, extractContext, extractTraceparent, getAllBaggage, getBaggageEntry, getLogger, getMeter, getTracer, initOtel, injectBaggage, injectTraceparent, registerWorkerGauges, removeBaggageEntry, safeStringify, setBaggageEntry, shutdownOtel, stopWorkerGauges, withSpan };
|
|
@@ -519,7 +519,7 @@ declare const init: (address: string, options?: InitOptions) => ISdk;
|
|
|
519
519
|
* Returns "[unserializable]" if serialization fails for any reason.
|
|
520
520
|
*/
|
|
521
521
|
declare function safeStringify(value: unknown): string;
|
|
522
|
-
declare const http: (callback: (req: HttpRequest, res: HttpResponse) => Promise<void>) => (req: InternalHttpRequest) => Promise<void>;
|
|
522
|
+
declare const http: (callback: (req: HttpRequest, res: HttpResponse) => Promise<void | ApiResponse>) => (req: InternalHttpRequest) => Promise<void | ApiResponse>;
|
|
523
523
|
//#endregion
|
|
524
524
|
export { IIIReconnectionConfig as $, getLogger as A, extractTraceparent as B, WorkerInfo as C, SeverityNumber as D, Meter$1 as E, withSpan as F, removeBaggageEntry as G, getBaggageEntry as H, currentSpanId as I, DEFAULT_BRIDGE_RECONNECTION_CONFIG as J, setBaggageEntry as K, currentTraceId as L, getTracer as M, initOtel as N, Span$1 as O, shutdownOtel as P, IIIConnectionState as Q, extractBaggage as R, StreamChannelRef as S, Logger as T, injectBaggage as U, getAllBaggage as V, injectTraceparent as W, EngineFunctions as X, DEFAULT_INVOCATION_TIMEOUT_MS as Y, EngineTriggers as Z, ChannelReader as _, init as a, HttpAuthConfig as b, Channel as c, HttpResponse as d, LogFunctions as et, ISdk as f, OtelLogEvent as g, LogSeverityLevel as h, InitOptions as i, getMeter as j, SpanStatusCode as k, FunctionsAvailableCallback as l, LogConfig as m, safeStringify as n, ApiRequest as o, LogCallback as p, OtelConfig as q, ConnectionStateCallback as r, ApiResponse as s, http as t, HttpRequest as u, ChannelWriter as v, WorkerStatus as w, HttpInvocationConfig as x, FunctionInfo as y, extractContext as z };
|
|
525
|
-
//# sourceMappingURL=utils-
|
|
525
|
+
//# sourceMappingURL=utils-00Nf7BPL.d.cts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils-00Nf7BPL.d.cts","names":[],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/context.ts","../src/telemetry-system/index.ts","../src/iii-types.ts","../src/triggers.ts","../src/channels.ts","../src/types.ts","../src/iii.ts","../src/utils.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -519,7 +519,7 @@ declare const init: (address: string, options?: InitOptions) => ISdk;
|
|
|
519
519
|
* Returns "[unserializable]" if serialization fails for any reason.
|
|
520
520
|
*/
|
|
521
521
|
declare function safeStringify(value: unknown): string;
|
|
522
|
-
declare const http: (callback: (req: HttpRequest, res: HttpResponse) => Promise<void>) => (req: InternalHttpRequest) => Promise<void>;
|
|
522
|
+
declare const http: (callback: (req: HttpRequest, res: HttpResponse) => Promise<void | ApiResponse>) => (req: InternalHttpRequest) => Promise<void | ApiResponse>;
|
|
523
523
|
//#endregion
|
|
524
524
|
export { IIIReconnectionConfig as $, getLogger as A, extractTraceparent as B, WorkerInfo as C, SeverityNumber$1 as D, Meter$1 as E, withSpan as F, removeBaggageEntry as G, getBaggageEntry as H, currentSpanId as I, DEFAULT_BRIDGE_RECONNECTION_CONFIG as J, setBaggageEntry as K, currentTraceId as L, getTracer as M, initOtel as N, Span$1 as O, shutdownOtel as P, IIIConnectionState as Q, extractBaggage as R, StreamChannelRef as S, Logger as T, injectBaggage as U, getAllBaggage as V, injectTraceparent as W, EngineFunctions as X, DEFAULT_INVOCATION_TIMEOUT_MS as Y, EngineTriggers as Z, ChannelReader as _, init as a, HttpAuthConfig as b, Channel as c, HttpResponse as d, LogFunctions as et, ISdk as f, OtelLogEvent as g, LogSeverityLevel as h, InitOptions as i, getMeter as j, SpanStatusCode$1 as k, FunctionsAvailableCallback as l, LogConfig as m, safeStringify as n, ApiRequest as o, LogCallback as p, OtelConfig as q, ConnectionStateCallback as r, ApiResponse as s, http as t, HttpRequest as u, ChannelWriter as v, WorkerStatus as w, HttpInvocationConfig as x, FunctionInfo as y, extractContext as z };
|
|
525
|
-
//# sourceMappingURL=utils-
|
|
525
|
+
//# sourceMappingURL=utils-DGk5SQIG.d.mts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"utils-DGk5SQIG.d.mts","names":[],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/context.ts","../src/telemetry-system/index.ts","../src/iii-types.ts","../src/triggers.ts","../src/channels.ts","../src/types.ts","../src/iii.ts","../src/utils.ts"],"sourcesContent":[],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils-CSKJ2XjM.d.cts","names":[],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/context.ts","../src/telemetry-system/index.ts","../src/iii-types.ts","../src/triggers.ts","../src/channels.ts","../src/types.ts","../src/iii.ts","../src/utils.ts"],"sourcesContent":[],"mappings":"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"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"utils-Dr4vNtCh.d.mts","names":[],"sources":["../src/iii-constants.ts","../src/telemetry-system/types.ts","../src/telemetry-system/context.ts","../src/telemetry-system/index.ts","../src/iii-types.ts","../src/triggers.ts","../src/channels.ts","../src/types.ts","../src/iii.ts","../src/utils.ts"],"sourcesContent":[],"mappings":"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"}
|