@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
|
@@ -8,11 +8,6 @@ import { join } from 'node:path';
|
|
|
8
8
|
import yaml from 'js-yaml';
|
|
9
9
|
import { v4 as uuid, validate as validateUuid } from 'uuid';
|
|
10
10
|
|
|
11
|
-
import type { Config } from '@dxos/client';
|
|
12
|
-
import { log } from '@dxos/log';
|
|
13
|
-
|
|
14
|
-
import { type Mode, Observability } from '../observability';
|
|
15
|
-
|
|
16
11
|
/**
|
|
17
12
|
* Print observability banner once per installation.
|
|
18
13
|
*/
|
|
@@ -22,7 +17,6 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
22
17
|
return;
|
|
23
18
|
}
|
|
24
19
|
bannercb(
|
|
25
|
-
// eslint-disable-next-line no-multi-str
|
|
26
20
|
'Basic observability data will be sent to the DXOS team in order to improve the product. This includes \
|
|
27
21
|
performance metrics, error logs, and usage data. No personally identifiable information, other than your \
|
|
28
22
|
public key, is included with this data and no private data ever leaves your devices. To disable sending \
|
|
@@ -32,7 +26,43 @@ export const showObservabilityBanner = async (configDir: string, bannercb: (inpu
|
|
|
32
26
|
await writeFile(path, '', 'utf-8');
|
|
33
27
|
};
|
|
34
28
|
|
|
35
|
-
|
|
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> => {
|
|
36
66
|
// check whether configDir exists and if it's a directory
|
|
37
67
|
|
|
38
68
|
if (existsSync(configDir)) {
|
|
@@ -54,8 +84,8 @@ export const getObservabilityState = async (configDir: string): Promise<Persiste
|
|
|
54
84
|
|
|
55
85
|
export type PersistentObservabilityState = {
|
|
56
86
|
installationId: string;
|
|
87
|
+
disabled: boolean;
|
|
57
88
|
group?: string;
|
|
58
|
-
mode: Mode;
|
|
59
89
|
};
|
|
60
90
|
|
|
61
91
|
// create initial state and write to file, using environment variables to override defaults.
|
|
@@ -63,8 +93,8 @@ const initializeState = async (idPath: string): Promise<PersistentObservabilityS
|
|
|
63
93
|
// TODO(nf): read initial values from config or seed file
|
|
64
94
|
const observabilityState = {
|
|
65
95
|
installationId: uuid(),
|
|
96
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : false,
|
|
66
97
|
group: process.env.DX_OBSERVABILITY_GROUP ?? undefined,
|
|
67
|
-
mode: (process.env.DX_DISABLE_OBSERVABILITY ? 'disabled' : (process.env.DX_OBSERVABILITY_MODE ?? 'basic')) as Mode,
|
|
68
98
|
};
|
|
69
99
|
|
|
70
100
|
await writeFile(
|
|
@@ -81,66 +111,7 @@ const validate = (contextString: string) => {
|
|
|
81
111
|
if (Boolean(context.installationId) && validateUuid(context.installationId!)) {
|
|
82
112
|
return {
|
|
83
113
|
...context,
|
|
84
|
-
|
|
114
|
+
disabled: process.env.DX_DISABLE_OBSERVABILITY ? true : (context.disabled ?? false),
|
|
85
115
|
};
|
|
86
116
|
}
|
|
87
117
|
};
|
|
88
|
-
|
|
89
|
-
export type NodeObservabilityOptions = {
|
|
90
|
-
installationId: string;
|
|
91
|
-
group?: string;
|
|
92
|
-
namespace: string;
|
|
93
|
-
version: string;
|
|
94
|
-
config: Config;
|
|
95
|
-
mode?: Mode;
|
|
96
|
-
tracingEnable?: boolean;
|
|
97
|
-
replayEnable?: boolean;
|
|
98
|
-
// TODO(nf): options for providers?
|
|
99
|
-
};
|
|
100
|
-
|
|
101
|
-
export const initializeNodeObservability = async ({
|
|
102
|
-
namespace,
|
|
103
|
-
version,
|
|
104
|
-
config,
|
|
105
|
-
installationId,
|
|
106
|
-
group,
|
|
107
|
-
mode = 'basic',
|
|
108
|
-
tracingEnable = true,
|
|
109
|
-
replayEnable = true,
|
|
110
|
-
}: NodeObservabilityOptions): Promise<Observability> => {
|
|
111
|
-
log('initializeCliObservability', { config });
|
|
112
|
-
|
|
113
|
-
// TODO(nf): make CLI build populate runtime.app.build config?
|
|
114
|
-
const release = `${namespace}@${version}`;
|
|
115
|
-
const environment = process.env.DX_ENVIRONMENT ?? 'unknown';
|
|
116
|
-
|
|
117
|
-
const observability = new Observability({
|
|
118
|
-
mode,
|
|
119
|
-
namespace,
|
|
120
|
-
release,
|
|
121
|
-
environment,
|
|
122
|
-
group,
|
|
123
|
-
errorLog: {
|
|
124
|
-
sentryInitOptions: {
|
|
125
|
-
environment,
|
|
126
|
-
release,
|
|
127
|
-
// TODO(wittjosiah): Configure this.
|
|
128
|
-
sampleRate: 1.0,
|
|
129
|
-
},
|
|
130
|
-
},
|
|
131
|
-
});
|
|
132
|
-
|
|
133
|
-
observability.setTag('installationId', installationId);
|
|
134
|
-
|
|
135
|
-
// TODO(nf): cache ipdata to avoid repeated requests
|
|
136
|
-
const IPDATA_API_KEY = config.get('runtime.app.env.DX_IPDATA_API_KEY');
|
|
137
|
-
try {
|
|
138
|
-
const res = await fetch(`https://api.ipdata.co/?api-key=${IPDATA_API_KEY}`);
|
|
139
|
-
const ipData = await res.json();
|
|
140
|
-
ipData && observability.setIPDataTelemetryTags(ipData);
|
|
141
|
-
} catch (err) {
|
|
142
|
-
observability?.captureException(err);
|
|
143
|
-
}
|
|
144
|
-
|
|
145
|
-
return observability;
|
|
146
|
-
};
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
//# sourceMappingURL=chunk-5ICT2XF2.mjs.map
|
|
@@ -1,148 +0,0 @@
|
|
|
1
|
-
import {
|
|
2
|
-
captureException
|
|
3
|
-
} from "./chunk-O4BG5MRL.mjs";
|
|
4
|
-
|
|
5
|
-
// src/segment/browser.ts
|
|
6
|
-
import snippet from "@segment/snippet";
|
|
7
|
-
import { log as log2 } from "@dxos/log";
|
|
8
|
-
|
|
9
|
-
// src/segment/base.ts
|
|
10
|
-
import { log } from "@dxos/log";
|
|
11
|
-
|
|
12
|
-
// src/segment/types.ts
|
|
13
|
-
var TelemetryEvent = /* @__PURE__ */ (function(TelemetryEvent2) {
|
|
14
|
-
TelemetryEvent2["ACTION"] = "action";
|
|
15
|
-
TelemetryEvent2["METRICS"] = "metrics";
|
|
16
|
-
return TelemetryEvent2;
|
|
17
|
-
})({});
|
|
18
|
-
|
|
19
|
-
// src/segment/base.ts
|
|
20
|
-
var __dxlog_file = "/__w/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
|
-
_getTags;
|
|
37
|
-
constructor(_getTags) {
|
|
38
|
-
this._getTags = _getTags;
|
|
39
|
-
}
|
|
40
|
-
createPageParams(options) {
|
|
41
|
-
const { properties, ...rest } = options;
|
|
42
|
-
return {
|
|
43
|
-
...getIdentityOptions(options),
|
|
44
|
-
...rest,
|
|
45
|
-
properties: {
|
|
46
|
-
common: this._getTags(),
|
|
47
|
-
custom: properties
|
|
48
|
-
}
|
|
49
|
-
};
|
|
50
|
-
}
|
|
51
|
-
createTrackParams(options) {
|
|
52
|
-
const { event, action, properties, ...rest } = options;
|
|
53
|
-
return {
|
|
54
|
-
...getIdentityOptions(options),
|
|
55
|
-
...rest,
|
|
56
|
-
event: event ?? TelemetryEvent.ACTION,
|
|
57
|
-
properties: {
|
|
58
|
-
action,
|
|
59
|
-
common: this._getTags(),
|
|
60
|
-
custom: properties
|
|
61
|
-
}
|
|
62
|
-
};
|
|
63
|
-
}
|
|
64
|
-
};
|
|
65
|
-
|
|
66
|
-
// src/segment/browser.ts
|
|
67
|
-
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/observability/src/segment/browser.ts";
|
|
68
|
-
var SegmentTelemetry = class extends AbstractSegmentTelemetry {
|
|
69
|
-
constructor({ apiKey, batchSize, getTags }) {
|
|
70
|
-
super(getTags);
|
|
71
|
-
try {
|
|
72
|
-
const contents = snippet.min({
|
|
73
|
-
apiKey,
|
|
74
|
-
page: false
|
|
75
|
-
});
|
|
76
|
-
const script = document.createElement("script");
|
|
77
|
-
script.innerHTML = contents;
|
|
78
|
-
document.body.append(script);
|
|
79
|
-
} catch (err) {
|
|
80
|
-
log2.catch("failed to initialize telemetry", err, {
|
|
81
|
-
F: __dxlog_file2,
|
|
82
|
-
L: 28,
|
|
83
|
-
S: this,
|
|
84
|
-
C: (f, a) => f(...a)
|
|
85
|
-
});
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
identify(options) {
|
|
89
|
-
try {
|
|
90
|
-
window.analytics?.identify(options.userId, options.traits);
|
|
91
|
-
} catch (err) {
|
|
92
|
-
log2.catch("failed to identify", err, {
|
|
93
|
-
F: __dxlog_file2,
|
|
94
|
-
L: 36,
|
|
95
|
-
S: this,
|
|
96
|
-
C: (f, a) => f(...a)
|
|
97
|
-
});
|
|
98
|
-
}
|
|
99
|
-
}
|
|
100
|
-
page(options) {
|
|
101
|
-
try {
|
|
102
|
-
const props = this.createPageParams(options);
|
|
103
|
-
window.analytics?.page(props.category, props.name, props.properties);
|
|
104
|
-
} catch (err) {
|
|
105
|
-
log2.catch("failed to track page", err, {
|
|
106
|
-
F: __dxlog_file2,
|
|
107
|
-
L: 45,
|
|
108
|
-
S: this,
|
|
109
|
-
C: (f, a) => f(...a)
|
|
110
|
-
});
|
|
111
|
-
}
|
|
112
|
-
}
|
|
113
|
-
track(options) {
|
|
114
|
-
try {
|
|
115
|
-
const props = this.createTrackParams(options);
|
|
116
|
-
window.analytics?.track(props.event, props.properties);
|
|
117
|
-
} catch (err) {
|
|
118
|
-
log2.catch("failed to track event", err, {
|
|
119
|
-
F: __dxlog_file2,
|
|
120
|
-
L: 54,
|
|
121
|
-
S: this,
|
|
122
|
-
C: (f, a) => f(...a)
|
|
123
|
-
});
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
async flush() {
|
|
127
|
-
try {
|
|
128
|
-
await window.analytics?.flush((err) => {
|
|
129
|
-
captureException(err);
|
|
130
|
-
});
|
|
131
|
-
} catch (err) {
|
|
132
|
-
log2.catch("failed to flush telemetry", err, {
|
|
133
|
-
F: __dxlog_file2,
|
|
134
|
-
L: 64,
|
|
135
|
-
S: this,
|
|
136
|
-
C: (f, a) => f(...a)
|
|
137
|
-
});
|
|
138
|
-
}
|
|
139
|
-
}
|
|
140
|
-
async close() {
|
|
141
|
-
}
|
|
142
|
-
};
|
|
143
|
-
|
|
144
|
-
export {
|
|
145
|
-
TelemetryEvent,
|
|
146
|
-
SegmentTelemetry
|
|
147
|
-
};
|
|
148
|
-
//# sourceMappingURL=chunk-5LN7D6GM.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 { captureException } from '../sentry';\n\nimport { AbstractSegmentTelemetry } from './base';\nimport type { PageOptions, SegmentTelemetryOptions, TrackOptions } from './types';\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.createPageParams(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.createTrackParams(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 IdentifyParams, type PageParams, type TrackParams } 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 createPageParams(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 createTrackParams(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,0BAAAA,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,iBAAiBC,SAAkC;AAC3D,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,kBAAkBL,SAAoC;AAC9D,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;;;;ADlDO,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,iBAAiBN,OAAAA;AACnCC,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,kBAAkBX,OAAAA;AACpCC,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", "createPageParams", "options", "properties", "rest", "common", "custom", "createTrackParams", "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", "createPageParams", "category", "name", "properties", "track", "createTrackParams", "event", "flush", "captureException", "close"]
|
|
7
|
-
}
|