@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
|
@@ -1,18 +1,12 @@
|
|
|
1
|
+
import yaml from 'js-yaml';
|
|
1
2
|
//
|
|
2
3
|
// Copyright 2022 DXOS.org
|
|
3
4
|
//
|
|
4
5
|
import { existsSync, statSync } from 'node:fs';
|
|
5
6
|
import { mkdir, readFile, writeFile } from 'node:fs/promises';
|
|
6
7
|
import { join } from 'node:path';
|
|
7
|
-
|
|
8
|
-
import yaml from 'js-yaml';
|
|
9
8
|
import { v4 as uuid, validate as validateUuid } from 'uuid';
|
|
10
9
|
|
|
11
|
-
import type { Config } from '@dxos/client';
|
|
12
|
-
import { log } from '@dxos/log';
|
|
13
|
-
|
|
14
|
-
import { type Mode, Observability } from '../observability';
|
|
15
|
-
|
|
16
10
|
/**
|
|
17
11
|
* Print observability banner once per installation.
|
|
18
12
|
*/
|
|
@@ -22,7 +16,6 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
22
16
|
return;
|
|
23
17
|
}
|
|
24
18
|
bannercb(
|
|
25
|
-
// eslint-disable-next-line no-multi-str
|
|
26
19
|
'Basic observability data will be sent to the DXOS team in order to improve the product. This includes \
|
|
27
20
|
performance metrics, error logs, and usage data. No personally identifiable information, other than your \
|
|
28
21
|
public key, is included with this data and no private data ever leaves your devices. To disable sending \
|
|
@@ -32,7 +25,43 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
32
25
|
await writeFile(path, '', 'utf-8');
|
|
33
26
|
};
|
|
34
27
|
|
|
35
|
-
|
|
28
|
+
/**
|
|
29
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
30
|
+
*/
|
|
31
|
+
export const isObservabilityDisabled = async (configDir: string): Promise<boolean> => {
|
|
32
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
33
|
+
return observabilityState.disabled;
|
|
34
|
+
};
|
|
35
|
+
|
|
36
|
+
/**
|
|
37
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
38
|
+
*/
|
|
39
|
+
// NOTE: read-modify-write is not atomic; concurrent callers could overwrite each other.
|
|
40
|
+
// Acceptable here because writes are infrequent and triggered by explicit user action.
|
|
41
|
+
export const storeObservabilityDisabled = async (configDir: string, value: boolean) => {
|
|
42
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
43
|
+
observabilityState.disabled = value;
|
|
44
|
+
await writeFile(join(configDir, 'observability.yml'), yaml.dump(observabilityState), 'utf-8');
|
|
45
|
+
};
|
|
46
|
+
|
|
47
|
+
/**
|
|
48
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
49
|
+
*/
|
|
50
|
+
export const getObservabilityGroup = async (configDir: string): Promise<string | undefined> => {
|
|
51
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
52
|
+
return observabilityState.group;
|
|
53
|
+
};
|
|
54
|
+
|
|
55
|
+
/**
|
|
56
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
57
|
+
*/
|
|
58
|
+
export const storeObservabilityGroup = async (configDir: string, value: string) => {
|
|
59
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
60
|
+
observabilityState.group = value;
|
|
61
|
+
await writeFile(join(configDir, 'observability.yml'), yaml.dump(observabilityState), 'utf-8');
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
const getObservabilityState = async (configDir: string): Promise<PersistentObservabilityState> => {
|
|
36
65
|
// check whether configDir exists and if it's a directory
|
|
37
66
|
|
|
38
67
|
if (existsSync(configDir)) {
|
|
@@ -54,8 +83,8 @@ export const getObservabilityState = async (configDir: string): Promise<Persiste
|
|
|
54
83
|
|
|
55
84
|
export type PersistentObservabilityState = {
|
|
56
85
|
installationId: string;
|
|
86
|
+
disabled: boolean;
|
|
57
87
|
group?: string;
|
|
58
|
-
mode: Mode;
|
|
59
88
|
};
|
|
60
89
|
|
|
61
90
|
// create initial state and write to file, using environment variables to override defaults.
|
|
@@ -63,8 +92,8 @@ const initializeState = async (idPath: string): Promise<PersistentObservabilityS
|
|
|
63
92
|
// TODO(nf): read initial values from config or seed file
|
|
64
93
|
const observabilityState = {
|
|
65
94
|
installationId: uuid(),
|
|
95
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : false,
|
|
66
96
|
group: process.env.DX_OBSERVABILITY_GROUP ?? undefined,
|
|
67
|
-
mode: (process.env.DX_DISABLE_OBSERVABILITY ? 'disabled' : (process.env.DX_OBSERVABILITY_MODE ?? 'basic')) as Mode,
|
|
68
97
|
};
|
|
69
98
|
|
|
70
99
|
await writeFile(
|
|
@@ -81,66 +110,7 @@ const validate = (contextString: string) => {
|
|
|
81
110
|
if (Boolean(context.installationId) && validateUuid(context.installationId!)) {
|
|
82
111
|
return {
|
|
83
112
|
...context,
|
|
84
|
-
|
|
113
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : (context.disabled ?? false),
|
|
85
114
|
};
|
|
86
115
|
}
|
|
87
116
|
};
|
|
88
|
-
|
|
89
|
-
export type NodeObservabilityOptions = {
|
|
90
|
-
installationId: string;
|
|
91
|
-
group?: string;
|
|
92
|
-
namespace: string;
|
|
93
|
-
version: string;
|
|
94
|
-
config: Config;
|
|
95
|
-
mode?: Mode;
|
|
96
|
-
tracingEnable?: boolean;
|
|
97
|
-
replayEnable?: boolean;
|
|
98
|
-
// TODO(nf): options for providers?
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
export const initializeNodeObservability = async ({
|
|
102
|
-
namespace,
|
|
103
|
-
version,
|
|
104
|
-
config,
|
|
105
|
-
installationId,
|
|
106
|
-
group,
|
|
107
|
-
mode = 'basic',
|
|
108
|
-
tracingEnable = true,
|
|
109
|
-
replayEnable = true,
|
|
110
|
-
}: NodeObservabilityOptions): Promise<Observability> => {
|
|
111
|
-
log('initializeCliObservability', { config });
|
|
112
|
-
|
|
113
|
-
// TODO(nf): make CLI build populate runtime.app.build config?
|
|
114
|
-
const release = `${namespace}@${version}`;
|
|
115
|
-
const environment = process.env.DX_ENVIRONMENT ?? 'unknown';
|
|
116
|
-
|
|
117
|
-
const observability = new Observability({
|
|
118
|
-
mode,
|
|
119
|
-
namespace,
|
|
120
|
-
release,
|
|
121
|
-
environment,
|
|
122
|
-
group,
|
|
123
|
-
errorLog: {
|
|
124
|
-
sentryInitOptions: {
|
|
125
|
-
environment,
|
|
126
|
-
release,
|
|
127
|
-
// TODO(wittjosiah): Configure this.
|
|
128
|
-
sampleRate: 1.0,
|
|
129
|
-
},
|
|
130
|
-
},
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
observability.setTag('installationId', installationId);
|
|
134
|
-
|
|
135
|
-
// TODO(nf): cache ipdata to avoid repeated requests
|
|
136
|
-
const IPDATA_API_KEY = config.get('runtime.app.env.DX_IPDATA_API_KEY');
|
|
137
|
-
try {
|
|
138
|
-
const res = await fetch(`https://api.ipdata.co/?api-key=${IPDATA_API_KEY}`);
|
|
139
|
-
const ipData = await res.json();
|
|
140
|
-
ipData && observability.setIPDataTelemetryTags(ipData);
|
|
141
|
-
} catch (err) {
|
|
142
|
-
observability?.captureException(err);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
return observability;
|
|
146
|
-
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
/**
|
|
6
|
+
* Vite replaces `import.meta.env` at build time. Aligns with `vite/client` without taking a Vite dependency.
|
|
7
|
+
* @see https://vitejs.dev/guide/env-and-mode.html
|
|
8
|
+
*/
|
|
9
|
+
interface ImportMetaEnv {
|
|
10
|
+
readonly DEV: boolean;
|
|
11
|
+
readonly PROD: boolean;
|
|
12
|
+
readonly MODE: string;
|
|
13
|
+
readonly SSR: boolean;
|
|
14
|
+
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=chunk-5ICT2XF2.mjs.map
|
|
@@ -1,164 +0,0 @@
|
|
|
1
|
-
// src/sentry/browser.ts
|
|
2
|
-
import { breadcrumbsIntegration, browserTracingIntegration, feedbackIntegration, httpClientIntegration, metrics, addBreadcrumb as naturalAddBreadcrumb, captureException as naturalCaptureException, captureMessage as naturalCaptureMessage, init as naturalInit, sendFeedback as naturalSendFeedback, withScope as naturalWithScope, replayIntegration, setTag, startInactiveSpan } from "@sentry/browser";
|
|
3
|
-
import { log } from "@dxos/log";
|
|
4
|
-
import { TRACE_PROCESSOR } from "@dxos/tracing";
|
|
5
|
-
import { setTag as setTag2, setTags, setUser } from "@sentry/browser";
|
|
6
|
-
var __dxlog_file = "/__w/dxos/dxos/packages/sdk/observability/src/sentry/browser.ts";
|
|
7
|
-
var init = (options) => {
|
|
8
|
-
try {
|
|
9
|
-
log("sentry init", options, {
|
|
10
|
-
F: __dxlog_file,
|
|
11
|
-
L: 38,
|
|
12
|
-
S: void 0,
|
|
13
|
-
C: (f, a) => f(...a)
|
|
14
|
-
});
|
|
15
|
-
naturalInit({
|
|
16
|
-
enabled: options.enable ?? true,
|
|
17
|
-
dsn: options.destination,
|
|
18
|
-
release: options.release,
|
|
19
|
-
environment: options.environment,
|
|
20
|
-
integrations: [
|
|
21
|
-
breadcrumbsIntegration({
|
|
22
|
-
console: false,
|
|
23
|
-
fetch: false
|
|
24
|
-
}),
|
|
25
|
-
httpClientIntegration({
|
|
26
|
-
failedRequestStatusCodes: [
|
|
27
|
-
// 401 errors are omitted as they happen as a part of the EDGE authentication flow.
|
|
28
|
-
[
|
|
29
|
-
400,
|
|
30
|
-
400
|
|
31
|
-
],
|
|
32
|
-
[
|
|
33
|
-
402,
|
|
34
|
-
599
|
|
35
|
-
]
|
|
36
|
-
]
|
|
37
|
-
}),
|
|
38
|
-
feedbackIntegration({
|
|
39
|
-
autoInject: false
|
|
40
|
-
}),
|
|
41
|
-
...options.tracing ? [
|
|
42
|
-
browserTracingIntegration()
|
|
43
|
-
] : [],
|
|
44
|
-
...options.replay ? [
|
|
45
|
-
replayIntegration({
|
|
46
|
-
blockAllMedia: true,
|
|
47
|
-
maskAllText: true
|
|
48
|
-
})
|
|
49
|
-
] : []
|
|
50
|
-
],
|
|
51
|
-
replaysSessionSampleRate: options.replaySampleRate,
|
|
52
|
-
replaysOnErrorSampleRate: options.replaySampleRateOnError,
|
|
53
|
-
tracesSampleRate: options.sampleRate,
|
|
54
|
-
transport: options.transport,
|
|
55
|
-
beforeSend: (event) => {
|
|
56
|
-
options.onError?.(event);
|
|
57
|
-
return event;
|
|
58
|
-
}
|
|
59
|
-
});
|
|
60
|
-
if (options.tracing) {
|
|
61
|
-
TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);
|
|
62
|
-
TRACE_PROCESSOR.remoteTracing.registerProcessor({
|
|
63
|
-
startSpan: startInactiveSpan
|
|
64
|
-
});
|
|
65
|
-
}
|
|
66
|
-
Object.entries(options.properties ?? {}).forEach(([key, value]) => {
|
|
67
|
-
setTag(key, value);
|
|
68
|
-
});
|
|
69
|
-
} catch (err) {
|
|
70
|
-
log.catch("Failed to initialize sentry", err, {
|
|
71
|
-
F: __dxlog_file,
|
|
72
|
-
L: 78,
|
|
73
|
-
S: void 0,
|
|
74
|
-
C: (f, a) => f(...a)
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
};
|
|
78
|
-
var addBreadcrumb = (breadcrumb) => {
|
|
79
|
-
try {
|
|
80
|
-
naturalAddBreadcrumb(breadcrumb);
|
|
81
|
-
log("add breadcrumb", breadcrumb, {
|
|
82
|
-
F: __dxlog_file,
|
|
83
|
-
L: 94,
|
|
84
|
-
S: void 0,
|
|
85
|
-
C: (f, a) => f(...a)
|
|
86
|
-
});
|
|
87
|
-
} catch (err) {
|
|
88
|
-
log.catch("Failed to add breadcrumb", err, {
|
|
89
|
-
F: __dxlog_file,
|
|
90
|
-
L: 96,
|
|
91
|
-
S: void 0,
|
|
92
|
-
C: (f, a) => f(...a)
|
|
93
|
-
});
|
|
94
|
-
}
|
|
95
|
-
};
|
|
96
|
-
var captureException = (exception, captureContext) => {
|
|
97
|
-
try {
|
|
98
|
-
const eventId = naturalCaptureException(exception, captureContext);
|
|
99
|
-
log("capture exception", {
|
|
100
|
-
exception,
|
|
101
|
-
eventId,
|
|
102
|
-
...captureContext
|
|
103
|
-
}, {
|
|
104
|
-
F: __dxlog_file,
|
|
105
|
-
L: 110,
|
|
106
|
-
S: void 0,
|
|
107
|
-
C: (f, a) => f(...a)
|
|
108
|
-
});
|
|
109
|
-
return eventId;
|
|
110
|
-
} catch (err) {
|
|
111
|
-
log.catch("Failed to capture exception", err, {
|
|
112
|
-
F: __dxlog_file,
|
|
113
|
-
L: 113,
|
|
114
|
-
S: void 0,
|
|
115
|
-
C: (f, a) => f(...a)
|
|
116
|
-
});
|
|
117
|
-
return "unknown";
|
|
118
|
-
}
|
|
119
|
-
};
|
|
120
|
-
var captureMessage = (exception, captureContext) => {
|
|
121
|
-
try {
|
|
122
|
-
const eventId = naturalCaptureMessage(exception, captureContext);
|
|
123
|
-
log("capture message", {
|
|
124
|
-
exception,
|
|
125
|
-
eventId,
|
|
126
|
-
captureContext
|
|
127
|
-
}, {
|
|
128
|
-
F: __dxlog_file,
|
|
129
|
-
L: 121,
|
|
130
|
-
S: void 0,
|
|
131
|
-
C: (f, a) => f(...a)
|
|
132
|
-
});
|
|
133
|
-
return eventId;
|
|
134
|
-
} catch (err) {
|
|
135
|
-
log.catch("Failed to capture message", err, {
|
|
136
|
-
F: __dxlog_file,
|
|
137
|
-
L: 124,
|
|
138
|
-
S: void 0,
|
|
139
|
-
C: (f, a) => f(...a)
|
|
140
|
-
});
|
|
141
|
-
return "unknown";
|
|
142
|
-
}
|
|
143
|
-
};
|
|
144
|
-
var captureUserFeedback = (message) => {
|
|
145
|
-
return naturalSendFeedback({
|
|
146
|
-
message
|
|
147
|
-
}, {
|
|
148
|
-
includeReplay: true
|
|
149
|
-
});
|
|
150
|
-
};
|
|
151
|
-
var withScope = naturalWithScope;
|
|
152
|
-
|
|
153
|
-
export {
|
|
154
|
-
init,
|
|
155
|
-
addBreadcrumb,
|
|
156
|
-
captureException,
|
|
157
|
-
captureMessage,
|
|
158
|
-
captureUserFeedback,
|
|
159
|
-
withScope,
|
|
160
|
-
setTag2 as setTag,
|
|
161
|
-
setTags,
|
|
162
|
-
setUser
|
|
163
|
-
};
|
|
164
|
-
//# sourceMappingURL=chunk-LJO63BXO.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/sentry/browser.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport {\n breadcrumbsIntegration,\n browserTracingIntegration,\n feedbackIntegration,\n httpClientIntegration,\n metrics,\n addBreadcrumb as naturalAddBreadcrumb,\n captureException as naturalCaptureException,\n captureMessage as naturalCaptureMessage,\n init as naturalInit,\n sendFeedback as naturalSendFeedback,\n withScope as naturalWithScope,\n replayIntegration,\n setTag,\n startInactiveSpan,\n} from '@sentry/browser';\n\nimport { log } from '@dxos/log';\nimport { TRACE_PROCESSOR } from '@dxos/tracing';\n\nimport { type InitOptions } from './types';\n\n// Polyfill export.\nexport { setTag, setTags, setUser } from '@sentry/browser';\n\n/**\n * To use this SDK, call the init function as early as possible when loading the web page.\n * To set context information or send manual events, use the provided methods.\n *\n * @param options {InitOptions}\n */\nexport const init = (options: InitOptions) => {\n try {\n log('sentry init', options);\n naturalInit({\n enabled: options.enable ?? true,\n dsn: options.destination,\n release: options.release,\n environment: options.environment,\n integrations: [\n breadcrumbsIntegration({ console: false, fetch: false }),\n httpClientIntegration({\n failedRequestStatusCodes: [\n // 401 errors are omitted as they happen as a part of the EDGE authentication flow.\n [400, 400],\n [402, 599],\n ],\n }),\n feedbackIntegration({ autoInject: false }),\n ...(options.tracing ? [browserTracingIntegration()] : []),\n ...(options.replay ? [replayIntegration({ blockAllMedia: true, maskAllText: true })] : []),\n ],\n replaysSessionSampleRate: options.replaySampleRate,\n replaysOnErrorSampleRate: options.replaySampleRateOnError,\n tracesSampleRate: options.sampleRate,\n transport: options.transport,\n beforeSend: (event) => {\n options.onError?.(event);\n return event;\n },\n });\n\n if (options.tracing) {\n TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);\n TRACE_PROCESSOR.remoteTracing.registerProcessor({\n startSpan: startInactiveSpan,\n });\n }\n\n Object.entries(options.properties ?? {}).forEach(([key, value]) => {\n setTag(key, value);\n });\n } catch (err) {\n log.catch('Failed to initialize sentry', err);\n }\n};\n\n/**\n * Records a new breadcrumb which will be attached to future events.\n *\n * Breadcrumbs will be added to subsequent events to provide more context on user's actions prior to an error or crash.\n *\n * https://docs.sentry.io/platforms/javascript/enriching-events/breadcrumbs/\n *\n * @param breadcrumb — The breadcrumb to record.\n */\nexport const addBreadcrumb: typeof naturalAddBreadcrumb = (breadcrumb) => {\n try {\n naturalAddBreadcrumb(breadcrumb);\n log('add breadcrumb', breadcrumb);\n } catch (err) {\n log.catch('Failed to add breadcrumb', err);\n }\n};\n\n/**\n * Captures an exception event and sends it to Sentry.\n *\n * @param exception — An exception-like object.\n * @param captureContext — Additional scope data to apply to exception event.\n * @returns — The generated eventId.\n */\nexport const captureException: typeof naturalCaptureException = (exception, captureContext) => {\n try {\n const eventId = naturalCaptureException(exception, captureContext);\n log('capture exception', { exception, eventId, ...captureContext });\n return eventId;\n } catch (err) {\n log.catch('Failed to capture exception', err);\n return 'unknown';\n }\n};\n\nexport const captureMessage: typeof naturalCaptureMessage = (exception, captureContext) => {\n try {\n const eventId = naturalCaptureMessage(exception, captureContext);\n log('capture message', { exception, eventId, captureContext });\n return eventId;\n } catch (err) {\n log.catch('Failed to capture message', err);\n return 'unknown';\n }\n};\n\nexport const captureUserFeedback = (message: string) => {\n return naturalSendFeedback({ message }, { includeReplay: true });\n};\n\nexport const withScope = naturalWithScope;\n"],
|
|
5
|
-
"mappings": ";AAIA,SACEA,wBACAC,2BACAC,qBACAC,uBACAC,SACAC,iBAAiBC,sBACjBC,oBAAoBC,yBACpBC,kBAAkBC,uBAClBC,QAAQC,aACRC,gBAAgBC,qBAChBC,aAAaC,kBACbC,mBACAC,QACAC,yBACK;AAEP,SAASC,WAAW;AACpB,SAASC,uBAAuB;AAKhC,SAASH,UAAAA,SAAQI,SAASC,eAAe;;AAQlC,IAAMZ,OAAO,CAACa,YAAAA;AACnB,MAAI;AACFJ,QAAI,eAAeI,SAAAA;;;;;;AACnBZ,gBAAY;MACVa,SAASD,QAAQE,UAAU;MAC3BC,KAAKH,QAAQI;MACbC,SAASL,QAAQK;MACjBC,aAAaN,QAAQM;MACrBC,cAAc;QACZ/B,uBAAuB;UAAEgC,SAAS;UAAOC,OAAO;QAAM,CAAA;QACtD9B,sBAAsB;UACpB+B,0BAA0B;;YAExB;cAAC;cAAK;;YACN;cAAC;cAAK;;;QAEV,CAAA;QACAhC,oBAAoB;UAAEiC,YAAY;QAAM,CAAA;WACpCX,QAAQY,UAAU;UAACnC,0BAAAA;YAA+B,CAAA;WAClDuB,QAAQa,SAAS;UAACpB,kBAAkB;YAAEqB,eAAe;YAAMC,aAAa;UAAK,CAAA;YAAM,CAAA;;MAEzFC,0BAA0BhB,QAAQiB;MAClCC,0BAA0BlB,QAAQmB;MAClCC,kBAAkBpB,QAAQqB;MAC1BC,WAAWtB,QAAQsB;MACnBC,YAAY,CAACC,UAAAA;AACXxB,gBAAQyB,UAAUD,KAAAA;AAClB,eAAOA;MACT;IACF,CAAA;AAEA,QAAIxB,QAAQY,SAAS;AACnBf,sBAAgB6B,cAAcC,kBAAkB/C,OAAAA;AAChDiB,sBAAgB+B,cAAcD,kBAAkB;QAC9CE,WAAWlC;MACb,CAAA;IACF;AAEAmC,WAAOC,QAAQ/B,QAAQgC,cAAc,CAAC,CAAA,EAAGC,QAAQ,CAAC,CAACC,KAAKC,KAAAA,MAAM;AAC5DzC,aAAOwC,KAAKC,KAAAA;IACd,CAAA;EACF,SAASC,KAAK;AACZxC,QAAIyC,MAAM,+BAA+BD,KAAAA;;;;;;EAC3C;AACF;AAWO,IAAMvD,gBAA6C,CAACyD,eAAAA;AACzD,MAAI;AACFxD,yBAAqBwD,UAAAA;AACrB1C,QAAI,kBAAkB0C,YAAAA;;;;;;EACxB,SAASF,KAAK;AACZxC,QAAIyC,MAAM,4BAA4BD,KAAAA;;;;;;EACxC;AACF;AASO,IAAMrD,mBAAmD,CAACwD,WAAWC,mBAAAA;AAC1E,MAAI;AACF,UAAMC,UAAUzD,wBAAwBuD,WAAWC,cAAAA;AACnD5C,QAAI,qBAAqB;MAAE2C;MAAWE;MAAS,GAAGD;IAAe,GAAA;;;;;;AACjE,WAAOC;EACT,SAASL,KAAK;AACZxC,QAAIyC,MAAM,+BAA+BD,KAAAA;;;;;;AACzC,WAAO;EACT;AACF;AAEO,IAAMnD,iBAA+C,CAACsD,WAAWC,mBAAAA;AACtE,MAAI;AACF,UAAMC,UAAUvD,sBAAsBqD,WAAWC,cAAAA;AACjD5C,QAAI,mBAAmB;MAAE2C;MAAWE;MAASD;IAAe,GAAA;;;;;;AAC5D,WAAOC;EACT,SAASL,KAAK;AACZxC,QAAIyC,MAAM,6BAA6BD,KAAAA;;;;;;AACvC,WAAO;EACT;AACF;AAEO,IAAMM,sBAAsB,CAACC,YAAAA;AAClC,SAAOrD,oBAAoB;IAAEqD;EAAQ,GAAG;IAAEC,eAAe;EAAK,CAAA;AAChE;AAEO,IAAMrD,YAAYC;",
|
|
6
|
-
"names": ["breadcrumbsIntegration", "browserTracingIntegration", "feedbackIntegration", "httpClientIntegration", "metrics", "addBreadcrumb", "naturalAddBreadcrumb", "captureException", "naturalCaptureException", "captureMessage", "naturalCaptureMessage", "init", "naturalInit", "sendFeedback", "naturalSendFeedback", "withScope", "naturalWithScope", "replayIntegration", "setTag", "startInactiveSpan", "log", "TRACE_PROCESSOR", "setTags", "setUser", "options", "enabled", "enable", "dsn", "destination", "release", "environment", "integrations", "console", "fetch", "failedRequestStatusCodes", "autoInject", "tracing", "replay", "blockAllMedia", "maskAllText", "replaysSessionSampleRate", "replaySampleRate", "replaysOnErrorSampleRate", "replaySampleRateOnError", "tracesSampleRate", "sampleRate", "transport", "beforeSend", "event", "onError", "remoteMetrics", "registerProcessor", "remoteTracing", "startSpan", "Object", "entries", "properties", "forEach", "key", "value", "err", "catch", "breadcrumb", "exception", "captureContext", "eventId", "captureUserFeedback", "message", "includeReplay"]
|
|
7
|
-
}
|