@dxos/observability 0.6.3-main.e6314a6 → 0.6.3-main.fe243fc

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (67) hide show
  1. package/dist/lib/browser/{chunk-2CXA7PYK.mjs → chunk-7HCG6KYK.mjs} +174 -133
  2. package/dist/lib/browser/chunk-7HCG6KYK.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +2 -1
  4. package/dist/lib/browser/meta.json +1 -1
  5. package/dist/lib/browser/observability-IFDZJFY2.mjs +8 -0
  6. package/dist/lib/node/{chunk-HBLKTDQE.cjs → chunk-63FCWS3M.cjs} +170 -136
  7. package/dist/lib/node/chunk-63FCWS3M.cjs.map +7 -0
  8. package/dist/lib/node/index.cjs +16 -15
  9. package/dist/lib/node/index.cjs.map +2 -2
  10. package/dist/lib/node/meta.json +1 -1
  11. package/dist/lib/node/{observability-4R6M4JMU.cjs → observability-W7TVZP2V.cjs} +7 -6
  12. package/dist/lib/node/observability-W7TVZP2V.cjs.map +7 -0
  13. package/dist/types/src/cli-observability-secrets.json +1 -3
  14. package/dist/types/src/helpers/browser-observability.d.ts.map +1 -1
  15. package/dist/types/src/helpers/browser-observability.js +0 -1
  16. package/dist/types/src/helpers/browser-observability.js.map +1 -1
  17. package/dist/types/src/observability.d.ts +0 -9
  18. package/dist/types/src/observability.d.ts.map +1 -1
  19. package/dist/types/src/observability.js +13 -90
  20. package/dist/types/src/observability.js.map +1 -1
  21. package/package.json +20 -35
  22. package/src/cli-observability-secrets.json +1 -3
  23. package/src/helpers/browser-observability.ts +0 -1
  24. package/src/observability.ts +14 -107
  25. package/dist/lib/browser/chunk-2CXA7PYK.mjs.map +0 -7
  26. package/dist/lib/browser/observability-MXAPN7J6.mjs +0 -7
  27. package/dist/lib/browser/otel-BUKBDMAL.mjs +0 -275
  28. package/dist/lib/browser/otel-BUKBDMAL.mjs.map +0 -7
  29. package/dist/lib/browser/sentry-log-processor-DVUUOZ6G.mjs +0 -132
  30. package/dist/lib/browser/sentry-log-processor-DVUUOZ6G.mjs.map +0 -7
  31. package/dist/lib/node/chunk-HBLKTDQE.cjs.map +0 -7
  32. package/dist/lib/node/observability-4R6M4JMU.cjs.map +0 -7
  33. package/dist/lib/node/otel-TSHMOAB4.cjs +0 -276
  34. package/dist/lib/node/otel-TSHMOAB4.cjs.map +0 -7
  35. package/dist/lib/node/sentry-log-processor-H6FUSKZI.cjs +0 -150
  36. package/dist/lib/node/sentry-log-processor-H6FUSKZI.cjs.map +0 -7
  37. package/dist/types/src/otel/index.d.ts +0 -5
  38. package/dist/types/src/otel/index.d.ts.map +0 -1
  39. package/dist/types/src/otel/index.js +0 -24
  40. package/dist/types/src/otel/index.js.map +0 -1
  41. package/dist/types/src/otel/logs.d.ts +0 -11
  42. package/dist/types/src/otel/logs.d.ts.map +0 -1
  43. package/dist/types/src/otel/logs.js +0 -72
  44. package/dist/types/src/otel/logs.js.map +0 -1
  45. package/dist/types/src/otel/metrics.d.ts +0 -14
  46. package/dist/types/src/otel/metrics.d.ts.map +0 -1
  47. package/dist/types/src/otel/metrics.js +0 -91
  48. package/dist/types/src/otel/metrics.js.map +0 -1
  49. package/dist/types/src/otel/otel.d.ts +0 -12
  50. package/dist/types/src/otel/otel.d.ts.map +0 -1
  51. package/dist/types/src/otel/otel.js +0 -15
  52. package/dist/types/src/otel/otel.js.map +0 -1
  53. package/dist/types/src/otel/traces-browser.d.ts +0 -8
  54. package/dist/types/src/otel/traces-browser.d.ts.map +0 -1
  55. package/dist/types/src/otel/traces-browser.js +0 -51
  56. package/dist/types/src/otel/traces-browser.js.map +0 -1
  57. package/dist/types/src/otel/traces.d.ts +0 -8
  58. package/dist/types/src/otel/traces.d.ts.map +0 -1
  59. package/dist/types/src/otel/traces.js +0 -44
  60. package/dist/types/src/otel/traces.js.map +0 -1
  61. package/src/otel/index.ts +0 -8
  62. package/src/otel/logs.ts +0 -86
  63. package/src/otel/metrics.ts +0 -111
  64. package/src/otel/otel.ts +0 -21
  65. package/src/otel/traces-browser.ts +0 -59
  66. package/src/otel/traces.ts +0 -57
  67. /package/dist/lib/browser/{observability-MXAPN7J6.mjs.map → observability-IFDZJFY2.mjs.map} +0 -0
