@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
@@ -0,0 +1,117 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ resolveOtlpUrl,
4
+ setDiagLogger
5
+ } from "./chunk-EDDZWPYV.mjs";
6
+ import "./chunk-HSLMI22Q.mjs";
7
+
8
+ // src/extensions/otel/metrics.ts
9
+ import { OTLPMetricExporter } from "@opentelemetry/exporter-metrics-otlp-http";
10
+ import { MeterProvider, PeriodicExportingMetricReader } from "@opentelemetry/sdk-metrics";
11
+ import { log } from "@dxos/log";
12
+ import { TRACE_PROCESSOR } from "@dxos/tracing";
13
+ var __dxlog_file = "/__w/dxos/dxos/packages/sdk/observability/src/extensions/otel/metrics.ts";
14
+ var EXPORT_INTERVAL = 60 * 1e3;
15
+ var OtelMetrics = class {
16
+ options;
17
+ _meterProvider;
18
+ _meter;
19
+ constructor(options) {
20
+ this.options = options;
21
+ setDiagLogger(options.consoleDiagLogLevel);
22
+ const grafanaMetricReader = new PeriodicExportingMetricReader({
23
+ exporter: new OTLPMetricExporter({
24
+ url: resolveOtlpUrl(this.options.endpoint + "/v1/metrics"),
25
+ headers: this.options.headers
26
+ }),
27
+ exportIntervalMillis: EXPORT_INTERVAL
28
+ });
29
+ this._meterProvider = new MeterProvider({
30
+ resource: this.options.resource,
31
+ readers: [
32
+ grafanaMetricReader
33
+ ]
34
+ });
35
+ this._meter = this._meterProvider.getMeter("dxos-observability");
36
+ const metrics = {
37
+ // TODO: update metrics names and remove prefix?
38
+ increment: (name, value, data) => {
39
+ this.increment(name, value, convertTags(data));
40
+ },
41
+ distribution: (name, value, data) => {
42
+ this.distribution(name, value, convertTags(data));
43
+ },
44
+ set: (name, value, data) => {
45
+ },
46
+ gauge: (name, value, data) => {
47
+ this.gauge(name, value, convertTags(data));
48
+ }
49
+ };
50
+ TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);
51
+ }
52
+ gauge(name, value, tags) {
53
+ const gauge = this._meter.createGauge(name);
54
+ log("otel gauge", {
55
+ name,
56
+ value,
57
+ tags: {
58
+ ...this.options.getTags(),
59
+ ...tags
60
+ }
61
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 52, S: this });
62
+ gauge.record(value, {
63
+ ...this.options.getTags(),
64
+ ...tags
65
+ });
66
+ }
67
+ increment(name, value, tags) {
68
+ const counter = this._meter.createCounter(name);
69
+ log("otel counter", {
70
+ name,
71
+ value,
72
+ tags: {
73
+ ...this.options.getTags(),
74
+ ...tags
75
+ }
76
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 67, S: this });
77
+ counter.add(value ?? 1, {
78
+ ...this.options.getTags(),
79
+ ...tags
80
+ });
81
+ }
82
+ distribution(name, value, tags) {
83
+ const distribution = this._meter.createHistogram(name);
84
+ log("otel distribution", {
85
+ name,
86
+ value,
87
+ tags: {
88
+ ...this.options.getTags(),
89
+ ...tags
90
+ }
91
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 82, S: this });
92
+ distribution.record(value, {
93
+ ...this.options.getTags(),
94
+ ...tags
95
+ });
96
+ }
97
+ flush() {
98
+ return this._meterProvider.forceFlush();
99
+ }
100
+ close() {
101
+ return this._meterProvider.shutdown();
102
+ }
103
+ };
104
+ var convertTags = (data) => {
105
+ if (data && data.tags) {
106
+ return Object.entries(data.tags).reduce((obj, [key, value]) => {
107
+ obj[key] = value;
108
+ return obj;
109
+ }, {});
110
+ } else {
111
+ return {};
112
+ }
113
+ };
114
+ export {
115
+ OtelMetrics
116
+ };
117
+ //# sourceMappingURL=metrics-DREJOOAC.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/extensions/otel/metrics.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type Meter } from '@opentelemetry/api';\nimport { OTLPMetricExporter } from '@opentelemetry/exporter-metrics-otlp-http';\nimport { MeterProvider, PeriodicExportingMetricReader } from '@opentelemetry/sdk-metrics';\n\nimport { log } from '@dxos/log';\nimport { type MetricData, TRACE_PROCESSOR } from '@dxos/tracing';\n\nimport { type OtelOptions, resolveOtlpUrl, setDiagLogger } from './otel';\n\nconst EXPORT_INTERVAL = 60 * 1000;\n\nexport class OtelMetrics {\n private _meterProvider: MeterProvider;\n private _meter: Meter;\n\n constructor(private readonly options: OtelOptions) {\n // TODO: improve error handling/logging\n // https://github.com/open-telemetry/opentelemetry-js/issues/4823\n setDiagLogger(options.consoleDiagLogLevel);\n\n const grafanaMetricReader = new PeriodicExportingMetricReader({\n exporter: new OTLPMetricExporter({\n url: resolveOtlpUrl(this.options.endpoint + '/v1/metrics'),\n headers: this.options.headers,\n }),\n exportIntervalMillis: EXPORT_INTERVAL,\n });\n\n this._meterProvider = new MeterProvider({\n resource: this.options.resource,\n readers: [grafanaMetricReader],\n });\n this._meter = this._meterProvider.getMeter('dxos-observability');\n\n const metrics = {\n // TODO: update metrics names and remove prefix?\n increment: (name: string, value?: number, data?: MetricData) => {\n this.increment(name, value, convertTags(data));\n },\n distribution: (name: string, value: number, data?: MetricData) => {\n this.distribution(name, value, convertTags(data));\n },\n set: (name: string, value: number | string, data?: MetricData) => {\n // Not implemented, not part of Otel spec.\n },\n gauge: (name: string, value: number, data?: MetricData) => {\n this.gauge(name, value, convertTags(data));\n },\n };\n\n TRACE_PROCESSOR.remoteMetrics.registerProcessor(metrics);\n }\n\n gauge(name: string, value: number, tags?: any): void {\n const gauge = this._meter.createGauge(name);\n log('otel gauge', { name, value, tags: { ...this.options.getTags(), ...tags } });\n gauge.record(value, { ...this.options.getTags(), ...tags });\n }\n\n increment(name: string, value?: number, tags?: any): void {\n const counter = this._meter.createCounter(name);\n log('otel counter', { name, value, tags: { ...this.options.getTags(), ...tags } });\n counter.add(value ?? 1, { ...this.options.getTags(), ...tags });\n }\n\n distribution(name: string, value: number, tags?: any): void {\n const distribution = this._meter.createHistogram(name);\n log('otel distribution', { name, value, tags: { ...this.options.getTags(), ...tags } });\n distribution.record(value, { ...this.options.getTags(), ...tags });\n }\n\n flush(): Promise<void> {\n return this._meterProvider.forceFlush();\n }\n\n close(): Promise<void> {\n return this._meterProvider.shutdown();\n }\n}\n\nconst convertTags = (data?: MetricData) => {\n if (data && data.tags) {\n return Object.entries(data.tags).reduce<{ [key: string]: any }>((obj, [key, value]) => {\n obj[key] = value;\n return obj;\n }, {});\n } else {\n return {};\n }\n};\n"],
5
+ "mappings": ";;;;;;;;AAKA,SAASA,0BAA0B;AACnC,SAASC,eAAeC,qCAAqC;AAE7D,SAASC,WAAW;AACpB,SAA0BC,uBAAuB;AAIjD,IAAA,eAAMC;;AAGIC,IAAAA,cAAAA,MAA8B;EAC9BC;EAER;;cACE,SAAA;AACA,SAAA,UAAA;kBAIY,QAAIC,mBAAmB;gCACX,IAAI,8BAAoB;gBAC5CC,IAAS,mBAAoB;QAC/B,KAAA,eAAA,KAAA,QAAA,WAAA,aAAA;QACAC,SAAAA,KAAAA,QAAsBL;MACxB,CAAA;MAEI,sBAAsBM;;SAExBC,iBAAS,IAAA,cAAA;gBAACC,KAAAA,QAAAA;eAAoB;QAChC;MACI;IAEJ,CAAA;SACE,SAAA,KAAA,eAAA,SAAA,oBAAgD;UAChDC,UAAYC;;MAEZ,WAAA,CAAA,MAAA,OAAA,SAAA;AACAC,aAAAA,UAAeD,MAAcE,OAAeC,YAAAA,IAAAA,CAAAA;;MAE5C,cAAA,CAAA,MAAA,OAAA,SAAA;AACAC,aAAMJ,aAAsCG,MAAAA,OAAAA,YAAAA,IAAAA,CAAAA;MAC1C;MACF,KAAA,CAAA,MAAA,OAAA,SAAA;;MAGA,OAAA,CAAA,MAAA,OAAA,SAAA;AACF,aAAA,MAAA,MAAA,OAAA,YAAA,IAAA,CAAA;MAEAE;IACF;AAEAC,oBAAmCC,cAAkB,kBAAA,OAAA;;QAEnDC,MAAI,OAAA,MAAc;UAAER,QAAAA,KAAAA,OAAAA,YAAAA,IAAAA;QAAME,cAAAA;MAAOK;;YAAmC;QAAQ,GAAA,KAAA,QAAA,QAAA;QAAE,GAAA;MAC9ED;qBAA8BG,YAAQC,GAAO,cAAE,GAAA,IAAA,GAAA,KAAA,CAAA;UAAE,OAAO,OAAA;MAAC,GAAA,KAAA,QAAA,QAAA;MAC3D,GAAA;IAEAX,CAAAA;;YAEM,MAAA,OAAA,MAAgB;UAAEC,UAAAA,KAAAA,OAAAA,cAAAA,IAAAA;QAAME,gBAAAA;MAAOK;;YAAmC;QAAQ,GAAA,KAAA,QAAA,QAAA;QAAE,GAAA;MAChFI;qBAAkCF,YAAQC,GAAO,cAAE,GAAA,IAAA,GAAA,KAAA,CAAA;YAAKH,IAAI,SAAA,GAAA;MAAC,GAAA,KAAA,QAAA,QAAA;MAC/D,GAAA;IAEAN,CAAAA;;eAEM,MAAA,OAAA,MAAqB;UAAED,eAAAA,KAAAA,OAAAA,gBAAAA,IAAAA;QAAME,qBAAAA;MAAOK;;YAAmC;QAAQ,GAAA,KAAA,QAAA,QAAA;QAAE,GAAA;MACrFN;qBAAqCQ,YAAQC,GAAO,cAAE,GAAA,IAAA,GAAA,KAAA,CAAA;iBAAS,OAAA,OAAA;MAAC,GAAA,KAAA,QAAA,QAAA;MAClE,GAAA;IAEAE,CAAAA;;EAEA,QAAA;AAEAC,WAAuB,KAAA,eAAA,WAAA;;EAEvB,QAAA;AACF,WAAA,KAAA,eAAA,SAAA;EAEA;;kBAEWC,CAAAA,SAAOC;cACRC,KAAI,MAAGd;WACX,OAAOe,QAAAA,KAAAA,IAAAA,EAAAA,OAAAA,CAAAA,KAAAA,CAAAA,KAAAA,KAAAA,MAAAA;AACL,UAAA,GAAA,IAAA;AACC,aAAA;IACL,GAAA,CAAA,CAAA;EACF,OAAA;AACF,WAAA,CAAA;;;",
6
+ "names": ["OTLPMetricExporter", "MeterProvider", "PeriodicExportingMetricReader", "log", "TRACE_PROCESSOR", "EXPORT_INTERVAL", "_meterProvider", "_meter", "OTLPMetricExporter", "headers", "exportIntervalMillis", "MeterProvider", "readers", "grafanaMetricReader", "increment", "name", "distribution", "value", "data", "set", "TRACE_PROCESSOR", "gauge", "tags", "log", "options", "getTags", "counter", "flush", "close", "Object", "entries", "key", "obj"]
7
+ }
@@ -0,0 +1,125 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ resolveOtlpUrl
4
+ } from "./chunk-EDDZWPYV.mjs";
5
+ import "./chunk-HSLMI22Q.mjs";
6
+
7
+ // src/extensions/otel/traces.ts
8
+ import { ROOT_CONTEXT, SpanStatusCode, context as otelContext, propagation, trace } from "@opentelemetry/api";
9
+ import { W3CTraceContextPropagator } from "@opentelemetry/core";
10
+ import { OTLPTraceExporter } from "@opentelemetry/exporter-trace-otlp-http";
11
+ import { BasicTracerProvider, BatchSpanProcessor } from "@opentelemetry/sdk-trace-base";
12
+ import { ATTR_SERVICE_VERSION } from "@opentelemetry/semantic-conventions";
13
+ import { log as log2 } from "@dxos/log";
14
+ import { TRACE_PROCESSOR } from "@dxos/tracing";
15
+
16
+ // src/extensions/otel/span-processors.ts
17
+ import { log } from "@dxos/log";
18
+ var __dxlog_file = "/__w/dxos/dxos/packages/sdk/observability/src/extensions/otel/span-processors.ts";
19
+ var TagInjectorSpanProcessor = class {
20
+ _getTags;
21
+ constructor(_getTags) {
22
+ this._getTags = _getTags;
23
+ }
24
+ onStart(span, _parentContext) {
25
+ let tags;
26
+ try {
27
+ tags = this._getTags();
28
+ } catch (err) {
29
+ log.catch(err, void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file, L: 28, S: this });
30
+ return;
31
+ }
32
+ for (const [key, value] of Object.entries(tags)) {
33
+ span.setAttribute(key, value);
34
+ }
35
+ }
36
+ onEnd(_span) {
37
+ }
38
+ async shutdown() {
39
+ }
40
+ async forceFlush() {
41
+ }
42
+ };
43
+
44
+ // src/extensions/otel/traces.ts
45
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/observability/src/extensions/otel/traces.ts";
46
+ var OtelTraces = class {
47
+ options;
48
+ _tracer;
49
+ _tracerProvider;
50
+ constructor(options) {
51
+ this.options = options;
52
+ propagation.setGlobalPropagator(new W3CTraceContextPropagator());
53
+ this._tracerProvider = new BasicTracerProvider({
54
+ resource: this.options.resource,
55
+ spanProcessors: [
56
+ new TagInjectorSpanProcessor(this.options.getTags),
57
+ new BatchSpanProcessor(new OTLPTraceExporter({
58
+ url: resolveOtlpUrl(this.options.endpoint + "/v1/traces"),
59
+ headers: this.options.headers,
60
+ concurrencyLimit: 10
61
+ }))
62
+ ]
63
+ });
64
+ trace.setGlobalTracerProvider(this._tracerProvider);
65
+ this._tracer = trace.getTracer("dxos-observability", this.options.resource.attributes[ATTR_SERVICE_VERSION]?.toString());
66
+ }
67
+ /**
68
+ * Forcibly flush the BatchSpanProcessor. Call before process exit to avoid
69
+ * losing queued spans (which manifests as "Missing Span" in SigNoz — their
70
+ * already-exported children reference a parent that never made it to OTLP).
71
+ */
72
+ async flush() {
73
+ await this._tracerProvider.forceFlush();
74
+ }
75
+ /**
76
+ * Flush + shut down the tracer provider via `BasicTracerProvider.shutdown()`,
77
+ * which forces a final export then terminates all span processors.
78
+ *
79
+ * Terminal and effectively one-shot: safe to call after `flush()`, but
80
+ * `flush()` MUST NOT be called after `close()` — shutdown stops further
81
+ * exporting, so subsequent `close()`/`flush()` calls resolve without
82
+ * emitting new spans.
83
+ */
84
+ async close() {
85
+ await this._tracerProvider.shutdown();
86
+ }
87
+ start() {
88
+ log2("trace processor registered", void 0, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 53, S: this });
89
+ const tracer = this._tracer;
90
+ TRACE_PROCESSOR.tracingBackend = {
91
+ startSpan: (options) => {
92
+ log2("begin otel trace", {
93
+ options
94
+ }, { "~LogMeta": "~LogMeta", F: __dxlog_file2, L: 57, S: this });
95
+ const parentCtx = options.parentContext ? propagation.extract(ROOT_CONTEXT, {
96
+ traceparent: options.parentContext.traceparent,
97
+ tracestate: options.parentContext.tracestate ?? ""
98
+ }) : otelContext.active();
99
+ const span = tracer.startSpan(options.name, options, parentCtx);
100
+ const sc = span.spanContext();
101
+ const spanContext = sc && sc.traceId && sc.spanId ? {
102
+ traceparent: `00-${sc.traceId}-${sc.spanId}-${(sc.traceFlags ?? 0).toString(16).padStart(2, "0")}`,
103
+ tracestate: sc.traceState?.serialize()
104
+ } : void 0;
105
+ return {
106
+ end: (endTime) => span.end(endTime),
107
+ setError: (err) => {
108
+ if (err instanceof Error) {
109
+ span.recordException(err);
110
+ }
111
+ span.setStatus({
112
+ code: SpanStatusCode.ERROR,
113
+ message: err instanceof Error ? err.message : String(err)
114
+ });
115
+ },
116
+ spanContext
117
+ };
118
+ }
119
+ };
120
+ }
121
+ };
122
+ export {
123
+ OtelTraces
124
+ };
125
+ //# sourceMappingURL=traces-74F7JUKF.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/extensions/otel/traces.ts", "../../../src/extensions/otel/span-processors.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport {\n ROOT_CONTEXT,\n SpanStatusCode,\n type Tracer,\n context as otelContext,\n propagation,\n trace,\n} from '@opentelemetry/api';\nimport { W3CTraceContextPropagator } from '@opentelemetry/core';\nimport { OTLPTraceExporter } from '@opentelemetry/exporter-trace-otlp-http';\nimport { BasicTracerProvider, BatchSpanProcessor } from '@opentelemetry/sdk-trace-base';\nimport { ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';\n\nimport { log } from '@dxos/log';\nimport { type RemoteSpan, type StartSpanOptions, TRACE_PROCESSOR } from '@dxos/tracing';\n\nimport { type OtelOptions, resolveOtlpUrl } from './otel';\nimport { TagInjectorSpanProcessor } from './span-processors';\n\nexport class OtelTraces {\n private _tracer: Tracer;\n private readonly _tracerProvider: BasicTracerProvider;\n\n constructor(private readonly options: OtelOptions) {\n propagation.setGlobalPropagator(new W3CTraceContextPropagator());\n\n this._tracerProvider = new BasicTracerProvider({\n resource: this.options.resource,\n spanProcessors: [\n new TagInjectorSpanProcessor(this.options.getTags),\n new BatchSpanProcessor(\n new OTLPTraceExporter({\n url: resolveOtlpUrl(this.options.endpoint + '/v1/traces'),\n headers: this.options.headers,\n concurrencyLimit: 10,\n }),\n ),\n ],\n });\n\n trace.setGlobalTracerProvider(this._tracerProvider);\n this._tracer = trace.getTracer(\n 'dxos-observability',\n this.options.resource.attributes[ATTR_SERVICE_VERSION]?.toString(),\n );\n }\n\n /**\n * Forcibly flush the BatchSpanProcessor. Call before process exit to avoid\n * losing queued spans (which manifests as \"Missing Span\" in SigNoz — their\n * already-exported children reference a parent that never made it to OTLP).\n */\n public async flush(): Promise<void> {\n await this._tracerProvider.forceFlush();\n }\n\n /**\n * Flush + shut down the tracer provider via `BasicTracerProvider.shutdown()`,\n * which forces a final export then terminates all span processors.\n *\n * Terminal and effectively one-shot: safe to call after `flush()`, but\n * `flush()` MUST NOT be called after `close()` — shutdown stops further\n * exporting, so subsequent `close()`/`flush()` calls resolve without\n * emitting new spans.\n */\n public async close(): Promise<void> {\n await this._tracerProvider.shutdown();\n }\n\n public start(): void {\n log('trace processor registered');\n\n const tracer = this._tracer;\n\n TRACE_PROCESSOR.tracingBackend = {\n startSpan: (options: StartSpanOptions): RemoteSpan => {\n log('begin otel trace', { options });\n const parentCtx = options.parentContext\n ? propagation.extract(ROOT_CONTEXT, {\n traceparent: options.parentContext.traceparent,\n tracestate: options.parentContext.tracestate ?? '',\n })\n : otelContext.active();\n\n const span = tracer.startSpan(options.name, options, parentCtx);\n\n const sc = span.spanContext();\n const spanContext =\n sc && sc.traceId && sc.spanId\n ? {\n traceparent: `00-${sc.traceId}-${sc.spanId}-${(sc.traceFlags ?? 0).toString(16).padStart(2, '0')}`,\n tracestate: sc.traceState?.serialize(),\n }\n : undefined;\n\n return {\n end: (endTime?: number) => span.end(endTime),\n setError: (err: unknown) => {\n if (err instanceof Error) {\n span.recordException(err);\n }\n span.setStatus({ code: SpanStatusCode.ERROR, message: err instanceof Error ? err.message : String(err) });\n },\n spanContext,\n };\n },\n };\n }\n}\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Context } from '@opentelemetry/api';\nimport { type ReadableSpan, type Span, type SpanProcessor } from '@opentelemetry/sdk-trace-base';\n\nimport { log } from '@dxos/log';\n\n/**\n * Injects dynamic tags as attributes on every span.\n *\n * This is an `onStart`-only processor; `onEnd`/`shutdown`/`forceFlush` are no-ops\n * because this processor never holds pending work (delegates export to downstream\n * processors like BatchSpanProcessor).\n *\n * Use for tags that are not known at provider construction (e.g. identity\n * resolved asynchronously after login). For values known at startup, prefer\n * putting them on the `Resource` — see `extension.ts`.\n *\n * Failures in the tag provider are swallowed so they can never break span\n * recording (the processor is best-effort and runs on the startSpan hot path).\n */\nexport class TagInjectorSpanProcessor implements SpanProcessor {\n constructor(private readonly _getTags: () => Record<string, string>) {}\n\n onStart(span: Span, _parentContext: Context): void {\n let tags: Record<string, string>;\n try {\n tags = this._getTags();\n } catch (err) {\n log.catch(err);\n return;\n }\n for (const [key, value] of Object.entries(tags)) {\n span.setAttribute(key, value);\n }\n }\n\n onEnd(_span: ReadableSpan): void {}\n\n async shutdown(): Promise<void> {}\n\n async forceFlush(): Promise<void> {}\n}\n"],
5
+ "mappings": ";;;;;;;AAIA,SACEA,cACAC,gBAEAC,WAAWC,aACXC,aACAC,aACK;AACP,SAASC,iCAAiC;AAC1C,SAASC,yBAAyB;AAClC,SAASC,qBAAqBC,0BAA0B;AACxD,SAASC,4BAA4B;AAErC,SAASC,OAAAA,YAAW;AACpB,SAAiDC,uBAAuB;;;ACXxE,SAASC,WAAW;AAEpB,IAAA,eAAA;AAeE,IAA6BC,2BAA7B,MAAqE;;EAAC,YAAA,UAAA;AAEtEC,SAAQC,WAAYC;;UAEd,MAAA,gBAAA;QACFC;AACF,QAAE;AACAL,aAAIM,KAAMC,SAAAA;aACV,KAAA;AACF,UAAA,MAAA,KAAA,QAAA,EAAA,YAAA,YAAA,GAAA,cAAA,GAAA,IAAA,GAAA,KAAA,CAAA;AACA;;AAEA,eAAA,CAAA,KAAA,KAAA,KAAA,OAAA,QAAA,IAAA,GAAA;AACF,WAAA,aAAA,KAAA,KAAA;IAEAC;EAEA;EAEA,MAAMC,OAAAA;EAAAA;EACR,MAAA,WAAA;EAAA;;;;;;ADrBA,IAAAC,gBAAaC;AACHC,IAAgB,aAAhBA,MAAgB;EACPC;EAEjB;;cACEC,SAAYC;AAEZ,SAAKF,UAAAA;gBACHG,oBAAuBA,IAAQ,0BAAA,CAAA;SAC/BC,kBAAgB,IAAA,oBAAA;gBACVC,KAAAA,QAAAA;sBACAC;YAEAC,yBAAyBC,KAAAA,QAAQC,OAAW;YAC5CC,mBAAcF,IAAQE,kBAAO;UAC7BC,KAAAA,eAAkB,KAAA,QAAA,WAAA,YAAA;UACpB,SAAA,KAAA,QAAA;UAEH,kBAAA;QACH,CAAA,CAAA;MAEAC;IACA,CAAA;AAIF,UAAA,wBAAA,KAAA,eAAA;AAEA,SAAA,UAAA,MAAA,UAAA,sBAAA,KAAA,QAAA,SAAA,WAAA,oBAAA,GAAA,SAAA,CAAA;;;;;;;EAOA,MAAA,QAAA;AAEA,UAAA,KAAA,gBAAA,WAAA;;;;;;;;;;;EAWA,MAAA,QAAA;AAEOC,UAAc,KAAA,gBAAA,SAAA;;UAGnB;AAEAC,IAAAA,KAAAA,8BAAiC,QAAA,EAAA,YAAA,YAAA,GAAAjB,eAAA,GAAA,IAAA,GAAA,KAAA,CAAA;UAC/BkB,SAAW,KAACP;oBACN,iBAAoB;iBAAEA,CAAAA,YAAAA;AAAQ,QAAAQ,KAAA,oBAAA;UAClC;yBAEMC,YAAqBC,GAAAA,eAAcD,GAAAA,IAAAA,GAAAA,KAAW,CAAA;cAC9CE,YAAYX,QAAQU,gBAAcC,YAAc,QAAA,cAAA;UAClD,aACYC,QAAM,cAAA;UAEtB,YAAaC,QAAON,cAAkBO,cAAMd;QAE5C,CAAA,IAAA,YAAgBe,OAAAA;AAChB,cAAMA,OAAAA,OACJC,UAASC,QAAO,MAAOC,SACnB,SAAA;cACET,KAAAA,KAAAA,YAAsBQ;cACtBN,cAAeQ,MAAAA,GAAU,WAAEC,GAAAA,SAAAA;UAE7BC,aAAAA,MAAAA,GAAAA,OAAAA,IAAAA,GAAAA,MAAAA,KAAAA,GAAAA,cAAAA,GAAAA,SAAAA,EAAAA,EAAAA,SAAAA,GAAAA,GAAAA,CAAAA;UAEN,YAAO,GAAA,YAAA,UAAA;YACLC;eACAC;eACE,CAAA,YAAIC,KAAAA,IAAeC,OAAO;oBACxBC,CAAAA,QAAKC;AACP,gBAAA,eAAA,OAAA;AACAD,mBAAKE,gBAAU,GAAA;;iBAA8BC,UAASL;cAAiD,MAAA,eAAA;cACzG,SAAA,eAAA,QAAA,IAAA,UAAA,OAAA,GAAA;YACAT,CAAAA;UACF;UACF;QACF;MACF;IACF;;;",
6
+ "names": ["ROOT_CONTEXT", "SpanStatusCode", "context", "otelContext", "propagation", "trace", "W3CTraceContextPropagator", "OTLPTraceExporter", "BasicTracerProvider", "BatchSpanProcessor", "ATTR_SERVICE_VERSION", "log", "TRACE_PROCESSOR", "log", "_getTags", "onStart", "span", "_parentContext", "tags", "catch", "err", "onEnd", "forceFlush", "__dxlog_file", "OtelTraces", "_tracer", "_tracerProvider", "propagation", "setGlobalPropagator", "resource", "spanProcessors", "TagInjectorSpanProcessor", "BatchSpanProcessor", "url", "options", "endpoint", "headers", "concurrencyLimit", "trace", "start", "TRACE_PROCESSOR", "startSpan", "log", "traceparent", "parentContext", "tracestate", "active", "tracer", "name", "spanContext", "sc", "traceId", "spanId", "traceState", "serialize", "undefined", "end", "setError", "err", "Error", "span", "recordException", "setStatus", "message"]
7
+ }
@@ -1,7 +1,6 @@
1
1
  {
2
- "SENTRY_DESTINATION": "https://2647916221e643869965e78469479aa4@o4504012000067584.ingest.sentry.io/4504012027265029",
3
- "TELEMETRY_API_KEY": "B00QG6PtJJrJ0VVFe0H5a6bcUUShKyZM",
2
+ "POSTHOG_API_KEY": null,
4
3
  "IPDATA_API_KEY": "73dfdecdf979c18f07d50cf841bbdd9e589f237256326ac8cca23786",
5
- "OTEL_ENDPOINT": "https://otlp-proxy.dxos.workers.dev",
6
- "OTEL_AUTHORIZATION": "Basic OTA3MzIzOmdsY19leUp2SWpvaU1URXdNVEl6TnlJc0ltNGlPaUp6ZEdGamF5MDVNRGN6TWpNdGFXNTBaV2R5WVhScGIyNHRZMnh2ZFdSbWJHRnlaUzF2ZEd4d0xYQnliM2g1SWl3aWF5STZJalZ2Tkd4cFYydE5iRmszTlRNMGJUVXpTemRTVjNBeVNpSXNJbTBpT25zaWNpSTZJbkJ5YjJRdGRYTXRaV0Z6ZEMwd0luMTk="
4
+ "OTEL_ENDPOINT": "/api/otel",
5
+ "OTEL_HEADERS": null
7
6
  }
