autotel 3.5.0 → 3.7.0

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 (591) hide show
  1. package/dist/attribute-redacting-processor-DtTS9xxh.d.cts +175 -0
  2. package/dist/attribute-redacting-processor-DtTS9xxh.d.cts.map +1 -0
  3. package/dist/attribute-redacting-processor-DtTS9xxh.d.ts +175 -0
  4. package/dist/attribute-redacting-processor-DtTS9xxh.d.ts.map +1 -0
  5. package/dist/attribute-redacting-processor.cjs +374 -33
  6. package/dist/attribute-redacting-processor.cjs.map +1 -1
  7. package/dist/attribute-redacting-processor.d.cts +2 -207
  8. package/dist/attribute-redacting-processor.d.ts +2 -207
  9. package/dist/attribute-redacting-processor.js +368 -2
  10. package/dist/attribute-redacting-processor.js.map +1 -1
  11. package/dist/attributes-D3etyRVc.cjs +713 -0
  12. package/dist/attributes-D3etyRVc.cjs.map +1 -0
  13. package/dist/attributes-ksn4HVbd.js +600 -0
  14. package/dist/attributes-ksn4HVbd.js.map +1 -0
  15. package/dist/attributes.cjs +21 -85
  16. package/dist/attributes.d.cts +2 -20
  17. package/dist/attributes.d.ts +2 -20
  18. package/dist/attributes.js +3 -5
  19. package/dist/auto.cjs +50 -28
  20. package/dist/auto.cjs.map +1 -1
  21. package/dist/auto.d.cts +1 -2
  22. package/dist/auto.d.ts +1 -2
  23. package/dist/auto.js +49 -23
  24. package/dist/auto.js.map +1 -1
  25. package/dist/business-baggage.cjs +357 -13
  26. package/dist/business-baggage.cjs.map +1 -1
  27. package/dist/business-baggage.d.cts +106 -139
  28. package/dist/business-baggage.d.cts.map +1 -0
  29. package/dist/business-baggage.d.ts +106 -139
  30. package/dist/business-baggage.d.ts.map +1 -0
  31. package/dist/business-baggage.js +357 -2
  32. package/dist/business-baggage.js.map +1 -1
  33. package/dist/canonical-log-line-processor--RlFDHhm.cjs +377 -0
  34. package/dist/canonical-log-line-processor--RlFDHhm.cjs.map +1 -0
  35. package/dist/canonical-log-line-processor-BcRuAdRk.d.ts +147 -0
  36. package/dist/canonical-log-line-processor-BcRuAdRk.d.ts.map +1 -0
  37. package/dist/canonical-log-line-processor-DbBQT5vY.js +366 -0
  38. package/dist/canonical-log-line-processor-DbBQT5vY.js.map +1 -0
  39. package/dist/canonical-log-line-processor-xvjMgtpF.d.cts +147 -0
  40. package/dist/canonical-log-line-processor-xvjMgtpF.d.cts.map +1 -0
  41. package/dist/config.cjs +118 -22
  42. package/dist/config.cjs.map +1 -1
  43. package/dist/config.d.cts +33 -45
  44. package/dist/config.d.cts.map +1 -0
  45. package/dist/config.d.ts +33 -45
  46. package/dist/config.d.ts.map +1 -0
  47. package/dist/config.js +116 -3
  48. package/dist/config.js.map +1 -1
  49. package/dist/correlated-events-Bzh5y-UB.js +28 -0
  50. package/dist/correlated-events-Bzh5y-UB.js.map +1 -0
  51. package/dist/correlated-events-kSwLo3mi.cjs +34 -0
  52. package/dist/correlated-events-kSwLo3mi.cjs.map +1 -0
  53. package/dist/correlation-id.cjs +11 -53
  54. package/dist/correlation-id.d.cts +6 -5
  55. package/dist/correlation-id.d.cts.map +1 -0
  56. package/dist/correlation-id.d.ts +6 -5
  57. package/dist/correlation-id.d.ts.map +1 -0
  58. package/dist/correlation-id.js +3 -16
  59. package/dist/db.cjs +244 -209
  60. package/dist/db.cjs.map +1 -1
  61. package/dist/db.d.cts +28 -26
  62. package/dist/db.d.cts.map +1 -0
  63. package/dist/db.d.ts +28 -26
  64. package/dist/db.d.ts.map +1 -0
  65. package/dist/db.js +243 -207
  66. package/dist/db.js.map +1 -1
  67. package/dist/decorators.cjs +39 -65
  68. package/dist/decorators.cjs.map +1 -1
  69. package/dist/decorators.d.cts +10 -37
  70. package/dist/decorators.d.cts.map +1 -0
  71. package/dist/decorators.d.ts +10 -37
  72. package/dist/decorators.d.ts.map +1 -0
  73. package/dist/decorators.js +38 -63
  74. package/dist/decorators.js.map +1 -1
  75. package/dist/define-event-CreknLm3.d.ts +25 -0
  76. package/dist/define-event-CreknLm3.d.ts.map +1 -0
  77. package/dist/define-event-HZRizPwz.d.cts +25 -0
  78. package/dist/define-event-HZRizPwz.d.cts.map +1 -0
  79. package/dist/drain-pipeline.cjs +111 -9
  80. package/dist/drain-pipeline.cjs.map +1 -1
  81. package/dist/drain-pipeline.d.cts +27 -32
  82. package/dist/drain-pipeline.d.cts.map +1 -0
  83. package/dist/drain-pipeline.d.ts +27 -32
  84. package/dist/drain-pipeline.d.ts.map +1 -0
  85. package/dist/drain-pipeline.js +111 -2
  86. package/dist/drain-pipeline.js.map +1 -1
  87. package/dist/enrichers.cjs +59 -66
  88. package/dist/enrichers.cjs.map +1 -1
  89. package/dist/enrichers.d.cts +15 -13
  90. package/dist/enrichers.d.cts.map +1 -0
  91. package/dist/enrichers.d.ts +15 -13
  92. package/dist/enrichers.d.ts.map +1 -0
  93. package/dist/enrichers.js +58 -65
  94. package/dist/enrichers.js.map +1 -1
  95. package/dist/event-Dlqr4ZNL.cjs +778 -0
  96. package/dist/event-Dlqr4ZNL.cjs.map +1 -0
  97. package/dist/event-_58ryBjh.js +761 -0
  98. package/dist/event-_58ryBjh.js.map +1 -0
  99. package/dist/event-subscriber-D1XLkPzi.d.cts +223 -0
  100. package/dist/event-subscriber-D1XLkPzi.d.cts.map +1 -0
  101. package/dist/event-subscriber-D1XLkPzi.d.ts +223 -0
  102. package/dist/event-subscriber-D1XLkPzi.d.ts.map +1 -0
  103. package/dist/event-subscriber.cjs +0 -6
  104. package/dist/event-subscriber.d.cts +2 -221
  105. package/dist/event-subscriber.d.ts +2 -221
  106. package/dist/event-subscriber.js +1 -3
  107. package/dist/event-testing-BqRnI0z4.d.cts +106 -0
  108. package/dist/event-testing-BqRnI0z4.d.cts.map +1 -0
  109. package/dist/event-testing-CfFs3to2.d.ts +106 -0
  110. package/dist/event-testing-CfFs3to2.d.ts.map +1 -0
  111. package/dist/event-testing.cjs +93 -17
  112. package/dist/event-testing.cjs.map +1 -1
  113. package/dist/event-testing.d.cts +2 -110
  114. package/dist/event-testing.d.ts +2 -110
  115. package/dist/event-testing.js +91 -2
  116. package/dist/event-testing.js.map +1 -1
  117. package/dist/event.cjs +5 -36
  118. package/dist/event.d.cts +295 -340
  119. package/dist/event.d.cts.map +1 -0
  120. package/dist/event.d.ts +295 -340
  121. package/dist/event.d.ts.map +1 -0
  122. package/dist/event.js +3 -20
  123. package/dist/exporters.cjs +12 -16
  124. package/dist/exporters.d.cts +86 -111
  125. package/dist/exporters.d.cts.map +1 -0
  126. package/dist/exporters.d.ts +86 -111
  127. package/dist/exporters.d.ts.map +1 -0
  128. package/dist/exporters.js +4 -4
  129. package/dist/filtering-span-processor-B8R8B7Uk.d.cts +59 -0
  130. package/dist/filtering-span-processor-B8R8B7Uk.d.cts.map +1 -0
  131. package/dist/filtering-span-processor-B8R8B7Uk.d.ts +59 -0
  132. package/dist/filtering-span-processor-B8R8B7Uk.d.ts.map +1 -0
  133. package/dist/filtering-span-processor.cjs +49 -9
  134. package/dist/filtering-span-processor.cjs.map +1 -1
  135. package/dist/filtering-span-processor.d.cts +2 -80
  136. package/dist/filtering-span-processor.d.ts +2 -80
  137. package/dist/filtering-span-processor.js +49 -2
  138. package/dist/filtering-span-processor.js.map +1 -1
  139. package/dist/functional-BGkT8J-h.js +1265 -0
  140. package/dist/functional-BGkT8J-h.js.map +1 -0
  141. package/dist/functional-C4CzoVrX.cjs +1312 -0
  142. package/dist/functional-C4CzoVrX.cjs.map +1 -0
  143. package/dist/functional.cjs +11 -56
  144. package/dist/functional.d.cts +96 -97
  145. package/dist/functional.d.cts.map +1 -0
  146. package/dist/functional.d.ts +96 -97
  147. package/dist/functional.d.ts.map +1 -0
  148. package/dist/functional.js +3 -19
  149. package/dist/http.cjs +276 -175
  150. package/dist/http.cjs.map +1 -1
  151. package/dist/http.d.cts +17 -37
  152. package/dist/http.d.cts.map +1 -0
  153. package/dist/http.d.ts +17 -37
  154. package/dist/http.d.ts.map +1 -0
  155. package/dist/http.js +275 -173
  156. package/dist/http.js.map +1 -1
  157. package/dist/index-CX0aG1Uh.d.ts +708 -0
  158. package/dist/index-CX0aG1Uh.d.ts.map +1 -0
  159. package/dist/index-DIWZFKUS.d.cts +708 -0
  160. package/dist/index-DIWZFKUS.d.cts.map +1 -0
  161. package/dist/index.cjs +1050 -1184
  162. package/dist/index.cjs.map +1 -1
  163. package/dist/index.d.cts +401 -570
  164. package/dist/index.d.cts.map +1 -0
  165. package/dist/index.d.ts +401 -570
  166. package/dist/index.d.ts.map +1 -0
  167. package/dist/index.js +913 -725
  168. package/dist/index.js.map +1 -1
  169. package/dist/init-CNp-ee80.d.cts +1157 -0
  170. package/dist/init-CNp-ee80.d.cts.map +1 -0
  171. package/dist/init-Ch6t7MNI.js +1015 -0
  172. package/dist/init-Ch6t7MNI.js.map +1 -0
  173. package/dist/init-DJQOdVlN.d.ts +1157 -0
  174. package/dist/init-DJQOdVlN.d.ts.map +1 -0
  175. package/dist/init-DvapOXCc.cjs +1092 -0
  176. package/dist/init-DvapOXCc.cjs.map +1 -0
  177. package/dist/instrumentation.cjs +159 -185
  178. package/dist/instrumentation.cjs.map +1 -1
  179. package/dist/instrumentation.d.cts +42 -40
  180. package/dist/instrumentation.d.cts.map +1 -0
  181. package/dist/instrumentation.d.ts +42 -40
  182. package/dist/instrumentation.d.ts.map +1 -0
  183. package/dist/instrumentation.js +158 -183
  184. package/dist/instrumentation.js.map +1 -1
  185. package/dist/logger-BauSUhUv.d.cts +313 -0
  186. package/dist/logger-BauSUhUv.d.cts.map +1 -0
  187. package/dist/logger-BauSUhUv.d.ts +313 -0
  188. package/dist/logger-BauSUhUv.d.ts.map +1 -0
  189. package/dist/logger.cjs +225 -25
  190. package/dist/logger.cjs.map +1 -1
  191. package/dist/logger.d.cts +2 -348
  192. package/dist/logger.d.ts +2 -348
  193. package/dist/logger.js +204 -4
  194. package/dist/logger.js.map +1 -1
  195. package/dist/messaging-adapters.cjs +292 -187
  196. package/dist/messaging-adapters.cjs.map +1 -1
  197. package/dist/messaging-adapters.d.cts +28 -66
  198. package/dist/messaging-adapters.d.cts.map +1 -0
  199. package/dist/messaging-adapters.d.ts +28 -66
  200. package/dist/messaging-adapters.d.ts.map +1 -0
  201. package/dist/messaging-adapters.js +291 -185
  202. package/dist/messaging-adapters.js.map +1 -1
  203. package/dist/messaging-testing.cjs +306 -372
  204. package/dist/messaging-testing.cjs.map +1 -1
  205. package/dist/messaging-testing.d.cts +194 -223
  206. package/dist/messaging-testing.d.cts.map +1 -0
  207. package/dist/messaging-testing.d.ts +194 -223
  208. package/dist/messaging-testing.d.ts.map +1 -0
  209. package/dist/messaging-testing.js +305 -371
  210. package/dist/messaging-testing.js.map +1 -1
  211. package/dist/messaging.cjs +757 -35
  212. package/dist/messaging.cjs.map +1 -1
  213. package/dist/messaging.d.cts +603 -644
  214. package/dist/messaging.d.cts.map +1 -0
  215. package/dist/messaging.d.ts +603 -644
  216. package/dist/messaging.d.ts.map +1 -0
  217. package/dist/messaging.js +756 -20
  218. package/dist/messaging.js.map +1 -1
  219. package/dist/metric-helpers.cjs +27 -27
  220. package/dist/metric-helpers.cjs.map +1 -1
  221. package/dist/metric-helpers.d.cts +4 -2
  222. package/dist/metric-helpers.d.cts.map +1 -0
  223. package/dist/metric-helpers.d.ts +4 -2
  224. package/dist/metric-helpers.d.ts.map +1 -0
  225. package/dist/metric-helpers.js +24 -4
  226. package/dist/metric-helpers.js.map +1 -1
  227. package/dist/metric-testing-DXdK3-Q3.d.ts +106 -0
  228. package/dist/metric-testing-DXdK3-Q3.d.ts.map +1 -0
  229. package/dist/metric-testing-MxvzChDp.d.cts +106 -0
  230. package/dist/metric-testing-MxvzChDp.d.cts.map +1 -0
  231. package/dist/metric-testing.cjs +93 -17
  232. package/dist/metric-testing.cjs.map +1 -1
  233. package/dist/metric-testing.d.cts +2 -110
  234. package/dist/metric-testing.d.ts +2 -110
  235. package/dist/metric-testing.js +91 -2
  236. package/dist/metric-testing.js.map +1 -1
  237. package/dist/metric.cjs +306 -22
  238. package/dist/metric.cjs.map +1 -1
  239. package/dist/metric.d.cts +170 -198
  240. package/dist/metric.d.cts.map +1 -0
  241. package/dist/metric.d.ts +170 -198
  242. package/dist/metric.d.ts.map +1 -0
  243. package/dist/metric.js +277 -7
  244. package/dist/metric.js.map +1 -1
  245. package/dist/node-require-DF5QBX6z.cjs +99 -0
  246. package/dist/node-require-DF5QBX6z.cjs.map +1 -0
  247. package/dist/node-require-Db1oDpLj.js +88 -0
  248. package/dist/node-require-Db1oDpLj.js.map +1 -0
  249. package/dist/operation-context-C-2hmmtP.js +59 -0
  250. package/dist/operation-context-C-2hmmtP.js.map +1 -0
  251. package/dist/operation-context-n4_obUwq.cjs +70 -0
  252. package/dist/operation-context-n4_obUwq.cjs.map +1 -0
  253. package/dist/parse-error.cjs +55 -9
  254. package/dist/parse-error.cjs.map +1 -1
  255. package/dist/parse-error.d.cts +12 -10
  256. package/dist/parse-error.d.cts.map +1 -0
  257. package/dist/parse-error.d.ts +12 -10
  258. package/dist/parse-error.d.ts.map +1 -0
  259. package/dist/parse-error.js +55 -2
  260. package/dist/parse-error.js.map +1 -1
  261. package/dist/pretty-console-exporter-CMzlrRNg.cjs +232 -0
  262. package/dist/pretty-console-exporter-CMzlrRNg.cjs.map +1 -0
  263. package/dist/pretty-console-exporter-DqKl_q9z.js +227 -0
  264. package/dist/pretty-console-exporter-DqKl_q9z.js.map +1 -0
  265. package/dist/processors.cjs +13 -17
  266. package/dist/processors.d.cts +3 -171
  267. package/dist/processors.d.ts +3 -171
  268. package/dist/processors.js +4 -4
  269. package/dist/register.cjs +35 -6
  270. package/dist/register.cjs.map +1 -1
  271. package/dist/register.d.cts +1 -2
  272. package/dist/register.d.ts +1 -2
  273. package/dist/register.js +36 -3
  274. package/dist/register.js.map +1 -1
  275. package/dist/registry-DfXA3R1L.js +184 -0
  276. package/dist/registry-DfXA3R1L.js.map +1 -0
  277. package/dist/registry-JZg2J3RZ.cjs +334 -0
  278. package/dist/registry-JZg2J3RZ.cjs.map +1 -0
  279. package/dist/sampling-CR0Va1VB.d.ts +351 -0
  280. package/dist/sampling-CR0Va1VB.d.ts.map +1 -0
  281. package/dist/sampling-DfYhDJij.d.cts +351 -0
  282. package/dist/sampling-DfYhDJij.d.cts.map +1 -0
  283. package/dist/sampling.cjs +452 -60
  284. package/dist/sampling.cjs.map +1 -1
  285. package/dist/sampling.d.cts +2 -379
  286. package/dist/sampling.d.ts +2 -379
  287. package/dist/sampling.js +441 -5
  288. package/dist/sampling.js.map +1 -1
  289. package/dist/security-schema.cjs +65 -46
  290. package/dist/security-schema.cjs.map +1 -1
  291. package/dist/security-schema.d.cts +23 -26
  292. package/dist/security-schema.d.cts.map +1 -0
  293. package/dist/security-schema.d.ts +23 -26
  294. package/dist/security-schema.d.ts.map +1 -0
  295. package/dist/security-schema.js +64 -45
  296. package/dist/security-schema.js.map +1 -1
  297. package/dist/semantic-conventions-FhSxv-bK.d.cts +32 -0
  298. package/dist/semantic-conventions-FhSxv-bK.d.cts.map +1 -0
  299. package/dist/semantic-conventions-FhSxv-bK.d.ts +32 -0
  300. package/dist/semantic-conventions-FhSxv-bK.d.ts.map +1 -0
  301. package/dist/semantic-conventions.cjs +15 -26
  302. package/dist/semantic-conventions.cjs.map +1 -1
  303. package/dist/semantic-conventions.d.cts +2 -29
  304. package/dist/semantic-conventions.d.ts +2 -29
  305. package/dist/semantic-conventions.js +12 -3
  306. package/dist/semantic-conventions.js.map +1 -1
  307. package/dist/semantic-helpers.cjs +440 -38
  308. package/dist/semantic-helpers.cjs.map +1 -1
  309. package/dist/semantic-helpers.d.cts +38 -45
  310. package/dist/semantic-helpers.d.cts.map +1 -0
  311. package/dist/semantic-helpers.d.ts +38 -45
  312. package/dist/semantic-helpers.d.ts.map +1 -0
  313. package/dist/semantic-helpers.js +438 -19
  314. package/dist/semantic-helpers.js.map +1 -1
  315. package/dist/span-name-normalizer-8ZOGJuwv.d.cts +70 -0
  316. package/dist/span-name-normalizer-8ZOGJuwv.d.cts.map +1 -0
  317. package/dist/span-name-normalizer-8ZOGJuwv.d.ts +70 -0
  318. package/dist/span-name-normalizer-8ZOGJuwv.d.ts.map +1 -0
  319. package/dist/span-name-normalizer.cjs +95 -17
  320. package/dist/span-name-normalizer.cjs.map +1 -1
  321. package/dist/span-name-normalizer.d.cts +2 -94
  322. package/dist/span-name-normalizer.d.ts +2 -94
  323. package/dist/span-name-normalizer.js +93 -2
  324. package/dist/span-name-normalizer.js.map +1 -1
  325. package/dist/stable-hash-BNTMrmdB.cjs +28 -0
  326. package/dist/stable-hash-BNTMrmdB.cjs.map +1 -0
  327. package/dist/stable-hash-Cg5cT34Q.js +23 -0
  328. package/dist/stable-hash-Cg5cT34Q.js.map +1 -0
  329. package/dist/structured-error-9--cxBay.js +143 -0
  330. package/dist/structured-error-9--cxBay.js.map +1 -0
  331. package/dist/structured-error-CHg7DoIQ.cjs +178 -0
  332. package/dist/structured-error-CHg7DoIQ.cjs.map +1 -0
  333. package/dist/tail-sampling-processor.cjs +26 -13
  334. package/dist/tail-sampling-processor.cjs.map +1 -1
  335. package/dist/tail-sampling-processor.d.cts +11 -23
  336. package/dist/tail-sampling-processor.d.cts.map +1 -0
  337. package/dist/tail-sampling-processor.d.ts +11 -23
  338. package/dist/tail-sampling-processor.d.ts.map +1 -0
  339. package/dist/tail-sampling-processor.js +27 -6
  340. package/dist/tail-sampling-processor.js.map +1 -1
  341. package/dist/test-span-collector.cjs +70 -72
  342. package/dist/test-span-collector.cjs.map +1 -1
  343. package/dist/test-span-collector.d.cts +25 -43
  344. package/dist/test-span-collector.d.cts.map +1 -0
  345. package/dist/test-span-collector.d.ts +25 -43
  346. package/dist/test-span-collector.d.ts.map +1 -0
  347. package/dist/test-span-collector.js +69 -70
  348. package/dist/test-span-collector.js.map +1 -1
  349. package/dist/testing.cjs +389 -278
  350. package/dist/testing.cjs.map +1 -1
  351. package/dist/testing.d.cts +39 -62
  352. package/dist/testing.d.cts.map +1 -0
  353. package/dist/testing.d.ts +39 -62
  354. package/dist/testing.d.ts.map +1 -0
  355. package/dist/testing.js +386 -265
  356. package/dist/testing.js.map +1 -1
  357. package/dist/trace-context-Cijqoi6e.d.cts +212 -0
  358. package/dist/trace-context-Cijqoi6e.d.cts.map +1 -0
  359. package/dist/trace-context-Cijqoi6e.d.ts +212 -0
  360. package/dist/trace-context-Cijqoi6e.d.ts.map +1 -0
  361. package/dist/trace-helpers.cjs +634 -54
  362. package/dist/trace-helpers.cjs.map +1 -1
  363. package/dist/trace-helpers.d.cts +17 -49
  364. package/dist/trace-helpers.d.cts.map +1 -0
  365. package/dist/trace-helpers.d.ts +17 -49
  366. package/dist/trace-helpers.d.ts.map +1 -0
  367. package/dist/trace-helpers.js +624 -3
  368. package/dist/trace-helpers.js.map +1 -1
  369. package/dist/tracer-provider.cjs +227 -16
  370. package/dist/tracer-provider.cjs.map +1 -1
  371. package/dist/tracer-provider.d.cts +5 -4
  372. package/dist/tracer-provider.d.cts.map +1 -0
  373. package/dist/tracer-provider.d.ts +5 -4
  374. package/dist/tracer-provider.d.ts.map +1 -0
  375. package/dist/tracer-provider.js +227 -2
  376. package/dist/tracer-provider.js.map +1 -1
  377. package/dist/track-3HY4NGV-.cjs +1212 -0
  378. package/dist/track-3HY4NGV-.cjs.map +1 -0
  379. package/dist/track-nsKVy-pj.js +1111 -0
  380. package/dist/track-nsKVy-pj.js.map +1 -0
  381. package/dist/validate.cjs +201 -0
  382. package/dist/validate.cjs.map +1 -0
  383. package/dist/validate.d.cts +105 -0
  384. package/dist/validate.d.cts.map +1 -0
  385. package/dist/validate.d.ts +105 -0
  386. package/dist/validate.d.ts.map +1 -0
  387. package/dist/validate.js +197 -0
  388. package/dist/validate.js.map +1 -0
  389. package/dist/validation-attributes.cjs +45 -0
  390. package/dist/validation-attributes.cjs.map +1 -0
  391. package/dist/validation-attributes.d.cts +33 -0
  392. package/dist/validation-attributes.d.cts.map +1 -0
  393. package/dist/validation-attributes.d.ts +33 -0
  394. package/dist/validation-attributes.d.ts.map +1 -0
  395. package/dist/validation-attributes.js +41 -0
  396. package/dist/validation-attributes.js.map +1 -0
  397. package/dist/webhook.cjs +286 -255
  398. package/dist/webhook.cjs.map +1 -1
  399. package/dist/webhook.d.cts +157 -192
  400. package/dist/webhook.d.cts.map +1 -0
  401. package/dist/webhook.d.ts +157 -192
  402. package/dist/webhook.d.ts.map +1 -0
  403. package/dist/webhook.js +285 -253
  404. package/dist/webhook.js.map +1 -1
  405. package/dist/workflow-distributed.cjs +498 -411
  406. package/dist/workflow-distributed.cjs.map +1 -1
  407. package/dist/workflow-distributed.d.cts +163 -173
  408. package/dist/workflow-distributed.d.cts.map +1 -0
  409. package/dist/workflow-distributed.d.ts +163 -173
  410. package/dist/workflow-distributed.d.ts.map +1 -0
  411. package/dist/workflow-distributed.js +497 -409
  412. package/dist/workflow-distributed.js.map +1 -1
  413. package/dist/workflow.cjs +405 -39
  414. package/dist/workflow.cjs.map +1 -1
  415. package/dist/workflow.d.cts +78 -131
  416. package/dist/workflow.d.cts.map +1 -0
  417. package/dist/workflow.d.ts +78 -131
  418. package/dist/workflow.d.ts.map +1 -0
  419. package/dist/workflow.js +403 -20
  420. package/dist/workflow.js.map +1 -1
  421. package/dist/yaml-config-B3dQ82GR.cjs +272 -0
  422. package/dist/yaml-config-B3dQ82GR.cjs.map +1 -0
  423. package/dist/yaml-config.cjs +5 -24
  424. package/dist/yaml-config.d.cts +30 -64
  425. package/dist/yaml-config.d.cts.map +1 -0
  426. package/dist/yaml-config.d.ts +30 -64
  427. package/dist/yaml-config.d.ts.map +1 -0
  428. package/dist/yaml-config.js +226 -7
  429. package/dist/yaml-config.js.map +1 -1
  430. package/package.json +14 -4
  431. package/src/define-event.ts +2 -21
  432. package/src/index.ts +3 -0
  433. package/src/request-logger.test.ts +53 -1
  434. package/src/request-logger.ts +58 -0
  435. package/src/stable-hash.ts +27 -0
  436. package/src/validate.test.ts +287 -0
  437. package/src/validate.ts +307 -0
  438. package/src/validation-attributes.ts +43 -0
  439. package/dist/attributes.cjs.map +0 -1
  440. package/dist/attributes.js.map +0 -1
  441. package/dist/chunk-2ZKEORFN.cjs +0 -14
  442. package/dist/chunk-2ZKEORFN.cjs.map +0 -1
  443. package/dist/chunk-3QXBFGKP.js +0 -344
  444. package/dist/chunk-3QXBFGKP.js.map +0 -1
  445. package/dist/chunk-454CH4OV.js +0 -744
  446. package/dist/chunk-454CH4OV.js.map +0 -1
  447. package/dist/chunk-4A53YIAX.js +0 -180
  448. package/dist/chunk-4A53YIAX.js.map +0 -1
  449. package/dist/chunk-4IFSYQVX.js +0 -337
  450. package/dist/chunk-4IFSYQVX.js.map +0 -1
  451. package/dist/chunk-4P6ZOARG.cjs +0 -33
  452. package/dist/chunk-4P6ZOARG.cjs.map +0 -1
  453. package/dist/chunk-55ER2KD5.js +0 -228
  454. package/dist/chunk-55ER2KD5.js.map +0 -1
  455. package/dist/chunk-5ZN622AO.js +0 -73
  456. package/dist/chunk-5ZN622AO.js.map +0 -1
  457. package/dist/chunk-6S5RUKU3.cjs +0 -347
  458. package/dist/chunk-6S5RUKU3.cjs.map +0 -1
  459. package/dist/chunk-6UQRVUN3.js +0 -222
  460. package/dist/chunk-6UQRVUN3.js.map +0 -1
  461. package/dist/chunk-7552UTQW.js +0 -11
  462. package/dist/chunk-7552UTQW.js.map +0 -1
  463. package/dist/chunk-7EQ4G4SI.cjs +0 -146
  464. package/dist/chunk-7EQ4G4SI.cjs.map +0 -1
  465. package/dist/chunk-7SAWIN74.js +0 -285
  466. package/dist/chunk-7SAWIN74.js.map +0 -1
  467. package/dist/chunk-A4E5AQFK.js +0 -30
  468. package/dist/chunk-A4E5AQFK.js.map +0 -1
  469. package/dist/chunk-AC5GNZKB.cjs +0 -344
  470. package/dist/chunk-AC5GNZKB.cjs.map +0 -1
  471. package/dist/chunk-ALPYR2GC.js +0 -1061
  472. package/dist/chunk-ALPYR2GC.js.map +0 -1
  473. package/dist/chunk-BZHG5IZ4.js +0 -73
  474. package/dist/chunk-BZHG5IZ4.js.map +0 -1
  475. package/dist/chunk-CEAQK2QY.cjs +0 -32
  476. package/dist/chunk-CEAQK2QY.cjs.map +0 -1
  477. package/dist/chunk-CMHVQR6P.js +0 -170
  478. package/dist/chunk-CMHVQR6P.js.map +0 -1
  479. package/dist/chunk-CU6IDACR.cjs +0 -224
  480. package/dist/chunk-CU6IDACR.cjs.map +0 -1
  481. package/dist/chunk-DPSA4QLA.js +0 -344
  482. package/dist/chunk-DPSA4QLA.js.map +0 -1
  483. package/dist/chunk-DQEHQNQE.js +0 -795
  484. package/dist/chunk-DQEHQNQE.js.map +0 -1
  485. package/dist/chunk-ESLWRGAG.cjs +0 -92
  486. package/dist/chunk-ESLWRGAG.cjs.map +0 -1
  487. package/dist/chunk-ESMHTKLJ.cjs +0 -206
  488. package/dist/chunk-ESMHTKLJ.cjs.map +0 -1
  489. package/dist/chunk-FGNDN2FD.cjs +0 -1242
  490. package/dist/chunk-FGNDN2FD.cjs.map +0 -1
  491. package/dist/chunk-FU6R566Y.cjs +0 -236
  492. package/dist/chunk-FU6R566Y.cjs.map +0 -1
  493. package/dist/chunk-GBFTC7Q7.cjs +0 -837
  494. package/dist/chunk-GBFTC7Q7.cjs.map +0 -1
  495. package/dist/chunk-GYR5K654.js +0 -91
  496. package/dist/chunk-GYR5K654.js.map +0 -1
  497. package/dist/chunk-HA2WBOGQ.js +0 -57
  498. package/dist/chunk-HA2WBOGQ.js.map +0 -1
  499. package/dist/chunk-HT5JQKN2.js +0 -118
  500. package/dist/chunk-HT5JQKN2.js.map +0 -1
  501. package/dist/chunk-INJD3G4K.cjs +0 -340
  502. package/dist/chunk-INJD3G4K.cjs.map +0 -1
  503. package/dist/chunk-IOYFAFHJ.cjs +0 -95
  504. package/dist/chunk-IOYFAFHJ.cjs.map +0 -1
  505. package/dist/chunk-J5QENANM.js +0 -87
  506. package/dist/chunk-J5QENANM.js.map +0 -1
  507. package/dist/chunk-J7VGRIAJ.js +0 -64
  508. package/dist/chunk-J7VGRIAJ.js.map +0 -1
  509. package/dist/chunk-KFOHQK7X.js +0 -144
  510. package/dist/chunk-KFOHQK7X.js.map +0 -1
  511. package/dist/chunk-KIL5CUN6.js +0 -31
  512. package/dist/chunk-KIL5CUN6.js.map +0 -1
  513. package/dist/chunk-LITNXTTT.js +0 -3
  514. package/dist/chunk-LITNXTTT.js.map +0 -1
  515. package/dist/chunk-M3LFHHTN.cjs +0 -764
  516. package/dist/chunk-M3LFHHTN.cjs.map +0 -1
  517. package/dist/chunk-NEIB3TLD.cjs +0 -360
  518. package/dist/chunk-NEIB3TLD.cjs.map +0 -1
  519. package/dist/chunk-NVAI5CCN.cjs +0 -39
  520. package/dist/chunk-NVAI5CCN.cjs.map +0 -1
  521. package/dist/chunk-NVGPMGI4.js +0 -95
  522. package/dist/chunk-NVGPMGI4.js.map +0 -1
  523. package/dist/chunk-NZ72VDNY.cjs +0 -4
  524. package/dist/chunk-NZ72VDNY.cjs.map +0 -1
  525. package/dist/chunk-O4JZUCUE.js +0 -1174
  526. package/dist/chunk-O4JZUCUE.js.map +0 -1
  527. package/dist/chunk-O7JOKRN2.js +0 -833
  528. package/dist/chunk-O7JOKRN2.js.map +0 -1
  529. package/dist/chunk-OPPXYVEZ.cjs +0 -131
  530. package/dist/chunk-OPPXYVEZ.cjs.map +0 -1
  531. package/dist/chunk-Q4EULJQY.js +0 -35
  532. package/dist/chunk-Q4EULJQY.js.map +0 -1
  533. package/dist/chunk-QWW3E3JM.cjs +0 -178
  534. package/dist/chunk-QWW3E3JM.cjs.map +0 -1
  535. package/dist/chunk-R7QYGZUP.cjs +0 -1075
  536. package/dist/chunk-R7QYGZUP.cjs.map +0 -1
  537. package/dist/chunk-RUPKBKUF.js +0 -352
  538. package/dist/chunk-RUPKBKUF.js.map +0 -1
  539. package/dist/chunk-SEO6NAQT.js +0 -14
  540. package/dist/chunk-SEO6NAQT.js.map +0 -1
  541. package/dist/chunk-T4B5LB6E.cjs +0 -66
  542. package/dist/chunk-T4B5LB6E.cjs.map +0 -1
  543. package/dist/chunk-TC5ZPWM4.cjs +0 -289
  544. package/dist/chunk-TC5ZPWM4.cjs.map +0 -1
  545. package/dist/chunk-TQ5UWA7S.js +0 -26
  546. package/dist/chunk-TQ5UWA7S.js.map +0 -1
  547. package/dist/chunk-URHPSJW2.js +0 -339
  548. package/dist/chunk-URHPSJW2.js.map +0 -1
  549. package/dist/chunk-UY3UYPBZ.cjs +0 -77
  550. package/dist/chunk-UY3UYPBZ.cjs.map +0 -1
  551. package/dist/chunk-VG2ABKJX.cjs +0 -100
  552. package/dist/chunk-VG2ABKJX.cjs.map +0 -1
  553. package/dist/chunk-VH77IPJN.cjs +0 -358
  554. package/dist/chunk-VH77IPJN.cjs.map +0 -1
  555. package/dist/chunk-VQTCQKHQ.cjs +0 -17
  556. package/dist/chunk-VQTCQKHQ.cjs.map +0 -1
  557. package/dist/chunk-WGWSHJ2N.js +0 -38
  558. package/dist/chunk-WGWSHJ2N.js.map +0 -1
  559. package/dist/chunk-WJH6IYU2.cjs +0 -32
  560. package/dist/chunk-WJH6IYU2.cjs.map +0 -1
  561. package/dist/chunk-YREV3LGG.cjs +0 -61
  562. package/dist/chunk-YREV3LGG.cjs.map +0 -1
  563. package/dist/chunk-YTXEZ4SD.cjs +0 -77
  564. package/dist/chunk-YTXEZ4SD.cjs.map +0 -1
  565. package/dist/chunk-YWCESU4Y.js +0 -1233
  566. package/dist/chunk-YWCESU4Y.js.map +0 -1
  567. package/dist/chunk-Z6HRSM2Y.cjs +0 -799
  568. package/dist/chunk-Z6HRSM2Y.cjs.map +0 -1
  569. package/dist/chunk-Z7PW3KHL.cjs +0 -1198
  570. package/dist/chunk-Z7PW3KHL.cjs.map +0 -1
  571. package/dist/chunk-ZNMBW67B.cjs +0 -40
  572. package/dist/chunk-ZNMBW67B.cjs.map +0 -1
  573. package/dist/correlation-id.cjs.map +0 -1
  574. package/dist/correlation-id.js.map +0 -1
  575. package/dist/event-subscriber.cjs.map +0 -1
  576. package/dist/event-subscriber.js.map +0 -1
  577. package/dist/event.cjs.map +0 -1
  578. package/dist/event.js.map +0 -1
  579. package/dist/exporters.cjs.map +0 -1
  580. package/dist/exporters.js.map +0 -1
  581. package/dist/functional.cjs.map +0 -1
  582. package/dist/functional.js.map +0 -1
  583. package/dist/init-DIowiiCh.d.ts +0 -1167
  584. package/dist/init-j-A1zI16.d.cts +0 -1167
  585. package/dist/processors.cjs.map +0 -1
  586. package/dist/processors.js.map +0 -1
  587. package/dist/trace-context-DbGKd1Rn.d.cts +0 -213
  588. package/dist/trace-context-DbGKd1Rn.d.ts +0 -213
  589. package/dist/utils-BahBCFtJ.d.cts +0 -712
  590. package/dist/utils-CLKwaUlG.d.ts +0 -712
  591. package/dist/yaml-config.cjs.map +0 -1
