jialing-code 1.1.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 (460) hide show
  1. package/README.md +97 -0
  2. package/dist/chunk-065m026w.js +97 -0
  3. package/dist/chunk-06saje2v.js +39 -0
  4. package/dist/chunk-0731m51q.js +8 -0
  5. package/dist/chunk-0975ccyw.js +265 -0
  6. package/dist/chunk-09n3fjx5.js +67 -0
  7. package/dist/chunk-0bdjdzew.js +41 -0
  8. package/dist/chunk-0ce6kd7y.js +212 -0
  9. package/dist/chunk-0e1xsncc.js +969 -0
  10. package/dist/chunk-0m2861gw.js +154 -0
  11. package/dist/chunk-0paqc2yw.js +15 -0
  12. package/dist/chunk-0rg6yrhy.js +99 -0
  13. package/dist/chunk-0sakxrcf.js +643 -0
  14. package/dist/chunk-0v9hwxvz.js +105 -0
  15. package/dist/chunk-0vkfrmqm.js +690 -0
  16. package/dist/chunk-0vvfnhhv.js +248 -0
  17. package/dist/chunk-0w4rsycj.js +145 -0
  18. package/dist/chunk-0x9b2nmd.js +63 -0
  19. package/dist/chunk-0xjaqda8.js +1124 -0
  20. package/dist/chunk-1141xmr4.js +8 -0
  21. package/dist/chunk-13d1842d.js +154 -0
  22. package/dist/chunk-1921a6yb.js +32 -0
  23. package/dist/chunk-1ad8mk9g.js +527 -0
  24. package/dist/chunk-1ax41pws.js +28 -0
  25. package/dist/chunk-1c8z1b5v.js +16 -0
  26. package/dist/chunk-1cbn5kxf.js +7 -0
  27. package/dist/chunk-1eapde8a.js +726 -0
  28. package/dist/chunk-1h2famwb.js +49 -0
  29. package/dist/chunk-1jggnf7z.js +85 -0
  30. package/dist/chunk-1k92pn9c.js +32 -0
  31. package/dist/chunk-1qakq4sn.js +802 -0
  32. package/dist/chunk-1rvz0433.js +722 -0
  33. package/dist/chunk-1xkekb9y.js +19 -0
  34. package/dist/chunk-238g70xa.js +36 -0
  35. package/dist/chunk-24ge0eqa.js +106 -0
  36. package/dist/chunk-278vghwm.js +5395 -0
  37. package/dist/chunk-27xc1csx.js +104 -0
  38. package/dist/chunk-2a42s11t.js +412 -0
  39. package/dist/chunk-2aa02aw6.js +438 -0
  40. package/dist/chunk-2eykm0j0.js +20 -0
  41. package/dist/chunk-2gzv8nrw.js +205 -0
  42. package/dist/chunk-2k995y2x.js +880 -0
  43. package/dist/chunk-2nayx6q1.js +63 -0
  44. package/dist/chunk-2sd2w2h4.js +44 -0
  45. package/dist/chunk-2tw2ve8h.js +145 -0
  46. package/dist/chunk-30rst83v.js +168 -0
  47. package/dist/chunk-3aavh06g.js +1581 -0
  48. package/dist/chunk-3b0yvt2h.js +469 -0
  49. package/dist/chunk-3be7ka25.js +56 -0
  50. package/dist/chunk-3c25bcsw.js +17 -0
  51. package/dist/chunk-3dyxka97.js +584 -0
  52. package/dist/chunk-3f7rypmf.js +16544 -0
  53. package/dist/chunk-3fsd7f51.js +93 -0
  54. package/dist/chunk-3gqdqmzb.js +75 -0
  55. package/dist/chunk-3h8a89gy.js +46 -0
  56. package/dist/chunk-3m84sret.js +71 -0
  57. package/dist/chunk-3nb7j3js.js +96 -0
  58. package/dist/chunk-3p08nvn2.js +98 -0
  59. package/dist/chunk-3r09htpc.js +318 -0
  60. package/dist/chunk-3r24h7t6.js +113 -0
  61. package/dist/chunk-3rkfxjtq.js +80 -0
  62. package/dist/chunk-3tmk7dc2.js +604 -0
  63. package/dist/chunk-3w6s9m5w.js +16 -0
  64. package/dist/chunk-43qjymy5.js +92 -0
  65. package/dist/chunk-44fpr6jq.js +434 -0
  66. package/dist/chunk-45kxdsp8.js +444 -0
  67. package/dist/chunk-495d85x1.js +8066 -0
  68. package/dist/chunk-4ba796se.js +1095 -0
  69. package/dist/chunk-4g3v8y12.js +23 -0
  70. package/dist/chunk-4h53xj8n.js +3445 -0
  71. package/dist/chunk-4jm600zv.js +13 -0
  72. package/dist/chunk-4jy9dtwk.js +116 -0
  73. package/dist/chunk-4p60dd45.js +55 -0
  74. package/dist/chunk-4z0jsrqg.js +81 -0
  75. package/dist/chunk-4zfkzkt6.js +37 -0
  76. package/dist/chunk-55wgxwa9.js +13877 -0
  77. package/dist/chunk-5dbk24zg.js +890 -0
  78. package/dist/chunk-5hzvp4va.js +115 -0
  79. package/dist/chunk-5kbt1mbt.js +500 -0
  80. package/dist/chunk-5pen7vr8.js +176 -0
  81. package/dist/chunk-5r280eng.js +198 -0
  82. package/dist/chunk-5srym52s.js +88 -0
  83. package/dist/chunk-600kg7k6.js +41 -0
  84. package/dist/chunk-616w0qj3.js +160 -0
  85. package/dist/chunk-62jw1t8c.js +94 -0
  86. package/dist/chunk-62xmt9mk.js +372 -0
  87. package/dist/chunk-64bvg7c3.js +229 -0
  88. package/dist/chunk-65yhe4s0.js +281 -0
  89. package/dist/chunk-6aewh27m.js +102 -0
  90. package/dist/chunk-6bd8brc4.js +48 -0
  91. package/dist/chunk-6dj5t602.js +341 -0
  92. package/dist/chunk-6exxdk1p.js +6956 -0
  93. package/dist/chunk-6f5j8fs0.js +752 -0
  94. package/dist/chunk-6g62sjpf.js +328 -0
  95. package/dist/chunk-6gecq2ta.js +1493 -0
  96. package/dist/chunk-6gr3c3w9.js +378 -0
  97. package/dist/chunk-6kpbgc5w.js +23 -0
  98. package/dist/chunk-6kseqw79.js +154 -0
  99. package/dist/chunk-6mxm1qd0.js +40764 -0
  100. package/dist/chunk-6n2qgm9v.js +8 -0
  101. package/dist/chunk-6tq2v3rk.js +186 -0
  102. package/dist/chunk-6wsdhj3v.js +93 -0
  103. package/dist/chunk-6zw9fhgb.js +4389 -0
  104. package/dist/chunk-71grc1mw.js +111 -0
  105. package/dist/chunk-73rpbt04.js +1947 -0
  106. package/dist/chunk-748feghg.js +604 -0
  107. package/dist/chunk-75e8gtg9.js +84 -0
  108. package/dist/chunk-75th4717.js +780 -0
  109. package/dist/chunk-760252na.js +101 -0
  110. package/dist/chunk-7739pg2c.js +4261 -0
  111. package/dist/chunk-778fnx46.js +472 -0
  112. package/dist/chunk-77g09znh.js +391 -0
  113. package/dist/chunk-7aw745vx.js +40175 -0
  114. package/dist/chunk-7m2nd8da.js +110 -0
  115. package/dist/chunk-7n35vjtw.js +444 -0
  116. package/dist/chunk-7n5ss4sh.js +144 -0
  117. package/dist/chunk-7rjnxcfe.js +107 -0
  118. package/dist/chunk-7sb5axvf.js +122 -0
  119. package/dist/chunk-7wm5s02e.js +216 -0
  120. package/dist/chunk-7ymfj7m3.js +151 -0
  121. package/dist/chunk-7z8j9qfn.js +121 -0
  122. package/dist/chunk-7zsapntc.js +216 -0
  123. package/dist/chunk-805fhkfh.js +908 -0
  124. package/dist/chunk-80k1nj24.js +253 -0
  125. package/dist/chunk-83hfzbx3.js +10 -0
  126. package/dist/chunk-85cypsdd.js +92 -0
  127. package/dist/chunk-8760caxf.js +2644 -0
  128. package/dist/chunk-88f6egg6.js +387 -0
  129. package/dist/chunk-88r7kwgj.js +22 -0
  130. package/dist/chunk-89e1v45e.js +463 -0
  131. package/dist/chunk-8bedvdm1.js +32 -0
  132. package/dist/chunk-8c4x4vdz.js +177 -0
  133. package/dist/chunk-8hq5kk3y.js +44 -0
  134. package/dist/chunk-8ngxagxq.js +18 -0
  135. package/dist/chunk-8tnsngw2.js +31 -0
  136. package/dist/chunk-8wjnca8h.js +307 -0
  137. package/dist/chunk-8y12jxg8.js +10 -0
  138. package/dist/chunk-8ymf4e6z.js +48 -0
  139. package/dist/chunk-90wp6wez.js +10510 -0
  140. package/dist/chunk-92bp5bnf.js +650 -0
  141. package/dist/chunk-92q8sx5z.js +90 -0
  142. package/dist/chunk-958rtmtx.js +10476 -0
  143. package/dist/chunk-9e2kqv5g.js +125 -0
  144. package/dist/chunk-9f4f1hy5.js +281 -0
  145. package/dist/chunk-9gbamk79.js +93 -0
  146. package/dist/chunk-9k5s3ryh.js +167 -0
  147. package/dist/chunk-9xzfqm15.js +97 -0
  148. package/dist/chunk-9zgdvbm6.js +110 -0
  149. package/dist/chunk-a0p3q8jw.js +24 -0
  150. package/dist/chunk-a22sayzp.js +220 -0
  151. package/dist/chunk-a8ejc632.js +3094 -0
  152. package/dist/chunk-a8gj9d9z.js +120 -0
  153. package/dist/chunk-a9vdeb6y.js +258 -0
  154. package/dist/chunk-a9yev47v.js +674 -0
  155. package/dist/chunk-a9zh40sj.js +48 -0
  156. package/dist/chunk-ack5mfba.js +105 -0
  157. package/dist/chunk-ae76ded0.js +30 -0
  158. package/dist/chunk-akjw4dh6.js +538 -0
  159. package/dist/chunk-asc6wz4q.js +1188 -0
  160. package/dist/chunk-atqejh3p.js +273 -0
  161. package/dist/chunk-atv2e6b7.js +61 -0
  162. package/dist/chunk-axvvkwz8.js +1551 -0
  163. package/dist/chunk-azgz7kj9.js +38 -0
  164. package/dist/chunk-b3zave8q.js +275 -0
  165. package/dist/chunk-b4wg70y1.js +54 -0
  166. package/dist/chunk-b8b13qn2.js +100 -0
  167. package/dist/chunk-bg3mt9bm.js +28 -0
  168. package/dist/chunk-bh4jvcjn.js +91 -0
  169. package/dist/chunk-bhdt6k7w.js +15 -0
  170. package/dist/chunk-bm1qb16p.js +17 -0
  171. package/dist/chunk-bpvsd1j1.js +266 -0
  172. package/dist/chunk-bqfnp99q.js +477 -0
  173. package/dist/chunk-bsbmmfyt.js +17 -0
  174. package/dist/chunk-bsbt34jm.js +42 -0
  175. package/dist/chunk-c78akdhr.js +458 -0
  176. package/dist/chunk-cdz5yb0r.js +57 -0
  177. package/dist/chunk-cfv996bs.js +22 -0
  178. package/dist/chunk-cgfdkzhb.js +12 -0
  179. package/dist/chunk-ckh4r5er.js +257 -0
  180. package/dist/chunk-cmgjnvn9.js +89 -0
  181. package/dist/chunk-cpjgvay8.js +687 -0
  182. package/dist/chunk-crfryjx9.js +276 -0
  183. package/dist/chunk-ctw5jwcd.js +213 -0
  184. package/dist/chunk-cvy3vntc.js +65 -0
  185. package/dist/chunk-cwbzz504.js +94 -0
  186. package/dist/chunk-cy2hswr1.js +15 -0
  187. package/dist/chunk-cyejkay3.js +222 -0
  188. package/dist/chunk-d18z9pna.js +106 -0
  189. package/dist/chunk-d5cq0n0v.js +162 -0
  190. package/dist/chunk-db45aryp.js +50 -0
  191. package/dist/chunk-de8nqh0z.js +790 -0
  192. package/dist/chunk-dfw6h350.js +2336 -0
  193. package/dist/chunk-dgqrcy74.js +48 -0
  194. package/dist/chunk-dn75ptgd.js +184 -0
  195. package/dist/chunk-dnh7jtpb.js +37 -0
  196. package/dist/chunk-dpshyv9m.js +90 -0
  197. package/dist/chunk-dt8cdvnm.js +642 -0
  198. package/dist/chunk-dtxby6fr.js +306 -0
  199. package/dist/chunk-dv1wfr85.js +6373 -0
  200. package/dist/chunk-dw363edx.js +1154 -0
  201. package/dist/chunk-dwrdacck.js +62 -0
  202. package/dist/chunk-dxnnv5e3.js +276 -0
  203. package/dist/chunk-e3g8q4cn.js +1646 -0
  204. package/dist/chunk-e3m9k9s2.js +542 -0
  205. package/dist/chunk-e4q49asn.js +155 -0
  206. package/dist/chunk-e5pntxye.js +37 -0
  207. package/dist/chunk-e7393td6.js +42 -0
  208. package/dist/chunk-ead42yrh.js +87 -0
  209. package/dist/chunk-eb90vwvr.js +152 -0
  210. package/dist/chunk-ecvwk9hg.js +250 -0
  211. package/dist/chunk-edjd6aay.js +173 -0
  212. package/dist/chunk-eg0h8mtm.js +130 -0
  213. package/dist/chunk-ehtwnxpg.js +1591 -0
  214. package/dist/chunk-ek686gx1.js +94 -0
  215. package/dist/chunk-eqp1rfft.js +17 -0
  216. package/dist/chunk-evhwt0ar.js +1015 -0
  217. package/dist/chunk-ewadzrm8.js +103 -0
  218. package/dist/chunk-ewsgsw9h.js +172291 -0
  219. package/dist/chunk-f0pa0r7e.js +3198 -0
  220. package/dist/chunk-f2mhrmww.js +62 -0
  221. package/dist/chunk-f39zxvwn.js +401 -0
  222. package/dist/chunk-f46z54tq.js +374 -0
  223. package/dist/chunk-f5ma3nh5.js +3436 -0
  224. package/dist/chunk-f60q23az.js +3038 -0
  225. package/dist/chunk-f6v2nz57.js +107 -0
  226. package/dist/chunk-f6yjan38.js +38 -0
  227. package/dist/chunk-fbv4apne.js +51 -0
  228. package/dist/chunk-fem4s778.js +70 -0
  229. package/dist/chunk-fezm1kn8.js +376 -0
  230. package/dist/chunk-fm1n3ysp.js +6108 -0
  231. package/dist/chunk-frg83bfw.js +225 -0
  232. package/dist/chunk-fscm8db0.js +692 -0
  233. package/dist/chunk-fyc5fepv.js +10 -0
  234. package/dist/chunk-g0j0t6qk.js +26 -0
  235. package/dist/chunk-g0nc1ftf.js +849 -0
  236. package/dist/chunk-g338npwr.js +1061 -0
  237. package/dist/chunk-g3t0act8.js +8 -0
  238. package/dist/chunk-g75w4hw3.js +26 -0
  239. package/dist/chunk-g8vp82en.js +1866 -0
  240. package/dist/chunk-gax0fcbx.js +182 -0
  241. package/dist/chunk-gsz4dh3y.js +606 -0
  242. package/dist/chunk-gtfffm7h.js +440 -0
  243. package/dist/chunk-gver9zb9.js +420 -0
  244. package/dist/chunk-gyj242zr.js +20 -0
  245. package/dist/chunk-h0qngp9w.js +157 -0
  246. package/dist/chunk-h14kemnk.js +123 -0
  247. package/dist/chunk-h8wj1a74.js +8960 -0
  248. package/dist/chunk-h9mcb2eg.js +87 -0
  249. package/dist/chunk-h9nh2980.js +91 -0
  250. package/dist/chunk-hakdhagh.js +16606 -0
  251. package/dist/chunk-hbc6ymdv.js +55 -0
  252. package/dist/chunk-hh7cmy4k.js +20 -0
  253. package/dist/chunk-hjhc4cpt.js +69 -0
  254. package/dist/chunk-hjwez8qc.js +5018 -0
  255. package/dist/chunk-hk9xz7gk.js +118 -0
  256. package/dist/chunk-hqmz36b3.js +552 -0
  257. package/dist/chunk-hrzerbfw.js +1299 -0
  258. package/dist/chunk-hs8ph4p8.js +8 -0
  259. package/dist/chunk-ht1xwrnd.js +716 -0
  260. package/dist/chunk-hvmfg2dc.js +338 -0
  261. package/dist/chunk-hx2tr4ep.js +7189 -0
  262. package/dist/chunk-hzhe8ygc.js +547 -0
  263. package/dist/chunk-j2k4p94p.js +55 -0
  264. package/dist/chunk-j3a4p81y.js +184 -0
  265. package/dist/chunk-j49g6g3s.js +57 -0
  266. package/dist/chunk-j5d5hp9h.js +71 -0
  267. package/dist/chunk-j64ga6ta.js +8035 -0
  268. package/dist/chunk-j7tyxan1.js +116 -0
  269. package/dist/chunk-j8v4774z.js +424 -0
  270. package/dist/chunk-jafes477.js +29 -0
  271. package/dist/chunk-jd32zbps.js +15 -0
  272. package/dist/chunk-jdgeec04.js +4249 -0
  273. package/dist/chunk-jftd4jq5.js +4521 -0
  274. package/dist/chunk-jkxqhv6y.js +812 -0
  275. package/dist/chunk-jmfr6h0n.js +120 -0
  276. package/dist/chunk-jn4aabmx.js +40 -0
  277. package/dist/chunk-jnhkref0.js +30 -0
  278. package/dist/chunk-jsbpm1gz.js +27 -0
  279. package/dist/chunk-jtcyjc3k.js +5802 -0
  280. package/dist/chunk-jx817w05.js +11 -0
  281. package/dist/chunk-jzmz18nn.js +65 -0
  282. package/dist/chunk-k0p9w03v.js +4957 -0
  283. package/dist/chunk-k3dcdnck.js +89 -0
  284. package/dist/chunk-k3wadzcd.js +88 -0
  285. package/dist/chunk-kaeshsk1.js +713 -0
  286. package/dist/chunk-kbkey9ed.js +522 -0
  287. package/dist/chunk-kcwfhqbb.js +196 -0
  288. package/dist/chunk-key6jr7p.js +224 -0
  289. package/dist/chunk-knay8cy9.js +173 -0
  290. package/dist/chunk-kr3rg2y1.js +95 -0
  291. package/dist/chunk-kwekc97v.js +18 -0
  292. package/dist/chunk-m06q12hg.js +61 -0
  293. package/dist/chunk-m2mcpbhk.js +43 -0
  294. package/dist/chunk-m8v220gz.js +71 -0
  295. package/dist/chunk-mgpqy78h.js +208 -0
  296. package/dist/chunk-mkejwh4t.js +16 -0
  297. package/dist/chunk-mptyw5n1.js +107 -0
  298. package/dist/chunk-mqajm0dp.js +66 -0
  299. package/dist/chunk-mrksbgxj.js +490 -0
  300. package/dist/chunk-msjfc5ba.js +246 -0
  301. package/dist/chunk-mt25echc.js +6157 -0
  302. package/dist/chunk-mt3jfnr8.js +277 -0
  303. package/dist/chunk-mtn242d4.js +9300 -0
  304. package/dist/chunk-mzfkvave.js +169 -0
  305. package/dist/chunk-n0qaeaa5.js +256 -0
  306. package/dist/chunk-n1erf6kh.js +22820 -0
  307. package/dist/chunk-n2avk1r2.js +61 -0
  308. package/dist/chunk-n6atnpcq.js +765 -0
  309. package/dist/chunk-n7ttdtk0.js +641 -0
  310. package/dist/chunk-ncnfzby5.js +822 -0
  311. package/dist/chunk-ncnr1jtf.js +2058 -0
  312. package/dist/chunk-nerv0jvx.js +74 -0
  313. package/dist/chunk-ngd2abep.js +90 -0
  314. package/dist/chunk-nka1g8f4.js +773 -0
  315. package/dist/chunk-nnaxkc2z.js +128 -0
  316. package/dist/chunk-npyrtj8j.js +691 -0
  317. package/dist/chunk-nq0fxyxh.js +752 -0
  318. package/dist/chunk-nrmffak7.js +114 -0
  319. package/dist/chunk-nsz546wq.js +1170 -0
  320. package/dist/chunk-nt837qt9.js +21 -0
  321. package/dist/chunk-nv64x1z5.js +86 -0
  322. package/dist/chunk-nxsh6de2.js +1711 -0
  323. package/dist/chunk-nz4getcr.js +40 -0
  324. package/dist/chunk-p1f607pa.js +83 -0
  325. package/dist/chunk-p2816w9z.js +1486 -0
  326. package/dist/chunk-p2d5nh3g.js +342 -0
  327. package/dist/chunk-p4r5y02t.js +90 -0
  328. package/dist/chunk-p7g7pf3f.js +336 -0
  329. package/dist/chunk-pb4ad8r2.js +110 -0
  330. package/dist/chunk-pbrhz0zr.js +716 -0
  331. package/dist/chunk-ps49ymvj.js +43 -0
  332. package/dist/chunk-pwnt3veb.js +103 -0
  333. package/dist/chunk-pwwa7s62.js +11 -0
  334. package/dist/chunk-px3w0kde.js +299 -0
  335. package/dist/chunk-pzn777jb.js +756 -0
  336. package/dist/chunk-q25bjaev.js +15 -0
  337. package/dist/chunk-q5by3da6.js +8 -0
  338. package/dist/chunk-q6av622g.js +38 -0
  339. package/dist/chunk-q6xkvtf2.js +1318 -0
  340. package/dist/chunk-q81jx1tq.js +476 -0
  341. package/dist/chunk-qehb6fk5.js +339 -0
  342. package/dist/chunk-qj1avx1q.js +87 -0
  343. package/dist/chunk-qn2dxr66.js +105 -0
  344. package/dist/chunk-qnfx3qtx.js +617 -0
  345. package/dist/chunk-qp18kd4h.js +48 -0
  346. package/dist/chunk-qp2qdcda.js +100 -0
  347. package/dist/chunk-qpjy9tcf.js +133 -0
  348. package/dist/chunk-qqfa0dqg.js +2343 -0
  349. package/dist/chunk-qwh3htcz.js +202 -0
  350. package/dist/chunk-qz2x630m.js +49145 -0
  351. package/dist/chunk-r3vakcs1.js +496 -0
  352. package/dist/chunk-r66hz8j6.js +34 -0
  353. package/dist/chunk-r6b58y3x.js +17 -0
  354. package/dist/chunk-rekp48rk.js +62 -0
  355. package/dist/chunk-rn0v1hk8.js +34 -0
  356. package/dist/chunk-rs1xrs6m.js +534 -0
  357. package/dist/chunk-rs45skes.js +123 -0
  358. package/dist/chunk-rzszqp82.js +524 -0
  359. package/dist/chunk-s274nv8k.js +8 -0
  360. package/dist/chunk-s3pzvdss.js +50 -0
  361. package/dist/chunk-s9mesaw0.js +26840 -0
  362. package/dist/chunk-sd36yzx8.js +954 -0
  363. package/dist/chunk-sdj9b9wh.js +782 -0
  364. package/dist/chunk-sdw2q69p.js +227 -0
  365. package/dist/chunk-sfgp9cc0.js +130 -0
  366. package/dist/chunk-spqaamnc.js +63 -0
  367. package/dist/chunk-spzrs4df.js +73 -0
  368. package/dist/chunk-sxkr7k43.js +55 -0
  369. package/dist/chunk-szj5wvdy.js +28 -0
  370. package/dist/chunk-t0rgmccj.js +39 -0
  371. package/dist/chunk-t1nnzjgg.js +17 -0
  372. package/dist/chunk-t94fcnt8.js +566 -0
  373. package/dist/chunk-tjaqa99q.js +125 -0
  374. package/dist/chunk-tjq2evtw.js +328 -0
  375. package/dist/chunk-ts2p6bv1.js +224 -0
  376. package/dist/chunk-ttk5dzz8.js +25 -0
  377. package/dist/chunk-tw0q7ynt.js +59 -0
  378. package/dist/chunk-v02jkvgy.js +131 -0
  379. package/dist/chunk-v084bqt3.js +1529 -0
  380. package/dist/chunk-v0amythm.js +164 -0
  381. package/dist/chunk-v1kzp02e.js +785 -0
  382. package/dist/chunk-v1mgv1et.js +15 -0
  383. package/dist/chunk-v399mzxk.js +58 -0
  384. package/dist/chunk-v3gm2day.js +8 -0
  385. package/dist/chunk-v43hrrxp.js +71 -0
  386. package/dist/chunk-v6aqb2aj.js +102 -0
  387. package/dist/chunk-v78fj8by.js +145 -0
  388. package/dist/chunk-v7qmhjdn.js +1921 -0
  389. package/dist/chunk-v9smspw2.js +4301 -0
  390. package/dist/chunk-vdw93s4h.js +2431 -0
  391. package/dist/chunk-vest0y6x.js +3830 -0
  392. package/dist/chunk-vf5sd1nq.js +12 -0
  393. package/dist/chunk-vratq94g.js +349 -0
  394. package/dist/chunk-vrz7t3m3.js +20 -0
  395. package/dist/chunk-vtb185z9.js +70 -0
  396. package/dist/chunk-vx01rvg8.js +654 -0
  397. package/dist/chunk-vyc0rjyx.js +31 -0
  398. package/dist/chunk-vyjeh50y.js +2149 -0
  399. package/dist/chunk-vzpffsza.js +269 -0
  400. package/dist/chunk-w2ef3kxk.js +3353 -0
  401. package/dist/chunk-w2z5pqd3.js +336 -0
  402. package/dist/chunk-w3whm4mn.js +432 -0
  403. package/dist/chunk-w7wgpqcp.js +157 -0
  404. package/dist/chunk-waa00cvb.js +301 -0
  405. package/dist/chunk-wb0qm4es.js +155 -0
  406. package/dist/chunk-wbkahkdc.js +27 -0
  407. package/dist/chunk-wfz0qffj.js +3939 -0
  408. package/dist/chunk-wn0cx0pt.js +283 -0
  409. package/dist/chunk-wv6gzt9c.js +726 -0
  410. package/dist/chunk-wx42ycm4.js +998 -0
  411. package/dist/chunk-wxkpgy05.js +268 -0
  412. package/dist/chunk-wzpdet3m.js +843 -0
  413. package/dist/chunk-x0mwzt38.js +714 -0
  414. package/dist/chunk-x592wbfh.js +244 -0
  415. package/dist/chunk-x5pqsp9r.js +100 -0
  416. package/dist/chunk-x679thag.js +825 -0
  417. package/dist/chunk-x8b7vft8.js +132 -0
  418. package/dist/chunk-x8cftch7.js +119 -0
  419. package/dist/chunk-x9q7r885.js +348 -0
  420. package/dist/chunk-xawkt0vb.js +1585 -0
  421. package/dist/chunk-xdw5dv00.js +8 -0
  422. package/dist/chunk-xe9cc860.js +287 -0
  423. package/dist/chunk-xjr9c3vt.js +101 -0
  424. package/dist/chunk-xk7zaqta.js +21933 -0
  425. package/dist/chunk-xktbmawc.js +678 -0
  426. package/dist/chunk-xn6yw46v.js +140 -0
  427. package/dist/chunk-xsq9ae7x.js +90 -0
  428. package/dist/chunk-xszk7n10.js +14358 -0
  429. package/dist/chunk-xt8a5r1t.js +84 -0
  430. package/dist/chunk-xydyndkv.js +195 -0
  431. package/dist/chunk-xzt10yc5.js +60 -0
  432. package/dist/chunk-y04y95dr.js +91 -0
  433. package/dist/chunk-y1784krc.js +19 -0
  434. package/dist/chunk-y1x32h3x.js +128 -0
  435. package/dist/chunk-y3s7aww5.js +99 -0
  436. package/dist/chunk-y47cg3kz.js +42 -0
  437. package/dist/chunk-y7kzvepn.js +469 -0
  438. package/dist/chunk-y89kbsyc.js +287 -0
  439. package/dist/chunk-yd87p1c3.js +159 -0
  440. package/dist/chunk-yf3yw8fw.js +105 -0
  441. package/dist/chunk-ygbf0ezx.js +1391 -0
  442. package/dist/chunk-yjbxnshv.js +208 -0
  443. package/dist/chunk-ynednmqd.js +192 -0
  444. package/dist/chunk-yvhez44y.js +259 -0
  445. package/dist/chunk-ywxd4qw4.js +22 -0
  446. package/dist/chunk-yzrmgpy4.js +117 -0
  447. package/dist/chunk-z0b2vb24.js +862 -0
  448. package/dist/chunk-z1zj044v.js +655 -0
  449. package/dist/chunk-z2dp53wn.js +17 -0
  450. package/dist/chunk-z3w0xasa.js +165 -0
  451. package/dist/chunk-z7ycmrb3.js +644 -0
  452. package/dist/chunk-zh11tdkb.js +347 -0
  453. package/dist/chunk-zk2wsm7d.js +15 -0
  454. package/dist/chunk-zqfqcf22.js +229 -0
  455. package/dist/chunk-zqk2j8px.js +699 -0
  456. package/dist/chunk-zqvsc10j.js +2833 -0
  457. package/dist/chunk-zsfxha74.js +17655 -0
  458. package/dist/chunk-zvc4snyb.js +117 -0
  459. package/dist/cli.js +194 -0
  460. package/package.json +173 -0
