autotel 3.6.0 → 4.0.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 (617) 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-CmYpdqCN.js +591 -0
  12. package/dist/attributes-CmYpdqCN.js.map +1 -0
  13. package/dist/attributes-PZ5doLgw.cjs +704 -0
  14. package/dist/attributes-PZ5doLgw.cjs.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 -54
  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 -17
  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 -66
  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 -64
  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 -37
  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 -21
  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 -57
  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 -20
  149. package/dist/http.cjs +276 -176
  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 -174
  156. package/dist/http.js.map +1 -1
  157. package/dist/index-Ck06vlW2.d.ts +678 -0
  158. package/dist/index-Ck06vlW2.d.ts.map +1 -0
  159. package/dist/index-eKuioqT1.d.cts +678 -0
  160. package/dist/index-eKuioqT1.d.cts.map +1 -0
  161. package/dist/index.cjs +751 -1218
  162. package/dist/index.cjs.map +1 -1
  163. package/dist/index.d.cts +341 -659
  164. package/dist/index.d.cts.map +1 -0
  165. package/dist/index.d.ts +341 -659
  166. package/dist/index.d.ts.map +1 -0
  167. package/dist/index.js +606 -737
  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 -36
  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 -21
  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-DVSmWg6Y.js +175 -0
  276. package/dist/registry-DVSmWg6Y.js.map +1 -0
  277. package/dist/registry-DYgvb62e.cjs +319 -0
  278. package/dist/registry-DYgvb62e.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 +327 -39
  308. package/dist/semantic-helpers.cjs.map +1 -1
  309. package/dist/semantic-helpers.d.cts +30 -150
  310. package/dist/semantic-helpers.d.cts.map +1 -0
  311. package/dist/semantic-helpers.d.ts +30 -150
  312. package/dist/semantic-helpers.d.ts.map +1 -0
  313. package/dist/semantic-helpers.js +326 -20
  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 +178 -115
  382. package/dist/validate.cjs.map +1 -1
  383. package/dist/validate.d.cts +40 -64
  384. package/dist/validate.d.cts.map +1 -0
  385. package/dist/validate.d.ts +40 -64
  386. package/dist/validate.d.ts.map +1 -0
  387. package/dist/validate.js +177 -113
  388. package/dist/validate.js.map +1 -1
  389. package/dist/validation-attributes.cjs +42 -17
  390. package/dist/validation-attributes.cjs.map +1 -1
  391. package/dist/validation-attributes.d.cts +13 -20
  392. package/dist/validation-attributes.d.cts.map +1 -0
  393. package/dist/validation-attributes.d.ts +13 -20
  394. package/dist/validation-attributes.d.ts.map +1 -0
  395. package/dist/validation-attributes.js +40 -2
  396. package/dist/validation-attributes.js.map +1 -1
  397. package/dist/webhook.cjs +286 -256
  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 -254
  404. package/dist/webhook.js.map +1 -1
  405. package/dist/workflow-distributed.cjs +498 -412
  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 -410
  412. package/dist/workflow-distributed.js.map +1 -1
  413. package/dist/workflow.cjs +405 -40
  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 -21
  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 +4 -4
  431. package/skills/analyze-traces/SKILL.md +14 -12
  432. package/skills/review-otel-patterns/SKILL.md +4 -2
  433. package/skills/tune-sampling/SKILL.md +8 -3
  434. package/src/attributes/builders.ts +2 -20
  435. package/src/attributes/index.ts +0 -1
  436. package/src/attributes/registry.ts +2 -9
  437. package/src/attributes/types.ts +0 -8
  438. package/src/index.ts +7 -41
  439. package/src/request-logger.test.ts +53 -1
  440. package/src/request-logger.ts +58 -0
  441. package/src/semantic-helpers.test.ts +2 -87
  442. package/src/semantic-helpers.ts +0 -146
  443. package/src/validate.test.ts +3 -1
  444. package/src/validate.ts +9 -3
  445. package/dist/attributes.cjs.map +0 -1
  446. package/dist/attributes.js.map +0 -1
  447. package/dist/chunk-2ZKEORFN.cjs +0 -14
  448. package/dist/chunk-2ZKEORFN.cjs.map +0 -1
  449. package/dist/chunk-3QXBFGKP.js +0 -344
  450. package/dist/chunk-3QXBFGKP.js.map +0 -1
  451. package/dist/chunk-454CH4OV.js +0 -744
  452. package/dist/chunk-454CH4OV.js.map +0 -1
  453. package/dist/chunk-4A53YIAX.js +0 -180
  454. package/dist/chunk-4A53YIAX.js.map +0 -1
  455. package/dist/chunk-4IFSYQVX.js +0 -337
  456. package/dist/chunk-4IFSYQVX.js.map +0 -1
  457. package/dist/chunk-4P6ZOARG.cjs +0 -33
  458. package/dist/chunk-4P6ZOARG.cjs.map +0 -1
  459. package/dist/chunk-55ER2KD5.js +0 -228
  460. package/dist/chunk-55ER2KD5.js.map +0 -1
  461. package/dist/chunk-5ZN622AO.js +0 -73
  462. package/dist/chunk-5ZN622AO.js.map +0 -1
  463. package/dist/chunk-66YJ66GG.js +0 -1021
  464. package/dist/chunk-66YJ66GG.js.map +0 -1
  465. package/dist/chunk-6S5RUKU3.cjs +0 -347
  466. package/dist/chunk-6S5RUKU3.cjs.map +0 -1
  467. package/dist/chunk-6UQRVUN3.js +0 -222
  468. package/dist/chunk-6UQRVUN3.js.map +0 -1
  469. package/dist/chunk-7552UTQW.js +0 -11
  470. package/dist/chunk-7552UTQW.js.map +0 -1
  471. package/dist/chunk-7EQ4G4SI.cjs +0 -146
  472. package/dist/chunk-7EQ4G4SI.cjs.map +0 -1
  473. package/dist/chunk-7SAWIN74.js +0 -285
  474. package/dist/chunk-7SAWIN74.js.map +0 -1
  475. package/dist/chunk-A4E5AQFK.js +0 -30
  476. package/dist/chunk-A4E5AQFK.js.map +0 -1
  477. package/dist/chunk-ALPYR2GC.js +0 -1061
  478. package/dist/chunk-ALPYR2GC.js.map +0 -1
  479. package/dist/chunk-B7SWBE4P.cjs +0 -799
  480. package/dist/chunk-B7SWBE4P.cjs.map +0 -1
  481. package/dist/chunk-BZHG5IZ4.js +0 -73
  482. package/dist/chunk-BZHG5IZ4.js.map +0 -1
  483. package/dist/chunk-CEAQK2QY.cjs +0 -32
  484. package/dist/chunk-CEAQK2QY.cjs.map +0 -1
  485. package/dist/chunk-CMHVQR6P.js +0 -170
  486. package/dist/chunk-CMHVQR6P.js.map +0 -1
  487. package/dist/chunk-CU6IDACR.cjs +0 -224
  488. package/dist/chunk-CU6IDACR.cjs.map +0 -1
  489. package/dist/chunk-D4TM63S3.js +0 -795
  490. package/dist/chunk-D4TM63S3.js.map +0 -1
  491. package/dist/chunk-DCEDJQGG.js +0 -28
  492. package/dist/chunk-DCEDJQGG.js.map +0 -1
  493. package/dist/chunk-DPSA4QLA.js +0 -344
  494. package/dist/chunk-DPSA4QLA.js.map +0 -1
  495. package/dist/chunk-E6TERL5O.cjs +0 -23
  496. package/dist/chunk-E6TERL5O.cjs.map +0 -1
  497. package/dist/chunk-EE6CPXKH.cjs +0 -164
  498. package/dist/chunk-EE6CPXKH.cjs.map +0 -1
  499. package/dist/chunk-EOFB7XCL.cjs +0 -837
  500. package/dist/chunk-EOFB7XCL.cjs.map +0 -1
  501. package/dist/chunk-ESLWRGAG.cjs +0 -92
  502. package/dist/chunk-ESLWRGAG.cjs.map +0 -1
  503. package/dist/chunk-ESMHTKLJ.cjs +0 -206
  504. package/dist/chunk-ESMHTKLJ.cjs.map +0 -1
  505. package/dist/chunk-FMTHVSYY.cjs +0 -1039
  506. package/dist/chunk-FMTHVSYY.cjs.map +0 -1
  507. package/dist/chunk-FU6R566Y.cjs +0 -236
  508. package/dist/chunk-FU6R566Y.cjs.map +0 -1
  509. package/dist/chunk-GYR5K654.js +0 -91
  510. package/dist/chunk-GYR5K654.js.map +0 -1
  511. package/dist/chunk-HA2WBOGQ.js +0 -57
  512. package/dist/chunk-HA2WBOGQ.js.map +0 -1
  513. package/dist/chunk-HT5JQKN2.js +0 -118
  514. package/dist/chunk-HT5JQKN2.js.map +0 -1
  515. package/dist/chunk-INJD3G4K.cjs +0 -340
  516. package/dist/chunk-INJD3G4K.cjs.map +0 -1
  517. package/dist/chunk-IOYFAFHJ.cjs +0 -95
  518. package/dist/chunk-IOYFAFHJ.cjs.map +0 -1
  519. package/dist/chunk-J5QENANM.js +0 -87
  520. package/dist/chunk-J5QENANM.js.map +0 -1
  521. package/dist/chunk-J7VGRIAJ.js +0 -64
  522. package/dist/chunk-J7VGRIAJ.js.map +0 -1
  523. package/dist/chunk-KFOHQK7X.js +0 -144
  524. package/dist/chunk-KFOHQK7X.js.map +0 -1
  525. package/dist/chunk-KIL5CUN6.js +0 -31
  526. package/dist/chunk-KIL5CUN6.js.map +0 -1
  527. package/dist/chunk-KYXZS3EA.cjs +0 -100
  528. package/dist/chunk-KYXZS3EA.cjs.map +0 -1
  529. package/dist/chunk-LITNXTTT.js +0 -3
  530. package/dist/chunk-LITNXTTT.js.map +0 -1
  531. package/dist/chunk-LVIPBYFE.js +0 -157
  532. package/dist/chunk-LVIPBYFE.js.map +0 -1
  533. package/dist/chunk-M3LFHHTN.cjs +0 -764
  534. package/dist/chunk-M3LFHHTN.cjs.map +0 -1
  535. package/dist/chunk-N25JDZSC.js +0 -95
  536. package/dist/chunk-N25JDZSC.js.map +0 -1
  537. package/dist/chunk-NEIB3TLD.cjs +0 -360
  538. package/dist/chunk-NEIB3TLD.cjs.map +0 -1
  539. package/dist/chunk-NENU7E6V.cjs +0 -344
  540. package/dist/chunk-NENU7E6V.cjs.map +0 -1
  541. package/dist/chunk-NVAI5CCN.cjs +0 -39
  542. package/dist/chunk-NVAI5CCN.cjs.map +0 -1
  543. package/dist/chunk-NZ72VDNY.cjs +0 -4
  544. package/dist/chunk-NZ72VDNY.cjs.map +0 -1
  545. package/dist/chunk-OPPXYVEZ.cjs +0 -131
  546. package/dist/chunk-OPPXYVEZ.cjs.map +0 -1
  547. package/dist/chunk-Q4EULJQY.js +0 -35
  548. package/dist/chunk-Q4EULJQY.js.map +0 -1
  549. package/dist/chunk-QF7ARNUM.js +0 -339
  550. package/dist/chunk-QF7ARNUM.js.map +0 -1
  551. package/dist/chunk-QWW3E3JM.cjs +0 -178
  552. package/dist/chunk-QWW3E3JM.cjs.map +0 -1
  553. package/dist/chunk-R7QYGZUP.cjs +0 -1075
  554. package/dist/chunk-R7QYGZUP.cjs.map +0 -1
  555. package/dist/chunk-RUPKBKUF.js +0 -352
  556. package/dist/chunk-RUPKBKUF.js.map +0 -1
  557. package/dist/chunk-SEO6NAQT.js +0 -14
  558. package/dist/chunk-SEO6NAQT.js.map +0 -1
  559. package/dist/chunk-T4B5LB6E.cjs +0 -66
  560. package/dist/chunk-T4B5LB6E.cjs.map +0 -1
  561. package/dist/chunk-T5WRA76K.cjs +0 -32
  562. package/dist/chunk-T5WRA76K.cjs.map +0 -1
  563. package/dist/chunk-T7JO2TCP.js +0 -1233
  564. package/dist/chunk-T7JO2TCP.js.map +0 -1
  565. package/dist/chunk-TC5ZPWM4.cjs +0 -289
  566. package/dist/chunk-TC5ZPWM4.cjs.map +0 -1
  567. package/dist/chunk-TQ5UWA7S.js +0 -26
  568. package/dist/chunk-TQ5UWA7S.js.map +0 -1
  569. package/dist/chunk-UIKYE2QZ.js +0 -833
  570. package/dist/chunk-UIKYE2QZ.js.map +0 -1
  571. package/dist/chunk-UNPLAVE7.js +0 -21
  572. package/dist/chunk-UNPLAVE7.js.map +0 -1
  573. package/dist/chunk-UY3UYPBZ.cjs +0 -77
  574. package/dist/chunk-UY3UYPBZ.cjs.map +0 -1
  575. package/dist/chunk-V7UBMJAB.cjs +0 -1242
  576. package/dist/chunk-V7UBMJAB.cjs.map +0 -1
  577. package/dist/chunk-VH77IPJN.cjs +0 -358
  578. package/dist/chunk-VH77IPJN.cjs.map +0 -1
  579. package/dist/chunk-VQTCQKHQ.cjs +0 -17
  580. package/dist/chunk-VQTCQKHQ.cjs.map +0 -1
  581. package/dist/chunk-WGWSHJ2N.js +0 -38
  582. package/dist/chunk-WGWSHJ2N.js.map +0 -1
  583. package/dist/chunk-WJH6IYU2.cjs +0 -32
  584. package/dist/chunk-WJH6IYU2.cjs.map +0 -1
  585. package/dist/chunk-YREV3LGG.cjs +0 -61
  586. package/dist/chunk-YREV3LGG.cjs.map +0 -1
  587. package/dist/chunk-YTXEZ4SD.cjs +0 -77
  588. package/dist/chunk-YTXEZ4SD.cjs.map +0 -1
  589. package/dist/chunk-ZNMBW67B.cjs +0 -40
  590. package/dist/chunk-ZNMBW67B.cjs.map +0 -1
  591. package/dist/correlation-id.cjs.map +0 -1
  592. package/dist/correlation-id.js.map +0 -1
  593. package/dist/define-event-BL6Li7CM.d.ts +0 -23
  594. package/dist/define-event-ClP3T1Jx.d.cts +0 -23
  595. package/dist/event-subscriber.cjs.map +0 -1
  596. package/dist/event-subscriber.js.map +0 -1
  597. package/dist/event.cjs.map +0 -1
  598. package/dist/event.js.map +0 -1
  599. package/dist/exporters.cjs.map +0 -1
  600. package/dist/exporters.js.map +0 -1
  601. package/dist/functional.cjs.map +0 -1
  602. package/dist/functional.js.map +0 -1
  603. package/dist/init-DIowiiCh.d.ts +0 -1167
  604. package/dist/init-j-A1zI16.d.cts +0 -1167
  605. package/dist/processors.cjs.map +0 -1
  606. package/dist/processors.js.map +0 -1
  607. package/dist/trace-context-DbGKd1Rn.d.cts +0 -213
  608. package/dist/trace-context-DbGKd1Rn.d.ts +0 -213
  609. package/dist/utils-BahBCFtJ.d.cts +0 -712
  610. package/dist/utils-CLKwaUlG.d.ts +0 -712
  611. package/dist/yaml-config.cjs.map +0 -1
  612. package/src/gen-ai-cost.test.ts +0 -81
  613. package/src/gen-ai-cost.ts +0 -145
  614. package/src/gen-ai-events.test.ts +0 -135
  615. package/src/gen-ai-events.ts +0 -208
  616. package/src/gen-ai-metrics.test.ts +0 -96
  617. package/src/gen-ai-metrics.ts +0 -128
