@dxos/observability 0.8.4-main.dedc0f3 → 0.8.4-main.dfabb4ec29
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/README.md +14 -11
- package/dist/lib/browser/chunk-3534PNWM.mjs +13 -0
- package/dist/lib/browser/chunk-3534PNWM.mjs.map +7 -0
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/index.mjs +940 -34
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/log-processor-HPHWNBOK.mjs +38 -0
- package/dist/lib/browser/log-processor-HPHWNBOK.mjs.map +7 -0
- package/dist/lib/browser/logs-A2VDAHHD.mjs +115 -0
- package/dist/lib/browser/logs-A2VDAHHD.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/metrics-6OSN54ZV.mjs +115 -0
- package/dist/lib/browser/metrics-6OSN54ZV.mjs.map +7 -0
- package/dist/lib/browser/traces-browser-6MRGAKFC.mjs +151 -0
- package/dist/lib/browser/traces-browser-6MRGAKFC.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
- package/dist/lib/node-esm/chunk-SYPJQI4L.mjs +15 -0
- package/dist/lib/node-esm/chunk-SYPJQI4L.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +962 -34
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/log-processor-ZODHERST.mjs +39 -0
- package/dist/lib/node-esm/log-processor-ZODHERST.mjs.map +7 -0
- package/dist/lib/node-esm/logs-TA32MBMW.mjs +116 -0
- package/dist/lib/node-esm/logs-TA32MBMW.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/metrics-C5IKPAWD.mjs +116 -0
- package/dist/lib/node-esm/metrics-C5IKPAWD.mjs.map +7 -0
- package/dist/lib/node-esm/traces-5LKHMVVG.mjs +122 -0
- package/dist/lib/node-esm/traces-5LKHMVVG.mjs.map +7 -0
- package/dist/types/src/cli-observability-secrets.json +3 -4
- package/dist/types/src/extensions/index.d.ts +3 -0
- package/dist/types/src/extensions/index.d.ts.map +1 -0
- package/dist/types/src/extensions/index.js +6 -0
- package/dist/types/src/extensions/index.js.map +1 -0
- package/dist/types/src/extensions/otel/extension.d.ts +23 -0
- package/dist/types/src/extensions/otel/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/extension.js +201 -0
- package/dist/types/src/extensions/otel/extension.js.map +1 -0
- package/dist/types/src/extensions/otel/index.d.ts +2 -0
- package/dist/types/src/extensions/otel/index.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/index.js +5 -0
- package/dist/types/src/extensions/otel/index.js.map +1 -0
- package/dist/types/src/{otel → extensions/otel}/logs.d.ts +4 -3
- package/dist/types/src/extensions/otel/logs.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/logs.js +107 -0
- package/dist/types/src/extensions/otel/logs.js.map +1 -0
- package/dist/types/src/{otel → extensions/otel}/metrics.d.ts +0 -1
- package/dist/types/src/extensions/otel/metrics.d.ts.map +1 -0
- package/dist/types/src/{otel → extensions/otel}/metrics.js +2 -11
- package/dist/types/src/extensions/otel/metrics.js.map +1 -0
- package/dist/types/src/{otel → extensions/otel}/otel.d.ts +3 -3
- package/dist/types/src/extensions/otel/otel.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/otel.js.map +1 -0
- package/dist/types/src/extensions/otel/span-processors.d.ts +25 -0
- package/dist/types/src/extensions/otel/span-processors.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/span-processors.js +41 -0
- package/dist/types/src/extensions/otel/span-processors.js.map +1 -0
- package/dist/types/src/extensions/otel/traces-browser.d.ts +25 -0
- package/dist/types/src/extensions/otel/traces-browser.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/traces-browser.js +104 -0
- package/dist/types/src/extensions/otel/traces-browser.js.map +1 -0
- package/dist/types/src/extensions/otel/traces.d.ts +25 -0
- package/dist/types/src/extensions/otel/traces.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/traces.js +87 -0
- package/dist/types/src/extensions/otel/traces.js.map +1 -0
- package/dist/types/src/extensions/posthog/extension.d.ts +22 -0
- package/dist/types/src/extensions/posthog/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/extension.js +144 -0
- package/dist/types/src/extensions/posthog/extension.js.map +1 -0
- package/dist/types/src/extensions/posthog/index.d.ts +2 -0
- package/dist/types/src/extensions/posthog/index.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/index.js +5 -0
- package/dist/types/src/extensions/posthog/index.js.map +1 -0
- package/dist/types/src/extensions/posthog/log-processor.d.ts +3 -0
- package/dist/types/src/extensions/posthog/log-processor.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/log-processor.js +36 -0
- package/dist/types/src/extensions/posthog/log-processor.js.map +1 -0
- package/dist/types/src/extensions/posthog/log-processor.test.d.ts +2 -0
- package/dist/types/src/extensions/posthog/log-processor.test.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/log-processor.test.js +146 -0
- package/dist/types/src/extensions/posthog/log-processor.test.js.map +1 -0
- package/dist/types/src/extensions/stub.d.ts +3 -0
- package/dist/types/src/extensions/stub.d.ts.map +1 -0
- package/dist/types/src/extensions/stub.js +16 -0
- package/dist/types/src/extensions/stub.js.map +1 -0
- package/dist/types/src/index.d.ts +3 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/index.js +4 -3
- package/dist/types/src/index.js.map +1 -1
- package/dist/types/src/observability-extension.d.ts +74 -0
- package/dist/types/src/observability-extension.d.ts.map +1 -0
- package/dist/types/src/observability-extension.js +5 -0
- package/dist/types/src/observability-extension.js.map +1 -0
- package/dist/types/src/observability.d.ts +32 -110
- package/dist/types/src/observability.d.ts.map +1 -1
- package/dist/types/src/observability.js +177 -465
- package/dist/types/src/observability.js.map +1 -1
- package/dist/types/src/observability.test.d.ts +2 -0
- package/dist/types/src/observability.test.d.ts.map +1 -0
- package/dist/types/src/observability.test.js +312 -0
- package/dist/types/src/observability.test.js.map +1 -0
- package/dist/types/src/providers/client-observability.d.ts +11 -0
- package/dist/types/src/providers/client-observability.d.ts.map +1 -0
- package/dist/types/src/providers/client-observability.js +202 -0
- package/dist/types/src/providers/client-observability.js.map +1 -0
- package/dist/types/src/providers/index.d.ts +4 -0
- package/dist/types/src/providers/index.d.ts.map +1 -0
- package/dist/types/src/providers/index.js +7 -0
- package/dist/types/src/providers/index.js.map +1 -0
- package/dist/types/src/providers/ip-data.d.ts +5 -0
- package/dist/types/src/providers/ip-data.d.ts.map +1 -0
- package/dist/types/src/providers/ip-data.js +57 -0
- package/dist/types/src/providers/ip-data.js.map +1 -0
- package/dist/types/src/providers/storage.d.ts +3 -0
- package/dist/types/src/providers/storage.d.ts.map +1 -0
- package/dist/types/src/providers/storage.js +19 -0
- package/dist/types/src/providers/storage.js.map +1 -0
- package/dist/types/src/storage/browser.d.ts +19 -0
- package/dist/types/src/storage/browser.d.ts.map +1 -0
- package/dist/types/src/storage/browser.js +69 -0
- package/dist/types/src/storage/browser.js.map +1 -0
- package/dist/types/src/storage/index.d.ts +2 -0
- package/dist/types/src/storage/index.d.ts.map +1 -0
- package/dist/types/src/storage/index.js.map +1 -0
- package/dist/types/src/storage/node.d.ts +26 -0
- package/dist/types/src/storage/node.d.ts.map +1 -0
- package/dist/types/src/{helpers/node-observability.js → storage/node.js} +38 -43
- package/dist/types/src/storage/node.js.map +1 -0
- package/dist/types/src/storage/node.test.d.ts +2 -0
- package/dist/types/src/storage/node.test.d.ts.map +1 -0
- package/dist/types/src/storage/node.test.js +103 -0
- package/dist/types/src/storage/node.test.js.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +46 -66
- package/src/cli-observability-secrets.json +3 -4
- package/src/extensions/index.ts +6 -0
- package/src/extensions/otel/extension.ts +258 -0
- package/src/extensions/otel/index.ts +5 -0
- package/src/extensions/otel/logs.ts +137 -0
- package/src/{otel → extensions/otel}/metrics.ts +3 -20
- package/src/{otel → extensions/otel}/otel.ts +3 -3
- package/src/extensions/otel/span-processors.ts +45 -0
- package/src/extensions/otel/traces-browser.ts +139 -0
- package/src/extensions/otel/traces.ts +113 -0
- package/src/extensions/posthog/extension.ts +181 -0
- package/src/extensions/posthog/index.ts +5 -0
- package/src/extensions/posthog/log-processor.test.ts +186 -0
- package/src/extensions/posthog/log-processor.ts +43 -0
- package/src/extensions/stub.ts +19 -0
- package/src/index.ts +4 -3
- package/src/observability-extension.ts +94 -0
- package/src/observability.test.ts +531 -0
- package/src/observability.ts +236 -577
- package/src/providers/client-observability.ts +255 -0
- package/src/providers/index.ts +7 -0
- package/src/providers/ip-data.ts +91 -0
- package/src/providers/storage.ts +23 -0
- package/src/storage/browser.ts +71 -0
- package/src/{segment → storage}/index.ts +0 -1
- package/src/storage/node.test.ts +129 -0
- package/src/{helpers/node-observability.ts → storage/node.ts} +41 -71
- package/src/vite-import-meta.d.ts +14 -0
- package/dist/lib/browser/chunk-5ICT2XF2.mjs +0 -1
- package/dist/lib/browser/chunk-LJO63BXO.mjs +0 -164
- package/dist/lib/browser/chunk-LJO63BXO.mjs.map +0 -7
- package/dist/lib/browser/chunk-MB7KKARJ.mjs +0 -1025
- package/dist/lib/browser/chunk-MB7KKARJ.mjs.map +0 -7
- package/dist/lib/browser/chunk-VSEBD3XA.mjs +0 -161
- package/dist/lib/browser/chunk-VSEBD3XA.mjs.map +0 -7
- package/dist/lib/browser/observability-NZM3OOLO.mjs +0 -10
- package/dist/lib/browser/otel-UHLVSR24.mjs +0 -325
- package/dist/lib/browser/otel-UHLVSR24.mjs.map +0 -7
- package/dist/lib/browser/segment/index.mjs +0 -11
- package/dist/lib/browser/segment/index.mjs.map +0 -7
- package/dist/lib/browser/sentry/index.mjs +0 -24
- package/dist/lib/browser/sentry/index.mjs.map +0 -7
- package/dist/lib/browser/sentry-log-processor-RG4CFVGL.mjs +0 -162
- package/dist/lib/browser/sentry-log-processor-RG4CFVGL.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GOWQOSY6.mjs +0 -229
- package/dist/lib/node-esm/chunk-GOWQOSY6.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QK5IUYVA.mjs +0 -135
- package/dist/lib/node-esm/chunk-QK5IUYVA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-QUZL7LKE.mjs +0 -2
- package/dist/lib/node-esm/chunk-QUZL7LKE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YLYRR73V.mjs +0 -1026
- package/dist/lib/node-esm/chunk-YLYRR73V.mjs.map +0 -7
- package/dist/lib/node-esm/observability-2CTGITMR.mjs +0 -11
- package/dist/lib/node-esm/observability-2CTGITMR.mjs.map +0 -7
- package/dist/lib/node-esm/otel-W6KWKVW5.mjs +0 -308
- package/dist/lib/node-esm/otel-W6KWKVW5.mjs.map +0 -7
- package/dist/lib/node-esm/segment/index.mjs +0 -12
- package/dist/lib/node-esm/segment/index.mjs.map +0 -7
- package/dist/lib/node-esm/sentry/index.mjs +0 -25
- package/dist/lib/node-esm/sentry/index.mjs.map +0 -7
- package/dist/lib/node-esm/sentry-log-processor-3BDS4BB4.mjs +0 -163
- package/dist/lib/node-esm/sentry-log-processor-3BDS4BB4.mjs.map +0 -7
- package/dist/types/src/helpers/browser-observability.d.ts +0 -17
- package/dist/types/src/helpers/browser-observability.d.ts.map +0 -1
- package/dist/types/src/helpers/browser-observability.js +0 -138
- package/dist/types/src/helpers/browser-observability.js.map +0 -1
- package/dist/types/src/helpers/common.d.ts +0 -12
- package/dist/types/src/helpers/common.d.ts.map +0 -1
- package/dist/types/src/helpers/common.js +0 -23
- package/dist/types/src/helpers/common.js.map +0 -1
- package/dist/types/src/helpers/index.d.ts +0 -6
- package/dist/types/src/helpers/index.d.ts.map +0 -1
- package/dist/types/src/helpers/index.js +0 -9
- package/dist/types/src/helpers/index.js.map +0 -1
- package/dist/types/src/helpers/map-spaces.d.ts +0 -18
- package/dist/types/src/helpers/map-spaces.d.ts.map +0 -1
- package/dist/types/src/helpers/map-spaces.js +0 -36
- package/dist/types/src/helpers/map-spaces.js.map +0 -1
- package/dist/types/src/helpers/node-observability.d.ts +0 -24
- package/dist/types/src/helpers/node-observability.d.ts.map +0 -1
- package/dist/types/src/helpers/node-observability.js.map +0 -1
- package/dist/types/src/helpers/setup-telemetry-listeners.d.ts +0 -4
- package/dist/types/src/helpers/setup-telemetry-listeners.d.ts.map +0 -1
- package/dist/types/src/helpers/setup-telemetry-listeners.js +0 -94
- package/dist/types/src/helpers/setup-telemetry-listeners.js.map +0 -1
- package/dist/types/src/otel/index.d.ts +0 -5
- package/dist/types/src/otel/index.d.ts.map +0 -1
- package/dist/types/src/otel/index.js +0 -8
- package/dist/types/src/otel/index.js.map +0 -1
- package/dist/types/src/otel/logs.d.ts.map +0 -1
- package/dist/types/src/otel/logs.js +0 -72
- package/dist/types/src/otel/logs.js.map +0 -1
- package/dist/types/src/otel/metrics.d.ts.map +0 -1
- package/dist/types/src/otel/metrics.js.map +0 -1
- package/dist/types/src/otel/otel.d.ts.map +0 -1
- package/dist/types/src/otel/otel.js.map +0 -1
- package/dist/types/src/otel/traces-browser.d.ts +0 -8
- package/dist/types/src/otel/traces-browser.d.ts.map +0 -1
- package/dist/types/src/otel/traces-browser.js +0 -49
- package/dist/types/src/otel/traces-browser.js.map +0 -1
- package/dist/types/src/otel/traces.d.ts +0 -8
- package/dist/types/src/otel/traces.d.ts.map +0 -1
- package/dist/types/src/otel/traces.js +0 -42
- package/dist/types/src/otel/traces.js.map +0 -1
- package/dist/types/src/segment/base.d.ts +0 -15
- package/dist/types/src/segment/base.d.ts.map +0 -1
- package/dist/types/src/segment/base.js +0 -51
- package/dist/types/src/segment/base.js.map +0 -1
- package/dist/types/src/segment/browser.d.ts +0 -15
- package/dist/types/src/segment/browser.d.ts.map +0 -1
- package/dist/types/src/segment/browser.js +0 -63
- package/dist/types/src/segment/browser.js.map +0 -1
- package/dist/types/src/segment/index.d.ts +0 -3
- package/dist/types/src/segment/index.d.ts.map +0 -1
- package/dist/types/src/segment/index.js +0 -6
- package/dist/types/src/segment/index.js.map +0 -1
- package/dist/types/src/segment/node.d.ts +0 -16
- package/dist/types/src/segment/node.d.ts.map +0 -1
- package/dist/types/src/segment/node.js +0 -84
- package/dist/types/src/segment/node.js.map +0 -1
- package/dist/types/src/segment/types.d.ts +0 -52
- package/dist/types/src/segment/types.d.ts.map +0 -1
- package/dist/types/src/segment/types.js +0 -18
- package/dist/types/src/segment/types.js.map +0 -1
- package/dist/types/src/sentry/browser.d.ts +0 -32
- package/dist/types/src/sentry/browser.d.ts.map +0 -1
- package/dist/types/src/sentry/browser.js +0 -110
- package/dist/types/src/sentry/browser.js.map +0 -1
- package/dist/types/src/sentry/index.d.ts +0 -3
- package/dist/types/src/sentry/index.d.ts.map +0 -1
- package/dist/types/src/sentry/index.js.map +0 -1
- package/dist/types/src/sentry/node.d.ts +0 -32
- package/dist/types/src/sentry/node.d.ts.map +0 -1
- package/dist/types/src/sentry/node.js +0 -106
- package/dist/types/src/sentry/node.js.map +0 -1
- package/dist/types/src/sentry/node.node.test.d.ts +0 -2
- package/dist/types/src/sentry/node.node.test.d.ts.map +0 -1
- package/dist/types/src/sentry/node.node.test.js +0 -32
- package/dist/types/src/sentry/node.node.test.js.map +0 -1
- package/dist/types/src/sentry/sentry-log-processor.d.ts +0 -9
- package/dist/types/src/sentry/sentry-log-processor.d.ts.map +0 -1
- package/dist/types/src/sentry/sentry-log-processor.js +0 -144
- package/dist/types/src/sentry/sentry-log-processor.js.map +0 -1
- package/dist/types/src/sentry/sentry.node.test.d.ts +0 -2
- package/dist/types/src/sentry/sentry.node.test.d.ts.map +0 -1
- package/dist/types/src/sentry/sentry.node.test.js +0 -28
- package/dist/types/src/sentry/sentry.node.test.js.map +0 -1
- package/dist/types/src/sentry/types.d.ts +0 -18
- package/dist/types/src/sentry/types.d.ts.map +0 -1
- package/dist/types/src/sentry/types.js +0 -4
- package/dist/types/src/sentry/types.js.map +0 -1
- package/dist/types/src/testing/index.d.ts +0 -2
- package/dist/types/src/testing/index.d.ts.map +0 -1
- package/dist/types/src/testing/index.js +0 -5
- package/dist/types/src/testing/index.js.map +0 -1
- package/dist/types/src/testing/testkit/browser.d.ts +0 -2
- package/dist/types/src/testing/testkit/browser.d.ts.map +0 -1
- package/dist/types/src/testing/testkit/browser.js +0 -7
- package/dist/types/src/testing/testkit/browser.js.map +0 -1
- package/dist/types/src/testing/testkit/index.d.ts +0 -2
- package/dist/types/src/testing/testkit/index.d.ts.map +0 -1
- package/dist/types/src/testing/testkit/index.js +0 -6
- package/dist/types/src/testing/testkit/index.js.map +0 -1
- package/src/helpers/browser-observability.ts +0 -178
- package/src/helpers/common.ts +0 -38
- package/src/helpers/index.ts +0 -9
- package/src/helpers/map-spaces.ts +0 -48
- package/src/helpers/setup-telemetry-listeners.ts +0 -109
- package/src/otel/index.ts +0 -8
- package/src/otel/logs.ts +0 -100
- package/src/otel/traces-browser.ts +0 -59
- package/src/otel/traces.ts +0 -57
- package/src/segment/base.ts +0 -69
- package/src/segment/browser.ts +0 -69
- package/src/segment/node.ts +0 -95
- package/src/segment/types.ts +0 -57
- package/src/sentry/browser.ts +0 -133
- package/src/sentry/index.ts +0 -6
- package/src/sentry/node.node.test.ts +0 -40
- package/src/sentry/node.ts +0 -126
- package/src/sentry/sentry-log-processor.ts +0 -174
- package/src/sentry/sentry.node.test.ts +0 -35
- package/src/sentry/types.ts +0 -22
- package/src/testing/index.ts +0 -5
- package/src/testing/testkit/browser.ts +0 -8
- package/src/testing/testkit/index.ts +0 -7
- package/src/testing/testkit/shims.d.ts +0 -5
- /package/dist/lib/browser/{chunk-5ICT2XF2.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/{browser/observability-NZM3OOLO.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
- /package/dist/types/src/{otel → extensions/otel}/otel.js +0 -0
- /package/dist/types/src/{sentry → storage}/index.js +0 -0
package/package.json
CHANGED
|
@@ -1,102 +1,82 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@dxos/observability",
|
|
3
|
-
"version": "0.8.4-main.
|
|
3
|
+
"version": "0.8.4-main.dfabb4ec29",
|
|
4
4
|
"description": "Provides a common interface for app and platform observability",
|
|
5
5
|
"homepage": "https://dxos.org",
|
|
6
6
|
"bugs": "https://github.com/dxos/dxos/issues",
|
|
7
|
+
"repository": {
|
|
8
|
+
"type": "git",
|
|
9
|
+
"url": "https://github.com/dxos/dxos"
|
|
10
|
+
},
|
|
7
11
|
"license": "MIT",
|
|
8
12
|
"author": "DXOS.org",
|
|
9
|
-
"sideEffects":
|
|
13
|
+
"sideEffects": false,
|
|
10
14
|
"type": "module",
|
|
11
15
|
"exports": {
|
|
12
16
|
".": {
|
|
13
|
-
"source": "./src/index.ts",
|
|
14
17
|
"types": "./dist/types/src/index.d.ts",
|
|
15
18
|
"browser": "./dist/lib/browser/index.mjs",
|
|
16
19
|
"node": "./dist/lib/node-esm/index.mjs"
|
|
17
|
-
},
|
|
18
|
-
"./segment": {
|
|
19
|
-
"source": "./src/segment/index.ts",
|
|
20
|
-
"types": "./dist/types/src/segment/index.d.ts",
|
|
21
|
-
"browser": "./dist/lib/browser/segment/index.mjs",
|
|
22
|
-
"node": "./dist/lib/node-esm/segment/index.mjs"
|
|
23
|
-
},
|
|
24
|
-
"./sentry": {
|
|
25
|
-
"source": "./src/sentry/index.ts",
|
|
26
|
-
"types": "./dist/types/src/sentry/index.d.ts",
|
|
27
|
-
"browser": "./dist/lib/browser/sentry/index.mjs",
|
|
28
|
-
"node": "./dist/lib/node-esm/sentry/index.mjs"
|
|
29
20
|
}
|
|
30
21
|
},
|
|
31
22
|
"browser": {
|
|
32
|
-
"./src/
|
|
33
|
-
"./src/
|
|
34
|
-
"./testing/testkit/index.ts": "./testing/testkit/browser.ts",
|
|
35
|
-
"./src/otel/traces.ts": "./src/otel/traces-browser.ts"
|
|
23
|
+
"./src/storage/node.ts": "./src/storage/browser.ts",
|
|
24
|
+
"./src/extensions/otel/traces.ts": "./src/extensions/otel/traces-browser.ts"
|
|
36
25
|
},
|
|
37
26
|
"types": "dist/types/src/index.d.ts",
|
|
38
|
-
"typesVersions": {
|
|
39
|
-
"*": {
|
|
40
|
-
"segment": [
|
|
41
|
-
"dist/types/src/segment/index.d.ts"
|
|
42
|
-
],
|
|
43
|
-
"sentry": [
|
|
44
|
-
"dist/types/src/sentry/index.d.ts"
|
|
45
|
-
]
|
|
46
|
-
}
|
|
47
|
-
},
|
|
48
27
|
"files": [
|
|
49
28
|
"dist",
|
|
50
29
|
"src"
|
|
51
30
|
],
|
|
52
31
|
"dependencies": {
|
|
53
32
|
"@opentelemetry/api": "^1.9.0",
|
|
54
|
-
"@opentelemetry/api-logs": "^0.
|
|
55
|
-
"@opentelemetry/auto-instrumentations-web": "^0.
|
|
56
|
-
"@opentelemetry/
|
|
57
|
-
"@opentelemetry/exporter-
|
|
58
|
-
"@opentelemetry/exporter-
|
|
59
|
-
"@opentelemetry/
|
|
60
|
-
"@opentelemetry/
|
|
61
|
-
"@opentelemetry/
|
|
62
|
-
"@opentelemetry/sdk-
|
|
63
|
-
"@opentelemetry/sdk-
|
|
64
|
-
"@opentelemetry/sdk-trace-
|
|
65
|
-
"@opentelemetry/
|
|
66
|
-
"@
|
|
67
|
-
"@segment/snippet": "^4.15.3",
|
|
68
|
-
"@sentry/browser": "^8.8.0",
|
|
69
|
-
"@sentry/node": "^8.8.0",
|
|
33
|
+
"@opentelemetry/api-logs": "^0.203.0",
|
|
34
|
+
"@opentelemetry/auto-instrumentations-web": "^0.51.0",
|
|
35
|
+
"@opentelemetry/core": "^2.1.0",
|
|
36
|
+
"@opentelemetry/exporter-logs-otlp-http": "^0.203.0",
|
|
37
|
+
"@opentelemetry/exporter-metrics-otlp-http": "^0.203.0",
|
|
38
|
+
"@opentelemetry/exporter-trace-otlp-http": "^0.203.0",
|
|
39
|
+
"@opentelemetry/instrumentation": "^0.203.0",
|
|
40
|
+
"@opentelemetry/resources": "^2.1.0",
|
|
41
|
+
"@opentelemetry/sdk-logs": "^0.203.0",
|
|
42
|
+
"@opentelemetry/sdk-metrics": "^2.1.0",
|
|
43
|
+
"@opentelemetry/sdk-trace-base": "^2.1.0",
|
|
44
|
+
"@opentelemetry/sdk-trace-web": "^2.1.0",
|
|
45
|
+
"@opentelemetry/semantic-conventions": "^1.37.0",
|
|
70
46
|
"debug": "^4.3.4",
|
|
71
|
-
"js-yaml": "
|
|
47
|
+
"js-yaml": "4.1.1",
|
|
72
48
|
"localforage": "^1.10.0",
|
|
49
|
+
"posthog-js": "^1.353.0",
|
|
73
50
|
"uuid": "^9.0.0",
|
|
74
|
-
"
|
|
75
|
-
"@dxos/
|
|
76
|
-
"@dxos/client": "0.8.4-main.
|
|
77
|
-
"@dxos/client-services": "0.8.4-main.
|
|
78
|
-
"@dxos/
|
|
79
|
-
"@dxos/
|
|
80
|
-
"@dxos/
|
|
81
|
-
"@dxos/
|
|
82
|
-
"@dxos/
|
|
83
|
-
"@dxos/log": "0.8.4-main.
|
|
84
|
-
"@dxos/network-manager": "0.8.4-main.
|
|
85
|
-
"@dxos/
|
|
86
|
-
"@dxos/
|
|
87
|
-
"@dxos/util": "0.8.4-main.
|
|
51
|
+
"zone.js": "^0.15.0",
|
|
52
|
+
"@dxos/async": "0.8.4-main.dfabb4ec29",
|
|
53
|
+
"@dxos/client": "0.8.4-main.dfabb4ec29",
|
|
54
|
+
"@dxos/client-services": "0.8.4-main.dfabb4ec29",
|
|
55
|
+
"@dxos/client-protocol": "0.8.4-main.dfabb4ec29",
|
|
56
|
+
"@dxos/context": "0.8.4-main.dfabb4ec29",
|
|
57
|
+
"@dxos/config": "0.8.4-main.dfabb4ec29",
|
|
58
|
+
"@dxos/debug": "0.8.4-main.dfabb4ec29",
|
|
59
|
+
"@dxos/log": "0.8.4-main.dfabb4ec29",
|
|
60
|
+
"@dxos/log-store-idb": "0.8.4-main.dfabb4ec29",
|
|
61
|
+
"@dxos/network-manager": "0.8.4-main.dfabb4ec29",
|
|
62
|
+
"@dxos/node-std": "0.8.4-main.dfabb4ec29",
|
|
63
|
+
"@dxos/invariant": "0.8.4-main.dfabb4ec29",
|
|
64
|
+
"@dxos/util": "0.8.4-main.dfabb4ec29",
|
|
65
|
+
"@dxos/protocols": "0.8.4-main.dfabb4ec29",
|
|
66
|
+
"@dxos/tracing": "0.8.4-main.dfabb4ec29"
|
|
88
67
|
},
|
|
89
68
|
"devDependencies": {
|
|
90
|
-
"@
|
|
69
|
+
"@effect/platform": "0.94.4",
|
|
91
70
|
"@types/debug": "^4.1.10",
|
|
92
71
|
"@types/js-yaml": "^4.0.5",
|
|
93
|
-
"
|
|
94
|
-
"
|
|
72
|
+
"@dxos/messaging": "0.8.4-main.dfabb4ec29",
|
|
73
|
+
"@dxos/effect": "0.8.4-main.dfabb4ec29"
|
|
74
|
+
},
|
|
75
|
+
"peerDependencies": {
|
|
76
|
+
"@effect/platform": "0.94.4",
|
|
77
|
+
"effect": "3.20.0"
|
|
95
78
|
},
|
|
96
79
|
"publishConfig": {
|
|
97
80
|
"access": "public"
|
|
98
|
-
},
|
|
99
|
-
"scripts": {
|
|
100
|
-
"api-keys": "./scripts/inject_api_keys.mjs"
|
|
101
81
|
}
|
|
102
82
|
}
|
|
@@ -1,7 +1,6 @@
|
|
|
1
1
|
{
|
|
2
|
-
"
|
|
3
|
-
"TELEMETRY_API_KEY": "B00QG6PtJJrJ0VVFe0H5a6bcUUShKyZM",
|
|
2
|
+
"POSTHOG_API_KEY": null,
|
|
4
3
|
"IPDATA_API_KEY": "73dfdecdf979c18f07d50cf841bbdd9e589f237256326ac8cca23786",
|
|
5
|
-
"OTEL_ENDPOINT": "
|
|
6
|
-
"
|
|
4
|
+
"OTEL_ENDPOINT": "/api/otel",
|
|
5
|
+
"OTEL_HEADERS": null
|
|
7
6
|
}
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { defaultResource, resourceFromAttributes } from '@opentelemetry/resources';
|
|
6
|
+
import { ATTR_SERVICE_NAME, ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
|
|
7
|
+
import * as Effect from 'effect/Effect';
|
|
8
|
+
import * as Match from 'effect/Match';
|
|
9
|
+
import * as Option from 'effect/Option';
|
|
10
|
+
import * as Ref from 'effect/Ref';
|
|
11
|
+
|
|
12
|
+
import { type Config, resolveTelemetryTag } from '@dxos/config';
|
|
13
|
+
import { LogLevel, log } from '@dxos/log';
|
|
14
|
+
import { isNode, isNonNullable } from '@dxos/util';
|
|
15
|
+
|
|
16
|
+
import buildSecrets from '../../cli-observability-secrets.json';
|
|
17
|
+
import { type Extension, type ExtensionApi } from '../../observability-extension';
|
|
18
|
+
import { isObservabilityDisabled, storeObservabilityDisabled } from '../../storage';
|
|
19
|
+
import { stubExtension } from '../stub';
|
|
20
|
+
|
|
21
|
+
export type ExtensionsOptions = {
|
|
22
|
+
/** For the OTEL, the name of the entity for which signals (metrics or trace) are collected. */
|
|
23
|
+
serviceName: string;
|
|
24
|
+
/** For the OTEL, the version of the entity for which signals (metrics or trace) are collected. */
|
|
25
|
+
serviceVersion: string;
|
|
26
|
+
/** For the OTEL, the environment of the entity for which signals (metrics or trace) are collected. */
|
|
27
|
+
environment: string;
|
|
28
|
+
config: Config;
|
|
29
|
+
endpoint?: string;
|
|
30
|
+
headers?: Record<string, string>;
|
|
31
|
+
logs?: boolean;
|
|
32
|
+
/** Minimum log level to export. Defaults to INFO (i.e. info, warn, error). */
|
|
33
|
+
logLevel?: LogLevel;
|
|
34
|
+
metrics?: boolean;
|
|
35
|
+
traces?: boolean;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
/** Create an OTEL-backed observability extension for logs, metrics, and/or traces. */
|
|
39
|
+
export const extensions: (options: ExtensionsOptions) => Effect.Effect<Extension> = Effect.fn(function* ({
|
|
40
|
+
serviceName,
|
|
41
|
+
serviceVersion,
|
|
42
|
+
environment,
|
|
43
|
+
config,
|
|
44
|
+
endpoint: _endpoint,
|
|
45
|
+
headers: _headers,
|
|
46
|
+
// TODO(wittjosiah): Logging integration.
|
|
47
|
+
// - logger should run even if observability is disabled
|
|
48
|
+
// - logs should be cached locally in a circular buffer
|
|
49
|
+
// - logs should be flushed to the server if user opts to include them in a bug report
|
|
50
|
+
logs: logsEnabled = false,
|
|
51
|
+
logLevel = LogLevel.INFO,
|
|
52
|
+
metrics: metricsEnabled = false,
|
|
53
|
+
traces: tracesEnabled = false,
|
|
54
|
+
}) {
|
|
55
|
+
const { OtelLogs } = yield* Effect.promise(() => import('./logs'));
|
|
56
|
+
const { OtelMetrics } = yield* Effect.promise(() => import('./metrics'));
|
|
57
|
+
const { OtelTraces } = yield* Effect.promise(() => import('./traces'));
|
|
58
|
+
|
|
59
|
+
const cachedDisabled = yield* Effect.promise(() => isObservabilityDisabled(serviceName));
|
|
60
|
+
const disabled = cachedDisabled || isObservabilityDisabledSync(serviceName);
|
|
61
|
+
const enabledRef = yield* Ref.make(!disabled);
|
|
62
|
+
const tags = new Map<string, string>();
|
|
63
|
+
|
|
64
|
+
const endpoint = isNode()
|
|
65
|
+
? (process.env.DX_OTEL_ENDPOINT ?? _endpoint ?? buildSecrets.OTEL_ENDPOINT)
|
|
66
|
+
: config.values.runtime?.app?.env?.DX_OTEL_ENDPOINT;
|
|
67
|
+
const headers =
|
|
68
|
+
_headers ??
|
|
69
|
+
Match.value(isNode()).pipe(
|
|
70
|
+
Match.when(true, () => Option.fromNullable(process.env.DX_OTEL_HEADERS ?? buildSecrets.OTEL_HEADERS)),
|
|
71
|
+
Match.when(false, () => Option.fromNullable(config.values.runtime?.app?.env?.DX_OTEL_HEADERS)),
|
|
72
|
+
Match.exhaustive,
|
|
73
|
+
Option.map((raw) => parseHeaders(raw)),
|
|
74
|
+
Option.getOrElse(() => undefined),
|
|
75
|
+
);
|
|
76
|
+
|
|
77
|
+
if (!endpoint || !headers) {
|
|
78
|
+
log.info('Missing OTEL_ENDPOINT or OTEL_HEADERS');
|
|
79
|
+
return stubExtension;
|
|
80
|
+
}
|
|
81
|
+
|
|
82
|
+
// Matches edge's `ctx.tag` span attribute (stamped by the edge log middleware
|
|
83
|
+
// when it reads the `X-DXOS-Client-Tag` header, see
|
|
84
|
+
// /edge/packages/services/edge/src/log-middleware.ts).
|
|
85
|
+
//
|
|
86
|
+
// Stamped in TWO places:
|
|
87
|
+
// 1. Resource attribute — so logs and metrics emitted from this extension
|
|
88
|
+
// also carry it, and for zero per-span cost.
|
|
89
|
+
// 2. Span attribute via `tags` — because edge puts `ctx.tag` in the span-
|
|
90
|
+
// attribute context (not resource), and SigNoz indexes the two contexts
|
|
91
|
+
// separately. Stamping it on span attributes here keeps a single
|
|
92
|
+
// `ctx.tag = <value>` filter matching spans from both tiers in SigNoz
|
|
93
|
+
// without requiring qualified `attribute.ctx.tag`/`resource.ctx.tag` syntax.
|
|
94
|
+
const clientTag = resolveTelemetryTag(config);
|
|
95
|
+
if (clientTag) {
|
|
96
|
+
tags.set('ctx.tag', clientTag);
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const resource = defaultResource().merge(
|
|
100
|
+
resourceFromAttributes({
|
|
101
|
+
[ATTR_SERVICE_NAME]: serviceName,
|
|
102
|
+
[ATTR_SERVICE_VERSION]: serviceVersion,
|
|
103
|
+
'session.id': crypto.randomUUID(),
|
|
104
|
+
'deployment.environment': environment,
|
|
105
|
+
'dxos.process.type': detectProcessType(),
|
|
106
|
+
...(clientTag ? { 'ctx.tag': clientTag } : {}),
|
|
107
|
+
}),
|
|
108
|
+
);
|
|
109
|
+
|
|
110
|
+
const logs = logsEnabled
|
|
111
|
+
? new OtelLogs({
|
|
112
|
+
endpoint,
|
|
113
|
+
headers,
|
|
114
|
+
resource,
|
|
115
|
+
getTags: () => Object.fromEntries(tags),
|
|
116
|
+
logLevel,
|
|
117
|
+
})
|
|
118
|
+
: undefined;
|
|
119
|
+
|
|
120
|
+
const metrics = metricsEnabled
|
|
121
|
+
? new OtelMetrics({
|
|
122
|
+
endpoint,
|
|
123
|
+
headers,
|
|
124
|
+
resource,
|
|
125
|
+
getTags: () => Object.fromEntries(tags),
|
|
126
|
+
})
|
|
127
|
+
: undefined;
|
|
128
|
+
|
|
129
|
+
const traces = tracesEnabled
|
|
130
|
+
? new OtelTraces({
|
|
131
|
+
endpoint,
|
|
132
|
+
headers,
|
|
133
|
+
resource,
|
|
134
|
+
getTags: () => Object.fromEntries(tags),
|
|
135
|
+
})
|
|
136
|
+
: undefined;
|
|
137
|
+
|
|
138
|
+
const extension: Extension = {
|
|
139
|
+
initialize: () =>
|
|
140
|
+
Effect.sync(() => {
|
|
141
|
+
if (disabled) {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
|
|
145
|
+
if (logs) {
|
|
146
|
+
log.runtimeConfig.processors.push(logs.logProcessor);
|
|
147
|
+
}
|
|
148
|
+
if (traces) {
|
|
149
|
+
traces.start();
|
|
150
|
+
}
|
|
151
|
+
}),
|
|
152
|
+
enable: Effect.fn(function* () {
|
|
153
|
+
yield* Effect.promise(() => storeObservabilityDisabled(serviceName, false));
|
|
154
|
+
yield* Ref.update(enabledRef, () => true);
|
|
155
|
+
}),
|
|
156
|
+
disable: Effect.fn(function* () {
|
|
157
|
+
yield* Effect.promise(() => storeObservabilityDisabled(serviceName, true));
|
|
158
|
+
yield* Ref.update(enabledRef, () => false);
|
|
159
|
+
}),
|
|
160
|
+
close: () =>
|
|
161
|
+
Effect.promise(async () => {
|
|
162
|
+
// Run logs/metrics close concurrently and swallow their failures so the
|
|
163
|
+
// tracer provider shutdown below ALWAYS runs. Without this, a rejection
|
|
164
|
+
// from logs or metrics would drop the tracer provider's BatchSpanProcessor
|
|
165
|
+
// queue on process exit, manifesting as "Missing Span" in SigNoz for any
|
|
166
|
+
// already-exported children.
|
|
167
|
+
const results = await Promise.allSettled([logs?.close(), metrics?.close()]);
|
|
168
|
+
for (const result of results) {
|
|
169
|
+
if (result.status === 'rejected') {
|
|
170
|
+
log.catch(result.reason);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
// Critical: shut down the tracer provider so BatchSpanProcessor drains its
|
|
174
|
+
// queue. Otherwise spans enqueued in the last 5s (close/teardown spans)
|
|
175
|
+
// are dropped on process exit.
|
|
176
|
+
await traces?.close();
|
|
177
|
+
}),
|
|
178
|
+
flush: () =>
|
|
179
|
+
Effect.promise(async () => {
|
|
180
|
+
const results = await Promise.allSettled([logs?.flush(), metrics?.flush()]);
|
|
181
|
+
for (const result of results) {
|
|
182
|
+
if (result.status === 'rejected') {
|
|
183
|
+
log.catch(result.reason);
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
await traces?.flush();
|
|
187
|
+
}),
|
|
188
|
+
setTags: (incomingTags) => {
|
|
189
|
+
for (const [key, value] of Object.entries(incomingTags)) {
|
|
190
|
+
tags.set(key, value);
|
|
191
|
+
}
|
|
192
|
+
},
|
|
193
|
+
get enabled() {
|
|
194
|
+
return Ref.get(enabledRef).pipe(Effect.runSync);
|
|
195
|
+
},
|
|
196
|
+
apis: [
|
|
197
|
+
{ kind: 'logs', isAvailable: () => Effect.succeed(!!logs) } satisfies ExtensionApi,
|
|
198
|
+
metrics
|
|
199
|
+
? ({
|
|
200
|
+
kind: 'metrics',
|
|
201
|
+
isAvailable: () => Effect.succeed(true),
|
|
202
|
+
gauge: (name, value, tags) => metrics.gauge(name, value, tags),
|
|
203
|
+
increment: (name, value, tags) => metrics.increment(name, value, tags),
|
|
204
|
+
distribution: (name, value, tags) => metrics.distribution(name, value, tags),
|
|
205
|
+
} satisfies ExtensionApi)
|
|
206
|
+
: undefined,
|
|
207
|
+
traces ? ({ kind: 'traces', isAvailable: () => Effect.succeed(true) } satisfies ExtensionApi) : undefined,
|
|
208
|
+
].filter(isNonNullable),
|
|
209
|
+
};
|
|
210
|
+
|
|
211
|
+
return extension;
|
|
212
|
+
});
|
|
213
|
+
|
|
214
|
+
/**
|
|
215
|
+
* Synchronous best-effort check for observability opt-out.
|
|
216
|
+
* Prevents telemetry from being emitted before the async storage check completes.
|
|
217
|
+
*/
|
|
218
|
+
const isObservabilityDisabledSync = (serviceName: string): boolean => {
|
|
219
|
+
if (isNode()) {
|
|
220
|
+
return process.env.DX_DISABLE_OBSERVABILITY === 'true';
|
|
221
|
+
}
|
|
222
|
+
try {
|
|
223
|
+
if (typeof localStorage !== 'undefined') {
|
|
224
|
+
return localStorage.getItem(`${serviceName}/observability-disabled`) === 'true';
|
|
225
|
+
}
|
|
226
|
+
} catch {
|
|
227
|
+
// localStorage not available (e.g., in workers).
|
|
228
|
+
}
|
|
229
|
+
return false;
|
|
230
|
+
};
|
|
231
|
+
|
|
232
|
+
/** Best-effort detection of the JavaScript execution context type. */
|
|
233
|
+
const detectProcessType = (): string => {
|
|
234
|
+
if (isNode()) {
|
|
235
|
+
return 'node';
|
|
236
|
+
}
|
|
237
|
+
if (typeof window !== 'undefined') {
|
|
238
|
+
return 'browser';
|
|
239
|
+
}
|
|
240
|
+
if (typeof (globalThis as any).ServiceWorkerGlobalScope !== 'undefined') {
|
|
241
|
+
return 'service-worker';
|
|
242
|
+
}
|
|
243
|
+
if (typeof (globalThis as any).SharedWorkerGlobalScope !== 'undefined') {
|
|
244
|
+
return 'shared-worker';
|
|
245
|
+
}
|
|
246
|
+
return 'dedicated-worker';
|
|
247
|
+
};
|
|
248
|
+
|
|
249
|
+
const parseHeaders = (unparsedHeaders: string): Record<string, string> => {
|
|
250
|
+
return unparsedHeaders.split(';').reduce((acc: Record<string, string>, header) => {
|
|
251
|
+
const [key, ...rest] = header.split(':');
|
|
252
|
+
if (key && rest.length > 0) {
|
|
253
|
+
acc[key.trim().toLowerCase()] = rest.join(':').trim();
|
|
254
|
+
}
|
|
255
|
+
|
|
256
|
+
return acc;
|
|
257
|
+
}, {});
|
|
258
|
+
};
|
|
@@ -0,0 +1,137 @@
|
|
|
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 { BatchLogRecordProcessor, LoggerProvider } from '@opentelemetry/sdk-logs';
|
|
8
|
+
import { ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
|
|
9
|
+
|
|
10
|
+
import {
|
|
11
|
+
type LogConfig,
|
|
12
|
+
type LogEntry,
|
|
13
|
+
LogLevel,
|
|
14
|
+
type LogProcessor,
|
|
15
|
+
getContextFromEntry,
|
|
16
|
+
getRelativeFilename,
|
|
17
|
+
} from '@dxos/log';
|
|
18
|
+
|
|
19
|
+
import { type OtelOptions, setDiagLogger } from './otel';
|
|
20
|
+
|
|
21
|
+
const FLATTEN_DEPTH = 1;
|
|
22
|
+
|
|
23
|
+
export type OtelLogOptions = OtelOptions & {
|
|
24
|
+
logLevel: LogLevel;
|
|
25
|
+
/**
|
|
26
|
+
* Include logs forwarded from the shared worker via LoggingService.
|
|
27
|
+
*
|
|
28
|
+
* @deprecated
|
|
29
|
+
*/
|
|
30
|
+
includeSharedWorkerLogs?: boolean;
|
|
31
|
+
};
|
|
32
|
+
|
|
33
|
+
export class OtelLogs {
|
|
34
|
+
private _loggerProvider: LoggerProvider;
|
|
35
|
+
constructor(private readonly options: OtelLogOptions) {
|
|
36
|
+
setDiagLogger(options.consoleDiagLogLevel);
|
|
37
|
+
const logExporter = new OTLPLogExporter({
|
|
38
|
+
url: this.options.endpoint + '/v1/logs',
|
|
39
|
+
headers: this.options.headers,
|
|
40
|
+
concurrencyLimit: 10, // an optional limit on pending requests
|
|
41
|
+
});
|
|
42
|
+
this._loggerProvider = new LoggerProvider({
|
|
43
|
+
resource: this.options.resource,
|
|
44
|
+
processors: [new BatchLogRecordProcessor(logExporter)],
|
|
45
|
+
});
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
public readonly logProcessor: LogProcessor = (_config: LogConfig, entry: LogEntry) => {
|
|
49
|
+
const logger = this._loggerProvider.getLogger(
|
|
50
|
+
'dxos-observability',
|
|
51
|
+
this.options.resource.attributes[ATTR_SERVICE_VERSION]?.toString(),
|
|
52
|
+
);
|
|
53
|
+
|
|
54
|
+
if (
|
|
55
|
+
entry.level < this.options.logLevel ||
|
|
56
|
+
(!this.options.includeSharedWorkerLogs && entry.meta?.S?.remoteSessionId)
|
|
57
|
+
) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
const attributes = {
|
|
62
|
+
...this.options.getTags(),
|
|
63
|
+
...(entry.meta ? { meta: { file: getRelativeFilename(entry.meta.F), line: entry.meta.L } } : {}),
|
|
64
|
+
...(entry.error ? { error: entry.error.stack } : {}),
|
|
65
|
+
...stringifyValues(getContextFromEntry(entry), 'ctx_'),
|
|
66
|
+
};
|
|
67
|
+
|
|
68
|
+
logger.emit({
|
|
69
|
+
severityNumber: convertLevel(entry.level),
|
|
70
|
+
body: entry.message,
|
|
71
|
+
attributes,
|
|
72
|
+
});
|
|
73
|
+
};
|
|
74
|
+
|
|
75
|
+
flush(): Promise<void> {
|
|
76
|
+
return this._loggerProvider.forceFlush();
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
close(): Promise<void> {
|
|
80
|
+
return this._loggerProvider.shutdown();
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
|
|
84
|
+
/** Maps {@link LogLevel} to OpenTelemetry {@link SeverityNumber}. */
|
|
85
|
+
const convertLevel = (level: LogLevel): SeverityNumber => {
|
|
86
|
+
switch (level) {
|
|
87
|
+
case LogLevel.TRACE:
|
|
88
|
+
return SeverityNumber.TRACE;
|
|
89
|
+
case LogLevel.DEBUG:
|
|
90
|
+
return SeverityNumber.DEBUG;
|
|
91
|
+
case LogLevel.VERBOSE:
|
|
92
|
+
return SeverityNumber.INFO;
|
|
93
|
+
case LogLevel.INFO:
|
|
94
|
+
return SeverityNumber.INFO;
|
|
95
|
+
case LogLevel.WARN:
|
|
96
|
+
return SeverityNumber.WARN;
|
|
97
|
+
case LogLevel.ERROR:
|
|
98
|
+
return SeverityNumber.ERROR;
|
|
99
|
+
default:
|
|
100
|
+
return SeverityNumber.UNSPECIFIED;
|
|
101
|
+
}
|
|
102
|
+
};
|
|
103
|
+
|
|
104
|
+
const safeStringify = (value: unknown): string => {
|
|
105
|
+
try {
|
|
106
|
+
return JSON.stringify(value);
|
|
107
|
+
} catch {
|
|
108
|
+
return '[Circular]';
|
|
109
|
+
}
|
|
110
|
+
};
|
|
111
|
+
|
|
112
|
+
// TODO(wittjosiah): Reconcile logging utils w/ EDGE.
|
|
113
|
+
const stringifyValues = (object: object | undefined, keyPrefix?: string, depth: number = 1) => {
|
|
114
|
+
if (!object) {
|
|
115
|
+
return {};
|
|
116
|
+
}
|
|
117
|
+
const result: Record<string, string> = {};
|
|
118
|
+
for (const [key, value] of Object.entries(object)) {
|
|
119
|
+
if (value === undefined) {
|
|
120
|
+
continue;
|
|
121
|
+
}
|
|
122
|
+
const newKey = keyPrefix ? `${keyPrefix}${key}` : key;
|
|
123
|
+
if (typeof value === 'object') {
|
|
124
|
+
if (!value || Array.isArray(value) || depth > FLATTEN_DEPTH) {
|
|
125
|
+
result[newKey] = safeStringify(value);
|
|
126
|
+
} else {
|
|
127
|
+
const flattened = stringifyValues(value, `${newKey}_`, depth + 1);
|
|
128
|
+
for (const [flattenedKey, flattenedValue] of Object.entries(flattened)) {
|
|
129
|
+
result[flattenedKey] = flattenedValue;
|
|
130
|
+
}
|
|
131
|
+
}
|
|
132
|
+
} else {
|
|
133
|
+
result[newKey] = String(value);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
return result;
|
|
137
|
+
};
|
|
@@ -2,11 +2,9 @@
|
|
|
2
2
|
// Copyright 2024 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { type
|
|
5
|
+
import { type Meter } from '@opentelemetry/api';
|
|
6
6
|
import { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';
|
|
7
|
-
import { Resource } from '@opentelemetry/resources';
|
|
8
7
|
import { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics';
|
|
9
|
-
import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
|
|
10
8
|
|
|
11
9
|
import { log } from '@dxos/log';
|
|
12
10
|
import { type MetricData, TRACE_PROCESSOR } from '@dxos/tracing';
|
|
@@ -15,40 +13,25 @@ import { type OtelOptions, setDiagLogger } from './otel';
|
|
|
15
13
|
|
|
16
14
|
const EXPORT_INTERVAL = 60 * 1000;
|
|
17
15
|
|
|
18
|
-
type SynchronousGauge = {
|
|
19
|
-
gauge: ObservableGauge<Attributes>;
|
|
20
|
-
nextValue: number;
|
|
21
|
-
nextTags?: any;
|
|
22
|
-
};
|
|
23
|
-
|
|
24
16
|
export class OtelMetrics {
|
|
25
17
|
private _meterProvider: MeterProvider;
|
|
26
18
|
private _meter: Meter;
|
|
27
|
-
private _gauges = new Map<string, SynchronousGauge>();
|
|
28
19
|
|
|
29
20
|
constructor(private readonly options: OtelOptions) {
|
|
30
21
|
// TODO: improve error handling/logging
|
|
31
22
|
// https://github.com/open-telemetry/opentelemetry-js/issues/4823
|
|
32
23
|
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
24
|
|
|
40
25
|
const grafanaMetricReader = new PeriodicExportingMetricReader({
|
|
41
26
|
exporter: new OTLPMetricExporter({
|
|
42
27
|
url: this.options.endpoint + '/v1/metrics',
|
|
43
|
-
headers:
|
|
44
|
-
Authorization: this.options.authorizationHeader,
|
|
45
|
-
},
|
|
28
|
+
headers: this.options.headers,
|
|
46
29
|
}),
|
|
47
30
|
exportIntervalMillis: EXPORT_INTERVAL,
|
|
48
31
|
});
|
|
49
32
|
|
|
50
33
|
this._meterProvider = new MeterProvider({
|
|
51
|
-
resource,
|
|
34
|
+
resource: this.options.resource,
|
|
52
35
|
readers: [grafanaMetricReader],
|
|
53
36
|
});
|
|
54
37
|
this._meter = this._meterProvider.getMeter('dxos-observability');
|
|
@@ -3,12 +3,12 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
import { DiagConsoleLogger, DiagLogLevel, diag } from '@opentelemetry/api';
|
|
6
|
+
import { type Resource } from '@opentelemetry/resources';
|
|
6
7
|
|
|
7
8
|
export type OtelOptions = {
|
|
8
9
|
endpoint: string;
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
serviceVersion: string; // For the Otel API, The name of the entity for which signals (metrics or trace) are collected.
|
|
10
|
+
headers: Record<string, string>;
|
|
11
|
+
resource: Resource;
|
|
12
12
|
getTags: () => { [key: string]: string };
|
|
13
13
|
consoleDiagLogLevel?: string;
|
|
14
14
|
};
|