@dxos/tracing 0.8.4-main.422d1c7879 → 0.8.4-main.4f23b4e393
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/lib/browser/index.mjs +8 -59
- package/dist/lib/browser/index.mjs.map +2 -2
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +8 -59
- package/dist/lib/node-esm/index.mjs.map +2 -2
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/src/api.d.ts.map +1 -1
- package/dist/types/src/buffering-backend.d.ts.map +1 -1
- package/dist/types/src/diagnostic.d.ts.map +1 -1
- package/dist/types/src/diagnostics-channel.d.ts.map +1 -1
- package/dist/types/src/metrics/base.d.ts.map +1 -1
- package/dist/types/src/metrics/custom-counter.d.ts.map +1 -1
- package/dist/types/src/metrics/map-counter.d.ts.map +1 -1
- package/dist/types/src/metrics/time-series-counter.d.ts.map +1 -1
- package/dist/types/src/metrics/time-usage-counter.d.ts.map +1 -1
- package/dist/types/src/metrics/unary-counter.d.ts.map +1 -1
- package/dist/types/src/remote/metrics.d.ts.map +1 -1
- package/dist/types/src/symbols.d.ts.map +1 -1
- package/dist/types/src/trace-processor.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +9 -9
|
@@ -154,27 +154,11 @@ var DiagnosticsManager = class {
|
|
|
154
154
|
}
|
|
155
155
|
async fetch(request) {
|
|
156
156
|
if (request.instanceId != null) {
|
|
157
|
-
invariant(request.instanceId === this.instanceId, "Invalid instance id", {
|
|
158
|
-
F: __dxlog_file,
|
|
159
|
-
L: 82,
|
|
160
|
-
S: this,
|
|
161
|
-
A: [
|
|
162
|
-
"request.instanceId === this.instanceId",
|
|
163
|
-
"'Invalid instance id'"
|
|
164
|
-
]
|
|
165
|
-
});
|
|
157
|
+
invariant(request.instanceId === this.instanceId, "Invalid instance id", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 52, S: this, A: ["request.instanceId === this.instanceId", "'Invalid instance id'"] });
|
|
166
158
|
}
|
|
167
159
|
const { id } = request;
|
|
168
160
|
const diagnostic2 = this.registry.get(id);
|
|
169
|
-
invariant(diagnostic2, "Diagnostic not found", {
|
|
170
|
-
F: __dxlog_file,
|
|
171
|
-
L: 86,
|
|
172
|
-
S: this,
|
|
173
|
-
A: [
|
|
174
|
-
"diagnostic",
|
|
175
|
-
"'Diagnostic not found'"
|
|
176
|
-
]
|
|
177
|
-
});
|
|
161
|
+
invariant(diagnostic2, "Diagnostic not found", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 56, S: this, A: ["diagnostic", "'Diagnostic not found'"] });
|
|
178
162
|
try {
|
|
179
163
|
const data = await asyncTimeout(diagnostic2.fetch(), DIAGNOSTICS_TIMEOUT);
|
|
180
164
|
return {
|
|
@@ -205,10 +189,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
205
189
|
static get supported() {
|
|
206
190
|
return globalThis.BroadcastChannel != null;
|
|
207
191
|
}
|
|
208
|
-
_ctx = new Context(void 0, {
|
|
209
|
-
F: __dxlog_file2,
|
|
210
|
-
L: 46
|
|
211
|
-
});
|
|
192
|
+
_ctx = new Context(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 16 });
|
|
212
193
|
// Separate channels becauase the client and server may be in the same process.
|
|
213
194
|
_serveChannel = void 0;
|
|
214
195
|
_clientChannel = void 0;
|
|
@@ -236,15 +217,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
236
217
|
}
|
|
237
218
|
}
|
|
238
219
|
serve(manager) {
|
|
239
|
-
invariant2(this._serveChannel, void 0, {
|
|
240
|
-
F: __dxlog_file2,
|
|
241
|
-
L: 78,
|
|
242
|
-
S: this,
|
|
243
|
-
A: [
|
|
244
|
-
"this._serveChannel",
|
|
245
|
-
""
|
|
246
|
-
]
|
|
247
|
-
});
|
|
220
|
+
invariant2(this._serveChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 43, S: this, A: ["this._serveChannel", ""] });
|
|
248
221
|
const listener = async (event) => {
|
|
249
222
|
switch (event.data.type) {
|
|
250
223
|
case "DIAGNOSTICS_DISCOVER": {
|
|
@@ -276,15 +249,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
276
249
|
this._ctx.onDispose(() => this._serveChannel.removeEventListener("message", listener));
|
|
277
250
|
}
|
|
278
251
|
async discover() {
|
|
279
|
-
invariant2(this._clientChannel, void 0, {
|
|
280
|
-
F: __dxlog_file2,
|
|
281
|
-
L: 114,
|
|
282
|
-
S: this,
|
|
283
|
-
A: [
|
|
284
|
-
"this._clientChannel",
|
|
285
|
-
""
|
|
286
|
-
]
|
|
287
|
-
});
|
|
252
|
+
invariant2(this._clientChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 77, S: this, A: ["this._clientChannel", ""] });
|
|
288
253
|
const diagnostics = [];
|
|
289
254
|
const collector = (event) => {
|
|
290
255
|
const data = event.data;
|
|
@@ -312,15 +277,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
312
277
|
}
|
|
313
278
|
}
|
|
314
279
|
async fetch(request) {
|
|
315
|
-
invariant2(this._clientChannel, void 0, {
|
|
316
|
-
F: __dxlog_file2,
|
|
317
|
-
L: 147,
|
|
318
|
-
S: this,
|
|
319
|
-
A: [
|
|
320
|
-
"this._clientChannel",
|
|
321
|
-
""
|
|
322
|
-
]
|
|
323
|
-
});
|
|
280
|
+
invariant2(this._clientChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 106, S: this, A: ["this._clientChannel", ""] });
|
|
324
281
|
const requestId = createId();
|
|
325
282
|
const trigger = new Trigger();
|
|
326
283
|
const listener = (event) => {
|
|
@@ -449,12 +406,7 @@ var TraceProcessor = class {
|
|
|
449
406
|
logs = [];
|
|
450
407
|
_instanceTag = null;
|
|
451
408
|
constructor() {
|
|
452
|
-
log.addProcessor(this._logProcessor.bind(this), void 0, {
|
|
453
|
-
F: __dxlog_file3,
|
|
454
|
-
L: 108,
|
|
455
|
-
S: this,
|
|
456
|
-
C: (f, a) => f(...a)
|
|
457
|
-
});
|
|
409
|
+
log.addProcessor(this._logProcessor.bind(this), void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file3, L: 80, S: this });
|
|
458
410
|
if (DiagnosticsChannel.supported) {
|
|
459
411
|
this.diagnosticsChannel.serve(this.diagnostics);
|
|
460
412
|
}
|
|
@@ -729,10 +681,7 @@ var resource = (options) => (constructor) => {
|
|
|
729
681
|
attributes: traceAttrs
|
|
730
682
|
}) : new Context2({
|
|
731
683
|
attributes: traceAttrs
|
|
732
|
-
}, {
|
|
733
|
-
F: __dxlog_file4,
|
|
734
|
-
L: 104
|
|
735
|
-
});
|
|
684
|
+
}, { "~LogMeta": "~LogMeta", F: __dxlog_file4, L: 79 });
|
|
736
685
|
}
|
|
737
686
|
try {
|
|
738
687
|
return await originalOpen.call(this, openCtx);
|
|
@@ -2,6 +2,6 @@
|
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/api.ts", "../../../src/symbols.ts", "../../../src/trace-processor.ts", "../../../src/buffering-backend.ts", "../../../src/diagnostic.ts", "../../../src/util.ts", "../../../src/diagnostics-channel.ts", "../../../src/remote/metrics.ts", "../../../src/weak-ref.ts", "../../../src/metrics/base.ts", "../../../src/metrics/unary-counter.ts", "../../../src/metrics/time-series-counter.ts", "../../../src/metrics/time-usage-counter.ts", "../../../src/metrics/map-counter.ts", "../../../src/metrics/custom-counter.ts", "../../../src/index.ts"],
|
|
4
4
|
"sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { Context, LifecycleState, Resource, TRACE_SPAN_ATTRIBUTE } from '@dxos/context';\nimport { type MaybePromise } from '@dxos/util';\n\nimport { getTracingContext } from './symbols';\nimport { TRACE_PROCESSOR, sanitizeClassName } from './trace-processor';\nimport type { RemoteSpan } from './tracing-types';\n\nconst LIFECYCLE_SPAN = Symbol('dxos.tracing.lifecycle-span');\n\n/** localStorage key that switches the browser OTEL sampler from 30% to 100%. */\nexport const TRACE_ALL_KEY = 'dxos.debug.traceAll';\n\n/**\n * Reads `@trace.info({ spanAttribute: true })` properties from the instance\n * and writes them into the span attributes map.\n */\nconst collectSpanAttributes = (instance: any, spanAttributes: Record<string, any>) => {\n const proto = Object.getPrototypeOf(instance);\n if (!proto) {\n return;\n }\n const tracingContext = getTracingContext(proto);\n for (const [key, { options }] of Object.entries(tracingContext.infoProperties)) {\n if (!options.spanAttribute) {\n continue;\n }\n try {\n const value = typeof instance[key] === 'function' ? instance[key]() : instance[key];\n if (value != null) {\n const resolved = options.enum ? options.enum[value] : String(value);\n spanAttributes[`ctx.${key}`] = resolved;\n }\n } catch {\n // Skip properties that throw (e.g. uninitialized).\n }\n }\n};\n\nexport type ResourceOptions = {\n annotation?: symbol;\n /**\n * Start a lifecycle span on `open()` and end it on `close()`.\n * `this._ctx` carries the lifecycle span's trace context, so background work\n * (subscriptions, timers) becomes children of the lifecycle span.\n * Direct calls within `_open` use the `_open` span's context as usual.\n * Requires the class to extend {@link Resource}.\n */\n lifecycle?: boolean;\n};\n\n/**\n * Annotates a class as a tracked resource.\n */\nconst resource =\n (options?: ResourceOptions) =>\n <T extends { new (...args: any[]): {} }>(constructor: T) => {\n if (options?.lifecycle && !(constructor.prototype instanceof Resource)) {\n throw new Error(`@trace.resource({ lifecycle: true }) requires ${constructor.name} to extend Resource`);\n }\n\n const klass = (() =>\n class extends constructor {\n constructor(...rest: any[]) {\n super(...rest);\n TRACE_PROCESSOR.createTraceResource({ constructor, annotation: options?.annotation, instance: this });\n }\n })();\n\n if (options?.lifecycle) {\n const sanitizedName = sanitizeClassName(constructor.name);\n const proto = klass.prototype as any;\n const originalOpen = proto.open;\n const originalClose = proto.close;\n\n proto.open = async function (ctx?: Context): Promise<any> {\n const self = this as any;\n\n if (self._lifecycleState !== LifecycleState.CLOSED) {\n return originalOpen.call(this, ctx);\n }\n\n const parentSpanContext = ctx?.getAttribute(TRACE_SPAN_ATTRIBUTE);\n const resourceEntry = TRACE_PROCESSOR.resourceInstanceIndex.get(this);\n const spanAttributes: Record<string, any> = {};\n if (resourceEntry) {\n spanAttributes.entryPoint = resourceEntry.sanitizedClassName;\n }\n\n const remoteSpan = TRACE_PROCESSOR.tracingBackend?.startSpan({\n name: `${sanitizedName}.lifecycle`,\n op: 'lifecycle',\n attributes: spanAttributes,\n parentContext: parentSpanContext,\n });\n self[LIFECYCLE_SPAN] = remoteSpan;\n\n let openCtx = ctx;\n if (remoteSpan?.spanContext != null) {\n const traceAttrs = { [TRACE_SPAN_ATTRIBUTE]: remoteSpan.spanContext };\n openCtx = ctx ? ctx.derive({ attributes: traceAttrs }) : new Context({ attributes: traceAttrs });\n }\n\n try {\n return await originalOpen.call(this, openCtx);\n } catch (err) {\n remoteSpan?.setError?.(err);\n remoteSpan?.end();\n self[LIFECYCLE_SPAN] = undefined;\n throw err;\n }\n };\n\n proto.close = async function (ctx?: Context): Promise<any> {\n const self = this as any;\n const remoteSpan: RemoteSpan | undefined = self[LIFECYCLE_SPAN];\n try {\n return await originalClose.call(this, ctx);\n } catch (err) {\n remoteSpan?.setError?.(err);\n throw err;\n } finally {\n if (remoteSpan) {\n remoteSpan.end();\n self[LIFECYCLE_SPAN] = undefined;\n }\n }\n };\n }\n\n Object.defineProperty(klass, 'name', { value: constructor.name });\n return klass;\n };\n\nexport interface TimeAware {\n tick(timeMs: number): void;\n}\n\nexport type InfoOptions = {\n /**\n * Value is of enum type and should be converted to string.\n *\n * Example:\n *\n * ```ts\n * @trace.info({ enum: SpaceState })\n * get state(): SpaceState { ... }\n * ```\n */\n enum?: Record<string, any>;\n\n /**\n * Max depth of the object to be included in the resource info section.\n *\n * null means no limit (a limit of 8 nested objects is still imposed).\n *\n * Default: 0 - objects will be stringified with toString.\n */\n depth?: number | null;\n\n /** When true, the property value is also set as an OTEL span attribute on every span created by this resource. */\n spanAttribute?: boolean;\n};\n\n/**\n * Marks a property or a method to be included in the resource info section.\n */\nconst info =\n (opts: InfoOptions = {}) =>\n (target: any, propertyKey: string, descriptor?: PropertyDescriptor) => {\n getTracingContext(target).infoProperties[propertyKey] = { options: opts };\n };\n\nconst mark = (name: string) => {\n performance.mark(name);\n};\n\nexport type SpanOptions = {\n showInBrowserTimeline?: boolean;\n /** When false the span is not exported to remote OTLP collectors. Defaults to true. */\n showInRemoteTracing?: boolean;\n op?: string;\n attributes?: Record<string, any>;\n};\n\n/**\n * Decorator that creates a span for the execution duration of the decorated method.\n * Calls the TracingBackend directly; no custom TracingSpan objects.\n */\nconst span =\n ({ showInBrowserTimeline = false, showInRemoteTracing = true, op, attributes }: SpanOptions = {}) =>\n (target: any, propertyKey: string, descriptor: TypedPropertyDescriptor<(...args: any) => any>) => {\n const method = descriptor.value!;\n\n descriptor.value = async function (this: any, ...args: any) {\n const parentCtx = args[0] instanceof Context ? args[0] : null;\n const startTs = performance.now();\n\n const parentSpanContext = parentCtx?.getAttribute(TRACE_SPAN_ATTRIBUTE);\n\n const resourceEntry = TRACE_PROCESSOR.resourceInstanceIndex.get(this);\n const className = resourceEntry?.sanitizedClassName ?? sanitizeClassName(target.constructor?.name ?? 'unknown');\n const spanName = `${className}.${propertyKey}`;\n\n const spanAttributes: Record<string, any> = {};\n if (resourceEntry) {\n spanAttributes.entryPoint = resourceEntry.sanitizedClassName;\n }\n collectSpanAttributes(this, spanAttributes);\n if (attributes) {\n for (const [key, value] of Object.entries(attributes)) {\n spanAttributes[key.startsWith('ctx.') ? key : `ctx.${key}`] = value;\n }\n }\n\n const remoteSpan = showInRemoteTracing\n ? TRACE_PROCESSOR.tracingBackend?.startSpan({\n name: spanName,\n op: op ?? 'function',\n attributes: spanAttributes,\n parentContext: parentSpanContext,\n })\n : undefined;\n\n let callArgs = args;\n if (parentCtx) {\n const childCtx =\n remoteSpan?.spanContext != null\n ? parentCtx.derive({ attributes: { [TRACE_SPAN_ATTRIBUTE]: remoteSpan.spanContext } })\n : parentCtx.derive();\n callArgs = [childCtx, ...args.slice(1)];\n }\n\n try {\n return await method.apply(this, callArgs);\n } catch (err) {\n remoteSpan?.setError?.(err);\n throw err;\n } finally {\n remoteSpan?.end();\n if (showInBrowserTimeline && typeof globalThis?.performance?.measure === 'function') {\n performance.measure(spanName, { start: startTs, end: performance.now() });\n }\n }\n };\n };\n\nconst manualSpans = new Map<string, RemoteSpan>();\nconst manualSpanTimestamps = new Map<string, { name: string; startTs: number }>();\n\nexport type ManualSpanParams = {\n id: string;\n instance: any;\n methodName: string;\n parentCtx: Context | null;\n showInBrowserTimeline?: boolean;\n showInRemoteTracing?: boolean;\n op?: string;\n attributes?: Record<string, any>;\n};\n\n/**\n * Creates a span that must be ended manually.\n *\n * Returns a child Context that carries the new span's `TRACE_SPAN_ATTRIBUTE`.\n * Callers should use the returned ctx for downstream work so that nested\n * `@trace.span` methods and RPC calls inherit this span as their parent\n * and land in the same trace (rather than starting a new root).\n *\n * When the new span cannot be created (duplicate id, no backend, or\n * `showInRemoteTracing: false`), the parentCtx is returned unchanged.\n */\nconst spanStart = (params: ManualSpanParams): Context | null => {\n if (manualSpans.has(params.id) || manualSpanTimestamps.has(params.id)) {\n return params.parentCtx;\n }\n\n const resourceEntry = TRACE_PROCESSOR.resourceInstanceIndex.get(params.instance);\n const className = resourceEntry?.sanitizedClassName ?? 'unknown';\n const spanName = `${className}.${params.methodName}`;\n\n if (params.showInBrowserTimeline) {\n manualSpanTimestamps.set(params.id, { name: spanName, startTs: performance.now() });\n }\n\n if (params.showInRemoteTracing === false || !TRACE_PROCESSOR.tracingBackend) {\n return params.parentCtx;\n }\n\n const parentSpanContext = params.parentCtx?.getAttribute(TRACE_SPAN_ATTRIBUTE);\n\n const spanAttributes: Record<string, any> = {};\n if (resourceEntry) {\n spanAttributes.entryPoint = resourceEntry.sanitizedClassName;\n }\n collectSpanAttributes(params.instance, spanAttributes);\n if (params.attributes) {\n for (const [key, value] of Object.entries(params.attributes)) {\n spanAttributes[key.startsWith('ctx.') ? key : `ctx.${key}`] = value;\n }\n }\n\n const remoteSpan = TRACE_PROCESSOR.tracingBackend.startSpan({\n name: spanName,\n op: params.op ?? 'function',\n attributes: spanAttributes,\n parentContext: parentSpanContext,\n });\n manualSpans.set(params.id, remoteSpan);\n\n if (params.parentCtx && remoteSpan.spanContext != null) {\n return params.parentCtx.derive({ attributes: { [TRACE_SPAN_ATTRIBUTE]: remoteSpan.spanContext } });\n }\n return params.parentCtx;\n};\n\n/**\n * Ends a span that was started manually.\n */\nconst spanEnd = (id: string) => {\n const remoteSpan = manualSpans.get(id);\n if (remoteSpan) {\n remoteSpan.end();\n manualSpans.delete(id);\n }\n\n const timestamps = manualSpanTimestamps.get(id);\n if (timestamps && typeof globalThis?.performance?.measure === 'function') {\n performance.measure(timestamps.name, { start: timestamps.startTs, end: performance.now() });\n manualSpanTimestamps.delete(id);\n }\n};\n\n/**\n * Attaches metrics counter to the resource.\n */\nconst metricsCounter = () => (target: any, propertyKey: string, descriptor?: PropertyDescriptor) => {\n getTracingContext(target).metricsProperties[propertyKey] = {};\n};\n\nexport type AddLinkOptions = {};\n\nconst addLink = (parent: any, child: any, opts: AddLinkOptions = {}) => {\n TRACE_PROCESSOR.addLink(parent, child, opts);\n};\n\nexport type TraceDiagnosticProps<T> = {\n /** Unique ID. */\n id: string;\n\n /**\n * Human-readable name.\n * @defaults Defaults to `id`\n */\n name?: string;\n\n /** Function that will be called to fetch the diagnostic data. */\n fetch: () => MaybePromise<T>;\n};\n\nexport interface TraceDiagnostic {\n id: string;\n unregister(): void;\n}\n\n/**\n * Register a diagnostic that could be queried.\n */\nconst diagnostic = <T>(params: TraceDiagnosticProps<T>): TraceDiagnostic => {\n return TRACE_PROCESSOR.diagnostics.registerDiagnostic(params);\n};\n\nexport const trace = {\n addLink,\n diagnostic,\n info,\n mark,\n metricsCounter,\n resource,\n span,\n spanStart,\n spanEnd,\n metrics: TRACE_PROCESSOR.remoteMetrics,\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type InfoOptions } from './api';\n\nexport const symbolTracingContext = Symbol('dxos.tracing.context');\n\nexport type TracingContext = {\n infoProperties: Record<\n string,\n {\n options: InfoOptions;\n }\n >;\n metricsProperties: Record<string, {}>;\n};\n\nexport const getTracingContext = (target: any): TracingContext => {\n return ((target[symbolTracingContext] as TracingContext | undefined) ??= {\n infoProperties: {},\n metricsProperties: {},\n });\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { LogLevel, type LogProcessor, log } from '@dxos/log';\nimport { type LogEntry } from '@dxos/protocols/proto/dxos/client/services';\nimport { type Metric, type Resource } from '@dxos/protocols/proto/dxos/tracing';\nimport { getPrototypeSpecificInstanceId } from '@dxos/util';\n\nimport type { AddLinkOptions, TimeAware } from './api';\nimport { BUFFERED_PREFIX, BufferingTracingBackend } from './buffering-backend';\nimport { DiagnosticsManager } from './diagnostic';\nimport { DiagnosticsChannel } from './diagnostics-channel';\nimport { type BaseCounter } from './metrics';\nimport { RemoteMetrics } from './remote/metrics';\nimport { getTracingContext } from './symbols';\nimport type { RemoteSpan, StartSpanOptions, TracingBackend } from './tracing-types';\nimport { WeakRef } from './weak-ref';\n\nexport type Diagnostics = {\n resources: Record<string, Resource>;\n logs: LogEntry[];\n};\n\nexport type TraceResourceConstructorProps = {\n constructor: { new (...args: any[]): {} };\n instance: any;\n annotation?: symbol;\n};\n\nexport class ResourceEntry {\n /**\n * Sometimes bundlers mangle class names: WebFile -> WebFile2.\n *\n * We use a heuristic to remove the suffix.\n */\n public readonly sanitizedClassName: string;\n\n constructor(\n public readonly data: Resource,\n public readonly instance: WeakRef<any>,\n public readonly annotation?: symbol,\n ) {\n this.sanitizedClassName = sanitizeClassName(data.className);\n }\n\n getMetric(name: string): Metric | undefined {\n return this.data.metrics?.find((metric) => metric.name === name);\n }\n}\n\nconst MAX_RESOURCE_RECORDS = 2_000;\nconst MAX_LOG_RECORDS = 1_000;\n\nconst MAX_INFO_OBJECT_DEPTH = 8;\n\nexport class TraceProcessor {\n public readonly diagnostics = new DiagnosticsManager();\n public readonly diagnosticsChannel = new DiagnosticsChannel();\n public readonly remoteMetrics = new RemoteMetrics();\n\n readonly #bufferingBackend = new BufferingTracingBackend();\n #activeBackend: TracingBackend = this.#bufferingBackend;\n\n /**\n * Tracing backend. Initially a buffering backend that records spans;\n * once the observability package sets a real backend, the buffer is drained\n * and a thin translating wrapper is installed that resolves stale buffered\n * parent IDs still held by in-flight {@link Context} objects.\n *\n * The wrapper only allocates when a `buffered-*` parent is actually encountered;\n * the common path is a single `startsWith` check and direct passthrough.\n */\n get tracingBackend(): TracingBackend {\n return this.#activeBackend;\n }\n\n set tracingBackend(backend: TracingBackend | undefined) {\n if (!backend || backend === this.#bufferingBackend) {\n this.#bufferingBackend.clear();\n this.#activeBackend = this.#bufferingBackend;\n return;\n }\n const idMap = this.#bufferingBackend.drain(backend);\n this.#activeBackend = {\n startSpan: (options: StartSpanOptions): RemoteSpan => {\n const parent = options.parentContext;\n if (parent?.traceparent.startsWith(BUFFERED_PREFIX)) {\n const translated = idMap.get(parent.traceparent);\n if (translated) {\n return backend.startSpan({ ...options, parentContext: translated });\n }\n }\n return backend.startSpan(options);\n },\n };\n }\n\n readonly resources = new Map<number, ResourceEntry>();\n readonly resourceInstanceIndex = new WeakMap<any, ResourceEntry>();\n readonly resourceIdList: number[] = [];\n\n readonly logs: LogEntry[] = [];\n\n private _instanceTag: string | null = null;\n\n constructor() {\n log.addProcessor(this._logProcessor.bind(this));\n\n if (DiagnosticsChannel.supported) {\n this.diagnosticsChannel.serve(this.diagnostics);\n }\n this.diagnosticsChannel.unref();\n }\n\n setInstanceTag(tag: string): void {\n this._instanceTag = tag;\n this.diagnostics.setInstanceTag(tag);\n }\n\n /** @internal */\n createTraceResource(params: TraceResourceConstructorProps): void {\n const id = this.resources.size;\n\n const tracingContext = getTracingContext(Object.getPrototypeOf(params.instance));\n for (const key of Object.keys(tracingContext.metricsProperties)) {\n (params.instance[key] as BaseCounter)._assign(params.instance, key);\n }\n\n const entry = new ResourceEntry(\n {\n id,\n className: params.constructor.name,\n instanceId: getPrototypeSpecificInstanceId(params.instance),\n info: this.getResourceInfo(params.instance),\n links: [],\n metrics: this.getResourceMetrics(params.instance),\n },\n new WeakRef(params.instance),\n params.annotation,\n );\n\n this.resources.set(id, entry);\n this.resourceInstanceIndex.set(params.instance, entry);\n this.resourceIdList.push(id);\n if (this.resourceIdList.length > MAX_RESOURCE_RECORDS) {\n this._clearResources();\n }\n }\n\n // TODO(burdon): Not implemented.\n addLink(parent: any, child: any, opts: AddLinkOptions): void {}\n\n getDiagnostics(): Diagnostics {\n this.refresh();\n\n return {\n resources: Object.fromEntries(\n Array.from(this.resources.entries()).map(([id, entry]) => [\n `${entry.sanitizedClassName}#${entry.data.instanceId}`,\n entry.data,\n ]),\n ),\n logs: this.logs.filter((log) => log.level >= LogLevel.INFO),\n };\n }\n\n getResourceInfo(instance: any): Record<string, any> {\n const res: Record<string, any> = {};\n const tracingContext = getTracingContext(Object.getPrototypeOf(instance));\n for (const [key, { options }] of Object.entries(tracingContext.infoProperties)) {\n try {\n const value = typeof instance[key] === 'function' ? instance[key]() : instance[key];\n if (options.enum) {\n res[key] = options.enum[value];\n } else {\n res[key] = sanitizeValue(\n value,\n options.depth === undefined ? 1 : (options.depth ?? MAX_INFO_OBJECT_DEPTH),\n this,\n );\n }\n } catch (err: any) {\n res[key] = err.message;\n }\n }\n\n return res;\n }\n\n getResourceMetrics(instance: any): Metric[] {\n const res: Metric[] = [];\n const tracingContext = getTracingContext(Object.getPrototypeOf(instance));\n for (const [key, _opts] of Object.entries(tracingContext.metricsProperties)) {\n res.push(instance[key].getData());\n }\n\n return res;\n }\n\n getResourceId(instance: any): number | null {\n const entry = this.resourceInstanceIndex.get(instance);\n return entry ? entry.data.id : null;\n }\n\n findResourcesByClassName(className: string): ResourceEntry[] {\n return [...this.resources.values()].filter(\n (res) => res.data.className === className || res.sanitizedClassName === className,\n );\n }\n\n findResourcesByAnnotation(annotation: symbol): ResourceEntry[] {\n return [...this.resources.values()].filter((res) => res.annotation === annotation);\n }\n\n refresh(): void {\n for (const resource of this.resources.values()) {\n const instance = resource.instance.deref();\n if (!instance) {\n continue;\n }\n\n const tracingContext = getTracingContext(Object.getPrototypeOf(instance));\n const time = performance.now();\n (instance as TimeAware).tick?.(time);\n for (const key of Object.keys(tracingContext.metricsProperties)) {\n (instance[key] as BaseCounter)._tick?.(time);\n }\n\n resource.data.info = this.getResourceInfo(instance);\n resource.data.metrics = this.getResourceMetrics(instance);\n }\n }\n\n private _clearResources(): void {\n while (this.resourceIdList.length > MAX_RESOURCE_RECORDS) {\n const id = this.resourceIdList.shift()!;\n this.resources.delete(id);\n }\n }\n\n private _pushLog(log: LogEntry): void {\n this.logs.push(log);\n if (this.logs.length > MAX_LOG_RECORDS) {\n this.logs.shift();\n }\n }\n\n private _logProcessor: LogProcessor = (config, entry) => {\n switch (entry.level) {\n case LogLevel.ERROR:\n case LogLevel.WARN:\n case LogLevel.TRACE: {\n const scope = entry.meta?.S;\n const resource = this.resourceInstanceIndex.get(scope);\n if (!resource) {\n return;\n }\n\n const context: Record<string, any> = { ...entry.computedContext };\n if (entry.computedError !== undefined) {\n context.error = entry.computedError;\n }\n\n const { filename, line } = entry.computedMeta;\n const entryToPush: LogEntry = {\n level: entry.level,\n message: entry.message ?? entry.computedError ?? '',\n context,\n timestamp: new Date(entry.timestamp),\n meta: {\n file: filename ?? '',\n line: line ?? 0,\n resourceId: resource.data.id,\n },\n };\n this._pushLog(entryToPush);\n break;\n }\n default:\n }\n };\n}\n\nexport const TRACE_PROCESSOR: TraceProcessor = ((globalThis as any).TRACE_PROCESSOR ??= new TraceProcessor());\n\nconst sanitizeValue = (value: any, depth: number, traceProcessor: TraceProcessor): any => {\n switch (typeof value) {\n case 'string':\n case 'number':\n case 'boolean':\n case 'undefined':\n return value;\n case 'object':\n case 'function':\n if (value === null) {\n return value;\n }\n\n {\n const resourceEntry = traceProcessor.resourceInstanceIndex.get(value);\n if (resourceEntry) {\n return `${resourceEntry.sanitizedClassName}#${resourceEntry.data.instanceId}`;\n }\n }\n\n if (typeof value.toJSON === 'function') {\n return sanitizeValue(value.toJSON(), depth, traceProcessor);\n }\n\n if (depth > 0) {\n if (isSetLike(value)) {\n return Object.fromEntries(\n Array.from(value.entries()).map((value) => sanitizeValue(value, depth - 1, traceProcessor)),\n );\n } else if (isMapLike(value)) {\n return Object.fromEntries(\n Array.from(value.entries()).map(([key, value]) => [key, sanitizeValue(value, depth - 1, traceProcessor)]),\n );\n } else if (Array.isArray(value)) {\n return value.map((item: any) => sanitizeValue(item, depth - 1, traceProcessor));\n } else if (typeof value === 'object') {\n const res: any = {};\n for (const key of Object.keys(value)) {\n res[key] = sanitizeValue(value[key], depth - 1, traceProcessor);\n }\n return res;\n }\n }\n\n if (typeof value.truncate === 'function') {\n return value.truncate();\n }\n\n return value.toString();\n }\n};\n\nexport const sanitizeClassName = (className: string) => {\n let name = className.replace(/^_+/, '');\n const SANITIZE_REGEX = /[^_](\\d+)$/;\n const m = name.match(SANITIZE_REGEX);\n if (m) {\n name = name.slice(0, -m[1].length);\n }\n return name;\n};\n\nconst isSetLike = (value: any): value is Set<any> =>\n value instanceof Set ||\n (typeof value === 'object' && value !== null && Object.getPrototypeOf(value).constructor.name === 'ComplexSet');\n\nconst isMapLike = (value: any): value is Map<any, any> =>\n value instanceof Map ||\n (typeof value === 'object' && value !== null && Object.getPrototypeOf(value).constructor.name === 'ComplexMap');\n", "//\n// Copyright 2026 DXOS.org\n//\n\nimport { type TraceContextData } from '@dxos/context';\n\nimport type { RemoteSpan, StartSpanOptions, TracingBackend } from './tracing-types';\n\nexport const BUFFERED_PREFIX = 'buffered-';\n\n/**\n * Span handle that records operations while no real OTEL backend is available.\n * Once a real backend is registered, the buffered span is replayed and a\n * {@link delegate} is set so future calls forward to the real span.\n */\nclass BufferedSpan implements RemoteSpan {\n readonly spanContext: TraceContextData;\n readonly startTime: number;\n delegate?: RemoteSpan;\n\n #ended = false;\n #endTime?: number;\n #error?: unknown;\n #hasError = false;\n\n constructor(\n readonly options: StartSpanOptions,\n id: number,\n ) {\n this.spanContext = { traceparent: `${BUFFERED_PREFIX}${id}` };\n this.startTime = Date.now();\n }\n\n end(endTime?: number): void {\n if (this.delegate) {\n this.delegate.end(endTime);\n return;\n }\n this.#endTime = endTime ?? Date.now();\n this.#ended = true;\n }\n\n setError(err: unknown): void {\n if (this.delegate) {\n this.delegate.setError?.(err);\n return;\n }\n this.#error = err;\n this.#hasError = true;\n }\n\n replay(real: RemoteSpan): void {\n if (this.#hasError) {\n real.setError?.(this.#error);\n }\n if (this.#ended) {\n real.end(this.#endTime);\n } else {\n this.delegate = real;\n }\n }\n}\n\n/**\n * A {@link TracingBackend} that buffers span operations until a real backend\n * registers. On {@link drain}, buffered spans are replayed in FIFO order with\n * parent IDs translated from synthetic `buffered-*` traceparents to real OTEL\n * IDs, preserving the trace hierarchy.\n */\nexport class BufferingTracingBackend implements TracingBackend {\n readonly #pending: BufferedSpan[] = [];\n #counter = 0;\n\n startSpan(options: StartSpanOptions): RemoteSpan {\n const span = new BufferedSpan(options, ++this.#counter);\n this.#pending.push(span);\n return span;\n }\n\n /** Discard all buffered spans without replaying them. */\n clear(): void {\n this.#pending.length = 0;\n }\n\n /**\n * Replay all buffered spans into {@link backend}.\n *\n * @returns Map from synthetic buffered traceparent to real {@link TraceContextData},\n * used by the post-drain translating wrapper to resolve stale buffered IDs\n * still present on in-flight {@link Context} objects.\n */\n drain(backend: TracingBackend): Map<string, TraceContextData> {\n const idMap = new Map<string, TraceContextData>();\n\n for (const buffered of this.#pending) {\n let parentContext = buffered.options.parentContext;\n if (parentContext && parentContext.traceparent.startsWith(BUFFERED_PREFIX)) {\n parentContext = idMap.get(parentContext.traceparent) ?? parentContext;\n }\n\n const real = backend.startSpan({ ...buffered.options, parentContext, startTime: buffered.startTime });\n\n if (real.spanContext) {\n idMap.set(buffered.spanContext.traceparent, real.spanContext);\n }\n\n buffered.replay(real);\n }\n this.#pending.length = 0;\n return idMap;\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { asyncTimeout } from '@dxos/async';\nimport { invariant } from '@dxos/invariant';\n\nimport { type TraceDiagnostic, type TraceDiagnosticProps } from './api';\nimport { createId } from './util';\n\nexport const DIAGNOSTICS_TIMEOUT = 10_000;\n\nexport type DiagnosticMetadata = {\n id: string;\n instanceId: string;\n instanceTag: string | null;\n name: string;\n};\n\nexport type DiagnosticsRequest = {\n id: string;\n instanceId?: string;\n instanceTag?: string | null;\n};\n\nexport type DiagnosticsData = {\n id: string;\n instanceId: string;\n data: any;\n error?: string;\n};\n\nexport class TraceDiagnosticImpl implements TraceDiagnostic {\n constructor(\n public id: string,\n public fetch: () => any,\n public name: string,\n private readonly _onUnregister: () => void,\n ) {}\n\n unregister(): void {\n this._onUnregister();\n }\n}\n\nexport class DiagnosticsManager {\n readonly instanceId = createId();\n\n readonly registry = new Map<string, TraceDiagnosticImpl>();\n\n private _instanceTag: string | null = null;\n\n get instanceTag(): string | null {\n return this._instanceTag;\n }\n\n setInstanceTag(tag: string): void {\n this._instanceTag = tag;\n }\n\n registerDiagnostic(params: TraceDiagnosticProps<any>): TraceDiagnostic {\n const impl = new TraceDiagnosticImpl(params.id, params.fetch, params.name ?? params.id, () => {\n if (this.registry.get(params.id) === impl) {\n this.registry.delete(params.id);\n }\n });\n this.registry.set(params.id, impl);\n return impl;\n }\n\n list(): DiagnosticMetadata[] {\n return Array.from(this.registry.values()).map((diagnostic) => ({\n id: diagnostic.id,\n instanceId: this.instanceId,\n instanceTag: this._instanceTag,\n name: diagnostic.name,\n }));\n }\n\n async fetch(request: DiagnosticsRequest): Promise<DiagnosticsData> {\n if (request.instanceId != null) {\n invariant(request.instanceId === this.instanceId, 'Invalid instance id');\n }\n const { id } = request;\n const diagnostic = this.registry.get(id);\n invariant(diagnostic, 'Diagnostic not found');\n try {\n const data = await asyncTimeout(diagnostic.fetch(), DIAGNOSTICS_TIMEOUT);\n return {\n id,\n instanceId: this.instanceId,\n data,\n };\n } catch (err: any) {\n return {\n id,\n instanceId: this.instanceId,\n data: null,\n error: err.stack,\n };\n }\n }\n}\n", "// TODO(dmaretskyi): Use UUID.\n//\n// Copyright 2024 DXOS.org\n//\n\nexport const createId = () => Math.random().toString(36).slice(2);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { Trigger, sleep } from '@dxos/async';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\n\nimport {\n DIAGNOSTICS_TIMEOUT,\n type DiagnosticMetadata,\n type DiagnosticsData,\n type DiagnosticsManager,\n type DiagnosticsRequest,\n} from './diagnostic';\nimport { createId } from './util';\n\nconst DEFAULT_CHANNEL_NAME = 'dxos-diagnostics';\n\nconst DISCOVER_TIME = 500;\n\nexport type DiagnosticChannelMessage =\n | {\n type: 'DIAGNOSTICS_DISCOVER';\n }\n | {\n type: 'DIAGNOSTICS_ANNOUNCE';\n diagnostics: DiagnosticMetadata[];\n }\n | {\n type: 'DIAGNOSTICS_FETCH';\n requestId: string;\n request: DiagnosticsRequest;\n }\n | {\n type: 'DIAGNOSTICS_RESPONSE';\n requestId: string;\n data: DiagnosticsData;\n };\n\nexport class DiagnosticsChannel {\n static get supported() {\n return globalThis.BroadcastChannel != null;\n }\n\n private _ctx = new Context();\n\n // Separate channels becauase the client and server may be in the same process.\n private readonly _serveChannel?: BroadcastChannel = undefined;\n private readonly _clientChannel?: BroadcastChannel = undefined;\n\n constructor(private readonly _channelName: string = DEFAULT_CHANNEL_NAME) {\n if (DiagnosticsChannel.supported) {\n this._serveChannel = new BroadcastChannel(_channelName);\n this._clientChannel = new BroadcastChannel(_channelName);\n }\n }\n\n destroy(): void {\n void this._ctx.dispose();\n this._serveChannel?.close();\n this._clientChannel?.close();\n }\n\n /**\n * In node.js, the channel will keep the process alive.\n * This method allows the process to exit.\n * Noop in the browser.\n */\n unref(): void {\n if (this._serveChannel && typeof (this._serveChannel as any).unref === 'function') {\n (this._serveChannel as any).unref();\n (this._clientChannel as any).unref();\n }\n }\n\n serve(manager: DiagnosticsManager): void {\n invariant(this._serveChannel);\n const listener = async (event: MessageEvent) => {\n switch (event.data.type) {\n case 'DIAGNOSTICS_DISCOVER': {\n const diagnostics = manager.list();\n this._serveChannel!.postMessage({\n type: 'DIAGNOSTICS_ANNOUNCE',\n diagnostics,\n } satisfies DiagnosticChannelMessage);\n break;\n }\n case 'DIAGNOSTICS_FETCH': {\n const { requestId, request } = event.data;\n\n if (request.instanceId != null && request.instanceId !== manager.instanceId) {\n break;\n } else if (request.instanceTag != null && request.instanceTag !== manager.instanceTag) {\n break;\n }\n\n const data = await manager.fetch(request);\n this._serveChannel!.postMessage({\n type: 'DIAGNOSTICS_RESPONSE',\n requestId,\n data,\n } satisfies DiagnosticChannelMessage);\n break;\n }\n }\n };\n\n this._serveChannel.addEventListener('message', listener);\n this._ctx.onDispose(() => this._serveChannel!.removeEventListener('message', listener));\n }\n\n async discover(): Promise<DiagnosticMetadata[]> {\n invariant(this._clientChannel);\n const diagnostics: DiagnosticMetadata[] = [];\n\n const collector = (event: MessageEvent) => {\n const data = event.data as DiagnosticChannelMessage;\n switch (data.type) {\n case 'DIAGNOSTICS_ANNOUNCE':\n diagnostics.push(...data.diagnostics);\n break;\n }\n };\n\n try {\n this._clientChannel.addEventListener('message', collector);\n this._clientChannel.postMessage({ type: 'DIAGNOSTICS_DISCOVER' } satisfies DiagnosticChannelMessage);\n\n await sleep(DISCOVER_TIME);\n\n // Dedup.\n const result: DiagnosticMetadata[] = [];\n for (const diagnostic of diagnostics) {\n if (!result.some((d) => d.id === diagnostic.id && d.instanceId === diagnostic.instanceId)) {\n result.push(diagnostic);\n }\n }\n\n return diagnostics;\n } finally {\n this._clientChannel.removeEventListener('message', collector);\n }\n }\n\n async fetch(request: DiagnosticsRequest): Promise<DiagnosticsData> {\n invariant(this._clientChannel);\n const requestId = createId();\n\n const trigger = new Trigger<DiagnosticsData>();\n const listener = (event: MessageEvent) => {\n const data = event.data as DiagnosticChannelMessage;\n if (data.type === 'DIAGNOSTICS_RESPONSE' && data.requestId === requestId) {\n trigger.wake(data.data);\n }\n };\n\n try {\n this._clientChannel.addEventListener('message', listener);\n this._clientChannel.postMessage({\n type: 'DIAGNOSTICS_FETCH',\n requestId,\n request,\n } satisfies DiagnosticChannelMessage);\n\n // NOTE: Must have await keyword in this block.\n const result = await trigger.wait({ timeout: DIAGNOSTICS_TIMEOUT });\n\n return result;\n } finally {\n this._clientChannel.removeEventListener('message', listener);\n }\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\ntype TagType = number | string | boolean | null | undefined;\n\nexport interface MetricData {\n unit?: string;\n tags?: Record<string, TagType>;\n timestamp?: number;\n}\n\ninterface MetricsMethods {\n /**\n * Adds a value to a counter metric\n */\n increment(name: string, value?: number, data?: MetricData): void;\n /**\n * Adds a value to a distribution metric\n */\n distribution(name: string, value: number, data?: MetricData): void;\n /**\n * Adds a value to a set metric. Value must be a string or integer.\n */\n set(name: string, value: number | string, data?: MetricData): void;\n /**\n * Adds a value to a gauge metric\n */\n gauge(name: string, value: number, data?: MetricData): void;\n}\n\n/**\n * Allows metrics to be recorded within SDK code without requiring specific consumers.\n */\nexport class RemoteMetrics implements MetricsMethods {\n private _metrics = new Set<MetricsMethods>();\n\n registerProcessor(processor: MetricsMethods): void {\n this._metrics.add(processor);\n }\n\n increment(name: string, value?: number, data?: MetricData): void[] {\n return Array.from(this._metrics.values()).map((processor) => processor.increment(name, value, data));\n }\n\n distribution(name: string, value: number, data?: MetricData): void[] {\n return Array.from(this._metrics.values()).map((processor) => processor.distribution(name, value, data));\n }\n\n set(name: string, value: number | string, data?: MetricData): void[] {\n return Array.from(this._metrics.values()).map((processor) => processor.set(name, value, data));\n }\n\n gauge(name: string, value: number, data?: MetricData): void[] {\n return Array.from(this._metrics.values()).map((processor) => processor.gauge(name, value, data));\n }\n}\n", "// Workerd does not support WeakRef\n\n//\n// Copyright 2024 DXOS.org\n//\n\nclass WeakRefMock<T> {\n // eslint-disable-next-line @typescript-eslint/no-useless-constructor\n constructor(target: T) {\n // do nothing\n }\n\n deref(): T | undefined {\n return undefined;\n }\n}\n\nexport const WeakRef = globalThis.WeakRef ?? WeakRefMock;\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nexport abstract class BaseCounter {\n /**\n * @internal\n */\n _instance: any;\n\n name?: string;\n\n /**\n * @internal\n */\n _assign(instance: any, name: string): void {\n this._instance = instance;\n this.name = name;\n }\n\n abstract getData(): Metric;\n\n _tick(time: number): void {}\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nimport { BaseCounter } from './base';\n\nexport class UnaryCounter extends BaseCounter {\n value = 0;\n units?: string;\n\n constructor({ units }: { units?: string } = {}) {\n super();\n this.units = units;\n }\n\n inc(by = 1): void {\n this.value += by;\n }\n\n getData(): Metric {\n return {\n name: this.name!,\n counter: {\n value: this.value,\n units: this.units,\n },\n };\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nimport { BaseCounter } from './base';\n\nconst MAX_BUCKETS = 60;\n\nexport class TimeSeriesCounter extends BaseCounter {\n private _currentValue = 0;\n private _totalValue = 0;\n private _buckets: number[] = [];\n units?: string;\n\n constructor({ units }: { units?: string } = {}) {\n super();\n this.units = units;\n }\n\n inc(by = 1): void {\n this._currentValue += by;\n this._totalValue += by;\n }\n\n override _tick(time: number): void {\n this._buckets.push(this._currentValue);\n if (this._buckets.length > MAX_BUCKETS) {\n this._buckets.shift();\n }\n this._currentValue = 0;\n }\n\n override getData(): Metric {\n return {\n name: this.name!,\n timeSeries: {\n tracks: [\n {\n name: this.name!,\n units: this.units,\n points: this._buckets.map((value, index) => ({\n value,\n })),\n total: this._totalValue,\n },\n ],\n },\n };\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nimport { BaseCounter } from './base';\n\nconst MAX_BUCKETS = 60;\n\nexport class TimeUsageCounter extends BaseCounter {\n private _currentValue = 0;\n private _totalValue = 0;\n private _buckets: number[] = [];\n\n private _lastTickTime = performance.now();\n\n record(time: number): void {\n this._currentValue += time;\n this._totalValue += time;\n }\n\n beginRecording(): { end: () => void } {\n const start = performance.now();\n return {\n end: () => {\n const end = performance.now();\n this.record(end - start);\n },\n };\n }\n\n override _tick(time: number): void {\n const delta = time - this._lastTickTime;\n this._lastTickTime = time;\n\n const percentage = (this._currentValue / delta) * 100;\n this._buckets.push(percentage);\n if (this._buckets.length > MAX_BUCKETS) {\n this._buckets.shift();\n }\n this._currentValue = 0;\n }\n\n override getData(): Metric {\n return {\n name: this.name!,\n timeSeries: {\n tracks: [\n {\n name: this.name!,\n units: '%',\n points: this._buckets.map((value, index) => ({\n value,\n })),\n total: this._totalValue,\n },\n ],\n },\n };\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nimport { BaseCounter } from './base';\n\nexport class MapCounter extends BaseCounter {\n values = new Map<string, number>();\n units?: string;\n\n constructor({ units }: { units?: string } = {}) {\n super();\n this.units = units;\n }\n\n inc(key: string, by = 1): void {\n const prev = this.values.get(key) ?? 0;\n this.values.set(key, prev + by);\n }\n\n getData(): Metric {\n return {\n name: this.name!,\n multiCounter: {\n records: Array.from(this.values.entries()).map(([key, value]) => ({\n key,\n value,\n })),\n units: this.units,\n },\n };\n }\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Metric } from '@dxos/protocols/proto/dxos/tracing';\n\nimport { BaseCounter } from './base';\n\nexport class CustomCounter extends BaseCounter {\n constructor(private readonly _getData: () => object) {\n super();\n }\n\n override getData(): Metric {\n return {\n name: this.name!,\n custom: {\n payload: this._getData(),\n },\n };\n }\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { trace } from './api';\n\nexport * from './api';\nexport * from './symbols';\nexport * from './trace-processor';\nexport * from './tracing-types';\nexport * from './metrics';\nexport * from './diagnostic';\nexport * from './diagnostics-channel';\nexport * from './remote/metrics';\n\ntrace.diagnostic({\n id: 'process-info',\n name: 'Process Info',\n fetch: async () => {\n return {\n platform: globalThis.process?.platform,\n arch: globalThis.process?.arch,\n versions: globalThis.process?.versions,\n href: globalThis.location?.href,\n };\n },\n});\n"],
|
|
5
|
-
"mappings": "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",
|
|
6
|
-
"names": ["Context", "LifecycleState", "Resource", "TRACE_SPAN_ATTRIBUTE", "symbolTracingContext", "Symbol", "getTracingContext", "target", "infoProperties", "metricsProperties", "LogLevel", "log", "getPrototypeSpecificInstanceId", "BUFFERED_PREFIX", "BufferedSpan", "spanContext", "startTime", "delegate", "options", "id", "traceparent", "Date", "now", "end", "endTime", "setError", "err", "replay", "real", "BufferingTracingBackend", "startSpan", "span", "push", "clear", "length", "drain", "backend", "idMap", "Map", "buffered", "parentContext", "startsWith", "get", "set", "asyncTimeout", "invariant", "createId", "Math", "random", "toString", "slice", "DIAGNOSTICS_TIMEOUT", "
|
|
5
|
+
"mappings": ";AAIA,SAASA,WAAAA,UAASC,gBAAgBC,UAAUC,4BAA4B;;;ACEjE,IAAMC,uBAAuBC,uBAAO,sBAAA;AAYpC,IAAMC,oBAAoB,CAACC,WAAAA;AAChC,SAASA,OAAOH,oBAAAA,MAAyD;IACvEI,gBAAgB,CAAC;IACjBC,mBAAmB,CAAC;EACtB;AACF;;;ACnBA,SAASC,UAA6BC,WAAW;AAGjD,SAASC,sCAAsC;;;ACCxC,IAAMC,kBAAkB;AAO/B,IAAMC,eAAN,MAAMA;;EACKC;EACAC;EACTC;EAEA,SAAS;EACT;EACA;EACA,YAAY;EAEZ,YACWC,SACTC,IACA;SAFSD,UAAAA;AAGT,SAAKH,cAAc;MAAEK,aAAa,GAAGP,eAAAA,GAAkBM,EAAAA;IAAK;AAC5D,SAAKH,YAAYK,KAAKC,IAAG;EAC3B;EAEAC,IAAIC,SAAwB;AAC1B,QAAI,KAAKP,UAAU;AACjB,WAAKA,SAASM,IAAIC,OAAAA;AAClB;IACF;AACA,SAAK,WAAWA,WAAWH,KAAKC,IAAG;AACnC,SAAK,SAAS;EAChB;EAEAG,SAASC,KAAoB;AAC3B,QAAI,KAAKT,UAAU;AACjB,WAAKA,SAASQ,WAAWC,GAAAA;AACzB;IACF;AACA,SAAK,SAASA;AACd,SAAK,YAAY;EACnB;EAEAC,OAAOC,MAAwB;AAC7B,QAAI,KAAK,WAAW;AAClBA,WAAKH,WAAW,KAAK,MAAM;IAC7B;AACA,QAAI,KAAK,QAAQ;AACfG,WAAKL,IAAI,KAAK,QAAQ;IACxB,OAAO;AACL,WAAKN,WAAWW;IAClB;EACF;AACF;AAQO,IAAMC,0BAAN,MAAMA;EACF,WAA2B,CAAA;EACpC,WAAW;EAEXC,UAAUZ,SAAuC;AAC/C,UAAMa,QAAO,IAAIjB,aAAaI,SAAS,EAAE,KAAK,QAAQ;AACtD,SAAK,SAASc,KAAKD,KAAAA;AACnB,WAAOA;EACT;;EAGAE,QAAc;AACZ,SAAK,SAASC,SAAS;EACzB;;;;;;;;EASAC,MAAMC,SAAwD;AAC5D,UAAMC,QAAQ,oBAAIC,IAAAA;AAElB,eAAWC,YAAY,KAAK,UAAU;AACpC,UAAIC,gBAAgBD,SAASrB,QAAQsB;AACrC,UAAIA,iBAAiBA,cAAcpB,YAAYqB,WAAW5B,eAAAA,GAAkB;AAC1E2B,wBAAgBH,MAAMK,IAAIF,cAAcpB,WAAW,KAAKoB;MAC1D;AAEA,YAAMZ,OAAOQ,QAAQN,UAAU;QAAE,GAAGS,SAASrB;QAASsB;QAAexB,WAAWuB,SAASvB;MAAU,CAAA;AAEnG,UAAIY,KAAKb,aAAa;AACpBsB,cAAMM,IAAIJ,SAASxB,YAAYK,aAAaQ,KAAKb,WAAW;MAC9D;AAEAwB,eAASZ,OAAOC,IAAAA;IAClB;AACA,SAAK,SAASM,SAAS;AACvB,WAAOG;EACT;AACF;;;AC3GA,SAASO,oBAAoB;AAC7B,SAASC,iBAAiB;;;ACAnB,IAAMC,WAAW,MAAMC,KAAKC,OAAM,EAAGC,SAAS,EAAA,EAAIC,MAAM,CAAA;;;ADK/D,IAAA,eAAaC;;;;;EAuBX;;cAESC,IAAAA,OAAAA,MAAAA,eAAAA;SACAC,KAAAA;SACUC,QAAAA;AAChB,SAAA,OAAA;AAEHC,SAAAA,gBAAmB;;EAEnB,aAAA;AACF,SAAA,cAAA;EAEA;;AAGWC,IAAAA,qBAAAA,MAAkD;EAEnDC,aAAAA,SAAmC;EAE3C,WAAIC,oBAAAA,IAA6B;iBACpB;EACb,IAAA,cAAA;AAEAC,WAAAA,KAAeC;;EAEf,eAAA,KAAA;AAEAC,SAAAA,eAAmBC;;qBAENN,QAASO;iBACXP,IAAAA,oBAAuBQ,OAAE,IAAA,OAAA,OAAA,OAAA,QAAA,OAAA,IAAA,MAAA;AAChC,UAAA,KAAA,SAAA,IAAA,OAAA,EAAA,MAAA,MAAA;AACF,aAAA,SAAA,OAAA,OAAA,EAAA;MACI;IACJ,CAAA;AACF,SAAA,SAAA,IAAA,OAAA,IAAA,IAAA;AAEAC,WAA6B;;;iBAGzBC,KAAAA,KAAY,SAAKA,OAAU,CAAA,EAAA,IAAA,CAAAC,iBAAA;MAC3BT,IAAAA,YAAa;MACbL,YAAMc,KAAWd;MACnB,aAAA,KAAA;MACF,MAAAc,YAAA;IAEMf,EAAAA;;cAEFgB,SAAUC;AACZ,QAAA,QAAA,cAAA,MAAA;AACA,gBAAY,QAAGA,eAAAA,KAAAA,YAAAA,uBAAAA,EAAAA,YAAAA,YAAAA,GAAAA,cAAAA,GAAAA,IAAAA,GAAAA,MAAAA,GAAAA,CAAAA,0CAAAA,uBAAAA,EAAAA,CAAAA;IACf;AACAD,UAAAA,EAAAA,GAAUD,IAAAA;AACV,UAAIA,cAAA,KAAA,SAAA,IAAA,EAAA;cACIG,aAAO,wBAAmBH,EAAAA,YAAoBhB,YAAAA,GAAAA,cAAAA,GAAAA,IAAAA,GAAAA,MAAAA,GAAAA,CAAAA,cAAAA,wBAAAA,EAAAA,CAAAA;QACpD;YACEa,OAAAA,MAAAA,aAAAA,YAAAA,MAAAA,GAAAA,mBAAAA;aACAE;QACAI;QACF,YAAA,KAAA;QACA;MACA;aACEN,KAAAA;aACAE;QACAI;QACAC,YAAWC,KAAK;QAClB,MAAA;QACF,OAAA,IAAA;MACF;IACF;;;;;AElGA,SAASC,SAASC,aAAa;AAC/B,SAASC,eAAe;AACxB,SAASC,aAAAA,kBAAiB;AAW1B,IAAAC,gBAAMC;AAuBN,IAAA,uBAAaC;;AACX,IAAA,qBAAA,MAAA,oBAAuB;;EAEvB,WAAA,YAAA;AAEQC,WAAWC,WAAU,oBAAA;EAE7B;EACiBC,OAAAA,IAAAA,QAAmCC,QAAU,EAAA,YAAA,YAAA,GAAAN,eAAA,GAAA,GAAA,CAAA;;EAG9D,gBAA6BO;mBAAAA;cACvBL,eAAmBM,sBAAW;SAChC,eAAKH;QACL,oBAAmB,WAAOI;AAC5B,WAAA,gBAAA,IAAA,iBAAA,YAAA;AACF,WAAA,iBAAA,IAAA,iBAAA,YAAA;IAEAC;;YAEOL;AACL,SAAKM,KAAAA,KAAAA,QAAgBC;AACvB,SAAA,eAAA,MAAA;AAEA,SAAA,gBAAA,MAAA;;;;;;;UAOK;QACA,KAAKD,iBAAuBE,OAAK,KAAA,cAAA,UAAA,YAAA;AACpC,WAAA,cAAA,MAAA;AACF,WAAA,eAAA,MAAA;IAEAC;;QAEE,SAAMC;eACJ,KAAQC,eAAe,QAAA,EAAA,YAAA,YAAA,GAAAhB,eAAA,GAAA,IAAA,GAAA,MAAA,GAAA,CAAA,sBAAA,EAAA,EAAA,CAAA;qBAChB,OAAA,UAAA;oBAAwB,KAAA,MAAA;;gBAGzBiB,cAAM,QAAA,KAAA;eACNC,cAAAA,YAAAA;YACF,MAAA;YACA;UACF,CAAA;AACK;QAAqB;;gBAItB,EAAA,WAAA,QAAA,IAAA,MAAA;AACF,cAAA,QAAWC,cAAQC,QAAe,QAAQD,eAAQC,QAAW,YAAaA;AACxE;UACF,WAAA,QAAA,eAAA,QAAA,QAAA,gBAAA,QAAA,aAAA;AAEA;UACA;gBACEH,OAAM,MAAA,QAAA,MAAA,OAAA;eACNI,cAAAA,YAAAA;YACAC,MAAAA;YACF;YACA;UACF,CAAA;AACF;QACF;MAEI;IACJ;AACF,SAAA,cAAA,iBAAA,WAAA,QAAA;AAEA,SAAMC,KAAAA,UAA0C,MAAA,KAAA,cAAA,oBAAA,WAAA,QAAA,CAAA;;QAE9C,WAAML;AAEN,IAAAM,WAAMC,KAAAA,gBAAaT,QAAAA,EAAAA,YAAAA,YAAAA,GAAAA,eAAAA,GAAAA,IAAAA,GAAAA,MAAAA,GAAAA,CAAAA,uBAAAA,EAAAA,EAAAA,CAAAA;UACjB,cAAaA,CAAAA;UACb,YAAaC,CAAAA,UAAI;YACf,OAAK,MAAA;mBACHC,MAAAA;aACA;AACJ,sBAAA,KAAA,GAAA,KAAA,WAAA;AACF;MAEI;;QAEF;WAAkCD,eAAM,iBAAA,WAAA,SAAA;AAAuB,WAAA,eAAA,YAAA;QAE/D,MAAMS;MAEN,CAAA;AACA,YAAMC,MAAAA,aAAiC;YAErC,SAAKA,CAAOC;iBACVD,eAAYE,aAAAA;AACd,YAAA,CAAA,OAAA,KAAA,CAAA,MAAA,EAAA,OAAAA,YAAA,MAAA,EAAA,eAAAA,YAAA,UAAA,GAAA;AACF,iBAAA,KAAAA,WAAA;QAEA;MACF;AACE,aAAKlB;IACP,UAAA;AACF,WAAA,eAAA,oBAAA,WAAA,SAAA;IAEA;;QAEE,MAAMU,SAAAA;AAEN,IAAAG,WAAMM,KAAAA,gBAAcC,QAAAA,EAAAA,YAAAA,YAAAA,GAAAA,eAAAA,GAAAA,KAAAA,GAAAA,MAAAA,GAAAA,CAAAA,uBAAAA,EAAAA,EAAAA,CAAAA;AACpB,UAAMhB,YAAYC,SAAAA;UAChB,UAAMM,IAAON,QAAU;UACvB,WAAa,CAAA,UAAK;YAChBc,OAAQE,MAAKV;AACf,UAAA,KAAA,SAAA,0BAAA,KAAA,cAAA,WAAA;AACF,gBAAA,KAAA,KAAA,IAAA;MAEI;;QAEF;WACEL,eAAM,iBAAA,WAAA,QAAA;WACNI,eAAAA,YAAAA;QACAF,MAAAA;QACF;QAEA;MACA,CAAA;AAAiE,YAAA,SAAA,MAAA,QAAA,KAAA;QAEjE,SAAOQ;MACT,CAAA;AACE,aAAKhB;IACP,UAAA;AACF,WAAA,eAAA,oBAAA,WAAA,QAAA;IACF;;;;;AC3IO,IAAMsB,gBAAN,MAAMA;EACHC,WAAW,oBAAIC,IAAAA;EAEvBC,kBAAkBC,WAAiC;AACjD,SAAKH,SAASI,IAAID,SAAAA;EACpB;EAEAE,UAAUC,MAAcC,OAAgBC,MAA2B;AACjE,WAAOC,MAAMC,KAAK,KAAKV,SAASW,OAAM,CAAA,EAAIC,IAAI,CAACT,cAAcA,UAAUE,UAAUC,MAAMC,OAAOC,IAAAA,CAAAA;EAChG;EAEAK,aAAaP,MAAcC,OAAeC,MAA2B;AACnE,WAAOC,MAAMC,KAAK,KAAKV,SAASW,OAAM,CAAA,EAAIC,IAAI,CAACT,cAAcA,UAAUU,aAAaP,MAAMC,OAAOC,IAAAA,CAAAA;EACnG;EAEAM,IAAIR,MAAcC,OAAwBC,MAA2B;AACnE,WAAOC,MAAMC,KAAK,KAAKV,SAASW,OAAM,CAAA,EAAIC,IAAI,CAACT,cAAcA,UAAUW,IAAIR,MAAMC,OAAOC,IAAAA,CAAAA;EAC1F;EAEAO,MAAMT,MAAcC,OAAeC,MAA2B;AAC5D,WAAOC,MAAMC,KAAK,KAAKV,SAASW,OAAM,CAAA,EAAIC,IAAI,CAACT,cAAcA,UAAUY,MAAMT,MAAMC,OAAOC,IAAAA,CAAAA;EAC5F;AACF;;;AClDA,IAAMQ,cAAN,MAAMA;;EAEJ,YAAYC,QAAW;EAEvB;EAEAC,QAAuB;AACrB,WAAOC;EACT;AACF;AAEO,IAAMC,UAAUC,WAAWD,WAAWJ;;;ANa7C,IAAAM,gBAAaC;;;EACX;;;;;;;;cASkBC,MAAAA,UAAAA,YAAAA;SACAC,OAAAA;AAEhB,SAAKC,WAAAA;AACP,SAAA,aAAA;AAEAC,SAAAA,qBAA4C,kBAAA,KAAA,SAAA;;EAE5C,UAAA,MAAA;AACF,WAAA,KAAA,KAAA,SAAA,KAAA,CAAA,WAAA,OAAA,SAAA,IAAA;EAEA;AACA;AAEA,IAAMC,uBAAAA;AAEN,IAAA,kBAAaC;IACKC,wBAAkBC;AAClBC,IAAAA,iBAAAA,MAAqB;EACrBC,cAAAA,IAAgB,mBAAoB;EAE3C,qBAAoB,IAAIC,mBAAAA;EACjC,gBAAc,IAAmB,cAAK;EAEtC,oBAAA,IAAA,wBAAA;;;;;;;;;;;EAWA,IAAA,iBAAA;AAEIC,WAAAA,KAAAA;;qBAEK,SAAA;QACL,CAAA,WAAK,YAAiB,KAAK,mBAAiB;AAC5C,WAAA,kBAAA,MAAA;AACF,WAAA,iBAAA,KAAA;AACA;IACA;UACEC,QAAAA,KAAYC,kBAAAA,MAAAA,OAAAA;0BACJC;iBACFA,CAAAA,YAAQC;cACV,SAAMC,QAAaC;YACnB,QAAID,YAAY,WAAA,eAAA,GAAA;gBACd,aAAeJ,MAAAA,IAAU,OAAA,WAAA;0BAAKC;mBAASK,QAAAA,UAAeF;cAAW,GAAA;cACnE,eAAA;YACF,CAAA;UACA;QACF;AACF,eAAA,QAAA,UAAA,OAAA;MACF;IAESG;EACAC;EACAC,YAAAA,oBAAAA,IAA8B;EAE9BC,wBAAsB,oBAAA,QAAA;EAEvBC,iBAA8B,CAAA;EAEtC,OAAA,CAAA;iBACMC;gBAEAC;QACF,aAAKjB,KAAAA,cAAyB,KAAKF,IAAAA,GAAAA,QAAW,EAAA,YAAA,YAAA,GAAAR,eAAA,GAAA,IAAA,GAAA,KAAA,CAAA;AAChD,QAAA,mBAAA,WAAA;AACI,WAACU,mBAAmBkB,MAAK,KAAA,WAAA;IAC/B;AAEAC,SAAAA,mBAAkC,MAAA;;iBAE3BrB,KAAW;AAClB,SAAA,eAAA;AAEA,SAAA,YACAsB,eAAAA,GAAoBC;;;EAGZC,oBAAiBC,QAAkBC;AACzC,UAAK,KAAMC,KAAAA,UAAcC;UACtBL,iBAAgBI,kBAAoCjC,OAAQ,eAAEiC,OAAAA,QAAAA,CAAAA;AACjE,eAAA,OAAA,OAAA,KAAA,eAAA,iBAAA,GAAA;AAEA,aAAME,SAAYpC,GAAAA,EAAAA,QAChB,OAAA,UAAA,GAAA;;UAEEqC,QAAAA,IAAWP,cAAO;MAClBQ;MACAC,WAAWC,OAAAA,YAAgBV;MAC3BW,YAAS,+BAAA,OAAA,QAAA;MACTC,MAAAA,KAAS,gBAAKC,OAAmBb,QAAO7B;MAE1C,OAAI2C,CAAAA;MAIF,SAACxB,KAAa,mBAAKgB,OAAAA,QAAAA;IACvB,GAAA,IAAKf,QAAAA,OAAAA,QAAyB,GAACS,OAAO7B,UAAUmC;AAChD,SAAKd,UAAAA,IAAc,IAACuB,KAAKC;AACzB,SAAI,sBAAoBC,IAAM,OAAGC,UAAAA,KAAAA;SAC/B,eAAKC,KAAe,EAAA;AACtB,QAAA,KAAA,eAAA,SAAA,sBAAA;AACF,WAAA,gBAAA;IAEA;EACAC;;UAGM,QAAQ,OAAA,MAAA;EAAA;mBAEL;SACL9B,QAAAA;;iBAGIgB,OAAU,YAAA,MAAA,KAAA,KAAA,UAAA,QAAA,CAAA,EAAA,IAAA,CAAA,CAAA,IAAA,KAAA,MAAA;QACX,GAAA,MAAA,kBAAA,IAAA,MAAA,KAAA,UAAA;QAEG,MAAKb;MACb,CAAA,CAAA;MACF,MAAA,KAAA,KAAA,OAAA,CAAA4B,SAAAA,KAAA,SAAA,SAAA,IAAA;IAEAX;;kBAEQT,UAAAA;AACN,UAAK,MAAOG,CAAAA;UACV,iBAAI,kBAAA,OAAA,eAAA,QAAA,CAAA;eACF,CAAA,KAAMkB,EAAAA,QAAQ,CAAA,KAAOnD,OAASiC,QAAS,eAAajC,cAAa,GAAKA;UACtE;cACEoD,QAAQ,OAAGvC,SAAasC,GAAAA,MAAM,aAAA,SAAA,GAAA,EAAA,IAAA,SAAA,GAAA;AAChC,YAAA,QAAO,MAAA;AACLC,cAAInB,GAAAA,IAAOoB,QAAAA,KAAAA,KACTF;QAIJ,OAAA;AACA,cAAOG,GAAU,IAAA,cAAA,OAAA,QAAA,UAAA,SAAA,IAAA,QAAA,SAAA,uBAAA,IAAA;QACjBF;MACF,SAAA,KAAA;AACF,YAAA,GAAA,IAAA,IAAA;MAEA;IACF;AAEAV,WAAAA;;qBAEQZ,UAAiBC;AACvB,UAAK,MAAOE,CAAAA;UACVmB,iBAAkBnB,kBAAY,OAAA,eAAA,QAAA,CAAA;AAChC,eAAA,CAAA,KAAA,KAAA,KAAA,OAAA,QAAA,eAAA,iBAAA,GAAA;AAEA,UAAOmB,KAAAA,SAAAA,GAAAA,EAAAA,QAAAA,CAAAA;IACT;AAEAG,WAAAA;;gBAESpB,UAAQA;AACjB,UAAA,QAAA,KAAA,sBAAA,IAAA,QAAA;AAEAqB,WAAAA,QAAAA,MAAyBpB,KAAAA,KAAiB;;2BACf,WAAO;WAAIqB;MAGtC,GAAA,KAAA,UAAA,OAAA;IAEAC,EAAAA,OAAAA,CAAAA,QAAAA,IAAAA,KAA0BzD,cAAqC,aAAA,IAAA,uBAAA,SAAA;;4BACnC0D,YAAM;WAAIF;MACtC,GAAA,KAAA,UAAA,OAAA;IAEAG,EAAAA,OAAgB,CAAA,QAAA,IAAA,eAAA,UAAA;;YAEZ;eACK5D,aAAU,KAAA,UAAA,OAAA,GAAA;YACb,WAAA6D,UAAA,SAAA,MAAA;AACF,UAAA,CAAA,UAAA;AAEA;MACA;AACC7D,YAAAA,iBAA8B8D,kBAAAA,OAAAA,eAAAA,QAAAA,CAAAA;AAC/B,YAAK,OAAM7B,YAAcC,IAAI;eAC1BlC,OAASiC,IAAqB8B;AACjC,iBAAA,OAAA,OAAA,KAAA,eAAA,iBAAA,GAAA;AAEAF,iBAAa,GAACvB,EAAI,QAAQC,IAAAA;MAC1BsB;AACF,MAAAA,UAAA,KAAA,OAAA,KAAA,gBAAA,QAAA;AACF,MAAAA,UAAA,KAAA,UAAA,KAAA,mBAAA,QAAA;IAEQb;;oBAEEH;WACN,KAAK1B,eAAiB0B,SAAAA,sBAAAA;AACxB,YAAA,KAAA,KAAA,eAAA,MAAA;AACF,WAAA,UAAA,OAAA,EAAA;IAEQmB;;WAEFd,MAAK5B;SACP,KAAKA,KAAK2C,IAAAA;AACZ,QAAA,KAAA,KAAA,SAAA,iBAAA;AACF,WAAA,KAAA,MAAA;IAEQC;;kBAECC,CAAAA,QAASC,UAAK;YACnB,MAAKD,OAASE;MACd,KAAKF,SAASG;WAAO,SAAA;oBACbC;AAEN,cAAKV,QAAAA,MAAU,MAAA;cACbA,YAAA,KAAA,sBAAA,IAAA,KAAA;AACF,YAAA,CAAAA,WAAA;AAEA;;AAAgE,cAAA,UAAA;UAC5D1B,GAAAA,MAAMqC;;AAEV,YAAA,MAAA,kBAAA,QAAA;AAEA,kBAAQC,QAAUC,MAAM;QACxB;cACEC,EAAAA,UAAaA,KAAK,IAAA,MAAA;cAClBC,cAAeA;UACfC,OAAAA,MAAAA;UACAC,SAAAA,MAAeC,WAAWD,MAAAA,iBAAS;UACnCE;qBACQP,IAAAA,KAAAA,MAAY,SAAA;gBAClBC;YACAO,MAAAA,YAAYpB;YACd,MAAA,QAAA;YACF,YAAAA,UAAA,KAAA;UACI;QACJ;AACF,aAAA,SAAA,WAAA;AACA;MACF;MACA;IACJ;EAEA;AAEA;AACE,IAAQ,kBAAOV,WAAAA,oBAAAA,IAAAA,eAAAA;oBACR,CAAA,OAAA,OAAA,mBAAA;UACL,OAAK,OAAA;IACL,KAAK;IACL,KAAK;SACH;IACF,KAAK;AACL,aAAK;SACH;;AAEA,UAAA,UAAA,MAAA;AAEA,eAAA;;;cAGI,gBAAU+B,eAAchF,sBAAsBgF,IAAAA,KAAkB;AAClE,YAAA,eAAA;AACF,iBAAA,GAAA,cAAA,kBAAA,IAAA,cAAA,KAAA,UAAA;QAEI;;AAEJ,UAAA,OAAA,MAAA,WAAA,YAAA;AAEIC,eAAAA,cAAW,MAAA,OAAA,GAAA,OAAA,cAAA;;kBAEX,GAAOnD;AAGT,YAAA,UAAWoD,KAAAA,GAAUjC;AACnB,iBAAOnB,OAAOqD,YACZC,MAAMC,KAAKpC,MAAMqC,QAAO,CAAA,EAAIC,IAAI,CAACtC,WAAMA,cAAWA,QAAA,QAAA,GAAA,cAAA,CAAA,CAAA;6BAAClB,KAAAA,GAAAA;wBAAKoB,YAAcF,MAAOgC,KAAQ,MAAGO,QAAAA,CAAAA,EAAAA,IAAAA,CAAAA,CAAAA,KAAAA,MAAAA,MAAAA;YAAgB;YAEjGJ,cAAcnC,QAAQ,QAAA,GAAA,cAAA;UAC/B,CAAA,CAAA;QACF,WAAW,MAAA,QAAOA,KAAU,GAAA;AAC1B,iBAAMC,MAAY,IAAA,CAAA,SAAA,cAAA,MAAA,QAAA,GAAA,cAAA,CAAA;mBACb,OAAMnB,UAAOD,UAAYmB;gBAC5BC,MAAQ,CAAA;AACV,qBAAA,OAAA,OAAA,KAAA,KAAA,GAAA;AACA,gBAAOA,GAAAA,IAAAA,cAAAA,MAAAA,GAAAA,GAAAA,QAAAA,GAAAA,cAAAA;UACT;AACF,iBAAA;QAEI;;AAEJ,UAAA,OAAA,MAAA,aAAA,YAAA;AAEA,eAAOD,MAAMwC,SAAQ;MACzB;AACF,aAAA,MAAA,SAAA;EAEA;;AAEE,IAAMC,oBAAiB,CAAA,cAAA;AACvB,MAAA,OAAUC,UAAWD,QAAAA,OAAAA,EAAAA;AACrB,QAAIE,iBAAG;QACLD,IAAAA,KAAOA,MAAU,cAAU/C;AAC7B,MAAA,GAAA;AACA,WAAO+C,KAAAA,MAAAA,GAAAA,CAAAA,EAAAA,CAAAA,EAAAA,MAAAA;EACP;AAEF,SAAME;AAIN;;;;;AFrVA,IAAAC,gBAAMC;AAKN,IAAA,iBAAA,uBAAA,6BAAA;;AAME,IAAKC,wBAAO,CAAA,UAAA,mBAAA;QACV,QAAA,OAAA,eAAA,QAAA;AACF,MAAA,CAAA,OAAA;AACA;EACA;QACE,iBAAaC,kBAAe,KAAA;aAC1B,CAAA,KAAA,EAAA,QAAA,CAAA,KAAA,OAAA,QAAA,eAAA,cAAA,GAAA;AACF,QAAA,CAAA,QAAA,eAAA;AACI;;QAEF;YACE,QAAMC,OAAWC,SAAQC,GAAI,MAAGD,aAAaE,SAASC,GAAAA,EAAOD,IAAAA,SAAAA,GAAAA;UAC7DE,SAAAA,MAAe;AACjB,cAAA,WAAA,QAAA,OAAA,QAAA,KAAA,KAAA,IAAA,OAAA,KAAA;AACA,uBAAM,OAAA,GAAA,EAAA,IAAA;MACN;IACF,QAAA;IAEJ;EAcA;;eAOY,CAAIC,YAAO,CAAA,gBAAA;AACnB,MAAA,SAAA,aAAA,EAAA,YAAA,qBAAA,WAAA;AAEA,UAAMC,IAAS,MACb,iDAAcC,YAAAA,IAAAA,qBAAAA;;gBAEV,uBAAK,cAAIC,YAAAA;mBACTC,MAAgBC;YAAsBH,GAAAA,IAAAA;sBAAyBP,oBAASW;QAAYC;QAAe,YAAA,SAAA;QACrG,UAAA;MACF,CAAA;IAEEZ;EACF,GAAA;MACA,SAAMH,WAAcgB;AACpB,UAAMC,gBAAejB,kBAAU,YAAA,IAAA;AAC/B,UAAMkB,QAAAA,MAAAA;AAENlB,UAAMmB,eAAO,MAAA;UACX,gBAAiB,MAAA;UAEjB,OAASC,eAAe,KAAKC;YAC3B,OAAOJ;AACT,UAAA,KAAA,oBAAA,eAAA,QAAA;AAEA,eAAMK,aAAAA,KAAoBC,MAAKC,GAAAA;MAC/B;AACA,YAAMjB,oBAAuC,KAAA,aAAA,oBAAA;AAC7C,YAAIkB,gBAAe,gBAAA,sBAAA,IAAA,IAAA;YACjBlB,iBAAemB,CAAAA;AACjB,UAAA,eAAA;AAEA,uBAAmBd,aAAAA,cAAgBe;;YAEjCC,aAAI,gBAAA,gBAAA,UAAA;QACJC,MAAAA,GAAAA,aAAYtB;QACZuB,IAAAA;QACF,YAAA;QACI,eAAC/B;MAEL,CAAA;AACA,WAAIgC,cAAYC,IAAAA;UACd,UAAMC;sBAAgBC,eAAqB,MAAEH;AAAuB,cAAA,aAAA;UACpEI,CAAAA,oBAAoBC,GAAO,WAAA;;AAAyB,kBAASC,MAAAA,IAAQ,OAAA;UAAER,YAAYI;QAAW,CAAA,IAAA,IAAAI,SAAA;UAChG,YAAA;QAEI,GAAA,EAAA,YAAA,YAAA,GAAAvC,eAAA,GAAA,GAAA,CAAA;;AAEJ,UAAE;AACAiC,eAAAA,MAAYO,aAAWC,KAAAA,MAAAA,OAAAA;eACvBR,KAAAA;AACAS,oBAAKzC,WAAkB0C,GAAAA;AACvB,oBAAMF,IAAAA;AACR,aAAA,cAAA,IAAA;AACF,cAAA;MAEAvC;;UAEE,QAAM+B,eAA0ChC,KAAAA;AAChD,YAAI,OAAA;YACF,aAAamB,KAAAA,cAAmB;AAClC,UAAE;AACAa,eAAAA,MAAYO,cAAWC,KAAAA,MAAAA,GAAAA;eACvB,KAAMA;AACR,oBAAU,WAAA,GAAA;AACR,cAAIR;;YAEFS,YAAKzC;AACP,qBAAA,IAAA;AACF,eAAA,cAAA,IAAA;QACF;MACF;IAEA2C;;AAA+D,SAAA,eAAA,OAAA,QAAA;IAC/D,OAAOjC,YAAAA;EACT,CAAA;AAgCF,SAAA;;WAM8DN,CAAAA,OAASwC,CAAAA,MAAAA,CAAAA,QAAAA,aAAAA,eAAAA;AAAK,oBAAA,MAAA,EAAA,eAAA,WAAA,IAAA;IAC1E,SAAA;EAEIC;AACJC;AACF,IAAA,OAAA,CAAA,SAAA;AAUA,cAAA,KAAA,IAAA;;IASIC,OAAAA,CAAAA,EAAWzC,wBAAmC,OAAY,sBAAA,MAAA,IAAA,WAAA,IAAA,CAAA,MAAA,CAAA,QAAA,aAAA,eAAA;QACxD,SAAM0C,WAAgB;aAChBC,QAAAA,kBAAyB,MAAA;AAE/B,UAAM1B,YAAAA,KAAAA,CAAAA,aAA+BE,WAAAA,KAAaU,CAAAA,IAAAA;AAElD,UAAMT,UAAAA,YAAgBb,IAAAA;AACtB,UAAMqC,oBAAYxB,WAAeyB,aAAAA,oBAAsBC;AACvD,UAAMC,gBAAcH,gBAAaI,sBAAa,IAAA,IAAA;AAE9C,UAAM9C,YAAAA,eAAuC,sBAAA,kBAAA,OAAA,aAAA,QAAA,SAAA;AAC7C,UAAIkB,WAAAA,GAAe,SAAA,IAAA,WAAA;UACjBlB,iBAAemB,CAAAA;AACjB,QAAA,eAAA;AACA4B,qBAAAA,aAA4B/C,cAAAA;IAC5B;0BACmBF,MAAM,cAAWkD;oBAChChD;AACF,iBAAA,CAAA,KAAA,KAAA,KAAA,OAAA,QAAA,UAAA,GAAA;AACF,uBAAA,IAAA,WAAA,MAAA,IAAA,MAAA,OAAA,GAAA,EAAA,IAAA;MAEA;;UAGMqB,aAAU,sBAAA,gBAAA,gBAAA,UAAA;MACVC,MAAAA;MACAC,IAAAA,MAAAA;MACF,YACAW;MAEAe,eAAWC;IACf,CAAA,IAAIV;QACF,WAAMW;mBAEmB7B;uBAAeK,YAAAA,eAAkCF,OAAAA,UAAW,OAAA;QAAC,YAAA;UAChFe,CAAAA,oBAAgB,GAAA,WAAA;QACtBS;WAAYE,UAAAA,OAAAA;iBAAaD;QAAc;QACzC,GAAA,KAAA,MAAA,CAAA;MAEI;;AAEJ,QAAE;AACA1B,aAAAA,MAAYO,OAAAA,MAAWC,MAAAA,QAAAA;aACvB,KAAMA;AACR,kBAAU,WAAA,GAAA;AACRR,YAAAA;;kBAEEc,IAAYc;mCAA2BX,OAAAA,YAAAA,aAAAA,YAAAA,YAAAA;oBAAcH,QAAAA,UAAe;UAAG,OAAA;UACzE,KAAA,YAAA,IAAA;QACF,CAAA;MACF;IACF;EAEIe;AACN;AAaA,IAAA,cAAA,oBAAA,IAAA;;IAaI,YAAcb,CAAAA,WAAS;AACzB,MAAA,YAAA,IAAA,OAAA,EAAA,KAAA,qBAAA,IAAA,OAAA,EAAA,GAAA;AAEA,WAAMtB,OAAAA;EACN;AACA,QAAM2B,gBAAcH,gBAAaY,sBAAmB,IAAA,OAAA,QAAA;AAEpD,QAAIA,YAAOC,eAAqB,sBAAE;QAChCC,WAAAA,GAAAA,SAAyBF,IAAAA,OAAW,UAAA;aAAEG,uBAAMZ;yBAAmBP,IAAYoB,OAAG,IAAA;MAAG,MAAA;MACnF,SAAA,YAAA,IAAA;IAEIJ,CAAAA;;AAEJ,MAAA,OAAA,wBAAA,SAAA,CAAA,gBAAA,gBAAA;AAEA,WAAMvC,OAAAA;EAEN;AACA,QAAIG,oBAAe,OAAA,WAAA,aAAA,oBAAA;QACjBlB,iBAAemB,CAAAA;AACjB,MAAA,eAAA;AACA4B,mBAAAA,aAA6BvC,cAAUR;EACvC;wBACmBF,OAAM,UAAWkD,cAAe1B;aAC/CtB,YAAe2D;AACjB,eAAA,CAAA,KAAA,KAAA,KAAA,OAAA,QAAA,OAAA,UAAA,GAAA;AACF,qBAAA,IAAA,WAAA,MAAA,IAAA,MAAA,OAAA,GAAA,EAAA,IAAA;IAEA;;QAEEtC,aAAa,gBAAI,eAAA,UAAA;IACjBC,MAAAA;IACAC,IAAAA,OAAAA,MAAeR;IACjB,YAAA;IACAsC,eAAgBC;EAEhB,CAAA;cACSA,IAAAA,OAAOd,IAAS,UAAQ;aAAElB,aAAY,WAAA,eAAA,MAAA;kBAAGK,UAAAA,OAAqB;MAAyB,YAAA;QAAE,CAAA,oBAAA,GAAA,WAAA;MAClG;IACA,CAAA;EACF;AAEA,SAAA,OAAA;;AAKE,IAAIH,UAAY,CAAA,OAAA;QACdA,aAAc,YAAA,IAAA,EAAA;MACd6B,YAAYO;AACd,eAAA,IAAA;AAEA,gBAAMC,OAAaL,EAAAA;EACnB;QACElB,aAAYc,qBAAuB,IAAE,EAAA;oBAASS,OAAAA,YAAkB,aAAA,YAAA,YAAA;gBAAOvB,QAAAA,WAAe,MAAA;MAAG,OAAA,WAAA;MACzFkB,KAAAA,YAAqBI,IAAAA;IACvB,CAAA;AACF,yBAAA,OAAA,EAAA;EAEA;;AAKA,IAAA,iBAAA,MAAA,CAAA,QAAA,aAAA,eAAA;AAIME,oBAAwBC,MAAY3B,EAAAA,kBAAyB,WAAA,IAAA,CAAA;AACjE/B;AACF,IAAA,UAAA,CAAA,QAAA,OAAA,OAAA,CAAA,MAAA;AAqBA,kBAAA,QAAA,QAAA,OAAA,IAAA;;AAKA,IAAA,aAAA,CAAA,WAAA;AAEA,SAAO,gBAAc,YAAA,mBAAA,MAAA;;AAEnB2D,IAAAA,QAAAA;EACAC;EACA5B;EACA6B;EACAC;EACAC;EACAC;EACAC;EACAC;EACA;;;;;AS5XK,IAAeC,cAAf,MAAeA;;;;EAIpBC;EAEAC;;;;EAKAC,QAAQC,UAAeF,MAAoB;AACzC,SAAKD,YAAYG;AACjB,SAAKF,OAAOA;EACd;EAIAG,MAAMC,MAAoB;EAAC;AAC7B;;;ACjBO,IAAMC,eAAN,cAA2BC,YAAAA;EAChCC,QAAQ;EACRC;EAEA,YAAY,EAAEA,MAAK,IAAyB,CAAC,GAAG;AAC9C,UAAK;AACL,SAAKA,QAAQA;EACf;EAEAC,IAAIC,KAAK,GAAS;AAChB,SAAKH,SAASG;EAChB;EAEAC,UAAkB;AAChB,WAAO;MACLC,MAAM,KAAKA;MACXC,SAAS;QACPN,OAAO,KAAKA;QACZC,OAAO,KAAKA;MACd;IACF;EACF;AACF;;;ACtBA,IAAMM,cAAc;AAEb,IAAMC,oBAAN,cAAgCC,YAAAA;EAC7BC,gBAAgB;EAChBC,cAAc;EACdC,WAAqB,CAAA;EAC7BC;EAEA,YAAY,EAAEA,MAAK,IAAyB,CAAC,GAAG;AAC9C,UAAK;AACL,SAAKA,QAAQA;EACf;EAEAC,IAAIC,KAAK,GAAS;AAChB,SAAKL,iBAAiBK;AACtB,SAAKJ,eAAeI;EACtB;EAESC,MAAMC,MAAoB;AACjC,SAAKL,SAASM,KAAK,KAAKR,aAAa;AACrC,QAAI,KAAKE,SAASO,SAASZ,aAAa;AACtC,WAAKK,SAASQ,MAAK;IACrB;AACA,SAAKV,gBAAgB;EACvB;EAESW,UAAkB;AACzB,WAAO;MACLC,MAAM,KAAKA;MACXC,YAAY;QACVC,QAAQ;UACN;YACEF,MAAM,KAAKA;YACXT,OAAO,KAAKA;YACZY,QAAQ,KAAKb,SAASc,IAAI,CAACC,OAAOC,WAAW;cAC3CD;YACF,EAAA;YACAE,OAAO,KAAKlB;UACd;;MAEJ;IACF;EACF;AACF;;;AC3CA,IAAMmB,eAAc;AAEb,IAAMC,mBAAN,cAA+BC,YAAAA;EAC5BC,gBAAgB;EAChBC,cAAc;EACdC,WAAqB,CAAA;EAErBC,gBAAgBC,YAAYC,IAAG;EAEvCC,OAAOC,MAAoB;AACzB,SAAKP,iBAAiBO;AACtB,SAAKN,eAAeM;EACtB;EAEAC,iBAAsC;AACpC,UAAMC,QAAQL,YAAYC,IAAG;AAC7B,WAAO;MACLK,KAAK,MAAA;AACH,cAAMA,MAAMN,YAAYC,IAAG;AAC3B,aAAKC,OAAOI,MAAMD,KAAAA;MACpB;IACF;EACF;EAESE,MAAMJ,MAAoB;AACjC,UAAMK,QAAQL,OAAO,KAAKJ;AAC1B,SAAKA,gBAAgBI;AAErB,UAAMM,aAAc,KAAKb,gBAAgBY,QAAS;AAClD,SAAKV,SAASY,KAAKD,UAAAA;AACnB,QAAI,KAAKX,SAASa,SAASlB,cAAa;AACtC,WAAKK,SAASc,MAAK;IACrB;AACA,SAAKhB,gBAAgB;EACvB;EAESiB,UAAkB;AACzB,WAAO;MACLC,MAAM,KAAKA;MACXC,YAAY;QACVC,QAAQ;UACN;YACEF,MAAM,KAAKA;YACXG,OAAO;YACPC,QAAQ,KAAKpB,SAASqB,IAAI,CAACC,OAAOC,WAAW;cAC3CD;YACF,EAAA;YACAE,OAAO,KAAKzB;UACd;;MAEJ;IACF;EACF;AACF;;;ACrDO,IAAM0B,aAAN,cAAyBC,YAAAA;EAC9BC,SAAS,oBAAIC,IAAAA;EACbC;EAEA,YAAY,EAAEA,MAAK,IAAyB,CAAC,GAAG;AAC9C,UAAK;AACL,SAAKA,QAAQA;EACf;EAEAC,IAAIC,KAAaC,KAAK,GAAS;AAC7B,UAAMC,OAAO,KAAKN,OAAOO,IAAIH,GAAAA,KAAQ;AACrC,SAAKJ,OAAOQ,IAAIJ,KAAKE,OAAOD,EAAAA;EAC9B;EAEAI,UAAkB;AAChB,WAAO;MACLC,MAAM,KAAKA;MACXC,cAAc;QACZC,SAASC,MAAMC,KAAK,KAAKd,OAAOe,QAAO,CAAA,EAAIC,IAAI,CAAC,CAACZ,KAAKa,KAAAA,OAAY;UAChEb;UACAa;QACF,EAAA;QACAf,OAAO,KAAKA;MACd;IACF;EACF;AACF;;;AC1BO,IAAMgB,gBAAN,cAA4BC,YAAAA;;EACjC,YAA6BC,UAAwB;AACnD,UAAK,GAAA,KADsBA,WAAAA;EAE7B;EAESC,UAAkB;AACzB,WAAO;MACLC,MAAM,KAAKA;MACXC,QAAQ;QACNC,SAAS,KAAKJ,SAAQ;MACxB;IACF;EACF;AACF;;;ACNAK,MAAMC,WAAW;EACfC,IAAI;EACJC,MAAM;EACNC,OAAO,YAAA;AACL,WAAO;MACLC,UAAUC,WAAWC,SAASF;MAC9BG,MAAMF,WAAWC,SAASC;MAC1BC,UAAUH,WAAWC,SAASE;MAC9BC,MAAMJ,WAAWK,UAAUD;IAC7B;EACF;AACF,CAAA;",
|
|
6
|
+
"names": ["Context", "LifecycleState", "Resource", "TRACE_SPAN_ATTRIBUTE", "symbolTracingContext", "Symbol", "getTracingContext", "target", "infoProperties", "metricsProperties", "LogLevel", "log", "getPrototypeSpecificInstanceId", "BUFFERED_PREFIX", "BufferedSpan", "spanContext", "startTime", "delegate", "options", "id", "traceparent", "Date", "now", "end", "endTime", "setError", "err", "replay", "real", "BufferingTracingBackend", "startSpan", "span", "push", "clear", "length", "drain", "backend", "idMap", "Map", "buffered", "parentContext", "startsWith", "get", "set", "asyncTimeout", "invariant", "createId", "Math", "random", "toString", "slice", "DIAGNOSTICS_TIMEOUT", "fetch", "name", "_onUnregister", "unregister", "registry", "_instanceTag", "instanceTag", "setInstanceTag", "tag", "registerDiagnostic", "params", "get", "id", "list", "instanceId", "diagnostic", "invariant", "request", "data", "error", "stack", "Trigger", "sleep", "Context", "invariant", "__dxlog_file", "DEFAULT_CHANNEL_NAME", "DiagnosticsChannel", "_ctx", "Context", "_serveChannel", "undefined", "_channelName", "supported", "BroadcastChannel", "destroy", "_clientChannel", "close", "unref", "serve", "listener", "event", "type", "diagnostics", "request", "instanceTag", "requestId", "data", "discover", "invariant", "collector", "sleep", "result", "some", "diagnostic", "trigger", "Trigger", "wake", "RemoteMetrics", "_metrics", "Set", "registerProcessor", "processor", "add", "increment", "name", "value", "data", "Array", "from", "values", "map", "distribution", "set", "gauge", "WeakRefMock", "target", "deref", "undefined", "WeakRef", "globalThis", "__dxlog_file", "ResourceEntry", "instance", "annotation", "sanitizedClassName", "getMetric", "MAX_INFO_OBJECT_DEPTH", "TraceProcessor", "diagnostics", "DiagnosticsManager", "diagnosticsChannel", "remoteMetrics", "BufferingTracingBackend", "tracingBackend", "startSpan", "options", "parent", "traceparent", "translated", "idMap", "parentContext", "resources", "resourceInstanceIndex", "resourceIdList", "logs", "_instanceTag", "addProcessor", "DiagnosticsChannel", "unref", "setInstanceTag", "createTraceResource", "params", "tracingContext", "getTracingContext", "Object", "key", "keys", "entry", "className", "instanceId", "info", "getResourceInfo", "links", "metrics", "getResourceMetrics", "WeakRef", "push", "id", "length", "MAX_RESOURCE_RECORDS", "_clearResources", "addLink", "log", "value", "res", "sanitizeValue", "err", "getResourceId", "findResourcesByClassName", "filter", "findResourcesByAnnotation", "values", "refresh", "resource", "time", "_tick", "_pushLog", "shift", "_logProcessor", "LogLevel", "ERROR", "WARN", "TRACE", "scope", "computedError", "filename", "line", "level", "message", "context", "timestamp", "Date", "meta", "resourceId", "resourceEntry", "depth", "isMapLike", "fromEntries", "Array", "from", "entries", "map", "traceProcessor", "toString", "SANITIZE_REGEX", "name", "m", "isSetLike", "__dxlog_file", "LIFECYCLE_SPAN", "proto", "spanAttribute", "resolved", "options", "enum", "value", "String", "spanAttributes", "Error", "klass", "constructor", "rest", "TRACE_PROCESSOR", "createTraceResource", "annotation", "instance", "prototype", "originalOpen", "originalClose", "open", "_lifecycleState", "LifecycleState", "parentSpanContext", "ctx", "getAttribute", "resourceEntry", "entryPoint", "tracingBackend", "op", "attributes", "parentContext", "remoteSpan", "spanContext", "traceAttrs", "TRACE_SPAN_ATTRIBUTE", "openCtx", "derive", "Context", "setError", "err", "self", "undefined", "Object", "opts", "mark", "performance", "descriptor", "parentCtx", "startTs", "className", "sanitizedClassName", "sanitizeClassName", "spanName", "propertyKey", "collectSpanAttributes", "entries", "callArgs", "args", "childCtx", "measure", "manualSpans", "params", "showInBrowserTimeline", "manualSpanTimestamps", "name", "now", "key", "delete", "timestamps", "addLink", "child", "diagnostic", "info", "metricsCounter", "resource", "span", "spanStart", "spanEnd", "metrics", "BaseCounter", "_instance", "name", "_assign", "instance", "_tick", "time", "UnaryCounter", "BaseCounter", "value", "units", "inc", "by", "getData", "name", "counter", "MAX_BUCKETS", "TimeSeriesCounter", "BaseCounter", "_currentValue", "_totalValue", "_buckets", "units", "inc", "by", "_tick", "time", "push", "length", "shift", "getData", "name", "timeSeries", "tracks", "points", "map", "value", "index", "total", "MAX_BUCKETS", "TimeUsageCounter", "BaseCounter", "_currentValue", "_totalValue", "_buckets", "_lastTickTime", "performance", "now", "record", "time", "beginRecording", "start", "end", "_tick", "delta", "percentage", "push", "length", "shift", "getData", "name", "timeSeries", "tracks", "units", "points", "map", "value", "index", "total", "MapCounter", "BaseCounter", "values", "Map", "units", "inc", "key", "by", "prev", "get", "set", "getData", "name", "multiCounter", "records", "Array", "from", "entries", "map", "value", "CustomCounter", "BaseCounter", "_getData", "getData", "name", "custom", "payload", "trace", "diagnostic", "id", "name", "fetch", "platform", "globalThis", "process", "arch", "versions", "href", "location"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/symbols.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/symbols.ts":{"bytes":1519,"imports":[],"format":"esm"},"src/buffering-backend.ts":{"bytes":10298,"imports":[],"format":"esm"},"src/util.ts":{"bytes":696,"imports":[],"format":"esm"},"src/diagnostic.ts":{"bytes":8527,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"src/util.ts","kind":"import-statement","original":"./util"}],"format":"esm"},"src/diagnostics-channel.ts":{"bytes":16746,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"src/diagnostic.ts","kind":"import-statement","original":"./diagnostic"},{"path":"src/util.ts","kind":"import-statement","original":"./util"}],"format":"esm"},"src/remote/metrics.ts":{"bytes":4725,"imports":[],"format":"esm"},"src/weak-ref.ts":{"bytes":1281,"imports":[],"format":"esm"},"src/trace-processor.ts":{"bytes":39575,"imports":[{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"src/buffering-backend.ts","kind":"import-statement","original":"./buffering-backend"},{"path":"src/diagnostic.ts","kind":"import-statement","original":"./diagnostic"},{"path":"src/diagnostics-channel.ts","kind":"import-statement","original":"./diagnostics-channel"},{"path":"src/remote/metrics.ts","kind":"import-statement","original":"./remote/metrics"},{"path":"src/symbols.ts","kind":"import-statement","original":"./symbols"},{"path":"src/weak-ref.ts","kind":"import-statement","original":"./weak-ref"}],"format":"esm"},"src/api.ts":{"bytes":38205,"imports":[{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"src/symbols.ts","kind":"import-statement","original":"./symbols"},{"path":"src/trace-processor.ts","kind":"import-statement","original":"./trace-processor"}],"format":"esm"},"src/tracing-types.ts":{"bytes":4206,"imports":[],"format":"esm"},"src/metrics/base.ts":{"bytes":1364,"imports":[],"format":"esm"},"src/metrics/unary-counter.ts":{"bytes":2013,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"}],"format":"esm"},"src/metrics/time-series-counter.ts":{"bytes":4147,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"}],"format":"esm"},"src/metrics/time-usage-counter.ts":{"bytes":5149,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"}],"format":"esm"},"src/metrics/map-counter.ts":{"bytes":2860,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"}],"format":"esm"},"src/metrics/custom-counter.ts":{"bytes":1551,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"}],"format":"esm"},"src/metrics/index.ts":{"bytes":903,"imports":[{"path":"src/metrics/base.ts","kind":"import-statement","original":"./base"},{"path":"src/metrics/unary-counter.ts","kind":"import-statement","original":"./unary-counter"},{"path":"src/metrics/time-series-counter.ts","kind":"import-statement","original":"./time-series-counter"},{"path":"src/metrics/time-usage-counter.ts","kind":"import-statement","original":"./time-usage-counter"},{"path":"src/metrics/map-counter.ts","kind":"import-statement","original":"./map-counter"},{"path":"src/metrics/custom-counter.ts","kind":"import-statement","original":"./custom-counter"}],"format":"esm"},"src/index.ts":{"bytes":2309,"imports":[{"path":"src/api.ts","kind":"import-statement","original":"./api"},{"path":"src/api.ts","kind":"import-statement","original":"./api"},{"path":"src/symbols.ts","kind":"import-statement","original":"./symbols"},{"path":"src/trace-processor.ts","kind":"import-statement","original":"./trace-processor"},{"path":"src/tracing-types.ts","kind":"import-statement","original":"./tracing-types"},{"path":"src/metrics/index.ts","kind":"import-statement","original":"./metrics"},{"path":"src/diagnostic.ts","kind":"import-statement","original":"./diagnostic"},{"path":"src/diagnostics-channel.ts","kind":"import-statement","original":"./diagnostics-channel"},{"path":"src/remote/metrics.ts","kind":"import-statement","original":"./remote/metrics"}],"format":"esm"}},"outputs":{"dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":67359},"dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true}],"exports":["BaseCounter","CustomCounter","DIAGNOSTICS_TIMEOUT","DiagnosticsChannel","DiagnosticsManager","MapCounter","RemoteMetrics","ResourceEntry","TRACE_ALL_KEY","TRACE_PROCESSOR","TimeSeriesCounter","TimeUsageCounter","TraceDiagnosticImpl","TraceProcessor","UnaryCounter","getTracingContext","sanitizeClassName","symbolTracingContext","trace"],"entryPoint":"src/index.ts","inputs":{"src/api.ts":{"bytesInOutput":8112},"src/symbols.ts":{"bytesInOutput":215},"src/trace-processor.ts":{"bytesInOutput":9477},"src/buffering-backend.ts":{"bytesInOutput":2140},"src/diagnostic.ts":{"bytesInOutput":2080},"src/util.ts":{"bytesInOutput":58},"src/diagnostics-channel.ts":{"bytesInOutput":4325},"src/remote/metrics.ts":{"bytesInOutput":700},"src/weak-ref.ts":{"bytesInOutput":213},"src/index.ts":{"bytesInOutput":284},"src/metrics/base.ts":{"bytesInOutput":205},"src/metrics/index.ts":{"bytesInOutput":0},"src/metrics/unary-counter.ts":{"bytesInOutput":326},"src/metrics/time-series-counter.ts":{"bytesInOutput":800},"src/metrics/time-usage-counter.ts":{"bytesInOutput":1061},"src/metrics/map-counter.ts":{"bytesInOutput":511},"src/metrics/custom-counter.ts":{"bytesInOutput":250}},"bytes":31643}}}
|
|
@@ -156,27 +156,11 @@ var DiagnosticsManager = class {
|
|
|
156
156
|
}
|
|
157
157
|
async fetch(request) {
|
|
158
158
|
if (request.instanceId != null) {
|
|
159
|
-
invariant(request.instanceId === this.instanceId, "Invalid instance id", {
|
|
160
|
-
F: __dxlog_file,
|
|
161
|
-
L: 82,
|
|
162
|
-
S: this,
|
|
163
|
-
A: [
|
|
164
|
-
"request.instanceId === this.instanceId",
|
|
165
|
-
"'Invalid instance id'"
|
|
166
|
-
]
|
|
167
|
-
});
|
|
159
|
+
invariant(request.instanceId === this.instanceId, "Invalid instance id", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 52, S: this, A: ["request.instanceId === this.instanceId", "'Invalid instance id'"] });
|
|
168
160
|
}
|
|
169
161
|
const { id } = request;
|
|
170
162
|
const diagnostic2 = this.registry.get(id);
|
|
171
|
-
invariant(diagnostic2, "Diagnostic not found", {
|
|
172
|
-
F: __dxlog_file,
|
|
173
|
-
L: 86,
|
|
174
|
-
S: this,
|
|
175
|
-
A: [
|
|
176
|
-
"diagnostic",
|
|
177
|
-
"'Diagnostic not found'"
|
|
178
|
-
]
|
|
179
|
-
});
|
|
163
|
+
invariant(diagnostic2, "Diagnostic not found", { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 56, S: this, A: ["diagnostic", "'Diagnostic not found'"] });
|
|
180
164
|
try {
|
|
181
165
|
const data = await asyncTimeout(diagnostic2.fetch(), DIAGNOSTICS_TIMEOUT);
|
|
182
166
|
return {
|
|
@@ -207,10 +191,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
207
191
|
static get supported() {
|
|
208
192
|
return globalThis.BroadcastChannel != null;
|
|
209
193
|
}
|
|
210
|
-
_ctx = new Context(void 0, {
|
|
211
|
-
F: __dxlog_file2,
|
|
212
|
-
L: 46
|
|
213
|
-
});
|
|
194
|
+
_ctx = new Context(void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 16 });
|
|
214
195
|
// Separate channels becauase the client and server may be in the same process.
|
|
215
196
|
_serveChannel = void 0;
|
|
216
197
|
_clientChannel = void 0;
|
|
@@ -238,15 +219,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
238
219
|
}
|
|
239
220
|
}
|
|
240
221
|
serve(manager) {
|
|
241
|
-
invariant2(this._serveChannel, void 0, {
|
|
242
|
-
F: __dxlog_file2,
|
|
243
|
-
L: 78,
|
|
244
|
-
S: this,
|
|
245
|
-
A: [
|
|
246
|
-
"this._serveChannel",
|
|
247
|
-
""
|
|
248
|
-
]
|
|
249
|
-
});
|
|
222
|
+
invariant2(this._serveChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 43, S: this, A: ["this._serveChannel", ""] });
|
|
250
223
|
const listener = async (event) => {
|
|
251
224
|
switch (event.data.type) {
|
|
252
225
|
case "DIAGNOSTICS_DISCOVER": {
|
|
@@ -278,15 +251,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
278
251
|
this._ctx.onDispose(() => this._serveChannel.removeEventListener("message", listener));
|
|
279
252
|
}
|
|
280
253
|
async discover() {
|
|
281
|
-
invariant2(this._clientChannel, void 0, {
|
|
282
|
-
F: __dxlog_file2,
|
|
283
|
-
L: 114,
|
|
284
|
-
S: this,
|
|
285
|
-
A: [
|
|
286
|
-
"this._clientChannel",
|
|
287
|
-
""
|
|
288
|
-
]
|
|
289
|
-
});
|
|
254
|
+
invariant2(this._clientChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 77, S: this, A: ["this._clientChannel", ""] });
|
|
290
255
|
const diagnostics = [];
|
|
291
256
|
const collector = (event) => {
|
|
292
257
|
const data = event.data;
|
|
@@ -314,15 +279,7 @@ var DiagnosticsChannel = class _DiagnosticsChannel {
|
|
|
314
279
|
}
|
|
315
280
|
}
|
|
316
281
|
async fetch(request) {
|
|
317
|
-
invariant2(this._clientChannel, void 0, {
|
|
318
|
-
F: __dxlog_file2,
|
|
319
|
-
L: 147,
|
|
320
|
-
S: this,
|
|
321
|
-
A: [
|
|
322
|
-
"this._clientChannel",
|
|
323
|
-
""
|
|
324
|
-
]
|
|
325
|
-
});
|
|
282
|
+
invariant2(this._clientChannel, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 106, S: this, A: ["this._clientChannel", ""] });
|
|
326
283
|
const requestId = createId();
|
|
327
284
|
const trigger = new Trigger();
|
|
328
285
|
const listener = (event) => {
|
|
@@ -451,12 +408,7 @@ var TraceProcessor = class {
|
|
|
451
408
|
logs = [];
|
|
452
409
|
_instanceTag = null;
|
|
453
410
|
constructor() {
|
|
454
|
-
log.addProcessor(this._logProcessor.bind(this), void 0, {
|
|
455
|
-
F: __dxlog_file3,
|
|
456
|
-
L: 108,
|
|
457
|
-
S: this,
|
|
458
|
-
C: (f, a) => f(...a)
|
|
459
|
-
});
|
|
411
|
+
log.addProcessor(this._logProcessor.bind(this), void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file3, L: 80, S: this });
|
|
460
412
|
if (DiagnosticsChannel.supported) {
|
|
461
413
|
this.diagnosticsChannel.serve(this.diagnostics);
|
|
462
414
|
}
|
|
@@ -731,10 +683,7 @@ var resource = (options) => (constructor) => {
|
|
|
731
683
|
attributes: traceAttrs
|
|
732
684
|
}) : new Context2({
|
|
733
685
|
attributes: traceAttrs
|
|
734
|
-
}, {
|
|
735
|
-
F: __dxlog_file4,
|
|
736
|
-
L: 104
|
|
737
|
-
});
|
|
686
|
+
}, { "~LogMeta": "~LogMeta", F: __dxlog_file4, L: 79 });
|
|
738
687
|
}
|
|
739
688
|
try {
|
|
740
689
|
return await originalOpen.call(this, openCtx);
|