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
package/dist/webhook.cjs CHANGED
@@ -1,270 +1,301 @@
1
- 'use strict';
2
-
3
- var chunk4P6ZOARG_cjs = require('./chunk-4P6ZOARG.cjs');
4
- var chunkFGNDN2FD_cjs = require('./chunk-FGNDN2FD.cjs');
5
- require('./chunk-OPPXYVEZ.cjs');
6
- require('./chunk-VQTCQKHQ.cjs');
7
- var chunkZ7PW3KHL_cjs = require('./chunk-Z7PW3KHL.cjs');
8
- require('./chunk-R7QYGZUP.cjs');
9
- require('./chunk-QWW3E3JM.cjs');
10
- require('./chunk-CEAQK2QY.cjs');
11
- require('./chunk-ZNMBW67B.cjs');
12
- require('./chunk-IOYFAFHJ.cjs');
13
- require('./chunk-NEIB3TLD.cjs');
14
- require('./chunk-CU6IDACR.cjs');
15
- require('./chunk-6S5RUKU3.cjs');
16
- require('./chunk-NVAI5CCN.cjs');
17
- require('./chunk-VH77IPJN.cjs');
18
- require('./chunk-FU6R566Y.cjs');
19
- require('./chunk-ESLWRGAG.cjs');
20
- require('./chunk-YREV3LGG.cjs');
21
- var api = require('@opentelemetry/api');
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ const require_structured_error = require('./structured-error-CHg7DoIQ.cjs');
3
+ const require_functional = require('./functional-C4CzoVrX.cjs');
4
+ const require_correlated_events = require('./correlated-events-kSwLo3mi.cjs');
5
+ let _opentelemetry_api = require("@opentelemetry/api");
22
6
 