@@ -1,8 +1,8 @@
1
- import * as _opentelemetry_api from '@opentelemetry/api';
2
- import { AsyncLocalStorage } from 'node:async_hooks';
1
+ import { AsyncLocalStorage } from "node:async_hooks";
3
2
 
3
+ //#region src/correlation-id.d.ts
4
4
  type CorrelationStore = {
5
- value: string;
5
+ value: string;
6
6
  };
7
7
  /**
8
8
  * Baggage key for correlation ID propagation
@@ -111,10 +111,11 @@ declare function setCorrelationId(correlationId: string): void;
111
111
  * });
112
112
  * ```
113
113
  */
114
- declare function setCorrelationIdInBaggage(correlationId: string): _opentelemetry_api.Context;
114
+ declare function setCorrelationIdInBaggage(correlationId: string): import('@opentelemetry/api').Context;
115
115
  /**
116
116
  * Get the correlation storage instance (for internal use in init/shutdown)
117
117
  */
118
118
  declare function getCorrelationStorage(): AsyncLocalStorage<CorrelationStore>;
119
-
119
+ //#endregion
120
120
  export { CORRELATION_ID_BAGGAGE_KEY, generateCorrelationId, getCorrelationId, getCorrelationStorage, getOrCreateCorrelationId, runWithCorrelationId, setCorrelationId, setCorrelationIdInBaggage };
