@dxos/observability 0.8.3 → 0.8.4-main.1068cf700f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-K4VFBKST.mjs +13 -0
- package/dist/lib/browser/chunk-K4VFBKST.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +1066 -34
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/log-processor-FDLTDQEM.mjs +45 -0
- package/dist/lib/browser/log-processor-FDLTDQEM.mjs.map +7 -0
- package/dist/lib/browser/logs-ATTRIUTL.mjs +113 -0
- package/dist/lib/browser/logs-ATTRIUTL.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/metrics-PKTV6IGF.mjs +130 -0
- package/dist/lib/browser/metrics-PKTV6IGF.mjs.map +7 -0
- package/dist/lib/browser/traces-browser-XYXBF5ZX.mjs +62 -0
- package/dist/lib/browser/traces-browser-XYXBF5ZX.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-FEVP3MK4.mjs +15 -0
- package/dist/lib/node-esm/chunk-FEVP3MK4.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
- package/dist/lib/node-esm/index.mjs +1070 -34
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/log-processor-TKJVJJSJ.mjs +46 -0
- package/dist/lib/node-esm/log-processor-TKJVJJSJ.mjs.map +7 -0
- package/dist/lib/node-esm/logs-7J45KLM7.mjs +114 -0
- package/dist/lib/node-esm/logs-7J45KLM7.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/metrics-H7DDLYSG.mjs +131 -0
- package/dist/lib/node-esm/metrics-H7DDLYSG.mjs.map +7 -0
- package/dist/lib/node-esm/traces-KMTHMYFX.mjs +44 -0
- package/dist/lib/node-esm/traces-KMTHMYFX.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 +124 -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 +104 -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 +6 -12
- 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/{otel → extensions/otel}/otel.js +1 -1
- package/dist/types/src/extensions/otel/otel.js.map +1 -0
- package/dist/types/src/extensions/otel/traces-browser.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/traces-browser.js +44 -0
- package/dist/types/src/extensions/otel/traces-browser.js.map +1 -0
- package/dist/types/src/extensions/otel/traces.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/traces.js +38 -0
- package/dist/types/src/extensions/otel/traces.js.map +1 -0
- package/dist/types/src/extensions/posthog/extension.d.ts +15 -0
- package/dist/types/src/extensions/posthog/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/extension.js +143 -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 +4 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/index.js +5 -3
- package/dist/types/src/index.js.map +1 -1
- package/dist/types/src/log-buffer.d.ts +34 -0
- package/dist/types/src/log-buffer.d.ts.map +1 -0
- package/dist/types/src/log-buffer.js +70 -0
- package/dist/types/src/log-buffer.js.map +1 -0
- package/dist/types/src/log-buffer.test.d.ts +2 -0
- package/dist/types/src/log-buffer.test.d.ts.map +1 -0
- package/dist/types/src/log-buffer.test.js +107 -0
- package/dist/types/src/log-buffer.test.js.map +1 -0
- 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 +176 -455
- 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 +200 -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 +55 -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 +58 -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/{src/segment/index.ts → dist/types/src/storage/index.js} +1 -2
- 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/storage/node.js +92 -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 +42 -63
- package/src/cli-observability-secrets.json +3 -4
- package/src/extensions/index.ts +6 -0
- package/src/extensions/otel/extension.ts +178 -0
- package/src/extensions/otel/index.ts +5 -0
- package/src/extensions/otel/logs.ts +134 -0
- package/src/{otel → extensions/otel}/metrics.ts +4 -21
- package/src/{otel → extensions/otel}/otel.ts +4 -4
- package/src/extensions/otel/traces-browser.ts +57 -0
- package/src/extensions/otel/traces.ts +49 -0
- package/src/extensions/posthog/extension.ts +172 -0
- package/src/extensions/posthog/index.ts +5 -0
- package/src/extensions/posthog/log-processor.test.ts +185 -0
- package/src/extensions/posthog/log-processor.ts +54 -0
- package/src/extensions/stub.ts +19 -0
- package/src/index.ts +5 -3
- package/src/log-buffer.test.ts +134 -0
- package/src/log-buffer.ts +101 -0
- 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 +253 -0
- package/src/providers/index.ts +7 -0
- package/src/providers/ip-data.ts +88 -0
- package/src/providers/storage.ts +23 -0
- package/src/storage/browser.ts +61 -0
- package/src/{sentry → storage}/index.ts +0 -1
- package/src/storage/node.test.ts +130 -0
- package/src/{helpers/node-observability.ts → storage/node.ts} +42 -70
- package/dist/lib/browser/chunk-G6EE7HFV.mjs +0 -147
- package/dist/lib/browser/chunk-G6EE7HFV.mjs.map +0 -7
- package/dist/lib/browser/chunk-JA5VJRKF.mjs +0 -164
- package/dist/lib/browser/chunk-JA5VJRKF.mjs.map +0 -7
- package/dist/lib/browser/chunk-KDP3SESE.mjs +0 -1
- package/dist/lib/browser/chunk-YQJELTRP.mjs +0 -996
- package/dist/lib/browser/chunk-YQJELTRP.mjs.map +0 -7
- package/dist/lib/browser/observability-HDE3I7TA.mjs +0 -10
- package/dist/lib/browser/otel-LHAFLNBQ.mjs +0 -277
- package/dist/lib/browser/otel-LHAFLNBQ.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-625AISXI.mjs +0 -146
- package/dist/lib/browser/sentry-log-processor-625AISXI.mjs.map +0 -7
- package/dist/lib/node/chunk-325GAGFA.cjs +0 -213
- package/dist/lib/node/chunk-325GAGFA.cjs.map +0 -7
- package/dist/lib/node/chunk-BZHVFSLF.cjs +0 -1025
- package/dist/lib/node/chunk-BZHVFSLF.cjs.map +0 -7
- package/dist/lib/node/chunk-GIYJMZEQ.cjs +0 -2
- package/dist/lib/node/chunk-GIYJMZEQ.cjs.map +0 -7
- package/dist/lib/node/chunk-MZ3PMDTP.cjs +0 -163
- package/dist/lib/node/chunk-MZ3PMDTP.cjs.map +0 -7
- package/dist/lib/node/index.cjs +0 -60
- package/dist/lib/node/index.cjs.map +0 -7
- package/dist/lib/node/meta.json +0 -1
- package/dist/lib/node/observability-E2NGRIEN.cjs +0 -32
- package/dist/lib/node/observability-E2NGRIEN.cjs.map +0 -7
- package/dist/lib/node/otel-VF5YNCR3.cjs +0 -278
- package/dist/lib/node/otel-VF5YNCR3.cjs.map +0 -7
- package/dist/lib/node/segment/index.cjs +0 -33
- package/dist/lib/node/segment/index.cjs.map +0 -7
- package/dist/lib/node/sentry/index.cjs +0 -46
- package/dist/lib/node/sentry/index.cjs.map +0 -7
- package/dist/lib/node/sentry-log-processor-CCV4RL7N.cjs +0 -164
- package/dist/lib/node/sentry-log-processor-CCV4RL7N.cjs.map +0 -7
- package/dist/lib/node-esm/chunk-AZMSBUWR.mjs +0 -202
- package/dist/lib/node-esm/chunk-AZMSBUWR.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-H7Y2DDUN.mjs +0 -135
- package/dist/lib/node-esm/chunk-H7Y2DDUN.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-M7QJLFGR.mjs +0 -997
- package/dist/lib/node-esm/chunk-M7QJLFGR.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YJ4KVBWC.mjs +0 -2
- package/dist/lib/node-esm/chunk-YJ4KVBWC.mjs.map +0 -7
- package/dist/lib/node-esm/observability-7BTI46NM.mjs +0 -11
- package/dist/lib/node-esm/observability-7BTI46NM.mjs.map +0 -7
- package/dist/lib/node-esm/otel-AF5TSABC.mjs +0 -260
- package/dist/lib/node-esm/otel-AF5TSABC.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-HPUPCMRG.mjs +0 -147
- package/dist/lib/node-esm/sentry-log-processor-HPUPCMRG.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 -140
- 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 -37
- 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 -101
- 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 -97
- 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 -71
- 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.map +0 -1
- package/dist/types/src/otel/traces-browser.js +0 -47
- package/dist/types/src/otel/traces-browser.js.map +0 -1
- package/dist/types/src/otel/traces.d.ts.map +0 -1
- package/dist/types/src/otel/traces.js +0 -40
- 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 -50
- 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 -67
- 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 -83
- 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 -112
- 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 +0 -6
- 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 -111
- 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 -34
- 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 -149
- 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 -177
- 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 -108
- 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 -68
- package/src/segment/node.ts +0 -94
- package/src/segment/types.ts +0 -57
- package/src/sentry/browser.ts +0 -133
- package/src/sentry/node.node.test.ts +0 -39
- package/src/sentry/node.ts +0 -126
- package/src/sentry/sentry-log-processor.ts +0 -166
- package/src/sentry/sentry.node.test.ts +0 -34
- 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-KDP3SESE.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/{browser/observability-HDE3I7TA.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
- /package/dist/types/src/{otel → extensions/otel}/traces-browser.d.ts +0 -0
- /package/dist/types/src/{otel → extensions/otel}/traces.d.ts +0 -0
|
@@ -1,16 +1,12 @@
|
|
|
1
1
|
//
|
|
2
2
|
// Copyright 2022 DXOS.org
|
|
3
3
|
//
|
|
4
|
-
import yaml from 'js-yaml';
|
|
5
4
|
import { existsSync, statSync } from 'node:fs';
|
|
6
5
|
import { mkdir, readFile, writeFile } from 'node:fs/promises';
|
|
7
6
|
import { join } from 'node:path';
|
|
8
|
-
import { v4 as uuid, validate as validateUuid } from 'uuid';
|
|
9
7
|
|
|
10
|
-
import
|
|
11
|
-
import {
|
|
12
|
-
|
|
13
|
-
import { Observability, type Mode } from '../observability';
|
|
8
|
+
import yaml from 'js-yaml';
|
|
9
|
+
import { v4 as uuid, validate as validateUuid } from 'uuid';
|
|
14
10
|
|
|
15
11
|
/**
|
|
16
12
|
* Print observability banner once per installation.
|
|
@@ -21,7 +17,6 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
21
17
|
return;
|
|
22
18
|
}
|
|
23
19
|
bannercb(
|
|
24
|
-
// eslint-disable-next-line no-multi-str
|
|
25
20
|
'Basic observability data will be sent to the DXOS team in order to improve the product. This includes \
|
|
26
21
|
performance metrics, error logs, and usage data. No personally identifiable information, other than your \
|
|
27
22
|
public key, is included with this data and no private data ever leaves your devices. To disable sending \
|
|
@@ -31,7 +26,43 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
31
26
|
await writeFile(path, '', 'utf-8');
|
|
32
27
|
};
|
|
33
28
|
|
|
34
|
-
|
|
29
|
+
/**
|
|
30
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
31
|
+
*/
|
|
32
|
+
export const isObservabilityDisabled = async (configDir: string): Promise<boolean> => {
|
|
33
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
34
|
+
return observabilityState.disabled;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
39
|
+
*/
|
|
40
|
+
// NOTE: read-modify-write is not atomic; concurrent callers could overwrite each other.
|
|
41
|
+
// Acceptable here because writes are infrequent and triggered by explicit user action.
|
|
42
|
+
export const storeObservabilityDisabled = async (configDir: string, value: boolean) => {
|
|
43
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
44
|
+
observabilityState.disabled = value;
|
|
45
|
+
await writeFile(join(configDir, 'observability.yml'), yaml.dump(observabilityState), 'utf-8');
|
|
46
|
+
};
|
|
47
|
+
|
|
48
|
+
/**
|
|
49
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
50
|
+
*/
|
|
51
|
+
export const getObservabilityGroup = async (configDir: string): Promise<string | undefined> => {
|
|
52
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
53
|
+
return observabilityState.group;
|
|
54
|
+
};
|
|
55
|
+
|
|
56
|
+
/**
|
|
57
|
+
* @param configDir - Filesystem path to the directory containing the `observability.yml` state file.
|
|
58
|
+
*/
|
|
59
|
+
export const storeObservabilityGroup = async (configDir: string, value: string) => {
|
|
60
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
61
|
+
observabilityState.group = value;
|
|
62
|
+
await writeFile(join(configDir, 'observability.yml'), yaml.dump(observabilityState), 'utf-8');
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
const getObservabilityState = async (configDir: string): Promise<PersistentObservabilityState> => {
|
|
35
66
|
// check whether configDir exists and if it's a directory
|
|
36
67
|
|
|
37
68
|
if (existsSync(configDir)) {
|
|
@@ -53,8 +84,8 @@ export const getObservabilityState = async (configDir: string): Promise<Persiste
|
|
|
53
84
|
|
|
54
85
|
export type PersistentObservabilityState = {
|
|
55
86
|
installationId: string;
|
|
87
|
+
disabled: boolean;
|
|
56
88
|
group?: string;
|
|
57
|
-
mode: Mode;
|
|
58
89
|
};
|
|
59
90
|
|
|
60
91
|
// create initial state and write to file, using environment variables to override defaults.
|
|
@@ -62,8 +93,8 @@ const initializeState = async (idPath: string): Promise<PersistentObservabilityS
|
|
|
62
93
|
// TODO(nf): read initial values from config or seed file
|
|
63
94
|
const observabilityState = {
|
|
64
95
|
installationId: uuid(),
|
|
96
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : false,
|
|
65
97
|
group: process.env.DX_OBSERVABILITY_GROUP ?? undefined,
|
|
66
|
-
mode: (process.env.DX_DISABLE_OBSERVABILITY ? 'disabled' : process.env.DX_OBSERVABILITY_MODE ?? 'basic') as Mode,
|
|
67
98
|
};
|
|
68
99
|
|
|
69
100
|
await writeFile(
|
|
@@ -80,66 +111,7 @@ const validate = (contextString: string) => {
|
|
|
80
111
|
if (Boolean(context.installationId) && validateUuid(context.installationId!)) {
|
|
81
112
|
return {
|
|
82
113
|
...context,
|
|
83
|
-
|
|
114
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : (context.disabled ?? false),
|
|
84
115
|
};
|
|
85
116
|
}
|
|
86
117
|
};
|
|
87
|
-
|
|
88
|
-
export type NodeObservabilityOptions = {
|
|
89
|
-
installationId: string;
|
|
90
|
-
group?: string;
|
|
91
|
-
namespace: string;
|
|
92
|
-
version: string;
|
|
93
|
-
config: Config;
|
|
94
|
-
mode?: Mode;
|
|
95
|
-
tracingEnable?: boolean;
|
|
96
|
-
replayEnable?: boolean;
|
|
97
|
-
// TODO(nf): options for providers?
|
|
98
|
-
};
|
|
99
|
-
|
|
100
|
-
export const initializeNodeObservability = async ({
|
|
101
|
-
namespace,
|
|
102
|
-
version,
|
|
103
|
-
config,
|
|
104
|
-
installationId,
|
|
105
|
-
group,
|
|
106
|
-
mode = 'basic',
|
|
107
|
-
tracingEnable = true,
|
|
108
|
-
replayEnable = true,
|
|
109
|
-
}: NodeObservabilityOptions): Promise<Observability> => {
|
|
110
|
-
log('initializeCliObservability', { config });
|
|
111
|
-
|
|
112
|
-
// TODO(nf): make CLI build populate runtime.app.build config?
|
|
113
|
-
const release = `${namespace}@${version}`;
|
|
114
|
-
const environment = process.env.DX_ENVIRONMENT ?? 'unknown';
|
|
115
|
-
|
|
116
|
-
const observability = new Observability({
|
|
117
|
-
mode,
|
|
118
|
-
namespace,
|
|
119
|
-
release,
|
|
120
|
-
environment,
|
|
121
|
-
group,
|
|
122
|
-
errorLog: {
|
|
123
|
-
sentryInitOptions: {
|
|
124
|
-
environment,
|
|
125
|
-
release,
|
|
126
|
-
// TODO(wittjosiah): Configure this.
|
|
127
|
-
sampleRate: 1.0,
|
|
128
|
-
},
|
|
129
|
-
},
|
|
130
|
-
});
|
|
131
|
-
|
|
132
|
-
observability.setTag('installationId', installationId);
|
|
133
|
-
|
|
134
|
-
// TODO(nf): cache ipdata to avoid repeated requests
|
|
135
|
-
const IPDATA_API_KEY = config.get('runtime.app.env.DX_IPDATA_API_KEY');
|
|
136
|
-
try {
|
|
137
|
-
const res = await fetch(`https://api.ipdata.co/?api-key=${IPDATA_API_KEY}`);
|
|
138
|
-
const ipData = await res.json();
|
|
139
|
-
ipData && observability.setIPDataTelemetryTags(ipData);
|
|
140
|
-
} catch (err) {
|
|
141
|
-
observability?.captureException(err);
|
|
142
|
-
}
|
|
143
|
-
|
|
144
|
-
return observability;
|
|
145
|
-
};
|
|
@@ -1,147 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
captureException
|
|
3
|
-
} from "./chunk-JA5VJRKF.mjs";
|
|
4
|
-
|
|
5
|
-
// packages/sdk/observability/src/segment/browser.ts
|
|
6
|
-
import snippet from "@segment/snippet";
|
|
7
|
-
import { log as log2 } from "@dxos/log";
|
|
8
|
-
|
|
9
|
-
// packages/sdk/observability/src/segment/base.ts
|
|
10
|
-
import { log } from "@dxos/log";
|
|
11
|
-
|
|
12
|
-
// packages/sdk/observability/src/segment/types.ts
|
|
13
|
-
var TelemetryEvent = /* @__PURE__ */ function(TelemetryEvent2) {
|
|
14
|
-
TelemetryEvent2["ACTION"] = "action";
|
|
15
|
-
TelemetryEvent2["METRICS"] = "metrics";
|
|
16
|
-
return TelemetryEvent2;
|
|
17
|
-
}({});
|
|
18
|
-
|
|
19
|
-
// packages/sdk/observability/src/segment/base.ts
|
|
20
|
-
var __dxlog_file = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/segment/base.ts";
|
|
21
|
-
var getIdentityOptions = ({ did, installationId }) => {
|
|
22
|
-
if (!did && !installationId) {
|
|
23
|
-
log.warn("No telemetry identifier provided.", void 0, {
|
|
24
|
-
F: __dxlog_file,
|
|
25
|
-
L: 23,
|
|
26
|
-
S: void 0,
|
|
27
|
-
C: (f, a) => f(...a)
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
return {
|
|
31
|
-
userId: did,
|
|
32
|
-
anonymousId: installationId
|
|
33
|
-
};
|
|
34
|
-
};
|
|
35
|
-
var AbstractSegmentTelemetry = class {
|
|
36
|
-
constructor(_getTags) {
|
|
37
|
-
this._getTags = _getTags;
|
|
38
|
-
}
|
|
39
|
-
createPageProps(options) {
|
|
40
|
-
const { properties, ...rest } = options;
|
|
41
|
-
return {
|
|
42
|
-
...getIdentityOptions(options),
|
|
43
|
-
...rest,
|
|
44
|
-
properties: {
|
|
45
|
-
common: this._getTags(),
|
|
46
|
-
custom: properties
|
|
47
|
-
}
|
|
48
|
-
};
|
|
49
|
-
}
|
|
50
|
-
createTrackProps(options) {
|
|
51
|
-
const { event, action, properties, ...rest } = options;
|
|
52
|
-
return {
|
|
53
|
-
...getIdentityOptions(options),
|
|
54
|
-
...rest,
|
|
55
|
-
event: event ?? TelemetryEvent.ACTION,
|
|
56
|
-
properties: {
|
|
57
|
-
action,
|
|
58
|
-
common: this._getTags(),
|
|
59
|
-
custom: properties
|
|
60
|
-
}
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
};
|
|
64
|
-
|
|
65
|
-
// packages/sdk/observability/src/segment/browser.ts
|
|
66
|
-
var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/sdk/observability/src/segment/browser.ts";
|
|
67
|
-
var SegmentTelemetry = class extends AbstractSegmentTelemetry {
|
|
68
|
-
constructor({ apiKey, batchSize, getTags }) {
|
|
69
|
-
super(getTags);
|
|
70
|
-
try {
|
|
71
|
-
const contents = snippet.min({
|
|
72
|
-
apiKey,
|
|
73
|
-
page: false
|
|
74
|
-
});
|
|
75
|
-
const script = document.createElement("script");
|
|
76
|
-
script.innerHTML = contents;
|
|
77
|
-
document.body.append(script);
|
|
78
|
-
} catch (err) {
|
|
79
|
-
log2.catch("failed to initialize telemetry", err, {
|
|
80
|
-
F: __dxlog_file2,
|
|
81
|
-
L: 27,
|
|
82
|
-
S: this,
|
|
83
|
-
C: (f, a) => f(...a)
|
|
84
|
-
});
|
|
85
|
-
}
|
|
86
|
-
}
|
|
87
|
-
identify(options) {
|
|
88
|
-
try {
|
|
89
|
-
window.analytics?.identify(options.userId, options.traits);
|
|
90
|
-
} catch (err) {
|
|
91
|
-
log2.catch("failed to identify", err, {
|
|
92
|
-
F: __dxlog_file2,
|
|
93
|
-
L: 35,
|
|
94
|
-
S: this,
|
|
95
|
-
C: (f, a) => f(...a)
|
|
96
|
-
});
|
|
97
|
-
}
|
|
98
|
-
}
|
|
99
|
-
page(options) {
|
|
100
|
-
try {
|
|
101
|
-
const props = this.createPageProps(options);
|
|
102
|
-
window.analytics?.page(props.category, props.name, props.properties);
|
|
103
|
-
} catch (err) {
|
|
104
|
-
log2.catch("failed to track page", err, {
|
|
105
|
-
F: __dxlog_file2,
|
|
106
|
-
L: 44,
|
|
107
|
-
S: this,
|
|
108
|
-
C: (f, a) => f(...a)
|
|
109
|
-
});
|
|
110
|
-
}
|
|
111
|
-
}
|
|
112
|
-
track(options) {
|
|
113
|
-
try {
|
|
114
|
-
const props = this.createTrackProps(options);
|
|
115
|
-
window.analytics?.track(props.event, props.properties);
|
|
116
|
-
} catch (err) {
|
|
117
|
-
log2.catch("failed to track event", err, {
|
|
118
|
-
F: __dxlog_file2,
|
|
119
|
-
L: 53,
|
|
120
|
-
S: this,
|
|
121
|
-
C: (f, a) => f(...a)
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
async flush() {
|
|
126
|
-
try {
|
|
127
|
-
await window.analytics?.flush((err) => {
|
|
128
|
-
captureException(err);
|
|
129
|
-
});
|
|
130
|
-
} catch (err) {
|
|
131
|
-
log2.catch("failed to flush telemetry", err, {
|
|
132
|
-
F: __dxlog_file2,
|
|
133
|
-
L: 63,
|
|
134
|
-
S: this,
|
|
135
|
-
C: (f, a) => f(...a)
|
|
136
|
-
});
|
|
137
|
-
}
|
|
138
|
-
}
|
|
139
|
-
async close() {
|
|
140
|
-
}
|
|
141
|
-
};
|
|
142
|
-
|
|
143
|
-
export {
|
|
144
|
-
TelemetryEvent,
|
|
145
|
-
SegmentTelemetry
|
|
146
|
-
};
|
|
147
|
-
//# sourceMappingURL=chunk-G6EE7HFV.mjs.map
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../../src/segment/browser.ts", "../../../src/segment/base.ts", "../../../src/segment/types.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { type IdentifyParams } from '@segment/analytics-node';\nimport snippet from '@segment/snippet';\n\nimport { log } from '@dxos/log';\n\nimport { AbstractSegmentTelemetry } from './base';\nimport type { TrackOptions, SegmentTelemetryOptions, PageOptions } from './types';\nimport { captureException } from '../sentry';\n\n/**\n * Browser telemetry.\n */\n// https://segment.com/docs/connections/sources/catalog/libraries/website/javascript/#basic-tracking-methods\nexport class SegmentTelemetry extends AbstractSegmentTelemetry {\n constructor({ apiKey, batchSize, getTags }: SegmentTelemetryOptions) {\n super(getTags);\n try {\n const contents = snippet.min({ apiKey, page: false });\n const script = document.createElement('script');\n script.innerHTML = contents;\n document.body.append(script);\n } catch (err) {\n log.catch('failed to initialize telemetry', err);\n }\n }\n\n identify(options: IdentifyParams): void {\n try {\n (window as any).analytics?.identify(options.userId, options.traits);\n } catch (err) {\n log.catch('failed to identify', err);\n }\n }\n\n page(options: PageOptions): void {\n try {\n const props = this.createPageProps(options);\n (window as any).analytics?.page(props.category, props.name, props.properties);\n } catch (err) {\n log.catch('failed to track page', err);\n }\n }\n\n track(options: TrackOptions): void {\n try {\n const props = this.createTrackProps(options);\n (window as any).analytics?.track(props.event, props.properties);\n } catch (err) {\n log.catch('failed to track event', err);\n }\n }\n\n async flush(): Promise<void> {\n try {\n await (window as any).analytics?.flush((err: any) => {\n captureException(err);\n });\n } catch (err) {\n log.catch('failed to flush telemetry', err);\n }\n }\n\n async close(): Promise<void> {}\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type TrackParams, type PageParams, type IdentifyParams } from '@segment/analytics-node';\n\nimport { log } from '@dxos/log';\n\nimport {\n type IdentityOptions,\n type PageOptions,\n type SegmentIdentityOptions,\n type Tags,\n TelemetryEvent,\n type TrackOptions,\n} from './types';\n\n/**\n * NOTE: Segment provides a default ID if we don't provide one.\n */\nconst getIdentityOptions = ({ did, installationId }: IdentityOptions): SegmentIdentityOptions => {\n if (!did && !installationId) {\n log.warn('No telemetry identifier provided.');\n }\n\n return {\n userId: did,\n anonymousId: installationId,\n } as SegmentIdentityOptions;\n};\n\n/**\n * Base class for Node and BrowserSegment telemetry.\n */\nexport abstract class AbstractSegmentTelemetry {\n constructor(private readonly _getTags: () => Tags) {}\n\n abstract identify(options: IdentifyParams): void;\n\n abstract page(options: PageOptions): void;\n\n abstract track(options: TrackOptions): void;\n\n protected createPageProps(options: PageOptions): PageParams {\n const { properties, ...rest } = options;\n return {\n ...getIdentityOptions(options),\n ...rest,\n properties: {\n common: this._getTags(),\n custom: properties,\n },\n };\n }\n\n protected createTrackProps(options: TrackOptions): TrackParams {\n const { event, action, properties, ...rest } = options;\n return {\n ...getIdentityOptions(options),\n ...rest,\n event: event ?? TelemetryEvent.ACTION,\n properties: {\n action,\n common: this._getTags(),\n custom: properties,\n },\n };\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nexport type Tags = Record<string, string>;\n\nexport type SegmentTelemetryOptions = {\n apiKey?: string;\n batchSize?: number;\n enable?: boolean;\n getTags: () => Tags;\n};\n\n// Copied from @segment/analytics-node.\nexport type SegmentIdentityOptions =\n | { userId: string; anonymousId?: string }\n | { userId?: string; anonymousId: string };\n\n// TODO(burdon): Should require one or the other.\nexport type IdentityOptions = { did?: string; installationId?: string };\n\nexport type CommonOptions = IdentityOptions & {\n timestamp?: Date;\n properties?: Record<string, unknown>;\n};\n\n/**\n * Page views.\n * https://segment.com/docs/connections/sources/catalog/libraries/server/node/#page\n */\nexport type PageOptions = CommonOptions & {\n category?: string;\n name?: string;\n};\n\n/**\n * Track actions.\n * https://segment.com/docs/connections/sources/catalog/libraries/server/node/#track\n */\nexport type TrackOptions = CommonOptions & {\n event?: TelemetryEvent;\n action: string;\n};\n\n/**\n * Each event will be mapped to a different Postgres table via segment.\n */\nexport enum TelemetryEvent {\n /**\n * Use actions.\n */\n ACTION = 'action',\n /**\n * High-volume technical metrics.\n */\n METRICS = 'metrics',\n}\n"],
|
|
5
|
-
"mappings": ";;;;;AAKA,OAAOA,aAAa;AAEpB,SAASC,OAAAA,YAAW;;;ACDpB,SAASC,WAAW;;;ACyCb,IAAKC,iBAAAA,yBAAAA,iBAAAA;AAGT,EAAAA,gBAAA,QAAA,IAAA;AAIA,EAAAA,gBAAA,SAAA,IAAA;SAPSA;;;;;AD3BZ,IAAMC,qBAAqB,CAAC,EAAEC,KAAKC,eAAc,MAAmB;AAClE,MAAI,CAACD,OAAO,CAACC,gBAAgB;AAC3BC,QAAIC,KAAK,qCAAA,QAAA;;;;;;EACX;AAEA,SAAO;IACLC,QAAQJ;IACRK,aAAaJ;EACf;AACF;AAKO,IAAeK,2BAAf,MAAeA;EACpB,YAA6BC,UAAsB;SAAtBA,WAAAA;EAAuB;EAQ1CC,gBAAgBC,SAAkC;AAC1D,UAAM,EAAEC,YAAY,GAAGC,KAAAA,IAASF;AAChC,WAAO;MACL,GAAGV,mBAAmBU,OAAAA;MACtB,GAAGE;MACHD,YAAY;QACVE,QAAQ,KAAKL,SAAQ;QACrBM,QAAQH;MACV;IACF;EACF;EAEUI,iBAAiBL,SAAoC;AAC7D,UAAM,EAAEM,OAAOC,QAAQN,YAAY,GAAGC,KAAAA,IAASF;AAC/C,WAAO;MACL,GAAGV,mBAAmBU,OAAAA;MACtB,GAAGE;MACHI,OAAOA,SAASE,eAAeC;MAC/BR,YAAY;QACVM;QACAJ,QAAQ,KAAKL,SAAQ;QACrBM,QAAQH;MACV;IACF;EACF;AACF;;;;ADnDO,IAAMS,mBAAN,cAA+BC,yBAAAA;EACpC,YAAY,EAAEC,QAAQC,WAAWC,QAAO,GAA6B;AACnE,UAAMA,OAAAA;AACN,QAAI;AACF,YAAMC,WAAWC,QAAQC,IAAI;QAAEL;QAAQM,MAAM;MAAM,CAAA;AACnD,YAAMC,SAASC,SAASC,cAAc,QAAA;AACtCF,aAAOG,YAAYP;AACnBK,eAASG,KAAKC,OAAOL,MAAAA;IACvB,SAASM,KAAK;AACZC,MAAAA,KAAIC,MAAM,kCAAkCF,KAAAA;;;;;;IAC9C;EACF;EAEAG,SAASC,SAA+B;AACtC,QAAI;AACDC,aAAeC,WAAWH,SAASC,QAAQG,QAAQH,QAAQI,MAAM;IACpE,SAASR,KAAK;AACZC,MAAAA,KAAIC,MAAM,sBAAsBF,KAAAA;;;;;;IAClC;EACF;EAEAP,KAAKW,SAA4B;AAC/B,QAAI;AACF,YAAMK,QAAQ,KAAKC,gBAAgBN,OAAAA;AAClCC,aAAeC,WAAWb,KAAKgB,MAAME,UAAUF,MAAMG,MAAMH,MAAMI,UAAU;IAC9E,SAASb,KAAK;AACZC,MAAAA,KAAIC,MAAM,wBAAwBF,KAAAA;;;;;;IACpC;EACF;EAEAc,MAAMV,SAA6B;AACjC,QAAI;AACF,YAAMK,QAAQ,KAAKM,iBAAiBX,OAAAA;AACnCC,aAAeC,WAAWQ,MAAML,MAAMO,OAAOP,MAAMI,UAAU;IAChE,SAASb,KAAK;AACZC,MAAAA,KAAIC,MAAM,yBAAyBF,KAAAA;;;;;;IACrC;EACF;EAEA,MAAMiB,QAAuB;AAC3B,QAAI;AACF,YAAOZ,OAAeC,WAAWW,MAAM,CAACjB,QAAAA;AACtCkB,yBAAiBlB,GAAAA;MACnB,CAAA;IACF,SAASA,KAAK;AACZC,MAAAA,KAAIC,MAAM,6BAA6BF,KAAAA;;;;;;IACzC;EACF;EAEA,MAAMmB,QAAuB;EAAC;AAChC;",
|
|
6
|
-
"names": ["snippet", "log", "log", "TelemetryEvent", "getIdentityOptions", "did", "installationId", "log", "warn", "userId", "anonymousId", "AbstractSegmentTelemetry", "_getTags", "createPageProps", "options", "properties", "rest", "common", "custom", "createTrackProps", "event", "action", "TelemetryEvent", "ACTION", "SegmentTelemetry", "AbstractSegmentTelemetry", "apiKey", "batchSize", "getTags", "contents", "snippet", "min", "page", "script", "document", "createElement", "innerHTML", "body", "append", "err", "log", "catch", "identify", "options", "window", "analytics", "userId", "traits", "props", "createPageProps", "category", "name", "properties", "track", "createTrackProps", "event", "flush", "captureException", "close"]
|
|
7
|
-
}
|
|
@@ -1,164 +0,0 @@
|
|
|
1
|
-
// packages/sdk/observability/src/sentry/browser.ts
|
|
2
|
-
import { init as naturalInit, setTag, addBreadcrumb as naturalAddBreadcrumb, captureException as naturalCaptureException, captureMessage as naturalCaptureMessage, sendFeedback as naturalSendFeedback, withScope as naturalWithScope, breadcrumbsIntegration, browserTracingIntegration, feedbackIntegration, httpClientIntegration, replayIntegration, metrics, 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 = "/home/runner/work/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-JA5VJRKF.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 init as naturalInit,\n setTag,\n addBreadcrumb as naturalAddBreadcrumb,\n captureException as naturalCaptureException,\n captureMessage as naturalCaptureMessage,\n sendFeedback as naturalSendFeedback,\n withScope as naturalWithScope,\n breadcrumbsIntegration,\n browserTracingIntegration,\n feedbackIntegration,\n httpClientIntegration,\n replayIntegration,\n metrics,\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,QAAQC,aACRC,QACAC,iBAAiBC,sBACjBC,oBAAoBC,yBACpBC,kBAAkBC,uBAClBC,gBAAgBC,qBAChBC,aAAaC,kBACbC,wBACAC,2BACAC,qBACAC,uBACAC,mBACAC,SACAC,yBACK;AAEP,SAASC,WAAW;AACpB,SAASC,uBAAuB;AAKhC,SAASnB,UAAAA,SAAQoB,SAASC,eAAe;;AAQlC,IAAMvB,OAAO,CAACwB,YAAAA;AACnB,MAAI;AACFJ,QAAI,eAAeI,SAAAA;;;;;;AACnBvB,gBAAY;MACVwB,SAASD,QAAQE,UAAU;MAC3BC,KAAKH,QAAQI;MACbC,SAASL,QAAQK;MACjBC,aAAaN,QAAQM;MACrBC,cAAc;QACZlB,uBAAuB;UAAEmB,SAAS;UAAOC,OAAO;QAAM,CAAA;QACtDjB,sBAAsB;UACpBkB,0BAA0B;;YAExB;cAAC;cAAK;;YACN;cAAC;cAAK;;;QAEV,CAAA;QACAnB,oBAAoB;UAAEoB,YAAY;QAAM,CAAA;WACpCX,QAAQY,UAAU;UAACtB,0BAAAA;YAA+B,CAAA;WAClDU,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,kBAAkBjC,OAAAA;AAChDG,sBAAgB+B,cAAcD,kBAAkB;QAC9CE,WAAWlC;MACb,CAAA;IACF;AAEAmC,WAAOC,QAAQ/B,QAAQgC,cAAc,CAAC,CAAA,EAAGC,QAAQ,CAAC,CAACC,KAAKC,KAAAA,MAAM;AAC5DzD,aAAOwD,KAAKC,KAAAA;IACd,CAAA;EACF,SAASC,KAAK;AACZxC,QAAIyC,MAAM,+BAA+BD,KAAAA;;;;;;EAC3C;AACF;AAWO,IAAMzD,gBAA6C,CAAC2D,eAAAA;AACzD,MAAI;AACF1D,yBAAqB0D,UAAAA;AACrB1C,QAAI,kBAAkB0C,YAAAA;;;;;;EACxB,SAASF,KAAK;AACZxC,QAAIyC,MAAM,4BAA4BD,KAAAA;;;;;;EACxC;AACF;AASO,IAAMvD,mBAAmD,CAAC0D,WAAWC,mBAAAA;AAC1E,MAAI;AACF,UAAMC,UAAU3D,wBAAwByD,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,IAAMrD,iBAA+C,CAACwD,WAAWC,mBAAAA;AACtE,MAAI;AACF,UAAMC,UAAUzD,sBAAsBuD,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,SAAOzD,oBAAoB;IAAEyD;EAAQ,GAAG;IAAEC,eAAe;EAAK,CAAA;AAChE;AAEO,IAAMzD,YAAYC;",
|
|
6
|
-
"names": ["init", "naturalInit", "setTag", "addBreadcrumb", "naturalAddBreadcrumb", "captureException", "naturalCaptureException", "captureMessage", "naturalCaptureMessage", "sendFeedback", "naturalSendFeedback", "withScope", "naturalWithScope", "breadcrumbsIntegration", "browserTracingIntegration", "feedbackIntegration", "httpClientIntegration", "replayIntegration", "metrics", "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
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=chunk-KDP3SESE.mjs.map
|