7
+ //#region src/webhook.ts
8
+ /**
9
+ * Webhook and callback tracing with the "Parking Lot" pattern
10
+ *
11
+ * When initiating async operations that return hours/days later (webhooks,
12
+ * payment callbacks, human approvals), you can't keep a span open. This module
13
+ * provides utilities to "park" trace context and retrieve it when callbacks arrive.
14
+ *
15
+ * @example Stripe payment webhook
16
+ * ```typescript
17
+ * import { createParkingLot, InMemoryTraceContextStore } from 'autotel/webhook';
18
+ *
19
+ * const parkingLot = createParkingLot({
20
+ * store: new InMemoryTraceContextStore(),
21
+ * defaultTTLMs: 24 * 60 * 60 * 1000, // 24 hours
22
+ * });
23
+ *
24
+ * // When initiating payment
25
+ * export const initiatePayment = trace(ctx => async (orderId: string) => {
26
+ * await parkingLot.park(`payment:${orderId}`, { orderId });
27
+ * await stripeClient.createPaymentIntent({ metadata: { orderId } });
28
+ * });
29
+ *
30
+ * // When Stripe webhook arrives (hours later)
31
+ * export const handleStripeWebhook = parkingLot.traceCallback({
32
+ * name: 'stripe.webhook.payment_intent.succeeded',
33
+ * correlationKeyFrom: (event) => `payment:${event.data.object.metadata.orderId}`,
34
+ * })(ctx => async (event: Stripe.Event) => {
35
+ * // ctx.parkedContext contains the original trace context
36
+ * // ctx.elapsedMs shows time since payment was initiated
37
+ * await fulfillOrder(event.data.object);
38
+ * });
39
+ * ```
40
+ *
41
+ * @module
42
+ */
43
+ /**
44
+ * In-memory trace context store
45
+ *
46
+ * Useful for testing and development. For production, use a persistent
47
+ * store like Redis or DynamoDB.
48
+ *
49
+ * @example
50
+ * ```typescript
51
+ * const store = new InMemoryTraceContextStore();
52
+ * const parkingLot = createParkingLot({ store });
53
+ * ```
54
+ */
23
55
  var InMemoryTraceContextStore = class {
24
- constructor(options = {}) {
25
- this.options = options;
26
- const cleanupMs = options.cleanupIntervalMs ?? 6e4;
27
- if (cleanupMs > 0) {
28
- this.cleanupInterval = setInterval(() => this.cleanup(), cleanupMs);
29
- if (this.cleanupInterval.unref) {
30
- this.cleanupInterval.unref();
31
- }
32
- }
33
- }
34
- options;
35
- store = /* @__PURE__ */ new Map();
36
- cleanupInterval = null;
37
- async save(key, context) {
38
- this.store.set(key, context);
39
- }
40
- async load(key) {
41
- const context = this.store.get(key);
42
- if (!context) {
43
- return null;
44
- }
45
- if (context.ttlMs) {
46
- const age = Date.now() - context.parkedAt;
47
- if (age > context.ttlMs) {
48
- this.store.delete(key);
49
- return null;
50
- }
51
- }
52
- return context;
53
- }
54
- async delete(key) {
55
- this.store.delete(key);
56
- }
57
- /**
58
- * Get number of stored contexts (for testing)
59
- */
60
- get size() {
61
- return this.store.size;
62
- }
63
- /**
64
- * Clear all stored contexts (for testing)
65
- */
66
- clear() {
67
- this.store.clear();
68
- }
69
- /**
70
- * Stop the cleanup interval
71
- */
72
- destroy() {
73
- if (this.cleanupInterval) {
74
- clearInterval(this.cleanupInterval);
75
- this.cleanupInterval = null;
76
- }
77
- }
78
- cleanup() {
79
- const now = Date.now();
80
- for (const [key, context] of this.store.entries()) {
81
- if (context.ttlMs) {
82
- const age = now - context.parkedAt;
83
- if (age > context.ttlMs) {
84
- this.store.delete(key);
85
- }
86
- }
87
- }
88
- }
56
+ options;
57
+ store = /* @__PURE__ */ new Map();
58
+ cleanupInterval = null;
59
+ constructor(options = {}) {
60
+ this.options = options;
61
+ const cleanupMs = options.cleanupIntervalMs ?? 6e4;
62
+ if (cleanupMs > 0) {
63
+ this.cleanupInterval = setInterval(() => this.cleanup(), cleanupMs);
64
+ if (this.cleanupInterval.unref) this.cleanupInterval.unref();
65
+ }
66
+ }
67
+ async save(key, context) {
68
+ this.store.set(key, context);
69
+ }
70
+ async load(key) {
71
+ const context = this.store.get(key);
72
+ if (!context) return null;
73
+ if (context.ttlMs) {
74
+ if (Date.now() - context.parkedAt > context.ttlMs) {
75
+ this.store.delete(key);
76
+ return null;
77
+ }
78
+ }
79
+ return context;
80
+ }
81
+ async delete(key) {
82
+ this.store.delete(key);
83
+ }
84
+ /**
85
+ * Get number of stored contexts (for testing)
86
+ */
87
+ get size() {
88
+ return this.store.size;
89
+ }
90
+ /**
91
+ * Clear all stored contexts (for testing)
92
+ */
93
+ clear() {
94
+ this.store.clear();
95
+ }
96
+ /**
97
+ * Stop the cleanup interval
98
+ */
99
+ destroy() {
100
+ if (this.cleanupInterval) {
101
+ clearInterval(this.cleanupInterval);
102
+ this.cleanupInterval = null;
103
+ }
104
+ }
105
+ cleanup() {
106
+ const now = Date.now();
107
+ for (const [key, context] of this.store.entries()) if (context.ttlMs) {
108
+ if (now - context.parkedAt > context.ttlMs) this.store.delete(key);
109
+ }
110
+ }
89
111
  };