121
+ //# sourceMappingURL=correlation-id.d.cts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"correlation-id.d.cts","names":[],"sources":["../src/correlation-id.ts"],"mappings":";;;KA4BK,gBAAA;EACH,KAAK;AAAA;AA+FiC;AAsBxC;;AAtBwC,cAnF3B,0BAAA;;;;;;;;AAyGiE;AAkB9E;;;;AAAsD;iBA5GtC,qBAAA;;;;AAsIuB;AAavC;;;;AAA2E;;;;;;;;;;;iBAvH3D,gBAAA;;;;;;;;;;;;;;;iBAwCA,wBAAA;;;;;;;;;;;;;;;;;;;iBAsBA,oBAAA,IAAwB,aAAA,UAAuB,EAAA,QAAU,CAAA,GAAI,CAAC;;;;;;;;;;;;;;;iBAkB9D,gBAAA,CAAiB,aAAqB;;;;;;;;;;;;;;;;;;;;;iBAwBtC,yBAAA,CACd,aAAA,wCAC8B,OAAO;;;;iBAavB,qBAAA,IAAyB,iBAAiB,CAAC,gBAAA"}
@@ -1,8 +1,8 @@
1
- import * as _opentelemetry_api from '@opentelemetry/api';
2
- import { AsyncLocalStorage } from 'node:async_hooks';
1
+ import { AsyncLocalStorage } from "node:async_hooks";
3
2
 