@@ -0,0 +1,3 @@
1
+ export * as Otel from './otel';
2
+ export * as PostHog from './posthog';
3
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/extensions/index.ts"],"names":[],"mappings":"AAIA,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC"}
@@ -0,0 +1,6 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+ export * as Otel from './otel';
5
+ export * as PostHog from './posthog';
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/extensions/index.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,OAAO,KAAK,IAAI,MAAM,QAAQ,CAAC;AAC/B,OAAO,KAAK,OAAO,MAAM,WAAW,CAAC"}
@@ -0,0 +1,23 @@
1
+ import * as Effect from 'effect/Effect';
2
+ import { type Config } from '@dxos/config';
3
+ import { LogLevel } from '@dxos/log';
4
+ import { type Extension } from '../../observability-extension';
5
+ export type ExtensionsOptions = {
6
+ /** For the OTEL, the name of the entity for which signals (metrics or trace) are collected. */
7
+ serviceName: string;
8
+ /** For the OTEL, the version of the entity for which signals (metrics or trace) are collected. */
9
+ serviceVersion: string;
10
+ /** For the OTEL, the environment of the entity for which signals (metrics or trace) are collected. */
11
+ environment: string;
12
+ config: Config;
13
+ endpoint?: string;
14
+ headers?: Record<string, string>;
15
+ logs?: boolean;
16
+ /** Minimum log level to export. Defaults to INFO (i.e. info, warn, error). */
17
+ logLevel?: LogLevel;
18
+ metrics?: boolean;
19
+ traces?: boolean;
20
+ };
21
+ /** Create an OTEL-backed observability extension for logs, metrics, and/or traces. */
22
+ export declare const extensions: (options: ExtensionsOptions) => Effect.Effect<Extension>;
23
+ //# sourceMappingURL=extension.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extension.d.ts","sourceRoot":"","sources":["../../../../../src/extensions/otel/extension.ts"],"names":[],"mappings":"AAMA,OAAO,KAAK,MAAM,MAAM,eAAe,CAAC;AAKxC,OAAO,EAAE,KAAK,MAAM,EAAuB,MAAM,cAAc,CAAC;AAChE,OAAO,EAAE,QAAQ,EAAO,MAAM,WAAW,CAAC;AAI1C,OAAO,EAAE,KAAK,SAAS,EAAqB,MAAM,+BAA+B,CAAC;AAIlF,MAAM,MAAM,iBAAiB,GAAG;IAC9B,+FAA+F;IAC/F,WAAW,EAAE,MAAM,CAAC;IACpB,kGAAkG;IAClG,cAAc,EAAE,MAAM,CAAC;IACvB,sGAAsG;IACtG,WAAW,EAAE,MAAM,CAAC;IACpB,MAAM,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,MAAM,CAAC;IAClB,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACjC,IAAI,CAAC,EAAE,OAAO,CAAC;IACf,8EAA8E;IAC9E,QAAQ,CAAC,EAAE,QAAQ,CAAC;IACpB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB,CAAC;AAEF,sFAAsF;AACtF,eAAO,MAAM,UAAU,EAAE,CAAC,OAAO,EAAE,iBAAiB,KAAK,MAAM,CAAC,MAAM,CAAC,SAAS,CAuL9E,CAAC"}
@@ -0,0 +1,220 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+ import { defaultResource, resourceFromAttributes } from '@opentelemetry/resources';
5
+ import { ATTR_SERVICE_NAME, ATTR_SERVICE_VERSION } from '@opentelemetry/semantic-conventions';
6
+ import * as Effect from 'effect/Effect';
7
+ import * as Match from 'effect/Match';
8
+ import * as Option from 'effect/Option';
9
+ import * as Ref from 'effect/Ref';
10
+ import { resolveTelemetryTag } from '@dxos/config';
11
+ import { LogLevel, log } from '@dxos/log';
12
+ import { isNode, isNonNullable } from '@dxos/util';
13
+ import buildSecrets from '../../cli-observability-secrets.json';
14
+ import { isObservabilityDisabled, storeObservabilityDisabled } from '../../storage';
15
+ import { stubExtension } from '../stub';
16
+ /** Create an OTEL-backed observability extension for logs, metrics, and/or traces. */
17
+ export const extensions = Effect.fn(function* ({ serviceName, serviceVersion, environment, config, endpoint: _endpoint, headers: _headers,
18
+ // TODO(wittjosiah): Logging integration.
19
+ // - logger should run even if observability is disabled
20
+ // - logs should be cached locally in a circular buffer
21
+ // - logs should be flushed to the server if user opts to include them in a bug report
22
+ logs: logsEnabled = false, logLevel = LogLevel.INFO, metrics: metricsEnabled = false, traces: tracesEnabled = false, }) {
23
+ const { OtelLogs } = yield* Effect.promise(() => import('./logs'));
24
+ const { OtelMetrics } = yield* Effect.promise(() => import('./metrics'));
25
+ const { OtelTraces } = yield* Effect.promise(() => import('./traces'));
26
+ const cachedDisabled = yield* Effect.promise(() => isObservabilityDisabled(serviceName));
27
+ const disabled = cachedDisabled || isObservabilityDisabledSync(serviceName);
28
+ const enabledRef = yield* Ref.make(!disabled);
29
+ const tags = new Map();
30
+ const rawEndpoint = isNode()
31
+ ? (process.env.DX_OTEL_ENDPOINT ?? _endpoint ?? buildSecrets.OTEL_ENDPOINT)
32
+ : (config.values.runtime?.app?.env?.DX_OTEL_ENDPOINT ?? _endpoint);
33
+ // The OTLP exporter (>= 0.203) validates URLs and rejects relative paths.
34
+ // In the browser/worker, resolve relative endpoints against the current origin
35
+ // so callers can keep using paths like `/api/otel` for proxied deployments.
36
+ const endpoint = !isNode() && rawEndpoint?.startsWith('/') ? resolveRelativeEndpoint(rawEndpoint) : rawEndpoint;
37
+ const headers = _headers ??
38
+ Match.value(isNode()).pipe(Match.when(true, () => Option.fromNullable(process.env.DX_OTEL_HEADERS ?? buildSecrets.OTEL_HEADERS)), Match.when(false, () => Option.fromNullable(config.values.runtime?.app?.env?.DX_OTEL_HEADERS)), Match.exhaustive, Option.map((raw) => parseHeaders(raw)), Option.getOrElse(() => undefined));
39
+ if (!endpoint) {
40
+ log.info('Missing OTEL_ENDPOINT');
41
+ return stubExtension;
42
+ }
43
+ // Headers are optional when using a proxy that injects auth server-side.
44
+ const resolvedHeaders = headers ?? {};
45
+ // OTLP HTTP exporters require an absolute URL. Resolve relative paths using the current origin.
46
+ // globalThis.location is defined in all browser contexts (main thread, dedicated/service workers).
47
+ const resolvedEndpoint = !isNode() && endpoint.startsWith('/') ? `${globalThis.location.origin}${endpoint}` : endpoint;
48
+ // Matches edge's `ctx.tag` span attribute (stamped by the edge log middleware
49
+ // when it reads the `X-DXOS-Client-Tag` header, see
50
+ // /edge/packages/services/edge/src/log-middleware.ts).
51
+ //
52
+ // Stamped in TWO places:
53
+ // 1. Resource attribute — so logs and metrics emitted from this extension
54
+ // also carry it, and for zero per-span cost.
55
+ // 2. Span attribute via `tags` — because edge puts `ctx.tag` in the span-
56
+ // attribute context (not resource), and SigNoz indexes the two contexts
57
+ // separately. Stamping it on span attributes here keeps a single
58
+ // `ctx.tag = <value>` filter matching spans from both tiers in SigNoz
59
+ // without requiring qualified `attribute.ctx.tag`/`resource.ctx.tag` syntax.
60
+ const clientTag = resolveTelemetryTag(config);
61
+ if (clientTag) {
62
+ tags.set('ctx.tag', clientTag);
63
+ }
64
+ const resource = defaultResource().merge(resourceFromAttributes({
65
+ [ATTR_SERVICE_NAME]: serviceName,
66
+ [ATTR_SERVICE_VERSION]: serviceVersion,
67
+ 'session.id': crypto.randomUUID(),
68
+ 'deployment.environment': environment,
69
+ 'dxos.process.type': detectProcessType(),
70
+ ...(clientTag ? { 'ctx.tag': clientTag } : {}),
71
+ }));
72
+ const logs = logsEnabled
73
+ ? new OtelLogs({
74
+ endpoint: resolvedEndpoint,
75
+ headers: resolvedHeaders,
76
+ resource,
77
+ getTags: () => Object.fromEntries(tags),
78
+ logLevel,
79
+ })
80
+ : undefined;
81
+ const metrics = metricsEnabled
82
+ ? new OtelMetrics({
83
+ endpoint: resolvedEndpoint,
84
+ headers: resolvedHeaders,
85
+ resource,
86
+ getTags: () => Object.fromEntries(tags),
87
+ })
88
+ : undefined;
89
+ const traces = tracesEnabled
90
+ ? new OtelTraces({
91
+ endpoint: resolvedEndpoint,
92
+ headers: resolvedHeaders,
93
+ resource,
94
+ getTags: () => Object.fromEntries(tags),
95
+ })
96
+ : undefined;
97
+ const extension = {
98
+ initialize: () => Effect.sync(() => {
99
+ if (disabled) {
100
+ return;
101
+ }
102
+ if (logs) {
103
+ log.runtimeConfig.processors.push(logs.logProcessor);
104
+ }
105
+ if (traces) {
106
+ traces.start();
107
+ }
108
+ }),
109
+ enable: Effect.fn(function* () {
110
+ yield* Effect.promise(() => storeObservabilityDisabled(serviceName, false));
111
+ yield* Ref.update(enabledRef, () => true);
112
+ }),
113
+ disable: Effect.fn(function* () {
114
+ yield* Effect.promise(() => storeObservabilityDisabled(serviceName, true));
115
+ yield* Ref.update(enabledRef, () => false);
116
+ }),
117
+ close: () => Effect.promise(async () => {
118
+ // Run logs/metrics close concurrently and swallow their failures so the
119
+ // tracer provider shutdown below ALWAYS runs. Without this, a rejection
120
+ // from logs or metrics would drop the tracer provider's BatchSpanProcessor
121
+ // queue on process exit, manifesting as "Missing Span" in SigNoz for any
122
+ // already-exported children.
123
+ const results = await Promise.allSettled([logs?.close(), metrics?.close()]);
124
+ for (const result of results) {
125
+ if (result.status === 'rejected') {
126
+ log.catch(result.reason);
127
+ }
128
+ }
129
+ // Critical: shut down the tracer provider so BatchSpanProcessor drains its
130
+ // queue. Otherwise spans enqueued in the last 5s (close/teardown spans)
131
+ // are dropped on process exit.
132
+ await traces?.close();
133
+ }),
134
+ flush: () => Effect.promise(async () => {
135
+ const results = await Promise.allSettled([logs?.flush(), metrics?.flush()]);
136
+ for (const result of results) {
137
+ if (result.status === 'rejected') {
138
+ log.catch(result.reason);
139
+ }
140
+ }
141
+ await traces?.flush();
142
+ }),
143
+ setTags: (incomingTags) => {
144
+ for (const [key, value] of Object.entries(incomingTags)) {
145
+ tags.set(key, value);
146
+ }
147
+ },
148
+ get enabled() {
149
+ return Ref.get(enabledRef).pipe(Effect.runSync);
150
+ },
151
+ apis: [
152
+ { kind: 'logs', isAvailable: () => Effect.succeed(!!logs) },
153
+ metrics
154
+ ? {
155
+ kind: 'metrics',
156
+ isAvailable: () => Effect.succeed(true),
157
+ gauge: (name, value, tags) => metrics.gauge(name, value, tags),
158
+ increment: (name, value, tags) => metrics.increment(name, value, tags),
159
+ distribution: (name, value, tags) => metrics.distribution(name, value, tags),
160
+ }
161
+ : undefined,
162
+ traces ? { kind: 'traces', isAvailable: () => Effect.succeed(true) } : undefined,
163
+ ].filter(isNonNullable),
164
+ };
165
+ return extension;
166
+ });
167
+ /**
168
+ * Synchronous best-effort check for observability opt-out.
169
+ * Prevents telemetry from being emitted before the async storage check completes.
170
+ */
171
+ const isObservabilityDisabledSync = (serviceName) => {
172
+ if (isNode()) {
173
+ return process.env.DX_DISABLE_OBSERVABILITY === 'true';
174
+ }
175
+ try {
176
+ if (typeof localStorage !== 'undefined') {
177
+ return localStorage.getItem(`${serviceName}/observability-disabled`) === 'true';
178
+ }
179
+ }
180
+ catch {
181
+ // localStorage not available (e.g., in workers).
182
+ }
183
+ return false;
184
+ };
185
+ /** Best-effort detection of the JavaScript execution context type. */
186
+ const detectProcessType = () => {
187
+ if (isNode()) {
188
+ return 'node';
189
+ }
190
+ if (typeof window !== 'undefined') {
191
+ return 'browser';
192
+ }
193
+ if (typeof globalThis.ServiceWorkerGlobalScope !== 'undefined') {
194
+ return 'service-worker';
195
+ }
196
+ if (typeof globalThis.SharedWorkerGlobalScope !== 'undefined') {
197
+ return 'shared-worker';
198
+ }
199
+ return 'dedicated-worker';
200
+ };
201
+ /**
202
+ * Resolves a relative OTLP endpoint path against the current global origin.
203
+ * Workers expose the same `globalThis.location` as the page that spawned them;
204
+ * if neither is available we fall back to the original path and let the OTLP
205
+ * exporter surface the configuration error.
206
+ */
207
+ const resolveRelativeEndpoint = (path) => {
208
+ const origin = globalThis.location?.origin;
209
+ return origin ? `${origin}${path}` : path;
210
+ };
211
+ const parseHeaders = (unparsedHeaders) => {
212
+ return unparsedHeaders.split(';').reduce((acc, header) => {
213
+ const [key, ...rest] = header.split(':');
214
+ if (key && rest.length > 0) {
215
+ acc[key.trim().toLowerCase()] = rest.join(':').trim();
216
+ }
217
+ return acc;
218
+ }, {});
219
+ };
220
+ //# sourceMappingURL=extension.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"extension.js","sourceRoot":"","sources":["../../../../../src/extensions/otel/extension.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,2 @@
1
+ export * from './extension';
2
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../../src/extensions/otel/index.ts"],"names":[],"mappings":"AAIA,cAAc,aAAa,CAAC"}
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+ export * from './extension';
5
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../../src/extensions/otel/index.ts"],"names":[],"mappings":"AAAA,EAAE;AACF,0BAA0B;AAC1B,EAAE;AAEF,cAAc,aAAa,CAAC"}
@@ -3,10 +3,11 @@ import { type OtelOptions } from './otel';
3
3
  export type OtelLogOptions = OtelOptions & {
4
4
  logLevel: LogLevel;
5
5
  /**
6
- * Set `true` to capture logs sent through LoggingService from shared worker.
7
- * Better to set to `false` because shared worker is initializing its own logger.
6
+ * Include logs forwarded from the shared worker via LoggingService.
7
+ *
8
+ * @deprecated
8
9
  */
9
- includeSharedWorkerLogs: boolean;
10
+ includeSharedWorkerLogs?: boolean;
10
11
  };