112
+ /**
113
+ * Create a parking lot for trace context storage and retrieval
114
+ *
115
+ * @param config - Parking lot configuration
116
+ * @returns A parking lot instance
117
+ *
118
+ * @example Basic usage
119
+ * ```typescript
120
+ * const parkingLot = createParkingLot({
121
+ * store: new InMemoryTraceContextStore(),
122
+ * defaultTTLMs: 24 * 60 * 60 * 1000, // 24 hours
123
+ * });
124
+ * ```
125
+ *
126
+ * @example With Redis store
127
+ * ```typescript
128
+ * class RedisTraceContextStore implements TraceContextStore {
129
+ * constructor(private redis: Redis) {}
130
+ *
131
+ * async save(key: string, context: StoredTraceContext) {
132
+ * const ttlSeconds = context.ttlMs ? Math.ceil(context.ttlMs / 1000) : 86400;
133
+ * await this.redis.setex(key, ttlSeconds, JSON.stringify(context));
134
+ * }
135
+ *
136
+ * async load(key: string) {
137
+ * const data = await this.redis.get(key);
138
+ * return data ? JSON.parse(data) : null;
139
+ * }
140
+ *
141
+ * async delete(key: string) {
142
+ * await this.redis.del(key);
143
+ * }
144
+ * }
145
+ *
146
+ * const parkingLot = createParkingLot({
147
+ * store: new RedisTraceContextStore(redis),
148
+ * });
149
+ * ```
150
+ */
90
151
  function createParkingLot(config) {
91
- const {
92
- store,
93
- defaultTTLMs = 24 * 60 * 60 * 1e3,
94
- // 24 hours
95
- keyPrefix = "parkingLot:",
96
- autoDeleteOnRetrieve = true,
97
- onMiss
98
- } = config;
99
- function getCurrentSpanContext() {
100
- const activeSpan = api.trace.getActiveSpan();
101
- if (!activeSpan) {
102
- return null;
103
- }
104
- return activeSpan.spanContext();
105
- }
106
- function prefixKey(key) {
107
- return `${keyPrefix}${key}`;
108
- }
109
- const parkingLot = {
110
- async park(correlationKey, metadata) {
111
- const spanContext = getCurrentSpanContext();
112
- const fullKey = prefixKey(correlationKey);
113
- const storedContext = {
114
- traceId: spanContext?.traceId ?? "",
115
- spanId: spanContext?.spanId ?? "",
116
- traceFlags: spanContext?.traceFlags ?? 0,
117
- parkedAt: Date.now(),
118
- ttlMs: defaultTTLMs,
119
- metadata
120
- };
121
- await store.save(fullKey, storedContext);
122
- const activeSpan = api.trace.getActiveSpan();
123
- if (activeSpan) {
124
- const parkAttrs = {
125
- "parking_lot.correlation_key": correlationKey,
126
- "parking_lot.ttl_ms": defaultTTLMs,
127
- ...metadata && Object.fromEntries(
128
- Object.entries(metadata).map(([k, v]) => [
129
- `parking_lot.metadata.${k}`,
130
- v
131
- ])
132
- )
133
- };
134
- chunk4P6ZOARG_cjs.emitCorrelatedEvent(
135
- {
136
- setAttribute: (k, v) => activeSpan.setAttribute(k, v),
137
- setAttributes: (a) => activeSpan.setAttributes(a),
138
- addEvent: (n, a) => activeSpan.addEvent(n, a)
139
- },
140
- "trace_context_parked",
141
- parkAttrs
142
- );
143
- }
144
- return correlationKey;
145
- },
146
- async retrieve(correlationKey) {
147
- const fullKey = prefixKey(correlationKey);
148
- const storedContext = await store.load(fullKey);
149
- if (!storedContext) {
150
- onMiss?.(correlationKey);
151
- return null;
152
- }
153
- if (autoDeleteOnRetrieve) {
154
- await store.delete(fullKey);
155
- }
156
- return storedContext;
157
- },
158
- traceCallback(callbackConfig) {
159
- return (fnFactory) => {
160
- return chunkFGNDN2FD_cjs.trace(
161
- {
162
- name: callbackConfig.name,
163
- spanKind: api.SpanKind.SERVER
164
- },
165
- (baseCtx) => {
166
- return async (...args) => {
167
- const correlationKey = callbackConfig.correlationKeyFrom(args);
168
- const parkedContext = await parkingLot.retrieve(correlationKey);
169
- const elapsedMs = parkedContext ? Date.now() - parkedContext.parkedAt : null;
170
- baseCtx.setAttribute(
171
- "parking_lot.correlation_key",
172
- correlationKey
173
- );
174
- if (parkedContext) {
175
- baseCtx.setAttribute("parking_lot.elapsed_ms", elapsedMs);
176
- baseCtx.setAttribute(
177
- "parking_lot.original_trace_id",
178
- parkedContext.traceId
179
- );
180
- baseCtx.setAttribute(
181
- "parking_lot.original_span_id",
182
- parkedContext.spanId
183
- );
184
- if (parkedContext.metadata) {
185
- for (const [key, value] of Object.entries(
186
- parkedContext.metadata
187
- )) {
188
- baseCtx.setAttribute(`parking_lot.metadata.${key}`, value);
189
- }
190
- }
191
- const link = parkingLot.createLink(parkedContext);
192
- baseCtx.addLinks([link]);
193
- chunk4P6ZOARG_cjs.emitCorrelatedEvent(baseCtx, "parked_context_retrieved", {
194
- "parking_lot.correlation_key": correlationKey,
195
- "parking_lot.elapsed_ms": elapsedMs,
196
- "parking_lot.original_trace_id": parkedContext.traceId
197
- });
198
- } else {
199
- baseCtx.setAttribute("parking_lot.context_found", false);
200
- if (callbackConfig.requireParkedContext) {
201
- const error = new Error(
202
- `Required parked context not found for key: ${correlationKey}`
203
- );
204
- chunkZ7PW3KHL_cjs.recordStructuredError(baseCtx, error);
205
- throw error;
206
- }
207
- }
208
- if (callbackConfig.attributes) {
209
- for (const [key, value] of Object.entries(
210
- callbackConfig.attributes
211
- )) {
212
- baseCtx.setAttribute(key, value);
213
- }
214
- }
215
- const callbackCtx = {
216
- ...baseCtx,
217
- parkedContext,
218
- elapsedMs,
219
- correlationKey
220
- };
221
- const userFn = fnFactory(callbackCtx);
222
- return userFn(...args);
223
- };
224
- }
225
- );
226
- };
227
- },
228
- createLink(storedContext) {
229
- return {
230
- context: {
231
- traceId: storedContext.traceId,
232
- spanId: storedContext.spanId,
233
- traceFlags: storedContext.traceFlags,
234
- isRemote: true
235
- },
236
- attributes: {
237
- "link.type": "parking_lot",
238
- "parking_lot.parked_at": storedContext.parkedAt,
239
- ...storedContext.metadata && {
240
- "parking_lot.has_metadata": true
241
- }
242
- }
243
- };
244
- },
245
- async exists(correlationKey) {
246
- const fullKey = prefixKey(correlationKey);
247
- const context = await store.load(fullKey);
248
- return context !== null;
249
- }
250
- };
251
- return parkingLot;
152
+ const { store, defaultTTLMs = 1440 * 60 * 1e3, keyPrefix = "parkingLot:", autoDeleteOnRetrieve = true, onMiss } = config;
153
+ /**
154
+ * Get current span context from active context
155
+ */
156
+ function getCurrentSpanContext() {
157
+ const activeSpan = _opentelemetry_api.trace.getActiveSpan();
158
+ if (!activeSpan) return null;
159
+ return activeSpan.spanContext();
160
+ }
161
+ /**
162
+ * Apply key prefix
163
+ */
164
+ function prefixKey(key) {
165
+ return `${keyPrefix}${key}`;
166
+ }
167
+ const parkingLot = {
168
+ async park(correlationKey, metadata) {
169
+ const spanContext = getCurrentSpanContext();
170
+ const fullKey = prefixKey(correlationKey);
171
+ const storedContext = {
172
+ traceId: spanContext?.traceId ?? "",
173
+ spanId: spanContext?.spanId ?? "",
174
+ traceFlags: spanContext?.traceFlags ?? 0,
175
+ parkedAt: Date.now(),
176
+ ttlMs: defaultTTLMs,
177
+ metadata
178
+ };
179
+ await store.save(fullKey, storedContext);
180
+ const activeSpan = _opentelemetry_api.trace.getActiveSpan();
181
+ if (activeSpan) require_correlated_events.emitCorrelatedEvent({
182
+ setAttribute: (k, v) => activeSpan.setAttribute(k, v),
183
+ setAttributes: (a) => activeSpan.setAttributes(a),
184
+ addEvent: (n, a) => activeSpan.addEvent(n, a)
185
+ }, "trace_context_parked", {
186
+ "parking_lot.correlation_key": correlationKey,
187
+ "parking_lot.ttl_ms": defaultTTLMs,
188
+ ...metadata && Object.fromEntries(Object.entries(metadata).map(([k, v]) => [`parking_lot.metadata.${k}`, v]))
189
+ });
190
+ return correlationKey;
191
+ },
192
+ async retrieve(correlationKey) {
193
+ const fullKey = prefixKey(correlationKey);
194
+ const storedContext = await store.load(fullKey);
195
+ if (!storedContext) {
196
+ onMiss?.(correlationKey);
197
+ return null;
198
+ }
199
+ if (autoDeleteOnRetrieve) await store.delete(fullKey);
200
+ return storedContext;
201
+ },
202
+ traceCallback(callbackConfig) {
203
+ return (fnFactory) => {
204
+ return require_functional.trace({
205
+ name: callbackConfig.name,
206
+ spanKind: _opentelemetry_api.SpanKind.SERVER
207
+ }, (baseCtx) => {
208
+ return async (...args) => {
209
+ const correlationKey = callbackConfig.correlationKeyFrom(args);
210
+ const parkedContext = await parkingLot.retrieve(correlationKey);
211
+ const elapsedMs = parkedContext ? Date.now() - parkedContext.parkedAt : null;
212
+ baseCtx.setAttribute("parking_lot.correlation_key", correlationKey);
213
+ if (parkedContext) {
214
+ baseCtx.setAttribute("parking_lot.elapsed_ms", elapsedMs);
215
+ baseCtx.setAttribute("parking_lot.original_trace_id", parkedContext.traceId);
216
+ baseCtx.setAttribute("parking_lot.original_span_id", parkedContext.spanId);
217
+ if (parkedContext.metadata) for (const [key, value] of Object.entries(parkedContext.metadata)) baseCtx.setAttribute(`parking_lot.metadata.${key}`, value);
218
+ const link = parkingLot.createLink(parkedContext);
219
+ baseCtx.addLinks([link]);
220
+ require_correlated_events.emitCorrelatedEvent(baseCtx, "parked_context_retrieved", {
221
+ "parking_lot.correlation_key": correlationKey,
222
+ "parking_lot.elapsed_ms": elapsedMs,
223
+ "parking_lot.original_trace_id": parkedContext.traceId
224
+ });
225
+ } else {
226
+ baseCtx.setAttribute("parking_lot.context_found", false);
227
+ if (callbackConfig.requireParkedContext) {
228
+ const error = /* @__PURE__ */ new Error(`Required parked context not found for key: ${correlationKey}`);
229
+ require_structured_error.recordStructuredError(baseCtx, error);
230
+ throw error;
231
+ }
232
+ }
233
+ if (callbackConfig.attributes) for (const [key, value] of Object.entries(callbackConfig.attributes)) baseCtx.setAttribute(key, value);
234
+ return fnFactory({
235
+ ...baseCtx,
236
+ parkedContext,
237
+ elapsedMs,
238
+ correlationKey
239
+ })(...args);
240
+ };
241
+ });
242
+ };
243
+ },
244
+ createLink(storedContext) {
245
+ return {
246
+ context: {
247
+ traceId: storedContext.traceId,
248
+ spanId: storedContext.spanId,
249
+ traceFlags: storedContext.traceFlags,
250
+ isRemote: true
251
+ },
252
+ attributes: {
253
+ "link.type": "parking_lot",
254
+ "parking_lot.parked_at": storedContext.parkedAt,
255
+ ...storedContext.metadata && { "parking_lot.has_metadata": true }
256
+ }
257
+ };
258
+ },
259
+ async exists(correlationKey) {
260
+ const fullKey = prefixKey(correlationKey);
261
+ return await store.load(fullKey) !== null;
262
+ }
263
+ };
264
+ return parkingLot;
252
265
  }