3
+ //#region src/correlation-id.d.ts
4
4
  type CorrelationStore = {
5
- value: string;
5
+ value: string;
6
6
  };
7
7
  /**
8
8
  * Baggage key for correlation ID propagation
@@ -111,10 +111,11 @@ declare function setCorrelationId(correlationId: string): void;
111
111
  * });
112
112
  * ```
113
113
  */
114
- declare function setCorrelationIdInBaggage(correlationId: string): _opentelemetry_api.Context;
114
+ declare function setCorrelationIdInBaggage(correlationId: string): import('@opentelemetry/api').Context;
115
115
  /**
116
116
  * Get the correlation storage instance (for internal use in init/shutdown)
117
117
  */
118
118
  declare function getCorrelationStorage(): AsyncLocalStorage<CorrelationStore>;
119
-
119
+ //#endregion
120
120
  export { CORRELATION_ID_BAGGAGE_KEY, generateCorrelationId, getCorrelationId, getCorrelationStorage, getOrCreateCorrelationId, runWithCorrelationId, setCorrelationId, setCorrelationIdInBaggage };
121
+ //# sourceMappingURL=correlation-id.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"correlation-id.d.ts","names":[],"sources":["../src/correlation-id.ts"],"mappings":";;;KA4BK,gBAAA;EACH,KAAK;AAAA;AA+FiC;AAsBxC;;AAtBwC,cAnF3B,0BAAA;;;;;;;;AAyGiE;AAkB9E;;;;AAAsD;iBA5GtC,qBAAA;;;;AAsIuB;AAavC;;;;AAA2E;;;;;;;;;;;iBAvH3D,gBAAA;;;;;;;;;;;;;;;iBAwCA,wBAAA;;;;;;;;;;;;;;;;;;;iBAsBA,oBAAA,IAAwB,aAAA,UAAuB,EAAA,QAAU,CAAA,GAAI,CAAC;;;;;;;;;;;;;;;iBAkB9D,gBAAA,CAAiB,aAAqB;;;;;;;;;;;;;;;;;;;;;iBAwBtC,yBAAA,CACd,aAAA,wCAC8B,OAAO;;;;iBAavB,qBAAA,IAAyB,iBAAiB,CAAC,gBAAA"}
@@ -1,17 +1,3 @@
1
- export { CORRELATION_ID_BAGGAGE_KEY, generateCorrelationId, getCorrelationId, getCorrelationStorage, getOrCreateCorrelationId, runWithCorrelationId, setCorrelationId, setCorrelationIdInBaggage } from './chunk-66YJ66GG.js';
2
- import './chunk-LVIPBYFE.js';
3
- import './chunk-ALPYR2GC.js';
4
- import './chunk-CMHVQR6P.js';
5
- import './chunk-A4E5AQFK.js';
6
- import './chunk-WGWSHJ2N.js';
7
- import './chunk-GYR5K654.js';
8
- import './chunk-RUPKBKUF.js';
9
- import './chunk-6UQRVUN3.js';
10
- import './chunk-3QXBFGKP.js';
11
- import './chunk-Q4EULJQY.js';
12
- import './chunk-DPSA4QLA.js';
13
- import './chunk-55ER2KD5.js';
14
- import './chunk-J5QENANM.js';
15
- import './chunk-HA2WBOGQ.js';
16
- //# sourceMappingURL=correlation-id.js.map
17
- //# sourceMappingURL=correlation-id.js.map
1
+ import { a as CORRELATION_ID_BAGGAGE_KEY, c as getCorrelationStorage, d as setCorrelationId, f as setCorrelationIdInBaggage, l as getOrCreateCorrelationId, o as generateCorrelationId, s as getCorrelationId, u as runWithCorrelationId } from "./track-nsKVy-pj.js";
2
+
3
+ export { CORRELATION_ID_BAGGAGE_KEY, generateCorrelationId, getCorrelationId, getCorrelationStorage, getOrCreateCorrelationId, runWithCorrelationId, setCorrelationId, setCorrelationIdInBaggage };
package/dist/db.cjs CHANGED
@@ -1,232 +1,267 @@
1
- 'use strict';
2
-
3
- var chunkESLWRGAG_cjs = require('./chunk-ESLWRGAG.cjs');
4
- require('./chunk-YREV3LGG.cjs');
5
- var api = require('@opentelemetry/api');
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_config = require('./config.cjs');
3
+ let _opentelemetry_api = require("@opentelemetry/api");
6
4
 
