@dxos/observability 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6
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-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 +922 -278
- 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-PUNCJ5KV.mjs +112 -0
- package/dist/lib/browser/traces-browser-PUNCJ5KV.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 +939 -293
- 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/{chunk-WAGGA7IT.mjs → traces-KMTHMYFX.mjs} +8 -16
- 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/{otel → extensions/otel}/logs.js +48 -18
- 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 +2 -10
- 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/traces-browser.d.ts.map +1 -0
- package/dist/types/src/extensions/otel/traces-browser.js +85 -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/{otel → extensions/otel}/traces.js +5 -13
- package/dist/types/src/extensions/otel/traces.js.map +1 -0
- package/dist/types/src/extensions/posthog/extension.d.ts +18 -0
- package/dist/types/src/extensions/posthog/extension.d.ts.map +1 -0
- package/dist/types/src/extensions/posthog/extension.js +142 -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 +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 +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 +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 +59 -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} +37 -42
- 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 +26 -47
- 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/{otel → extensions/otel}/logs.ts +55 -23
- package/src/{otel → extensions/otel}/metrics.ts +2 -12
- package/src/{otel → extensions/otel}/otel.ts +3 -3
- package/src/extensions/otel/traces-browser.ts +110 -0
- package/src/{otel → extensions/otel}/traces.ts +10 -21
- package/src/extensions/posthog/extension.ts +174 -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 +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 +253 -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 +62 -0
- package/src/{segment → storage}/index.ts +0 -1
- package/src/storage/node.test.ts +130 -0
- package/src/{helpers/node-observability.ts → storage/node.ts} +40 -69
- package/dist/lib/browser/chunk-5ICT2XF2.mjs +0 -1
- package/dist/lib/browser/chunk-5LN7D6GM.mjs +0 -148
- package/dist/lib/browser/chunk-5LN7D6GM.mjs.map +0 -7
- package/dist/lib/browser/chunk-JJQT5TQH.mjs +0 -672
- package/dist/lib/browser/chunk-JJQT5TQH.mjs.map +0 -7
- package/dist/lib/browser/chunk-O4BG5MRL.mjs +0 -164
- package/dist/lib/browser/chunk-O4BG5MRL.mjs.map +0 -7
- package/dist/lib/browser/chunk-U6JWT3E2.mjs +0 -1
- package/dist/lib/browser/chunk-VL6LVQPU.mjs +0 -69
- package/dist/lib/browser/chunk-VL6LVQPU.mjs.map +0 -7
- package/dist/lib/browser/observability-XK652NZG.mjs +0 -11
- package/dist/lib/browser/observability-XK652NZG.mjs.map +0 -7
- package/dist/lib/browser/otel/traces-browser.mjs +0 -7
- package/dist/lib/browser/otel/traces-browser.mjs.map +0 -7
- package/dist/lib/browser/otel/traces.mjs +0 -7
- package/dist/lib/browser/otel/traces.mjs.map +0 -7
- package/dist/lib/browser/otel-DI4ASU7Y.mjs +0 -226
- package/dist/lib/browser/otel-DI4ASU7Y.mjs.map +0 -7
- package/dist/lib/browser/segment/browser.mjs +0 -9
- package/dist/lib/browser/segment/browser.mjs.map +0 -7
- package/dist/lib/browser/segment/index.mjs +0 -12
- package/dist/lib/browser/segment/index.mjs.map +0 -7
- package/dist/lib/browser/segment/node.mjs +0 -9
- package/dist/lib/browser/segment/node.mjs.map +0 -7
- package/dist/lib/browser/sentry/browser.mjs +0 -23
- package/dist/lib/browser/sentry/browser.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/node.mjs +0 -23
- package/dist/lib/browser/sentry/node.mjs.map +0 -7
- package/dist/lib/browser/sentry-log-processor-W7LI6WXA.mjs +0 -146
- package/dist/lib/browser/sentry-log-processor-W7LI6WXA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-KKNY7TRV.mjs +0 -673
- package/dist/lib/node-esm/chunk-KKNY7TRV.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-KLJGCUYA.mjs +0 -2
- package/dist/lib/node-esm/chunk-KLJGCUYA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-KVJTNW3F.mjs +0 -147
- package/dist/lib/node-esm/chunk-KVJTNW3F.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-M4627SMT.mjs +0 -135
- package/dist/lib/node-esm/chunk-M4627SMT.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-UIVXGEGJ.mjs +0 -62
- package/dist/lib/node-esm/chunk-UIVXGEGJ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WAGGA7IT.mjs.map +0 -7
- package/dist/lib/node-esm/observability-CXQ3CZGB.mjs +0 -13
- package/dist/lib/node-esm/observability-CXQ3CZGB.mjs.map +0 -7
- package/dist/lib/node-esm/otel/traces-browser.mjs +0 -70
- package/dist/lib/node-esm/otel/traces-browser.mjs.map +0 -7
- package/dist/lib/node-esm/otel/traces.mjs +0 -8
- package/dist/lib/node-esm/otel/traces.mjs.map +0 -7
- package/dist/lib/node-esm/otel-JFXO22WD.mjs +0 -227
- package/dist/lib/node-esm/otel-JFXO22WD.mjs.map +0 -7
- package/dist/lib/node-esm/segment/browser.mjs +0 -92
- package/dist/lib/node-esm/segment/browser.mjs.map +0 -7
- package/dist/lib/node-esm/segment/index.mjs +0 -15
- package/dist/lib/node-esm/segment/index.mjs.map +0 -7
- package/dist/lib/node-esm/segment/node.mjs +0 -11
- package/dist/lib/node-esm/segment/node.mjs.map +0 -7
- package/dist/lib/node-esm/sentry/browser.mjs +0 -165
- package/dist/lib/node-esm/sentry/browser.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/node.mjs +0 -24
- package/dist/lib/node-esm/sentry/node.mjs.map +0 -7
- package/dist/lib/node-esm/sentry-log-processor-W3SG4RQL.mjs +0 -147
- package/dist/lib/node-esm/sentry-log-processor-W3SG4RQL.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.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 -53
- 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.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/traces-browser.ts +0 -62
- 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/chunk-U6JWT3E2.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/{otel → extensions/otel}/otel.js +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
- /package/dist/types/src/{sentry → storage}/index.js +0 -0
|
@@ -1,192 +1,60 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
getTelemetryIdentity,
|
|
6
|
-
mapSpaces
|
|
7
|
-
} from "./chunk-KKNY7TRV.mjs";
|
|
8
|
-
import "./chunk-KLJGCUYA.mjs";
|
|
9
|
-
import "./chunk-KVJTNW3F.mjs";
|
|
10
|
-
import "./chunk-UIVXGEGJ.mjs";
|
|
11
|
-
import "./chunk-QUZL7LKE.mjs";
|
|
12
|
-
import "./chunk-M4627SMT.mjs";
|
|
3
|
+
__export
|
|
4
|
+
} from "./chunk-HSLMI22Q.mjs";
|
|
13
5
|
|
|
14
|
-
// src/
|
|
15
|
-
|
|
6
|
+
// src/observability.ts
|
|
7
|
+
var observability_exports = {};
|
|
8
|
+
__export(observability_exports, {
|
|
9
|
+
addDataProvider: () => addDataProvider,
|
|
10
|
+
addExtension: () => addExtension,
|
|
11
|
+
getObservabilityGroup: () => getObservabilityGroup,
|
|
12
|
+
initialize: () => initialize,
|
|
13
|
+
isObservabilityDisabled: () => isObservabilityDisabled,
|
|
14
|
+
make: () => make,
|
|
15
|
+
showObservabilityBanner: () => showObservabilityBanner,
|
|
16
|
+
storeObservabilityDisabled: () => storeObservabilityDisabled,
|
|
17
|
+
storeObservabilityGroup: () => storeObservabilityGroup
|
|
18
|
+
});
|
|
19
|
+
import * as Array from "effect/Array";
|
|
20
|
+
import * as Effect from "effect/Effect";
|
|
21
|
+
import * as Function from "effect/Function";
|
|
22
|
+
import { SubscriptionList } from "@dxos/async";
|
|
23
|
+
import { invariant } from "@dxos/invariant";
|
|
16
24
|
import { log } from "@dxos/log";
|
|
17
|
-
var __dxlog_file = "/__w/dxos/dxos/packages/sdk/observability/src/helpers/browser-observability.ts";
|
|
18
|
-
var OBSERVABILITY_DISABLED_KEY = "observability-disabled";
|
|
19
|
-
var OBSERVABILITY_GROUP_KEY = "observability-group";
|
|
20
|
-
var isObservabilityDisabled = async (namespace) => {
|
|
21
|
-
try {
|
|
22
|
-
return await localForage.getItem(`${namespace}:${OBSERVABILITY_DISABLED_KEY}`) === "true";
|
|
23
|
-
} catch (err) {
|
|
24
|
-
log.catch("Failed to check if observability is disabled, assuming it is", err, {
|
|
25
|
-
F: __dxlog_file,
|
|
26
|
-
L: 25,
|
|
27
|
-
S: void 0,
|
|
28
|
-
C: (f, a) => f(...a)
|
|
29
|
-
});
|
|
30
|
-
return true;
|
|
31
|
-
}
|
|
32
|
-
};
|
|
33
|
-
var storeObservabilityDisabled = async (namespace, value) => {
|
|
34
|
-
try {
|
|
35
|
-
await localForage.setItem(`${namespace}:${OBSERVABILITY_DISABLED_KEY}`, String(value));
|
|
36
|
-
} catch (err) {
|
|
37
|
-
log.catch("Failed to store observability disabled", err, {
|
|
38
|
-
F: __dxlog_file,
|
|
39
|
-
L: 34,
|
|
40
|
-
S: void 0,
|
|
41
|
-
C: (f, a) => f(...a)
|
|
42
|
-
});
|
|
43
|
-
}
|
|
44
|
-
};
|
|
45
|
-
var getObservabilityGroup = async (namespace) => {
|
|
46
|
-
try {
|
|
47
|
-
return await localForage.getItem(`${namespace}:${OBSERVABILITY_GROUP_KEY}`) ?? void 0;
|
|
48
|
-
} catch (err) {
|
|
49
|
-
log.catch("Failed to get observability group", err, {
|
|
50
|
-
F: __dxlog_file,
|
|
51
|
-
L: 42,
|
|
52
|
-
S: void 0,
|
|
53
|
-
C: (f, a) => f(...a)
|
|
54
|
-
});
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
var storeObservabilityGroup = async (namespace, value) => {
|
|
58
|
-
try {
|
|
59
|
-
await localForage.setItem(`${namespace}:${OBSERVABILITY_GROUP_KEY}`, value);
|
|
60
|
-
} catch (err) {
|
|
61
|
-
log.catch("Failed to store observability group", err, {
|
|
62
|
-
F: __dxlog_file,
|
|
63
|
-
L: 50,
|
|
64
|
-
S: void 0,
|
|
65
|
-
C: (f, a) => f(...a)
|
|
66
|
-
});
|
|
67
|
-
}
|
|
68
|
-
};
|
|
69
|
-
var initializeAppObservability = async ({
|
|
70
|
-
namespace,
|
|
71
|
-
config,
|
|
72
|
-
// TODO(nf): Configure mode.
|
|
73
|
-
mode = "basic",
|
|
74
|
-
tracingEnable = false,
|
|
75
|
-
replayEnable = false
|
|
76
|
-
}) => {
|
|
77
|
-
log("initializeAppObservability", {
|
|
78
|
-
config
|
|
79
|
-
}, {
|
|
80
|
-
F: __dxlog_file,
|
|
81
|
-
L: 74,
|
|
82
|
-
S: void 0,
|
|
83
|
-
C: (f, a) => f(...a)
|
|
84
|
-
});
|
|
85
|
-
const group = await getObservabilityGroup(namespace) ?? void 0;
|
|
86
|
-
const release = `${namespace}@${config.get("runtime.app.build.version")}`;
|
|
87
|
-
const environment = config.get("runtime.app.env.DX_ENVIRONMENT");
|
|
88
|
-
const { Observability: Observability2 } = await import("./observability-CXQ3CZGB.mjs");
|
|
89
|
-
const observability = new Observability2({
|
|
90
|
-
namespace,
|
|
91
|
-
release,
|
|
92
|
-
environment,
|
|
93
|
-
group,
|
|
94
|
-
mode,
|
|
95
|
-
config,
|
|
96
|
-
errorLog: {
|
|
97
|
-
sentryInitOptions: {
|
|
98
|
-
environment,
|
|
99
|
-
release,
|
|
100
|
-
tracing: tracingEnable,
|
|
101
|
-
replay: replayEnable,
|
|
102
|
-
// TODO(wittjosiah): Configure these.
|
|
103
|
-
// Consider using a sampling function to dynamically configure these values.
|
|
104
|
-
// https://docs.sentry.io/platforms/javascript/configuration/sampling/#setting-a-sampling-function
|
|
105
|
-
sampleRate: 1,
|
|
106
|
-
replaySampleRate: 1,
|
|
107
|
-
replaySampleRateOnError: 1
|
|
108
|
-
}
|
|
109
|
-
}
|
|
110
|
-
});
|
|
111
|
-
const observabilityDisabled = await isObservabilityDisabled(namespace);
|
|
112
|
-
if (observabilityDisabled) {
|
|
113
|
-
observability.setMode("disabled");
|
|
114
|
-
log.info("observability disabled", void 0, {
|
|
115
|
-
F: __dxlog_file,
|
|
116
|
-
L: 114,
|
|
117
|
-
S: void 0,
|
|
118
|
-
C: (f, a) => f(...a)
|
|
119
|
-
});
|
|
120
|
-
return observability;
|
|
121
|
-
}
|
|
122
|
-
try {
|
|
123
|
-
const getIPData = async (config2) => {
|
|
124
|
-
const IP_DATA_CACHE_TIMEOUT = 6 * 60 * 60 * 1e3;
|
|
125
|
-
const cachedData = await localForage.getItem("dxos:observability:ipdata");
|
|
126
|
-
if (cachedData && cachedData.timestamp > Date.now() - IP_DATA_CACHE_TIMEOUT) {
|
|
127
|
-
return cachedData.data;
|
|
128
|
-
}
|
|
129
|
-
const IPDATA_API_KEY = config2.get("runtime.app.env.DX_IPDATA_API_KEY");
|
|
130
|
-
if (IPDATA_API_KEY) {
|
|
131
|
-
return fetch(`https://api.ipdata.co?api-key=${IPDATA_API_KEY}`).then((res) => res.json()).then((data) => {
|
|
132
|
-
localForage.setItem("dxos:observability:ipdata", {
|
|
133
|
-
data,
|
|
134
|
-
timestamp: Date.now()
|
|
135
|
-
}).catch((err) => observability.captureException(err));
|
|
136
|
-
return data;
|
|
137
|
-
}).catch((err) => observability.captureException(err));
|
|
138
|
-
}
|
|
139
|
-
};
|
|
140
|
-
await observability.initialize();
|
|
141
|
-
observability.startErrorLogs();
|
|
142
|
-
const ipData = await getIPData(config);
|
|
143
|
-
ipData && observability.setIPDataTelemetryTags(ipData);
|
|
144
|
-
if (typeof navigator !== "undefined" && navigator.storage?.estimate) {
|
|
145
|
-
setInterval(async () => {
|
|
146
|
-
try {
|
|
147
|
-
const storageEstimate = await navigator.storage.estimate();
|
|
148
|
-
storageEstimate.usage && observability.setTag("storageUsage", storageEstimate.usage.toString(), "telemetry");
|
|
149
|
-
storageEstimate.quota && observability.setTag("storageQuota", storageEstimate.quota.toString(), "telemetry");
|
|
150
|
-
} catch (error) {
|
|
151
|
-
log.warn("Failed to run estimate()", error, {
|
|
152
|
-
F: __dxlog_file,
|
|
153
|
-
L: 169,
|
|
154
|
-
S: void 0,
|
|
155
|
-
C: (f, a) => f(...a)
|
|
156
|
-
});
|
|
157
|
-
}
|
|
158
|
-
}, 1e4);
|
|
159
|
-
}
|
|
160
|
-
} catch (err) {
|
|
161
|
-
log.error("Failed to initialize app observability", err, {
|
|
162
|
-
F: __dxlog_file,
|
|
163
|
-
L: 174,
|
|
164
|
-
S: void 0,
|
|
165
|
-
C: (f, a) => f(...a)
|
|
166
|
-
});
|
|
167
|
-
}
|
|
168
|
-
return observability;
|
|
169
|
-
};
|
|
170
25
|
|
|
171
|
-
// src/
|
|
26
|
+
// src/storage/node.ts
|
|
172
27
|
import { existsSync, statSync } from "node:fs";
|
|
173
28
|
import { mkdir, readFile, writeFile } from "node:fs/promises";
|
|
174
29
|
import { join } from "node:path";
|
|
175
30
|
import yaml from "js-yaml";
|
|
176
31
|
import { v4 as uuid, validate as validateUuid } from "uuid";
|
|
177
|
-
import { log as log2 } from "@dxos/log";
|
|
178
|
-
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/observability/src/helpers/node-observability.ts";
|
|
179
32
|
var showObservabilityBanner = async (configDir, bannercb) => {
|
|
180
33
|
const path = join(configDir, ".observability-banner-printed");
|
|
181
34
|
if (existsSync(path)) {
|
|
182
35
|
return;
|
|
183
36
|
}
|
|
184
|
-
bannercb(
|
|
185
|
-
// eslint-disable-next-line no-multi-str
|
|
186
|
-
"Basic observability data will be sent to the DXOS team in order to improve the product. This includes performance metrics, error logs, and usage data. No personally identifiable information, other than your public key, is included with this data and no private data ever leaves your devices. To disable sending observability data, set the environment variable DX_DISABLE_OBSERVABILITY=true."
|
|
187
|
-
);
|
|
37
|
+
bannercb("Basic observability data will be sent to the DXOS team in order to improve the product. This includes performance metrics, error logs, and usage data. No personally identifiable information, other than your public key, is included with this data and no private data ever leaves your devices. To disable sending observability data, set the environment variable DX_DISABLE_OBSERVABILITY=true.");
|
|
188
38
|
await writeFile(path, "", "utf-8");
|
|
189
39
|
};
|
|
40
|
+
var isObservabilityDisabled = async (configDir) => {
|
|
41
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
42
|
+
return observabilityState.disabled;
|
|
43
|
+
};
|
|
44
|
+
var storeObservabilityDisabled = async (configDir, value2) => {
|
|
45
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
46
|
+
observabilityState.disabled = value2;
|
|
47
|
+
await writeFile(join(configDir, "observability.yml"), yaml.dump(observabilityState), "utf-8");
|
|
48
|
+
};
|
|
49
|
+
var getObservabilityGroup = async (configDir) => {
|
|
50
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
51
|
+
return observabilityState.group;
|
|
52
|
+
};
|
|
53
|
+
var storeObservabilityGroup = async (configDir, value2) => {
|
|
54
|
+
const observabilityState = await getObservabilityState(configDir);
|
|
55
|
+
observabilityState.group = value2;
|
|
56
|
+
await writeFile(join(configDir, "observability.yml"), yaml.dump(observabilityState), "utf-8");
|
|
57
|
+
};
|
|
190
58
|
var getObservabilityState = async (configDir) => {
|
|
191
59
|
if (existsSync(configDir)) {
|
|
192
60
|
if (!statSync(configDir).isDirectory()) {
|
|
@@ -207,8 +75,8 @@ var getObservabilityState = async (configDir) => {
|
|
|
207
75
|
var initializeState = async (idPath) => {
|
|
208
76
|
const observabilityState = {
|
|
209
77
|
installationId: uuid(),
|
|
210
|
-
|
|
211
|
-
|
|
78
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : false,
|
|
79
|
+
group: process.env.DX_OBSERVABILITY_GROUP ?? void 0
|
|
212
80
|
};
|
|
213
81
|
await writeFile(idPath, "# This file is automatically generated by the @dxos/cli.\n" + yaml.dump(observabilityState), "utf-8");
|
|
214
82
|
return observabilityState;
|
|
@@ -218,149 +86,927 @@ var validate = (contextString) => {
|
|
|
218
86
|
if (Boolean(context.installationId) && validateUuid(context.installationId)) {
|
|
219
87
|
return {
|
|
220
88
|
...context,
|
|
221
|
-
|
|
89
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : context.disabled ?? false
|
|
222
90
|
};
|
|
223
91
|
}
|
|
224
92
|
};
|
|
225
|
-
|
|
226
|
-
|
|
227
|
-
|
|
228
|
-
|
|
229
|
-
|
|
230
|
-
|
|
231
|
-
|
|
232
|
-
|
|
233
|
-
|
|
234
|
-
|
|
235
|
-
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
|
|
240
|
-
|
|
241
|
-
|
|
242
|
-
|
|
243
|
-
|
|
244
|
-
environment,
|
|
245
|
-
release,
|
|
246
|
-
// TODO(wittjosiah): Configure this.
|
|
247
|
-
sampleRate: 1
|
|
93
|
+
|
|
94
|
+
// src/observability.ts
|
|
95
|
+
var __dxlog_file = "/__w/dxos/dxos/packages/sdk/observability/src/observability.ts";
|
|
96
|
+
var ObservabilityImpl = class {
|
|
97
|
+
_initialized = false;
|
|
98
|
+
_extensions = [];
|
|
99
|
+
_dataProviders = [];
|
|
100
|
+
_subscriptions = new SubscriptionList();
|
|
101
|
+
initialize() {
|
|
102
|
+
if (this._initialized) {
|
|
103
|
+
return Effect.succeed(void 0);
|
|
104
|
+
}
|
|
105
|
+
const initializedExtensions = [];
|
|
106
|
+
return Effect.gen(this, function* () {
|
|
107
|
+
for (const extension of this._extensions) {
|
|
108
|
+
if (extension.initialize) {
|
|
109
|
+
yield* extension.initialize();
|
|
110
|
+
}
|
|
111
|
+
initializedExtensions.push(extension);
|
|
248
112
|
}
|
|
113
|
+
const cleanups = yield* Effect.all(this._dataProviders.map((provider3) => provider3(this)));
|
|
114
|
+
this._subscriptions.add(...cleanups.filter((cleanup) => cleanup !== void 0));
|
|
115
|
+
this._initialized = true;
|
|
116
|
+
}).pipe(Effect.catchAll((error) => Effect.gen(this, function* () {
|
|
117
|
+
log.catch(error, void 0, {
|
|
118
|
+
F: __dxlog_file,
|
|
119
|
+
L: 85,
|
|
120
|
+
S: this,
|
|
121
|
+
C: (f, a) => f(...a)
|
|
122
|
+
});
|
|
123
|
+
for (const extension of initializedExtensions) {
|
|
124
|
+
if (extension.close) {
|
|
125
|
+
yield* extension.close().pipe(Effect.catchAll(() => Effect.succeed(void 0)));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
this._subscriptions.clear();
|
|
129
|
+
})));
|
|
130
|
+
}
|
|
131
|
+
close() {
|
|
132
|
+
return Effect.gen(this, function* () {
|
|
133
|
+
this._subscriptions.clear();
|
|
134
|
+
this._dataProviders.length = 0;
|
|
135
|
+
for (const extension of this._extensions) {
|
|
136
|
+
if (extension.close) {
|
|
137
|
+
yield* extension.close();
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
this._initialized = false;
|
|
141
|
+
});
|
|
142
|
+
}
|
|
143
|
+
enable() {
|
|
144
|
+
return Effect.gen(this, function* () {
|
|
145
|
+
for (const extension of this._extensions) {
|
|
146
|
+
if (extension.enable) {
|
|
147
|
+
yield* extension.enable();
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
}
|
|
152
|
+
disable() {
|
|
153
|
+
return Effect.gen(this, function* () {
|
|
154
|
+
for (const extension of this._extensions) {
|
|
155
|
+
if (extension.disable) {
|
|
156
|
+
yield* extension.disable();
|
|
157
|
+
}
|
|
158
|
+
}
|
|
159
|
+
});
|
|
160
|
+
}
|
|
161
|
+
flush() {
|
|
162
|
+
return Effect.gen(this, function* () {
|
|
163
|
+
for (const extension of this._extensions) {
|
|
164
|
+
if (extension.flush) {
|
|
165
|
+
yield* extension.flush();
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
}
|
|
170
|
+
_addExtension(extension) {
|
|
171
|
+
invariant(!this._initialized, "Observability is already initialized", {
|
|
172
|
+
F: __dxlog_file,
|
|
173
|
+
L: 142,
|
|
174
|
+
S: this,
|
|
175
|
+
A: [
|
|
176
|
+
"!this._initialized",
|
|
177
|
+
"'Observability is already initialized'"
|
|
178
|
+
]
|
|
179
|
+
});
|
|
180
|
+
this._extensions.push(extension);
|
|
181
|
+
}
|
|
182
|
+
_addDataProvider(dataProvider) {
|
|
183
|
+
invariant(!this._initialized, "Observability is already initialized", {
|
|
184
|
+
F: __dxlog_file,
|
|
185
|
+
L: 147,
|
|
186
|
+
S: this,
|
|
187
|
+
A: [
|
|
188
|
+
"!this._initialized",
|
|
189
|
+
"'Observability is already initialized'"
|
|
190
|
+
]
|
|
191
|
+
});
|
|
192
|
+
this._dataProviders.push(dataProvider);
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Adds a data provider and initializes it.
|
|
196
|
+
*/
|
|
197
|
+
addDataProvider(dataProvider) {
|
|
198
|
+
return Effect.gen(this, function* () {
|
|
199
|
+
this._dataProviders.push(dataProvider);
|
|
200
|
+
const cleanup = yield* dataProvider(this);
|
|
201
|
+
if (cleanup) {
|
|
202
|
+
this._subscriptions.add(cleanup);
|
|
203
|
+
}
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
identify(distinctId, attributes, setOnceAttributes) {
|
|
207
|
+
for (const extension of this._extensions) {
|
|
208
|
+
extension.identify?.(distinctId, attributes, setOnceAttributes);
|
|
249
209
|
}
|
|
250
|
-
});
|
|
251
|
-
observability.setTag("installationId", installationId);
|
|
252
|
-
const IPDATA_API_KEY = config.get("runtime.app.env.DX_IPDATA_API_KEY");
|
|
253
|
-
try {
|
|
254
|
-
const res = await fetch(`https://api.ipdata.co/?api-key=${IPDATA_API_KEY}`);
|
|
255
|
-
const ipData = await res.json();
|
|
256
|
-
ipData && observability.setIPDataTelemetryTags(ipData);
|
|
257
|
-
} catch (err) {
|
|
258
|
-
observability?.captureException(err);
|
|
259
210
|
}
|
|
211
|
+
alias(distinctId, previousId) {
|
|
212
|
+
for (const extension of this._extensions) {
|
|
213
|
+
extension.alias?.(distinctId, previousId);
|
|
214
|
+
}
|
|
215
|
+
}
|
|
216
|
+
setTags(tags, kind) {
|
|
217
|
+
for (const extension of this._extensions) {
|
|
218
|
+
if (kind && !extension.apis.some((api) => api.kind === kind)) {
|
|
219
|
+
continue;
|
|
220
|
+
}
|
|
221
|
+
const processedTags = Object.fromEntries(Object.entries(tags).filter((entry) => entry[1] !== void 0).map(([key, value2]) => [
|
|
222
|
+
key,
|
|
223
|
+
value2.toString()
|
|
224
|
+
]));
|
|
225
|
+
extension.setTags?.(processedTags);
|
|
226
|
+
}
|
|
227
|
+
}
|
|
228
|
+
get enabled() {
|
|
229
|
+
return this._extensions.every((extension) => extension.enabled);
|
|
230
|
+
}
|
|
231
|
+
get errors() {
|
|
232
|
+
return {
|
|
233
|
+
captureException: (error, attributes) => {
|
|
234
|
+
for (const extension of this._getExtensions("errors")) {
|
|
235
|
+
extension.captureException(error, attributes);
|
|
236
|
+
}
|
|
237
|
+
}
|
|
238
|
+
};
|
|
239
|
+
}
|
|
240
|
+
get events() {
|
|
241
|
+
return {
|
|
242
|
+
captureEvent: (event, attributes) => {
|
|
243
|
+
for (const extension of this._getExtensions("events")) {
|
|
244
|
+
extension.captureEvent(event, attributes);
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
};
|
|
248
|
+
}
|
|
249
|
+
get feedback() {
|
|
250
|
+
return {
|
|
251
|
+
captureUserFeedback: (form) => {
|
|
252
|
+
for (const extension of this._getExtensions("feedback")) {
|
|
253
|
+
extension.captureUserFeedback(form);
|
|
254
|
+
}
|
|
255
|
+
}
|
|
256
|
+
};
|
|
257
|
+
}
|
|
258
|
+
isAvailable(kind) {
|
|
259
|
+
const apis = this._getExtensions(kind);
|
|
260
|
+
if (apis.length === 0) {
|
|
261
|
+
return Effect.succeed(false);
|
|
262
|
+
}
|
|
263
|
+
return Effect.gen(this, function* () {
|
|
264
|
+
for (const api of apis) {
|
|
265
|
+
const available = yield* api.isAvailable();
|
|
266
|
+
if (available) {
|
|
267
|
+
return true;
|
|
268
|
+
}
|
|
269
|
+
}
|
|
270
|
+
return false;
|
|
271
|
+
});
|
|
272
|
+
}
|
|
273
|
+
get metrics() {
|
|
274
|
+
return {
|
|
275
|
+
gauge: (name, value2, attributes) => {
|
|
276
|
+
for (const extension of this._getExtensions("metrics")) {
|
|
277
|
+
extension.gauge(name, value2, attributes);
|
|
278
|
+
}
|
|
279
|
+
},
|
|
280
|
+
increment: (name, value2, attributes) => {
|
|
281
|
+
for (const extension of this._getExtensions("metrics")) {
|
|
282
|
+
extension.increment(name, value2, attributes);
|
|
283
|
+
}
|
|
284
|
+
},
|
|
285
|
+
distribution: (name, value2, attributes) => {
|
|
286
|
+
for (const extension of this._getExtensions("metrics")) {
|
|
287
|
+
extension.distribution(name, value2, attributes);
|
|
288
|
+
}
|
|
289
|
+
}
|
|
290
|
+
};
|
|
291
|
+
}
|
|
292
|
+
_getExtensions(kind) {
|
|
293
|
+
return Function.pipe(this._extensions, Array.flatMap((extension) => extension.apis), Array.filter((api) => api.kind === kind));
|
|
294
|
+
}
|
|
295
|
+
};
|
|
296
|
+
var make = () => Effect.succeed(new ObservabilityImpl());
|
|
297
|
+
var addExtension = (_extension) => Effect.fn(function* (_observability) {
|
|
298
|
+
const observability = yield* _observability;
|
|
299
|
+
const extension = yield* _extension;
|
|
300
|
+
invariant("_addExtension" in observability && typeof observability._addExtension === "function", void 0, {
|
|
301
|
+
F: __dxlog_file,
|
|
302
|
+
L: 276,
|
|
303
|
+
S: this,
|
|
304
|
+
A: [
|
|
305
|
+
"'_addExtension' in observability && typeof observability._addExtension === 'function'",
|
|
306
|
+
""
|
|
307
|
+
]
|
|
308
|
+
});
|
|
309
|
+
observability._addExtension(extension);
|
|
310
|
+
return observability;
|
|
311
|
+
});
|
|
312
|
+
var addDataProvider = (dataProvider) => Effect.fn(function* (_observability) {
|
|
313
|
+
const observability = yield* _observability;
|
|
314
|
+
invariant("_addDataProvider" in observability && typeof observability._addDataProvider === "function", void 0, {
|
|
315
|
+
F: __dxlog_file,
|
|
316
|
+
L: 284,
|
|
317
|
+
S: this,
|
|
318
|
+
A: [
|
|
319
|
+
"'_addDataProvider' in observability && typeof observability._addDataProvider === 'function'",
|
|
320
|
+
""
|
|
321
|
+
]
|
|
322
|
+
});
|
|
323
|
+
observability._addDataProvider(dataProvider);
|
|
260
324
|
return observability;
|
|
325
|
+
});
|
|
326
|
+
var initialize = Effect.fn(function* (_observability) {
|
|
327
|
+
const observability = yield* _observability;
|
|
328
|
+
yield* observability.initialize();
|
|
329
|
+
return observability;
|
|
330
|
+
});
|
|
331
|
+
|
|
332
|
+
// src/observability-extension.ts
|
|
333
|
+
var observability_extension_exports = {};
|
|
334
|
+
__export(observability_extension_exports, {
|
|
335
|
+
Otel: () => otel_exports,
|
|
336
|
+
PostHog: () => posthog_exports
|
|
337
|
+
});
|
|
338
|
+
|
|
339
|
+
// src/extensions/otel/index.ts
|
|
340
|
+
var otel_exports = {};
|
|
341
|
+
__export(otel_exports, {
|
|
342
|
+
extensions: () => extensions
|
|
343
|
+
});
|
|
344
|
+
|
|
345
|
+
// src/extensions/otel/extension.ts
|
|
346
|
+
import { defaultResource, resourceFromAttributes } from "@opentelemetry/resources";
|
|
347
|
+
import { ATTR_SERVICE_NAME, ATTR_SERVICE_VERSION } from "@opentelemetry/semantic-conventions";
|
|
348
|
+
import * as Effect3 from "effect/Effect";
|
|
349
|
+
import * as Match from "effect/Match";
|
|
350
|
+
import * as Option from "effect/Option";
|
|
351
|
+
import * as Ref from "effect/Ref";
|
|
352
|
+
import { LogLevel, log as log2 } from "@dxos/log";
|
|
353
|
+
import { isNode, isNonNullable } from "@dxos/util";
|
|
354
|
+
|
|
355
|
+
// src/cli-observability-secrets.json
|
|
356
|
+
var cli_observability_secrets_default = {
|
|
357
|
+
POSTHOG_API_KEY: null,
|
|
358
|
+
IPDATA_API_KEY: "73dfdecdf979c18f07d50cf841bbdd9e589f237256326ac8cca23786",
|
|
359
|
+
OTEL_ENDPOINT: "https://ingest.eu.signoz.cloud:443",
|
|
360
|
+
OTEL_HEADERS: "signoz-ingestion-key: 5300e0c9-a5e8-4a10-9c61-f473e539c0b7"
|
|
261
361
|
};
|
|
262
362
|
|
|
263
|
-
// src/
|
|
264
|
-
|
|
265
|
-
var
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
269
|
-
|
|
270
|
-
|
|
363
|
+
// src/extensions/stub.ts
|
|
364
|
+
import * as Effect2 from "effect/Effect";
|
|
365
|
+
var stubExtension = {
|
|
366
|
+
initialize: () => Effect2.succeed(void 0),
|
|
367
|
+
enable: () => Effect2.succeed(void 0),
|
|
368
|
+
disable: () => Effect2.succeed(void 0),
|
|
369
|
+
flush: () => Effect2.succeed(void 0),
|
|
370
|
+
setTags: () => void 0,
|
|
371
|
+
get enabled() {
|
|
372
|
+
return true;
|
|
373
|
+
},
|
|
374
|
+
apis: []
|
|
375
|
+
};
|
|
376
|
+
|
|
377
|
+
// src/extensions/otel/extension.ts
|
|
378
|
+
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/observability/src/extensions/otel/extension.ts";
|
|
379
|
+
var extensions = Effect3.fn(function* ({
|
|
380
|
+
serviceName,
|
|
381
|
+
serviceVersion,
|
|
382
|
+
environment,
|
|
383
|
+
config,
|
|
384
|
+
endpoint: _endpoint,
|
|
385
|
+
headers: _headers,
|
|
386
|
+
// TODO(wittjosiah): Logging integration.
|
|
387
|
+
// - logger should run even if observability is disabled
|
|
388
|
+
// - logs should be cached locally in a circular buffer
|
|
389
|
+
// - logs should be flushed to the server if user opts to include them in a bug report
|
|
390
|
+
logs: logsEnabled = false,
|
|
391
|
+
logLevel = LogLevel.INFO,
|
|
392
|
+
metrics: metricsEnabled = false,
|
|
393
|
+
traces: tracesEnabled = false
|
|
394
|
+
}) {
|
|
395
|
+
const { OtelLogs } = yield* Effect3.promise(() => import("./logs-7J45KLM7.mjs"));
|
|
396
|
+
const { OtelMetrics } = yield* Effect3.promise(() => import("./metrics-H7DDLYSG.mjs"));
|
|
397
|
+
const { OtelTraces } = yield* Effect3.promise(() => import("./traces-KMTHMYFX.mjs"));
|
|
398
|
+
const cachedDisabled = yield* Effect3.promise(() => isObservabilityDisabled(serviceName));
|
|
399
|
+
const enabledRef = yield* Ref.make(!cachedDisabled);
|
|
400
|
+
const tags = /* @__PURE__ */ new Map();
|
|
401
|
+
const endpoint = isNode() ? process.env.DX_OTEL_ENDPOINT ?? _endpoint ?? cli_observability_secrets_default.OTEL_ENDPOINT : config.values.runtime?.app?.env?.DX_OTEL_ENDPOINT;
|
|
402
|
+
const headers = _headers ?? Match.value(isNode()).pipe(Match.when(true, () => Option.fromNullable(process.env.DX_OTEL_HEADERS ?? cli_observability_secrets_default.OTEL_HEADERS)), Match.when(false, () => Option.fromNullable(config.values.runtime?.app?.env?.DX_OTEL_HEADERS)), Match.exhaustive, Option.map((raw) => parseHeaders(raw)), Option.getOrElse(() => void 0));
|
|
403
|
+
if (!endpoint || !headers) {
|
|
404
|
+
log2.info("Missing OTEL_ENDPOINT or OTEL_HEADERS", void 0, {
|
|
405
|
+
F: __dxlog_file2,
|
|
406
|
+
L: 77,
|
|
407
|
+
S: this,
|
|
408
|
+
C: (f, a) => f(...a)
|
|
409
|
+
});
|
|
410
|
+
return stubExtension;
|
|
411
|
+
}
|
|
412
|
+
const resource = defaultResource().merge(resourceFromAttributes({
|
|
413
|
+
[ATTR_SERVICE_NAME]: serviceName,
|
|
414
|
+
[ATTR_SERVICE_VERSION]: serviceVersion,
|
|
415
|
+
"deployment.environment": environment
|
|
416
|
+
}));
|
|
417
|
+
const logs = logsEnabled ? new OtelLogs({
|
|
418
|
+
endpoint,
|
|
419
|
+
headers,
|
|
420
|
+
resource,
|
|
421
|
+
getTags: () => Object.fromEntries(tags),
|
|
422
|
+
logLevel
|
|
423
|
+
}) : void 0;
|
|
424
|
+
const metrics = metricsEnabled ? new OtelMetrics({
|
|
425
|
+
endpoint,
|
|
426
|
+
headers,
|
|
427
|
+
resource,
|
|
428
|
+
getTags: () => Object.fromEntries(tags)
|
|
429
|
+
}) : void 0;
|
|
430
|
+
const traces = tracesEnabled ? new OtelTraces({
|
|
431
|
+
endpoint,
|
|
432
|
+
headers,
|
|
433
|
+
resource,
|
|
434
|
+
getTags: () => Object.fromEntries(tags)
|
|
435
|
+
}) : void 0;
|
|
436
|
+
return {
|
|
437
|
+
initialize: () => Effect3.sync(() => {
|
|
438
|
+
if (logs) {
|
|
439
|
+
log2.runtimeConfig.processors.push(logs.logProcessor);
|
|
440
|
+
}
|
|
441
|
+
if (traces) {
|
|
442
|
+
traces.start();
|
|
443
|
+
}
|
|
444
|
+
}),
|
|
445
|
+
enable: Effect3.fn(function* () {
|
|
446
|
+
yield* Effect3.promise(() => storeObservabilityDisabled(serviceName, false));
|
|
447
|
+
yield* Ref.update(enabledRef, () => true);
|
|
448
|
+
}),
|
|
449
|
+
disable: Effect3.fn(function* () {
|
|
450
|
+
yield* Effect3.promise(() => storeObservabilityDisabled(serviceName, true));
|
|
451
|
+
yield* Ref.update(enabledRef, () => false);
|
|
452
|
+
}),
|
|
453
|
+
close: () => Effect3.promise(async () => {
|
|
454
|
+
await logs?.close();
|
|
455
|
+
await metrics?.close();
|
|
456
|
+
}),
|
|
457
|
+
flush: () => Effect3.promise(async () => {
|
|
458
|
+
await logs?.flush();
|
|
459
|
+
await metrics?.flush();
|
|
460
|
+
}),
|
|
461
|
+
setTags: (incomingTags) => {
|
|
462
|
+
for (const [key, value2] of Object.entries(incomingTags)) {
|
|
463
|
+
tags.set(key, value2);
|
|
464
|
+
}
|
|
465
|
+
},
|
|
466
|
+
get enabled() {
|
|
467
|
+
return Ref.get(enabledRef).pipe(Effect3.runSync);
|
|
468
|
+
},
|
|
469
|
+
apis: [
|
|
470
|
+
{
|
|
471
|
+
kind: "logs",
|
|
472
|
+
isAvailable: () => Effect3.succeed(!!logs)
|
|
473
|
+
},
|
|
474
|
+
metrics ? {
|
|
475
|
+
kind: "metrics",
|
|
476
|
+
isAvailable: () => Effect3.succeed(true),
|
|
477
|
+
gauge: (name, value2, tags2) => metrics.gauge(name, value2, tags2),
|
|
478
|
+
increment: (name, value2, tags2) => metrics.increment(name, value2, tags2),
|
|
479
|
+
distribution: (name, value2, tags2) => metrics.distribution(name, value2, tags2)
|
|
480
|
+
} : void 0,
|
|
481
|
+
traces ? {
|
|
482
|
+
kind: "traces",
|
|
483
|
+
isAvailable: () => Effect3.succeed(true)
|
|
484
|
+
} : void 0
|
|
485
|
+
].filter(isNonNullable)
|
|
486
|
+
};
|
|
487
|
+
});
|
|
488
|
+
var parseHeaders = (unparsedHeaders) => {
|
|
489
|
+
return unparsedHeaders.split(";").reduce((acc, header) => {
|
|
490
|
+
const [key, ...rest] = header.split(":");
|
|
491
|
+
if (key && rest.length > 0) {
|
|
492
|
+
acc[key.trim().toLowerCase()] = rest.join(":").trim();
|
|
271
493
|
}
|
|
272
|
-
|
|
273
|
-
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
|
|
494
|
+
return acc;
|
|
495
|
+
}, {});
|
|
496
|
+
};
|
|
497
|
+
|
|
498
|
+
// src/extensions/posthog/index.ts
|
|
499
|
+
var posthog_exports = {};
|
|
500
|
+
__export(posthog_exports, {
|
|
501
|
+
extensions: () => extensions2
|
|
502
|
+
});
|
|
503
|
+
|
|
504
|
+
// src/extensions/posthog/extension.ts
|
|
505
|
+
import * as Effect4 from "effect/Effect";
|
|
506
|
+
import { LogBuffer, log as log3 } from "@dxos/log";
|
|
507
|
+
var __dxlog_file3 = "/__w/dxos/dxos/packages/sdk/observability/src/extensions/posthog/extension.ts";
|
|
508
|
+
var uploadLogs = async (body) => {
|
|
509
|
+
try {
|
|
510
|
+
const response = await fetch("/api/feedback-logs", {
|
|
511
|
+
method: "POST",
|
|
512
|
+
headers: {
|
|
513
|
+
"Content-Type": "application/x-ndjson"
|
|
514
|
+
},
|
|
515
|
+
body
|
|
516
|
+
});
|
|
517
|
+
if (!response.ok) {
|
|
518
|
+
log3.warn("feedback log upload failed", {
|
|
519
|
+
status: response.status
|
|
520
|
+
}, {
|
|
521
|
+
F: __dxlog_file3,
|
|
522
|
+
L: 34,
|
|
523
|
+
S: void 0,
|
|
524
|
+
C: (f, a) => f(...a)
|
|
280
525
|
});
|
|
526
|
+
return void 0;
|
|
527
|
+
}
|
|
528
|
+
const { key } = await response.json();
|
|
529
|
+
return key;
|
|
530
|
+
} catch (err) {
|
|
531
|
+
log3.warn("feedback log upload error", {
|
|
532
|
+
error: err
|
|
533
|
+
}, {
|
|
534
|
+
F: __dxlog_file3,
|
|
535
|
+
L: 40,
|
|
536
|
+
S: void 0,
|
|
537
|
+
C: (f, a) => f(...a)
|
|
281
538
|
});
|
|
282
|
-
|
|
283
|
-
|
|
284
|
-
|
|
285
|
-
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
539
|
+
return void 0;
|
|
540
|
+
}
|
|
541
|
+
};
|
|
542
|
+
var extensions2 = Effect4.fn(function* ({ config, release, environment, posthog: posthogConfig, logBuffer: externalLogBuffer }) {
|
|
543
|
+
if (typeof window === "undefined") {
|
|
544
|
+
log3("PostHog is being stubbed because it is running in a worker.", void 0, {
|
|
545
|
+
F: __dxlog_file3,
|
|
546
|
+
L: 54,
|
|
547
|
+
S: this,
|
|
548
|
+
C: (f, a) => f(...a)
|
|
549
|
+
});
|
|
550
|
+
return stubExtension;
|
|
551
|
+
}
|
|
552
|
+
const feedbackSurveyId = config.get("runtime.app.env.DX_POSTHOG_FEEDBACK_SURVEY_ID");
|
|
553
|
+
const apiKey = config.get("runtime.app.env.DX_POSTHOG_API_KEY");
|
|
554
|
+
const api_host = config.get("runtime.app.env.DX_POSTHOG_API_HOST");
|
|
555
|
+
if (!apiKey || !api_host) {
|
|
556
|
+
log3.info("Missing POSTHOG_API_KEY or POSTHOG_API_HOST", void 0, {
|
|
557
|
+
F: __dxlog_file3,
|
|
558
|
+
L: 62,
|
|
559
|
+
S: this,
|
|
560
|
+
C: (f, a) => f(...a)
|
|
561
|
+
});
|
|
562
|
+
return stubExtension;
|
|
563
|
+
}
|
|
564
|
+
const { default: posthog } = yield* Effect4.promise(() => import("posthog-js"));
|
|
565
|
+
const { logProcessor } = yield* Effect4.promise(() => import("./log-processor-TKJVJJSJ.mjs"));
|
|
566
|
+
const logBuffer = externalLogBuffer ?? new LogBuffer();
|
|
567
|
+
let feedbackSurveyAvailable = null;
|
|
568
|
+
const checkFeedbackSurveyAvailable = () => feedbackSurveyId ? Effect4.promise(() => {
|
|
569
|
+
if (feedbackSurveyAvailable !== null) {
|
|
570
|
+
return Promise.resolve(feedbackSurveyAvailable);
|
|
571
|
+
}
|
|
572
|
+
return new Promise((resolve) => {
|
|
573
|
+
posthog.getSurveys((surveys) => {
|
|
574
|
+
const found = surveys.some((s) => s.id === feedbackSurveyId);
|
|
575
|
+
feedbackSurveyAvailable = found;
|
|
576
|
+
resolve(found);
|
|
292
577
|
});
|
|
293
578
|
});
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
...
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
579
|
+
}) : Effect4.succeed(false);
|
|
580
|
+
return {
|
|
581
|
+
initialize: () => Effect4.sync(() => {
|
|
582
|
+
posthog.init(apiKey, {
|
|
583
|
+
api_host,
|
|
584
|
+
mask_all_text: true,
|
|
585
|
+
capture_exceptions: true,
|
|
586
|
+
...posthogConfig
|
|
587
|
+
});
|
|
588
|
+
if (release || environment) {
|
|
589
|
+
posthog.register({
|
|
590
|
+
...release ? {
|
|
591
|
+
release
|
|
592
|
+
} : {},
|
|
593
|
+
...environment ? {
|
|
594
|
+
environment
|
|
595
|
+
} : {}
|
|
596
|
+
});
|
|
597
|
+
}
|
|
598
|
+
log3.runtimeConfig.processors.push(logProcessor);
|
|
599
|
+
log3.runtimeConfig.processors.push(logBuffer.logProcessor);
|
|
600
|
+
}),
|
|
601
|
+
close: () => Effect4.sync(() => {
|
|
602
|
+
for (const processor of [
|
|
603
|
+
logProcessor,
|
|
604
|
+
logBuffer.logProcessor
|
|
605
|
+
]) {
|
|
606
|
+
const index = log3.runtimeConfig.processors.indexOf(processor);
|
|
607
|
+
if (index !== -1) {
|
|
608
|
+
log3.runtimeConfig.processors.splice(index, 1);
|
|
609
|
+
}
|
|
610
|
+
}
|
|
611
|
+
}),
|
|
612
|
+
enable: () => Effect4.sync(() => posthog.opt_in_capturing()),
|
|
613
|
+
disable: () => Effect4.sync(() => posthog.opt_out_capturing()),
|
|
614
|
+
identify: (distinctId, attributes, setOnceAttributes) => {
|
|
615
|
+
posthog.identify(distinctId, attributes, setOnceAttributes);
|
|
616
|
+
},
|
|
617
|
+
alias: (distinctId, previousId) => {
|
|
618
|
+
posthog.alias(distinctId, previousId);
|
|
619
|
+
},
|
|
620
|
+
setTags: (tags) => {
|
|
621
|
+
posthog.register_for_session(tags);
|
|
622
|
+
},
|
|
623
|
+
get enabled() {
|
|
624
|
+
return posthog.is_capturing();
|
|
625
|
+
},
|
|
626
|
+
apis: [
|
|
627
|
+
{
|
|
628
|
+
kind: "events",
|
|
629
|
+
isAvailable: () => Effect4.succeed(true),
|
|
630
|
+
captureEvent: (event, attributes) => {
|
|
631
|
+
posthog.capture(event, attributes);
|
|
632
|
+
}
|
|
633
|
+
},
|
|
634
|
+
{
|
|
635
|
+
kind: "errors",
|
|
636
|
+
isAvailable: () => Effect4.succeed(true),
|
|
637
|
+
captureException: (error, attributes) => {
|
|
638
|
+
posthog.captureException(error, attributes);
|
|
305
639
|
}
|
|
640
|
+
},
|
|
641
|
+
{
|
|
642
|
+
kind: "feedback",
|
|
643
|
+
// TODO(wittjosiah): Support custom surveys.
|
|
644
|
+
captureUserFeedback: (form) => {
|
|
645
|
+
posthog.getSurveys(async (surveys) => {
|
|
646
|
+
const survey = surveys.find((survey2) => survey2.id === feedbackSurveyId);
|
|
647
|
+
if (!survey || survey.questions.length === 0) {
|
|
648
|
+
log3.error("Missing feedback survey or survey has no questions", {
|
|
649
|
+
feedbackSurveyId
|
|
650
|
+
}, {
|
|
651
|
+
F: __dxlog_file3,
|
|
652
|
+
L: 151,
|
|
653
|
+
S: this,
|
|
654
|
+
C: (f, a) => f(...a)
|
|
655
|
+
});
|
|
656
|
+
return;
|
|
657
|
+
}
|
|
658
|
+
let debugLogDumpKey = null;
|
|
659
|
+
if (form.includeLogs !== false && logBuffer.size > 0) {
|
|
660
|
+
debugLogDumpKey = await uploadLogs(logBuffer.serialize()) ?? "failed";
|
|
661
|
+
}
|
|
662
|
+
const question = survey.questions[0];
|
|
663
|
+
posthog.capture("survey sent", {
|
|
664
|
+
$survey_id: survey.id,
|
|
665
|
+
$survey_questions: [
|
|
666
|
+
{
|
|
667
|
+
id: question.id,
|
|
668
|
+
question: question.question
|
|
669
|
+
}
|
|
670
|
+
],
|
|
671
|
+
[`$survey_response_${question.id}`]: form.message,
|
|
672
|
+
debug_log_dump_key: debugLogDumpKey
|
|
673
|
+
});
|
|
674
|
+
});
|
|
675
|
+
},
|
|
676
|
+
isAvailable: checkFeedbackSurveyAvailable
|
|
677
|
+
}
|
|
678
|
+
]
|
|
679
|
+
};
|
|
680
|
+
});
|
|
681
|
+
|
|
682
|
+
// src/providers/index.ts
|
|
683
|
+
var providers_exports = {};
|
|
684
|
+
__export(providers_exports, {
|
|
685
|
+
Client: () => client_observability_exports,
|
|
686
|
+
IPData: () => ip_data_exports,
|
|
687
|
+
Storage: () => storage_exports
|
|
688
|
+
});
|
|
689
|
+
|
|
690
|
+
// src/providers/client-observability.ts
|
|
691
|
+
var client_observability_exports = {};
|
|
692
|
+
__export(client_observability_exports, {
|
|
693
|
+
identityProvider: () => identityProvider,
|
|
694
|
+
networkMetricsProvider: () => networkMetricsProvider,
|
|
695
|
+
runtimeMetricsProvider: () => runtimeMetricsProvider,
|
|
696
|
+
spacesMetricsProvider: () => spacesMetricsProvider
|
|
697
|
+
});
|
|
698
|
+
import * as Effect5 from "effect/Effect";
|
|
699
|
+
import { Event, scheduleTaskInterval } from "@dxos/async";
|
|
700
|
+
import { DeviceKind } from "@dxos/client/halo";
|
|
701
|
+
import { Context } from "@dxos/context";
|
|
702
|
+
import { invariant as invariant2 } from "@dxos/invariant";
|
|
703
|
+
import { log as log4 } from "@dxos/log";
|
|
704
|
+
import { ConnectionState, Platform } from "@dxos/protocols/proto/dxos/client/services";
|
|
705
|
+
var __dxlog_file4 = "/__w/dxos/dxos/packages/sdk/observability/src/providers/client-observability.ts";
|
|
706
|
+
var SPACE_METRICS_MIN_INTERVAL = 1e3 * 60 * 10;
|
|
707
|
+
var NETWORK_METRICS_MIN_INTERVAL = 1e3 * 60 * 10;
|
|
708
|
+
var RUNTIME_METRICS_MIN_INTERVAL = 1e3 * 60 * 10;
|
|
709
|
+
var identityProvider = (clientServices) => Effect5.fn(function* (observability) {
|
|
710
|
+
clientServices.IdentityService.queryIdentity().subscribe((idqr) => {
|
|
711
|
+
if (!idqr?.identity?.did) {
|
|
712
|
+
return;
|
|
713
|
+
}
|
|
714
|
+
observability.identify(idqr.identity.did);
|
|
715
|
+
observability.setTags({
|
|
716
|
+
did: idqr.identity.did
|
|
717
|
+
});
|
|
718
|
+
});
|
|
719
|
+
clientServices.DevicesService.queryDevices().subscribe((dqr) => {
|
|
720
|
+
if (!dqr?.devices || dqr.devices.length === 0) {
|
|
721
|
+
return;
|
|
722
|
+
}
|
|
723
|
+
const thisDevice = dqr.devices.find((device) => device.kind === DeviceKind.CURRENT);
|
|
724
|
+
if (!thisDevice) {
|
|
725
|
+
return;
|
|
726
|
+
}
|
|
727
|
+
observability.setTags({
|
|
728
|
+
deviceKey: thisDevice.deviceKey.truncate()
|
|
729
|
+
});
|
|
730
|
+
if (thisDevice.profile?.label) {
|
|
731
|
+
observability.setTags({
|
|
732
|
+
deviceProfile: thisDevice.profile.label
|
|
306
733
|
});
|
|
734
|
+
}
|
|
735
|
+
});
|
|
736
|
+
});
|
|
737
|
+
var networkMetricsProvider = (clientServices) => Effect5.fn(function* (observability) {
|
|
738
|
+
const ctx = new Context(void 0, {
|
|
739
|
+
F: __dxlog_file4,
|
|
740
|
+
L: 61
|
|
741
|
+
});
|
|
742
|
+
let lastNetworkStatus;
|
|
743
|
+
const updateSignalMetrics = new Event().debounce(NETWORK_METRICS_MIN_INTERVAL);
|
|
744
|
+
updateSignalMetrics.on(ctx, async () => {
|
|
745
|
+
log4("send signal metrics", void 0, {
|
|
746
|
+
F: __dxlog_file4,
|
|
747
|
+
L: 67,
|
|
748
|
+
S: this,
|
|
749
|
+
C: (f, a) => f(...a)
|
|
307
750
|
});
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
const unloadCallback = () => {
|
|
312
|
-
setTimeout(() => {
|
|
313
|
-
observability.track({
|
|
314
|
-
...getTelemetryIdentity(client),
|
|
315
|
-
action: "page.unload",
|
|
316
|
-
properties: {
|
|
317
|
-
duration: totalTime
|
|
318
|
-
}
|
|
751
|
+
lastNetworkStatus?.signaling?.forEach(({ server, state }) => {
|
|
752
|
+
observability.metrics.gauge("dxos.client.network.signal.connectionState", state, {
|
|
753
|
+
server
|
|
319
754
|
});
|
|
320
755
|
});
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
|
|
326
|
-
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
756
|
+
let swarmCount = 0;
|
|
757
|
+
const connectionStates = /* @__PURE__ */ new Map();
|
|
758
|
+
for (const state in ConnectionState) {
|
|
759
|
+
connectionStates.set(state, 0);
|
|
760
|
+
}
|
|
761
|
+
let totalReadBufferSize = 0;
|
|
762
|
+
let totalWriteBufferSize = 0;
|
|
763
|
+
let totalChannelBufferSize = 0;
|
|
764
|
+
lastNetworkStatus?.connectionInfo?.forEach((connectionInfo) => {
|
|
765
|
+
swarmCount++;
|
|
766
|
+
for (const conn of connectionInfo.connections ?? []) {
|
|
767
|
+
connectionStates.set(conn.state, (connectionStates.get(conn.state) ?? 0) + 1);
|
|
768
|
+
totalReadBufferSize += conn.readBufferSize ?? 0;
|
|
769
|
+
totalWriteBufferSize += conn.writeBufferSize ?? 0;
|
|
770
|
+
for (const stream of conn.streams ?? []) {
|
|
771
|
+
totalChannelBufferSize += stream.writeBufferSize ?? 0;
|
|
332
772
|
}
|
|
333
|
-
}
|
|
773
|
+
}
|
|
774
|
+
observability.metrics.gauge("dxos.client.network.swarm.count", swarmCount);
|
|
775
|
+
for (const state in ConnectionState) {
|
|
776
|
+
observability.metrics.gauge("dxos.client.network.connection.count", connectionStates.get(state) ?? 0, {
|
|
777
|
+
state
|
|
778
|
+
});
|
|
779
|
+
}
|
|
780
|
+
observability.metrics.gauge("dxos.client.network.totalReadBufferSize", totalReadBufferSize);
|
|
781
|
+
observability.metrics.gauge("dxos.client.network.totalWriteBufferSize", totalWriteBufferSize);
|
|
782
|
+
observability.metrics.gauge("dxos.client.network.totalChannelBufferSize", totalChannelBufferSize);
|
|
334
783
|
});
|
|
784
|
+
});
|
|
785
|
+
clientServices.NetworkService.queryStatus().subscribe((networkStatus) => {
|
|
786
|
+
lastNetworkStatus = networkStatus;
|
|
787
|
+
updateSignalMetrics.emit();
|
|
788
|
+
});
|
|
789
|
+
scheduleTaskInterval(ctx, async () => updateSignalMetrics.emit(), NETWORK_METRICS_MIN_INTERVAL);
|
|
790
|
+
return async () => {
|
|
791
|
+
await ctx.dispose();
|
|
335
792
|
};
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
793
|
+
});
|
|
794
|
+
var runtimeMetricsProvider = (clientServices) => Effect5.fn(function* (observability) {
|
|
795
|
+
const ctx = new Context(void 0, {
|
|
796
|
+
F: __dxlog_file4,
|
|
797
|
+
L: 121
|
|
798
|
+
});
|
|
799
|
+
const platform = yield* Effect5.promise(() => clientServices.SystemService.getPlatform());
|
|
800
|
+
invariant2(platform, "platform is required", {
|
|
801
|
+
F: __dxlog_file4,
|
|
802
|
+
L: 123,
|
|
803
|
+
S: this,
|
|
804
|
+
A: [
|
|
805
|
+
"platform",
|
|
806
|
+
"'platform is required'"
|
|
807
|
+
]
|
|
808
|
+
});
|
|
809
|
+
observability.setTags({
|
|
810
|
+
platformType: Platform.PLATFORM_TYPE[platform.type].toLowerCase(),
|
|
811
|
+
platform: platform.platform,
|
|
812
|
+
arch: platform.arch,
|
|
813
|
+
runtime: platform.runtime
|
|
814
|
+
});
|
|
815
|
+
scheduleTaskInterval(ctx, async () => {
|
|
816
|
+
if (clientServices.constructor.name === "WorkerClientServices") {
|
|
817
|
+
const memory = window.performance.memory;
|
|
818
|
+
if (memory) {
|
|
819
|
+
observability.metrics.gauge("dxos.client.runtime.heapTotal", memory.totalJSHeapSize);
|
|
820
|
+
observability.metrics.gauge("dxos.client.runtime.heapUsed", memory.usedJSHeapSize);
|
|
821
|
+
observability.metrics.gauge("dxos.client.runtime.heapSizeLimit", memory.jsHeapSizeLimit);
|
|
822
|
+
}
|
|
823
|
+
}
|
|
824
|
+
clientServices.SystemService?.getPlatform().then((platform2) => {
|
|
825
|
+
if (platform2.memory) {
|
|
826
|
+
observability.metrics.gauge("dxos.client.services.runtime.rss", platform2.memory.rss);
|
|
827
|
+
observability.metrics.gauge("dxos.client.services.runtime.heapTotal", platform2.memory.heapTotal);
|
|
828
|
+
observability.metrics.gauge("dxos.client.services.runtime.heapUsed", platform2.memory.heapUsed);
|
|
829
|
+
}
|
|
830
|
+
}).catch((error) => log4("platform error", {
|
|
831
|
+
error
|
|
832
|
+
}, {
|
|
833
|
+
F: __dxlog_file4,
|
|
834
|
+
L: 152,
|
|
835
|
+
S: this,
|
|
836
|
+
C: (f, a) => f(...a)
|
|
837
|
+
}));
|
|
838
|
+
}, RUNTIME_METRICS_MIN_INTERVAL);
|
|
839
|
+
return async () => {
|
|
840
|
+
await ctx.dispose();
|
|
347
841
|
};
|
|
842
|
+
});
|
|
843
|
+
var spacesMetricsProvider = (client) => Effect5.fn(function* (observability) {
|
|
844
|
+
const ctx = new Context(void 0, {
|
|
845
|
+
F: __dxlog_file4,
|
|
846
|
+
L: 165
|
|
847
|
+
});
|
|
848
|
+
const spaces = client.spaces.get();
|
|
849
|
+
const subscriptions = /* @__PURE__ */ new Map();
|
|
850
|
+
ctx.onDispose(() => subscriptions.forEach((subscription) => subscription.unsubscribe()));
|
|
851
|
+
const updateSpaceMetrics = new Event().debounce(SPACE_METRICS_MIN_INTERVAL);
|
|
852
|
+
updateSpaceMetrics.on(ctx, async () => {
|
|
853
|
+
log4("send space metrics", void 0, {
|
|
854
|
+
F: __dxlog_file4,
|
|
855
|
+
L: 173,
|
|
856
|
+
S: this,
|
|
857
|
+
C: (f, a) => f(...a)
|
|
858
|
+
});
|
|
859
|
+
for (const data of mapSpaces(spaces, {
|
|
860
|
+
truncateKeys: true
|
|
861
|
+
})) {
|
|
862
|
+
observability.metrics.gauge("dxos.client.space.members", data.members, {
|
|
863
|
+
key: data.key
|
|
864
|
+
});
|
|
865
|
+
observability.metrics.gauge("dxos.client.space.objects", data.objects, {
|
|
866
|
+
key: data.key
|
|
867
|
+
});
|
|
868
|
+
observability.metrics.gauge("dxos.client.space.epoch", data.epoch, {
|
|
869
|
+
key: data.key
|
|
870
|
+
});
|
|
871
|
+
observability.metrics.gauge("dxos.client.space.currentDataMutations", data.currentDataMutations, {
|
|
872
|
+
key: data.key
|
|
873
|
+
});
|
|
874
|
+
}
|
|
875
|
+
});
|
|
876
|
+
const subscribeToSpaceUpdate = (space) => space.pipeline.subscribe({
|
|
877
|
+
next: () => {
|
|
878
|
+
updateSpaceMetrics.emit();
|
|
879
|
+
}
|
|
880
|
+
});
|
|
881
|
+
spaces.forEach((space) => {
|
|
882
|
+
subscriptions.set(space.id, subscribeToSpaceUpdate(space));
|
|
883
|
+
});
|
|
884
|
+
client.spaces.subscribe({
|
|
885
|
+
next: async (spaces2) => {
|
|
886
|
+
spaces2.filter((space) => !subscriptions.has(space.id)).forEach((space) => {
|
|
887
|
+
subscriptions.set(space.id, subscribeToSpaceUpdate(space));
|
|
888
|
+
});
|
|
889
|
+
}
|
|
890
|
+
});
|
|
891
|
+
scheduleTaskInterval(ctx, async () => updateSpaceMetrics.emit(), SPACE_METRICS_MIN_INTERVAL);
|
|
892
|
+
return async () => {
|
|
893
|
+
await ctx.dispose();
|
|
894
|
+
};
|
|
895
|
+
});
|
|
896
|
+
var mapSpaces = (spaces, options = {
|
|
897
|
+
verbose: false,
|
|
898
|
+
truncateKeys: false
|
|
899
|
+
}) => {
|
|
900
|
+
return spaces.map((space) => {
|
|
901
|
+
const { open, ready } = space.internal.data.metrics ?? {};
|
|
902
|
+
const startup = open && ready && ready.getTime() - open.getTime();
|
|
903
|
+
const pipeline = space.internal.data.pipeline;
|
|
904
|
+
const startDataMutations = pipeline?.currentEpoch?.subject.assertion.timeframe.totalMessages() ?? 0;
|
|
905
|
+
const epoch = pipeline?.currentEpoch?.subject.assertion.number;
|
|
906
|
+
const currentDataMutations = pipeline?.currentDataTimeframe?.totalMessages() ?? 0;
|
|
907
|
+
const totalDataMutations = pipeline?.targetDataTimeframe?.totalMessages() ?? 0;
|
|
908
|
+
return {
|
|
909
|
+
// TODO(nf): truncate keys for DD?
|
|
910
|
+
key: space.key.truncate(),
|
|
911
|
+
open: space.isOpen,
|
|
912
|
+
members: space.members.get().length,
|
|
913
|
+
objects: space.internal.db.coreDatabase.getAllObjectIds().length,
|
|
914
|
+
startup,
|
|
915
|
+
epoch,
|
|
916
|
+
// appliedEpoch,
|
|
917
|
+
startDataMutations,
|
|
918
|
+
currentDataMutations,
|
|
919
|
+
totalDataMutations,
|
|
920
|
+
// TODO(burdon): Negative?
|
|
921
|
+
progress: (Math.min(Math.abs((currentDataMutations - startDataMutations) / (totalDataMutations - startDataMutations)), 1) * 100).toFixed(0)
|
|
922
|
+
};
|
|
923
|
+
});
|
|
348
924
|
};
|
|
925
|
+
|
|
926
|
+
// src/providers/ip-data.ts
|
|
927
|
+
var ip_data_exports = {};
|
|
928
|
+
__export(ip_data_exports, {
|
|
929
|
+
provider: () => provider
|
|
930
|
+
});
|
|
931
|
+
import * as FetchHttpClient from "@effect/platform/FetchHttpClient";
|
|
932
|
+
import * as HttpClient from "@effect/platform/HttpClient";
|
|
933
|
+
import * as HttpClientRequest from "@effect/platform/HttpClientRequest";
|
|
934
|
+
import * as Effect6 from "effect/Effect";
|
|
935
|
+
import * as Schema from "effect/Schema";
|
|
936
|
+
import * as localForage from "localforage";
|
|
937
|
+
import { log as log5 } from "@dxos/log";
|
|
938
|
+
var __dxlog_file5 = "/__w/dxos/dxos/packages/sdk/observability/src/providers/ip-data.ts";
|
|
939
|
+
var IP_DATA_CACHE_TIMEOUT = 6 * 60 * 60 * 1e3;
|
|
940
|
+
var IPData = Schema.Struct({
|
|
941
|
+
city: Schema.String,
|
|
942
|
+
region: Schema.String,
|
|
943
|
+
country: Schema.String,
|
|
944
|
+
latitude: Schema.optional(Schema.Number),
|
|
945
|
+
longitude: Schema.optional(Schema.Number)
|
|
946
|
+
});
|
|
947
|
+
var getIPData = Effect6.fn(function* (config) {
|
|
948
|
+
const httpClient = yield* HttpClient.HttpClient;
|
|
949
|
+
const httpClientNoTrace = httpClient.pipe(HttpClient.withTracerDisabledWhen(() => true));
|
|
950
|
+
const cachedData = yield* Effect6.promise(() => localForage.getItem("dxos:observability:ipdata"));
|
|
951
|
+
if (cachedData && cachedData.timestamp > Date.now() - IP_DATA_CACHE_TIMEOUT) {
|
|
952
|
+
return cachedData.data;
|
|
953
|
+
}
|
|
954
|
+
const IPDATA_API_KEY = config.get("runtime.app.env.DX_IPDATA_API_KEY");
|
|
955
|
+
if (IPDATA_API_KEY) {
|
|
956
|
+
const data = yield* HttpClientRequest.get(`https://api.ipdata.co?api-key=${IPDATA_API_KEY}`).pipe(httpClientNoTrace.execute, Effect6.flatMap((res) => res.json), Effect6.flatMap(Schema.decodeUnknown(IPData)));
|
|
957
|
+
yield* Effect6.promise(() => localForage.setItem("dxos:observability:ipdata", {
|
|
958
|
+
data,
|
|
959
|
+
timestamp: Date.now()
|
|
960
|
+
}));
|
|
961
|
+
return data;
|
|
962
|
+
}
|
|
963
|
+
});
|
|
964
|
+
var provider = (config) => (observability) => Effect6.gen(function* () {
|
|
965
|
+
const ipData = yield* getIPData(config);
|
|
966
|
+
if (!ipData) {
|
|
967
|
+
return;
|
|
968
|
+
}
|
|
969
|
+
observability.setTags({
|
|
970
|
+
city: ipData.city,
|
|
971
|
+
region: ipData.region,
|
|
972
|
+
country: ipData.country,
|
|
973
|
+
latitude: ipData.latitude,
|
|
974
|
+
longitude: ipData.longitude
|
|
975
|
+
});
|
|
976
|
+
}).pipe(Effect6.provide(FetchHttpClient.layer), Effect6.catchAll((err) => Effect6.sync(() => {
|
|
977
|
+
log5.verbose("ipdata fetch failed", {
|
|
978
|
+
err
|
|
979
|
+
}, {
|
|
980
|
+
F: __dxlog_file5,
|
|
981
|
+
L: 88,
|
|
982
|
+
S: void 0,
|
|
983
|
+
C: (f, a) => f(...a)
|
|
984
|
+
});
|
|
985
|
+
})));
|
|
986
|
+
|
|
987
|
+
// src/providers/storage.ts
|
|
988
|
+
var storage_exports = {};
|
|
989
|
+
__export(storage_exports, {
|
|
990
|
+
provider: () => provider2
|
|
991
|
+
});
|
|
992
|
+
import * as Duration from "effect/Duration";
|
|
993
|
+
import * as Effect7 from "effect/Effect";
|
|
994
|
+
import * as Fiber from "effect/Fiber";
|
|
995
|
+
import * as Schedule from "effect/Schedule";
|
|
996
|
+
var provider2 = Effect7.fn(function* (observability) {
|
|
997
|
+
if (typeof navigator !== "undefined" && navigator.storage?.estimate) {
|
|
998
|
+
const action = Effect7.gen(function* () {
|
|
999
|
+
const storageEstimate = yield* Effect7.tryPromise(() => navigator.storage.estimate());
|
|
1000
|
+
storageEstimate.usage && observability.metrics.gauge("storageUsage", storageEstimate.usage);
|
|
1001
|
+
storageEstimate.quota && observability.metrics.gauge("storageQuota", storageEstimate.quota);
|
|
1002
|
+
});
|
|
1003
|
+
const fiber = action.pipe(Effect7.repeat(Schedule.fixed(Duration.hours(1))), Effect7.runFork);
|
|
1004
|
+
return () => Effect7.runSync(Fiber.interrupt(fiber));
|
|
1005
|
+
}
|
|
1006
|
+
});
|
|
349
1007
|
export {
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
getObservabilityGroup,
|
|
354
|
-
getObservabilityState,
|
|
355
|
-
getTelemetryIdentifier,
|
|
356
|
-
getTelemetryIdentity,
|
|
357
|
-
initializeAppObservability,
|
|
358
|
-
initializeNodeObservability,
|
|
359
|
-
isObservabilityDisabled,
|
|
360
|
-
mapSpaces,
|
|
361
|
-
setupTelemetryListeners,
|
|
362
|
-
showObservabilityBanner,
|
|
363
|
-
storeObservabilityDisabled,
|
|
364
|
-
storeObservabilityGroup
|
|
1008
|
+
observability_exports as Observability,
|
|
1009
|
+
observability_extension_exports as ObservabilityExtension,
|
|
1010
|
+
providers_exports as ObservabilityProvider
|
|
365
1011
|
};
|
|
366
1012
|
//# sourceMappingURL=index.mjs.map
|