@dxos/observability 0.8.4-main.84f28bd → 0.8.4-main.8baae0fced

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.
Files changed (330) hide show
  1. package/LICENSE +102 -5
  2. package/README.md +14 -11
  3. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  4. package/dist/lib/browser/chunk-PSFTIG54.mjs +20 -0
  5. package/dist/lib/browser/chunk-PSFTIG54.mjs.map +7 -0
  6. package/dist/lib/browser/index.mjs +964 -34
  7. package/dist/lib/browser/index.mjs.map +4 -4
  8. package/dist/lib/browser/log-processor-HPHWNBOK.mjs +38 -0
  9. package/dist/lib/browser/log-processor-HPHWNBOK.mjs.map +7 -0
  10. package/dist/lib/browser/logs-UTNIFYHF.mjs +116 -0
  11. package/dist/lib/browser/logs-UTNIFYHF.mjs.map +7 -0
  12. package/dist/lib/browser/meta.json +1 -1
  13. package/dist/lib/browser/metrics-PRGSYAZJ.mjs +116 -0
  14. package/dist/lib/browser/metrics-PRGSYAZJ.mjs.map +7 -0
  15. package/dist/lib/browser/traces-browser-XRINKQUA.mjs +154 -0
  16. package/dist/lib/browser/traces-browser-XRINKQUA.mjs.map +7 -0
  17. package/dist/lib/node-esm/chunk-EDDZWPYV.mjs +22 -0
  18. package/dist/lib/node-esm/chunk-EDDZWPYV.mjs.map +7 -0
  19. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  20. package/dist/lib/node-esm/index.mjs +986 -34
  21. package/dist/lib/node-esm/index.mjs.map +4 -4
  22. package/dist/lib/node-esm/log-processor-ZODHERST.mjs +39 -0
  23. package/dist/lib/node-esm/log-processor-ZODHERST.mjs.map +7 -0
  24. package/dist/lib/node-esm/logs-ARJUVN3T.mjs +117 -0
  25. package/dist/lib/node-esm/logs-ARJUVN3T.mjs.map +7 -0
  26. package/dist/lib/node-esm/meta.json +1 -1
  27. package/dist/lib/node-esm/metrics-DREJOOAC.mjs +117 -0
  28. package/dist/lib/node-esm/metrics-DREJOOAC.mjs.map +7 -0
  29. package/dist/lib/node-esm/traces-74F7JUKF.mjs +125 -0
  30. package/dist/lib/node-esm/traces-74F7JUKF.mjs.map +7 -0
  31. package/dist/types/src/cli-observability-secrets.json +3 -4
  32. package/dist/types/src/extensions/index.d.ts +3 -0
  33. package/dist/types/src/extensions/index.d.ts.map +1 -0
  34. package/dist/types/src/extensions/index.js +6 -0
  35. package/dist/types/src/extensions/index.js.map +1 -0
  36. package/dist/types/src/extensions/otel/extension.d.ts +23 -0
  37. package/dist/types/src/extensions/otel/extension.d.ts.map +1 -0
  38. package/dist/types/src/extensions/otel/extension.js +220 -0
  39. package/dist/types/src/extensions/otel/extension.js.map +1 -0
  40. package/dist/types/src/extensions/otel/index.d.ts +2 -0
  41. package/dist/types/src/extensions/otel/index.d.ts.map +1 -0
  42. package/dist/types/src/extensions/otel/index.js +5 -0
  43. package/dist/types/src/extensions/otel/index.js.map +1 -0
  44. package/dist/types/src/{otel → extensions/otel}/logs.d.ts +4 -3
  45. package/dist/types/src/extensions/otel/logs.d.ts.map +1 -0
  46. package/dist/types/src/extensions/otel/logs.js +107 -0
  47. package/dist/types/src/extensions/otel/logs.js.map +1 -0
  48. package/dist/types/src/{otel → extensions/otel}/metrics.d.ts +0 -1
  49. package/dist/types/src/extensions/otel/metrics.d.ts.map +1 -0
  50. package/dist/types/src/{otel → extensions/otel}/metrics.js +8 -14
  51. package/dist/types/src/extensions/otel/metrics.js.map +1 -0
  52. package/dist/types/src/extensions/otel/otel.d.ts +19 -0
  53. package/dist/types/src/extensions/otel/otel.d.ts.map +1 -0
  54. package/dist/types/src/extensions/otel/otel.js +23 -0
  55. package/dist/types/src/extensions/otel/otel.js.map +1 -0
  56. package/dist/types/src/extensions/otel/span-processors.d.ts +25 -0
  57. package/dist/types/src/extensions/otel/span-processors.d.ts.map +1 -0
  58. package/dist/types/src/extensions/otel/span-processors.js +41 -0
  59. package/dist/types/src/extensions/otel/span-processors.js.map +1 -0
  60. package/dist/types/src/extensions/otel/traces-browser.d.ts +25 -0
  61. package/dist/types/src/extensions/otel/traces-browser.d.ts.map +1 -0
  62. package/dist/types/src/extensions/otel/traces-browser.js +105 -0
  63. package/dist/types/src/extensions/otel/traces-browser.js.map +1 -0
  64. package/dist/types/src/extensions/otel/traces.d.ts +25 -0
  65. package/dist/types/src/extensions/otel/traces.d.ts.map +1 -0
  66. package/dist/types/src/extensions/otel/traces.js +88 -0
  67. package/dist/types/src/extensions/otel/traces.js.map +1 -0
  68. package/dist/types/src/extensions/posthog/extension.d.ts +28 -0
  69. package/dist/types/src/extensions/posthog/extension.d.ts.map +1 -0
  70. package/dist/types/src/extensions/posthog/extension.js +156 -0
  71. package/dist/types/src/extensions/posthog/extension.js.map +1 -0
  72. package/dist/types/src/extensions/posthog/index.d.ts +2 -0
  73. package/dist/types/src/extensions/posthog/index.d.ts.map +1 -0
  74. package/dist/types/src/extensions/posthog/index.js +5 -0
  75. package/dist/types/src/extensions/posthog/index.js.map +1 -0
  76. package/dist/types/src/extensions/posthog/log-processor.d.ts +3 -0
  77. package/dist/types/src/extensions/posthog/log-processor.d.ts.map +1 -0
  78. package/dist/types/src/extensions/posthog/log-processor.js +36 -0
  79. package/dist/types/src/extensions/posthog/log-processor.js.map +1 -0
  80. package/dist/types/src/extensions/posthog/log-processor.test.d.ts +2 -0
  81. package/dist/types/src/extensions/posthog/log-processor.test.d.ts.map +1 -0
  82. package/dist/types/src/extensions/posthog/log-processor.test.js +146 -0
  83. package/dist/types/src/extensions/posthog/log-processor.test.js.map +1 -0
  84. package/dist/types/src/extensions/stub.d.ts +3 -0
  85. package/dist/types/src/extensions/stub.d.ts.map +1 -0
  86. package/dist/types/src/extensions/stub.js +16 -0
  87. package/dist/types/src/extensions/stub.js.map +1 -0
  88. package/dist/types/src/index.d.ts +3 -2
  89. package/dist/types/src/index.d.ts.map +1 -1
  90. package/dist/types/src/index.js +4 -3
  91. package/dist/types/src/index.js.map +1 -1
  92. package/dist/types/src/observability-extension.d.ts +74 -0
  93. package/dist/types/src/observability-extension.d.ts.map +1 -0
  94. package/dist/types/src/observability-extension.js +5 -0
  95. package/dist/types/src/observability-extension.js.map +1 -0
  96. package/dist/types/src/observability.d.ts +32 -110
  97. package/dist/types/src/observability.d.ts.map +1 -1
  98. package/dist/types/src/observability.js +178 -455
  99. package/dist/types/src/observability.js.map +1 -1
  100. package/dist/types/src/observability.test.d.ts +2 -0
  101. package/dist/types/src/observability.test.d.ts.map +1 -0
  102. package/dist/types/src/observability.test.js +312 -0
  103. package/dist/types/src/observability.test.js.map +1 -0
  104. package/dist/types/src/providers/client-observability.d.ts +11 -0
  105. package/dist/types/src/providers/client-observability.d.ts.map +1 -0
  106. package/dist/types/src/providers/client-observability.js +202 -0
  107. package/dist/types/src/providers/client-observability.js.map +1 -0
  108. package/dist/types/src/providers/index.d.ts +4 -0
  109. package/dist/types/src/providers/index.d.ts.map +1 -0
  110. package/dist/types/src/providers/index.js +7 -0
  111. package/dist/types/src/providers/index.js.map +1 -0
  112. package/dist/types/src/providers/ip-data.d.ts +5 -0
  113. package/dist/types/src/providers/ip-data.d.ts.map +1 -0
  114. package/dist/types/src/providers/ip-data.js +57 -0
  115. package/dist/types/src/providers/ip-data.js.map +1 -0
  116. package/dist/types/src/providers/storage.d.ts +3 -0
  117. package/dist/types/src/providers/storage.d.ts.map +1 -0
  118. package/dist/types/src/providers/storage.js +19 -0
  119. package/dist/types/src/providers/storage.js.map +1 -0
  120. package/dist/types/src/storage/browser.d.ts +19 -0
  121. package/dist/types/src/storage/browser.d.ts.map +1 -0
  122. package/dist/types/src/storage/browser.js +69 -0
  123. package/dist/types/src/storage/browser.js.map +1 -0
  124. package/dist/types/src/storage/index.d.ts +2 -0
  125. package/dist/types/src/storage/index.d.ts.map +1 -0
  126. package/{src/segment/index.ts → dist/types/src/storage/index.js} +1 -2
  127. package/dist/types/src/storage/index.js.map +1 -0
  128. package/dist/types/src/storage/node.d.ts +26 -0
  129. package/dist/types/src/storage/node.d.ts.map +1 -0
  130. package/dist/types/src/storage/node.js +92 -0
  131. package/dist/types/src/storage/node.js.map +1 -0
  132. package/dist/types/src/storage/node.test.d.ts +2 -0
  133. package/dist/types/src/storage/node.test.d.ts.map +1 -0
  134. package/dist/types/src/storage/node.test.js +103 -0
  135. package/dist/types/src/storage/node.test.js.map +1 -0
  136. package/dist/types/tsconfig.tsbuildinfo +1 -1
  137. package/package.json +48 -65
  138. package/src/cli-observability-secrets.json +3 -4
  139. package/src/extensions/index.ts +6 -0
  140. package/src/extensions/otel/extension.ts +279 -0
  141. package/src/extensions/otel/index.ts +5 -0
  142. package/src/extensions/otel/logs.ts +137 -0
  143. package/src/{otel → extensions/otel}/metrics.ts +6 -23
  144. package/src/extensions/otel/otel.ts +34 -0
  145. package/src/extensions/otel/span-processors.ts +45 -0
  146. package/src/extensions/otel/traces-browser.ts +139 -0
  147. package/src/extensions/otel/traces.ts +113 -0
  148. package/src/extensions/posthog/extension.ts +199 -0
  149. package/src/extensions/posthog/index.ts +5 -0
  150. package/src/extensions/posthog/log-processor.test.ts +186 -0
  151. package/src/extensions/posthog/log-processor.ts +43 -0
  152. package/src/extensions/stub.ts +19 -0
  153. package/src/index.ts +4 -3
  154. package/src/observability-extension.ts +94 -0
  155. package/src/observability.test.ts +531 -0
  156. package/src/observability.ts +238 -577
  157. package/src/providers/client-observability.ts +255 -0
  158. package/src/providers/index.ts +7 -0
  159. package/src/providers/ip-data.ts +91 -0
  160. package/src/providers/storage.ts +23 -0
  161. package/src/storage/browser.ts +71 -0
  162. package/src/{sentry → storage}/index.ts +0 -1
  163. package/src/storage/node.test.ts +129 -0
  164. package/src/{helpers/node-observability.ts → storage/node.ts} +41 -70
  165. package/src/vite-import-meta.d.ts +14 -0
  166. package/dist/lib/browser/chunk-33TCMAUB.mjs +0 -996
  167. package/dist/lib/browser/chunk-33TCMAUB.mjs.map +0 -7
  168. package/dist/lib/browser/chunk-5OQYI27L.mjs +0 -1
  169. package/dist/lib/browser/chunk-MWTIKIBZ.mjs +0 -147
  170. package/dist/lib/browser/chunk-MWTIKIBZ.mjs.map +0 -7
  171. package/dist/lib/browser/chunk-YEPQFAES.mjs +0 -164
  172. package/dist/lib/browser/chunk-YEPQFAES.mjs.map +0 -7
  173. package/dist/lib/browser/observability-EEM6BEY6.mjs +0 -10
  174. package/dist/lib/browser/otel-IRDZ7PES.mjs +0 -277
  175. package/dist/lib/browser/otel-IRDZ7PES.mjs.map +0 -7
  176. package/dist/lib/browser/segment/index.mjs +0 -11
  177. package/dist/lib/browser/segment/index.mjs.map +0 -7
  178. package/dist/lib/browser/sentry/index.mjs +0 -24
  179. package/dist/lib/browser/sentry/index.mjs.map +0 -7
  180. package/dist/lib/browser/sentry-log-processor-3F3SBJXM.mjs +0 -146
  181. package/dist/lib/browser/sentry-log-processor-3F3SBJXM.mjs.map +0 -7
  182. package/dist/lib/node-esm/chunk-552KLA6Z.mjs +0 -202
  183. package/dist/lib/node-esm/chunk-552KLA6Z.mjs.map +0 -7
  184. package/dist/lib/node-esm/chunk-EYW4X3O6.mjs +0 -997
  185. package/dist/lib/node-esm/chunk-EYW4X3O6.mjs.map +0 -7
  186. package/dist/lib/node-esm/chunk-MRAK2H7O.mjs +0 -2
  187. package/dist/lib/node-esm/chunk-MRAK2H7O.mjs.map +0 -7
  188. package/dist/lib/node-esm/chunk-TEH6VIKV.mjs +0 -135
  189. package/dist/lib/node-esm/chunk-TEH6VIKV.mjs.map +0 -7
  190. package/dist/lib/node-esm/observability-DAXZGOBS.mjs +0 -11
  191. package/dist/lib/node-esm/observability-DAXZGOBS.mjs.map +0 -7
  192. package/dist/lib/node-esm/otel-62HYJETM.mjs +0 -260
  193. package/dist/lib/node-esm/otel-62HYJETM.mjs.map +0 -7
  194. package/dist/lib/node-esm/segment/index.mjs +0 -12
  195. package/dist/lib/node-esm/segment/index.mjs.map +0 -7
  196. package/dist/lib/node-esm/sentry/index.mjs +0 -25
  197. package/dist/lib/node-esm/sentry/index.mjs.map +0 -7
  198. package/dist/lib/node-esm/sentry-log-processor-JAYRA23C.mjs +0 -147
  199. package/dist/lib/node-esm/sentry-log-processor-JAYRA23C.mjs.map +0 -7
  200. package/dist/types/src/helpers/browser-observability.d.ts +0 -17
  201. package/dist/types/src/helpers/browser-observability.d.ts.map +0 -1
  202. package/dist/types/src/helpers/browser-observability.js +0 -140
  203. package/dist/types/src/helpers/browser-observability.js.map +0 -1
  204. package/dist/types/src/helpers/common.d.ts +0 -12
  205. package/dist/types/src/helpers/common.d.ts.map +0 -1
  206. package/dist/types/src/helpers/common.js +0 -23
  207. package/dist/types/src/helpers/common.js.map +0 -1
  208. package/dist/types/src/helpers/index.d.ts +0 -6
  209. package/dist/types/src/helpers/index.d.ts.map +0 -1
  210. package/dist/types/src/helpers/index.js +0 -9
  211. package/dist/types/src/helpers/index.js.map +0 -1
  212. package/dist/types/src/helpers/map-spaces.d.ts +0 -18
  213. package/dist/types/src/helpers/map-spaces.d.ts.map +0 -1
  214. package/dist/types/src/helpers/map-spaces.js +0 -37
  215. package/dist/types/src/helpers/map-spaces.js.map +0 -1
  216. package/dist/types/src/helpers/node-observability.d.ts +0 -24
  217. package/dist/types/src/helpers/node-observability.d.ts.map +0 -1
  218. package/dist/types/src/helpers/node-observability.js +0 -101
  219. package/dist/types/src/helpers/node-observability.js.map +0 -1
  220. package/dist/types/src/helpers/setup-telemetry-listeners.d.ts +0 -4
  221. package/dist/types/src/helpers/setup-telemetry-listeners.d.ts.map +0 -1
  222. package/dist/types/src/helpers/setup-telemetry-listeners.js +0 -97
  223. package/dist/types/src/helpers/setup-telemetry-listeners.js.map +0 -1
  224. package/dist/types/src/otel/index.d.ts +0 -5
  225. package/dist/types/src/otel/index.d.ts.map +0 -1
  226. package/dist/types/src/otel/index.js +0 -8
  227. package/dist/types/src/otel/index.js.map +0 -1
  228. package/dist/types/src/otel/logs.d.ts.map +0 -1
  229. package/dist/types/src/otel/logs.js +0 -71
  230. package/dist/types/src/otel/logs.js.map +0 -1
  231. package/dist/types/src/otel/metrics.d.ts.map +0 -1
  232. package/dist/types/src/otel/metrics.js.map +0 -1
  233. package/dist/types/src/otel/otel.d.ts +0 -12
  234. package/dist/types/src/otel/otel.d.ts.map +0 -1
  235. package/dist/types/src/otel/otel.js +0 -11
  236. package/dist/types/src/otel/otel.js.map +0 -1
  237. package/dist/types/src/otel/traces-browser.d.ts +0 -8
  238. package/dist/types/src/otel/traces-browser.d.ts.map +0 -1
  239. package/dist/types/src/otel/traces-browser.js +0 -47
  240. package/dist/types/src/otel/traces-browser.js.map +0 -1
  241. package/dist/types/src/otel/traces.d.ts +0 -8
  242. package/dist/types/src/otel/traces.d.ts.map +0 -1
  243. package/dist/types/src/otel/traces.js +0 -40
  244. package/dist/types/src/otel/traces.js.map +0 -1
  245. package/dist/types/src/segment/base.d.ts +0 -15
  246. package/dist/types/src/segment/base.d.ts.map +0 -1
  247. package/dist/types/src/segment/base.js +0 -50
  248. package/dist/types/src/segment/base.js.map +0 -1
  249. package/dist/types/src/segment/browser.d.ts +0 -15
  250. package/dist/types/src/segment/browser.d.ts.map +0 -1
  251. package/dist/types/src/segment/browser.js +0 -67
  252. package/dist/types/src/segment/browser.js.map +0 -1
  253. package/dist/types/src/segment/index.d.ts +0 -3
  254. package/dist/types/src/segment/index.d.ts.map +0 -1
  255. package/dist/types/src/segment/index.js +0 -6
  256. package/dist/types/src/segment/index.js.map +0 -1
  257. package/dist/types/src/segment/node.d.ts +0 -16
  258. package/dist/types/src/segment/node.d.ts.map +0 -1
  259. package/dist/types/src/segment/node.js +0 -83
  260. package/dist/types/src/segment/node.js.map +0 -1
  261. package/dist/types/src/segment/types.d.ts +0 -52
  262. package/dist/types/src/segment/types.d.ts.map +0 -1
  263. package/dist/types/src/segment/types.js +0 -18
  264. package/dist/types/src/segment/types.js.map +0 -1
  265. package/dist/types/src/sentry/browser.d.ts +0 -32
  266. package/dist/types/src/sentry/browser.d.ts.map +0 -1
  267. package/dist/types/src/sentry/browser.js +0 -112
  268. package/dist/types/src/sentry/browser.js.map +0 -1
  269. package/dist/types/src/sentry/index.d.ts +0 -3
  270. package/dist/types/src/sentry/index.d.ts.map +0 -1
  271. package/dist/types/src/sentry/index.js +0 -6
  272. package/dist/types/src/sentry/index.js.map +0 -1
  273. package/dist/types/src/sentry/node.d.ts +0 -32
  274. package/dist/types/src/sentry/node.d.ts.map +0 -1
  275. package/dist/types/src/sentry/node.js +0 -111
  276. package/dist/types/src/sentry/node.js.map +0 -1
  277. package/dist/types/src/sentry/node.node.test.d.ts +0 -2
  278. package/dist/types/src/sentry/node.node.test.d.ts.map +0 -1
  279. package/dist/types/src/sentry/node.node.test.js +0 -34
  280. package/dist/types/src/sentry/node.node.test.js.map +0 -1
  281. package/dist/types/src/sentry/sentry-log-processor.d.ts +0 -9
  282. package/dist/types/src/sentry/sentry-log-processor.d.ts.map +0 -1
  283. package/dist/types/src/sentry/sentry-log-processor.js +0 -149
  284. package/dist/types/src/sentry/sentry-log-processor.js.map +0 -1
  285. package/dist/types/src/sentry/sentry.node.test.d.ts +0 -2
  286. package/dist/types/src/sentry/sentry.node.test.d.ts.map +0 -1
  287. package/dist/types/src/sentry/sentry.node.test.js +0 -28
  288. package/dist/types/src/sentry/sentry.node.test.js.map +0 -1
  289. package/dist/types/src/sentry/types.d.ts +0 -18
  290. package/dist/types/src/sentry/types.d.ts.map +0 -1
  291. package/dist/types/src/sentry/types.js +0 -4
  292. package/dist/types/src/sentry/types.js.map +0 -1
  293. package/dist/types/src/testing/index.d.ts +0 -2
  294. package/dist/types/src/testing/index.d.ts.map +0 -1
  295. package/dist/types/src/testing/index.js +0 -5
  296. package/dist/types/src/testing/index.js.map +0 -1
  297. package/dist/types/src/testing/testkit/browser.d.ts +0 -2
  298. package/dist/types/src/testing/testkit/browser.d.ts.map +0 -1
  299. package/dist/types/src/testing/testkit/browser.js +0 -7
  300. package/dist/types/src/testing/testkit/browser.js.map +0 -1
  301. package/dist/types/src/testing/testkit/index.d.ts +0 -2
  302. package/dist/types/src/testing/testkit/index.d.ts.map +0 -1
  303. package/dist/types/src/testing/testkit/index.js +0 -6
  304. package/dist/types/src/testing/testkit/index.js.map +0 -1
  305. package/src/helpers/browser-observability.ts +0 -177
  306. package/src/helpers/common.ts +0 -38
  307. package/src/helpers/index.ts +0 -9
  308. package/src/helpers/map-spaces.ts +0 -48
  309. package/src/helpers/setup-telemetry-listeners.ts +0 -108
  310. package/src/otel/index.ts +0 -8
  311. package/src/otel/logs.ts +0 -100
  312. package/src/otel/otel.ts +0 -21
  313. package/src/otel/traces-browser.ts +0 -59
  314. package/src/otel/traces.ts +0 -57
  315. package/src/segment/base.ts +0 -69
  316. package/src/segment/browser.ts +0 -68
  317. package/src/segment/node.ts +0 -94
  318. package/src/segment/types.ts +0 -57
  319. package/src/sentry/browser.ts +0 -133
  320. package/src/sentry/node.node.test.ts +0 -39
  321. package/src/sentry/node.ts +0 -126
  322. package/src/sentry/sentry-log-processor.ts +0 -166
  323. package/src/sentry/sentry.node.test.ts +0 -34
  324. package/src/sentry/types.ts +0 -22
  325. package/src/testing/index.ts +0 -5
  326. package/src/testing/testkit/browser.ts +0 -8
  327. package/src/testing/testkit/index.ts +0 -7
  328. package/src/testing/testkit/shims.d.ts +0 -5
  329. /package/dist/lib/browser/{chunk-5OQYI27L.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
  330. /package/dist/lib/{browser/observability-EEM6BEY6.mjs.map → node-esm/chunk-HSLMI22Q.mjs.map} +0 -0
@@ -1,101 +0,0 @@
1
- //
2
- // Copyright 2022 DXOS.org
3
- //
4
- import yaml from 'js-yaml';
5
- import { existsSync, statSync } from 'node:fs';
6
- import { mkdir, readFile, writeFile } from 'node:fs/promises';
7
- import { join } from 'node:path';
8
- import { v4 as uuid, validate as validateUuid } from 'uuid';
9
- import { log } from '@dxos/log';
10
- import { Observability } from '../observability';
11
- /**
12
- * Print observability banner once per installation.
13
- */
14
- export const showObservabilityBanner = async (configDir, bannercb) => {
15
- const path = join(configDir, '.observability-banner-printed');
16
- if (existsSync(path)) {
17
- return;
18
- }
19
- bannercb(
20
- // eslint-disable-next-line no-multi-str
21
- 'Basic observability data will be sent to the DXOS team in order to improve the product. This includes \
22
- performance metrics, error logs, and usage data. No personally identifiable information, other than your \
23
- public key, is included with this data and no private data ever leaves your devices. To disable sending \
24
- observability data, set the environment variable DX_DISABLE_OBSERVABILITY=true.');
25
- await writeFile(path, '', 'utf-8');
26
- };
27
- export const getObservabilityState = async (configDir) => {
28
- // check whether configDir exists and if it's a directory
29
- var _a;
30
- if (existsSync(configDir)) {
31
- if (!statSync(configDir).isDirectory()) {
32
- throw new Error(`Config directory ${configDir} exists but is not a directory`);
33
- }
34
- }
35
- else {
36
- await mkdir(configDir, { recursive: true });
37
- }
38
- const idPath = join(configDir, 'observability.yml');
39
- if (existsSync(idPath)) {
40
- const context = await readFile(idPath, 'utf-8');
41
- return (_a = validate(context)) !== null && _a !== void 0 ? _a : initializeState(idPath);
42
- }
43
- return initializeState(idPath);
44
- };
45
- // create initial state and write to file, using environment variables to override defaults.
46
- const initializeState = async (idPath) => {
47
- var _a, _b;
48
- // TODO(nf): read initial values from config or seed file
49
- const observabilityState = {
50
- installationId: uuid(),
51
- group: (_a = process.env.DX_OBSERVABILITY_GROUP) !== null && _a !== void 0 ? _a : undefined,
52
- mode: (process.env.DX_DISABLE_OBSERVABILITY ? 'disabled' : (_b = process.env.DX_OBSERVABILITY_MODE) !== null && _b !== void 0 ? _b : 'basic'),
53
- };
54
- await writeFile(idPath, '# This file is automatically generated by the @dxos/cli.\n' + yaml.dump(observabilityState), 'utf-8');
55
- return observabilityState;
56
- };
57
- const validate = (contextString) => {
58
- var _a;
59
- const context = yaml.load(contextString);
60
- if (Boolean(context.installationId) && validateUuid(context.installationId)) {
61
- return {
62
- ...context,
63
- mode: process.env.DX_DISABLE_OBSERVABILITY ? 'disabled' : (_a = context.mode) !== null && _a !== void 0 ? _a : 'basic',
64
- };
65
- }
66
- };
67
- export const initializeNodeObservability = async ({ namespace, version, config, installationId, group, mode = 'basic', tracingEnable = true, replayEnable = true, }) => {
68
- var _a;
69
- log('initializeCliObservability', { config });
70
- // TODO(nf): make CLI build populate runtime.app.build config?
71
- const release = `${namespace}@${version}`;
72
- const environment = (_a = process.env.DX_ENVIRONMENT) !== null && _a !== void 0 ? _a : 'unknown';
73
- const observability = new Observability({
74
- mode,
75
- namespace,
76
- release,
77
- environment,
78
- group,
79
- errorLog: {
80
- sentryInitOptions: {
81
- environment,
82
- release,
83
- // TODO(wittjosiah): Configure this.
84
- sampleRate: 1.0,
85
- },
86
- },
87
- });
88
- observability.setTag('installationId', installationId);
89
- // TODO(nf): cache ipdata to avoid repeated requests
90
- const IPDATA_API_KEY = config.get('runtime.app.env.DX_IPDATA_API_KEY');
91
- try {
92
- const res = await fetch(`https://api.ipdata.co/?api-key=${IPDATA_API_KEY}`);
93
- const ipData = await res.json();
94
- ipData && observability.setIPDataTelemetryTags(ipData);
95
- }
96
- catch (err) {
97
- observability === null || observability === void 0 ? void 0 : observability.captureException(err);
98
- }
99
- return observability;
100
- };
101
- //# sourceMappingURL=node-observability.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"node-observability.js","sourceRoot":"","sources":["../../../../src/helpers/node-observability.ts"],"names":[],"mappings":"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"}
@@ -1,4 +0,0 @@
1
- import type { Client } from '@dxos/client';
2
- import { type Observability } from '../observability';
3
- export declare const setupTelemetryListeners: (namespace: string, client: Client, observability: Observability) => () => void;
4
- //# sourceMappingURL=setup-telemetry-listeners.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"setup-telemetry-listeners.d.ts","sourceRoot":"","sources":["../../../../src/helpers/setup-telemetry-listeners.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,cAAc,CAAC;AAG3C,OAAO,EAAE,KAAK,aAAa,EAAE,MAAM,kBAAkB,CAAC;AAKtD,eAAO,MAAM,uBAAuB,GAAI,WAAW,MAAM,EAAE,QAAQ,MAAM,EAAE,eAAe,aAAa,eA+FtG,CAAC"}
@@ -1,97 +0,0 @@
1
- //
2
- // Copyright 2022 DXOS.org
3
- //
4
- import { getTelemetryIdentity } from './common';
5
- let lastFocusEvent = new Date();
6
- let totalTime = 0;
7
- export const setupTelemetryListeners = (namespace, client, observability) => {
8
- const clickCallback = (event) => {
9
- var _a;
10
- const id = (_a = event.target) === null || _a === void 0 ? void 0 : _a.id;
11
- if (!id) {
12
- return;
13
- }
14
- setTimeout(() => {
15
- var _a;
16
- observability.track({
17
- ...getTelemetryIdentity(client),
18
- action: 'window.click',
19
- properties: {
20
- id: (_a = event.target) === null || _a === void 0 ? void 0 : _a.id,
21
- path: event.composedPath()
22
- .filter((el) => Boolean(el.tagName))
23
- .map((el) => `${el.tagName.toLowerCase()}${el.id ? `#${el.id}` : ''}`)
24
- .reverse()
25
- .join('>'),
26
- },
27
- });
28
- });
29
- };
30
- const focusCallback = () => {
31
- const now = new Date();
32
- setTimeout(() => {
33
- observability.track({
34
- ...getTelemetryIdentity(client),
35
- action: 'window.focus',
36
- properties: {
37
- timeAway: now.getTime() - lastFocusEvent.getTime(),
38
- },
39
- });
40
- });
41
- lastFocusEvent = now;
42
- };
43
- const blurCallback = () => {
44
- const now = new Date();
45
- const duration = now.getTime() - lastFocusEvent.getTime();
46
- setTimeout(() => {
47
- observability.track({
48
- ...getTelemetryIdentity(client),
49
- action: 'window.blur',
50
- properties: {
51
- duration,
52
- },
53
- });
54
- });
55
- lastFocusEvent = now;
56
- totalTime = totalTime + duration;
57
- };
58
- const unloadCallback = () => {
59
- setTimeout(() => {
60
- observability.track({
61
- ...getTelemetryIdentity(client),
62
- action: 'page.unload',
63
- properties: {
64
- duration: totalTime,
65
- },
66
- });
67
- });
68
- };
69
- const errorCallback = (event) => {
70
- setTimeout(() => {
71
- var _a, _b;
72
- observability.track({
73
- ...getTelemetryIdentity(client),
74
- action: 'window.error',
75
- properties: {
76
- message: event.message,
77
- filename: event.filename,
78
- stack: (_a = event.error) === null || _a === void 0 ? void 0 : _a.stack,
79
- cause: (_b = event.error) === null || _b === void 0 ? void 0 : _b.cause,
80
- },
81
- });
82
- });
83
- };
84
- window.addEventListener('click', clickCallback, true);
85
- window.addEventListener('focus', focusCallback);
86
- window.addEventListener('blur', blurCallback);
87
- window.addEventListener('beforeunload', unloadCallback);
88
- window.addEventListener('error', errorCallback);
89
- return () => {
90
- window.removeEventListener('click', clickCallback, true);
91
- window.removeEventListener('focus', focusCallback);
92
- window.removeEventListener('blur', blurCallback);
93
- window.removeEventListener('beforeunload', unloadCallback);
94
- window.removeEventListener('error', errorCallback);
95
- };
96
- };
97
- //# sourceMappingURL=setup-telemetry-listeners.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"setup-telemetry-listeners.js","sourceRoot":"","sources":["../../../../src/helpers/setup-telemetry-listeners.ts"],"names":[],"mappings":"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"}
@@ -1,5 +0,0 @@
1
- export * from './otel';
2
- export * from './logs';
3
- export * from './metrics';
4
- export * from './traces';
5
- //# sourceMappingURL=index.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/otel/index.ts"],"names":[],"mappings":"AAIA,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC"}
@@ -1,8 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
- export * from './otel';
5
- export * from './logs';
6
- export * from './metrics';
7
- export * from './traces';
8
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/otel/index.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,cAAc,QAAQ,CAAC;AACvB,cAAc,QAAQ,CAAC;AACvB,cAAc,WAAW,CAAC;AAC1B,cAAc,UAAU,CAAC"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../../src/otel/logs.ts"],"names":[],"mappings":"AAUA,OAAO,EAKL,QAAQ,EACR,KAAK,YAAY,EAClB,MAAM,WAAW,CAAC;AAGnB,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,QAAQ,CAAC;AAEzD,MAAM,MAAM,cAAc,GAAG,WAAW,GAAG;IACzC,QAAQ,EAAE,QAAQ,CAAC;IACnB;;;OAGG;IACH,uBAAuB,EAAE,OAAO,CAAC;CAClC,CAAC;AAEF,qBAAa,QAAQ;IAEP,OAAO,CAAC,QAAQ,CAAC,OAAO;IADpC,OAAO,CAAC,eAAe,CAAiB;gBACX,OAAO,EAAE,cAAc;IAmBpD,SAAgB,YAAY,EAAE,YAAY,CAqBxC;IAEF,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAItB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGvB"}
@@ -1,71 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
- import { SeverityNumber } from '@opentelemetry/api-logs';
5
- import { OTLPLogExporter } from '@opentelemetry/exporter-logs-otlp-http';
6
- import { Resource } from '@opentelemetry/resources';
7
- import { BatchLogRecordProcessor, LoggerProvider } from '@opentelemetry/sdk-logs';
8
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
9
- import { getContextFromEntry, getRelativeFilename, LogLevel, } from '@dxos/log';
10
- import { jsonlogify } from '@dxos/util';
11
- import { setDiagLogger } from './otel';
12
- export class OtelLogs {
13
- constructor(options) {
14
- this.options = options;
15
- this.logProcessor = (config, entry) => {
16
- var _a, _b;
17
- const logger = this._loggerProvider.getLogger('dxos-observability', this.options.serviceVersion);
18
- if (entry.level < this.options.logLevel ||
19
- (!this.options.includeSharedWorkerLogs && ((_b = (_a = entry.meta) === null || _a === void 0 ? void 0 : _a.S) === null || _b === void 0 ? void 0 : _b.remoteSessionId))) {
20
- return;
21
- }
22
- const record = {
23
- ...entry,
24
- ...(entry.meta ? { meta: { file: getRelativeFilename(entry.meta.F), line: entry.meta.L } } : {}),
25
- context: jsonlogify(getContextFromEntry(entry)),
26
- };
27
- logger.emit({
28
- severityNumber: convertLevel(entry.level),
29
- body: JSON.stringify(record),
30
- attributes: this.options.getTags(),
31
- });
32
- };
33
- setDiagLogger(options.consoleDiagLogLevel);
34
- const resource = Resource.default().merge(new Resource({
35
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
36
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
37
- }));
38
- const logExporter = new OTLPLogExporter({
39
- url: this.options.endpoint + '/v1/logs',
40
- headers: {
41
- Authorization: this.options.authorizationHeader,
42
- },
43
- concurrencyLimit: 10, // an optional limit on pending requests
44
- });
45
- this._loggerProvider = new LoggerProvider({ resource });
46
- this._loggerProvider.addLogRecordProcessor(new BatchLogRecordProcessor(logExporter));
47
- }
48
- flush() {
49
- return this._loggerProvider.forceFlush();
50
- }
51
- close() {
52
- return this._loggerProvider.shutdown();
53
- }
54
- }
55
- const convertLevel = (level) => {
56
- switch (level) {
57
- case LogLevel.DEBUG:
58
- return SeverityNumber.DEBUG;
59
- case LogLevel.VERBOSE:
60
- return SeverityNumber.INFO;
61
- case LogLevel.INFO:
62
- return SeverityNumber.INFO;
63
- case LogLevel.WARN:
64
- return SeverityNumber.WARN;
65
- case LogLevel.ERROR:
66
- return SeverityNumber.ERROR;
67
- default:
68
- return SeverityNumber.ERROR;
69
- }
70
- };
71
- //# sourceMappingURL=logs.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../../src/otel/logs.ts"],"names":[],"mappings":"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"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../../../src/otel/metrics.ts"],"names":[],"mappings":"AAaA,OAAO,EAAE,KAAK,WAAW,EAAiB,MAAM,QAAQ,CAAC;AAUzD,qBAAa,WAAW;IAKV,OAAO,CAAC,QAAQ,CAAC,OAAO;IAJpC,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,MAAM,CAAQ;IACtB,OAAO,CAAC,OAAO,CAAuC;gBAEzB,OAAO,EAAE,WAAW;IA8CjD,KAAK,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAMpD,SAAS,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAMzD,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,IAAI,CAAC,EAAE,GAAG,GAAG,IAAI;IAM3D,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAItB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAGvB"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"metrics.js","sourceRoot":"","sources":["../../../../src/otel/metrics.ts"],"names":[],"mappings":"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"}
@@ -1,12 +0,0 @@
1
- export type OtelOptions = {
2
- endpoint: string;
3
- authorizationHeader: string;
4
- serviceName: string;
5
- serviceVersion: string;
6
- getTags: () => {
7
- [key: string]: string;
8
- };
9
- consoleDiagLogLevel?: string;
10
- };
11
- export declare const setDiagLogger: (level?: string) => void;
12
- //# sourceMappingURL=otel.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"otel.d.ts","sourceRoot":"","sources":["../../../../src/otel/otel.ts"],"names":[],"mappings":"AAMA,MAAM,MAAM,WAAW,GAAG;IACxB,QAAQ,EAAE,MAAM,CAAC;IACjB,mBAAmB,EAAE,MAAM,CAAC;IAC5B,WAAW,EAAE,MAAM,CAAC;IACpB,cAAc,EAAE,MAAM,CAAC;IACvB,OAAO,EAAE,MAAM;QAAE,CAAC,GAAG,EAAE,MAAM,GAAG,MAAM,CAAA;KAAE,CAAC;IACzC,mBAAmB,CAAC,EAAE,MAAM,CAAC;CAC9B,CAAC;AAEF,eAAO,MAAM,aAAa,GAAI,QAAQ,MAAM,SAK3C,CAAC"}
@@ -1,11 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
- import { diag, DiagConsoleLogger, DiagLogLevel } from '@opentelemetry/api';
5
- export const setDiagLogger = (level) => {
6
- const logLevel = DiagLogLevel[level];
7
- if (logLevel) {
8
- diag.setLogger(new DiagConsoleLogger(), logLevel);
9
- }
10
- };
11
- //# sourceMappingURL=otel.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"otel.js","sourceRoot":"","sources":["../../../../src/otel/otel.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,OAAO,EAAE,IAAI,EAAE,iBAAiB,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAW3E,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,KAAc,EAAE,EAAE;IAC9C,MAAM,QAAQ,GAAG,YAAY,CAAC,KAAkC,CAAC,CAAC;IAClE,IAAI,QAAQ,EAAE,CAAC;QACb,IAAI,CAAC,SAAS,CAAC,IAAI,iBAAiB,EAAE,EAAE,QAAQ,CAAC,CAAC;IACpD,CAAC;AACH,CAAC,CAAC"}
@@ -1,8 +0,0 @@
1
- import { type OtelOptions } from './otel';
2
- export declare class OtelTraces {
3
- private readonly options;
4
- private _tracer;
5
- constructor(options: OtelOptions);
6
- start(): void;
7
- }
8
- //# sourceMappingURL=traces-browser.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"traces-browser.d.ts","sourceRoot":"","sources":["../../../../src/otel/traces-browser.ts"],"names":[],"mappings":"AAgBA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,QAAQ,CAAC;AAE1C,qBAAa,UAAU;IAET,OAAO,CAAC,QAAQ,CAAC,OAAO;IADpC,OAAO,CAAC,OAAO,CAAS;gBACK,OAAO,EAAE,WAAW;IA0B1C,KAAK,IAAI,IAAI;CAYrB"}
@@ -1,47 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
- import { trace } from '@opentelemetry/api';
5
- import { getWebAutoInstrumentations } from '@opentelemetry/auto-instrumentations-web';
6
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
7
- import { registerInstrumentations } from '@opentelemetry/instrumentation';
8
- import { Resource } from '@opentelemetry/resources';
9
- import { ConsoleSpanExporter, SimpleSpanProcessor, BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';
10
- import { WebTracerProvider } from '@opentelemetry/sdk-trace-web';
11
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
12
- import { log } from '@dxos/log';
13
- import { TRACE_PROCESSOR } from '@dxos/tracing';
14
- export class OtelTraces {
15
- constructor(options) {
16
- this.options = options;
17
- const resource = Resource.default().merge(new Resource({
18
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
19
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
20
- }));
21
- const tracerProvider = new WebTracerProvider({ resource });
22
- tracerProvider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));
23
- tracerProvider.addSpanProcessor(new BatchSpanProcessor(new OTLPTraceExporter({
24
- url: this.options.endpoint + '/v1/traces',
25
- headers: {
26
- Authorization: this.options.authorizationHeader,
27
- },
28
- concurrencyLimit: 10, // an optional limit on pending requests
29
- })));
30
- // TODO(nf): ContextManager? Propogator?
31
- tracerProvider.register({});
32
- this._tracer = trace.getTracer('dxos-observability', this.options.serviceVersion);
33
- }
34
- start() {
35
- registerInstrumentations({
36
- instrumentations: [getWebAutoInstrumentations()],
37
- });
38
- log('trace processor registered');
39
- TRACE_PROCESSOR.remoteTracing.registerProcessor({
40
- startSpan: (options) => {
41
- log('begin otel trace', { options });
42
- return this._tracer.startSpan(options.name, options);
43
- },
44
- });
45
- }
46
- }
47
- //# sourceMappingURL=traces-browser.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"traces-browser.js","sourceRoot":"","sources":["../../../../src/otel/traces-browser.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,OAAO,EAAE,KAAK,EAAe,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,0BAA0B,EAAE,MAAM,0CAA0C,CAAC;AACtF,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAC;AAC5E,OAAO,EAAE,wBAAwB,EAAE,MAAM,gCAAgC,CAAC;AAC1E,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EAAE,mBAAmB,EAAE,mBAAmB,EAAE,kBAAkB,EAAE,MAAM,+BAA+B,CAAC;AAC7G,OAAO,EAAE,iBAAiB,EAAE,MAAM,8BAA8B,CAAC;AACjE,OAAO,EAAE,wBAAwB,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAE5G,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAChC,OAAO,EAAE,eAAe,EAAyB,MAAM,eAAe,CAAC;AAIvE,MAAM,OAAO,UAAU;IAErB,YAA6B,OAAoB;QAApB,YAAO,GAAP,OAAO,CAAa;QAC/C,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC,KAAK,CACvC,IAAI,QAAQ,CAAC;YACX,CAAC,wBAAwB,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW;YACpD,CAAC,2BAA2B,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc;SAC3D,CAAC,CACH,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,iBAAiB,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC3D,cAAc,CAAC,gBAAgB,CAAC,IAAI,mBAAmB,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC,CAAC;QACpF,cAAc,CAAC,gBAAgB,CAC7B,IAAI,kBAAkB,CACpB,IAAI,iBAAiB,CAAC;YACpB,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,YAAY;YACzC,OAAO,EAAE;gBACP,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,mBAAmB;aAChD;YACD,gBAAgB,EAAE,EAAE,EAAE,wCAAwC;SAC/D,CAAC,CACH,CACF,CAAC;QACF,wCAAwC;QACxC,cAAc,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAC;QAC5B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,oBAAoB,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACpF,CAAC;IAEM,KAAK;QACV,wBAAwB,CAAC;YACvB,gBAAgB,EAAE,CAAC,0BAA0B,EAAE,CAAC;SACjD,CAAC,CAAC;QACH,GAAG,CAAC,4BAA4B,CAAC,CAAC;QAClC,eAAe,CAAC,aAAa,CAAC,iBAAiB,CAAC;YAC9C,SAAS,EAAE,CAAC,OAAyB,EAAE,EAAE;gBACvC,GAAG,CAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;gBACrC,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YACvD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;CACF"}
@@ -1,8 +0,0 @@
1
- import { type OtelOptions } from './otel';
2
- export declare class OtelTraces {
3
- private readonly options;
4
- private _tracer;
5
- constructor(options: OtelOptions);
6
- start(): void;
7
- }
8
- //# sourceMappingURL=traces.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"traces.d.ts","sourceRoot":"","sources":["../../../../src/otel/traces.ts"],"names":[],"mappings":"AAkBA,OAAO,EAAE,KAAK,WAAW,EAAE,MAAM,QAAQ,CAAC;AAE1C,qBAAa,UAAU;IAET,OAAO,CAAC,QAAQ,CAAC,OAAO;IADpC,OAAO,CAAC,OAAO,CAAS;gBACK,OAAO,EAAE,WAAW;IAyB1C,KAAK,IAAI,IAAI;CASrB"}
@@ -1,40 +0,0 @@
1
- //
2
- // Copyright 2024 DXOS.org
3
- //
4
- import { trace } from '@opentelemetry/api';
5
- import { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';
6
- import { Resource } from '@opentelemetry/resources';
7
- import { BasicTracerProvider, BatchSpanProcessor, ConsoleSpanExporter, SimpleSpanProcessor, } from '@opentelemetry/sdk-trace-base';
8
- import { SEMRESATTRS_SERVICE_NAME, SEMRESATTRS_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
9
- import { log } from 'debug';
10
- import { TRACE_PROCESSOR } from '@dxos/tracing';
11
- export class OtelTraces {
12
- constructor(options) {
13
- this.options = options;
14
- const resource = Resource.default().merge(new Resource({
15
- [SEMRESATTRS_SERVICE_NAME]: this.options.serviceName,
16
- [SEMRESATTRS_SERVICE_VERSION]: this.options.serviceVersion,
17
- }));
18
- const tracerProvider = new BasicTracerProvider({ resource });
19
- tracerProvider.addSpanProcessor(new SimpleSpanProcessor(new ConsoleSpanExporter()));
20
- tracerProvider.addSpanProcessor(new BatchSpanProcessor(new OTLPTraceExporter({
21
- url: this.options.endpoint + '/v1/traces',
22
- headers: {
23
- Authorization: this.options.authorizationHeader,
24
- },
25
- concurrencyLimit: 10, // an optional limit on pending requests
26
- })));
27
- tracerProvider.register();
28
- this._tracer = trace.getTracer('dxos-observability', this.options.serviceVersion);
29
- }
30
- start() {
31
- log('trace processor registered');
32
- TRACE_PROCESSOR.remoteTracing.registerProcessor({
33
- startSpan: (options) => {
34
- log('begin otel trace', { options });
35
- return this._tracer.startSpan(options.name, options);
36
- },
37
- });
38
- }
39
- }
40
- //# sourceMappingURL=traces.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"traces.js","sourceRoot":"","sources":["../../../../src/otel/traces.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,OAAO,EAAE,KAAK,EAAe,MAAM,oBAAoB,CAAC;AACxD,OAAO,EAAE,iBAAiB,EAAE,MAAM,yCAAyC,CAAC;AAC5E,OAAO,EAAE,QAAQ,EAAE,MAAM,0BAA0B,CAAC;AACpD,OAAO,EACL,mBAAmB,EACnB,kBAAkB,EAClB,mBAAmB,EACnB,mBAAmB,GACpB,MAAM,+BAA+B,CAAC;AACvC,OAAO,EAAE,wBAAwB,EAAE,2BAA2B,EAAE,MAAM,qCAAqC,CAAC;AAC5G,OAAO,EAAE,GAAG,EAAE,MAAM,OAAO,CAAC;AAE5B,OAAO,EAAE,eAAe,EAAyB,MAAM,eAAe,CAAC;AAIvE,MAAM,OAAO,UAAU;IAErB,YAA6B,OAAoB;QAApB,YAAO,GAAP,OAAO,CAAa;QAC/C,MAAM,QAAQ,GAAG,QAAQ,CAAC,OAAO,EAAE,CAAC,KAAK,CACvC,IAAI,QAAQ,CAAC;YACX,CAAC,wBAAwB,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,WAAW;YACpD,CAAC,2BAA2B,CAAC,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc;SAC3D,CAAC,CACH,CAAC;QAEF,MAAM,cAAc,GAAG,IAAI,mBAAmB,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC;QAC7D,cAAc,CAAC,gBAAgB,CAAC,IAAI,mBAAmB,CAAC,IAAI,mBAAmB,EAAE,CAAC,CAAC,CAAC;QACpF,cAAc,CAAC,gBAAgB,CAC7B,IAAI,kBAAkB,CACpB,IAAI,iBAAiB,CAAC;YACpB,GAAG,EAAE,IAAI,CAAC,OAAO,CAAC,QAAQ,GAAG,YAAY;YACzC,OAAO,EAAE;gBACP,aAAa,EAAE,IAAI,CAAC,OAAO,CAAC,mBAAmB;aAChD;YACD,gBAAgB,EAAE,EAAE,EAAE,wCAAwC;SAC/D,CAAC,CACH,CACF,CAAC;QACF,cAAc,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC,SAAS,CAAC,oBAAoB,EAAE,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,CAAC;IACpF,CAAC;IAEM,KAAK;QACV,GAAG,CAAC,4BAA4B,CAAC,CAAC;QAClC,eAAe,CAAC,aAAa,CAAC,iBAAiB,CAAC;YAC9C,SAAS,EAAE,CAAC,OAAyB,EAAE,EAAE;gBACvC,GAAG,CAAC,kBAAkB,EAAE,EAAE,OAAO,EAAE,CAAC,CAAC;gBACrC,OAAO,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC;YACvD,CAAC;SACF,CAAC,CAAC;IACL,CAAC;CACF"}
@@ -1,15 +0,0 @@
1
- import { type TrackParams, type PageParams, type IdentifyParams } from '@segment/analytics-node';
2
- import { type PageOptions, type Tags, type TrackOptions } from './types';
3
- /**
4
- * Base class for Node and BrowserSegment telemetry.
5
- */
6
- export declare abstract class AbstractSegmentTelemetry {
7
- private readonly _getTags;
8
- constructor(_getTags: () => Tags);
9
- abstract identify(options: IdentifyParams): void;
10
- abstract page(options: PageOptions): void;
11
- abstract track(options: TrackOptions): void;
12
- protected createPageProps(options: PageOptions): PageParams;
13
- protected createTrackProps(options: TrackOptions): TrackParams;
14
- }
15
- //# sourceMappingURL=base.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"base.d.ts","sourceRoot":"","sources":["../../../../src/segment/base.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,WAAW,EAAE,KAAK,UAAU,EAAE,KAAK,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAIjG,OAAO,EAEL,KAAK,WAAW,EAEhB,KAAK,IAAI,EAET,KAAK,YAAY,EAClB,MAAM,SAAS,CAAC;AAgBjB;;GAEG;AACH,8BAAsB,wBAAwB;IAChC,OAAO,CAAC,QAAQ,CAAC,QAAQ;gBAAR,QAAQ,EAAE,MAAM,IAAI;IAEjD,QAAQ,CAAC,QAAQ,CAAC,OAAO,EAAE,cAAc,GAAG,IAAI;IAEhD,QAAQ,CAAC,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI;IAEzC,QAAQ,CAAC,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAE3C,SAAS,CAAC,eAAe,CAAC,OAAO,EAAE,WAAW,GAAG,UAAU;IAY3D,SAAS,CAAC,gBAAgB,CAAC,OAAO,EAAE,YAAY,GAAG,WAAW;CAa/D"}
@@ -1,50 +0,0 @@
1
- //
2
- // Copyright 2025 DXOS.org
3
- //
4
- import { log } from '@dxos/log';
5
- import { TelemetryEvent, } from './types';
6
- /**
7
- * NOTE: Segment provides a default ID if we don't provide one.
8
- */
9
- const getIdentityOptions = ({ did, installationId }) => {
10
- if (!did && !installationId) {
11
- log.warn('No telemetry identifier provided.');
12
- }
13
- return {
14
- userId: did,
15
- anonymousId: installationId,
16
- };
17
- };
18
- /**
19
- * Base class for Node and BrowserSegment telemetry.
20
- */
21
- export class AbstractSegmentTelemetry {
22
- constructor(_getTags) {
23
- this._getTags = _getTags;
24
- }
25
- createPageProps(options) {
26
- const { properties, ...rest } = options;
27
- return {
28
- ...getIdentityOptions(options),
29
- ...rest,
30
- properties: {
31
- common: this._getTags(),
32
- custom: properties,
33
- },
34
- };
35
- }
36
- createTrackProps(options) {
37
- const { event, action, properties, ...rest } = options;
38
- return {
39
- ...getIdentityOptions(options),
40
- ...rest,
41
- event: event !== null && event !== void 0 ? event : TelemetryEvent.ACTION,
42
- properties: {
43
- action,
44
- common: this._getTags(),
45
- custom: properties,
46
- },
47
- };
48
- }
49
- }
50
- //# sourceMappingURL=base.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"base.js","sourceRoot":"","sources":["../../../../src/segment/base.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAIF,OAAO,EAAE,GAAG,EAAE,MAAM,WAAW,CAAC;AAEhC,OAAO,EAKL,cAAc,GAEf,MAAM,SAAS,CAAC;AAEjB;;GAEG;AACH,MAAM,kBAAkB,GAAG,CAAC,EAAE,GAAG,EAAE,cAAc,EAAmB,EAA0B,EAAE;IAC9F,IAAI,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,CAAC;QAC5B,GAAG,CAAC,IAAI,CAAC,mCAAmC,CAAC,CAAC;IAChD,CAAC;IAED,OAAO;QACL,MAAM,EAAE,GAAG;QACX,WAAW,EAAE,cAAc;KACF,CAAC;AAC9B,CAAC,CAAC;AAEF;;GAEG;AACH,MAAM,OAAgB,wBAAwB;IAC5C,YAA6B,QAAoB;QAApB,aAAQ,GAAR,QAAQ,CAAY;IAAG,CAAC;IAQ3C,eAAe,CAAC,OAAoB;QAC5C,MAAM,EAAE,UAAU,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,CAAC;QACxC,OAAO;YACL,GAAG,kBAAkB,CAAC,OAAO,CAAC;YAC9B,GAAG,IAAI;YACP,UAAU,EAAE;gBACV,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE;gBACvB,MAAM,EAAE,UAAU;aACnB;SACF,CAAC;IACJ,CAAC;IAES,gBAAgB,CAAC,OAAqB;QAC9C,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,UAAU,EAAE,GAAG,IAAI,EAAE,GAAG,OAAO,CAAC;QACvD,OAAO;YACL,GAAG,kBAAkB,CAAC,OAAO,CAAC;YAC9B,GAAG,IAAI;YACP,KAAK,EAAE,KAAK,aAAL,KAAK,cAAL,KAAK,GAAI,cAAc,CAAC,MAAM;YACrC,UAAU,EAAE;gBACV,MAAM;gBACN,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE;gBACvB,MAAM,EAAE,UAAU;aACnB;SACF,CAAC;IACJ,CAAC;CACF"}
@@ -1,15 +0,0 @@
1
- import { type IdentifyParams } from '@segment/analytics-node';
2
- import { AbstractSegmentTelemetry } from './base';
3
- import type { TrackOptions, SegmentTelemetryOptions, PageOptions } from './types';
4
- /**
5
- * Browser telemetry.
6
- */
7
- export declare class SegmentTelemetry extends AbstractSegmentTelemetry {
8
- constructor({ apiKey, batchSize, getTags }: SegmentTelemetryOptions);
9
- identify(options: IdentifyParams): void;
10
- page(options: PageOptions): void;
11
- track(options: TrackOptions): void;
12
- flush(): Promise<void>;
13
- close(): Promise<void>;
14
- }
15
- //# sourceMappingURL=browser.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"browser.d.ts","sourceRoot":"","sources":["../../../../src/segment/browser.ts"],"names":[],"mappings":"AAIA,OAAO,EAAE,KAAK,cAAc,EAAE,MAAM,yBAAyB,CAAC;AAK9D,OAAO,EAAE,wBAAwB,EAAE,MAAM,QAAQ,CAAC;AAClD,OAAO,KAAK,EAAE,YAAY,EAAE,uBAAuB,EAAE,WAAW,EAAE,MAAM,SAAS,CAAC;AAGlF;;GAEG;AAEH,qBAAa,gBAAiB,SAAQ,wBAAwB;gBAChD,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,EAAE,EAAE,uBAAuB;IAYnE,QAAQ,CAAC,OAAO,EAAE,cAAc,GAAG,IAAI;IAQvC,IAAI,CAAC,OAAO,EAAE,WAAW,GAAG,IAAI;IAShC,KAAK,CAAC,OAAO,EAAE,YAAY,GAAG,IAAI;IAS5B,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;IAUtB,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC;CAC7B"}