5
+ //#region src/db.ts
6
+ /**
7
+ * Database Instrumentation Helpers
8
+ *
9
+ * Optional import: Not included in main bundle
10
+ * Import from: 'autotel/db'
11
+ *
12
+ * Provides functional utilities for database query instrumentation.
13
+ * Works with Prisma, Drizzle, TypeORM, raw SQL, and more.
14
+ *
15
+ * @example
16
+ * ```typescript
17
+ * import { instrumentDatabase } from 'autotel/db'
18
+ *
19
+ * const db = drizzle(pool)
20
+ * instrumentDatabase(db, { dbSystem: 'postgresql', dbName: 'myapp' })
21
+ *
22
+ * // Now all queries are automatically trace
23
+ * await db.select().from(users)
24
+ * ```
25
+ */
26
+ /**
27
+ * Helper: Trace a single database query
28
+ *
29
+ * @example
30
+ * ```typescript
31
+ * import { tracebQuery } from 'autotel/db'
32
+ *
33
+ * const users = await tracebQuery(
34
+ * 'postgresql',
35
+ * 'SELECT',
36
+ * () => db.query('SELECT * FROM users WHERE active = true')
37
+ * )
38
+ * ```
39
+ */
7
40
  async function tracebQuery(dbSystem, operation, fn, attributes) {
8
- const config = chunkESLWRGAG_cjs.getConfig();
9
- const tracer = config.tracer;
10
- const spanName = `${dbSystem}.${operation}`;
11
- return tracer.startActiveSpan(spanName, async (span) => {
12
- const startTime = performance.now();
13
- try {
14
- span.setAttributes({
15
- "db.system": dbSystem,
16
- "db.operation": operation,
17
- ...attributes
18
- });
19
- const result = await fn();
20
- const duration = performance.now() - startTime;
21
- span.setStatus({ code: api.SpanStatusCode.OK });
22
- span.setAttribute("db.duration_ms", duration);
23
- if (Array.isArray(result)) {
24
- span.setAttribute("db.result_count", result.length);
25
- }
26
- return result;
27
- } catch (error) {
28
- const duration = performance.now() - startTime;
29
- span.setStatus({
30
- code: api.SpanStatusCode.ERROR,
31
- message: error instanceof Error ? error.message : "Unknown error"
32
- });
33
- span.setAttributes({
34
- "db.duration_ms": duration,
35
- "error.type": error instanceof Error ? error.constructor.name : "Unknown",
36
- "error.message": error instanceof Error ? error.message : "Unknown error"
37
- });
38
- throw error;
39
- } finally {
40
- span.end();
41
- }
42
- });
41
+ const tracer = require_config.getConfig().tracer;
42
+ const spanName = `${dbSystem}.${operation}`;
43
+ return tracer.startActiveSpan(spanName, async (span) => {
44
+ const startTime = performance.now();
45
+ try {
46
+ span.setAttributes({
47
+ "db.system": dbSystem,
48
+ "db.operation": operation,
49
+ ...attributes
50
+ });
51
+ const result = await fn();
52
+ const duration = performance.now() - startTime;
53
+ span.setStatus({ code: _opentelemetry_api.SpanStatusCode.OK });
54
+ span.setAttribute("db.duration_ms", duration);
55
+ if (Array.isArray(result)) span.setAttribute("db.result_count", result.length);
56
+ return result;
57
+ } catch (error) {
58
+ const duration = performance.now() - startTime;
59
+ span.setStatus({
60
+ code: _opentelemetry_api.SpanStatusCode.ERROR,
61
+ message: error instanceof Error ? error.message : "Unknown error"
62
+ });
63
+ span.setAttributes({
64
+ "db.duration_ms": duration,
65
+ "error.type": error instanceof Error ? error.constructor.name : "Unknown",
66
+ "error.message": error instanceof Error ? error.message : "Unknown error"
67
+ });
68
+ throw error;
69
+ } finally {
70
+ span.end();
71
+ }
72
+ });
43
73
  }
