autotel 3.6.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 (602) 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 -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-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 +1049 -1172
  162. package/dist/index.cjs.map +1 -1
  163. package/dist/index.d.cts +401 -551
  164. package/dist/index.d.cts.map +1 -0
  165. package/dist/index.d.ts +401 -551
  166. package/dist/index.d.ts.map +1 -0
  167. package/dist/index.js +912 -714
  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-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 -39
  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 -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/src/index.ts +3 -0
  432. package/src/request-logger.test.ts +53 -1
  433. package/src/request-logger.ts +58 -0
  434. package/src/validate.test.ts +3 -1
  435. package/src/validate.ts +9 -3
  436. package/dist/attributes.cjs.map +0 -1
  437. package/dist/attributes.js.map +0 -1
  438. package/dist/chunk-2ZKEORFN.cjs +0 -14
  439. package/dist/chunk-2ZKEORFN.cjs.map +0 -1
  440. package/dist/chunk-3QXBFGKP.js +0 -344
  441. package/dist/chunk-3QXBFGKP.js.map +0 -1
  442. package/dist/chunk-454CH4OV.js +0 -744
  443. package/dist/chunk-454CH4OV.js.map +0 -1
  444. package/dist/chunk-4A53YIAX.js +0 -180
  445. package/dist/chunk-4A53YIAX.js.map +0 -1
  446. package/dist/chunk-4IFSYQVX.js +0 -337
  447. package/dist/chunk-4IFSYQVX.js.map +0 -1
  448. package/dist/chunk-4P6ZOARG.cjs +0 -33
  449. package/dist/chunk-4P6ZOARG.cjs.map +0 -1
  450. package/dist/chunk-55ER2KD5.js +0 -228
  451. package/dist/chunk-55ER2KD5.js.map +0 -1
  452. package/dist/chunk-5ZN622AO.js +0 -73
  453. package/dist/chunk-5ZN622AO.js.map +0 -1
  454. package/dist/chunk-66YJ66GG.js +0 -1021
  455. package/dist/chunk-66YJ66GG.js.map +0 -1
  456. package/dist/chunk-6S5RUKU3.cjs +0 -347
  457. package/dist/chunk-6S5RUKU3.cjs.map +0 -1
  458. package/dist/chunk-6UQRVUN3.js +0 -222
  459. package/dist/chunk-6UQRVUN3.js.map +0 -1
  460. package/dist/chunk-7552UTQW.js +0 -11
  461. package/dist/chunk-7552UTQW.js.map +0 -1
  462. package/dist/chunk-7EQ4G4SI.cjs +0 -146
  463. package/dist/chunk-7EQ4G4SI.cjs.map +0 -1
  464. package/dist/chunk-7SAWIN74.js +0 -285
  465. package/dist/chunk-7SAWIN74.js.map +0 -1
  466. package/dist/chunk-A4E5AQFK.js +0 -30
  467. package/dist/chunk-A4E5AQFK.js.map +0 -1
  468. package/dist/chunk-ALPYR2GC.js +0 -1061
  469. package/dist/chunk-ALPYR2GC.js.map +0 -1
  470. package/dist/chunk-B7SWBE4P.cjs +0 -799
  471. package/dist/chunk-B7SWBE4P.cjs.map +0 -1
  472. package/dist/chunk-BZHG5IZ4.js +0 -73
  473. package/dist/chunk-BZHG5IZ4.js.map +0 -1
  474. package/dist/chunk-CEAQK2QY.cjs +0 -32
  475. package/dist/chunk-CEAQK2QY.cjs.map +0 -1
  476. package/dist/chunk-CMHVQR6P.js +0 -170
  477. package/dist/chunk-CMHVQR6P.js.map +0 -1
  478. package/dist/chunk-CU6IDACR.cjs +0 -224
  479. package/dist/chunk-CU6IDACR.cjs.map +0 -1
  480. package/dist/chunk-D4TM63S3.js +0 -795
  481. package/dist/chunk-D4TM63S3.js.map +0 -1
  482. package/dist/chunk-DCEDJQGG.js +0 -28
  483. package/dist/chunk-DCEDJQGG.js.map +0 -1
  484. package/dist/chunk-DPSA4QLA.js +0 -344
  485. package/dist/chunk-DPSA4QLA.js.map +0 -1
  486. package/dist/chunk-E6TERL5O.cjs +0 -23
  487. package/dist/chunk-E6TERL5O.cjs.map +0 -1
  488. package/dist/chunk-EE6CPXKH.cjs +0 -164
  489. package/dist/chunk-EE6CPXKH.cjs.map +0 -1
  490. package/dist/chunk-EOFB7XCL.cjs +0 -837
  491. package/dist/chunk-EOFB7XCL.cjs.map +0 -1
  492. package/dist/chunk-ESLWRGAG.cjs +0 -92
  493. package/dist/chunk-ESLWRGAG.cjs.map +0 -1
  494. package/dist/chunk-ESMHTKLJ.cjs +0 -206
  495. package/dist/chunk-ESMHTKLJ.cjs.map +0 -1
  496. package/dist/chunk-FMTHVSYY.cjs +0 -1039
  497. package/dist/chunk-FMTHVSYY.cjs.map +0 -1
  498. package/dist/chunk-FU6R566Y.cjs +0 -236
  499. package/dist/chunk-FU6R566Y.cjs.map +0 -1
  500. package/dist/chunk-GYR5K654.js +0 -91
  501. package/dist/chunk-GYR5K654.js.map +0 -1
  502. package/dist/chunk-HA2WBOGQ.js +0 -57
  503. package/dist/chunk-HA2WBOGQ.js.map +0 -1
  504. package/dist/chunk-HT5JQKN2.js +0 -118
  505. package/dist/chunk-HT5JQKN2.js.map +0 -1
  506. package/dist/chunk-INJD3G4K.cjs +0 -340
  507. package/dist/chunk-INJD3G4K.cjs.map +0 -1
  508. package/dist/chunk-IOYFAFHJ.cjs +0 -95
  509. package/dist/chunk-IOYFAFHJ.cjs.map +0 -1
  510. package/dist/chunk-J5QENANM.js +0 -87
  511. package/dist/chunk-J5QENANM.js.map +0 -1
  512. package/dist/chunk-J7VGRIAJ.js +0 -64
  513. package/dist/chunk-J7VGRIAJ.js.map +0 -1
  514. package/dist/chunk-KFOHQK7X.js +0 -144
  515. package/dist/chunk-KFOHQK7X.js.map +0 -1
  516. package/dist/chunk-KIL5CUN6.js +0 -31
  517. package/dist/chunk-KIL5CUN6.js.map +0 -1
  518. package/dist/chunk-KYXZS3EA.cjs +0 -100
  519. package/dist/chunk-KYXZS3EA.cjs.map +0 -1
  520. package/dist/chunk-LITNXTTT.js +0 -3
  521. package/dist/chunk-LITNXTTT.js.map +0 -1
  522. package/dist/chunk-LVIPBYFE.js +0 -157
  523. package/dist/chunk-LVIPBYFE.js.map +0 -1
  524. package/dist/chunk-M3LFHHTN.cjs +0 -764
  525. package/dist/chunk-M3LFHHTN.cjs.map +0 -1
  526. package/dist/chunk-N25JDZSC.js +0 -95
  527. package/dist/chunk-N25JDZSC.js.map +0 -1
  528. package/dist/chunk-NEIB3TLD.cjs +0 -360
  529. package/dist/chunk-NEIB3TLD.cjs.map +0 -1
  530. package/dist/chunk-NENU7E6V.cjs +0 -344
  531. package/dist/chunk-NENU7E6V.cjs.map +0 -1
  532. package/dist/chunk-NVAI5CCN.cjs +0 -39
  533. package/dist/chunk-NVAI5CCN.cjs.map +0 -1
  534. package/dist/chunk-NZ72VDNY.cjs +0 -4
  535. package/dist/chunk-NZ72VDNY.cjs.map +0 -1
  536. package/dist/chunk-OPPXYVEZ.cjs +0 -131
  537. package/dist/chunk-OPPXYVEZ.cjs.map +0 -1
  538. package/dist/chunk-Q4EULJQY.js +0 -35
  539. package/dist/chunk-Q4EULJQY.js.map +0 -1
  540. package/dist/chunk-QF7ARNUM.js +0 -339
  541. package/dist/chunk-QF7ARNUM.js.map +0 -1
  542. package/dist/chunk-QWW3E3JM.cjs +0 -178
  543. package/dist/chunk-QWW3E3JM.cjs.map +0 -1
  544. package/dist/chunk-R7QYGZUP.cjs +0 -1075
  545. package/dist/chunk-R7QYGZUP.cjs.map +0 -1
  546. package/dist/chunk-RUPKBKUF.js +0 -352
  547. package/dist/chunk-RUPKBKUF.js.map +0 -1
  548. package/dist/chunk-SEO6NAQT.js +0 -14
  549. package/dist/chunk-SEO6NAQT.js.map +0 -1
  550. package/dist/chunk-T4B5LB6E.cjs +0 -66
  551. package/dist/chunk-T4B5LB6E.cjs.map +0 -1
  552. package/dist/chunk-T5WRA76K.cjs +0 -32
  553. package/dist/chunk-T5WRA76K.cjs.map +0 -1
  554. package/dist/chunk-T7JO2TCP.js +0 -1233
  555. package/dist/chunk-T7JO2TCP.js.map +0 -1
  556. package/dist/chunk-TC5ZPWM4.cjs +0 -289
  557. package/dist/chunk-TC5ZPWM4.cjs.map +0 -1
  558. package/dist/chunk-TQ5UWA7S.js +0 -26
  559. package/dist/chunk-TQ5UWA7S.js.map +0 -1
  560. package/dist/chunk-UIKYE2QZ.js +0 -833
  561. package/dist/chunk-UIKYE2QZ.js.map +0 -1
  562. package/dist/chunk-UNPLAVE7.js +0 -21
  563. package/dist/chunk-UNPLAVE7.js.map +0 -1
  564. package/dist/chunk-UY3UYPBZ.cjs +0 -77
  565. package/dist/chunk-UY3UYPBZ.cjs.map +0 -1
  566. package/dist/chunk-V7UBMJAB.cjs +0 -1242
  567. package/dist/chunk-V7UBMJAB.cjs.map +0 -1
  568. package/dist/chunk-VH77IPJN.cjs +0 -358
  569. package/dist/chunk-VH77IPJN.cjs.map +0 -1
  570. package/dist/chunk-VQTCQKHQ.cjs +0 -17
  571. package/dist/chunk-VQTCQKHQ.cjs.map +0 -1
  572. package/dist/chunk-WGWSHJ2N.js +0 -38
  573. package/dist/chunk-WGWSHJ2N.js.map +0 -1
  574. package/dist/chunk-WJH6IYU2.cjs +0 -32
  575. package/dist/chunk-WJH6IYU2.cjs.map +0 -1
  576. package/dist/chunk-YREV3LGG.cjs +0 -61
  577. package/dist/chunk-YREV3LGG.cjs.map +0 -1
  578. package/dist/chunk-YTXEZ4SD.cjs +0 -77
  579. package/dist/chunk-YTXEZ4SD.cjs.map +0 -1
  580. package/dist/chunk-ZNMBW67B.cjs +0 -40
  581. package/dist/chunk-ZNMBW67B.cjs.map +0 -1
  582. package/dist/correlation-id.cjs.map +0 -1
  583. package/dist/correlation-id.js.map +0 -1
  584. package/dist/define-event-BL6Li7CM.d.ts +0 -23
  585. package/dist/define-event-ClP3T1Jx.d.cts +0 -23
  586. package/dist/event-subscriber.cjs.map +0 -1
  587. package/dist/event-subscriber.js.map +0 -1
  588. package/dist/event.cjs.map +0 -1
  589. package/dist/event.js.map +0 -1
  590. package/dist/exporters.cjs.map +0 -1
  591. package/dist/exporters.js.map +0 -1
  592. package/dist/functional.cjs.map +0 -1
  593. package/dist/functional.js.map +0 -1
  594. package/dist/init-DIowiiCh.d.ts +0 -1167
  595. package/dist/init-j-A1zI16.d.cts +0 -1167
  596. package/dist/processors.cjs.map +0 -1
  597. package/dist/processors.js.map +0 -1
  598. package/dist/trace-context-DbGKd1Rn.d.cts +0 -213
  599. package/dist/trace-context-DbGKd1Rn.d.ts +0 -213
  600. package/dist/utils-BahBCFtJ.d.cts +0 -712
  601. package/dist/utils-CLKwaUlG.d.ts +0 -712
  602. package/dist/yaml-config.cjs.map +0 -1