@@ -0,0 +1,232 @@
1
+ let _opentelemetry_api = require("@opentelemetry/api");
2
+
3
+ //#region src/pretty-console-exporter.ts
4
+ /**
5
+ * Export result code constants (avoid importing @opentelemetry/core)
6
+ */
7
+ const ExportResultCode = {
8
+ SUCCESS: 0,
9
+ FAILED: 1
10
+ };
11
+ /**
12
+ * ANSI escape codes for terminal colors (zero dependencies)
13
+ */
14
+ const ANSI = {
15
+ reset: "\x1B[0m",
16
+ bold: "\x1B[1m",
17
+ dim: "\x1B[2m",
18
+ green: "\x1B[32m",
19
+ red: "\x1B[31m",
20
+ yellow: "\x1B[33m",
21
+ blue: "\x1B[34m",
22
+ cyan: "\x1B[36m",
23
+ gray: "\x1B[90m"
24
+ };
25
+ /**
26
+ * Pretty Console Exporter - colorized, hierarchical span output for development
27
+ *
28
+ * Features:
29
+ * - Colorized status indicators (✓ green, ✗ red)
30
+ * - Duration with color coding (fast=green, medium=yellow, slow=red)
31
+ * - Hierarchical tree view showing parent-child relationships
32
+ * - Attribute display with truncation
33
+ * - Error message highlighting
34
+ */
35
+ var PrettyConsoleExporter = class {
36
+ options;
37
+ constructor(options = {}) {
38
+ this.options = {
39
+ colors: options.colors ?? process.stdout?.isTTY ?? false,
40
+ showAttributes: options.showAttributes ?? true,
41
+ maxValueLength: options.maxValueLength ?? 50,
42
+ showScope: options.showScope ?? true,
43
+ hideAttributes: options.hideAttributes ?? [],
44
+ showTraceId: options.showTraceId ?? false
45
+ };
46
+ }
47
+ /**
48
+ * Export spans with pretty formatting
49
+ */
50
+ export(spans, resultCallback) {
51
+ if (spans.length === 0) {
52
+ resultCallback({ code: ExportResultCode.SUCCESS });
53
+ return;
54
+ }
55
+ try {
56
+ const traceGroups = this.groupByTrace(spans);
57
+ for (const [traceId, traceSpans] of traceGroups) this.printTrace(traceId, traceSpans);
58
+ resultCallback({ code: ExportResultCode.SUCCESS });
59
+ } catch {
60
+ resultCallback({ code: ExportResultCode.SUCCESS });
61
+ }
62
+ }
63
+ /**
64
+ * Group spans by their trace ID
65
+ */
66
+ groupByTrace(spans) {
67
+ const groups = /* @__PURE__ */ new Map();
68
+ for (const span of spans) {
69
+ const traceId = span.spanContext().traceId;
70
+ const group = groups.get(traceId) ?? [];
71
+ group.push(span);
72
+ groups.set(traceId, group);
73
+ }
74
+ return groups;
75
+ }
76
+ /**
77
+ * Print a single trace with all its spans as a tree
78
+ */
79
+ printTrace(traceId, spans) {
80
+ const sorted = [...spans].toSorted((a, b) => {
81
+ return hrTimeToMs(a.startTime) - hrTimeToMs(b.startTime);
82
+ });
83
+ const tree = this.buildSpanTree(sorted);
84
+ if (this.options.showTraceId && tree.length > 0) console.log(this.color(`trace: ${traceId}`, "gray"));
85
+ for (const node of tree) this.printNode(node, 0, false);
86
+ console.log("");
87
+ }
88
+ /**
89
+ * Build a tree structure from flat spans using parent-child relationships
90
+ */
91
+ buildSpanTree(spans) {
92
+ const spanMap = /* @__PURE__ */ new Map();
93
+ const roots = [];
94
+ for (const span of spans) {
95
+ const spanId = span.spanContext().spanId;
96
+ spanMap.set(spanId, {
97
+ span,
98
+ children: []
99
+ });
100
+ }
101
+ for (const span of spans) {
102
+ const spanId = span.spanContext().spanId;
103
+ const parentId = span.parentSpanContext?.spanId;
104
+ const node = spanMap.get(spanId);
105
+ if (parentId && spanMap.has(parentId)) spanMap.get(parentId).children.push(node);
106
+ else roots.push(node);
107
+ }
108
+ return roots;
109
+ }
110
+ /**
111
+ * Print a span node with indentation and tree characters
112
+ */
113
+ printNode(node, depth, isLast) {
114
+ const { span } = node;
115
+ const prefix = depth === 0 ? "" : " ".repeat(depth - 1) + (isLast ? "└─ " : "├─ ");
116
+ const isError = span.status.code === _opentelemetry_api.SpanStatusCode.ERROR;
117
+ const statusChar = isError ? "✗" : "✓";
118
+ const statusColor = isError ? "red" : "green";
119
+ const durationMs = hrTimeToMs(span.duration);
120
+ const durationStr = formatDuration(durationMs);
121
+ const durationColor = getDurationColor(durationMs);
122
+ const scopeName = this.options.showScope ? this.color(` [${this.getScopeName(span)}]`, "gray") : "";
123
+ const line = [
124
+ prefix,
125
+ this.color(statusChar, statusColor),
126
+ " ",
127
+ span.name.padEnd(Math.max(35 - prefix.length, 10)),
128
+ this.color(durationStr.padStart(8), durationColor),
129
+ scopeName
130
+ ].join("");
131
+ console.log(line);
132
+ if (this.options.showAttributes) {
133
+ const attrs = this.formatAttributes(span);
134
+ if (attrs) {
135
+ const attrIndent = " ".repeat(depth) + " ";
136
+ console.log(this.color(`${attrIndent}${attrs}`, "dim"));
137
+ }
138
+ }
139
+ if (isError && span.status.message) {
140
+ const errorIndent = " ".repeat(depth) + " ";
141
+ console.log(this.color(`${errorIndent}Error: ${span.status.message}`, "red"));
142
+ }
143
+ const childCount = node.children.length;
144
+ let index = 0;
145
+ for (const child of node.children) {
146
+ this.printNode(child, depth + 1, index === childCount - 1);
147
+ index++;
148
+ }
149
+ }
150
+ /**
151
+ * Get short scope name from instrumentation scope
152
+ */
153
+ getScopeName(span) {
154
+ const name = span.instrumentationScope?.name ?? "unknown";
155
+ const match = name.match(/@opentelemetry\/instrumentation-(.+)/);
156
+ if (match?.[1]) return match[1];
157
+ return name.split("/").at(-1) ?? name;
158
+ }
159
+ /**
160
+ * Format span attributes as a comma-separated string
161
+ */
162
+ formatAttributes(span) {
163
+ const attrs = span.attributes;
164
+ if (!attrs || Object.keys(attrs).length === 0) return "";
165
+ const pairs = [];
166
+ for (const [key, value] of Object.entries(attrs)) {
167
+ if (this.options.hideAttributes.includes(key)) continue;
168
+ if (value === void 0 || value === null) continue;
169
+ const strValue = this.truncate(Array.isArray(value) ? `[${value.join(", ")}]` : String(value), this.options.maxValueLength);
170
+ pairs.push(`${key}=${strValue}`);
171
+ }
172
+ return pairs.join(", ");
173
+ }
174
+ /**
175
+ * Truncate string to max length with ellipsis
176
+ */
177
+ truncate(str, max) {
178
+ if (str.length <= max) return str;
179
+ return str.slice(0, max - 3) + "...";
180
+ }
181
+ /**
182
+ * Apply ANSI color if colors are enabled
183
+ */
184
+ color(text, color) {
185
+ if (!this.options.colors) return text;
186
+ return `${ANSI[color]}${text}${ANSI.reset}`;
187
+ }
188
+ /**
189
+ * Shutdown (no-op for console exporter)
190
+ */
191
+ shutdown() {
192
+ return Promise.resolve();
193
+ }
194
+ /**
195
+ * Force flush (no-op for console exporter)
196
+ */
197
+ forceFlush() {
198
+ return Promise.resolve();
199
+ }
200
+ };
201
+ /**
202
+ * Convert HrTime [seconds, nanoseconds] to milliseconds
203
+ */
204
+ function hrTimeToMs(hrTime) {
205
+ const [seconds, nanos] = hrTime;
206
+ return seconds * 1e3 + nanos / 1e6;
207
+ }
208
+ /**
209
+ * Format duration with appropriate units
210
+ */
211
+ function formatDuration(ms) {
212
+ if (ms < 1) return `${(ms * 1e3).toFixed(0)}µs`;
213
+ if (ms < 1e3) return `${ms.toFixed(0)}ms`;
214
+ return `${(ms / 1e3).toFixed(2)}s`;
215
+ }
216
+ /**
217
+ * Get color based on duration (fast=green, medium=yellow, slow=red)
218
+ */
219
+ function getDurationColor(ms) {
220
+ if (ms < 100) return "green";
221
+ if (ms < 500) return "yellow";
222
+ return "red";
223
+ }
224
+
225
+ //#endregion
226
+ Object.defineProperty(exports, 'PrettyConsoleExporter', {
227
+ enumerable: true,
228
+ get: function () {
229
+ return PrettyConsoleExporter;
230
+ }
231
+ });
232
+ //# sourceMappingURL=pretty-console-exporter-CMzlrRNg.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pretty-console-exporter-CMzlrRNg.cjs","names":["SpanStatusCode"],"sources":["../src/pretty-console-exporter.ts"],"sourcesContent":["/**\n * Pretty Console Exporter\n *\n * A developer-friendly span exporter that displays colorized, hierarchical\n * trace output in the terminal. Zero external dependencies - uses ANSI escape codes.\n *\n * @example Basic usage\n * ```typescript\n * init({\n * service: 'my-app',\n * debug: 'pretty' // Uses PrettyConsoleExporter\n * })\n * ```\n *\n * @example Explicit usage with options\n * ```typescript\n * import { PrettyConsoleExporter } from 'autotel/exporters'\n *\n * init({\n * service: 'my-app',\n * spanExporters: [new PrettyConsoleExporter({\n * colors: true,\n * showAttributes: true,\n * hideAttributes: ['http.user_agent']\n * })]\n * })\n * ```\n */\n\nimport type { SpanExporter, ReadableSpan } from '@opentelemetry/sdk-trace-base';\nimport { SpanStatusCode } from '@opentelemetry/api';\n\n/**\n * Export result code constants (avoid importing @opentelemetry/core)\n */\nconst ExportResultCode = {\n SUCCESS: 0,\n FAILED: 1,\n} as const;\n\n/**\n * Export result type for SpanExporter callback\n */\ninterface ExportResult {\n code: number;\n error?: Error;\n}\n\n/**\n * ANSI escape codes for terminal colors (zero dependencies)\n */\nconst ANSI = {\n reset: '\\u001B[0m',\n bold: '\\u001B[1m',\n dim: '\\u001B[2m',\n green: '\\u001B[32m',\n red: '\\u001B[31m',\n yellow: '\\u001B[33m',\n blue: '\\u001B[34m',\n cyan: '\\u001B[36m',\n gray: '\\u001B[90m',\n} as const;\n\ntype AnsiColor = keyof typeof ANSI;\n\n/**\n * Configuration options for PrettyConsoleExporter\n */\nexport interface PrettyConsoleExporterOptions {\n /**\n * Enable ANSI colors in output\n * @default auto-detect TTY\n */\n colors?: boolean;\n\n /**\n * Show span attributes in output\n * @default true\n */\n showAttributes?: boolean;\n\n /**\n * Maximum length for attribute values before truncation\n * @default 50\n */\n maxValueLength?: number;\n\n /**\n * Show instrumentation scope name (e.g., [http], [pg])\n * @default true\n */\n showScope?: boolean;\n\n /**\n * Attribute keys to always hide from output\n * @default []\n */\n hideAttributes?: string[];\n\n /**\n * Show trace ID for each root span\n * @default false\n */\n showTraceId?: boolean;\n}\n\n/**\n * Internal node structure for building span trees\n */\ninterface SpanNode {\n span: ReadableSpan;\n children: SpanNode[];\n}\n\n/**\n * Pretty Console Exporter - colorized, hierarchical span output for development\n *\n * Features:\n * - Colorized status indicators (✓ green, ✗ red)\n * - Duration with color coding (fast=green, medium=yellow, slow=red)\n * - Hierarchical tree view showing parent-child relationships\n * - Attribute display with truncation\n * - Error message highlighting\n */\nexport class PrettyConsoleExporter implements SpanExporter {\n private readonly options: Required<PrettyConsoleExporterOptions>;\n\n constructor(options: PrettyConsoleExporterOptions = {}) {\n this.options = {\n colors: options.colors ?? process.stdout?.isTTY ?? false,\n showAttributes: options.showAttributes ?? true,\n maxValueLength: options.maxValueLength ?? 50,\n showScope: options.showScope ?? true,\n hideAttributes: options.hideAttributes ?? [],\n showTraceId: options.showTraceId ?? false,\n };\n }\n\n /**\n * Export spans with pretty formatting\n */\n export(\n spans: ReadableSpan[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (spans.length === 0) {\n resultCallback({ code: ExportResultCode.SUCCESS });\n return;\n }\n\n try {\n // Group spans by trace ID\n const traceGroups = this.groupByTrace(spans);\n\n // Print each trace group\n for (const [traceId, traceSpans] of traceGroups) {\n this.printTrace(traceId, traceSpans);\n }\n\n resultCallback({ code: ExportResultCode.SUCCESS });\n } catch {\n // Fail-open: don't crash the app if formatting fails\n resultCallback({ code: ExportResultCode.SUCCESS });\n }\n }\n\n /**\n * Group spans by their trace ID\n */\n private groupByTrace(spans: ReadableSpan[]): Map<string, ReadableSpan[]> {\n const groups = new Map<string, ReadableSpan[]>();\n\n for (const span of spans) {\n const traceId = span.spanContext().traceId;\n const group = groups.get(traceId) ?? [];\n group.push(span);\n groups.set(traceId, group);\n }\n\n return groups;\n }\n\n /**\n * Print a single trace with all its spans as a tree\n */\n private printTrace(traceId: string, spans: ReadableSpan[]): void {\n // Sort by start time\n const sorted = [...spans].toSorted((a, b) => {\n const aTime = hrTimeToMs(a.startTime);\n const bTime = hrTimeToMs(b.startTime);\n return aTime - bTime;\n });\n\n // Build tree structure\n const tree = this.buildSpanTree(sorted);\n\n // Print trace ID header if enabled\n if (this.options.showTraceId && tree.length > 0) {\n console.log(this.color(`trace: ${traceId}`, 'gray'));\n }\n\n // Print each root span and its children\n for (const node of tree) {\n this.printNode(node, 0, false);\n }\n\n // Add blank line between traces\n console.log('');\n }\n\n /**\n * Build a tree structure from flat spans using parent-child relationships\n */\n private buildSpanTree(spans: ReadableSpan[]): SpanNode[] {\n const spanMap = new Map<string, SpanNode>();\n const roots: SpanNode[] = [];\n\n // Create nodes for all spans\n for (const span of spans) {\n const spanId = span.spanContext().spanId;\n spanMap.set(spanId, { span, children: [] });\n }\n\n // Build parent-child relationships\n for (const span of spans) {\n const spanId = span.spanContext().spanId;\n const parentId = span.parentSpanContext?.spanId;\n const node = spanMap.get(spanId)!;\n\n if (parentId && spanMap.has(parentId)) {\n // Has parent in this batch - add as child\n spanMap.get(parentId)!.children.push(node);\n } else {\n // No parent or parent not in batch - treat as root\n roots.push(node);\n }\n }\n\n return roots;\n }\n\n /**\n * Print a span node with indentation and tree characters\n */\n private printNode(node: SpanNode, depth: number, isLast: boolean): void {\n const { span } = node;\n\n // Build tree prefix\n const prefix =\n depth === 0 ? '' : ' '.repeat(depth - 1) + (isLast ? '└─ ' : '├─ ');\n\n // Status indicator\n const isError = span.status.code === SpanStatusCode.ERROR;\n const statusChar = isError ? '✗' : '✓';\n const statusColor: AnsiColor = isError ? 'red' : 'green';\n\n // Duration formatting\n const durationMs = hrTimeToMs(span.duration);\n const durationStr = formatDuration(durationMs);\n const durationColor = getDurationColor(durationMs);\n\n // Scope name (instrumentation library)\n const scopeName = this.options.showScope\n ? this.color(` [${this.getScopeName(span)}]`, 'gray')\n : '';\n\n // Build the main line\n const line = [\n prefix,\n this.color(statusChar, statusColor),\n ' ',\n span.name.padEnd(Math.max(35 - prefix.length, 10)),\n this.color(durationStr.padStart(8), durationColor),\n scopeName,\n ].join('');\n\n console.log(line);\n\n // Print attributes on next line (indented)\n if (this.options.showAttributes) {\n const attrs = this.formatAttributes(span);\n if (attrs) {\n const attrIndent = ' '.repeat(depth) + ' ';\n console.log(this.color(`${attrIndent}${attrs}`, 'dim'));\n }\n }\n\n // Print error message if present\n if (isError && span.status.message) {\n const errorIndent = ' '.repeat(depth) + ' ';\n console.log(\n this.color(`${errorIndent}Error: ${span.status.message}`, 'red'),\n );\n }\n\n // Print children\n const childCount = node.children.length;\n let index = 0;\n for (const child of node.children) {\n this.printNode(child, depth + 1, index === childCount - 1);\n index++;\n }\n }\n\n /**\n * Get short scope name from instrumentation scope\n */\n private getScopeName(span: ReadableSpan): string {\n const name = span.instrumentationScope?.name ?? 'unknown';\n // Extract short name from @opentelemetry/instrumentation-xxx format\n const match = name.match(/@opentelemetry\\/instrumentation-(.+)/);\n if (match?.[1]) return match[1];\n // Fall back to last part of name or full name\n const lastPart = name.split('/').at(-1);\n return lastPart ?? name;\n }\n\n /**\n * Format span attributes as a comma-separated string\n */\n private formatAttributes(span: ReadableSpan): string {\n const attrs = span.attributes;\n if (!attrs || Object.keys(attrs).length === 0) {\n return '';\n }\n\n const pairs: string[] = [];\n for (const [key, value] of Object.entries(attrs)) {\n // Skip hidden attributes\n if (this.options.hideAttributes.includes(key)) continue;\n\n // Skip undefined/null values\n if (value === undefined || value === null) continue;\n\n // Format value\n const strValue = this.truncate(\n Array.isArray(value) ? `[${value.join(', ')}]` : String(value),\n this.options.maxValueLength,\n );\n pairs.push(`${key}=${strValue}`);\n }\n\n return pairs.join(', ');\n }\n\n /**\n * Truncate string to max length with ellipsis\n */\n private truncate(str: string, max: number): string {\n if (str.length <= max) return str;\n return str.slice(0, max - 3) + '...';\n }\n\n /**\n * Apply ANSI color if colors are enabled\n */\n private color(text: string, color: AnsiColor): string {\n if (!this.options.colors) return text;\n return `${ANSI[color]}${text}${ANSI.reset}`;\n }\n\n /**\n * Shutdown (no-op for console exporter)\n */\n shutdown(): Promise<void> {\n return Promise.resolve();\n }\n\n /**\n * Force flush (no-op for console exporter)\n */\n forceFlush(): Promise<void> {\n return Promise.resolve();\n }\n}\n\n/**\n * Convert HrTime [seconds, nanoseconds] to milliseconds\n */\nfunction hrTimeToMs(hrTime: [number, number]): number {\n const [seconds, nanos] = hrTime;\n return seconds * 1000 + nanos / 1_000_000;\n}\n\n/**\n * Format duration with appropriate units\n */\nfunction formatDuration(ms: number): string {\n if (ms < 1) {\n // Sub-millisecond: show as microseconds\n return `${(ms * 1000).toFixed(0)}µs`;\n }\n if (ms < 1000) {\n // Under 1 second: show as milliseconds\n return `${ms.toFixed(0)}ms`;\n }\n // 1 second or more: show as seconds\n return `${(ms / 1000).toFixed(2)}s`;\n}\n\n/**\n * Get color based on duration (fast=green, medium=yellow, slow=red)\n */\nfunction getDurationColor(ms: number): AnsiColor {\n if (ms < 100) return 'green';\n if (ms < 500) return 'yellow';\n return 'red';\n}\n\n/**\n * Export utility functions for testing\n */\nexport { formatDuration, getDurationColor, hrTimeToMs };\n"],"mappings":"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"}
@@ -0,0 +1,227 @@
1
+ import { SpanStatusCode } from "@opentelemetry/api";
2
+
3
+ //#region src/pretty-console-exporter.ts
4
+ /**
5
+ * Export result code constants (avoid importing @opentelemetry/core)
6
+ */
7
+ const ExportResultCode = {
8
+ SUCCESS: 0,
9
+ FAILED: 1
10
+ };
11
+ /**
12
+ * ANSI escape codes for terminal colors (zero dependencies)
13
+ */
14
+ const ANSI = {
15
+ reset: "\x1B[0m",
16
+ bold: "\x1B[1m",
17
+ dim: "\x1B[2m",
18
+ green: "\x1B[32m",
19
+ red: "\x1B[31m",
20
+ yellow: "\x1B[33m",
21
+ blue: "\x1B[34m",
22
+ cyan: "\x1B[36m",
23
+ gray: "\x1B[90m"
24
+ };
25
+ /**
26
+ * Pretty Console Exporter - colorized, hierarchical span output for development
27
+ *
28
+ * Features:
29
+ * - Colorized status indicators (✓ green, ✗ red)
30
+ * - Duration with color coding (fast=green, medium=yellow, slow=red)
31
+ * - Hierarchical tree view showing parent-child relationships
32
+ * - Attribute display with truncation
33
+ * - Error message highlighting
34
+ */
35
+ var PrettyConsoleExporter = class {
36
+ options;
37
+ constructor(options = {}) {
38
+ this.options = {
39
+ colors: options.colors ?? process.stdout?.isTTY ?? false,
40
+ showAttributes: options.showAttributes ?? true,
41
+ maxValueLength: options.maxValueLength ?? 50,
42
+ showScope: options.showScope ?? true,
43
+ hideAttributes: options.hideAttributes ?? [],
44
+ showTraceId: options.showTraceId ?? false
45
+ };
46
+ }
47
+ /**
48
+ * Export spans with pretty formatting
49
+ */
50
+ export(spans, resultCallback) {
51
+ if (spans.length === 0) {
52
+ resultCallback({ code: ExportResultCode.SUCCESS });
53
+ return;
54
+ }
55
+ try {
56
+ const traceGroups = this.groupByTrace(spans);
57
+ for (const [traceId, traceSpans] of traceGroups) this.printTrace(traceId, traceSpans);
58
+ resultCallback({ code: ExportResultCode.SUCCESS });
59
+ } catch {
60
+ resultCallback({ code: ExportResultCode.SUCCESS });
61
+ }
62
+ }
63
+ /**
64
+ * Group spans by their trace ID
65
+ */
66
+ groupByTrace(spans) {
67
+ const groups = /* @__PURE__ */ new Map();
68
+ for (const span of spans) {
69
+ const traceId = span.spanContext().traceId;
70
+ const group = groups.get(traceId) ?? [];
71
+ group.push(span);
72
+ groups.set(traceId, group);
73
+ }
74
+ return groups;
75
+ }
76
+ /**
77
+ * Print a single trace with all its spans as a tree
78
+ */
79
+ printTrace(traceId, spans) {
80
+ const sorted = [...spans].toSorted((a, b) => {
81
+ return hrTimeToMs(a.startTime) - hrTimeToMs(b.startTime);
82
+ });
83
+ const tree = this.buildSpanTree(sorted);
84
+ if (this.options.showTraceId && tree.length > 0) console.log(this.color(`trace: ${traceId}`, "gray"));
85
+ for (const node of tree) this.printNode(node, 0, false);
86
+ console.log("");
87
+ }
88
+ /**
89
+ * Build a tree structure from flat spans using parent-child relationships
90
+ */
91
+ buildSpanTree(spans) {
92
+ const spanMap = /* @__PURE__ */ new Map();
93
+ const roots = [];
94
+ for (const span of spans) {
95
+ const spanId = span.spanContext().spanId;
96
+ spanMap.set(spanId, {
97
+ span,
98
+ children: []
99
+ });
100
+ }
101
+ for (const span of spans) {
102
+ const spanId = span.spanContext().spanId;
103
+ const parentId = span.parentSpanContext?.spanId;
104
+ const node = spanMap.get(spanId);
105
+ if (parentId && spanMap.has(parentId)) spanMap.get(parentId).children.push(node);
106
+ else roots.push(node);
107
+ }
108
+ return roots;
109
+ }
110
+ /**
111
+ * Print a span node with indentation and tree characters
112
+ */
113
+ printNode(node, depth, isLast) {
114
+ const { span } = node;
115
+ const prefix = depth === 0 ? "" : " ".repeat(depth - 1) + (isLast ? "└─ " : "├─ ");
116
+ const isError = span.status.code === SpanStatusCode.ERROR;
117
+ const statusChar = isError ? "✗" : "✓";
118
+ const statusColor = isError ? "red" : "green";
119
+ const durationMs = hrTimeToMs(span.duration);
120
+ const durationStr = formatDuration(durationMs);
121
+ const durationColor = getDurationColor(durationMs);
122
+ const scopeName = this.options.showScope ? this.color(` [${this.getScopeName(span)}]`, "gray") : "";
123
+ const line = [
124
+ prefix,
125
+ this.color(statusChar, statusColor),
126
+ " ",
127
+ span.name.padEnd(Math.max(35 - prefix.length, 10)),
128
+ this.color(durationStr.padStart(8), durationColor),
129
+ scopeName
130
+ ].join("");
131
+ console.log(line);
132
+ if (this.options.showAttributes) {
133
+ const attrs = this.formatAttributes(span);
134
+ if (attrs) {
135
+ const attrIndent = " ".repeat(depth) + " ";
136
+ console.log(this.color(`${attrIndent}${attrs}`, "dim"));
137
+ }
138
+ }
139
+ if (isError && span.status.message) {
140
+ const errorIndent = " ".repeat(depth) + " ";
141
+ console.log(this.color(`${errorIndent}Error: ${span.status.message}`, "red"));
142
+ }
143
+ const childCount = node.children.length;
144
+ let index = 0;
145
+ for (const child of node.children) {
146
+ this.printNode(child, depth + 1, index === childCount - 1);
147
+ index++;
148
+ }
149
+ }
150
+ /**
151
+ * Get short scope name from instrumentation scope
152
+ */
153
+ getScopeName(span) {
154
+ const name = span.instrumentationScope?.name ?? "unknown";
155
+ const match = name.match(/@opentelemetry\/instrumentation-(.+)/);
156
+ if (match?.[1]) return match[1];
157
+ return name.split("/").at(-1) ?? name;
158
+ }
159
+ /**
160
+ * Format span attributes as a comma-separated string
161
+ */
162
+ formatAttributes(span) {
163
+ const attrs = span.attributes;
164
+ if (!attrs || Object.keys(attrs).length === 0) return "";
165
+ const pairs = [];
166
+ for (const [key, value] of Object.entries(attrs)) {
167
+ if (this.options.hideAttributes.includes(key)) continue;
168
+ if (value === void 0 || value === null) continue;
169
+ const strValue = this.truncate(Array.isArray(value) ? `[${value.join(", ")}]` : String(value), this.options.maxValueLength);
170
+ pairs.push(`${key}=${strValue}`);
171
+ }
172
+ return pairs.join(", ");
173
+ }
174
+ /**
175
+ * Truncate string to max length with ellipsis
176
+ */
177
+ truncate(str, max) {
178
+ if (str.length <= max) return str;
179
+ return str.slice(0, max - 3) + "...";
180
+ }
181
+ /**
182
+ * Apply ANSI color if colors are enabled
183
+ */
184
+ color(text, color) {
185
+ if (!this.options.colors) return text;
186
+ return `${ANSI[color]}${text}${ANSI.reset}`;
187
+ }
188
+ /**
189
+ * Shutdown (no-op for console exporter)
190
+ */
191
+ shutdown() {
192
+ return Promise.resolve();
193
+ }
194
+ /**
195
+ * Force flush (no-op for console exporter)
196
+ */
197
+ forceFlush() {
198
+ return Promise.resolve();
199
+ }
200
+ };
201
+ /**
202
+ * Convert HrTime [seconds, nanoseconds] to milliseconds
203
+ */
204
+ function hrTimeToMs(hrTime) {
205
+ const [seconds, nanos] = hrTime;
206
+ return seconds * 1e3 + nanos / 1e6;
207
+ }
208
+ /**
209
+ * Format duration with appropriate units
210
+ */
211
+ function formatDuration(ms) {
212
+ if (ms < 1) return `${(ms * 1e3).toFixed(0)}µs`;
213
+ if (ms < 1e3) return `${ms.toFixed(0)}ms`;
214
+ return `${(ms / 1e3).toFixed(2)}s`;
215
+ }
216
+ /**
217
+ * Get color based on duration (fast=green, medium=yellow, slow=red)
218
+ */
219
+ function getDurationColor(ms) {
220
+ if (ms < 100) return "green";
221
+ if (ms < 500) return "yellow";
222
+ return "red";
223
+ }
224
+
225
+ //#endregion
226
+ export { PrettyConsoleExporter as t };
227
+ //# sourceMappingURL=pretty-console-exporter-DqKl_q9z.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"pretty-console-exporter-DqKl_q9z.js","names":[],"sources":["../src/pretty-console-exporter.ts"],"sourcesContent":["/**\n * Pretty Console Exporter\n *\n * A developer-friendly span exporter that displays colorized, hierarchical\n * trace output in the terminal. Zero external dependencies - uses ANSI escape codes.\n *\n * @example Basic usage\n * ```typescript\n * init({\n * service: 'my-app',\n * debug: 'pretty' // Uses PrettyConsoleExporter\n * })\n * ```\n *\n * @example Explicit usage with options\n * ```typescript\n * import { PrettyConsoleExporter } from 'autotel/exporters'\n *\n * init({\n * service: 'my-app',\n * spanExporters: [new PrettyConsoleExporter({\n * colors: true,\n * showAttributes: true,\n * hideAttributes: ['http.user_agent']\n * })]\n * })\n * ```\n */\n\nimport type { SpanExporter, ReadableSpan } from '@opentelemetry/sdk-trace-base';\nimport { SpanStatusCode } from '@opentelemetry/api';\n\n/**\n * Export result code constants (avoid importing @opentelemetry/core)\n */\nconst ExportResultCode = {\n SUCCESS: 0,\n FAILED: 1,\n} as const;\n\n/**\n * Export result type for SpanExporter callback\n */\ninterface ExportResult {\n code: number;\n error?: Error;\n}\n\n/**\n * ANSI escape codes for terminal colors (zero dependencies)\n */\nconst ANSI = {\n reset: '\\u001B[0m',\n bold: '\\u001B[1m',\n dim: '\\u001B[2m',\n green: '\\u001B[32m',\n red: '\\u001B[31m',\n yellow: '\\u001B[33m',\n blue: '\\u001B[34m',\n cyan: '\\u001B[36m',\n gray: '\\u001B[90m',\n} as const;\n\ntype AnsiColor = keyof typeof ANSI;\n\n/**\n * Configuration options for PrettyConsoleExporter\n */\nexport interface PrettyConsoleExporterOptions {\n /**\n * Enable ANSI colors in output\n * @default auto-detect TTY\n */\n colors?: boolean;\n\n /**\n * Show span attributes in output\n * @default true\n */\n showAttributes?: boolean;\n\n /**\n * Maximum length for attribute values before truncation\n * @default 50\n */\n maxValueLength?: number;\n\n /**\n * Show instrumentation scope name (e.g., [http], [pg])\n * @default true\n */\n showScope?: boolean;\n\n /**\n * Attribute keys to always hide from output\n * @default []\n */\n hideAttributes?: string[];\n\n /**\n * Show trace ID for each root span\n * @default false\n */\n showTraceId?: boolean;\n}\n\n/**\n * Internal node structure for building span trees\n */\ninterface SpanNode {\n span: ReadableSpan;\n children: SpanNode[];\n}\n\n/**\n * Pretty Console Exporter - colorized, hierarchical span output for development\n *\n * Features:\n * - Colorized status indicators (✓ green, ✗ red)\n * - Duration with color coding (fast=green, medium=yellow, slow=red)\n * - Hierarchical tree view showing parent-child relationships\n * - Attribute display with truncation\n * - Error message highlighting\n */\nexport class PrettyConsoleExporter implements SpanExporter {\n private readonly options: Required<PrettyConsoleExporterOptions>;\n\n constructor(options: PrettyConsoleExporterOptions = {}) {\n this.options = {\n colors: options.colors ?? process.stdout?.isTTY ?? false,\n showAttributes: options.showAttributes ?? true,\n maxValueLength: options.maxValueLength ?? 50,\n showScope: options.showScope ?? true,\n hideAttributes: options.hideAttributes ?? [],\n showTraceId: options.showTraceId ?? false,\n };\n }\n\n /**\n * Export spans with pretty formatting\n */\n export(\n spans: ReadableSpan[],\n resultCallback: (result: ExportResult) => void,\n ): void {\n if (spans.length === 0) {\n resultCallback({ code: ExportResultCode.SUCCESS });\n return;\n }\n\n try {\n // Group spans by trace ID\n const traceGroups = this.groupByTrace(spans);\n\n // Print each trace group\n for (const [traceId, traceSpans] of traceGroups) {\n this.printTrace(traceId, traceSpans);\n }\n\n resultCallback({ code: ExportResultCode.SUCCESS });\n } catch {\n // Fail-open: don't crash the app if formatting fails\n resultCallback({ code: ExportResultCode.SUCCESS });\n }\n }\n\n /**\n * Group spans by their trace ID\n */\n private groupByTrace(spans: ReadableSpan[]): Map<string, ReadableSpan[]> {\n const groups = new Map<string, ReadableSpan[]>();\n\n for (const span of spans) {\n const traceId = span.spanContext().traceId;\n const group = groups.get(traceId) ?? [];\n group.push(span);\n groups.set(traceId, group);\n }\n\n return groups;\n }\n\n /**\n * Print a single trace with all its spans as a tree\n */\n private printTrace(traceId: string, spans: ReadableSpan[]): void {\n // Sort by start time\n const sorted = [...spans].toSorted((a, b) => {\n const aTime = hrTimeToMs(a.startTime);\n const bTime = hrTimeToMs(b.startTime);\n return aTime - bTime;\n });\n\n // Build tree structure\n const tree = this.buildSpanTree(sorted);\n\n // Print trace ID header if enabled\n if (this.options.showTraceId && tree.length > 0) {\n console.log(this.color(`trace: ${traceId}`, 'gray'));\n }\n\n // Print each root span and its children\n for (const node of tree) {\n this.printNode(node, 0, false);\n }\n\n // Add blank line between traces\n console.log('');\n }\n\n /**\n * Build a tree structure from flat spans using parent-child relationships\n */\n private buildSpanTree(spans: ReadableSpan[]): SpanNode[] {\n const spanMap = new Map<string, SpanNode>();\n const roots: SpanNode[] = [];\n\n // Create nodes for all spans\n for (const span of spans) {\n const spanId = span.spanContext().spanId;\n spanMap.set(spanId, { span, children: [] });\n }\n\n // Build parent-child relationships\n for (const span of spans) {\n const spanId = span.spanContext().spanId;\n const parentId = span.parentSpanContext?.spanId;\n const node = spanMap.get(spanId)!;\n\n if (parentId && spanMap.has(parentId)) {\n // Has parent in this batch - add as child\n spanMap.get(parentId)!.children.push(node);\n } else {\n // No parent or parent not in batch - treat as root\n roots.push(node);\n }\n }\n\n return roots;\n }\n\n /**\n * Print a span node with indentation and tree characters\n */\n private printNode(node: SpanNode, depth: number, isLast: boolean): void {\n const { span } = node;\n\n // Build tree prefix\n const prefix =\n depth === 0 ? '' : ' '.repeat(depth - 1) + (isLast ? '└─ ' : '├─ ');\n\n // Status indicator\n const isError = span.status.code === SpanStatusCode.ERROR;\n const statusChar = isError ? '✗' : '✓';\n const statusColor: AnsiColor = isError ? 'red' : 'green';\n\n // Duration formatting\n const durationMs = hrTimeToMs(span.duration);\n const durationStr = formatDuration(durationMs);\n const durationColor = getDurationColor(durationMs);\n\n // Scope name (instrumentation library)\n const scopeName = this.options.showScope\n ? this.color(` [${this.getScopeName(span)}]`, 'gray')\n : '';\n\n // Build the main line\n const line = [\n prefix,\n this.color(statusChar, statusColor),\n ' ',\n span.name.padEnd(Math.max(35 - prefix.length, 10)),\n this.color(durationStr.padStart(8), durationColor),\n scopeName,\n ].join('');\n\n console.log(line);\n\n // Print attributes on next line (indented)\n if (this.options.showAttributes) {\n const attrs = this.formatAttributes(span);\n if (attrs) {\n const attrIndent = ' '.repeat(depth) + ' ';\n console.log(this.color(`${attrIndent}${attrs}`, 'dim'));\n }\n }\n\n // Print error message if present\n if (isError && span.status.message) {\n const errorIndent = ' '.repeat(depth) + ' ';\n console.log(\n this.color(`${errorIndent}Error: ${span.status.message}`, 'red'),\n );\n }\n\n // Print children\n const childCount = node.children.length;\n let index = 0;\n for (const child of node.children) {\n this.printNode(child, depth + 1, index === childCount - 1);\n index++;\n }\n }\n\n /**\n * Get short scope name from instrumentation scope\n */\n private getScopeName(span: ReadableSpan): string {\n const name = span.instrumentationScope?.name ?? 'unknown';\n // Extract short name from @opentelemetry/instrumentation-xxx format\n const match = name.match(/@opentelemetry\\/instrumentation-(.+)/);\n if (match?.[1]) return match[1];\n // Fall back to last part of name or full name\n const lastPart = name.split('/').at(-1);\n return lastPart ?? name;\n }\n\n /**\n * Format span attributes as a comma-separated string\n */\n private formatAttributes(span: ReadableSpan): string {\n const attrs = span.attributes;\n if (!attrs || Object.keys(attrs).length === 0) {\n return '';\n }\n\n const pairs: string[] = [];\n for (const [key, value] of Object.entries(attrs)) {\n // Skip hidden attributes\n if (this.options.hideAttributes.includes(key)) continue;\n\n // Skip undefined/null values\n if (value === undefined || value === null) continue;\n\n // Format value\n const strValue = this.truncate(\n Array.isArray(value) ? `[${value.join(', ')}]` : String(value),\n this.options.maxValueLength,\n );\n pairs.push(`${key}=${strValue}`);\n }\n\n return pairs.join(', ');\n }\n\n /**\n * Truncate string to max length with ellipsis\n */\n private truncate(str: string, max: number): string {\n if (str.length <= max) return str;\n return str.slice(0, max - 3) + '...';\n }\n\n /**\n * Apply ANSI color if colors are enabled\n */\n private color(text: string, color: AnsiColor): string {\n if (!this.options.colors) return text;\n return `${ANSI[color]}${text}${ANSI.reset}`;\n }\n\n /**\n * Shutdown (no-op for console exporter)\n */\n shutdown(): Promise<void> {\n return Promise.resolve();\n }\n\n /**\n * Force flush (no-op for console exporter)\n */\n forceFlush(): Promise<void> {\n return Promise.resolve();\n }\n}\n\n/**\n * Convert HrTime [seconds, nanoseconds] to milliseconds\n */\nfunction hrTimeToMs(hrTime: [number, number]): number {\n const [seconds, nanos] = hrTime;\n return seconds * 1000 + nanos / 1_000_000;\n}\n\n/**\n * Format duration with appropriate units\n */\nfunction formatDuration(ms: number): string {\n if (ms < 1) {\n // Sub-millisecond: show as microseconds\n return `${(ms * 1000).toFixed(0)}µs`;\n }\n if (ms < 1000) {\n // Under 1 second: show as milliseconds\n return `${ms.toFixed(0)}ms`;\n }\n // 1 second or more: show as seconds\n return `${(ms / 1000).toFixed(2)}s`;\n}\n\n/**\n * Get color based on duration (fast=green, medium=yellow, slow=red)\n */\nfunction getDurationColor(ms: number): AnsiColor {\n if (ms < 100) return 'green';\n if (ms < 500) return 'yellow';\n return 'red';\n}\n\n/**\n * Export utility functions for testing\n */\nexport { formatDuration, getDurationColor, hrTimeToMs };\n"],"mappings":"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"}
@@ -1,21 +1,17 @@
1
- 'use strict';
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_canonical_log_line_processor = require('./canonical-log-line-processor--RlFDHhm.cjs');
3
+ let _opentelemetry_sdk_trace_base = require("@opentelemetry/sdk-trace-base");
2
4
 