44
74
  function inferDbOperation(methodName) {
45
- const lower = methodName.toLowerCase();
46
- if (lower.includes("find") || lower.includes("get") || lower.includes("list"))
47
- return "SELECT";
48
- if (lower.includes("create") || lower.includes("insert")) return "INSERT";
49
- if (lower.includes("update") || lower.includes("modify")) return "UPDATE";
50
- if (lower.includes("delete") || lower.includes("remove")) return "DELETE";
51
- if (lower.includes("count")) return "COUNT";
52
- return "QUERY";
75
+ const lower = methodName.toLowerCase();
76
+ if (lower.includes("find") || lower.includes("get") || lower.includes("list")) return "SELECT";
77
+ if (lower.includes("create") || lower.includes("insert")) return "INSERT";
78
+ if (lower.includes("update") || lower.includes("modify")) return "UPDATE";
79
+ if (lower.includes("delete") || lower.includes("remove")) return "DELETE";
80
+ if (lower.includes("count")) return "COUNT";
81
+ return "QUERY";
53
82
  }
54
83
  function inferTableName(methodName) {
55
- const patterns = [
56
- /find([A-Z][a-zA-Z]+)/,
57
- /get([A-Z][a-zA-Z]+)/,
58
- /list([A-Z][a-zA-Z]+)/,
59
- /create([A-Z][a-zA-Z]+)/,
60
- /update([A-Z][a-zA-Z]+)/,
61
- /delete([A-Z][a-zA-Z]+)/,
62
- /remove([A-Z][a-zA-Z]+)/
63
- ];
64
- for (const pattern of patterns) {
65
- const match = methodName.match(pattern);
66
- if (match && match[1]) {
67
- return match[1].toLowerCase();
68
- }
69
- }
70
- return void 0;
84
+ for (const pattern of [
85
+ /find([A-Z][a-zA-Z]+)/,
86
+ /get([A-Z][a-zA-Z]+)/,
87
+ /list([A-Z][a-zA-Z]+)/,
88
+ /create([A-Z][a-zA-Z]+)/,
89
+ /update([A-Z][a-zA-Z]+)/,
90
+ /delete([A-Z][a-zA-Z]+)/,
91
+ /remove([A-Z][a-zA-Z]+)/
92
+ ]) {
93
+ const match = methodName.match(pattern);
94
+ if (match && match[1]) return match[1].toLowerCase();
95
+ }
71
96
  }
72
97
  function sanitizeSqlQuery(query) {
73
- return query.replaceAll(/'[^']*'/g, "'?'").replaceAll(/"[^"]*"/g, '"?"').replaceAll(/\b\d+\b/g, "?").trim();
98
+ return query.replaceAll(/'[^']*'/g, "'?'").replaceAll(/"[^"]*"/g, "\"?\"").replaceAll(/\b\d+\b/g, "?").trim();
74
99
  }