@@ -0,0 +1,2058 @@
1
+ // @bun
2
+ import {
3
+ endInteractionSpan,
4
+ init_betaSessionTracing,
5
+ init_perfettoTracing,
6
+ init_sessionTracing,
7
+ initializePerfettoTracing,
8
+ isBetaTracingEnabled,
9
+ isEnhancedTelemetryEnabled
10
+ } from "./chunk-ygbf0ezx.js";
11
+ import {
12
+ require_src as require_src5
13
+ } from "./chunk-a8ejc632.js";
14
+ import {
15
+ BatchLogRecordProcessor,
16
+ ConsoleLogRecordExporter,
17
+ LoggerProvider,
18
+ checkHasTrustDialogAccepted,
19
+ getAuthHeaders,
20
+ getClaudeCodeUserAgent,
21
+ getGlobalConfig,
22
+ getOtelHeadersFromHelper,
23
+ getSettings_DEPRECATED,
24
+ getSubscriptionType,
25
+ hasProfileScope,
26
+ init_auth,
27
+ init_config1 as init_config,
28
+ init_esm,
29
+ init_esm1 as init_esm2,
30
+ init_http,
31
+ init_settings1 as init_settings,
32
+ init_userAgent,
33
+ is1PApiCustomer,
34
+ isClaudeAISubscriber,
35
+ logs,
36
+ saveGlobalConfig,
37
+ withOAuth401Retry
38
+ } from "./chunk-3f7rypmf.js";
39
+ import"./chunk-e3g8q4cn.js";
40
+ import"./chunk-ctw5jwcd.js";
41
+ import"./chunk-0e1xsncc.js";
42
+ import"./chunk-vratq94g.js";
43
+ import"./chunk-g0j0t6qk.js";
44
+ import"./chunk-6kpbgc5w.js";
45
+ import"./chunk-3c25bcsw.js";
46
+ import {
47
+ getPlatform,
48
+ getWslVersion,
49
+ init_platform
50
+ } from "./chunk-tjaqa99q.js";
51
+ import"./chunk-55wgxwa9.js";
52
+ import"./chunk-w2z5pqd3.js";
53
+ import"./chunk-7ymfj7m3.js";
54
+ import {
55
+ require_src as require_src2,
56
+ require_src1 as require_src3,
57
+ require_src2 as require_src4
58
+ } from "./chunk-f5ma3nh5.js";
59
+ import"./chunk-v1kzp02e.js";
60
+ import {
61
+ HttpsProxyAgent,
62
+ getCACertificates,
63
+ getMTLSConfig,
64
+ getProxyUrl,
65
+ init_caCerts,
66
+ init_dist,
67
+ init_mtls,
68
+ init_proxy,
69
+ shouldBypassProxy
70
+ } from "./chunk-1eapde8a.js";
71
+ import {
72
+ require_src
73
+ } from "./chunk-p2816w9z.js";
74
+ import {
75
+ init_startupProfiler,
76
+ profileCheckpoint
77
+ } from "./chunk-1rvz0433.js";
78
+ import"./chunk-cdz5yb0r.js";
79
+ import"./chunk-f2mhrmww.js";
80
+ import"./chunk-hrzerbfw.js";
81
+ import {
82
+ init_memoize,
83
+ memoizeWithTTLAsync
84
+ } from "./chunk-d18z9pna.js";
85
+ import"./chunk-qnfx3qtx.js";
86
+ import"./chunk-hjhc4cpt.js";
87
+ import"./chunk-vyc0rjyx.js";
88
+ import"./chunk-hx2tr4ep.js";
89
+ import {
90
+ init_log,
91
+ init_privacyLevel,
92
+ isEssentialTrafficOnly,
93
+ logError
94
+ } from "./chunk-p7g7pf3f.js";
95
+ import"./chunk-8tnsngw2.js";
96
+ import"./chunk-8bedvdm1.js";
97
+ import"./chunk-7wm5s02e.js";
98
+ import {
99
+ errorMessage,
100
+ getHasFormattedOutput,
101
+ init_cleanupRegistry,
102
+ init_debug,
103
+ init_errors,
104
+ init_slowOperations,
105
+ jsonStringify,
106
+ logForDebugging,
107
+ registerCleanup,
108
+ toError
109
+ } from "./chunk-nxsh6de2.js";
110
+ import"./chunk-fbv4apne.js";
111
+ import {
112
+ init_envUtils,
113
+ isEnvTruthy
114
+ } from "./chunk-3r24h7t6.js";
115
+ import {
116
+ getIsNonInteractiveSession,
117
+ getLoggerProvider,
118
+ getMeterProvider,
119
+ getTracerProvider,
120
+ init_state,
121
+ setEventLogger,
122
+ setLoggerProvider,
123
+ setMeterProvider,
124
+ setTracerProvider
125
+ } from "./chunk-qqfa0dqg.js";
126
+ import"./chunk-hqmz36b3.js";
127
+ import"./chunk-4g3v8y12.js";
128
+ import"./chunk-7739pg2c.js";
129
+ import {
130
+ axios_default,
131
+ init_axios
132
+ } from "./chunk-xszk7n10.js";
133
+ import"./chunk-sdj9b9wh.js";
134
+ import {
135
+ __esm,
136
+ __require,
137
+ __toESM
138
+ } from "./chunk-qp2qdcda.js";
139
+
140
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/enums.js
141
+ var ExceptionEventName = "exception";
142
+ var init_enums = () => {};
143
+
144
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/Span.js
145
+ class SpanImpl {
146
+ _spanContext;
147
+ kind;
148
+ parentSpanContext;
149
+ attributes = {};
150
+ links = [];
151
+ events = [];
152
+ startTime;
153
+ resource;
154
+ instrumentationScope;
155
+ _droppedAttributesCount = 0;
156
+ _droppedEventsCount = 0;
157
+ _droppedLinksCount = 0;
158
+ _attributesCount = 0;
159
+ name;
160
+ status = {
161
+ code: import_api.SpanStatusCode.UNSET
162
+ };
163
+ endTime = [0, 0];
164
+ _ended = false;
165
+ _duration = [-1, -1];
166
+ _spanProcessor;
167
+ _spanLimits;
168
+ _attributeValueLengthLimit;
169
+ _recordEndMetrics;
170
+ _performanceStartTime;
171
+ _performanceOffset;
172
+ _startTimeProvided;
173
+ constructor(opts) {
174
+ const now = Date.now();
175
+ this._spanContext = opts.spanContext;
176
+ this._performanceStartTime = import_core.otperformance.now();
177
+ this._performanceOffset = now - (this._performanceStartTime + import_core.otperformance.timeOrigin);
178
+ this._startTimeProvided = opts.startTime != null;
179
+ this._spanLimits = opts.spanLimits;
180
+ this._attributeValueLengthLimit = this._spanLimits.attributeValueLengthLimit ?? 0;
181
+ this._spanProcessor = opts.spanProcessor;
182
+ this.name = opts.name;
183
+ this.parentSpanContext = opts.parentSpanContext;
184
+ this.kind = opts.kind;
185
+ if (opts.links) {
186
+ for (const link of opts.links) {
187
+ this.addLink(link);
188
+ }
189
+ }
190
+ this.startTime = this._getTime(opts.startTime ?? now);
191
+ this.resource = opts.resource;
192
+ this.instrumentationScope = opts.scope;
193
+ this._recordEndMetrics = opts.recordEndMetrics;
194
+ if (opts.attributes != null) {
195
+ this.setAttributes(opts.attributes);
196
+ }
197
+ this._spanProcessor.onStart(this, opts.context);
198
+ }
199
+ spanContext() {
200
+ return this._spanContext;
201
+ }
202
+ setAttribute(key, value) {
203
+ if (value == null || this._isSpanEnded())
204
+ return this;
205
+ if (key.length === 0) {
206
+ import_api.diag.warn(`Invalid attribute key: ${key}`);
207
+ return this;
208
+ }
209
+ if (!import_core.isAttributeValue(value)) {
210
+ import_api.diag.warn(`Invalid attribute value set for key: ${key}`);
211
+ return this;
212
+ }
213
+ const { attributeCountLimit } = this._spanLimits;
214
+ const isNewKey = !Object.prototype.hasOwnProperty.call(this.attributes, key);
215
+ if (attributeCountLimit !== undefined && this._attributesCount >= attributeCountLimit && isNewKey) {
216
+ this._droppedAttributesCount++;
217
+ return this;
218
+ }
219
+ this.attributes[key] = this._truncateToSize(value);
220
+ if (isNewKey) {
221
+ this._attributesCount++;
222
+ }
223
+ return this;
224
+ }
225
+ setAttributes(attributes) {
226
+ for (const key in attributes) {
227
+ if (Object.prototype.hasOwnProperty.call(attributes, key)) {
228
+ this.setAttribute(key, attributes[key]);
229
+ }
230
+ }
231
+ return this;
232
+ }
233
+ addEvent(name, attributesOrStartTime, timeStamp) {
234
+ if (this._isSpanEnded())
235
+ return this;
236
+ const { eventCountLimit } = this._spanLimits;
237
+ if (eventCountLimit === 0) {
238
+ import_api.diag.warn("No events allowed.");
239
+ this._droppedEventsCount++;
240
+ return this;
241
+ }
242
+ if (eventCountLimit !== undefined && this.events.length >= eventCountLimit) {
243
+ if (this._droppedEventsCount === 0) {
244
+ import_api.diag.debug("Dropping extra events.");
245
+ }
246
+ this.events.shift();
247
+ this._droppedEventsCount++;
248
+ }
249
+ if (import_core.isTimeInput(attributesOrStartTime)) {
250
+ if (!import_core.isTimeInput(timeStamp)) {
251
+ timeStamp = attributesOrStartTime;
252
+ }
253
+ attributesOrStartTime = undefined;
254
+ }
255
+ const sanitized = import_core.sanitizeAttributes(attributesOrStartTime);
256
+ const { attributePerEventCountLimit } = this._spanLimits;
257
+ const attributes = {};
258
+ let droppedAttributesCount = 0;
259
+ let eventAttributesCount = 0;
260
+ for (const attr in sanitized) {
261
+ if (!Object.prototype.hasOwnProperty.call(sanitized, attr)) {
262
+ continue;
263
+ }
264
+ const attrVal = sanitized[attr];
265
+ if (attributePerEventCountLimit !== undefined && eventAttributesCount >= attributePerEventCountLimit) {
266
+ droppedAttributesCount++;
267
+ continue;
268
+ }
269
+ attributes[attr] = this._truncateToSize(attrVal);
270
+ eventAttributesCount++;
271
+ }
272
+ this.events.push({
273
+ name,
274
+ attributes,
275
+ time: this._getTime(timeStamp),
276
+ droppedAttributesCount
277
+ });
278
+ return this;
279
+ }
280
+ addLink(link) {
281
+ if (this._isSpanEnded())
282
+ return this;
283
+ const { linkCountLimit } = this._spanLimits;
284
+ if (linkCountLimit === 0) {
285
+ this._droppedLinksCount++;
286
+ return this;
287
+ }
288
+ if (linkCountLimit !== undefined && this.links.length >= linkCountLimit) {
289
+ if (this._droppedLinksCount === 0) {
290
+ import_api.diag.debug("Dropping extra links.");
291
+ }
292
+ this.links.shift();
293
+ this._droppedLinksCount++;
294
+ }
295
+ const { attributePerLinkCountLimit } = this._spanLimits;
296
+ const sanitized = import_core.sanitizeAttributes(link.attributes);
297
+ const attributes = {};
298
+ let droppedAttributesCount = 0;
299
+ let linkAttributesCount = 0;
300
+ for (const attr in sanitized) {
301
+ if (!Object.prototype.hasOwnProperty.call(sanitized, attr)) {
302
+ continue;
303
+ }
304
+ const attrVal = sanitized[attr];
305
+ if (attributePerLinkCountLimit !== undefined && linkAttributesCount >= attributePerLinkCountLimit) {
306
+ droppedAttributesCount++;
307
+ continue;
308
+ }
309
+ attributes[attr] = this._truncateToSize(attrVal);
310
+ linkAttributesCount++;
311
+ }
312
+ const processedLink = { context: link.context };
313
+ if (linkAttributesCount > 0) {
314
+ processedLink.attributes = attributes;
315
+ }
316
+ if (droppedAttributesCount > 0) {
317
+ processedLink.droppedAttributesCount = droppedAttributesCount;
318
+ }
319
+ this.links.push(processedLink);
320
+ return this;
321
+ }
322
+ addLinks(links) {
323
+ for (const link of links) {
324
+ this.addLink(link);
325
+ }
326
+ return this;
327
+ }
328
+ setStatus(status) {
329
+ if (this._isSpanEnded())
330
+ return this;
331
+ if (status.code === import_api.SpanStatusCode.UNSET)
332
+ return this;
333
+ if (this.status.code === import_api.SpanStatusCode.OK)
334
+ return this;
335
+ const newStatus = { code: status.code };
336
+ if (status.code === import_api.SpanStatusCode.ERROR) {
337
+ if (typeof status.message === "string") {
338
+ newStatus.message = status.message;
339
+ } else if (status.message != null) {
340
+ import_api.diag.warn(`Dropping invalid status.message of type '${typeof status.message}', expected 'string'`);
341
+ }
342
+ }
343
+ this.status = newStatus;
344
+ return this;
345
+ }
346
+ updateName(name) {
347
+ if (this._isSpanEnded())
348
+ return this;
349
+ this.name = name;
350
+ return this;
351
+ }
352
+ end(endTime) {
353
+ if (this._isSpanEnded()) {
354
+ import_api.diag.error(`${this.name} ${this._spanContext.traceId}-${this._spanContext.spanId} - You can only call end() on a span once.`);
355
+ return;
356
+ }
357
+ this.endTime = this._getTime(endTime);
358
+ this._duration = import_core.hrTimeDuration(this.startTime, this.endTime);
359
+ if (this._duration[0] < 0) {
360
+ import_api.diag.warn("Inconsistent start and end time, startTime > endTime. Setting span duration to 0ms.", this.startTime, this.endTime);
361
+ this.endTime = this.startTime.slice();
362
+ this._duration = [0, 0];
363
+ }
364
+ if (this._droppedEventsCount > 0) {
365
+ import_api.diag.warn(`Dropped ${this._droppedEventsCount} events because eventCountLimit reached`);
366
+ }
367
+ if (this._droppedLinksCount > 0) {
368
+ import_api.diag.warn(`Dropped ${this._droppedLinksCount} links because linkCountLimit reached`);
369
+ }
370
+ if (this._spanProcessor.onEnding) {
371
+ this._spanProcessor.onEnding(this);
372
+ }
373
+ this._recordEndMetrics?.();
374
+ this._ended = true;
375
+ this._spanProcessor.onEnd(this);
376
+ }
377
+ _getTime(inp) {
378
+ if (typeof inp === "number" && inp <= import_core.otperformance.now()) {
379
+ return import_core.hrTime(inp + this._performanceOffset);
380
+ }
381
+ if (typeof inp === "number") {
382
+ return import_core.millisToHrTime(inp);
383
+ }
384
+ if (inp instanceof Date) {
385
+ return import_core.millisToHrTime(inp.getTime());
386
+ }
387
+ if (import_core.isTimeInputHrTime(inp)) {
388
+ return inp;
389
+ }
390
+ if (this._startTimeProvided) {
391
+ return import_core.millisToHrTime(Date.now());
392
+ }
393
+ const msDuration = import_core.otperformance.now() - this._performanceStartTime;
394
+ return import_core.addHrTimes(this.startTime, import_core.millisToHrTime(msDuration));
395
+ }
396
+ isRecording() {
397
+ return this._ended === false;
398
+ }
399
+ recordException(exception, time) {
400
+ const attributes = {};
401
+ if (typeof exception === "string") {
402
+ attributes[import_semantic_conventions.ATTR_EXCEPTION_MESSAGE] = exception;
403
+ } else if (exception) {
404
+ if (exception.code) {
405
+ attributes[import_semantic_conventions.ATTR_EXCEPTION_TYPE] = exception.code.toString();
406
+ } else if (exception.name) {
407
+ attributes[import_semantic_conventions.ATTR_EXCEPTION_TYPE] = exception.name;
408
+ }
409
+ if (exception.message) {
410
+ attributes[import_semantic_conventions.ATTR_EXCEPTION_MESSAGE] = exception.message;
411
+ }
412
+ if (exception.stack) {
413
+ attributes[import_semantic_conventions.ATTR_EXCEPTION_STACKTRACE] = exception.stack;
414
+ }
415
+ }
416
+ if (attributes[import_semantic_conventions.ATTR_EXCEPTION_TYPE] || attributes[import_semantic_conventions.ATTR_EXCEPTION_MESSAGE]) {
417
+ this.addEvent(ExceptionEventName, attributes, time);
418
+ } else {
419
+ import_api.diag.warn(`Failed to record an exception ${exception}`);
420
+ }
421
+ }
422
+ get duration() {
423
+ return this._duration;
424
+ }
425
+ get ended() {
426
+ return this._ended;
427
+ }
428
+ get droppedAttributesCount() {
429
+ return this._droppedAttributesCount;
430
+ }
431
+ get droppedEventsCount() {
432
+ return this._droppedEventsCount;
433
+ }
434
+ get droppedLinksCount() {
435
+ return this._droppedLinksCount;
436
+ }
437
+ _isSpanEnded() {
438
+ if (this._ended) {
439
+ const error = new Error(`Operation attempted on ended Span {traceId: ${this._spanContext.traceId}, spanId: ${this._spanContext.spanId}}`);
440
+ import_api.diag.warn(`Cannot execute the operation on ended Span {traceId: ${this._spanContext.traceId}, spanId: ${this._spanContext.spanId}}`, error);
441
+ }
442
+ return this._ended;
443
+ }
444
+ _truncateToLimitUtil(value, limit) {
445
+ if (value.length <= limit) {
446
+ return value;
447
+ }
448
+ return value.substring(0, limit);
449
+ }
450
+ _truncateToSize(value) {
451
+ const limit = this._attributeValueLengthLimit;
452
+ if (limit <= 0) {
453
+ import_api.diag.warn(`Attribute value limit must be positive, got ${limit}`);
454
+ return value;
455
+ }
456
+ if (typeof value === "string") {
457
+ return this._truncateToLimitUtil(value, limit);
458
+ }
459
+ if (Array.isArray(value)) {
460
+ return value.map((val) => typeof val === "string" ? this._truncateToLimitUtil(val, limit) : val);
461
+ }
462
+ return value;
463
+ }
464
+ }
465
+ var import_api, import_core, import_semantic_conventions;
466
+ var init_Span = __esm(() => {
467
+ init_enums();
468
+ import_api = __toESM(require_src(), 1);
469
+ import_core = __toESM(require_src3(), 1);
470
+ import_semantic_conventions = __toESM(require_src2(), 1);
471
+ });
472
+
473
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/Sampler.js
474
+ var SamplingDecision;
475
+ var init_Sampler = __esm(() => {
476
+ (function(SamplingDecision2) {
477
+ SamplingDecision2[SamplingDecision2["NOT_RECORD"] = 0] = "NOT_RECORD";
478
+ SamplingDecision2[SamplingDecision2["RECORD"] = 1] = "RECORD";
479
+ SamplingDecision2[SamplingDecision2["RECORD_AND_SAMPLED"] = 2] = "RECORD_AND_SAMPLED";
480
+ })(SamplingDecision || (SamplingDecision = {}));
481
+ });
482
+
483
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/sampler/AlwaysOffSampler.js
484
+ class AlwaysOffSampler {
485
+ shouldSample() {
486
+ return {
487
+ decision: SamplingDecision.NOT_RECORD
488
+ };
489
+ }
490
+ toString() {
491
+ return "AlwaysOffSampler";
492
+ }
493
+ }
494
+ var init_AlwaysOffSampler = __esm(() => {
495
+ init_Sampler();
496
+ });
497
+
498
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/sampler/AlwaysOnSampler.js
499
+ class AlwaysOnSampler {
500
+ shouldSample() {
501
+ return {
502
+ decision: SamplingDecision.RECORD_AND_SAMPLED
503
+ };
504
+ }
505
+ toString() {
506
+ return "AlwaysOnSampler";
507
+ }
508
+ }
509
+ var init_AlwaysOnSampler = __esm(() => {
510
+ init_Sampler();
511
+ });
512
+
513
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/sampler/ParentBasedSampler.js
514
+ class ParentBasedSampler {
515
+ _root;
516
+ _remoteParentSampled;
517
+ _remoteParentNotSampled;
518
+ _localParentSampled;
519
+ _localParentNotSampled;
520
+ constructor(config) {
521
+ this._root = config.root;
522
+ if (!this._root) {
523
+ import_core2.globalErrorHandler(new Error("ParentBasedSampler must have a root sampler configured"));
524
+ this._root = new AlwaysOnSampler;
525
+ }
526
+ this._remoteParentSampled = config.remoteParentSampled ?? new AlwaysOnSampler;
527
+ this._remoteParentNotSampled = config.remoteParentNotSampled ?? new AlwaysOffSampler;
528
+ this._localParentSampled = config.localParentSampled ?? new AlwaysOnSampler;
529
+ this._localParentNotSampled = config.localParentNotSampled ?? new AlwaysOffSampler;
530
+ }
531
+ shouldSample(context, traceId, spanName, spanKind, attributes, links) {
532
+ const parentContext = import_api2.trace.getSpanContext(context);
533
+ if (!parentContext || !import_api2.isSpanContextValid(parentContext)) {
534
+ return this._root.shouldSample(context, traceId, spanName, spanKind, attributes, links);
535
+ }
536
+ if (parentContext.isRemote) {
537
+ if (parentContext.traceFlags & import_api2.TraceFlags.SAMPLED) {
538
+ return this._remoteParentSampled.shouldSample(context, traceId, spanName, spanKind, attributes, links);
539
+ }
540
+ return this._remoteParentNotSampled.shouldSample(context, traceId, spanName, spanKind, attributes, links);
541
+ }
542
+ if (parentContext.traceFlags & import_api2.TraceFlags.SAMPLED) {
543
+ return this._localParentSampled.shouldSample(context, traceId, spanName, spanKind, attributes, links);
544
+ }
545
+ return this._localParentNotSampled.shouldSample(context, traceId, spanName, spanKind, attributes, links);
546
+ }
547
+ toString() {
548
+ return `ParentBased{root=${this._root.toString()}, remoteParentSampled=${this._remoteParentSampled.toString()}, remoteParentNotSampled=${this._remoteParentNotSampled.toString()}, localParentSampled=${this._localParentSampled.toString()}, localParentNotSampled=${this._localParentNotSampled.toString()}}`;
549
+ }
550
+ }
551
+ var import_api2, import_core2;
552
+ var init_ParentBasedSampler = __esm(() => {
553
+ init_AlwaysOffSampler();
554
+ init_AlwaysOnSampler();
555
+ import_api2 = __toESM(require_src(), 1);
556
+ import_core2 = __toESM(require_src3(), 1);
557
+ });
558
+
559
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/sampler/TraceIdRatioBasedSampler.js
560
+ class TraceIdRatioBasedSampler {
561
+ _ratio;
562
+ _upperBound;
563
+ constructor(ratio = 0) {
564
+ this._ratio = this._normalize(ratio);
565
+ this._upperBound = Math.floor(this._ratio * 4294967295);
566
+ }
567
+ shouldSample(context, traceId) {
568
+ return {
569
+ decision: import_api3.isValidTraceId(traceId) && this._accumulate(traceId) < this._upperBound ? SamplingDecision.RECORD_AND_SAMPLED : SamplingDecision.NOT_RECORD
570
+ };
571
+ }
572
+ toString() {
573
+ return `TraceIdRatioBased{${this._ratio}}`;
574
+ }
575
+ _normalize(ratio) {
576
+ if (typeof ratio !== "number" || isNaN(ratio))
577
+ return 0;
578
+ return ratio >= 1 ? 1 : ratio <= 0 ? 0 : ratio;
579
+ }
580
+ _accumulate(traceId) {
581
+ let accumulation = 0;
582
+ for (let i = 0;i < traceId.length / 8; i++) {
583
+ const pos = i * 8;
584
+ const part = parseInt(traceId.slice(pos, pos + 8), 16);
585
+ accumulation = (accumulation ^ part) >>> 0;
586
+ }
587
+ return accumulation;
588
+ }
589
+ }
590
+ var import_api3;
591
+ var init_TraceIdRatioBasedSampler = __esm(() => {
592
+ init_Sampler();
593
+ import_api3 = __toESM(require_src(), 1);
594
+ });
595
+
596
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/config.js
597
+ function loadDefaultConfig() {
598
+ return {
599
+ sampler: buildSamplerFromEnv(),
600
+ forceFlushTimeoutMillis: 30000,
601
+ generalLimits: {
602
+ attributeValueLengthLimit: import_core3.getNumberFromEnv("OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT") ?? Infinity,
603
+ attributeCountLimit: import_core3.getNumberFromEnv("OTEL_ATTRIBUTE_COUNT_LIMIT") ?? 128
604
+ },
605
+ spanLimits: {
606
+ attributeValueLengthLimit: import_core3.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT") ?? Infinity,
607
+ attributeCountLimit: import_core3.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT") ?? 128,
608
+ linkCountLimit: import_core3.getNumberFromEnv("OTEL_SPAN_LINK_COUNT_LIMIT") ?? 128,
609
+ eventCountLimit: import_core3.getNumberFromEnv("OTEL_SPAN_EVENT_COUNT_LIMIT") ?? 128,
610
+ attributePerEventCountLimit: import_core3.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_PER_EVENT_COUNT_LIMIT") ?? 128,
611
+ attributePerLinkCountLimit: import_core3.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_PER_LINK_COUNT_LIMIT") ?? 128
612
+ }
613
+ };
614
+ }
615
+ function buildSamplerFromEnv() {
616
+ const sampler = import_core3.getStringFromEnv("OTEL_TRACES_SAMPLER") ?? TracesSamplerValues.ParentBasedAlwaysOn;
617
+ switch (sampler) {
618
+ case TracesSamplerValues.AlwaysOn:
619
+ return new AlwaysOnSampler;
620
+ case TracesSamplerValues.AlwaysOff:
621
+ return new AlwaysOffSampler;
622
+ case TracesSamplerValues.ParentBasedAlwaysOn:
623
+ return new ParentBasedSampler({
624
+ root: new AlwaysOnSampler
625
+ });
626
+ case TracesSamplerValues.ParentBasedAlwaysOff:
627
+ return new ParentBasedSampler({
628
+ root: new AlwaysOffSampler
629
+ });
630
+ case TracesSamplerValues.TraceIdRatio:
631
+ return new TraceIdRatioBasedSampler(getSamplerProbabilityFromEnv());
632
+ case TracesSamplerValues.ParentBasedTraceIdRatio:
633
+ return new ParentBasedSampler({
634
+ root: new TraceIdRatioBasedSampler(getSamplerProbabilityFromEnv())
635
+ });
636
+ default:
637
+ import_api4.diag.error(`OTEL_TRACES_SAMPLER value "${sampler}" invalid, defaulting to "${TracesSamplerValues.ParentBasedAlwaysOn}".`);
638
+ return new ParentBasedSampler({
639
+ root: new AlwaysOnSampler
640
+ });
641
+ }
642
+ }
643
+ function getSamplerProbabilityFromEnv() {
644
+ const probability = import_core3.getNumberFromEnv("OTEL_TRACES_SAMPLER_ARG");
645
+ if (probability == null) {
646
+ import_api4.diag.error(`OTEL_TRACES_SAMPLER_ARG is blank, defaulting to ${DEFAULT_RATIO}.`);
647
+ return DEFAULT_RATIO;
648
+ }
649
+ if (probability < 0 || probability > 1) {
650
+ import_api4.diag.error(`OTEL_TRACES_SAMPLER_ARG=${probability} was given, but it is out of range ([0..1]), defaulting to ${DEFAULT_RATIO}.`);
651
+ return DEFAULT_RATIO;
652
+ }
653
+ return probability;
654
+ }
655
+ var import_api4, import_core3, TracesSamplerValues, DEFAULT_RATIO = 1;
656
+ var init_config2 = __esm(() => {
657
+ init_AlwaysOffSampler();
658
+ init_AlwaysOnSampler();
659
+ init_ParentBasedSampler();
660
+ init_TraceIdRatioBasedSampler();
661
+ import_api4 = __toESM(require_src(), 1);
662
+ import_core3 = __toESM(require_src3(), 1);
663
+ (function(TracesSamplerValues2) {
664
+ TracesSamplerValues2["AlwaysOff"] = "always_off";
665
+ TracesSamplerValues2["AlwaysOn"] = "always_on";
666
+ TracesSamplerValues2["ParentBasedAlwaysOff"] = "parentbased_always_off";
667
+ TracesSamplerValues2["ParentBasedAlwaysOn"] = "parentbased_always_on";
668
+ TracesSamplerValues2["ParentBasedTraceIdRatio"] = "parentbased_traceidratio";
669
+ TracesSamplerValues2["TraceIdRatio"] = "traceidratio";
670
+ })(TracesSamplerValues || (TracesSamplerValues = {}));
671
+ });
672
+
673
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/utility.js
674
+ function mergeConfig(userConfig) {
675
+ const perInstanceDefaults = {
676
+ sampler: buildSamplerFromEnv()
677
+ };
678
+ const DEFAULT_CONFIG = loadDefaultConfig();
679
+ const target = Object.assign({}, DEFAULT_CONFIG, perInstanceDefaults, userConfig);
680
+ target.generalLimits = Object.assign({}, DEFAULT_CONFIG.generalLimits, userConfig.generalLimits || {});
681
+ target.spanLimits = Object.assign({}, DEFAULT_CONFIG.spanLimits, userConfig.spanLimits || {});
682
+ return target;
683
+ }
684
+ function reconfigureLimits(userConfig) {
685
+ const spanLimits = Object.assign({}, userConfig.spanLimits);
686
+ spanLimits.attributeCountLimit = userConfig.spanLimits?.attributeCountLimit ?? userConfig.generalLimits?.attributeCountLimit ?? import_core4.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_COUNT_LIMIT") ?? import_core4.getNumberFromEnv("OTEL_ATTRIBUTE_COUNT_LIMIT") ?? DEFAULT_ATTRIBUTE_COUNT_LIMIT;
687
+ spanLimits.attributeValueLengthLimit = userConfig.spanLimits?.attributeValueLengthLimit ?? userConfig.generalLimits?.attributeValueLengthLimit ?? import_core4.getNumberFromEnv("OTEL_SPAN_ATTRIBUTE_VALUE_LENGTH_LIMIT") ?? import_core4.getNumberFromEnv("OTEL_ATTRIBUTE_VALUE_LENGTH_LIMIT") ?? DEFAULT_ATTRIBUTE_VALUE_LENGTH_LIMIT;
688
+ return Object.assign({}, userConfig, { spanLimits });
689
+ }
690
+ var import_core4, DEFAULT_ATTRIBUTE_COUNT_LIMIT = 128, DEFAULT_ATTRIBUTE_VALUE_LENGTH_LIMIT = Infinity;
691
+ var init_utility = __esm(() => {
692
+ init_config2();
693
+ import_core4 = __toESM(require_src3(), 1);
694
+ });
695
+
696
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/export/BatchSpanProcessorBase.js
697
+ class BatchSpanProcessorBase {
698
+ _maxExportBatchSize;
699
+ _maxQueueSize;
700
+ _scheduledDelayMillis;
701
+ _exportTimeoutMillis;
702
+ _exporter;
703
+ _isExporting = false;
704
+ _finishedSpans = [];
705
+ _timer;
706
+ _shutdownOnce;
707
+ _droppedSpansCount = 0;
708
+ constructor(exporter, config) {
709
+ this._exporter = exporter;
710
+ this._maxExportBatchSize = typeof config?.maxExportBatchSize === "number" ? config.maxExportBatchSize : import_core5.getNumberFromEnv("OTEL_BSP_MAX_EXPORT_BATCH_SIZE") ?? 512;
711
+ this._maxQueueSize = typeof config?.maxQueueSize === "number" ? config.maxQueueSize : import_core5.getNumberFromEnv("OTEL_BSP_MAX_QUEUE_SIZE") ?? 2048;
712
+ this._scheduledDelayMillis = typeof config?.scheduledDelayMillis === "number" ? config.scheduledDelayMillis : import_core5.getNumberFromEnv("OTEL_BSP_SCHEDULE_DELAY") ?? 5000;
713
+ this._exportTimeoutMillis = typeof config?.exportTimeoutMillis === "number" ? config.exportTimeoutMillis : import_core5.getNumberFromEnv("OTEL_BSP_EXPORT_TIMEOUT") ?? 30000;
714
+ this._shutdownOnce = new import_core5.BindOnceFuture(this._shutdown, this);
715
+ if (this._maxExportBatchSize > this._maxQueueSize) {
716
+ import_api5.diag.warn("BatchSpanProcessor: maxExportBatchSize must be smaller or equal to maxQueueSize, setting maxExportBatchSize to match maxQueueSize");
717
+ this._maxExportBatchSize = this._maxQueueSize;
718
+ }
719
+ }
720
+ forceFlush() {
721
+ if (this._shutdownOnce.isCalled) {
722
+ return this._shutdownOnce.promise;
723
+ }
724
+ return this._flushAll();
725
+ }
726
+ onStart(_span, _parentContext) {}
727
+ onEnd(span) {
728
+ if (this._shutdownOnce.isCalled) {
729
+ return;
730
+ }
731
+ if ((span.spanContext().traceFlags & import_api5.TraceFlags.SAMPLED) === 0) {
732
+ return;
733
+ }
734
+ this._addToBuffer(span);
735
+ }
736
+ shutdown() {
737
+ return this._shutdownOnce.call();
738
+ }
739
+ _shutdown() {
740
+ return Promise.resolve().then(() => {
741
+ return this.onShutdown();
742
+ }).then(() => {
743
+ return this._flushAll();
744
+ }).then(() => {
745
+ return this._exporter.shutdown();
746
+ });
747
+ }
748
+ _addToBuffer(span) {
749
+ if (this._finishedSpans.length >= this._maxQueueSize) {
750
+ if (this._droppedSpansCount === 0) {
751
+ import_api5.diag.debug("maxQueueSize reached, dropping spans");
752
+ }
753
+ this._droppedSpansCount++;
754
+ return;
755
+ }
756
+ if (this._droppedSpansCount > 0) {
757
+ import_api5.diag.warn(`Dropped ${this._droppedSpansCount} spans because maxQueueSize reached`);
758
+ this._droppedSpansCount = 0;
759
+ }
760
+ this._finishedSpans.push(span);
761
+ this._maybeStartTimer();
762
+ }
763
+ _flushAll() {
764
+ return new Promise((resolve, reject) => {
765
+ const promises = [];
766
+ const count = Math.ceil(this._finishedSpans.length / this._maxExportBatchSize);
767
+ for (let i = 0, j = count;i < j; i++) {
768
+ promises.push(this._flushOneBatch());
769
+ }
770
+ Promise.all(promises).then(() => {
771
+ resolve();
772
+ }).catch(reject);
773
+ });
774
+ }
775
+ _flushOneBatch() {
776
+ this._clearTimer();
777
+ if (this._finishedSpans.length === 0) {
778
+ return Promise.resolve();
779
+ }
780
+ return new Promise((resolve, reject) => {
781
+ const timer = setTimeout(() => {
782
+ reject(new Error("Timeout"));
783
+ }, this._exportTimeoutMillis);
784
+ import_api5.context.with(import_core5.suppressTracing(import_api5.context.active()), () => {
785
+ let spans;
786
+ if (this._finishedSpans.length <= this._maxExportBatchSize) {
787
+ spans = this._finishedSpans;
788
+ this._finishedSpans = [];
789
+ } else {
790
+ spans = this._finishedSpans.splice(0, this._maxExportBatchSize);
791
+ }
792
+ const doExport = () => this._exporter.export(spans, (result) => {
793
+ clearTimeout(timer);
794
+ if (result.code === import_core5.ExportResultCode.SUCCESS) {
795
+ resolve();
796
+ } else {
797
+ reject(result.error ?? new Error("BatchSpanProcessor: span export failed"));
798
+ }
799
+ });
800
+ let pendingResources = null;
801
+ for (let i = 0, len = spans.length;i < len; i++) {
802
+ const span = spans[i];
803
+ if (span.resource.asyncAttributesPending && span.resource.waitForAsyncAttributes) {
804
+ pendingResources ??= [];
805
+ pendingResources.push(span.resource.waitForAsyncAttributes());
806
+ }
807
+ }
808
+ if (pendingResources === null) {
809
+ doExport();
810
+ } else {
811
+ Promise.all(pendingResources).then(doExport, (err) => {
812
+ import_core5.globalErrorHandler(err);
813
+ reject(err);
814
+ });
815
+ }
816
+ });
817
+ });
818
+ }
819
+ _maybeStartTimer() {
820
+ if (this._isExporting)
821
+ return;
822
+ const flush = () => {
823
+ this._isExporting = true;
824
+ this._flushOneBatch().finally(() => {
825
+ this._isExporting = false;
826
+ if (this._finishedSpans.length > 0) {
827
+ this._clearTimer();
828
+ this._maybeStartTimer();
829
+ }
830
+ }).catch((e) => {
831
+ this._isExporting = false;
832
+ import_core5.globalErrorHandler(e);
833
+ });
834
+ };
835
+ if (this._finishedSpans.length >= this._maxExportBatchSize) {
836
+ return flush();
837
+ }
838
+ if (this._timer !== undefined)
839
+ return;
840
+ this._timer = setTimeout(() => flush(), this._scheduledDelayMillis);
841
+ if (typeof this._timer !== "number") {
842
+ this._timer.unref();
843
+ }
844
+ }
845
+ _clearTimer() {
846
+ if (this._timer !== undefined) {
847
+ clearTimeout(this._timer);
848
+ this._timer = undefined;
849
+ }
850
+ }
851
+ }
852
+ var import_api5, import_core5;
853
+ var init_BatchSpanProcessorBase = __esm(() => {
854
+ import_api5 = __toESM(require_src(), 1);
855
+ import_core5 = __toESM(require_src3(), 1);
856
+ });
857
+
858
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/platform/node/export/BatchSpanProcessor.js
859
+ var BatchSpanProcessor;
860
+ var init_BatchSpanProcessor = __esm(() => {
861
+ init_BatchSpanProcessorBase();
862
+ BatchSpanProcessor = class BatchSpanProcessor extends BatchSpanProcessorBase {
863
+ onShutdown() {}
864
+ };
865
+ });
866
+
867
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/platform/node/RandomIdGenerator.js
868
+ class RandomIdGenerator {
869
+ generateTraceId = getIdGenerator(TRACE_ID_BYTES);
870
+ generateSpanId = getIdGenerator(SPAN_ID_BYTES);
871
+ }
872
+ function getIdGenerator(bytes) {
873
+ return function generateId() {
874
+ for (let i = 0;i < bytes / 4; i++) {
875
+ SHARED_BUFFER.writeUInt32BE(Math.random() * 2 ** 32 >>> 0, i * 4);
876
+ }
877
+ for (let i = 0;i < bytes; i++) {
878
+ if (SHARED_BUFFER[i] > 0) {
879
+ break;
880
+ } else if (i === bytes - 1) {
881
+ SHARED_BUFFER[bytes - 1] = 1;
882
+ }
883
+ }
884
+ return SHARED_BUFFER.toString("hex", 0, bytes);
885
+ };
886
+ }
887
+ var SPAN_ID_BYTES = 8, TRACE_ID_BYTES = 16, SHARED_BUFFER;
888
+ var init_RandomIdGenerator = __esm(() => {
889
+ SHARED_BUFFER = Buffer.allocUnsafe(TRACE_ID_BYTES);
890
+ });
891
+
892
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/platform/node/index.js
893
+ var init_node = __esm(() => {
894
+ init_BatchSpanProcessor();
895
+ init_RandomIdGenerator();
896
+ });
897
+
898
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/platform/index.js
899
+ var init_platform2 = __esm(() => {
900
+ init_node();
901
+ });
902
+
903
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/semconv.js
904
+ var ATTR_OTEL_SPAN_PARENT_ORIGIN = "otel.span.parent.origin", ATTR_OTEL_SPAN_SAMPLING_RESULT = "otel.span.sampling_result", METRIC_OTEL_SDK_SPAN_LIVE = "otel.sdk.span.live", METRIC_OTEL_SDK_SPAN_STARTED = "otel.sdk.span.started";
905
+ var init_semconv = () => {};
906
+
907
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/TracerMetrics.js
908
+ class TracerMetrics {
909
+ startedSpans;
910
+ liveSpans;
911
+ constructor(meter) {
912
+ this.startedSpans = meter.createCounter(METRIC_OTEL_SDK_SPAN_STARTED, {
913
+ unit: "{span}",
914
+ description: "The number of created spans."
915
+ });
916
+ this.liveSpans = meter.createUpDownCounter(METRIC_OTEL_SDK_SPAN_LIVE, {
917
+ unit: "{span}",
918
+ description: "The number of currently live spans."
919
+ });
920
+ }
921
+ startSpan(parentSpanCtx, samplingDecision) {
922
+ const samplingDecisionStr = samplingDecisionToString(samplingDecision);
923
+ this.startedSpans.add(1, {
924
+ [ATTR_OTEL_SPAN_PARENT_ORIGIN]: parentOrigin(parentSpanCtx),
925
+ [ATTR_OTEL_SPAN_SAMPLING_RESULT]: samplingDecisionStr
926
+ });
927
+ if (samplingDecision === SamplingDecision.NOT_RECORD) {
928
+ return () => {};
929
+ }
930
+ const liveSpanAttributes = {
931
+ [ATTR_OTEL_SPAN_SAMPLING_RESULT]: samplingDecisionStr
932
+ };
933
+ this.liveSpans.add(1, liveSpanAttributes);
934
+ return () => {
935
+ this.liveSpans.add(-1, liveSpanAttributes);
936
+ };
937
+ }
938
+ }
939
+ function parentOrigin(parentSpanContext) {
940
+ if (!parentSpanContext) {
941
+ return "none";
942
+ }
943
+ if (parentSpanContext.isRemote) {
944
+ return "remote";
945
+ }
946
+ return "local";
947
+ }
948
+ function samplingDecisionToString(decision) {
949
+ switch (decision) {
950
+ case SamplingDecision.RECORD_AND_SAMPLED:
951
+ return "RECORD_AND_SAMPLE";
952
+ case SamplingDecision.RECORD:
953
+ return "RECORD_ONLY";
954
+ case SamplingDecision.NOT_RECORD:
955
+ return "DROP";
956
+ }
957
+ }
958
+ var init_TracerMetrics = __esm(() => {
959
+ init_Sampler();
960
+ init_semconv();
961
+ });
962
+
963
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/version.js
964
+ var VERSION = "2.6.1";
965
+ var init_version = () => {};
966
+
967
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/Tracer.js
968
+ class Tracer {
969
+ _sampler;
970
+ _generalLimits;
971
+ _spanLimits;
972
+ _idGenerator;
973
+ instrumentationScope;
974
+ _resource;
975
+ _spanProcessor;
976
+ _tracerMetrics;
977
+ constructor(instrumentationScope, config, resource, spanProcessor) {
978
+ const localConfig = mergeConfig(config);
979
+ this._sampler = localConfig.sampler;
980
+ this._generalLimits = localConfig.generalLimits;
981
+ this._spanLimits = localConfig.spanLimits;
982
+ this._idGenerator = config.idGenerator || new RandomIdGenerator;
983
+ this._resource = resource;
984
+ this._spanProcessor = spanProcessor;
985
+ this.instrumentationScope = instrumentationScope;
986
+ const meter = localConfig.meterProvider ? localConfig.meterProvider.getMeter("@opentelemetry/sdk-trace", VERSION) : api.createNoopMeter();
987
+ this._tracerMetrics = new TracerMetrics(meter);
988
+ }
989
+ startSpan(name, options = {}, context3 = api.context.active()) {
990
+ if (options.root) {
991
+ context3 = api.trace.deleteSpan(context3);
992
+ }
993
+ const parentSpan = api.trace.getSpan(context3);
994
+ if (import_core6.isTracingSuppressed(context3)) {
995
+ api.diag.debug("Instrumentation suppressed, returning Noop Span");
996
+ const nonRecordingSpan = api.trace.wrapSpanContext(api.INVALID_SPAN_CONTEXT);
997
+ return nonRecordingSpan;
998
+ }
999
+ const parentSpanContext = parentSpan?.spanContext();
1000
+ const spanId = this._idGenerator.generateSpanId();
1001
+ let validParentSpanContext;
1002
+ let traceId;
1003
+ let traceState;
1004
+ if (!parentSpanContext || !api.trace.isSpanContextValid(parentSpanContext)) {
1005
+ traceId = this._idGenerator.generateTraceId();
1006
+ } else {
1007
+ traceId = parentSpanContext.traceId;
1008
+ traceState = parentSpanContext.traceState;
1009
+ validParentSpanContext = parentSpanContext;
1010
+ }
1011
+ const spanKind = options.kind ?? api.SpanKind.INTERNAL;
1012
+ const links = (options.links ?? []).map((link) => {
1013
+ return {
1014
+ context: link.context,
1015
+ attributes: import_core6.sanitizeAttributes(link.attributes)
1016
+ };
1017
+ });
1018
+ const attributes = import_core6.sanitizeAttributes(options.attributes);
1019
+ const samplingResult = this._sampler.shouldSample(context3, traceId, name, spanKind, attributes, links);
1020
+ const recordEndMetrics = this._tracerMetrics.startSpan(parentSpanContext, samplingResult.decision);
1021
+ traceState = samplingResult.traceState ?? traceState;
1022
+ const traceFlags = samplingResult.decision === api.SamplingDecision.RECORD_AND_SAMPLED ? api.TraceFlags.SAMPLED : api.TraceFlags.NONE;
1023
+ const spanContext = { traceId, spanId, traceFlags, traceState };
1024
+ if (samplingResult.decision === api.SamplingDecision.NOT_RECORD) {
1025
+ api.diag.debug("Recording is off, propagating context in a non-recording span");
1026
+ const nonRecordingSpan = api.trace.wrapSpanContext(spanContext);
1027
+ return nonRecordingSpan;
1028
+ }
1029
+ const initAttributes = import_core6.sanitizeAttributes(Object.assign(attributes, samplingResult.attributes));
1030
+ const span = new SpanImpl({
1031
+ resource: this._resource,
1032
+ scope: this.instrumentationScope,
1033
+ context: context3,
1034
+ spanContext,
1035
+ name,
1036
+ kind: spanKind,
1037
+ links,
1038
+ parentSpanContext: validParentSpanContext,
1039
+ attributes: initAttributes,
1040
+ startTime: options.startTime,
1041
+ spanProcessor: this._spanProcessor,
1042
+ spanLimits: this._spanLimits,
1043
+ recordEndMetrics
1044
+ });
1045
+ return span;
1046
+ }
1047
+ startActiveSpan(name, arg2, arg3, arg4) {
1048
+ let opts;
1049
+ let ctx;
1050
+ let fn;
1051
+ if (arguments.length < 2) {
1052
+ return;
1053
+ } else if (arguments.length === 2) {
1054
+ fn = arg2;
1055
+ } else if (arguments.length === 3) {
1056
+ opts = arg2;
1057
+ fn = arg3;
1058
+ } else {
1059
+ opts = arg2;
1060
+ ctx = arg3;
1061
+ fn = arg4;
1062
+ }
1063
+ const parentContext = ctx ?? api.context.active();
1064
+ const span = this.startSpan(name, opts, parentContext);
1065
+ const contextWithSpanSet = api.trace.setSpan(parentContext, span);
1066
+ return api.context.with(contextWithSpanSet, fn, undefined, span);
1067
+ }
1068
+ getGeneralLimits() {
1069
+ return this._generalLimits;
1070
+ }
1071
+ getSpanLimits() {
1072
+ return this._spanLimits;
1073
+ }
1074
+ }
1075
+ var api, import_core6;
1076
+ var init_Tracer = __esm(() => {
1077
+ init_Span();
1078
+ init_utility();
1079
+ init_platform2();
1080
+ init_TracerMetrics();
1081
+ init_version();
1082
+ api = __toESM(require_src(), 1);
1083
+ import_core6 = __toESM(require_src3(), 1);
1084
+ });
1085
+
1086
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/MultiSpanProcessor.js
1087
+ class MultiSpanProcessor {
1088
+ _spanProcessors;
1089
+ constructor(spanProcessors) {
1090
+ this._spanProcessors = spanProcessors;
1091
+ }
1092
+ forceFlush() {
1093
+ const promises = [];
1094
+ for (const spanProcessor of this._spanProcessors) {
1095
+ promises.push(spanProcessor.forceFlush());
1096
+ }
1097
+ return new Promise((resolve) => {
1098
+ Promise.all(promises).then(() => {
1099
+ resolve();
1100
+ }).catch((error) => {
1101
+ import_core7.globalErrorHandler(error || new Error("MultiSpanProcessor: forceFlush failed"));
1102
+ resolve();
1103
+ });
1104
+ });
1105
+ }
1106
+ onStart(span, context3) {
1107
+ for (const spanProcessor of this._spanProcessors) {
1108
+ spanProcessor.onStart(span, context3);
1109
+ }
1110
+ }
1111
+ onEnding(span) {
1112
+ for (const spanProcessor of this._spanProcessors) {
1113
+ if (spanProcessor.onEnding) {
1114
+ spanProcessor.onEnding(span);
1115
+ }
1116
+ }
1117
+ }
1118
+ onEnd(span) {
1119
+ for (const spanProcessor of this._spanProcessors) {
1120
+ spanProcessor.onEnd(span);
1121
+ }
1122
+ }
1123
+ shutdown() {
1124
+ const promises = [];
1125
+ for (const spanProcessor of this._spanProcessors) {
1126
+ promises.push(spanProcessor.shutdown());
1127
+ }
1128
+ return new Promise((resolve, reject) => {
1129
+ Promise.all(promises).then(() => {
1130
+ resolve();
1131
+ }, reject);
1132
+ });
1133
+ }
1134
+ }
1135
+ var import_core7;
1136
+ var init_MultiSpanProcessor = __esm(() => {
1137
+ import_core7 = __toESM(require_src3(), 1);
1138
+ });
1139
+
1140
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/BasicTracerProvider.js
1141
+ class BasicTracerProvider {
1142
+ _config;
1143
+ _tracers = new Map;
1144
+ _resource;
1145
+ _activeSpanProcessor;
1146
+ constructor(config = {}) {
1147
+ const mergedConfig = import_core8.merge({}, loadDefaultConfig(), reconfigureLimits(config));
1148
+ this._resource = mergedConfig.resource ?? import_resources.defaultResource();
1149
+ this._config = Object.assign({}, mergedConfig, {
1150
+ resource: this._resource
1151
+ });
1152
+ const spanProcessors = [];
1153
+ if (config.spanProcessors?.length) {
1154
+ spanProcessors.push(...config.spanProcessors);
1155
+ }
1156
+ this._activeSpanProcessor = new MultiSpanProcessor(spanProcessors);
1157
+ }
1158
+ getTracer(name, version, options) {
1159
+ const key = `${name}@${version || ""}:${options?.schemaUrl || ""}`;
1160
+ if (!this._tracers.has(key)) {
1161
+ this._tracers.set(key, new Tracer({ name, version, schemaUrl: options?.schemaUrl }, this._config, this._resource, this._activeSpanProcessor));
1162
+ }
1163
+ return this._tracers.get(key);
1164
+ }
1165
+ forceFlush() {
1166
+ const timeout = this._config.forceFlushTimeoutMillis;
1167
+ const promises = this._activeSpanProcessor["_spanProcessors"].map((spanProcessor) => {
1168
+ return new Promise((resolve) => {
1169
+ let state;
1170
+ const timeoutInterval = setTimeout(() => {
1171
+ resolve(new Error(`Span processor did not completed within timeout period of ${timeout} ms`));
1172
+ state = ForceFlushState.timeout;
1173
+ }, timeout);
1174
+ spanProcessor.forceFlush().then(() => {
1175
+ clearTimeout(timeoutInterval);
1176
+ if (state !== ForceFlushState.timeout) {
1177
+ state = ForceFlushState.resolved;
1178
+ resolve(state);
1179
+ }
1180
+ }).catch((error) => {
1181
+ clearTimeout(timeoutInterval);
1182
+ state = ForceFlushState.error;
1183
+ resolve(error);
1184
+ });
1185
+ });
1186
+ });
1187
+ return new Promise((resolve, reject) => {
1188
+ Promise.all(promises).then((results) => {
1189
+ const errors = results.filter((result) => result !== ForceFlushState.resolved);
1190
+ if (errors.length > 0) {
1191
+ reject(errors);
1192
+ } else {
1193
+ resolve();
1194
+ }
1195
+ }).catch((error) => reject([error]));
1196
+ });
1197
+ }
1198
+ shutdown() {
1199
+ return this._activeSpanProcessor.shutdown();
1200
+ }
1201
+ }
1202
+ var import_core8, import_resources, ForceFlushState;
1203
+ var init_BasicTracerProvider = __esm(() => {
1204
+ init_Tracer();
1205
+ init_config2();
1206
+ init_MultiSpanProcessor();
1207
+ init_utility();
1208
+ import_core8 = __toESM(require_src3(), 1);
1209
+ import_resources = __toESM(require_src4(), 1);
1210
+ (function(ForceFlushState2) {
1211
+ ForceFlushState2[ForceFlushState2["resolved"] = 0] = "resolved";
1212
+ ForceFlushState2[ForceFlushState2["timeout"] = 1] = "timeout";
1213
+ ForceFlushState2[ForceFlushState2["error"] = 2] = "error";
1214
+ ForceFlushState2[ForceFlushState2["unresolved"] = 3] = "unresolved";
1215
+ })(ForceFlushState || (ForceFlushState = {}));
1216
+ });
1217
+
1218
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/export/ConsoleSpanExporter.js
1219
+ class ConsoleSpanExporter {
1220
+ export(spans, resultCallback) {
1221
+ return this._sendSpans(spans, resultCallback);
1222
+ }
1223
+ shutdown() {
1224
+ this._sendSpans([]);
1225
+ return this.forceFlush();
1226
+ }
1227
+ forceFlush() {
1228
+ return Promise.resolve();
1229
+ }
1230
+ _exportInfo(span) {
1231
+ return {
1232
+ resource: {
1233
+ attributes: span.resource.attributes
1234
+ },
1235
+ instrumentationScope: span.instrumentationScope,
1236
+ traceId: span.spanContext().traceId,
1237
+ parentSpanContext: span.parentSpanContext,
1238
+ traceState: span.spanContext().traceState?.serialize(),
1239
+ name: span.name,
1240
+ id: span.spanContext().spanId,
1241
+ kind: span.kind,
1242
+ timestamp: import_core9.hrTimeToMicroseconds(span.startTime),
1243
+ duration: import_core9.hrTimeToMicroseconds(span.duration),
1244
+ attributes: span.attributes,
1245
+ status: span.status,
1246
+ events: span.events,
1247
+ links: span.links
1248
+ };
1249
+ }
1250
+ _sendSpans(spans, done) {
1251
+ for (const span of spans) {
1252
+ console.dir(this._exportInfo(span), { depth: 3 });
1253
+ }
1254
+ if (done) {
1255
+ return done({ code: import_core9.ExportResultCode.SUCCESS });
1256
+ }
1257
+ }
1258
+ }
1259
+ var import_core9;
1260
+ var init_ConsoleSpanExporter = __esm(() => {
1261
+ import_core9 = __toESM(require_src3(), 1);
1262
+ });
1263
+
1264
+ // node_modules/.bun/@opentelemetry+sdk-trace-base@2.6.1+e40b0dfdd726a224/node_modules/@opentelemetry/sdk-trace-base/build/esm/index.js
1265
+ var init_esm3 = __esm(() => {
1266
+ init_BasicTracerProvider();
1267
+ init_platform2();
1268
+ init_ConsoleSpanExporter();
1269
+ });
1270
+
1271
+ // src/services/api/metricsOptOut.ts
1272
+ async function _fetchMetricsEnabled() {
1273
+ const authResult = getAuthHeaders();
1274
+ if (authResult.error) {
1275
+ throw new Error(`Auth error: ${authResult.error}`);
1276
+ }
1277
+ const headers = {
1278
+ "Content-Type": "application/json",
1279
+ "User-Agent": getClaudeCodeUserAgent(),
1280
+ ...authResult.headers
1281
+ };
1282
+ const endpoint = `https://api.anthropic.com/api/claude_code/organizations/metrics_enabled`;
1283
+ const response = await axios_default.get(endpoint, {
1284
+ headers,
1285
+ timeout: 5000
1286
+ });
1287
+ return response.data;
1288
+ }
1289
+ async function _checkMetricsEnabledAPI() {
1290
+ if (isEssentialTrafficOnly()) {
1291
+ return { enabled: false, hasError: false };
1292
+ }
1293
+ try {
1294
+ const data = await withOAuth401Retry(_fetchMetricsEnabled, {
1295
+ also403Revoked: true
1296
+ });
1297
+ logForDebugging(`Metrics opt-out API response: enabled=${data.metrics_logging_enabled}`);
1298
+ return {
1299
+ enabled: data.metrics_logging_enabled,
1300
+ hasError: false
1301
+ };
1302
+ } catch (error) {
1303
+ logForDebugging(`Failed to check metrics opt-out status: ${errorMessage(error)}`);
1304
+ logError(error);
1305
+ return { enabled: false, hasError: true };
1306
+ }
1307
+ }
1308
+ async function refreshMetricsStatus() {
1309
+ const result = await memoizedCheckMetrics();
1310
+ if (result.hasError) {
1311
+ return result;
1312
+ }
1313
+ const cached = getGlobalConfig().metricsStatusCache;
1314
+ const unchanged = cached !== undefined && cached.enabled === result.enabled;
1315
+ if (unchanged && Date.now() - cached.timestamp < DISK_CACHE_TTL_MS) {
1316
+ return result;
1317
+ }
1318
+ saveGlobalConfig((current) => ({
1319
+ ...current,
1320
+ metricsStatusCache: {
1321
+ enabled: result.enabled,
1322
+ timestamp: Date.now()
1323
+ }
1324
+ }));
1325
+ return result;
1326
+ }
1327
+ async function checkMetricsEnabled() {
1328
+ if (isClaudeAISubscriber() && !hasProfileScope()) {
1329
+ return { enabled: false, hasError: false };
1330
+ }
1331
+ const cached = getGlobalConfig().metricsStatusCache;
1332
+ if (cached) {
1333
+ if (Date.now() - cached.timestamp > DISK_CACHE_TTL_MS) {
1334
+ refreshMetricsStatus().catch(logError);
1335
+ }
1336
+ return {
1337
+ enabled: cached.enabled,
1338
+ hasError: false
1339
+ };
1340
+ }
1341
+ return refreshMetricsStatus();
1342
+ }
1343
+ var CACHE_TTL_MS, DISK_CACHE_TTL_MS, memoizedCheckMetrics;
1344
+ var init_metricsOptOut = __esm(() => {
1345
+ init_axios();
1346
+ init_auth();
1347
+ init_config();
1348
+ init_debug();
1349
+ init_errors();
1350
+ init_http();
1351
+ init_log();
1352
+ init_memoize();
1353
+ init_privacyLevel();
1354
+ init_userAgent();
1355
+ CACHE_TTL_MS = 60 * 60 * 1000;
1356
+ DISK_CACHE_TTL_MS = 24 * 60 * 60 * 1000;
1357
+ memoizedCheckMetrics = memoizeWithTTLAsync(_checkMetricsEnabledAPI, CACHE_TTL_MS);
1358
+ });
1359
+
1360
+ // src/utils/telemetry/bigqueryExporter.ts
1361
+ class BigQueryMetricsExporter {
1362
+ endpoint;
1363
+ timeout;
1364
+ pendingExports = [];
1365
+ isShutdown = false;
1366
+ constructor(options = {}) {
1367
+ const defaultEndpoint = "https://api.anthropic.com/api/claude_code/metrics";
1368
+ if (process.env.USER_TYPE === "ant" && process.env.ANT_CLAUDE_CODE_METRICS_ENDPOINT) {
1369
+ this.endpoint = process.env.ANT_CLAUDE_CODE_METRICS_ENDPOINT + "/api/claude_code/metrics";
1370
+ } else {
1371
+ this.endpoint = defaultEndpoint;
1372
+ }
1373
+ this.timeout = options.timeout || 5000;
1374
+ }
1375
+ async export(metrics, resultCallback) {
1376
+ if (this.isShutdown) {
1377
+ resultCallback({
1378
+ code: import_core10.ExportResultCode.FAILED,
1379
+ error: new Error("Exporter has been shutdown")
1380
+ });
1381
+ return;
1382
+ }
1383
+ const exportPromise = this.doExport(metrics, resultCallback);
1384
+ this.pendingExports.push(exportPromise);
1385
+ exportPromise.finally(() => {
1386
+ const index = this.pendingExports.indexOf(exportPromise);
1387
+ if (index > -1) {
1388
+ this.pendingExports.splice(index, 1);
1389
+ }
1390
+ });
1391
+ }
1392
+ async doExport(metrics, resultCallback) {
1393
+ try {
1394
+ const hasTrust = checkHasTrustDialogAccepted() || getIsNonInteractiveSession();
1395
+ if (!hasTrust) {
1396
+ logForDebugging("BigQuery metrics export: trust not established, skipping");
1397
+ resultCallback({ code: import_core10.ExportResultCode.SUCCESS });
1398
+ return;
1399
+ }
1400
+ const metricsStatus = await checkMetricsEnabled();
1401
+ if (!metricsStatus.enabled) {
1402
+ logForDebugging("Metrics export disabled by organization setting");
1403
+ resultCallback({ code: import_core10.ExportResultCode.SUCCESS });
1404
+ return;
1405
+ }
1406
+ const payload = this.transformMetricsForInternal(metrics);
1407
+ const authResult = getAuthHeaders();
1408
+ if (authResult.error) {
1409
+ logForDebugging(`Metrics export failed: ${authResult.error}`);
1410
+ resultCallback({
1411
+ code: import_core10.ExportResultCode.FAILED,
1412
+ error: new Error(authResult.error)
1413
+ });
1414
+ return;
1415
+ }
1416
+ const headers = {
1417
+ "Content-Type": "application/json",
1418
+ "User-Agent": getClaudeCodeUserAgent(),
1419
+ ...authResult.headers
1420
+ };
1421
+ const response = await axios_default.post(this.endpoint, payload, {
1422
+ timeout: this.timeout,
1423
+ headers
1424
+ });
1425
+ logForDebugging("BigQuery metrics exported successfully");
1426
+ logForDebugging(`BigQuery API Response: ${jsonStringify(response.data, null, 2)}`);
1427
+ resultCallback({ code: import_core10.ExportResultCode.SUCCESS });
1428
+ } catch (error) {
1429
+ logForDebugging(`BigQuery metrics export failed: ${errorMessage(error)}`);
1430
+ logError(error);
1431
+ resultCallback({
1432
+ code: import_core10.ExportResultCode.FAILED,
1433
+ error: toError(error)
1434
+ });
1435
+ }
1436
+ }
1437
+ transformMetricsForInternal(metrics) {
1438
+ const attrs = metrics.resource.attributes;
1439
+ const resourceAttributes = {
1440
+ "service.name": attrs["service.name"] || "claude-code",
1441
+ "service.version": attrs["service.version"] || "unknown",
1442
+ "os.type": attrs["os.type"] || "unknown",
1443
+ "os.version": attrs["os.version"] || "unknown",
1444
+ "host.arch": attrs["host.arch"] || "unknown",
1445
+ "aggregation.temporality": this.selectAggregationTemporality() === import_sdk_metrics.AggregationTemporality.DELTA ? "delta" : "cumulative"
1446
+ };
1447
+ if (attrs["wsl.version"]) {
1448
+ resourceAttributes["wsl.version"] = attrs["wsl.version"];
1449
+ }
1450
+ if (isClaudeAISubscriber()) {
1451
+ resourceAttributes["user.customer_type"] = "claude_ai";
1452
+ const subscriptionType = getSubscriptionType();
1453
+ if (subscriptionType) {
1454
+ resourceAttributes["user.subscription_type"] = subscriptionType;
1455
+ }
1456
+ } else {
1457
+ resourceAttributes["user.customer_type"] = "api";
1458
+ }
1459
+ const transformed = {
1460
+ resource_attributes: resourceAttributes,
1461
+ metrics: metrics.scopeMetrics.flatMap((scopeMetric) => scopeMetric.metrics.map((metric) => ({
1462
+ name: metric.descriptor.name,
1463
+ description: metric.descriptor.description,
1464
+ unit: metric.descriptor.unit,
1465
+ data_points: this.extractDataPoints(metric)
1466
+ })))
1467
+ };
1468
+ return transformed;
1469
+ }
1470
+ extractDataPoints(metric) {
1471
+ const dataPoints = metric.dataPoints || [];
1472
+ return dataPoints.filter((point) => typeof point.value === "number").map((point) => ({
1473
+ attributes: this.convertAttributes(point.attributes),
1474
+ value: point.value,
1475
+ timestamp: this.hrTimeToISOString(point.endTime || point.startTime || [Date.now() / 1000, 0])
1476
+ }));
1477
+ }
1478
+ async shutdown() {
1479
+ this.isShutdown = true;
1480
+ await this.forceFlush();
1481
+ logForDebugging("BigQuery metrics exporter shutdown complete");
1482
+ }
1483
+ async forceFlush() {
1484
+ await Promise.all(this.pendingExports);
1485
+ logForDebugging("BigQuery metrics exporter flush complete");
1486
+ }
1487
+ convertAttributes(attributes) {
1488
+ const result = {};
1489
+ if (attributes) {
1490
+ for (const [key, value] of Object.entries(attributes)) {
1491
+ if (value !== undefined && value !== null) {
1492
+ result[key] = String(value);
1493
+ }
1494
+ }
1495
+ }
1496
+ return result;
1497
+ }
1498
+ hrTimeToISOString(hrTime2) {
1499
+ const [seconds, nanoseconds] = hrTime2;
1500
+ const date = new Date(seconds * 1000 + nanoseconds / 1e6);
1501
+ return date.toISOString();
1502
+ }
1503
+ selectAggregationTemporality() {
1504
+ return import_sdk_metrics.AggregationTemporality.DELTA;
1505
+ }
1506
+ }
1507
+ var import_core10, import_sdk_metrics;
1508
+ var init_bigqueryExporter = __esm(() => {
1509
+ init_axios();
1510
+ init_metricsOptOut();
1511
+ init_state();
1512
+ init_auth();
1513
+ init_config();
1514
+ init_debug();
1515
+ init_errors();
1516
+ init_http();
1517
+ init_log();
1518
+ init_slowOperations();
1519
+ init_userAgent();
1520
+ import_core10 = __toESM(require_src3(), 1);
1521
+ import_sdk_metrics = __toESM(require_src5(), 1);
1522
+ });
1523
+
1524
+ // src/utils/telemetry/logger.ts
1525
+ class ClaudeCodeDiagLogger {
1526
+ error(message, ..._) {
1527
+ logError(new Error(message));
1528
+ logForDebugging(`[3P telemetry] OTEL diag error: ${message}`, {
1529
+ level: "error"
1530
+ });
1531
+ }
1532
+ warn(message, ..._) {
1533
+ logError(new Error(message));
1534
+ logForDebugging(`[3P telemetry] OTEL diag warn: ${message}`, {
1535
+ level: "warn"
1536
+ });
1537
+ }
1538
+ info(_message, ..._args) {
1539
+ return;
1540
+ }
1541
+ debug(_message, ..._args) {
1542
+ return;
1543
+ }
1544
+ verbose(_message, ..._args) {
1545
+ return;
1546
+ }
1547
+ }
1548
+ var init_logger = __esm(() => {
1549
+ init_debug();
1550
+ init_log();
1551
+ });
1552
+
1553
+ // src/utils/telemetry/instrumentation.ts
1554
+ function telemetryTimeout(ms, message) {
1555
+ return new Promise((_, reject) => {
1556
+ setTimeout((rej, msg) => rej(new TelemetryTimeoutError(msg)), ms, reject, message).unref();
1557
+ });
1558
+ }
1559
+ function bootstrapTelemetry() {
1560
+ if (process.env.USER_TYPE === "ant") {
1561
+ if (process.env.ANT_OTEL_METRICS_EXPORTER) {
1562
+ process.env.OTEL_METRICS_EXPORTER = process.env.ANT_OTEL_METRICS_EXPORTER;
1563
+ }
1564
+ if (process.env.ANT_OTEL_LOGS_EXPORTER) {
1565
+ process.env.OTEL_LOGS_EXPORTER = process.env.ANT_OTEL_LOGS_EXPORTER;
1566
+ }
1567
+ if (process.env.ANT_OTEL_TRACES_EXPORTER) {
1568
+ process.env.OTEL_TRACES_EXPORTER = process.env.ANT_OTEL_TRACES_EXPORTER;
1569
+ }
1570
+ if (process.env.ANT_OTEL_EXPORTER_OTLP_PROTOCOL) {
1571
+ process.env.OTEL_EXPORTER_OTLP_PROTOCOL = process.env.ANT_OTEL_EXPORTER_OTLP_PROTOCOL;
1572
+ }
1573
+ if (process.env.ANT_OTEL_EXPORTER_OTLP_ENDPOINT) {
1574
+ process.env.OTEL_EXPORTER_OTLP_ENDPOINT = process.env.ANT_OTEL_EXPORTER_OTLP_ENDPOINT;
1575
+ }
1576
+ if (process.env.ANT_OTEL_EXPORTER_OTLP_HEADERS) {
1577
+ process.env.OTEL_EXPORTER_OTLP_HEADERS = process.env.ANT_OTEL_EXPORTER_OTLP_HEADERS;
1578
+ }
1579
+ }
1580
+ if (!process.env.OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE) {
1581
+ process.env.OTEL_EXPORTER_OTLP_METRICS_TEMPORALITY_PREFERENCE = "delta";
1582
+ }
1583
+ }
1584
+ function parseExporterTypes(value) {
1585
+ return (value || "").trim().split(",").filter(Boolean).map((t) => t.trim()).filter((t) => t !== "none");
1586
+ }
1587
+ async function getOtlpReaders() {
1588
+ const exporterTypes = parseExporterTypes(process.env.OTEL_METRICS_EXPORTER);
1589
+ const exportInterval = parseInt(process.env.OTEL_METRIC_EXPORT_INTERVAL || DEFAULT_METRICS_EXPORT_INTERVAL_MS.toString());
1590
+ const exporters = [];
1591
+ for (const exporterType of exporterTypes) {
1592
+ if (exporterType === "console") {
1593
+ const consoleExporter = new import_sdk_metrics2.ConsoleMetricExporter;
1594
+ const originalExport = consoleExporter.export.bind(consoleExporter);
1595
+ consoleExporter.export = (metrics, callback) => {
1596
+ if (metrics.resource && metrics.resource.attributes) {
1597
+ logForDebugging(`
1598
+ === Resource Attributes ===`);
1599
+ logForDebugging(jsonStringify(metrics.resource.attributes));
1600
+ logForDebugging(`===========================
1601
+ `);
1602
+ }
1603
+ return originalExport(metrics, callback);
1604
+ };
1605
+ exporters.push(consoleExporter);
1606
+ } else if (exporterType === "otlp") {
1607
+ const protocol = process.env.OTEL_EXPORTER_OTLP_METRICS_PROTOCOL?.trim() || process.env.OTEL_EXPORTER_OTLP_PROTOCOL?.trim();
1608
+ const httpConfig = getOTLPExporterConfig();
1609
+ switch (protocol) {
1610
+ case "grpc": {
1611
+ const { OTLPMetricExporter } = await import("./chunk-m2mcpbhk.js").then((m)=>__toESM(m.default,1));
1612
+ exporters.push(new OTLPMetricExporter);
1613
+ break;
1614
+ }
1615
+ case "http/json": {
1616
+ const { OTLPMetricExporter } = await import("./chunk-8y12jxg8.js").then((m)=>__toESM(m.default,1));
1617
+ exporters.push(new OTLPMetricExporter(httpConfig));
1618
+ break;
1619
+ }
1620
+ case "http/protobuf": {
1621
+ const { OTLPMetricExporter } = await import("./chunk-s3pzvdss.js");
1622
+ exporters.push(new OTLPMetricExporter(httpConfig));
1623
+ break;
1624
+ }
1625
+ default:
1626
+ throw new Error(`Unknown protocol set in OTEL_EXPORTER_OTLP_METRICS_PROTOCOL or OTEL_EXPORTER_OTLP_PROTOCOL env var: ${protocol}`);
1627
+ }
1628
+ } else if (exporterType === "prometheus") {
1629
+ const { PrometheusExporter } = await import("./chunk-6gr3c3w9.js").then((m)=>__toESM(m.default,1));
1630
+ exporters.push(new PrometheusExporter);
1631
+ } else {
1632
+ throw new Error(`Unknown exporter type set in OTEL_EXPORTER_OTLP_METRICS_PROTOCOL or OTEL_EXPORTER_OTLP_PROTOCOL env var: ${exporterType}`);
1633
+ }
1634
+ }
1635
+ return exporters.map((exporter) => {
1636
+ if ("export" in exporter) {
1637
+ return new import_sdk_metrics2.PeriodicExportingMetricReader({
1638
+ exporter,
1639
+ exportIntervalMillis: exportInterval
1640
+ });
1641
+ }
1642
+ return exporter;
1643
+ });
1644
+ }
1645
+ async function getOtlpLogExporters() {
1646
+ const exporterTypes = parseExporterTypes(process.env.OTEL_LOGS_EXPORTER);
1647
+ const protocol = process.env.OTEL_EXPORTER_OTLP_LOGS_PROTOCOL?.trim() || process.env.OTEL_EXPORTER_OTLP_PROTOCOL?.trim();
1648
+ const endpoint = process.env.OTEL_EXPORTER_OTLP_ENDPOINT;
1649
+ logForDebugging(`[3P telemetry] getOtlpLogExporters: types=${jsonStringify(exporterTypes)}, protocol=${protocol}, endpoint=${endpoint}`);
1650
+ const exporters = [];
1651
+ for (const exporterType of exporterTypes) {
1652
+ if (exporterType === "console") {
1653
+ exporters.push(new ConsoleLogRecordExporter);
1654
+ } else if (exporterType === "otlp") {
1655
+ const httpConfig = getOTLPExporterConfig();
1656
+ switch (protocol) {
1657
+ case "grpc": {
1658
+ const { OTLPLogExporter } = await import("./chunk-600kg7k6.js").then((m)=>__toESM(m.default,1));
1659
+ exporters.push(new OTLPLogExporter);
1660
+ break;
1661
+ }
1662
+ case "http/json": {
1663
+ const { OTLPLogExporter } = await import("./chunk-6bd8brc4.js");
1664
+ exporters.push(new OTLPLogExporter(httpConfig));
1665
+ break;
1666
+ }
1667
+ case "http/protobuf": {
1668
+ const { OTLPLogExporter } = await import("./chunk-a9zh40sj.js");
1669
+ exporters.push(new OTLPLogExporter(httpConfig));
1670
+ break;
1671
+ }
1672
+ default:
1673
+ throw new Error(`Unknown protocol set in OTEL_EXPORTER_OTLP_LOGS_PROTOCOL or OTEL_EXPORTER_OTLP_PROTOCOL env var: ${protocol}`);
1674
+ }
1675
+ } else {
1676
+ throw new Error(`Unknown exporter type set in OTEL_LOGS_EXPORTER env var: ${exporterType}`);
1677
+ }
1678
+ }
1679
+ return exporters;
1680
+ }
1681
+ async function getOtlpTraceExporters() {
1682
+ const exporterTypes = parseExporterTypes(process.env.OTEL_TRACES_EXPORTER);
1683
+ const exporters = [];
1684
+ for (const exporterType of exporterTypes) {
1685
+ if (exporterType === "console") {
1686
+ exporters.push(new ConsoleSpanExporter);
1687
+ } else if (exporterType === "otlp") {
1688
+ const protocol = process.env.OTEL_EXPORTER_OTLP_TRACES_PROTOCOL?.trim() || process.env.OTEL_EXPORTER_OTLP_PROTOCOL?.trim();
1689
+ const httpConfig = getOTLPExporterConfig();
1690
+ switch (protocol) {
1691
+ case "grpc": {
1692
+ const { OTLPTraceExporter } = await import("./chunk-0bdjdzew.js").then((m)=>__toESM(m.default,1));
1693
+ exporters.push(new OTLPTraceExporter);
1694
+ break;
1695
+ }
1696
+ case "http/json": {
1697
+ const { OTLPTraceExporter } = await import("./chunk-dgqrcy74.js");
1698
+ exporters.push(new OTLPTraceExporter(httpConfig));
1699
+ break;
1700
+ }
1701
+ case "http/protobuf": {
1702
+ const { OTLPTraceExporter } = await import("./chunk-8ymf4e6z.js");
1703
+ exporters.push(new OTLPTraceExporter(httpConfig));
1704
+ break;
1705
+ }
1706
+ default:
1707
+ throw new Error(`Unknown protocol set in OTEL_EXPORTER_OTLP_TRACES_PROTOCOL or OTEL_EXPORTER_OTLP_PROTOCOL env var: ${protocol}`);
1708
+ }
1709
+ } else {
1710
+ throw new Error(`Unknown exporter type set in OTEL_TRACES_EXPORTER env var: ${exporterType}`);
1711
+ }
1712
+ }
1713
+ return exporters;
1714
+ }
1715
+ function isTelemetryEnabled() {
1716
+ return isEnvTruthy(process.env.CLAUDE_CODE_ENABLE_TELEMETRY);
1717
+ }
1718
+ function getBigQueryExportingReader() {
1719
+ const bigqueryExporter = new BigQueryMetricsExporter;
1720
+ return new import_sdk_metrics2.PeriodicExportingMetricReader({
1721
+ exporter: bigqueryExporter,
1722
+ exportIntervalMillis: 300000
1723
+ });
1724
+ }
1725
+ function isBigQueryMetricsEnabled() {
1726
+ const subscriptionType = getSubscriptionType();
1727
+ const isC4EOrTeamUser = isClaudeAISubscriber() && (subscriptionType === "enterprise" || subscriptionType === "team");
1728
+ return is1PApiCustomer() || isC4EOrTeamUser;
1729
+ }
1730
+ async function initializeBetaTracing(resource) {
1731
+ const endpoint = process.env.BETA_TRACING_ENDPOINT;
1732
+ if (!endpoint) {
1733
+ return;
1734
+ }
1735
+ const [{ OTLPTraceExporter }, { OTLPLogExporter }] = await Promise.all([
1736
+ import("./chunk-dgqrcy74.js"),
1737
+ import("./chunk-6bd8brc4.js")
1738
+ ]);
1739
+ const httpConfig = {
1740
+ url: `${endpoint}/v1/traces`
1741
+ };
1742
+ const logHttpConfig = {
1743
+ url: `${endpoint}/v1/logs`
1744
+ };
1745
+ const traceExporter = new OTLPTraceExporter(httpConfig);
1746
+ const spanProcessor = new BatchSpanProcessor(traceExporter, {
1747
+ scheduledDelayMillis: DEFAULT_TRACES_EXPORT_INTERVAL_MS
1748
+ });
1749
+ const tracerProvider = new BasicTracerProvider({
1750
+ resource,
1751
+ spanProcessors: [spanProcessor]
1752
+ });
1753
+ import_api6.trace.setGlobalTracerProvider(tracerProvider);
1754
+ setTracerProvider(tracerProvider);
1755
+ const logExporter = new OTLPLogExporter(logHttpConfig);
1756
+ const loggerProvider = new LoggerProvider({
1757
+ resource,
1758
+ processors: [
1759
+ new BatchLogRecordProcessor(logExporter, {
1760
+ scheduledDelayMillis: DEFAULT_LOGS_EXPORT_INTERVAL_MS
1761
+ })
1762
+ ]
1763
+ });
1764
+ logs.setGlobalLoggerProvider(loggerProvider);
1765
+ setLoggerProvider(loggerProvider);
1766
+ const eventLogger = logs.getLogger("com.anthropic.claude_code.events", MACRO.VERSION);
1767
+ setEventLogger(eventLogger);
1768
+ process.on("beforeExit", async () => {
1769
+ await loggerProvider?.forceFlush();
1770
+ await tracerProvider?.forceFlush();
1771
+ });
1772
+ process.on("exit", () => {
1773
+ loggerProvider?.forceFlush();
1774
+ tracerProvider?.forceFlush();
1775
+ });
1776
+ }
1777
+ async function initializeTelemetry() {
1778
+ profileCheckpoint("telemetry_init_start");
1779
+ bootstrapTelemetry();
1780
+ if (getHasFormattedOutput()) {
1781
+ for (const key of [
1782
+ "OTEL_METRICS_EXPORTER",
1783
+ "OTEL_LOGS_EXPORTER",
1784
+ "OTEL_TRACES_EXPORTER"
1785
+ ]) {
1786
+ const v = process.env[key];
1787
+ if (v?.includes("console")) {
1788
+ process.env[key] = v.split(",").map((s) => s.trim()).filter((s) => s !== "console").join(",");
1789
+ }
1790
+ }
1791
+ }
1792
+ import_api6.diag.setLogger(new ClaudeCodeDiagLogger, import_api6.DiagLogLevel.ERROR);
1793
+ initializePerfettoTracing();
1794
+ const readers = [];
1795
+ const telemetryEnabled = isTelemetryEnabled();
1796
+ logForDebugging(`[3P telemetry] isTelemetryEnabled=${telemetryEnabled} (CLAUDE_CODE_ENABLE_TELEMETRY=${process.env.CLAUDE_CODE_ENABLE_TELEMETRY})`);
1797
+ if (telemetryEnabled) {
1798
+ readers.push(...await getOtlpReaders());
1799
+ }
1800
+ if (isBigQueryMetricsEnabled()) {
1801
+ readers.push(getBigQueryExportingReader());
1802
+ }
1803
+ const platform = getPlatform();
1804
+ const baseAttributes = {
1805
+ [import_semantic_conventions2.ATTR_SERVICE_NAME]: "claude-code",
1806
+ [import_semantic_conventions2.ATTR_SERVICE_VERSION]: MACRO.VERSION
1807
+ };
1808
+ if (platform === "wsl") {
1809
+ const wslVersion = getWslVersion();
1810
+ if (wslVersion) {
1811
+ baseAttributes["wsl.version"] = wslVersion;
1812
+ }
1813
+ }
1814
+ const baseResource = import_resources2.resourceFromAttributes(baseAttributes);
1815
+ const osResource = import_resources2.resourceFromAttributes(import_resources2.osDetector.detect().attributes || {});
1816
+ const hostDetected = import_resources2.hostDetector.detect();
1817
+ const hostArchAttributes = hostDetected.attributes?.[import_semantic_conventions2.SEMRESATTRS_HOST_ARCH] ? {
1818
+ [import_semantic_conventions2.SEMRESATTRS_HOST_ARCH]: hostDetected.attributes[import_semantic_conventions2.SEMRESATTRS_HOST_ARCH]
1819
+ } : {};
1820
+ const hostArchResource = import_resources2.resourceFromAttributes(hostArchAttributes);
1821
+ const envResource = import_resources2.resourceFromAttributes(import_resources2.envDetector.detect().attributes || {});
1822
+ const resource = baseResource.merge(osResource).merge(hostArchResource).merge(envResource);
1823
+ if (isBetaTracingEnabled()) {
1824
+ initializeBetaTracing(resource).catch((e) => logForDebugging(`Beta tracing init failed: ${e}`, { level: "error" }));
1825
+ const meterProvider2 = new import_sdk_metrics2.MeterProvider({
1826
+ resource,
1827
+ views: [],
1828
+ readers
1829
+ });
1830
+ setMeterProvider(meterProvider2);
1831
+ const shutdownTelemetry2 = async () => {
1832
+ const timeoutMs = parseInt(process.env.CLAUDE_CODE_OTEL_SHUTDOWN_TIMEOUT_MS || "2000");
1833
+ try {
1834
+ endInteractionSpan();
1835
+ const loggerProvider = getLoggerProvider();
1836
+ const tracerProvider = getTracerProvider();
1837
+ const chains = [meterProvider2.shutdown()];
1838
+ if (loggerProvider) {
1839
+ chains.push(loggerProvider.forceFlush().then(() => loggerProvider.shutdown()));
1840
+ }
1841
+ if (tracerProvider) {
1842
+ chains.push(tracerProvider.forceFlush().then(() => tracerProvider.shutdown()));
1843
+ }
1844
+ await Promise.race([
1845
+ Promise.all(chains),
1846
+ telemetryTimeout(timeoutMs, "OpenTelemetry shutdown timeout")
1847
+ ]);
1848
+ } catch {}
1849
+ };
1850
+ registerCleanup(shutdownTelemetry2);
1851
+ return meterProvider2.getMeter("com.anthropic.claude_code", MACRO.VERSION);
1852
+ }
1853
+ const meterProvider = new import_sdk_metrics2.MeterProvider({
1854
+ resource,
1855
+ views: [],
1856
+ readers
1857
+ });
1858
+ setMeterProvider(meterProvider);
1859
+ if (telemetryEnabled) {
1860
+ const logExporters = await getOtlpLogExporters();
1861
+ logForDebugging(`[3P telemetry] Created ${logExporters.length} log exporter(s)`);
1862
+ if (logExporters.length > 0) {
1863
+ const loggerProvider = new LoggerProvider({
1864
+ resource,
1865
+ processors: logExporters.map((exporter) => new BatchLogRecordProcessor(exporter, {
1866
+ scheduledDelayMillis: parseInt(process.env.OTEL_LOGS_EXPORT_INTERVAL || DEFAULT_LOGS_EXPORT_INTERVAL_MS.toString())
1867
+ }))
1868
+ });
1869
+ logs.setGlobalLoggerProvider(loggerProvider);
1870
+ setLoggerProvider(loggerProvider);
1871
+ const eventLogger = logs.getLogger("com.anthropic.claude_code.events", MACRO.VERSION);
1872
+ setEventLogger(eventLogger);
1873
+ logForDebugging("[3P telemetry] Event logger set successfully");
1874
+ process.on("beforeExit", async () => {
1875
+ await loggerProvider?.forceFlush();
1876
+ const tracerProvider = getTracerProvider();
1877
+ await tracerProvider?.forceFlush();
1878
+ });
1879
+ process.on("exit", () => {
1880
+ loggerProvider?.forceFlush();
1881
+ getTracerProvider()?.forceFlush();
1882
+ });
1883
+ }
1884
+ }
1885
+ if (telemetryEnabled && isEnhancedTelemetryEnabled()) {
1886
+ const traceExporters = await getOtlpTraceExporters();
1887
+ if (traceExporters.length > 0) {
1888
+ const spanProcessors = traceExporters.map((exporter) => new BatchSpanProcessor(exporter, {
1889
+ scheduledDelayMillis: parseInt(process.env.OTEL_TRACES_EXPORT_INTERVAL || DEFAULT_TRACES_EXPORT_INTERVAL_MS.toString())
1890
+ }));
1891
+ const tracerProvider = new BasicTracerProvider({
1892
+ resource,
1893
+ spanProcessors
1894
+ });
1895
+ import_api6.trace.setGlobalTracerProvider(tracerProvider);
1896
+ setTracerProvider(tracerProvider);
1897
+ }
1898
+ }
1899
+ const shutdownTelemetry = async () => {
1900
+ const timeoutMs = parseInt(process.env.CLAUDE_CODE_OTEL_SHUTDOWN_TIMEOUT_MS || "2000");
1901
+ try {
1902
+ endInteractionSpan();
1903
+ const shutdownPromises = [meterProvider.shutdown()];
1904
+ const loggerProvider = getLoggerProvider();
1905
+ if (loggerProvider) {
1906
+ shutdownPromises.push(loggerProvider.shutdown());
1907
+ }
1908
+ const tracerProvider = getTracerProvider();
1909
+ if (tracerProvider) {
1910
+ shutdownPromises.push(tracerProvider.shutdown());
1911
+ }
1912
+ await Promise.race([
1913
+ Promise.all(shutdownPromises),
1914
+ telemetryTimeout(timeoutMs, "OpenTelemetry shutdown timeout")
1915
+ ]);
1916
+ } catch (error) {
1917
+ if (error instanceof Error && error.message.includes("timeout")) {
1918
+ logForDebugging(`
1919
+ OpenTelemetry telemetry flush timed out after ${timeoutMs}ms
1920
+
1921
+ To resolve this issue, you can:
1922
+ 1. Increase the timeout by setting CLAUDE_CODE_OTEL_SHUTDOWN_TIMEOUT_MS env var (e.g., 5000 for 5 seconds)
1923
+ 2. Check if your OpenTelemetry backend is experiencing scalability issues
1924
+ 3. Disable OpenTelemetry by unsetting CLAUDE_CODE_ENABLE_TELEMETRY env var
1925
+
1926
+ Current timeout: ${timeoutMs}ms
1927
+ `, { level: "error" });
1928
+ }
1929
+ throw error;
1930
+ }
1931
+ };
1932
+ registerCleanup(shutdownTelemetry);
1933
+ return meterProvider.getMeter("com.anthropic.claude_code", MACRO.VERSION);
1934
+ }
1935
+ async function flushTelemetry() {
1936
+ const meterProvider = getMeterProvider();
1937
+ if (!meterProvider) {
1938
+ return;
1939
+ }
1940
+ const timeoutMs = parseInt(process.env.CLAUDE_CODE_OTEL_FLUSH_TIMEOUT_MS || "5000");
1941
+ try {
1942
+ const flushPromises = [meterProvider.forceFlush()];
1943
+ const loggerProvider = getLoggerProvider();
1944
+ if (loggerProvider) {
1945
+ flushPromises.push(loggerProvider.forceFlush());
1946
+ }
1947
+ const tracerProvider = getTracerProvider();
1948
+ if (tracerProvider) {
1949
+ flushPromises.push(tracerProvider.forceFlush());
1950
+ }
1951
+ await Promise.race([
1952
+ Promise.all(flushPromises),
1953
+ telemetryTimeout(timeoutMs, "OpenTelemetry flush timeout")
1954
+ ]);
1955
+ logForDebugging("Telemetry flushed successfully");
1956
+ } catch (error) {
1957
+ if (error instanceof TelemetryTimeoutError) {
1958
+ logForDebugging(`Telemetry flush timed out after ${timeoutMs}ms. Some metrics may not be exported.`, { level: "warn" });
1959
+ } else {
1960
+ logForDebugging(`Telemetry flush failed: ${errorMessage(error)}`, {
1961
+ level: "error"
1962
+ });
1963
+ }
1964
+ }
1965
+ }
1966
+ function parseOtelHeadersEnvVar() {
1967
+ const headers = {};
1968
+ const envHeaders = process.env.OTEL_EXPORTER_OTLP_HEADERS;
1969
+ if (envHeaders) {
1970
+ for (const pair of envHeaders.split(",")) {
1971
+ const [key, ...valueParts] = pair.split("=");
1972
+ if (key && valueParts.length > 0) {
1973
+ headers[key.trim()] = valueParts.join("=").trim();
1974
+ }
1975
+ }
1976
+ }
1977
+ return headers;
1978
+ }
1979
+ function getOTLPExporterConfig() {
1980
+ const proxyUrl = getProxyUrl();
1981
+ const mtlsConfig = getMTLSConfig();
1982
+ const settings = getSettings_DEPRECATED();
1983
+ const config = {};
1984
+ const staticHeaders = parseOtelHeadersEnvVar();
1985
+ if (settings?.otelHeadersHelper) {
1986
+ config.headers = async () => {
1987
+ const dynamicHeaders = getOtelHeadersFromHelper();
1988
+ return { ...staticHeaders, ...dynamicHeaders };
1989
+ };
1990
+ } else if (Object.keys(staticHeaders).length > 0) {
1991
+ config.headers = async () => staticHeaders;
1992
+ }
1993
+ const otelEndpoint = process.env.OTEL_EXPORTER_OTLP_ENDPOINT;
1994
+ if (!proxyUrl || otelEndpoint && shouldBypassProxy(otelEndpoint)) {
1995
+ const caCerts2 = getCACertificates();
1996
+ if (mtlsConfig || caCerts2) {
1997
+ config.httpAgentOptions = {
1998
+ ...mtlsConfig,
1999
+ ...caCerts2 && { ca: caCerts2 }
2000
+ };
2001
+ }
2002
+ return config;
2003
+ }
2004
+ const caCerts = getCACertificates();
2005
+ const agentFactory = (_protocol) => {
2006
+ const proxyAgent = mtlsConfig || caCerts ? new HttpsProxyAgent(proxyUrl, {
2007
+ ...mtlsConfig && {
2008
+ cert: mtlsConfig.cert,
2009
+ key: mtlsConfig.key,
2010
+ passphrase: mtlsConfig.passphrase
2011
+ },
2012
+ ...caCerts && { ca: caCerts }
2013
+ }) : new HttpsProxyAgent(proxyUrl);
2014
+ return proxyAgent;
2015
+ };
2016
+ config.httpAgentOptions = agentFactory;
2017
+ return config;
2018
+ }
2019
+ var import_api6, import_resources2, import_sdk_metrics2, import_semantic_conventions2, DEFAULT_METRICS_EXPORT_INTERVAL_MS = 60000, DEFAULT_LOGS_EXPORT_INTERVAL_MS = 5000, DEFAULT_TRACES_EXPORT_INTERVAL_MS = 5000, TelemetryTimeoutError;
2020
+ var init_instrumentation = __esm(() => {
2021
+ init_esm();
2022
+ init_esm2();
2023
+ init_esm3();
2024
+ init_dist();
2025
+ init_state();
2026
+ init_auth();
2027
+ init_platform();
2028
+ init_caCerts();
2029
+ init_cleanupRegistry();
2030
+ init_debug();
2031
+ init_envUtils();
2032
+ init_errors();
2033
+ init_mtls();
2034
+ init_proxy();
2035
+ init_settings();
2036
+ init_slowOperations();
2037
+ init_startupProfiler();
2038
+ init_betaSessionTracing();
2039
+ init_bigqueryExporter();
2040
+ init_logger();
2041
+ init_perfettoTracing();
2042
+ init_sessionTracing();
2043
+ import_api6 = __toESM(require_src(), 1);
2044
+ import_resources2 = __toESM(require_src4(), 1);
2045
+ import_sdk_metrics2 = __toESM(require_src5(), 1);
2046
+ import_semantic_conventions2 = __toESM(require_src2(), 1);
2047
+ TelemetryTimeoutError = class TelemetryTimeoutError extends Error {
2048
+ };
2049
+ });
2050
+ init_instrumentation();
2051
+
2052
+ export {
2053
+ parseExporterTypes,
2054
+ isTelemetryEnabled,
2055
+ initializeTelemetry,
2056
+ flushTelemetry,
2057
+ bootstrapTelemetry
2058
+ };