3
- var chunk6S5RUKU3_cjs = require('./chunk-6S5RUKU3.cjs');
4
- var sdkTraceBase = require('@opentelemetry/sdk-trace-base');
5
-
6
-
7
-
8
- Object.defineProperty(exports, "CanonicalLogLineProcessor", {
5
+ Object.defineProperty(exports, 'BatchSpanProcessor', {
9
6
  enumerable: true,
10
- get: function () { return chunk6S5RUKU3_cjs.CanonicalLogLineProcessor; }
7
+ get: function () {
8
+ return _opentelemetry_sdk_trace_base.BatchSpanProcessor;
9
+ }
11
10
  });
12
- Object.defineProperty(exports, "BatchSpanProcessor", {
11
+ exports.CanonicalLogLineProcessor = require_canonical_log_line_processor.CanonicalLogLineProcessor;
12
+ Object.defineProperty(exports, 'SimpleSpanProcessor', {
13
13
  enumerable: true,
14
- get: function () { return sdkTraceBase.BatchSpanProcessor; }
15
- });
16
- Object.defineProperty(exports, "SimpleSpanProcessor", {
17
- enumerable: true,
18
- get: function () { return sdkTraceBase.SimpleSpanProcessor; }
19
- });
20
- //# sourceMappingURL=processors.cjs.map
21
- //# sourceMappingURL=processors.cjs.map
14
+ get: function () {
15
+ return _opentelemetry_sdk_trace_base.SimpleSpanProcessor;
16
+ }
17
+ });