11
12
  export declare class OtelLogs {
12
13
  private readonly options;
@@ -0,0 +1 @@
1
+ {"version":3,"file":"logs.d.ts","sourceRoot":"","sources":["../../../../../src/extensions/otel/logs.ts"],"names":[],"mappings":"AASA,OAAO,EAGL,QAAQ,EACR,KAAK,YAAY,EAGlB,MAAM,WAAW,CAAC;AAEnB,OAAO,EAAE,KAAK,WAAW,EAAiC,MAAM,QAAQ,CAAC;AAIzE,MAAM,MAAM,cAAc,GAAG,WAAW,GAAG;IACzC,QAAQ,EAAE,QAAQ,CAAC;IACnB;;;;OAIG;IACH,uBAAuB,CAAC,EAAE,OAAO,CAAC;CACnC,CAAC;AAEF,qBAAa,QAAQ;IAEP,OAAO,CAAC,QAAQ,CAAC,OAAO;IADpC,OAAO,CAAC,eAAe,CAAiB;IACxC,YAA6B,OAAO,EAAE,cAAc,EAWnD;IAED,SAAgB,YAAY,EAAE,YAAY,CAyBxC;IAEF,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAErB;IAED,KAAK,IAAI,OAAO,CAAC,IAAI,CAAC,CAErB;CACF"}