266
+ /**
267
+ * Create a correlation key from multiple parts
268
+ *
269
+ * @param parts - Key parts to join
270
+ * @returns A correlation key string
271
+ *
272
+ * @example
273
+ * ```typescript
274
+ * const key = createCorrelationKey('payment', orderId, 'stripe');
275
+ * // Returns: "payment:order-123:stripe"
276
+ * ```
277
+ */
253
278
  function createCorrelationKey(...parts) {
254
- return parts.map(String).join(":");
279
+ return parts.map(String).join(":");
255
280
  }
281
+ /**
282
+ * Extract span context from stored context for manual linking
283
+ *
284
+ * @param storedContext - The stored trace context
285
+ * @returns SpanContext compatible object
286
+ */
256
287
  function toSpanContext(storedContext) {
257
- return {
258
- traceId: storedContext.traceId,
259
- spanId: storedContext.spanId,
260
- traceFlags: storedContext.traceFlags,
261
- isRemote: true
262
- };
288
+ return {
289
+ traceId: storedContext.traceId,
290
+ spanId: storedContext.spanId,
291
+ traceFlags: storedContext.traceFlags,
292
+ isRemote: true
293
+ };
263
294
  }
264
295
 
296
+ //#endregion
265
297
  exports.InMemoryTraceContextStore = InMemoryTraceContextStore;
266
298
  exports.createCorrelationKey = createCorrelationKey;
267
299
  exports.createParkingLot = createParkingLot;
268
300
  exports.toSpanContext = toSpanContext;
269
- //# sourceMappingURL=webhook.cjs.map
270
301
  //# sourceMappingURL=webhook.cjs.map