@dxos/observability 0.8.4-main.fffef41 → 0.9.0
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/LICENSE +102 -5
- package/README.md +14 -11
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-PSFTIG54.mjs +20 -0
- package/dist/lib/browser/chunk-PSFTIG54.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +1011 -34
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/log-processor-MZCTEVJC.mjs +46 -0
- package/dist/lib/browser/log-processor-MZCTEVJC.mjs.map +7 -0
- package/dist/lib/browser/logs-UTNIFYHF.mjs +116 -0
- package/dist/lib/browser/logs-UTNIFYHF.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/metrics-PRGSYAZJ.mjs +116 -0
- package/dist/lib/browser/metrics-PRGSYAZJ.mjs.map +7 -0
- package/dist/lib/browser/traces-browser-XRINKQUA.mjs +154 -0
- package/dist/lib/browser/traces-browser-XRINKQUA.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-EDDZWPYV.mjs +22 -0
- package/dist/lib/node-esm/chunk-EDDZWPYV.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
- package/dist/lib/node-esm/index.mjs +1016 -34
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/log-processor-GA24XTJF.mjs +47 -0
- package/dist/lib/node-esm/log-processor-GA24XTJF.mjs.map +7 -0
- package/dist/lib/node-esm/logs-ARJUVN3T.mjs +117 -0
- package/dist/lib/node-esm/logs-ARJUVN3T.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/metrics-DREJOOAC.mjs +117 -0
- package/dist/lib/node-esm/metrics-DREJOOAC.mjs.map +7 -0
- package/dist/lib/node-esm/traces-74F7JUKF.mjs +125 -0
- package/dist/lib/node-esm/traces-74F7JUKF.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 +222 -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/extensions/otel/metrics.d.ts.map +1 -0
- package/dist/types/src/{otel → extensions/otel}/metrics.js +4 -12
- package/dist/types/src/extensions/otel/metrics.js.map +1 -0
- package/dist/types/src/extensions/otel/otel.d.ts +19 -0
- package/dist/types/src/extensions/otel/otel.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/otel.js +23 -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 +105 -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 +88 -0
- package/dist/types/src/extensions/otel/traces.js.map +1 -0
- package/dist/types/src/extensions/posthog/extension.d.ts +28 -0
- package/dist/types/src/extensions/posthog/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/extension.js +156 -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 +45 -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 +179 -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 +65 -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 +27 -0
- package/dist/types/src/storage/browser.d.ts.map +1 -0
- package/dist/types/src/storage/browser.js +98 -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 +30 -0
- package/dist/types/src/storage/node.d.ts.map +1 -0
- package/dist/types/src/storage/node.js +96 -0
- 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 +282 -0
- package/src/extensions/otel/index.ts +5 -0
- package/src/extensions/otel/logs.ts +137 -0
- package/src/{otel → extensions/otel}/metrics.ts +4 -14
- package/src/extensions/otel/otel.ts +34 -0
- 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 +199 -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 +53 -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 +238 -577
- package/src/providers/client-observability.ts +255 -0
- package/src/providers/index.ts +7 -0
- package/src/providers/ip-data.ts +100 -0
- package/src/providers/storage.ts +23 -0
- package/src/storage/browser.ts +99 -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} +47 -71
- package/src/vite-import-meta.d.ts +14 -0
- package/dist/lib/browser/chunk-5ICT2XF2.mjs +0 -1
- package/dist/lib/browser/chunk-VIGEEYDR.mjs +0 -1019
- package/dist/lib/browser/chunk-VIGEEYDR.mjs.map +0 -7
- package/dist/lib/browser/chunk-XNAF22QM.mjs +0 -148
- package/dist/lib/browser/chunk-XNAF22QM.mjs.map +0 -7
- package/dist/lib/browser/chunk-ZI3ZS3PA.mjs +0 -164
- package/dist/lib/browser/chunk-ZI3ZS3PA.mjs.map +0 -7
- package/dist/lib/browser/observability-I65SW7NE.mjs +0 -10
- package/dist/lib/browser/otel-UH7ZRWC2.mjs +0 -287
- package/dist/lib/browser/otel-UH7ZRWC2.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-5VGDTKZN.mjs +0 -146
- package/dist/lib/browser/sentry-log-processor-5VGDTKZN.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MTKIPRBH.mjs +0 -1020
- package/dist/lib/node-esm/chunk-MTKIPRBH.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-OJV247NY.mjs +0 -204
- package/dist/lib/node-esm/chunk-OJV247NY.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/observability-5KKD7B6J.mjs +0 -11
- package/dist/lib/node-esm/observability-5KKD7B6J.mjs.map +0 -7
- package/dist/lib/node-esm/otel-7PUCFSTY.mjs +0 -270
- package/dist/lib/node-esm/otel-7PUCFSTY.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-A2EV7P3Y.mjs +0 -147
- package/dist/lib/node-esm/sentry-log-processor-A2EV7P3Y.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 +0 -97
- 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 -74
- 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 +0 -12
- package/dist/types/src/otel/otel.d.ts.map +0 -1
- package/dist/types/src/otel/otel.js +0 -11
- 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 -53
- 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 -46
- 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 -102
- package/src/otel/otel.ts +0 -21
- package/src/otel/traces-browser.ts +0 -62
- package/src/otel/traces.ts +0 -60
- 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 -176
- 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-I65SW7NE.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
- /package/dist/types/src/{otel → extensions/otel}/metrics.d.ts +0 -0
- /package/dist/types/src/{sentry → storage}/index.js +0 -0
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import posthog from 'posthog-js';
|
|
6
|
+
|
|
7
|
+
import { InvariantViolation } from '@dxos/invariant';
|
|
8
|
+
import { type LogConfig, type LogEntry, LogLevel, type LogProcessor, getContextFromEntry, shouldLog } from '@dxos/log';
|
|
9
|
+
|
|
10
|
+
export const logProcessor: LogProcessor = (config: LogConfig, entry: LogEntry) => {
|
|
11
|
+
// Don't forward logs from remote sessions.
|
|
12
|
+
if (!shouldLog(entry, config.captureFilters) || entry.meta?.S?.remoteSessionId) {
|
|
13
|
+
return;
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
let capturedError = entry.error;
|
|
17
|
+
if (capturedError == null && entry.level === LogLevel.ERROR) {
|
|
18
|
+
capturedError = Object.values(entry.context ?? {}).find((v): v is Error => v instanceof Error);
|
|
19
|
+
}
|
|
20
|
+
|
|
21
|
+
if (!capturedError) {
|
|
22
|
+
return;
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
const additionalProperties: Record<string, string | boolean | number> = {};
|
|
26
|
+
const { filename, line } = entry.computedMeta;
|
|
27
|
+
if (filename !== undefined && line !== undefined) {
|
|
28
|
+
additionalProperties.transaction = `${filename}:${line}`;
|
|
29
|
+
}
|
|
30
|
+
if (entry.meta?.S?.hostSessionId) {
|
|
31
|
+
additionalProperties.service_host_issue = true;
|
|
32
|
+
additionalProperties.service_host_session = entry.meta.S.hostSessionId;
|
|
33
|
+
}
|
|
34
|
+
if (entry.meta?.S?.uptimeSeconds != null) {
|
|
35
|
+
additionalProperties.uptime_seconds = entry.meta.S.uptimeSeconds;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
if (capturedError instanceof InvariantViolation) {
|
|
39
|
+
additionalProperties.invariant_violation = true;
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
// Forward primitive context values so callers can attach queryable attributes (e.g. fatal_dialog: true).
|
|
43
|
+
const context = getContextFromEntry(entry);
|
|
44
|
+
if (context) {
|
|
45
|
+
for (const [key, value] of Object.entries(context)) {
|
|
46
|
+
if (typeof value === 'string' || typeof value === 'boolean' || typeof value === 'number') {
|
|
47
|
+
additionalProperties[key] = value;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
|
|
52
|
+
posthog.captureException(capturedError, additionalProperties);
|
|
53
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
|
|
7
|
+
import { type Extension } from '../observability-extension';
|
|
8
|
+
|
|
9
|
+
export const stubExtension: Extension = {
|
|
10
|
+
initialize: () => Effect.succeed(undefined),
|
|
11
|
+
enable: () => Effect.succeed(undefined),
|
|
12
|
+
disable: () => Effect.succeed(undefined),
|
|
13
|
+
flush: () => Effect.succeed(undefined),
|
|
14
|
+
setTags: () => undefined,
|
|
15
|
+
get enabled() {
|
|
16
|
+
return true;
|
|
17
|
+
},
|
|
18
|
+
apis: [],
|
|
19
|
+
};
|
package/src/index.ts
CHANGED
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
//
|
|
2
|
-
// Copyright
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
export * from './
|
|
6
|
-
export * from './observability';
|
|
5
|
+
export * as Observability from './observability';
|
|
6
|
+
export * as ObservabilityExtension from './observability-extension';
|
|
7
|
+
export * as ObservabilityProvider from './providers';
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import type * as Effect from 'effect/Effect';
|
|
6
|
+
|
|
7
|
+
export * from './extensions';
|
|
8
|
+
|
|
9
|
+
/**
|
|
10
|
+
* Kind of observability extension.
|
|
11
|
+
*
|
|
12
|
+
* - errors: Error tracking (e.g., PostHog)
|
|
13
|
+
* - events: Product usage event tracking (e.g., PostHog)
|
|
14
|
+
* - feedback: User feedback submission (e.g., PostHog)
|
|
15
|
+
* - logs: Structured logging (e.g., OTEL)
|
|
16
|
+
* - metrics: Metric data (e.g., OTEL)
|
|
17
|
+
* - traces: Distributed tracing (e.g., OTEL)
|
|
18
|
+
*/
|
|
19
|
+
export type Kind = 'errors' | 'events' | 'feedback' | 'logs' | 'metrics' | 'traces';
|
|
20
|
+
|
|
21
|
+
/**
|
|
22
|
+
* Base for every extension API variant. All kinds implement availability the same way.
|
|
23
|
+
*/
|
|
24
|
+
export type ExtensionApiBase<K extends Kind = Kind> = {
|
|
25
|
+
kind: K;
|
|
26
|
+
isAvailable(): Effect.Effect<boolean>;
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
/**
|
|
30
|
+
* Metrics extension API (kind-specific methods only).
|
|
31
|
+
*/
|
|
32
|
+
export type Metrics = {
|
|
33
|
+
gauge(name: string, value: number, tags?: Attributes): void;
|
|
34
|
+
increment(name: string, value?: number, tags?: Attributes): void;
|
|
35
|
+
distribution(name: string, value: number, tags?: Attributes): void;
|
|
36
|
+
};
|
|
37
|
+
|
|
38
|
+
/**
|
|
39
|
+
* Errors extension API (kind-specific methods only).
|
|
40
|
+
*/
|
|
41
|
+
export type Errors = {
|
|
42
|
+
captureException(error: Error, attributes?: Attributes): void;
|
|
43
|
+
};
|
|
44
|
+
|
|
45
|
+
/**
|
|
46
|
+
* Events extension API (kind-specific methods only).
|
|
47
|
+
*/
|
|
48
|
+
export type Events = {
|
|
49
|
+
captureEvent(event: string, attributes?: Attributes): void;
|
|
50
|
+
};
|
|
51
|
+
|
|
52
|
+
/**
|
|
53
|
+
* Feedback extension API (kind-specific methods only).
|
|
54
|
+
*/
|
|
55
|
+
export type Feedback = {
|
|
56
|
+
captureUserFeedback(form: FeedbackForm): Promise<string | undefined>;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
export type ExtensionApi =
|
|
60
|
+
| (ExtensionApiBase<'errors'> & Errors)
|
|
61
|
+
| (ExtensionApiBase<'events'> & Events)
|
|
62
|
+
| (ExtensionApiBase<'feedback'> & Feedback)
|
|
63
|
+
// TODO(wittjosiah): Direct logs api?
|
|
64
|
+
| ExtensionApiBase<'logs'>
|
|
65
|
+
| (ExtensionApiBase<'metrics'> & Metrics)
|
|
66
|
+
// TODO(wittjosiah): Direct traces api?
|
|
67
|
+
| ExtensionApiBase<'traces'>;
|
|
68
|
+
|
|
69
|
+
/**
|
|
70
|
+
* Feedback form to be captured by the feedback extension.
|
|
71
|
+
*/
|
|
72
|
+
// TODO(wittjosiah): Support more form fields (e.g., PostHog custom surveys).
|
|
73
|
+
export type FeedbackForm = { message: string; includeLogs?: boolean };
|
|
74
|
+
|
|
75
|
+
/**
|
|
76
|
+
* Attributes to be attached to observability events.
|
|
77
|
+
*/
|
|
78
|
+
export type Attributes = Record<string, string | number | boolean | undefined>;
|
|
79
|
+
|
|
80
|
+
/**
|
|
81
|
+
* Implementation of an observability extension API.
|
|
82
|
+
*/
|
|
83
|
+
export type Extension = {
|
|
84
|
+
initialize?(): Effect.Effect<void, Error>;
|
|
85
|
+
close?(): Effect.Effect<void>;
|
|
86
|
+
enable?(): Effect.Effect<void>;
|
|
87
|
+
disable?(): Effect.Effect<void>;
|
|
88
|
+
flush?(): Effect.Effect<void>;
|
|
89
|
+
identify?(distinctId: string, attributes?: Attributes, setOnceAttributes?: Attributes): void;
|
|
90
|
+
alias?(distinctId: string, previousId?: string): void;
|
|
91
|
+
setTags?(tags: Record<string, string>): void;
|
|
92
|
+
enabled: boolean;
|
|
93
|
+
apis: ExtensionApi[];
|
|
94
|
+
};
|