package/src/otel/logs.ts DELETED
@@ -1,86 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { SeverityNumber } from '@opentelemetry/api-logs';
6
- import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
7
- import { Resource } from '@opentelemetry/resources';
8
- import { BatchLogRecordProcessor, LoggerProvider } from '@opentelemetry/sdk-logs';
9
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
10
-
11
- import {
12
- getContextFromEntry,
13
- getRelativeFilename,
14
- type LogConfig,
15
- type LogEntry,
16
- LogLevel,
17
- type LogProcessor,
18
- shouldLog,
19
- } from '@dxos/log';
20
- import { jsonlogify } from '@dxos/util';
21
-
22
- import { type OtelOptions, setDiagLogger } from './otel';
23
-
24
- export class OtelLogs {
25
- private _loggerProvider: LoggerProvider;
26
- constructor(private readonly options: OtelOptions) {
27
- setDiagLogger(options.consoleDiagLogLevel);
28
- const resource = Resource.default().merge(
29
- new Resource({
30
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
31
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
32
- }),
33
- );
34
- const logExporter = new OTLPLogExporter({
35
- url: this.options.endpoint + '/v1/logs',
36
- headers: {
37
- Authorization: this.options.authorizationHeader,
38
- },
39
- concurrencyLimit: 10, // an optional limit on pending requests
40
- });
41
- this._loggerProvider = new LoggerProvider({ resource });
42
- this._loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter));
43
- }
44
-
45
- public readonly logProcessor: LogProcessor = (config: LogConfig, entry: LogEntry) => {
46
- const logger = this._loggerProvider.getLogger('dxos-observability', this.options.serviceVersion);
47
-
48
- if (!shouldLog(entry, config.captureFilters) || entry.meta?.S?.remoteSessionId) {
49
- return;
50
- }
51
- const record = {
52
- ...entry,
53
- ...(entry.meta ? { meta: { file: getRelativeFilename(entry.meta.F), line: entry.meta.L } } : {}),
54
- context: jsonlogify(getContextFromEntry(entry)),
55
- };
56
-
57
- logger.emit({
58
- severityNumber: convertLevel(entry.level),
59
- body: JSON.stringify(record),
60
- attributes: this.options.getTags(),
61
- });
62
- };
63
-
64
- flush() {
65
- return this._loggerProvider.forceFlush();
66
- }
67
-
68
- close() {
69
- return this._loggerProvider.shutdown();
70
- }
71
- }
72
-
73
- const convertLevel = (level: LogLevel): SeverityNumber => {
74
- switch (level) {
75
- case LogLevel.DEBUG:
76
- return SeverityNumber.DEBUG;
77
- case LogLevel.INFO:
78
- return SeverityNumber.INFO;
79
- case LogLevel.WARN:
80
- return SeverityNumber.WARN;
81
- case LogLevel.ERROR:
82
- return SeverityNumber.ERROR;
83
- default:
84
- return SeverityNumber.ERROR;
85
- }
86
- };
@@ -1,111 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { type Attributes, type Meter, type ObservableGauge } from '@opentelemetry/api';
6
- import { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';
7
- import { Resource } from '@opentelemetry/resources';
8
- import { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics';
9
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
10
-
11
- import { log } from '@dxos/log';
12
- import { TRACE_PROCESSOR, type MetricData } from '@dxos/tracing';
13
-
14
- import { type OtelOptions, setDiagLogger } from './otel';
15
-
16
- const EXPORT_INTERVAL = 60 * 1000;
17
-
18
- type SynchronousGauge = {
19
- gauge: ObservableGauge<Attributes>;
20
- nextValue: number;
21
- nextTags?: any;
22
- };
23
-
24
- export class OtelMetrics {
25
- private _meterProvider: MeterProvider;
26
- private _meter: Meter;
27
- private _gauges = new Map<string, SynchronousGauge>();
28
-
29
- constructor(private readonly options: OtelOptions) {
30
- // TODO: improve error handling/logging
31
- // https://github.com/open-telemetry/opentelemetry-js/issues/4823
32
- setDiagLogger(options.consoleDiagLogLevel);
33
- const resource = Resource.default().merge(
34
- new Resource({
35
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
36
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
37
- }),
38
- );
39
-
40
- const grafanaMetricReader = new PeriodicExportingMetricReader({
41
- exporter: new OTLPMetricExporter({
42
- url: this.options.endpoint + '/v1/metrics',
43
- headers: {
44
- Authorization: this.options.authorizationHeader,
45
- },
46
- }),
47
- exportIntervalMillis: EXPORT_INTERVAL,
48
- });
49
-
50
- this._meterProvider = new MeterProvider({
51
- resource,
52
- readers: [grafanaMetricReader],
53
- });
54
- this._meter = this._meterProvider.getMeter('dxos-observability');
55
-
56
- const metrics = {
57
- // TODO: update metrics names and remove prefix?
58
- increment: (name: string, value?: number, data?: MetricData) => {
59
- this.increment(name, value, convertTags(data));
60
- },
61
- distribution: (name: string, value: number, data?: MetricData) => {
62
- this.distribution(name, value, convertTags(data));
63
- },
64
- set: (name: string, value: number | string, data?: MetricData) => {
65
- // Not implemented, not part of Otel spec.
66
- },
67
- gauge: (name: string, value: number, data?: MetricData) => {
68
- this.gauge(name, value, convertTags(data));
69
- },
70
- };
71
-
72
- TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);
73
- }
74
-
75
- gauge(name: string, value: number, tags?: any) {
76
- const gauge = this._meter.createGauge(name);
77
- log('otel gauge', { name, value, tags: { ...this.options.getTags(), ...tags } });
78
- gauge.record(value, { ...this.options.getTags(), ...tags });
79
- }
80
-
81
- increment(name: string, value?: number, tags?: any) {
82
- const counter = this._meter.createCounter(name);
83
- log('otel counter', { name, value, tags: { ...this.options.getTags(), ...tags } });
84
- counter.add(value ?? 1, { ...this.options.getTags(), ...tags });
85
- }
86
-
87
- distribution(name: string, value: number, tags?: any) {
88
- const distribution = this._meter.createHistogram(name);
89
- log('otel distribution', { name, value, tags: { ...this.options.getTags(), ...tags } });
90
- distribution.record(value, { ...this.options.getTags(), ...tags });
91
- }
92
-
93
- flush() {
94
- return this._meterProvider.forceFlush();
95
- }
96
-
97
- close() {
98
- return this._meterProvider.shutdown();
99
- }
100
- }
101
-
102
- const convertTags = (data?: MetricData) => {
103
- if (data && data.tags) {
104
- return Object.entries(data.tags).reduce<{ [key: string]: any }>((obj, [key, value]) => {
105
- obj[key] = value;
106
- return obj;
107
- }, {});
108
- } else {
109
- return {};
110
- }
111
- };
package/src/otel/otel.ts DELETED
@@ -1,21 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { diag, DiagConsoleLogger, DiagLogLevel } from '@opentelemetry/api';
6
-
7
- export type OtelOptions = {
8
- endpoint: string;
9
- authorizationHeader: string;
10
- serviceName: string; // For the Otel API, the name of the entity for which signals (metrics or trace) are collected.
11
- serviceVersion: string; // For the Otel API, The name of the entity for which signals (metrics or trace) are collected.
12
- getTags: () => { [key: string]: string };
13
- consoleDiagLogLevel?: string;
14
- };
15
-
16
- export const setDiagLogger = (level?: string) => {
17
- const logLevel = DiagLogLevel[level as keyof typeof DiagLogLevel];
18
- if (logLevel) {
19
- diag.setLogger(new DiagConsoleLogger(), logLevel);
20
- }
21
- };
@@ -1,59 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { trace, type Tracer } from '@opentelemetry/api';
6
- import { getWebAutoInstrumentations } from '@opentelemetry/auto-instrumentations-web';
7
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
8
- import { registerInstrumentations } from '@opentelemetry/instrumentation';
9
- import { Resource } from '@opentelemetry/resources';
10
- import { ConsoleSpanExporter, SimpleSpanProcessor, BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';
11
- import { WebTracerProvider } from '@opentelemetry/sdk-trace-web';
12
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
13
-
14
- import { log } from '@dxos/log';
15
- import { TRACE_PROCESSOR, type StartSpanOptions } from '@dxos/tracing';
16
-
17
- import { type OtelOptions } from './otel';
18
-
19
- export class OtelTraces {
20
- private _tracer: Tracer;
21
- constructor(private readonly options: OtelOptions) {
22
- const resource = Resource.default().merge(
23
- new Resource({
24
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
25
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
26
- }),
27
- );
28
-
29
- const tracerProvider = new WebTracerProvider({ resource });
30
- tracerProvider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));
31
- tracerProvider.addSpanProcessor(
32
- new BatchSpanProcessor(
33
- new OTLPTraceExporter({
34
- url: this.options.endpoint + '/v1/traces',
35
- headers: {
36
- Authorization: this.options.authorizationHeader,
37
- },
38
- concurrencyLimit: 10, // an optional limit on pending requests
39
- }),
40
- ),
41
- );
42
- // TODO(nf): ContextManager? Propogator?
43
- tracerProvider.register({});
44
- this._tracer = trace.getTracer('dxos-observability', this.options.serviceVersion);
45
- }
46
-
47
- public start() {
48
- registerInstrumentations({
49
- instrumentations: [getWebAutoInstrumentations()],
50
- });
51
- log('trace processor registered');
52
- TRACE_PROCESSOR.remoteTracing.registerProcessor({
53
- startSpan: (options: StartSpanOptions) => {
54
- log('begin otel trace', { options });
55
- return this._tracer.startSpan(options.name, options);
56
- },
57
- });
58
- }
59
- }
@@ -1,57 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
-
5
- import { trace, type Tracer } from '@opentelemetry/api';
6
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
7
- import { Resource } from '@opentelemetry/resources';
8
- import {
9
- BasicTracerProvider,
10
- BatchSpanProcessor,
11
- ConsoleSpanExporter,
12
- SimpleSpanProcessor,
13
- } from '@opentelemetry/sdk-trace-base';
14
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
15
- import { log } from 'debug';
16
-
17
- import { TRACE_PROCESSOR, type StartSpanOptions } from '@dxos/tracing';
18
-
19
- import { type OtelOptions } from './otel';
20
-
21
- export class OtelTraces {
22
- private _tracer: Tracer;
23
- constructor(private readonly options: OtelOptions) {
24
- const resource = Resource.default().merge(
25
- new Resource({
26
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
27
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
28
- }),
29
- );
30
-
31
- const tracerProvider = new BasicTracerProvider({ resource });
32
- tracerProvider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));
33
- tracerProvider.addSpanProcessor(
34
- new BatchSpanProcessor(
35
- new OTLPTraceExporter({
36
- url: this.options.endpoint + '/v1/traces',
37
- headers: {
38
- Authorization: this.options.authorizationHeader,
39
- },
40
- concurrencyLimit: 10, // an optional limit on pending requests
41
- }),
42
- ),
43
- );
44
- tracerProvider.register();
45
- this._tracer = trace.getTracer('dxos-observability', this.options.serviceVersion);
46
- }
47
-
48
- public start() {
49
- log('trace processor registered');
50
- TRACE_PROCESSOR.remoteTracing.registerProcessor({
51
- startSpan: (options: StartSpanOptions) => {
52
- log('begin otel trace', { options });
53
- return this._tracer.startSpan(options.name, options);
54
- },
55
- });
56
- }
57
- }