75
- var DB_OPERATIONS = {
76
- SELECT: "SELECT",
77
- INSERT: "INSERT",
78
- UPDATE: "UPDATE",
79
- DELETE: "DELETE",
80
- COUNT: "COUNT",
81
- AGGREGATE: "AGGREGATE"
100
+ /**
101
+ * Common database operation metrics
102
+ */
103
+ const DB_OPERATIONS = {
104
+ SELECT: "SELECT",
105
+ INSERT: "INSERT",
106
+ UPDATE: "UPDATE",
107
+ DELETE: "DELETE",
108
+ COUNT: "COUNT",
109
+ AGGREGATE: "AGGREGATE"
82
110
  };
83
- var DB_SYSTEMS = {
84
- POSTGRESQL: "postgresql",
85
- MYSQL: "mysql",
86
- MONGODB: "mongodb",
87
- REDIS: "redis",
88
- SQLITE: "sqlite",
89
- MSSQL: "mssql"
111
+ /**
112
+ * Common database systems
113
+ */
114
+ const DB_SYSTEMS = {
115
+ POSTGRESQL: "postgresql",
116
+ MYSQL: "mysql",
117
+ MONGODB: "mongodb",
118
+ REDIS: "redis",
119
+ SQLITE: "sqlite",
120
+ MSSQL: "mssql"
90
121
  };
91
- var INSTRUMENTED_SYMBOL = /* @__PURE__ */ Symbol.for("autotel.db.instrumented");
122
+ const INSTRUMENTED_SYMBOL = Symbol.for("autotel.db.instrumented");
123
+ /**
124
+ * Instrument a database client instance with OpenTelemetry tracing
125
+ *
126
+ * This is a function-based alternative to @DbInstrumented decorator.
127
+ * Modifies the client in-place and returns it (idempotent - safe to call multiple times).
128
+ *
129
+ * Inspired by otel-drizzle and other otel instrumentation packages.
130
+ *
131
+ * @example Drizzle ORM
132
+ * ```typescript
133
+ * import { drizzle } from 'drizzle-orm/node-postgres'
134
+ * import { instrumentDatabase } from 'autotel/db'
135
+ *
136
+ * const db = drizzle(pool)
137
+ * instrumentDatabase(db, { dbSystem: 'postgresql', dbName: 'myapp' })
138
+ *
139
+ * // Now all db queries are automatically trace
140
+ * await db.select().from(users)
141
+ * ```
142
+ *
143
+ * @example Prisma
144
+ * ```typescript
145
+ * import { PrismaClient } from '@prisma/client'
146
+ * import { instrumentDatabase } from 'autotel/db'
147
+ *
148
+ * const prisma = new PrismaClient()
149
+ * instrumentDatabase(prisma, {
150
+ * dbSystem: 'postgresql',
151
+ * methods: ['findMany', 'findUnique', 'create', 'update', 'delete']
152
+ * })
153
+ *
154
+ * // All specified methods are trace
155
+ * await prisma.user.findMany()
156
+ * ```
157
+ *
158
+ * @example Generic database client
159
+ * ```typescript
160
+ * import { instrumentDatabase } from 'autotel/db'
161
+ *
162
+ * const db = createDatabaseClient()
163
+ * instrumentDatabase(db, {
164
+ * dbSystem: 'mongodb',
165
+ * methods: ['find', 'findOne', 'insertOne', 'updateOne', 'deleteOne']
166
+ * })
167
+ * ```
168
+ */
92
169
  function instrumentDatabase(client, options) {
93
- if (client[INSTRUMENTED_SYMBOL]) {
94
- return client;
95
- }
96
- const {
97
- dbSystem,
98
- dbName,
99
- methods,
100
- skipMethods = [],
101
- sanitizeQuery = true,
102
- slowQueryThresholdMs = 1e3
103
- } = options;
104
- const config = chunkESLWRGAG_cjs.getConfig();
105
- const tracer = config.tracer;
106
- const methodsToInstrument = methods || extractDatabaseMethods(client);
107
- const skipSet = new Set(skipMethods);
108
- for (const methodName of methodsToInstrument) {
109
- if (skipSet.has(methodName)) continue;
110
- if (methodName.startsWith("_")) continue;
111
- const method = client[methodName];
112
- if (typeof method !== "function") continue;
113
- const originalMethod = method;
114
- client[methodName] = async function(...args) {
115
- const operation = inferDbOperation(methodName);
116
- const table = inferTableName(methodName);
117
- const spanName = table ? `${dbSystem}.${operation} ${table}` : `${dbSystem}.${operation}`;
118
- return tracer.startActiveSpan(spanName, async (span) => {
119
- const startTime = performance.now();
120
- try {
121
- span.setAttributes({
122
- "db.system": dbSystem,
123
- "db.operation": operation
124
- });
125
- if (dbName) {
126
- span.setAttribute("db.name", dbName);
127
- }
128
- if (table) {
129
- span.setAttribute("db.sql.table", table);
130
- }
131
- const query = extractQueryFromArgs(args);
132
- if (query) {
133
- span.setAttribute(
134
- "db.statement",
135
- sanitizeQuery ? sanitizeSqlQuery(query) : query
136
- );
137
- }
138
- const result = await originalMethod.apply(this, args);
139
- const duration = performance.now() - startTime;
140
- span.setStatus({ code: api.SpanStatusCode.OK });
141
- span.setAttributes({
142
- "db.duration_ms": duration
143
- });
144
- if (duration > slowQueryThresholdMs) {
145
- span.setAttribute("db.slow_query", true);
146
- span.setAttribute(
147
- "db.slow_query_threshold_ms",
148
- slowQueryThresholdMs
149
- );
150
- }
151
- if (Array.isArray(result)) {
152
- span.setAttribute("db.result_count", result.length);
153
- }
154
- return result;
155
- } catch (error) {
156
- const duration = performance.now() - startTime;
157
- span.setStatus({
158
- code: api.SpanStatusCode.ERROR,
159
- message: error instanceof Error ? error.message : "Unknown error"
160
- });
161
- span.setAttributes({
162
- "db.duration_ms": duration,
163
- "error.type": error instanceof Error ? error.constructor.name : "Unknown",
164
- "error.message": error instanceof Error ? error.message : "Unknown error"
165
- });
166
- span.recordException(
167
- error instanceof Error ? error : new Error(String(error))
168
- );
169
- throw error;
170
- } finally {
171
- span.end();
172
- }
173
- });
174
- };
175
- Object.defineProperty(client[methodName], "name", {
176
- value: methodName,
177
- configurable: true
178
- });
179
- }
180
- client[INSTRUMENTED_SYMBOL] = true;
181
- return client;
170
+ if (client[INSTRUMENTED_SYMBOL]) return client;
171
+ const { dbSystem, dbName, methods, skipMethods = [], sanitizeQuery = true, slowQueryThresholdMs = 1e3 } = options;
172
+ const tracer = require_config.getConfig().tracer;
173
+ const methodsToInstrument = methods || extractDatabaseMethods(client);
174
+ const skipSet = new Set(skipMethods);
175
+ for (const methodName of methodsToInstrument) {
176
+ if (skipSet.has(methodName)) continue;
177
+ if (methodName.startsWith("_")) continue;
178
+ const method = client[methodName];
179
+ if (typeof method !== "function") continue;
180
+ const originalMethod = method;
181
+ client[methodName] = async function(...args) {
182
+ const operation = inferDbOperation(methodName);
183
+ const table = inferTableName(methodName);
184
+ const spanName = table ? `${dbSystem}.${operation} ${table}` : `${dbSystem}.${operation}`;
185
+ return tracer.startActiveSpan(spanName, async (span) => {
186
+ const startTime = performance.now();
187
+ try {
188
+ span.setAttributes({
189
+ "db.system": dbSystem,
190
+ "db.operation": operation
191
+ });
192
+ if (dbName) span.setAttribute("db.name", dbName);
193
+ if (table) span.setAttribute("db.sql.table", table);
194
+ const query = extractQueryFromArgs(args);
195
+ if (query) span.setAttribute("db.statement", sanitizeQuery ? sanitizeSqlQuery(query) : query);
196
+ const result = await originalMethod.apply(this, args);
197
+ const duration = performance.now() - startTime;
198
+ span.setStatus({ code: _opentelemetry_api.SpanStatusCode.OK });
199
+ span.setAttributes({ "db.duration_ms": duration });
200
+ if (duration > slowQueryThresholdMs) {
201
+ span.setAttribute("db.slow_query", true);
202
+ span.setAttribute("db.slow_query_threshold_ms", slowQueryThresholdMs);
203
+ }
204
+ if (Array.isArray(result)) span.setAttribute("db.result_count", result.length);
205
+ return result;
206
+ } catch (error) {
207
+ const duration = performance.now() - startTime;
208
+ span.setStatus({
209
+ code: _opentelemetry_api.SpanStatusCode.ERROR,
210
+ message: error instanceof Error ? error.message : "Unknown error"
211
+ });
212
+ span.setAttributes({
213
+ "db.duration_ms": duration,
214
+ "error.type": error instanceof Error ? error.constructor.name : "Unknown",
215
+ "error.message": error instanceof Error ? error.message : "Unknown error"
216
+ });
217
+ span.recordException(error instanceof Error ? error : new Error(String(error)));
218
+ throw error;
219
+ } finally {
220
+ span.end();
221
+ }
222
+ });
223
+ };
224
+ Object.defineProperty(client[methodName], "name", {
225
+ value: methodName,
226
+ configurable: true
227
+ });
228
+ }
229
+ client[INSTRUMENTED_SYMBOL] = true;
230
+ return client;
182
231
  }
232
+ /**
233
+ * Extract method names from a database client that should be instrumented
234
+ */
183
235
  function extractDatabaseMethods(client) {
184
- const methods = [];
185
- const proto = Object.getPrototypeOf(client);
186
- for (const key of Object.getOwnPropertyNames(client)) {
187
- if (typeof client[key] === "function" && !key.startsWith("_")) {
188
- methods.push(key);
189
- }
190
- }
191
- if (proto) {
192
- for (const key of Object.getOwnPropertyNames(proto)) {
193
- if (typeof proto[key] === "function" && !key.startsWith("_") && key !== "constructor") {
194
- methods.push(key);
195
- }
196
- }
197
- }
198
- return [...new Set(methods)];
236
+ const methods = [];
237
+ const proto = Object.getPrototypeOf(client);
238
+ for (const key of Object.getOwnPropertyNames(client)) if (typeof client[key] === "function" && !key.startsWith("_")) methods.push(key);
239
+ if (proto) {
240
+ for (const key of Object.getOwnPropertyNames(proto)) if (typeof proto[key] === "function" && !key.startsWith("_") && key !== "constructor") methods.push(key);
241
+ }
242
+ return [...new Set(methods)];
199
243
  }
244
+ /**
245
+ * Try to extract SQL query from common argument patterns
246
+ */
200
247
  function extractQueryFromArgs(args) {
201
- if (args.length === 0) return void 0;
202
- const firstArg = args[0];
203
- if (typeof firstArg === "string") {
204
- return firstArg;
205
- }
206
- if (firstArg && typeof firstArg === "object") {
207
- if ("sql" in firstArg && typeof firstArg.sql === "string") {
208
- return firstArg.sql;
209
- }
210
- if ("text" in firstArg && typeof firstArg.text === "string") {
211
- return firstArg.text;
212
- }
213
- if ("toQuery" in firstArg && typeof firstArg.toQuery === "function") {
214
- try {
215
- const queryResult = firstArg.toQuery();
216
- if (typeof queryResult === "string") return queryResult;
217
- if (queryResult && typeof queryResult === "object" && "sql" in queryResult) {
218
- return queryResult.sql;
219
- }
220
- } catch {
221
- }
222
- }
223
- }
224
- return void 0;
248
+ if (args.length === 0) return void 0;
249
+ const firstArg = args[0];
250
+ if (typeof firstArg === "string") return firstArg;
251
+ if (firstArg && typeof firstArg === "object") {
252
+ if ("sql" in firstArg && typeof firstArg.sql === "string") return firstArg.sql;
253
+ if ("text" in firstArg && typeof firstArg.text === "string") return firstArg.text;
254
+ if ("toQuery" in firstArg && typeof firstArg.toQuery === "function") try {
255
+ const queryResult = firstArg.toQuery();
256
+ if (typeof queryResult === "string") return queryResult;
257
+ if (queryResult && typeof queryResult === "object" && "sql" in queryResult) return queryResult.sql;
258
+ } catch {}
259
+ }
225
260
  }
226
261
 
262
+ //#endregion
227
263
  exports.DB_OPERATIONS = DB_OPERATIONS;
228
264
  exports.DB_SYSTEMS = DB_SYSTEMS;
229
265
  exports.instrumentDatabase = instrumentDatabase;
230
266
  exports.tracebQuery = tracebQuery;
231
- //# sourceMappingURL=db.cjs.map
232
267
  //# sourceMappingURL=db.cjs.map