@@ -1,16 +1,360 @@
1
- 'use strict';
1
+ Object.defineProperty(exports, Symbol.toStringTag, { value: 'Module' });
2
+ let _opentelemetry_api = require("@opentelemetry/api");
2
3
 
3
- var chunkINJD3G4K_cjs = require('./chunk-INJD3G4K.cjs');
4
-
5
-
6
-
7
- Object.defineProperty(exports, "BusinessBaggage", {
8
- enumerable: true,
9
- get: function () { return chunkINJD3G4K_cjs.BusinessBaggage; }
4
+ //#region src/business-baggage.ts
5
+ /**
6
+ * Safe baggage propagation with guardrails
7
+ *
8
+ * Provides type-safe baggage schemas with built-in protection against
9
+ * common pitfalls: high-cardinality values, PII leakage, and oversized payloads.
10
+ *
11
+ * @example Define a custom schema
12
+ * ```typescript
13
+ * import { createSafeBaggageSchema } from 'autotel/business-baggage';
14
+ *
15
+ * const OrderBaggage = createSafeBaggageSchema({
16
+ * orderId: { type: 'string' },
17
+ * customerId: { type: 'string', hash: true }, // Auto-hash for privacy
18
+ * priority: { type: 'enum', values: ['low', 'normal', 'high'] },
19
+ * });
20
+ *
21
+ * // Usage in traced function
22
+ * OrderBaggage.set(ctx, { orderId: 'ord-123', customerId: 'cust-456', priority: 'high' });
23
+ * const { orderId, priority } = OrderBaggage.get(ctx);
24
+ * ```
25
+ *
26
+ * @example Use pre-built BusinessBaggage
27
+ * ```typescript
28
+ * import { BusinessBaggage } from 'autotel/business-baggage';
29
+ *
30
+ * BusinessBaggage.set(ctx, { tenantId: 'acme', userId: 'user-123' });
31
+ * const { tenantId } = BusinessBaggage.get(ctx);
32
+ * ```
33
+ *
34
+ * @module
35
+ */
36
+ const DEFAULT_MAX_KEY_LENGTH = 64;
37
+ const DEFAULT_MAX_VALUE_LENGTH = 256;
38
+ const DEFAULT_MAX_TOTAL_SIZE = 8192;
39
+ const PII_PATTERNS = [
40
+ /\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b/,
41
+ /\b\d{3}[-.]?\d{3}[-.]?\d{4}\b/,
42
+ /\b\d{3}[-]?\d{2}[-]?\d{4}\b/,
43
+ /\b\d{16}\b/
44
+ ];
45
+ const HIGH_CARDINALITY_PATTERNS = [
46
+ /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i,
47
+ /^\d{13,}$/,
48
+ /^[A-Za-z0-9+/]{20,}={0,2}$/
49
+ ];
50
+ /**
51
+ * Create a safe baggage schema with validation and guardrails
52
+ *
53
+ * @param schema - Field definitions
54
+ * @param options - Safety options
55
+ * @returns Type-safe baggage schema
56
+ *
57
+ * @example
58
+ * ```typescript
59
+ * const MyBaggage = createSafeBaggageSchema({
60
+ * userId: { type: 'string', hash: true },
61
+ * region: { type: 'enum', values: ['us', 'eu', 'ap'] },
62
+ * debug: { type: 'boolean', defaultValue: false },
63
+ * });
64
+ * ```
65
+ */
66
+ function createSafeBaggageSchema(schema, options = {}) {
67
+ const { maxKeyLength = DEFAULT_MAX_KEY_LENGTH, maxValueLength = DEFAULT_MAX_VALUE_LENGTH, maxTotalSize = DEFAULT_MAX_TOTAL_SIZE, prefix = "", hashHighCardinality = false, redactPII = false, allowedKeys, onError } = options;
68
+ const schemaKeys = new Set(Object.keys(schema));
69
+ if (allowedKeys) {
70
+ for (const key of schemaKeys) if (!allowedKeys.includes(key)) throw new Error(`Key "${key}" not in allowedKeys whitelist`);
71
+ }
72
+ const prefixKey = (key) => prefix ? `${prefix}.${key}` : key;
73
+ const hashValue = (value) => {
74
+ let hash = 2166136261;
75
+ for (let i = 0; i < value.length; i++) {
76
+ hash ^= value.codePointAt(i) ?? 0;
77
+ hash = hash * 16777619 >>> 0;
78
+ }
79
+ return `h_${hash.toString(16)}`;
80
+ };
81
+ const containsPII = (value) => {
82
+ return PII_PATTERNS.some((pattern) => pattern.test(value));
83
+ };
84
+ const isHighCardinality = (value) => {
85
+ return HIGH_CARDINALITY_PATTERNS.some((pattern) => pattern.test(value));
86
+ };
87
+ const validateAndTransform = (key, value, fieldDef) => {
88
+ if (prefixKey(key).length > maxKeyLength) {
89
+ onError?.({
90
+ type: "key_length",
91
+ key,
92
+ message: `Key "${key}" exceeds max length ${maxKeyLength}`
93
+ });
94
+ return null;
95
+ }
96
+ if (value === void 0 || value === null) {
97
+ if (fieldDef.required) {
98
+ onError?.({
99
+ type: "validation",
100
+ key,
101
+ message: `Required field "${key}" is missing`
102
+ });
103
+ return null;
104
+ }
105
+ if (fieldDef.defaultValue === void 0) return null;
106
+ else value = fieldDef.defaultValue;
107
+ }
108
+ let stringValue;
109
+ switch (fieldDef.type) {
110
+ case "string":
111
+ if (typeof value !== "string") {
112
+ onError?.({
113
+ type: "validation",
114
+ key,
115
+ message: `Field "${key}" expected string, got ${typeof value}`,
116
+ value
117
+ });
118
+ return null;
119
+ }
120
+ stringValue = value;
121
+ break;
122
+ case "number":
123
+ if (typeof value !== "number" || Number.isNaN(value)) {
124
+ onError?.({
125
+ type: "validation",
126
+ key,
127
+ message: `Field "${key}" expected number, got ${typeof value}`,
128
+ value
129
+ });
130
+ return null;
131
+ }
132
+ stringValue = String(value);
133
+ break;
134
+ case "boolean":
135
+ if (typeof value !== "boolean") {
136
+ onError?.({
137
+ type: "validation",
138
+ key,
139
+ message: `Field "${key}" expected boolean, got ${typeof value}`,
140
+ value
141
+ });
142
+ return null;
143
+ }
144
+ stringValue = String(value);
145
+ break;
146
+ case "enum":
147
+ if (!fieldDef.values?.includes(String(value))) {
148
+ onError?.({
149
+ type: "validation",
150
+ key,
151
+ message: `Field "${key}" value "${value}" not in allowed values: ${fieldDef.values?.join(", ")}`,
152
+ value
153
+ });
154
+ return null;
155
+ }
156
+ stringValue = String(value);
157
+ break;
158
+ default: stringValue = String(value);
159
+ }
160
+ if (fieldDef.validate && !fieldDef.validate(value)) {
161
+ onError?.({
162
+ type: "validation",
163
+ key,
164
+ message: `Field "${key}" failed custom validation`,
165
+ value
166
+ });
167
+ return null;
168
+ }
169
+ if (redactPII && containsPII(stringValue)) {
170
+ onError?.({
171
+ type: "pii",
172
+ key,
173
+ message: `Field "${key}" contains PII pattern`,
174
+ value: "[REDACTED]"
175
+ });
176
+ stringValue = hashValue(stringValue);
177
+ }
178
+ if (fieldDef.hash || hashHighCardinality && isHighCardinality(stringValue)) stringValue = hashValue(stringValue);
179
+ const maxLen = fieldDef.maxLength ?? maxValueLength;
180
+ if (stringValue.length > maxLen) {
181
+ onError?.({
182
+ type: "value_length",
183
+ key,
184
+ message: `Field "${key}" value exceeds max length ${maxLen}`,
185
+ value: stringValue
186
+ });
187
+ stringValue = stringValue.slice(0, maxLen);
188
+ }
189
+ return stringValue;
190
+ };
191
+ const parseValue = (key, stringValue, fieldDef) => {
192
+ switch (fieldDef.type) {
193
+ case "number": return Number.parseFloat(stringValue);
194
+ case "boolean": return stringValue === "true";
195
+ default: return stringValue;
196
+ }
197
+ };
198
+ return {
199
+ get() {
200
+ const baggage = _opentelemetry_api.propagation.getBaggage(_opentelemetry_api.context.active());
201
+ if (!baggage) return {};
202
+ const result = {};
203
+ for (const [key, fieldDef] of Object.entries(schema)) {
204
+ const fullKey = prefixKey(key);
205
+ const entry = baggage.getEntry(fullKey);
206
+ if (entry) result[key] = parseValue(key, entry.value, fieldDef);
207
+ else if (fieldDef.defaultValue !== void 0) result[key] = fieldDef.defaultValue;
208
+ }
209
+ return result;
210
+ },
211
+ set(ctx, values) {
212
+ let baggage = _opentelemetry_api.propagation.getBaggage(_opentelemetry_api.context.active()) ?? _opentelemetry_api.propagation.createBaggage();
213
+ let totalSize = 0;
214
+ for (const [key, entry] of baggage.getAllEntries()) totalSize += key.length + entry.value.length;
215
+ for (const [key, value] of Object.entries(values)) {
216
+ const fieldDef = schema[key];
217
+ if (!fieldDef) continue;
218
+ const fullKey = prefixKey(key);
219
+ const stringValue = validateAndTransform(key, value, fieldDef);
220
+ if (stringValue !== null) {
221
+ const entrySize = fullKey.length + stringValue.length;
222
+ if (totalSize + entrySize > maxTotalSize) {
223
+ onError?.({
224
+ type: "size",
225
+ key,
226
+ message: `Adding "${key}" would exceed max baggage size ${maxTotalSize}`,
227
+ value
228
+ });
229
+ continue;
230
+ }
231
+ baggage = baggage.setEntry(fullKey, { value: stringValue });
232
+ totalSize += entrySize;
233
+ }
234
+ }
235
+ const newContext = _opentelemetry_api.propagation.setBaggage(_opentelemetry_api.context.active(), baggage);
236
+ _opentelemetry_api.propagation.setBaggage(newContext, baggage);
237
+ },
238
+ getValue(key) {
239
+ const baggage = _opentelemetry_api.propagation.getBaggage(_opentelemetry_api.context.active());
240
+ if (!baggage) return void 0;
241
+ const fullKey = prefixKey(String(key));
242
+ const entry = baggage.getEntry(fullKey);
243
+ const fieldDef = schema[String(key)];
244
+ if (!entry) return fieldDef?.defaultValue;
245
+ if (!fieldDef) return;
246
+ return parseValue(String(key), entry.value, fieldDef);
247
+ },
248
+ setValue(key, value, ctx) {
249
+ this.set(ctx, { [key]: value });
250
+ },
251
+ clear() {
252
+ let baggage = _opentelemetry_api.propagation.getBaggage(_opentelemetry_api.context.active());
253
+ if (!baggage) return;
254
+ for (const key of Object.keys(schema)) {
255
+ const fullKey = prefixKey(key);
256
+ baggage = baggage.removeEntry(fullKey);
257
+ }
258
+ _opentelemetry_api.propagation.setBaggage(_opentelemetry_api.context.active(), baggage);
259
+ },
260
+ toHeaders() {
261
+ const headers = {};
262
+ _opentelemetry_api.propagation.inject(_opentelemetry_api.context.active(), headers);
263
+ return headers;
264
+ },
265
+ fromHeaders(headers, ctx) {
266
+ const extractedContext = _opentelemetry_api.propagation.extract(_opentelemetry_api.context.active(), headers);
267
+ const baggage = _opentelemetry_api.propagation.getBaggage(extractedContext);
268
+ if (baggage) {
269
+ const values = {};
270
+ for (const [key, fieldDef] of Object.entries(schema)) {
271
+ const fullKey = prefixKey(key);
272
+ const entry = baggage.getEntry(fullKey);
273
+ if (entry) values[key] = parseValue(key, entry.value, fieldDef);
274
+ }
275
+ this.set(ctx, values);
276
+ }
277
+ }
278
+ };
279
+ }
280
+ /**
281
+ * Pre-built baggage schema for common business context fields
282
+ *
283
+ * Fields:
284
+ * - `tenantId`: Multi-tenant identifier (string, max 64 chars)
285
+ * - `userId`: User identifier (hashed for privacy)
286
+ * - `correlationId`: Request correlation ID (string)
287
+ * - `workflowId`: Workflow/saga instance ID (string)
288
+ * - `priority`: Request priority (low, normal, high, critical)
289
+ * - `region`: Geographic region (string)
290
+ * - `channel`: Request channel (web, mobile, api, internal)
291
+ *
292
+ * @example
293
+ * ```typescript
294
+ * import { BusinessBaggage } from 'autotel/business-baggage';
295
+ *
296
+ * // Set business context at entry point
297
+ * BusinessBaggage.set(ctx, {
298
+ * tenantId: 'acme-corp',
299
+ * userId: 'user-123',
300
+ * priority: 'high',
301
+ * channel: 'api',
302
+ * });
303
+ *
304
+ * // Access anywhere in the trace
305
+ * const { tenantId, priority } = BusinessBaggage.get(ctx);
306
+ * ```
307
+ */
308
+ const BusinessBaggage = createSafeBaggageSchema({
309
+ tenantId: {
310
+ type: "string",
311
+ maxLength: 64
312
+ },
313
+ userId: {
314
+ type: "string",
315
+ hash: true,
316
+ maxLength: 64
317
+ },
318
+ correlationId: {
319
+ type: "string",
320
+ maxLength: 128
321
+ },
322
+ workflowId: {
323
+ type: "string",
324
+ maxLength: 128
325
+ },
326
+ priority: {
327
+ type: "enum",
328
+ values: [
329
+ "low",
330
+ "normal",
331
+ "high",
332
+ "critical"
333
+ ],
334
+ defaultValue: "normal"
335
+ },
336
+ region: {
337
+ type: "string",
338
+ maxLength: 32
339
+ },
340
+ channel: {
341
+ type: "enum",
342
+ values: [
343
+ "web",
344
+ "mobile",
345
+ "api",
346
+ "internal",
347
+ "webhook",
348
+ "scheduled"
349
+ ]
350
+ }
351
+ }, {
352
+ prefix: "biz",
353
+ redactPII: true,
354
+ hashHighCardinality: true
10
355
  });
11
- Object.defineProperty(exports, "createSafeBaggageSchema", {
12
- enumerable: true,
13
- get: function () { return chunkINJD3G4K_cjs.createSafeBaggageSchema; }
14
- });
15
- //# sourceMappingURL=business-baggage.cjs.map
356
+
357
+ //#endregion
358
+ exports.BusinessBaggage = BusinessBaggage;
359
+ exports.createSafeBaggageSchema = createSafeBaggageSchema;
16
360
  //# sourceMappingURL=business-baggage.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":[],"names":[],"mappings":"","file":"business-baggage.cjs"}
1
+ {"version":3,"file":"business-baggage.cjs","names":["propagation","context"],"sources":["../src/business-baggage.ts"],"sourcesContent":["/**\n * Safe baggage propagation with guardrails\n *\n * Provides type-safe baggage schemas with built-in protection against\n * common pitfalls: high-cardinality values, PII leakage, and oversized payloads.\n *\n * @example Define a custom schema\n * ```typescript\n * import { createSafeBaggageSchema } from 'autotel/business-baggage';\n *\n * const OrderBaggage = createSafeBaggageSchema({\n * orderId: { type: 'string' },\n * customerId: { type: 'string', hash: true }, // Auto-hash for privacy\n * priority: { type: 'enum', values: ['low', 'normal', 'high'] },\n * });\n *\n * // Usage in traced function\n * OrderBaggage.set(ctx, { orderId: 'ord-123', customerId: 'cust-456', priority: 'high' });\n * const { orderId, priority } = OrderBaggage.get(ctx);\n * ```\n *\n * @example Use pre-built BusinessBaggage\n * ```typescript\n * import { BusinessBaggage } from 'autotel/business-baggage';\n *\n * BusinessBaggage.set(ctx, { tenantId: 'acme', userId: 'user-123' });\n * const { tenantId } = BusinessBaggage.get(ctx);\n * ```\n *\n * @module\n */\n\nimport { context, propagation } from '@opentelemetry/api';\nimport type { TraceContext } from './trace-context';\n\n// ============================================================================\n// Types\n// ============================================================================\n\n/**\n * Supported field types in baggage schema\n */\nexport type BaggageFieldType = 'string' | 'number' | 'boolean' | 'enum';\n\n/**\n * Field definition in a baggage schema\n */\nexport interface BaggageFieldDefinition {\n /** Field type */\n type: BaggageFieldType;\n\n /** Maximum length for string values (default: 256) */\n maxLength?: number;\n\n /** Hash value before storing (for privacy) */\n hash?: boolean;\n\n /** Allowed values for enum type */\n values?: readonly string[];\n\n /** Default value if not provided */\n defaultValue?: string | number | boolean;\n\n /** Whether field is required */\n required?: boolean;\n\n /** Custom validation function */\n validate?: (value: unknown) => boolean;\n}\n\n/**\n * Options for creating a safe baggage schema\n */\nexport interface SafeBaggageOptions {\n /** Maximum key length (default: 64) */\n maxKeyLength?: number;\n\n /** Maximum value length (default: 256) */\n maxValueLength?: number;\n\n /** Maximum total baggage size in bytes (default: 8192) */\n maxTotalSize?: number;\n\n /** Prefix for all keys (default: none) */\n prefix?: string;\n\n /** Hash high-cardinality values automatically */\n hashHighCardinality?: boolean;\n\n /** Detect and redact PII patterns */\n redactPII?: boolean;\n\n /** Allowed keys whitelist (others rejected) */\n allowedKeys?: string[];\n\n /** Custom error handler */\n onError?: (error: BaggageError) => void;\n}\n\n/**\n * Schema definition type - maps field names to definitions\n */\nexport type BaggageSchemaDefinition = Record<string, BaggageFieldDefinition>;\n\n/**\n * Inferred type from schema definition\n */\nexport type InferBaggageType<T extends BaggageSchemaDefinition> = {\n [K in keyof T]?: T[K]['type'] extends 'string'\n ? string\n : T[K]['type'] extends 'number'\n ? number\n : T[K]['type'] extends 'boolean'\n ? boolean\n : T[K]['type'] extends 'enum'\n ? T[K]['values'] extends readonly string[]\n ? T[K]['values'][number]\n : string\n : unknown;\n};\n\n/**\n * Baggage error details\n */\nexport interface BaggageError {\n type: 'validation' | 'size' | 'pii' | 'key_length' | 'value_length';\n key: string;\n message: string;\n value?: unknown;\n}\n\n/**\n * Safe baggage schema interface\n */\nexport interface SafeBaggageSchema<T extends BaggageSchemaDefinition> {\n /**\n * Get baggage values from context\n */\n get(ctx?: TraceContext): Partial<InferBaggageType<T>>;\n\n /**\n * Set baggage values in context\n * Returns new context with baggage (for context propagation)\n */\n set(\n ctx: TraceContext | undefined,\n values: Partial<InferBaggageType<T>>,\n ): void;\n\n /**\n * Get a single baggage value\n */\n getValue<K extends keyof T>(\n key: K,\n ctx?: TraceContext,\n ): InferBaggageType<T>[K] | undefined;\n\n /**\n * Set a single baggage value\n */\n setValue<K extends keyof T>(\n key: K,\n value: InferBaggageType<T>[K],\n ctx?: TraceContext,\n ): void;\n\n /**\n * Clear all schema baggage values\n */\n clear(ctx?: TraceContext): void;\n\n /**\n * Get all baggage as headers for propagation\n */\n toHeaders(ctx?: TraceContext): Record<string, string>;\n\n /**\n * Restore baggage from headers\n */\n fromHeaders(headers: Record<string, string>, ctx?: TraceContext): void;\n}\n\n// ============================================================================\n// Constants\n// ============================================================================\n\nconst DEFAULT_MAX_KEY_LENGTH = 64;\nconst DEFAULT_MAX_VALUE_LENGTH = 256;\nconst DEFAULT_MAX_TOTAL_SIZE = 8192;\n\n// PII patterns to detect and redact\nconst PII_PATTERNS = [\n /\\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\\.[A-Z|a-z]{2,}\\b/, // Email\n /\\b\\d{3}[-.]?\\d{3}[-.]?\\d{4}\\b/, // Phone (US)\n /\\b\\d{3}[-]?\\d{2}[-]?\\d{4}\\b/, // SSN\n /\\b\\d{16}\\b/, // Credit card (basic)\n];\n\n// High-cardinality value patterns\nconst HIGH_CARDINALITY_PATTERNS = [\n /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/i, // UUID\n /^\\d{13,}$/, // Timestamps\n /^[A-Za-z0-9+/]{20,}={0,2}$/, // Base64\n];\n\n// ============================================================================\n// Implementation\n// ============================================================================\n\n/**\n * Create a safe baggage schema with validation and guardrails\n *\n * @param schema - Field definitions\n * @param options - Safety options\n * @returns Type-safe baggage schema\n *\n * @example\n * ```typescript\n * const MyBaggage = createSafeBaggageSchema({\n * userId: { type: 'string', hash: true },\n * region: { type: 'enum', values: ['us', 'eu', 'ap'] },\n * debug: { type: 'boolean', defaultValue: false },\n * });\n * ```\n */\nexport function createSafeBaggageSchema<T extends BaggageSchemaDefinition>(\n schema: T,\n options: SafeBaggageOptions = {},\n): SafeBaggageSchema<T> {\n const {\n maxKeyLength = DEFAULT_MAX_KEY_LENGTH,\n maxValueLength = DEFAULT_MAX_VALUE_LENGTH,\n maxTotalSize = DEFAULT_MAX_TOTAL_SIZE,\n prefix = '',\n hashHighCardinality = false,\n redactPII = false,\n allowedKeys,\n onError,\n } = options;\n\n // Validate schema keys\n const schemaKeys = new Set(Object.keys(schema));\n if (allowedKeys) {\n for (const key of schemaKeys) {\n if (!allowedKeys.includes(key)) {\n throw new Error(`Key \"${key}\" not in allowedKeys whitelist`);\n }\n }\n }\n\n // Prefix a key\n const prefixKey = (key: string): string =>\n prefix ? `${prefix}.${key}` : key;\n\n // Hash a value using simple FNV-1a (synchronous, no crypto dependency)\n const hashValue = (value: string): string => {\n let hash = 2_166_136_261;\n for (let i = 0; i < value.length; i++) {\n hash ^= value.codePointAt(i) ?? 0;\n hash = (hash * 16_777_619) >>> 0;\n }\n return `h_${hash.toString(16)}`;\n };\n\n // Check for PII\n const containsPII = (value: string): boolean => {\n return PII_PATTERNS.some((pattern) => pattern.test(value));\n };\n\n // Check for high-cardinality\n const isHighCardinality = (value: string): boolean => {\n return HIGH_CARDINALITY_PATTERNS.some((pattern) => pattern.test(value));\n };\n\n // Validate and transform a single value\n const validateAndTransform = (\n key: string,\n value: unknown,\n fieldDef: BaggageFieldDefinition,\n ): string | null => {\n const fullKey = prefixKey(key);\n\n // Check key length\n if (fullKey.length > maxKeyLength) {\n onError?.({\n type: 'key_length',\n key,\n message: `Key \"${key}\" exceeds max length ${maxKeyLength}`,\n });\n return null;\n }\n\n // Handle undefined/null with default\n if (value === undefined || value === null) {\n if (fieldDef.required) {\n onError?.({\n type: 'validation',\n key,\n message: `Required field \"${key}\" is missing`,\n });\n return null;\n }\n if (fieldDef.defaultValue === undefined) {\n return null;\n } else {\n value = fieldDef.defaultValue;\n }\n }\n\n // Type validation\n let stringValue: string;\n\n switch (fieldDef.type) {\n case 'string': {\n if (typeof value !== 'string') {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected string, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = value;\n break;\n }\n\n case 'number': {\n if (typeof value !== 'number' || Number.isNaN(value)) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected number, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n case 'boolean': {\n if (typeof value !== 'boolean') {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" expected boolean, got ${typeof value}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n case 'enum': {\n if (!fieldDef.values?.includes(String(value))) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" value \"${value}\" not in allowed values: ${fieldDef.values?.join(', ')}`,\n value,\n });\n return null;\n }\n stringValue = String(value);\n break;\n }\n\n default: {\n stringValue = String(value);\n }\n }\n\n // Custom validation\n if (fieldDef.validate && !fieldDef.validate(value)) {\n onError?.({\n type: 'validation',\n key,\n message: `Field \"${key}\" failed custom validation`,\n value,\n });\n return null;\n }\n\n // PII check\n if (redactPII && containsPII(stringValue)) {\n onError?.({\n type: 'pii',\n key,\n message: `Field \"${key}\" contains PII pattern`,\n value: '[REDACTED]',\n });\n stringValue = hashValue(stringValue);\n }\n\n // Hash if requested or high-cardinality\n if (\n fieldDef.hash ||\n (hashHighCardinality && isHighCardinality(stringValue))\n ) {\n stringValue = hashValue(stringValue);\n }\n\n // Length validation\n const maxLen = fieldDef.maxLength ?? maxValueLength;\n if (stringValue.length > maxLen) {\n onError?.({\n type: 'value_length',\n key,\n message: `Field \"${key}\" value exceeds max length ${maxLen}`,\n value: stringValue,\n });\n stringValue = stringValue.slice(0, maxLen);\n }\n\n return stringValue;\n };\n\n // Parse value back from baggage string\n const parseValue = (\n key: string,\n stringValue: string,\n fieldDef: BaggageFieldDefinition,\n ): unknown => {\n switch (fieldDef.type) {\n case 'number': {\n return Number.parseFloat(stringValue);\n }\n case 'boolean': {\n return stringValue === 'true';\n }\n default: {\n return stringValue;\n }\n }\n };\n\n return {\n get(): Partial<InferBaggageType<T>> {\n const baggage = propagation.getBaggage(context.active());\n if (!baggage) {\n return {};\n }\n\n const result: Record<string, unknown> = {};\n\n for (const [key, fieldDef] of Object.entries(schema)) {\n const fullKey = prefixKey(key);\n const entry = baggage.getEntry(fullKey);\n\n if (entry) {\n result[key] = parseValue(key, entry.value, fieldDef);\n } else if (fieldDef.defaultValue !== undefined) {\n result[key] = fieldDef.defaultValue;\n }\n }\n\n return result as Partial<InferBaggageType<T>>;\n },\n\n set(\n ctx: TraceContext | undefined,\n values: Partial<InferBaggageType<T>>,\n ): void {\n let baggage =\n propagation.getBaggage(context.active()) ?? propagation.createBaggage();\n let totalSize = 0;\n\n // Calculate existing size\n for (const [key, entry] of baggage.getAllEntries()) {\n totalSize += key.length + entry.value.length;\n }\n\n for (const [key, value] of Object.entries(values)) {\n const fieldDef = schema[key];\n if (!fieldDef) continue;\n\n const fullKey = prefixKey(key);\n const stringValue = validateAndTransform(key, value, fieldDef);\n\n if (stringValue !== null) {\n // Check total size\n const entrySize = fullKey.length + stringValue.length;\n if (totalSize + entrySize > maxTotalSize) {\n onError?.({\n type: 'size',\n key,\n message: `Adding \"${key}\" would exceed max baggage size ${maxTotalSize}`,\n value,\n });\n continue;\n }\n\n baggage = baggage.setEntry(fullKey, { value: stringValue });\n totalSize += entrySize;\n }\n }\n\n // Update context with new baggage\n const newContext = propagation.setBaggage(context.active(), baggage);\n // Note: This only works if the caller propagates the context\n // In OTel, baggage propagation happens via context.with()\n // For now we set on active context\n propagation.setBaggage(newContext, baggage);\n },\n\n getValue<K extends keyof T>(key: K): InferBaggageType<T>[K] | undefined {\n const baggage = propagation.getBaggage(context.active());\n if (!baggage) return undefined;\n\n const fullKey = prefixKey(String(key));\n const entry = baggage.getEntry(fullKey);\n const fieldDef = schema[String(key)];\n\n if (!entry) {\n return fieldDef?.defaultValue as InferBaggageType<T>[K] | undefined;\n }\n\n if (!fieldDef) {\n return undefined;\n }\n\n return parseValue(\n String(key),\n entry.value,\n fieldDef,\n ) as InferBaggageType<T>[K];\n },\n\n setValue<K extends keyof T>(\n key: K,\n value: InferBaggageType<T>[K],\n ctx?: TraceContext,\n ): void {\n this.set(ctx, { [key]: value } as Partial<InferBaggageType<T>>);\n },\n\n clear(): void {\n let baggage = propagation.getBaggage(context.active());\n if (!baggage) return;\n\n for (const key of Object.keys(schema)) {\n const fullKey = prefixKey(key);\n baggage = baggage.removeEntry(fullKey);\n }\n\n propagation.setBaggage(context.active(), baggage);\n },\n\n toHeaders(): Record<string, string> {\n const headers: Record<string, string> = {};\n propagation.inject(context.active(), headers);\n return headers;\n },\n\n fromHeaders(headers: Record<string, string>, ctx?: TraceContext): void {\n const extractedContext = propagation.extract(context.active(), headers);\n const baggage = propagation.getBaggage(extractedContext);\n\n if (baggage) {\n const values: Record<string, unknown> = {};\n\n for (const [key, fieldDef] of Object.entries(schema)) {\n const fullKey = prefixKey(key);\n const entry = baggage.getEntry(fullKey);\n\n if (entry) {\n values[key] = parseValue(key, entry.value, fieldDef);\n }\n }\n\n this.set(ctx, values as Partial<InferBaggageType<T>>);\n }\n },\n };\n}\n\n// ============================================================================\n// Pre-built Business Context Schema\n// ============================================================================\n\n/**\n * Pre-built baggage schema for common business context fields\n *\n * Fields:\n * - `tenantId`: Multi-tenant identifier (string, max 64 chars)\n * - `userId`: User identifier (hashed for privacy)\n * - `correlationId`: Request correlation ID (string)\n * - `workflowId`: Workflow/saga instance ID (string)\n * - `priority`: Request priority (low, normal, high, critical)\n * - `region`: Geographic region (string)\n * - `channel`: Request channel (web, mobile, api, internal)\n *\n * @example\n * ```typescript\n * import { BusinessBaggage } from 'autotel/business-baggage';\n *\n * // Set business context at entry point\n * BusinessBaggage.set(ctx, {\n * tenantId: 'acme-corp',\n * userId: 'user-123',\n * priority: 'high',\n * channel: 'api',\n * });\n *\n * // Access anywhere in the trace\n * const { tenantId, priority } = BusinessBaggage.get(ctx);\n * ```\n */\nexport const BusinessBaggage = createSafeBaggageSchema(\n {\n tenantId: {\n type: 'string',\n maxLength: 64,\n },\n userId: {\n type: 'string',\n hash: true, // Auto-hash for privacy\n maxLength: 64,\n },\n correlationId: {\n type: 'string',\n maxLength: 128,\n },\n workflowId: {\n type: 'string',\n maxLength: 128,\n },\n priority: {\n type: 'enum',\n values: ['low', 'normal', 'high', 'critical'] as const,\n defaultValue: 'normal',\n },\n region: {\n type: 'string',\n maxLength: 32,\n },\n channel: {\n type: 'enum',\n values: [\n 'web',\n 'mobile',\n 'api',\n 'internal',\n 'webhook',\n 'scheduled',\n ] as const,\n },\n },\n {\n prefix: 'biz',\n redactPII: true,\n hashHighCardinality: true,\n },\n);\n\n/**\n * Type alias for BusinessBaggage values\n */\nexport type BusinessBaggageValues = {\n tenantId?: string;\n userId?: string;\n correlationId?: string;\n workflowId?: string;\n priority?: 'low' | 'normal' | 'high' | 'critical';\n region?: string;\n channel?: 'web' | 'mobile' | 'api' | 'internal' | 'webhook' | 'scheduled';\n};\n"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA0LA,MAAM,yBAAyB;AAC/B,MAAM,2BAA2B;AACjC,MAAM,yBAAyB;AAG/B,MAAM,eAAe;CACnB;CACA;CACA;CACA;AACF;AAGA,MAAM,4BAA4B;CAChC;CACA;CACA;AACF;;;;;;;;;;;;;;;;;AAsBA,SAAgB,wBACd,QACA,UAA8B,CAAC,GACT;CACtB,MAAM,EACJ,eAAe,wBACf,iBAAiB,0BACjB,eAAe,wBACf,SAAS,IACT,sBAAsB,OACtB,YAAY,OACZ,aACA,YACE;CAGJ,MAAM,aAAa,IAAI,IAAI,OAAO,KAAK,MAAM,CAAC;CAC9C,IAAI,aACF;OAAK,MAAM,OAAO,YAChB,IAAI,CAAC,YAAY,SAAS,GAAG,GAC3B,MAAM,IAAI,MAAM,QAAQ,IAAI,+BAA+B;CAE/D;CAIF,MAAM,aAAa,QACjB,SAAS,GAAG,OAAO,GAAG,QAAQ;CAGhC,MAAM,aAAa,UAA0B;EAC3C,IAAI,OAAO;EACX,KAAK,IAAI,IAAI,GAAG,IAAI,MAAM,QAAQ,KAAK;GACrC,QAAQ,MAAM,YAAY,CAAC,KAAK;GAChC,OAAQ,OAAO,aAAgB;EACjC;EACA,OAAO,KAAK,KAAK,SAAS,EAAE;CAC9B;CAGA,MAAM,eAAe,UAA2B;EAC9C,OAAO,aAAa,MAAM,YAAY,QAAQ,KAAK,KAAK,CAAC;CAC3D;CAGA,MAAM,qBAAqB,UAA2B;EACpD,OAAO,0BAA0B,MAAM,YAAY,QAAQ,KAAK,KAAK,CAAC;CACxE;CAGA,MAAM,wBACJ,KACA,OACA,aACkB;EAIlB,IAHgB,UAAU,GAGhB,CAAC,CAAC,SAAS,cAAc;GACjC,UAAU;IACR,MAAM;IACN;IACA,SAAS,QAAQ,IAAI,uBAAuB;GAC9C,CAAC;GACD,OAAO;EACT;EAGA,IAAI,UAAU,UAAa,UAAU,MAAM;GACzC,IAAI,SAAS,UAAU;IACrB,UAAU;KACR,MAAM;KACN;KACA,SAAS,mBAAmB,IAAI;IAClC,CAAC;IACD,OAAO;GACT;GACA,IAAI,SAAS,iBAAiB,QAC5B,OAAO;QAEP,QAAQ,SAAS;EAErB;EAGA,IAAI;EAEJ,QAAQ,SAAS,MAAjB;GACE,KAAK;IACH,IAAI,OAAO,UAAU,UAAU;KAC7B,UAAU;MACR,MAAM;MACN;MACA,SAAS,UAAU,IAAI,yBAAyB,OAAO;MACvD;KACF,CAAC;KACD,OAAO;IACT;IACA,cAAc;IACd;GAGF,KAAK;IACH,IAAI,OAAO,UAAU,YAAY,OAAO,MAAM,KAAK,GAAG;KACpD,UAAU;MACR,MAAM;MACN;MACA,SAAS,UAAU,IAAI,yBAAyB,OAAO;MACvD;KACF,CAAC;KACD,OAAO;IACT;IACA,cAAc,OAAO,KAAK;IAC1B;GAGF,KAAK;IACH,IAAI,OAAO,UAAU,WAAW;KAC9B,UAAU;MACR,MAAM;MACN;MACA,SAAS,UAAU,IAAI,0BAA0B,OAAO;MACxD;KACF,CAAC;KACD,OAAO;IACT;IACA,cAAc,OAAO,KAAK;IAC1B;GAGF,KAAK;IACH,IAAI,CAAC,SAAS,QAAQ,SAAS,OAAO,KAAK,CAAC,GAAG;KAC7C,UAAU;MACR,MAAM;MACN;MACA,SAAS,UAAU,IAAI,WAAW,MAAM,2BAA2B,SAAS,QAAQ,KAAK,IAAI;MAC7F;KACF,CAAC;KACD,OAAO;IACT;IACA,cAAc,OAAO,KAAK;IAC1B;GAGF,SACE,cAAc,OAAO,KAAK;EAE9B;EAGA,IAAI,SAAS,YAAY,CAAC,SAAS,SAAS,KAAK,GAAG;GAClD,UAAU;IACR,MAAM;IACN;IACA,SAAS,UAAU,IAAI;IACvB;GACF,CAAC;GACD,OAAO;EACT;EAGA,IAAI,aAAa,YAAY,WAAW,GAAG;GACzC,UAAU;IACR,MAAM;IACN;IACA,SAAS,UAAU,IAAI;IACvB,OAAO;GACT,CAAC;GACD,cAAc,UAAU,WAAW;EACrC;EAGA,IACE,SAAS,QACR,uBAAuB,kBAAkB,WAAW,GAErD,cAAc,UAAU,WAAW;EAIrC,MAAM,SAAS,SAAS,aAAa;EACrC,IAAI,YAAY,SAAS,QAAQ;GAC/B,UAAU;IACR,MAAM;IACN;IACA,SAAS,UAAU,IAAI,6BAA6B;IACpD,OAAO;GACT,CAAC;GACD,cAAc,YAAY,MAAM,GAAG,MAAM;EAC3C;EAEA,OAAO;CACT;CAGA,MAAM,cACJ,KACA,aACA,aACY;EACZ,QAAQ,SAAS,MAAjB;GACE,KAAK,UACH,OAAO,OAAO,WAAW,WAAW;GAEtC,KAAK,WACH,OAAO,gBAAgB;GAEzB,SACE,OAAO;EAEX;CACF;CAEA,OAAO;EACL,MAAoC;GAClC,MAAM,UAAUA,+BAAY,WAAWC,2BAAQ,OAAO,CAAC;GACvD,IAAI,CAAC,SACH,OAAO,CAAC;GAGV,MAAM,SAAkC,CAAC;GAEzC,KAAK,MAAM,CAAC,KAAK,aAAa,OAAO,QAAQ,MAAM,GAAG;IACpD,MAAM,UAAU,UAAU,GAAG;IAC7B,MAAM,QAAQ,QAAQ,SAAS,OAAO;IAEtC,IAAI,OACF,OAAO,OAAO,WAAW,KAAK,MAAM,OAAO,QAAQ;SAC9C,IAAI,SAAS,iBAAiB,QACnC,OAAO,OAAO,SAAS;GAE3B;GAEA,OAAO;EACT;EAEA,IACE,KACA,QACM;GACN,IAAI,UACFD,+BAAY,WAAWC,2BAAQ,OAAO,CAAC,KAAKD,+BAAY,cAAc;GACxE,IAAI,YAAY;GAGhB,KAAK,MAAM,CAAC,KAAK,UAAU,QAAQ,cAAc,GAC/C,aAAa,IAAI,SAAS,MAAM,MAAM;GAGxC,KAAK,MAAM,CAAC,KAAK,UAAU,OAAO,QAAQ,MAAM,GAAG;IACjD,MAAM,WAAW,OAAO;IACxB,IAAI,CAAC,UAAU;IAEf,MAAM,UAAU,UAAU,GAAG;IAC7B,MAAM,cAAc,qBAAqB,KAAK,OAAO,QAAQ;IAE7D,IAAI,gBAAgB,MAAM;KAExB,MAAM,YAAY,QAAQ,SAAS,YAAY;KAC/C,IAAI,YAAY,YAAY,cAAc;MACxC,UAAU;OACR,MAAM;OACN;OACA,SAAS,WAAW,IAAI,kCAAkC;OAC1D;MACF,CAAC;MACD;KACF;KAEA,UAAU,QAAQ,SAAS,SAAS,EAAE,OAAO,YAAY,CAAC;KAC1D,aAAa;IACf;GACF;GAGA,MAAM,aAAaA,+BAAY,WAAWC,2BAAQ,OAAO,GAAG,OAAO;GAInE,+BAAY,WAAW,YAAY,OAAO;EAC5C;EAEA,SAA4B,KAA4C;GACtE,MAAM,UAAUD,+BAAY,WAAWC,2BAAQ,OAAO,CAAC;GACvD,IAAI,CAAC,SAAS,OAAO;GAErB,MAAM,UAAU,UAAU,OAAO,GAAG,CAAC;GACrC,MAAM,QAAQ,QAAQ,SAAS,OAAO;GACtC,MAAM,WAAW,OAAO,OAAO,GAAG;GAElC,IAAI,CAAC,OACH,OAAO,UAAU;GAGnB,IAAI,CAAC,UACH;GAGF,OAAO,WACL,OAAO,GAAG,GACV,MAAM,OACN,QACF;EACF;EAEA,SACE,KACA,OACA,KACM;GACN,KAAK,IAAI,KAAK,GAAG,MAAM,MAAM,CAAiC;EAChE;EAEA,QAAc;GACZ,IAAI,UAAUD,+BAAY,WAAWC,2BAAQ,OAAO,CAAC;GACrD,IAAI,CAAC,SAAS;GAEd,KAAK,MAAM,OAAO,OAAO,KAAK,MAAM,GAAG;IACrC,MAAM,UAAU,UAAU,GAAG;IAC7B,UAAU,QAAQ,YAAY,OAAO;GACvC;GAEA,+BAAY,WAAWA,2BAAQ,OAAO,GAAG,OAAO;EAClD;EAEA,YAAoC;GAClC,MAAM,UAAkC,CAAC;GACzC,+BAAY,OAAOA,2BAAQ,OAAO,GAAG,OAAO;GAC5C,OAAO;EACT;EAEA,YAAY,SAAiC,KAA0B;GACrE,MAAM,mBAAmBD,+BAAY,QAAQC,2BAAQ,OAAO,GAAG,OAAO;GACtE,MAAM,UAAUD,+BAAY,WAAW,gBAAgB;GAEvD,IAAI,SAAS;IACX,MAAM,SAAkC,CAAC;IAEzC,KAAK,MAAM,CAAC,KAAK,aAAa,OAAO,QAAQ,MAAM,GAAG;KACpD,MAAM,UAAU,UAAU,GAAG;KAC7B,MAAM,QAAQ,QAAQ,SAAS,OAAO;KAEtC,IAAI,OACF,OAAO,OAAO,WAAW,KAAK,MAAM,OAAO,QAAQ;IAEvD;IAEA,KAAK,IAAI,KAAK,MAAsC;GACtD;EACF;CACF;AACF;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkCA,MAAa,kBAAkB,wBAC7B;CACE,UAAU;EACR,MAAM;EACN,WAAW;CACb;CACA,QAAQ;EACN,MAAM;EACN,MAAM;EACN,WAAW;CACb;CACA,eAAe;EACb,MAAM;EACN,WAAW;CACb;CACA,YAAY;EACV,MAAM;EACN,WAAW;CACb;CACA,UAAU;EACR,MAAM;EACN,QAAQ;GAAC;GAAO;GAAU;GAAQ;EAAU;EAC5C,cAAc;CAChB;CACA,QAAQ;EACN,MAAM;EACN,WAAW;CACb;CACA,SAAS;EACP,MAAM;EACN,QAAQ;GACN;GACA;GACA;GACA;GACA;GACA;EACF;CACF;AACF,GACA;CACE,QAAQ;CACR,WAAW;CACX,qBAAqB;AACvB,CACF"}