@rainhole/rain-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 (496) hide show
  1. package/README.md +172 -0
  2. package/dist/chunk-06b2745w.js +3583 -0
  3. package/dist/chunk-06saje2v.js +39 -0
  4. package/dist/chunk-07069jq1.js +30 -0
  5. package/dist/chunk-0731m51q.js +8 -0
  6. package/dist/chunk-0bs2528v.js +192 -0
  7. package/dist/chunk-0fj1d707.js +313 -0
  8. package/dist/chunk-0gdkvtx4.js +117 -0
  9. package/dist/chunk-0jd8rpt4.js +34257 -0
  10. package/dist/chunk-0paqc2yw.js +15 -0
  11. package/dist/chunk-0pk0w4j1.js +332 -0
  12. package/dist/chunk-0rpb2bdp.js +8 -0
  13. package/dist/chunk-0rvwew67.js +9300 -0
  14. package/dist/chunk-0sa1g8jf.js +318 -0
  15. package/dist/chunk-0vkfrmqm.js +690 -0
  16. package/dist/chunk-0xgxxqhr.js +708 -0
  17. package/dist/chunk-0xjaqda8.js +1124 -0
  18. package/dist/chunk-0zep39v0.js +81 -0
  19. package/dist/chunk-1141xmr4.js +8 -0
  20. package/dist/chunk-12hn2mhy.js +17 -0
  21. package/dist/chunk-12rjry89.js +81 -0
  22. package/dist/chunk-168xb8v1.js +436 -0
  23. package/dist/chunk-1cwdhk7a.js +969 -0
  24. package/dist/chunk-1cx0fd76.js +132 -0
  25. package/dist/chunk-1erfksyp.js +107 -0
  26. package/dist/chunk-1h1tc4mw.js +126 -0
  27. package/dist/chunk-1h2famwb.js +49 -0
  28. package/dist/chunk-1jnbys9f.js +1811 -0
  29. package/dist/chunk-1k4fp6ft.js +389 -0
  30. package/dist/chunk-1mjn8xxc.js +22 -0
  31. package/dist/chunk-1mn6r4y2.js +747 -0
  32. package/dist/chunk-1p8myfza.js +1568 -0
  33. package/dist/chunk-1vthytca.js +79 -0
  34. package/dist/chunk-1y32rx73.js +145 -0
  35. package/dist/chunk-200781fd.js +64 -0
  36. package/dist/chunk-205mmm67.js +100 -0
  37. package/dist/chunk-209eh6ak.js +9381 -0
  38. package/dist/chunk-21mfpnva.js +85 -0
  39. package/dist/chunk-238g70xa.js +36 -0
  40. package/dist/chunk-24k6t9fa.js +151 -0
  41. package/dist/chunk-29gg6hx0.js +2992 -0
  42. package/dist/chunk-2a42s11t.js +412 -0
  43. package/dist/chunk-2ekjxh7d.js +289 -0
  44. package/dist/chunk-2eykm0j0.js +20 -0
  45. package/dist/chunk-2fwze72g.js +24 -0
  46. package/dist/chunk-2gzv8nrw.js +205 -0
  47. package/dist/chunk-2k995y2x.js +880 -0
  48. package/dist/chunk-2nayx6q1.js +63 -0
  49. package/dist/chunk-2pg9pmvc.js +182 -0
  50. package/dist/chunk-2qp2hc02.js +36 -0
  51. package/dist/chunk-2rj0dnps.js +436 -0
  52. package/dist/chunk-2t0xa4dt.js +145 -0
  53. package/dist/chunk-2ym6tnww.js +216 -0
  54. package/dist/chunk-30bpz5m2.js +34 -0
  55. package/dist/chunk-30rst83v.js +168 -0
  56. package/dist/chunk-36b2q5fg.js +1299 -0
  57. package/dist/chunk-3c25bcsw.js +17 -0
  58. package/dist/chunk-3ewzhjyb.js +207 -0
  59. package/dist/chunk-3h8a89gy.js +46 -0
  60. package/dist/chunk-3nk79af8.js +8 -0
  61. package/dist/chunk-3sfr7j85.js +884 -0
  62. package/dist/chunk-3w6s9m5w.js +16 -0
  63. package/dist/chunk-3x52v1wb.js +660 -0
  64. package/dist/chunk-404qm8xt.js +1715 -0
  65. package/dist/chunk-42fjay4q.js +141 -0
  66. package/dist/chunk-48649h96.js +8590 -0
  67. package/dist/chunk-495d85x1.js +8066 -0
  68. package/dist/chunk-4anj5saq.js +111 -0
  69. package/dist/chunk-4asynmj4.js +259 -0
  70. package/dist/chunk-4ck9wve9.js +225 -0
  71. package/dist/chunk-4cp6193g.js +9076 -0
  72. package/dist/chunk-4g3v8y12.js +23 -0
  73. package/dist/chunk-4geyher8.js +244 -0
  74. package/dist/chunk-4hv90qcz.js +8 -0
  75. package/dist/chunk-4jhr03e7.js +61 -0
  76. package/dist/chunk-4jm600zv.js +13 -0
  77. package/dist/chunk-4nspekjp.js +69 -0
  78. package/dist/chunk-4ptqcw4p.js +16 -0
  79. package/dist/chunk-4qj8cqbh.js +173 -0
  80. package/dist/chunk-4wxsg6a0.js +122 -0
  81. package/dist/chunk-4zfkzkt6.js +37 -0
  82. package/dist/chunk-54dckh8a.js +1169 -0
  83. package/dist/chunk-54y13759.js +650 -0
  84. package/dist/chunk-54yf6e8d.js +91 -0
  85. package/dist/chunk-57qz90z8.js +154 -0
  86. package/dist/chunk-59k0mjnc.js +120 -0
  87. package/dist/chunk-59p9jye4.js +104 -0
  88. package/dist/chunk-5c753bd4.js +64 -0
  89. package/dist/chunk-5cw6zwep.js +106 -0
  90. package/dist/chunk-5eaf3j24.js +133 -0
  91. package/dist/chunk-5me7398b.js +81 -0
  92. package/dist/chunk-5pevjsyw.js +118 -0
  93. package/dist/chunk-5q3c2rf4.js +107 -0
  94. package/dist/chunk-5xwtnq4g.js +146 -0
  95. package/dist/chunk-5z28bqne.js +6748 -0
  96. package/dist/chunk-613f6fbv.js +63 -0
  97. package/dist/chunk-641hawvm.js +95 -0
  98. package/dist/chunk-64c1avct.js +13 -0
  99. package/dist/chunk-64hks9ax.js +456 -0
  100. package/dist/chunk-677as3nh.js +15 -0
  101. package/dist/chunk-6bd8brc4.js +48 -0
  102. package/dist/chunk-6cs6mmez.js +112 -0
  103. package/dist/chunk-6dj5t602.js +341 -0
  104. package/dist/chunk-6e8vht4y.js +780 -0
  105. package/dist/chunk-6gr3c3w9.js +378 -0
  106. package/dist/chunk-6hkd32eh.js +83 -0
  107. package/dist/chunk-6jqxvef0.js +198 -0
  108. package/dist/chunk-6mh3vfa4.js +115 -0
  109. package/dist/chunk-6mpw9h55.js +1071 -0
  110. package/dist/chunk-6p4cyhb3.js +16 -0
  111. package/dist/chunk-6qvgnepd.js +26 -0
  112. package/dist/chunk-6r2bhsvt.js +6956 -0
  113. package/dist/chunk-6tq2v3rk.js +186 -0
  114. package/dist/chunk-7316m01k.js +125 -0
  115. package/dist/chunk-73rpbt04.js +1947 -0
  116. package/dist/chunk-75zk7zr1.js +309 -0
  117. package/dist/chunk-760252na.js +101 -0
  118. package/dist/chunk-764ec4ja.js +173 -0
  119. package/dist/chunk-76vgnv24.js +108 -0
  120. package/dist/chunk-7739pg2c.js +4261 -0
  121. package/dist/chunk-7a7hxy3d.js +167 -0
  122. package/dist/chunk-7aw745vx.js +40175 -0
  123. package/dist/chunk-7b6bg1r4.js +16128 -0
  124. package/dist/chunk-7ca4qskp.js +99 -0
  125. package/dist/chunk-7deph26x.js +311 -0
  126. package/dist/chunk-7ds8zqar.js +108 -0
  127. package/dist/chunk-7fqxw3d2.js +479 -0
  128. package/dist/chunk-7nysf9yd.js +266 -0
  129. package/dist/chunk-7tascxe2.js +90 -0
  130. package/dist/chunk-7wm5s02e.js +216 -0
  131. package/dist/chunk-7xmw2tcz.js +277 -0
  132. package/dist/chunk-7xyswgjh.js +8 -0
  133. package/dist/chunk-7zkhadkb.js +220 -0
  134. package/dist/chunk-8225arm6.js +6374 -0
  135. package/dist/chunk-83hfzbx3.js +10 -0
  136. package/dist/chunk-85tag8nv.js +1391 -0
  137. package/dist/chunk-8bd8q5xw.js +359 -0
  138. package/dist/chunk-8bwqtasa.js +213 -0
  139. package/dist/chunk-8g5pe1gr.js +37 -0
  140. package/dist/chunk-8g747a8x.js +26 -0
  141. package/dist/chunk-8h6sdj66.js +447 -0
  142. package/dist/chunk-8mm8b6dd.js +19 -0
  143. package/dist/chunk-8ndwn6st.js +120 -0
  144. package/dist/chunk-8pn8tvgg.js +637 -0
  145. package/dist/chunk-8tnn9kcb.js +131 -0
  146. package/dist/chunk-8tnsngw2.js +31 -0
  147. package/dist/chunk-8x5w267y.js +112 -0
  148. package/dist/chunk-8y12jxg8.js +10 -0
  149. package/dist/chunk-8ymf4e6z.js +48 -0
  150. package/dist/chunk-90mt0m1w.js +102 -0
  151. package/dist/chunk-90wp6wez.js +10510 -0
  152. package/dist/chunk-91ew1d6f.js +2689 -0
  153. package/dist/chunk-97jsc1kn.js +231 -0
  154. package/dist/chunk-993pnm45.js +4521 -0
  155. package/dist/chunk-9a0rsdre.js +46 -0
  156. package/dist/chunk-9d7fmqkw.js +41 -0
  157. package/dist/chunk-9dgaq0g4.js +667 -0
  158. package/dist/chunk-9f52phb8.js +138 -0
  159. package/dist/chunk-9fbpqghc.js +105 -0
  160. package/dist/chunk-9hzxd5q3.js +122 -0
  161. package/dist/chunk-9kyrssch.js +28 -0
  162. package/dist/chunk-9q93n4w6.js +308 -0
  163. package/dist/chunk-9s0xs06y.js +581 -0
  164. package/dist/chunk-9x5zgy22.js +12 -0
  165. package/dist/chunk-9zdcb9jy.js +105 -0
  166. package/dist/chunk-a136cvvz.js +27 -0
  167. package/dist/chunk-a4psxnr1.js +224 -0
  168. package/dist/chunk-a4twdmhf.js +45 -0
  169. package/dist/chunk-a7rhvq9b.js +106 -0
  170. package/dist/chunk-a8ejc632.js +3094 -0
  171. package/dist/chunk-a9vdeb6y.js +258 -0
  172. package/dist/chunk-a9zh40sj.js +48 -0
  173. package/dist/chunk-aawg48hh.js +4102 -0
  174. package/dist/chunk-ad2f3890.js +65 -0
  175. package/dist/chunk-ae7ar1jk.js +105 -0
  176. package/dist/chunk-ak3hdbe4.js +234 -0
  177. package/dist/chunk-as4e9g8f.js +298 -0
  178. package/dist/chunk-ase86y73.js +15 -0
  179. package/dist/chunk-awb4vc41.js +69 -0
  180. package/dist/chunk-b4bep0aq.js +5041 -0
  181. package/dist/chunk-b4wg70y1.js +54 -0
  182. package/dist/chunk-b81hd3m6.js +32 -0
  183. package/dist/chunk-b9knmzt0.js +106 -0
  184. package/dist/chunk-besmz4ym.js +32 -0
  185. package/dist/chunk-bgpkemkg.js +65 -0
  186. package/dist/chunk-bj8x29tz.js +54 -0
  187. package/dist/chunk-bkqsnwrq.js +239 -0
  188. package/dist/chunk-bnf662he.js +359 -0
  189. package/dist/chunk-bq00fcsd.js +165 -0
  190. package/dist/chunk-brz2c4cq.js +275 -0
  191. package/dist/chunk-bsa118r4.js +502 -0
  192. package/dist/chunk-bsengrbt.js +2737 -0
  193. package/dist/chunk-bt64sq5y.js +19 -0
  194. package/dist/chunk-bxcfz5gy.js +56 -0
  195. package/dist/chunk-bxs2a71m.js +213 -0
  196. package/dist/chunk-byv2p9hn.js +397 -0
  197. package/dist/chunk-c03am3es.js +29 -0
  198. package/dist/chunk-c2ahb7yg.js +105 -0
  199. package/dist/chunk-c2qm0t6p.js +111 -0
  200. package/dist/chunk-c42h9gzx.js +71 -0
  201. package/dist/chunk-c47xbxqw.js +38 -0
  202. package/dist/chunk-c5vkve4j.js +68 -0
  203. package/dist/chunk-c6sjhj89.js +1284 -0
  204. package/dist/chunk-ca147npg.js +27 -0
  205. package/dist/chunk-caxx597g.js +71 -0
  206. package/dist/chunk-cbrt5vsb.js +31 -0
  207. package/dist/chunk-ce0z23ct.js +443 -0
  208. package/dist/chunk-cefsp8h1.js +155 -0
  209. package/dist/chunk-cfv996bs.js +22 -0
  210. package/dist/chunk-cgfdkzhb.js +12 -0
  211. package/dist/chunk-chsyvavm.js +3435 -0
  212. package/dist/chunk-cmsknj6n.js +28228 -0
  213. package/dist/chunk-cn8bkmvj.js +264 -0
  214. package/dist/chunk-crmjpsqe.js +68 -0
  215. package/dist/chunk-cthpw4pj.js +849 -0
  216. package/dist/chunk-cwy9nj4y.js +134 -0
  217. package/dist/chunk-cyagce56.js +155 -0
  218. package/dist/chunk-cynewytp.js +227 -0
  219. package/dist/chunk-cznf6k4g.js +46 -0
  220. package/dist/chunk-d0954t9j.js +267 -0
  221. package/dist/chunk-d1qhftze.js +118 -0
  222. package/dist/chunk-d4mdda98.js +94 -0
  223. package/dist/chunk-d4rnqevg.js +41 -0
  224. package/dist/chunk-d7886r6a.js +13870 -0
  225. package/dist/chunk-dd1qvamk.js +678 -0
  226. package/dist/chunk-dg4je8qj.js +183 -0
  227. package/dist/chunk-dggvswz1.js +104 -0
  228. package/dist/chunk-dgqrcy74.js +48 -0
  229. package/dist/chunk-dm3n2qgd.js +24 -0
  230. package/dist/chunk-dnh7jtpb.js +37 -0
  231. package/dist/chunk-dsenyfax.js +105 -0
  232. package/dist/chunk-dtf0a7rr.js +655 -0
  233. package/dist/chunk-dxdb7bs1.js +60 -0
  234. package/dist/chunk-e0pth8g7.js +79 -0
  235. package/dist/chunk-e36y0q82.js +109 -0
  236. package/dist/chunk-ef55cwrv.js +267 -0
  237. package/dist/chunk-efh644hv.js +915 -0
  238. package/dist/chunk-ehtwnxpg.js +1591 -0
  239. package/dist/chunk-ejahyhd8.js +120 -0
  240. package/dist/chunk-ejk1bpzz.js +472 -0
  241. package/dist/chunk-emef71ea.js +202 -0
  242. package/dist/chunk-en7v028t.js +333 -0
  243. package/dist/chunk-eqp1rfft.js +17 -0
  244. package/dist/chunk-ewadzrm8.js +103 -0
  245. package/dist/chunk-exh7z6tv.js +132 -0
  246. package/dist/chunk-f0npbgyf.js +340 -0
  247. package/dist/chunk-f2qkc8ce.js +229 -0
  248. package/dist/chunk-f49sb3q7.js +40 -0
  249. package/dist/chunk-f5ma3nh5.js +3436 -0
  250. package/dist/chunk-fbv4apne.js +51 -0
  251. package/dist/chunk-fday7sfg.js +269 -0
  252. package/dist/chunk-feyzykye.js +10 -0
  253. package/dist/chunk-fgqwr70t.js +241 -0
  254. package/dist/chunk-fhy7zs1w.js +943 -0
  255. package/dist/chunk-fmw3f68k.js +432 -0
  256. package/dist/chunk-fmwqvpqm.js +506 -0
  257. package/dist/chunk-fn1apgre.js +66 -0
  258. package/dist/chunk-fpy4nam9.js +21933 -0
  259. package/dist/chunk-fqy0erkw.js +908 -0
  260. package/dist/chunk-ftqwza3a.js +43 -0
  261. package/dist/chunk-fyc5fepv.js +10 -0
  262. package/dist/chunk-fz0ch109.js +329 -0
  263. package/dist/chunk-fzhn8z8j.js +253 -0
  264. package/dist/chunk-g12brv6y.js +321 -0
  265. package/dist/chunk-g338npwr.js +1061 -0
  266. package/dist/chunk-g5tpks28.js +795 -0
  267. package/dist/chunk-g63tgj4f.js +58 -0
  268. package/dist/chunk-g827r0mk.js +266 -0
  269. package/dist/chunk-g8wzsxgc.js +2534 -0
  270. package/dist/chunk-gey7mwcw.js +36 -0
  271. package/dist/chunk-gghb9pks.js +120 -0
  272. package/dist/chunk-grdpaf1p.js +606 -0
  273. package/dist/chunk-gx8016vp.js +125 -0
  274. package/dist/chunk-h0qngp9w.js +157 -0
  275. package/dist/chunk-h0rbjg6x.js +55 -0
  276. package/dist/chunk-h1mr3371.js +121 -0
  277. package/dist/chunk-h3xwdgpd.js +68 -0
  278. package/dist/chunk-h4b85amj.js +2331 -0
  279. package/dist/chunk-h6d137aa.js +20 -0
  280. package/dist/chunk-h9n7z00d.js +95 -0
  281. package/dist/chunk-hakdhagh.js +16606 -0
  282. package/dist/chunk-hd8531ec.js +685 -0
  283. package/dist/chunk-heq3rn8t.js +33068 -0
  284. package/dist/chunk-hfvxc9fd.js +542 -0
  285. package/dist/chunk-hgpd0qmm.js +371 -0
  286. package/dist/chunk-hh7cmy4k.js +20 -0
  287. package/dist/chunk-hhjs87wh.js +1407 -0
  288. package/dist/chunk-hjtvdvgj.js +208 -0
  289. package/dist/chunk-hk9xz7gk.js +118 -0
  290. package/dist/chunk-hknbjky3.js +160798 -0
  291. package/dist/chunk-htsbqyf9.js +338 -0
  292. package/dist/chunk-htx7jmxk.js +78 -0
  293. package/dist/chunk-hzhe8ygc.js +547 -0
  294. package/dist/chunk-j2k4p94p.js +55 -0
  295. package/dist/chunk-j3a4p81y.js +184 -0
  296. package/dist/chunk-j46rb9m9.js +544 -0
  297. package/dist/chunk-j5bth84e.js +97 -0
  298. package/dist/chunk-j64ga6ta.js +8035 -0
  299. package/dist/chunk-j6jh72hw.js +140 -0
  300. package/dist/chunk-j9gxwbe3.js +349 -0
  301. package/dist/chunk-jaaxk89e.js +113 -0
  302. package/dist/chunk-jd32zbps.js +15 -0
  303. package/dist/chunk-jdgeec04.js +4249 -0
  304. package/dist/chunk-jk826edv.js +174 -0
  305. package/dist/chunk-jnhkref0.js +30 -0
  306. package/dist/chunk-jsx72hep.js +208 -0
  307. package/dist/chunk-jx817w05.js +11 -0
  308. package/dist/chunk-jzmz18nn.js +65 -0
  309. package/dist/chunk-k0p9w03v.js +4957 -0
  310. package/dist/chunk-k3s4yk22.js +477 -0
  311. package/dist/chunk-kfd89dsd.js +21 -0
  312. package/dist/chunk-kgfz4522.js +126 -0
  313. package/dist/chunk-kn6zg6bd.js +524 -0
  314. package/dist/chunk-kp9vkzj6.js +120 -0
  315. package/dist/chunk-kraf793v.js +118 -0
  316. package/dist/chunk-kw0r30h3.js +208 -0
  317. package/dist/chunk-kwekc97v.js +18 -0
  318. package/dist/chunk-m2bcpk8j.js +30 -0
  319. package/dist/chunk-m2kp5f7p.js +4389 -0
  320. package/dist/chunk-m74w3187.js +164 -0
  321. package/dist/chunk-m88q4jmb.js +61 -0
  322. package/dist/chunk-man6wb4n.js +1456 -0
  323. package/dist/chunk-mdk3xgya.js +42 -0
  324. package/dist/chunk-mf4g439x.js +82 -0
  325. package/dist/chunk-mg8g0xqs.js +71 -0
  326. package/dist/chunk-mkwzrqvf.js +38 -0
  327. package/dist/chunk-mn61mk4v.js +351 -0
  328. package/dist/chunk-ms09sxcj.js +908 -0
  329. package/dist/chunk-mtn1anwe.js +2351 -0
  330. package/dist/chunk-mv0zm0qj.js +65 -0
  331. package/dist/chunk-mx28h61f.js +1147 -0
  332. package/dist/chunk-mxbf8ajn.js +1067 -0
  333. package/dist/chunk-n0qaeaa5.js +256 -0
  334. package/dist/chunk-n34z5cw8.js +74 -0
  335. package/dist/chunk-n55ehz77.js +120 -0
  336. package/dist/chunk-n7ttdtk0.js +641 -0
  337. package/dist/chunk-n9ktjngj.js +336 -0
  338. package/dist/chunk-nb2ntesh.js +149 -0
  339. package/dist/chunk-netzwgv1.js +154 -0
  340. package/dist/chunk-nh3cd07f.js +14358 -0
  341. package/dist/chunk-nka1g8f4.js +773 -0
  342. package/dist/chunk-nm97cw83.js +458 -0
  343. package/dist/chunk-nq0fxyxh.js +752 -0
  344. package/dist/chunk-nt837qt9.js +21 -0
  345. package/dist/chunk-nx87c0vw.js +250 -0
  346. package/dist/chunk-nxw6y6xm.js +862 -0
  347. package/dist/chunk-nzt717xg.js +32 -0
  348. package/dist/chunk-p2816w9z.js +1486 -0
  349. package/dist/chunk-p2d5nh3g.js +342 -0
  350. package/dist/chunk-p9cdykwf.js +72 -0
  351. package/dist/chunk-paxw1ryd.js +227 -0
  352. package/dist/chunk-ph5g4d1j.js +109 -0
  353. package/dist/chunk-pp42p8y3.js +574 -0
  354. package/dist/chunk-ppdn71n4.js +400 -0
  355. package/dist/chunk-ppwjyveh.js +8 -0
  356. package/dist/chunk-ps49ymvj.js +43 -0
  357. package/dist/chunk-pshjyzq4.js +17656 -0
  358. package/dist/chunk-pw8nf9rt.js +126 -0
  359. package/dist/chunk-pwwa7s62.js +11 -0
  360. package/dist/chunk-py3zxq5j.js +129 -0
  361. package/dist/chunk-pyz1qswz.js +300 -0
  362. package/dist/chunk-q50q8mc5.js +157 -0
  363. package/dist/chunk-q7tpyeb3.js +39 -0
  364. package/dist/chunk-q82r31er.js +151 -0
  365. package/dist/chunk-qajrkk97.js +298 -0
  366. package/dist/chunk-qcpxnyeh.js +110 -0
  367. package/dist/chunk-qeabchwr.js +132 -0
  368. package/dist/chunk-qm7nbd10.js +755 -0
  369. package/dist/chunk-qm8j7kxr.js +280 -0
  370. package/dist/chunk-qmwgg5zy.js +136 -0
  371. package/dist/chunk-qnfx3qtx.js +617 -0
  372. package/dist/chunk-qp2qdcda.js +100 -0
  373. package/dist/chunk-qphaajd7.js +305 -0
  374. package/dist/chunk-qt21xxgm.js +419 -0
  375. package/dist/chunk-qy2z2p0b.js +122 -0
  376. package/dist/chunk-qyz8q0dj.js +689 -0
  377. package/dist/chunk-qz2x630m.js +49145 -0
  378. package/dist/chunk-qzq5n1yn.js +76 -0
  379. package/dist/chunk-r0ya57xw.js +170 -0
  380. package/dist/chunk-r7j395t6.js +122 -0
  381. package/dist/chunk-r7trcrs7.js +62 -0
  382. package/dist/chunk-re4yh70t.js +1095 -0
  383. package/dist/chunk-rhte1r8g.js +272 -0
  384. package/dist/chunk-rhw4ayb1.js +6851 -0
  385. package/dist/chunk-rn0v1hk8.js +34 -0
  386. package/dist/chunk-rphakhme.js +281 -0
  387. package/dist/chunk-rrtzz2pv.js +32 -0
  388. package/dist/chunk-rtnjk8ge.js +726 -0
  389. package/dist/chunk-rwhswkma.js +87 -0
  390. package/dist/chunk-rxd4kn2g.js +308 -0
  391. package/dist/chunk-s083x8ry.js +2840 -0
  392. package/dist/chunk-s16sn02n.js +365 -0
  393. package/dist/chunk-s1s8qfdh.js +182 -0
  394. package/dist/chunk-s2bwz69v.js +473 -0
  395. package/dist/chunk-s3pzvdss.js +50 -0
  396. package/dist/chunk-s9y6t0mt.js +291 -0
  397. package/dist/chunk-sd36yzx8.js +954 -0
  398. package/dist/chunk-se8xzw8h.js +87 -0
  399. package/dist/chunk-sg66v252.js +1648 -0
  400. package/dist/chunk-sg7gf3hj.js +1585 -0
  401. package/dist/chunk-spx24x6j.js +98 -0
  402. package/dist/chunk-sybxpy18.js +73 -0
  403. package/dist/chunk-szj5wvdy.js +28 -0
  404. package/dist/chunk-t0gb304x.js +182 -0
  405. package/dist/chunk-t3fr4skc.js +165 -0
  406. package/dist/chunk-t58wfamm.js +5368 -0
  407. package/dist/chunk-t6s2kkm3.js +104 -0
  408. package/dist/chunk-t8hv0x81.js +116 -0
  409. package/dist/chunk-tezak8rx.js +6157 -0
  410. package/dist/chunk-th5y3hj5.js +189 -0
  411. package/dist/chunk-tj0d3870.js +180 -0
  412. package/dist/chunk-tjgsawpx.js +40 -0
  413. package/dist/chunk-ts2p6bv1.js +224 -0
  414. package/dist/chunk-ttk5dzz8.js +25 -0
  415. package/dist/chunk-tv9pcdnz.js +51 -0
  416. package/dist/chunk-ty99rgvw.js +122 -0
  417. package/dist/chunk-tzgp8av2.js +61 -0
  418. package/dist/chunk-v1kzp02e.js +785 -0
  419. package/dist/chunk-v2c9dq7t.js +275 -0
  420. package/dist/chunk-v3aq3heg.js +620 -0
  421. package/dist/chunk-v78fj8by.js +145 -0
  422. package/dist/chunk-v9smspw2.js +4301 -0
  423. package/dist/chunk-var1et7e.js +66 -0
  424. package/dist/chunk-vchrkvet.js +120 -0
  425. package/dist/chunk-vest0y6x.js +3830 -0
  426. package/dist/chunk-vf5sd1nq.js +12 -0
  427. package/dist/chunk-vf612n57.js +472 -0
  428. package/dist/chunk-vgpy9md6.js +339 -0
  429. package/dist/chunk-vkzt82ry.js +644 -0
  430. package/dist/chunk-vsh80y0c.js +100 -0
  431. package/dist/chunk-vxkdxhyk.js +103 -0
  432. package/dist/chunk-vxt6ywm9.js +485 -0
  433. package/dist/chunk-vyjeh50y.js +2149 -0
  434. package/dist/chunk-vytdzvqs.js +1181 -0
  435. package/dist/chunk-w0qks2ja.js +1030 -0
  436. package/dist/chunk-wfz0qffj.js +3939 -0
  437. package/dist/chunk-wp1568nt.js +828 -0
  438. package/dist/chunk-wpckhx7b.js +66 -0
  439. package/dist/chunk-wpvkvwvc.js +41 -0
  440. package/dist/chunk-ws5d6qs4.js +655 -0
  441. package/dist/chunk-wsnxrrb5.js +986 -0
  442. package/dist/chunk-wyavftcj.js +103 -0
  443. package/dist/chunk-wybh0bvv.js +121 -0
  444. package/dist/chunk-wzpdet3m.js +843 -0
  445. package/dist/chunk-x2dp18yj.js +74 -0
  446. package/dist/chunk-x6r4v44b.js +8 -0
  447. package/dist/chunk-x7r5k0hf.js +423 -0
  448. package/dist/chunk-xahk20z8.js +877 -0
  449. package/dist/chunk-xajwdaxm.js +295 -0
  450. package/dist/chunk-xkt36p6r.js +61 -0
  451. package/dist/chunk-xnav6j8h.js +490 -0
  452. package/dist/chunk-xrj294jg.js +440 -0
  453. package/dist/chunk-xsq9ae7x.js +90 -0
  454. package/dist/chunk-xt9z9t7b.js +40 -0
  455. package/dist/chunk-xv3era3s.js +8 -0
  456. package/dist/chunk-y1784krc.js +19 -0
  457. package/dist/chunk-y289fz8y.js +116 -0
  458. package/dist/chunk-y3r7v9pq.js +336 -0
  459. package/dist/chunk-y98z50mm.js +158 -0
  460. package/dist/chunk-yhce3x0q.js +64 -0
  461. package/dist/chunk-yhhf6n9p.js +338 -0
  462. package/dist/chunk-ykr34msh.js +411 -0
  463. package/dist/chunk-yks9ggzn.js +103 -0
  464. package/dist/chunk-ym5r3jnk.js +2007 -0
  465. package/dist/chunk-ypa349qq.js +148 -0
  466. package/dist/chunk-yzx3mhfd.js +110 -0
  467. package/dist/chunk-z1bs6d7k.js +24 -0
  468. package/dist/chunk-z2dp53wn.js +17 -0
  469. package/dist/chunk-z3k0k30d.js +882 -0
  470. package/dist/chunk-z42cqdtf.js +107 -0
  471. package/dist/chunk-z7asrz6j.js +259 -0
  472. package/dist/chunk-za09fhhh.js +716 -0
  473. package/dist/chunk-zae0t3p4.js +252 -0
  474. package/dist/chunk-zbsw794g.js +259 -0
  475. package/dist/chunk-ze6zvkg6.js +22820 -0
  476. package/dist/chunk-zejm280k.js +39 -0
  477. package/dist/chunk-zk2wsm7d.js +15 -0
  478. package/dist/chunk-znf2b75k.js +113 -0
  479. package/dist/chunk-zqpnvsdz.js +24 -0
  480. package/dist/chunk-zs2gdkj5.js +433 -0
  481. package/dist/chunk-zseb1639.js +37 -0
  482. package/dist/chunk-zsgha506.js +63 -0
  483. package/dist/chunk-zvsfgmq8.js +146 -0
  484. package/dist/chunk-zw5xd7m9.js +160 -0
  485. package/dist/chunk-zzm33q8x.js +8 -0
  486. package/dist/cli.js +97 -0
  487. package/dist/download-ripgrep.js +24821 -0
  488. package/dist/vendor/audio-capture/arm64-darwin/audio-capture.node +0 -0
  489. package/dist/vendor/audio-capture/arm64-linux/audio-capture.node +0 -0
  490. package/dist/vendor/audio-capture/arm64-win32/audio-capture.node +0 -0
  491. package/dist/vendor/audio-capture/x64-darwin/audio-capture.node +0 -0
  492. package/dist/vendor/audio-capture/x64-linux/audio-capture.node +0 -0
  493. package/dist/vendor/audio-capture/x64-win32/audio-capture.node +0 -0
  494. package/package.json +178 -0
  495. package/scripts/download-ripgrep.ts +335 -0
  496. package/scripts/postinstall.cjs +319 -0
@@ -0,0 +1,915 @@
1
+ // @bun
2
+ import {
3
+ getSessionIngressAuthHeaders,
4
+ getSessionIngressAuthToken,
5
+ init_sessionActivity,
6
+ init_sessionIngressAuth,
7
+ registerSessionActivityCallback,
8
+ unregisterSessionActivityCallback
9
+ } from "./chunk-a4psxnr1.js";
10
+ import {
11
+ getClaudeCodeUserAgent,
12
+ init_userAgent
13
+ } from "./chunk-7b6bg1r4.js";
14
+ import {
15
+ createAxiosInstance,
16
+ init_proxy
17
+ } from "./chunk-rtnjk8ge.js";
18
+ import {
19
+ init_sleep,
20
+ sleep
21
+ } from "./chunk-8g5pe1gr.js";
22
+ import {
23
+ init_analytics,
24
+ logEvent
25
+ } from "./chunk-h0rbjg6x.js";
26
+ import {
27
+ init_diagLogs,
28
+ logForDiagnosticsNoPII
29
+ } from "./chunk-36b2q5fg.js";
30
+ import {
31
+ errorMessage,
32
+ getErrnoCode,
33
+ init_debug,
34
+ init_errors,
35
+ init_slowOperations,
36
+ jsonParse,
37
+ jsonStringify,
38
+ logForDebugging
39
+ } from "./chunk-404qm8xt.js";
40
+
41
+ // src/bridge/jwtUtils.ts
42
+ init_analytics();
43
+ init_debug();
44
+ init_diagLogs();
45
+ init_errors();
46
+ init_slowOperations();
47
+ function formatDuration(ms) {
48
+ if (ms < 60000)
49
+ return `${Math.round(ms / 1000)}s`;
50
+ const m = Math.floor(ms / 60000);
51
+ const s = Math.round(ms % 60000 / 1000);
52
+ return s > 0 ? `${m}m ${s}s` : `${m}m`;
53
+ }
54
+ function decodeJwtPayload(token) {
55
+ const jwt = token.startsWith("sk-ant-si-") ? token.slice("sk-ant-si-".length) : token;
56
+ const parts = jwt.split(".");
57
+ if (parts.length !== 3 || !parts[1])
58
+ return null;
59
+ try {
60
+ return jsonParse(Buffer.from(parts[1], "base64url").toString("utf8"));
61
+ } catch {
62
+ return null;
63
+ }
64
+ }
65
+ function decodeJwtExpiry(token) {
66
+ const payload = decodeJwtPayload(token);
67
+ if (payload !== null && typeof payload === "object" && "exp" in payload && typeof payload.exp === "number") {
68
+ return payload.exp;
69
+ }
70
+ return null;
71
+ }
72
+ var TOKEN_REFRESH_BUFFER_MS = 5 * 60 * 1000;
73
+ var FALLBACK_REFRESH_INTERVAL_MS = 30 * 60 * 1000;
74
+ var MAX_REFRESH_FAILURES = 3;
75
+ var REFRESH_RETRY_DELAY_MS = 60000;
76
+ function createTokenRefreshScheduler({
77
+ getAccessToken,
78
+ onRefresh,
79
+ label,
80
+ refreshBufferMs = TOKEN_REFRESH_BUFFER_MS
81
+ }) {
82
+ const timers = new Map;
83
+ const failureCounts = new Map;
84
+ const generations = new Map;
85
+ function nextGeneration(sessionId) {
86
+ const gen = (generations.get(sessionId) ?? 0) + 1;
87
+ generations.set(sessionId, gen);
88
+ return gen;
89
+ }
90
+ function schedule(sessionId, token) {
91
+ const expiry = decodeJwtExpiry(token);
92
+ if (!expiry) {
93
+ logForDebugging(`[${label}:token] Could not decode JWT expiry for sessionId=${sessionId}, token prefix=${token.slice(0, 15)}\u2026, keeping existing timer`);
94
+ return;
95
+ }
96
+ const existing = timers.get(sessionId);
97
+ if (existing) {
98
+ clearTimeout(existing);
99
+ }
100
+ const gen = nextGeneration(sessionId);
101
+ const expiryDate = new Date(expiry * 1000).toISOString();
102
+ const delayMs = expiry * 1000 - Date.now() - refreshBufferMs;
103
+ if (delayMs <= 0) {
104
+ logForDebugging(`[${label}:token] Token for sessionId=${sessionId} expires=${expiryDate} (past or within buffer), refreshing immediately`);
105
+ doRefresh(sessionId, gen);
106
+ return;
107
+ }
108
+ logForDebugging(`[${label}:token] Scheduled token refresh for sessionId=${sessionId} in ${formatDuration(delayMs)} (expires=${expiryDate}, buffer=${refreshBufferMs / 1000}s)`);
109
+ const timer = setTimeout(doRefresh, delayMs, sessionId, gen);
110
+ timers.set(sessionId, timer);
111
+ }
112
+ function scheduleFromExpiresIn(sessionId, expiresInSeconds) {
113
+ const existing = timers.get(sessionId);
114
+ if (existing)
115
+ clearTimeout(existing);
116
+ const gen = nextGeneration(sessionId);
117
+ const delayMs = Math.max(expiresInSeconds * 1000 - refreshBufferMs, 30000);
118
+ logForDebugging(`[${label}:token] Scheduled token refresh for sessionId=${sessionId} in ${formatDuration(delayMs)} (expires_in=${expiresInSeconds}s, buffer=${refreshBufferMs / 1000}s)`);
119
+ const timer = setTimeout(doRefresh, delayMs, sessionId, gen);
120
+ timers.set(sessionId, timer);
121
+ }
122
+ async function doRefresh(sessionId, gen) {
123
+ let oauthToken;
124
+ try {
125
+ oauthToken = await getAccessToken();
126
+ } catch (err) {
127
+ logForDebugging(`[${label}:token] getAccessToken threw for sessionId=${sessionId}: ${errorMessage(err)}`, { level: "error" });
128
+ }
129
+ if (generations.get(sessionId) !== gen) {
130
+ logForDebugging(`[${label}:token] doRefresh for sessionId=${sessionId} stale (gen ${gen} vs ${generations.get(sessionId)}), skipping`);
131
+ return;
132
+ }
133
+ if (!oauthToken) {
134
+ const failures = (failureCounts.get(sessionId) ?? 0) + 1;
135
+ failureCounts.set(sessionId, failures);
136
+ logForDebugging(`[${label}:token] No OAuth token available for refresh, sessionId=${sessionId} (failure ${failures}/${MAX_REFRESH_FAILURES})`, { level: "error" });
137
+ logForDiagnosticsNoPII("error", "bridge_token_refresh_no_oauth");
138
+ if (failures < MAX_REFRESH_FAILURES) {
139
+ const retryTimer = setTimeout(doRefresh, REFRESH_RETRY_DELAY_MS, sessionId, gen);
140
+ timers.set(sessionId, retryTimer);
141
+ }
142
+ return;
143
+ }
144
+ failureCounts.delete(sessionId);
145
+ logForDebugging(`[${label}:token] Refreshing token for sessionId=${sessionId}: new token prefix=${oauthToken.slice(0, 15)}\u2026`);
146
+ logEvent("tengu_bridge_token_refreshed", {});
147
+ onRefresh(sessionId, oauthToken);
148
+ const timer = setTimeout(doRefresh, FALLBACK_REFRESH_INTERVAL_MS, sessionId, gen);
149
+ timers.set(sessionId, timer);
150
+ logForDebugging(`[${label}:token] Scheduled follow-up refresh for sessionId=${sessionId} in ${formatDuration(FALLBACK_REFRESH_INTERVAL_MS)}`);
151
+ }
152
+ function cancel(sessionId) {
153
+ nextGeneration(sessionId);
154
+ const timer = timers.get(sessionId);
155
+ if (timer) {
156
+ clearTimeout(timer);
157
+ timers.delete(sessionId);
158
+ }
159
+ failureCounts.delete(sessionId);
160
+ }
161
+ function cancelAll() {
162
+ for (const sessionId of generations.keys()) {
163
+ nextGeneration(sessionId);
164
+ }
165
+ for (const timer of timers.values()) {
166
+ clearTimeout(timer);
167
+ }
168
+ timers.clear();
169
+ failureCounts.clear();
170
+ }
171
+ return { schedule, scheduleFromExpiresIn, cancel, cancelAll };
172
+ }
173
+
174
+ // src/cli/transports/ccrClient.ts
175
+ import { randomUUID } from "crypto";
176
+ init_debug();
177
+ init_diagLogs();
178
+ init_errors();
179
+ init_proxy();
180
+ init_sessionActivity();
181
+ init_sessionIngressAuth();
182
+ init_sleep();
183
+ init_userAgent();
184
+
185
+ // src/cli/transports/SerialBatchEventUploader.ts
186
+ init_slowOperations();
187
+
188
+ class RetryableError extends Error {
189
+ retryAfterMs;
190
+ constructor(message, retryAfterMs) {
191
+ super(message);
192
+ this.retryAfterMs = retryAfterMs;
193
+ }
194
+ }
195
+
196
+ class SerialBatchEventUploader {
197
+ pending = [];
198
+ pendingAtClose = 0;
199
+ draining = false;
200
+ closed = false;
201
+ backpressureResolvers = [];
202
+ sleepResolve = null;
203
+ flushResolvers = [];
204
+ droppedBatches = 0;
205
+ config;
206
+ constructor(config) {
207
+ this.config = config;
208
+ }
209
+ get droppedBatchCount() {
210
+ return this.droppedBatches;
211
+ }
212
+ get pendingCount() {
213
+ return this.closed ? this.pendingAtClose : this.pending.length;
214
+ }
215
+ async enqueue(events) {
216
+ if (this.closed)
217
+ return;
218
+ const items = Array.isArray(events) ? events : [events];
219
+ if (items.length === 0)
220
+ return;
221
+ while (this.pending.length + items.length > this.config.maxQueueSize && !this.closed) {
222
+ await new Promise((resolve) => {
223
+ this.backpressureResolvers.push(resolve);
224
+ });
225
+ }
226
+ if (this.closed)
227
+ return;
228
+ this.pending.push(...items);
229
+ this.drain();
230
+ }
231
+ flush() {
232
+ if (this.pending.length === 0 && !this.draining) {
233
+ return Promise.resolve();
234
+ }
235
+ this.drain();
236
+ return new Promise((resolve) => {
237
+ this.flushResolvers.push(resolve);
238
+ });
239
+ }
240
+ close() {
241
+ if (this.closed)
242
+ return;
243
+ this.closed = true;
244
+ this.pendingAtClose = this.pending.length;
245
+ this.pending = [];
246
+ this.sleepResolve?.();
247
+ this.sleepResolve = null;
248
+ for (const resolve of this.backpressureResolvers)
249
+ resolve();
250
+ this.backpressureResolvers = [];
251
+ for (const resolve of this.flushResolvers)
252
+ resolve();
253
+ this.flushResolvers = [];
254
+ }
255
+ async drain() {
256
+ if (this.draining || this.closed)
257
+ return;
258
+ this.draining = true;
259
+ let failures = 0;
260
+ try {
261
+ while (this.pending.length > 0 && !this.closed) {
262
+ const batch = this.takeBatch();
263
+ if (batch.length === 0)
264
+ continue;
265
+ try {
266
+ await this.config.send(batch);
267
+ failures = 0;
268
+ } catch (err) {
269
+ failures++;
270
+ if (this.config.maxConsecutiveFailures !== undefined && failures >= this.config.maxConsecutiveFailures) {
271
+ this.droppedBatches++;
272
+ this.config.onBatchDropped?.(batch.length, failures);
273
+ failures = 0;
274
+ this.releaseBackpressure();
275
+ continue;
276
+ }
277
+ this.pending = batch.concat(this.pending);
278
+ const retryAfterMs = err instanceof RetryableError ? err.retryAfterMs : undefined;
279
+ await this.sleep(this.retryDelay(failures, retryAfterMs));
280
+ continue;
281
+ }
282
+ this.releaseBackpressure();
283
+ }
284
+ } finally {
285
+ this.draining = false;
286
+ if (this.pending.length === 0) {
287
+ for (const resolve of this.flushResolvers)
288
+ resolve();
289
+ this.flushResolvers = [];
290
+ }
291
+ }
292
+ }
293
+ takeBatch() {
294
+ const { maxBatchSize, maxBatchBytes } = this.config;
295
+ if (maxBatchBytes === undefined) {
296
+ return this.pending.splice(0, maxBatchSize);
297
+ }
298
+ let bytes = 0;
299
+ let count = 0;
300
+ while (count < this.pending.length && count < maxBatchSize) {
301
+ let itemBytes;
302
+ try {
303
+ itemBytes = Buffer.byteLength(jsonStringify(this.pending[count]));
304
+ } catch {
305
+ this.pending.splice(count, 1);
306
+ continue;
307
+ }
308
+ if (count > 0 && bytes + itemBytes > maxBatchBytes)
309
+ break;
310
+ bytes += itemBytes;
311
+ count++;
312
+ }
313
+ return this.pending.splice(0, count);
314
+ }
315
+ retryDelay(failures, retryAfterMs) {
316
+ const jitter = Math.random() * this.config.jitterMs;
317
+ if (retryAfterMs !== undefined) {
318
+ const clamped = Math.max(this.config.baseDelayMs, Math.min(retryAfterMs, this.config.maxDelayMs));
319
+ return clamped + jitter;
320
+ }
321
+ const exponential = Math.min(this.config.baseDelayMs * 2 ** (failures - 1), this.config.maxDelayMs);
322
+ return exponential + jitter;
323
+ }
324
+ releaseBackpressure() {
325
+ const resolvers = this.backpressureResolvers;
326
+ this.backpressureResolvers = [];
327
+ for (const resolve of resolvers)
328
+ resolve();
329
+ }
330
+ sleep(ms) {
331
+ return new Promise((resolve) => {
332
+ this.sleepResolve = resolve;
333
+ setTimeout((self, resolve2) => {
334
+ self.sleepResolve = null;
335
+ resolve2();
336
+ }, ms, this, resolve);
337
+ });
338
+ }
339
+ }
340
+
341
+ // src/cli/transports/WorkerStateUploader.ts
342
+ init_sleep();
343
+
344
+ class WorkerStateUploader {
345
+ inflight = null;
346
+ pending = null;
347
+ closed = false;
348
+ config;
349
+ constructor(config) {
350
+ this.config = config;
351
+ }
352
+ enqueue(patch) {
353
+ if (this.closed)
354
+ return;
355
+ this.pending = this.pending ? coalescePatches(this.pending, patch) : patch;
356
+ this.drain();
357
+ }
358
+ close() {
359
+ this.closed = true;
360
+ this.pending = null;
361
+ }
362
+ async drain() {
363
+ if (this.inflight || this.closed)
364
+ return;
365
+ if (!this.pending)
366
+ return;
367
+ const payload = this.pending;
368
+ this.pending = null;
369
+ this.inflight = this.sendWithRetry(payload).then(() => {
370
+ this.inflight = null;
371
+ if (this.pending && !this.closed) {
372
+ this.drain();
373
+ }
374
+ });
375
+ }
376
+ async sendWithRetry(payload) {
377
+ let current = payload;
378
+ let failures = 0;
379
+ while (!this.closed) {
380
+ const ok = await this.config.send(current);
381
+ if (ok)
382
+ return;
383
+ failures++;
384
+ await sleep(this.retryDelay(failures));
385
+ if (this.pending && !this.closed) {
386
+ current = coalescePatches(current, this.pending);
387
+ this.pending = null;
388
+ }
389
+ }
390
+ }
391
+ retryDelay(failures) {
392
+ const exponential = Math.min(this.config.baseDelayMs * 2 ** (failures - 1), this.config.maxDelayMs);
393
+ const jitter = Math.random() * this.config.jitterMs;
394
+ return exponential + jitter;
395
+ }
396
+ }
397
+ function coalescePatches(base, overlay) {
398
+ const merged = { ...base };
399
+ for (const [key, value] of Object.entries(overlay)) {
400
+ if ((key === "external_metadata" || key === "internal_metadata") && merged[key] && typeof merged[key] === "object" && typeof value === "object" && value !== null) {
401
+ merged[key] = {
402
+ ...merged[key],
403
+ ...value
404
+ };
405
+ } else {
406
+ merged[key] = value;
407
+ }
408
+ }
409
+ return merged;
410
+ }
411
+
412
+ // src/cli/transports/ccrClient.ts
413
+ var DEFAULT_HEARTBEAT_INTERVAL_MS = 20000;
414
+ var STREAM_EVENT_FLUSH_INTERVAL_MS = 100;
415
+ function alwaysValidStatus() {
416
+ return true;
417
+ }
418
+
419
+ class CCRInitError extends Error {
420
+ reason;
421
+ constructor(reason) {
422
+ super(`CCRClient init failed: ${reason}`);
423
+ this.reason = reason;
424
+ }
425
+ }
426
+ var MAX_CONSECUTIVE_AUTH_FAILURES = 10;
427
+ function createStreamAccumulator() {
428
+ return { byMessage: new Map, scopeToMessage: new Map };
429
+ }
430
+ function scopeKey(m) {
431
+ return `${m.session_id}:${m.parent_tool_use_id ?? ""}`;
432
+ }
433
+ function accumulateStreamEvents(buffer, state) {
434
+ const out = [];
435
+ const touched = new Map;
436
+ for (const msg of buffer) {
437
+ switch (msg.event.type) {
438
+ case "message_start": {
439
+ const id = msg.event.message.id;
440
+ const prevId = state.scopeToMessage.get(scopeKey(msg));
441
+ if (prevId)
442
+ state.byMessage.delete(prevId);
443
+ state.scopeToMessage.set(scopeKey(msg), id);
444
+ state.byMessage.set(id, []);
445
+ out.push(msg);
446
+ break;
447
+ }
448
+ case "content_block_delta": {
449
+ if (msg.event.delta.type !== "text_delta") {
450
+ out.push(msg);
451
+ break;
452
+ }
453
+ const messageId = state.scopeToMessage.get(scopeKey(msg));
454
+ const blocks = messageId ? state.byMessage.get(messageId) : undefined;
455
+ if (!blocks) {
456
+ out.push(msg);
457
+ break;
458
+ }
459
+ const chunks = blocks[msg.event.index] ??= [];
460
+ chunks.push(msg.event.delta.text);
461
+ const existing = touched.get(chunks);
462
+ if (existing) {
463
+ existing.event.delta.text = chunks.join("");
464
+ break;
465
+ }
466
+ const snapshot = {
467
+ type: "stream_event",
468
+ uuid: msg.uuid,
469
+ session_id: msg.session_id,
470
+ parent_tool_use_id: msg.parent_tool_use_id,
471
+ event: {
472
+ type: "content_block_delta",
473
+ index: msg.event.index,
474
+ delta: { type: "text_delta", text: chunks.join("") }
475
+ }
476
+ };
477
+ touched.set(chunks, snapshot);
478
+ out.push(snapshot);
479
+ break;
480
+ }
481
+ default:
482
+ out.push(msg);
483
+ }
484
+ }
485
+ return out;
486
+ }
487
+ function clearStreamAccumulatorForMessage(state, assistant) {
488
+ state.byMessage.delete(assistant.message.id);
489
+ const scope = scopeKey(assistant);
490
+ if (state.scopeToMessage.get(scope) === assistant.message.id) {
491
+ state.scopeToMessage.delete(scope);
492
+ }
493
+ }
494
+
495
+ class CCRClient {
496
+ workerEpoch = 0;
497
+ heartbeatIntervalMs;
498
+ heartbeatJitterFraction;
499
+ heartbeatTimer = null;
500
+ heartbeatInFlight = false;
501
+ closed = false;
502
+ consecutiveAuthFailures = 0;
503
+ currentState = null;
504
+ sessionBaseUrl;
505
+ sessionId;
506
+ http = createAxiosInstance({ keepAlive: true });
507
+ streamEventBuffer = [];
508
+ streamEventTimer = null;
509
+ streamTextAccumulator = createStreamAccumulator();
510
+ workerState;
511
+ eventUploader;
512
+ internalEventUploader;
513
+ deliveryUploader;
514
+ onEpochMismatch;
515
+ getAuthHeaders;
516
+ constructor(transport, sessionUrl, opts) {
517
+ this.onEpochMismatch = opts?.onEpochMismatch ?? (() => {
518
+ process.exit(1);
519
+ });
520
+ this.heartbeatIntervalMs = opts?.heartbeatIntervalMs ?? DEFAULT_HEARTBEAT_INTERVAL_MS;
521
+ this.heartbeatJitterFraction = opts?.heartbeatJitterFraction ?? 0;
522
+ this.getAuthHeaders = opts?.getAuthHeaders ?? getSessionIngressAuthHeaders;
523
+ if (sessionUrl.protocol !== "http:" && sessionUrl.protocol !== "https:") {
524
+ throw new Error(`CCRClient: Expected http(s) URL, got ${sessionUrl.protocol}`);
525
+ }
526
+ const pathname = sessionUrl.pathname.replace(/\/$/, "");
527
+ this.sessionBaseUrl = `${sessionUrl.protocol}//${sessionUrl.host}${pathname}`;
528
+ this.sessionId = pathname.split("/").pop() || "";
529
+ this.workerState = new WorkerStateUploader({
530
+ send: (body) => this.request("put", "/worker", { worker_epoch: this.workerEpoch, ...body }, "PUT worker").then((r) => r.ok),
531
+ baseDelayMs: 500,
532
+ maxDelayMs: 30000,
533
+ jitterMs: 500
534
+ });
535
+ this.eventUploader = new SerialBatchEventUploader({
536
+ maxBatchSize: 100,
537
+ maxBatchBytes: 10 * 1024 * 1024,
538
+ maxQueueSize: 1e5,
539
+ send: async (batch) => {
540
+ const result = await this.request("post", "/worker/events", { worker_epoch: this.workerEpoch, events: batch }, "client events");
541
+ if (!result.ok) {
542
+ throw new RetryableError("client event POST failed", result.retryAfterMs);
543
+ }
544
+ },
545
+ baseDelayMs: 500,
546
+ maxDelayMs: 30000,
547
+ jitterMs: 500
548
+ });
549
+ this.internalEventUploader = new SerialBatchEventUploader({
550
+ maxBatchSize: 100,
551
+ maxBatchBytes: 10 * 1024 * 1024,
552
+ maxQueueSize: 200,
553
+ send: async (batch) => {
554
+ const result = await this.request("post", "/worker/internal-events", { worker_epoch: this.workerEpoch, events: batch }, "internal events");
555
+ if (!result.ok) {
556
+ throw new RetryableError("internal event POST failed", result.retryAfterMs);
557
+ }
558
+ },
559
+ baseDelayMs: 500,
560
+ maxDelayMs: 30000,
561
+ jitterMs: 500
562
+ });
563
+ this.deliveryUploader = new SerialBatchEventUploader({
564
+ maxBatchSize: 64,
565
+ maxQueueSize: 64,
566
+ send: async (batch) => {
567
+ const result = await this.request("post", "/worker/events/delivery", {
568
+ worker_epoch: this.workerEpoch,
569
+ updates: batch.map((d) => ({
570
+ event_id: d.eventId,
571
+ status: d.status
572
+ }))
573
+ }, "delivery batch");
574
+ if (!result.ok) {
575
+ throw new RetryableError("delivery POST failed", result.retryAfterMs);
576
+ }
577
+ },
578
+ baseDelayMs: 500,
579
+ maxDelayMs: 30000,
580
+ jitterMs: 500
581
+ });
582
+ transport.setOnEvent((event) => {
583
+ this.reportDelivery(event.event_id, "received");
584
+ });
585
+ }
586
+ async initialize(epoch) {
587
+ const startMs = Date.now();
588
+ if (Object.keys(this.getAuthHeaders()).length === 0) {
589
+ throw new CCRInitError("no_auth_headers");
590
+ }
591
+ if (epoch === undefined) {
592
+ const rawEpoch = process.env.CLAUDE_CODE_WORKER_EPOCH;
593
+ epoch = rawEpoch ? parseInt(rawEpoch, 10) : NaN;
594
+ }
595
+ if (isNaN(epoch)) {
596
+ throw new CCRInitError("missing_epoch");
597
+ }
598
+ this.workerEpoch = epoch;
599
+ const restoredPromise = this.getWorkerState();
600
+ const result = await this.request("put", "/worker", {
601
+ worker_status: "idle",
602
+ worker_epoch: this.workerEpoch,
603
+ external_metadata: {
604
+ pending_action: null,
605
+ task_summary: null
606
+ }
607
+ }, "PUT worker (init)");
608
+ if (!result.ok) {
609
+ throw new CCRInitError("worker_register_failed");
610
+ }
611
+ this.currentState = "idle";
612
+ this.startHeartbeat();
613
+ registerSessionActivityCallback(() => {
614
+ this.writeEvent({ type: "keep_alive" });
615
+ });
616
+ logForDebugging(`CCRClient: initialized, epoch=${this.workerEpoch}`);
617
+ logForDiagnosticsNoPII("info", "cli_worker_lifecycle_initialized", {
618
+ epoch: this.workerEpoch,
619
+ duration_ms: Date.now() - startMs
620
+ });
621
+ const { metadata, durationMs } = await restoredPromise;
622
+ if (!this.closed) {
623
+ logForDiagnosticsNoPII("info", "cli_worker_state_restored", {
624
+ duration_ms: durationMs,
625
+ had_state: metadata !== null
626
+ });
627
+ }
628
+ return metadata;
629
+ }
630
+ async getWorkerState() {
631
+ const startMs = Date.now();
632
+ const authHeaders = this.getAuthHeaders();
633
+ if (Object.keys(authHeaders).length === 0) {
634
+ return { metadata: null, durationMs: 0 };
635
+ }
636
+ const data = await this.getWithRetry(`${this.sessionBaseUrl}/worker`, authHeaders, "worker_state");
637
+ return {
638
+ metadata: data?.worker?.external_metadata ?? null,
639
+ durationMs: Date.now() - startMs
640
+ };
641
+ }
642
+ async request(method, path, body, label, { timeout = 1e4 } = {}) {
643
+ const authHeaders = this.getAuthHeaders();
644
+ if (Object.keys(authHeaders).length === 0)
645
+ return { ok: false };
646
+ try {
647
+ const response = await this.http[method](`${this.sessionBaseUrl}${path}`, body, {
648
+ headers: {
649
+ ...authHeaders,
650
+ "Content-Type": "application/json",
651
+ "anthropic-version": "2023-06-01",
652
+ "User-Agent": getClaudeCodeUserAgent()
653
+ },
654
+ validateStatus: alwaysValidStatus,
655
+ timeout
656
+ });
657
+ if (response.status >= 200 && response.status < 300) {
658
+ this.consecutiveAuthFailures = 0;
659
+ return { ok: true };
660
+ }
661
+ if (response.status === 409) {
662
+ this.handleEpochMismatch();
663
+ }
664
+ if (response.status === 401 || response.status === 403) {
665
+ const tok = getSessionIngressAuthToken();
666
+ const exp = tok ? decodeJwtExpiry(tok) : null;
667
+ if (exp !== null && exp * 1000 < Date.now()) {
668
+ logForDebugging(`CCRClient: session_token expired (exp=${new Date(exp * 1000).toISOString()}) \u2014 no refresh was delivered, exiting`, { level: "error" });
669
+ logForDiagnosticsNoPII("error", "cli_worker_token_expired_no_refresh");
670
+ this.onEpochMismatch();
671
+ }
672
+ this.consecutiveAuthFailures++;
673
+ if (this.consecutiveAuthFailures >= MAX_CONSECUTIVE_AUTH_FAILURES) {
674
+ logForDebugging(`CCRClient: ${this.consecutiveAuthFailures} consecutive auth failures with a valid-looking token \u2014 server-side auth unrecoverable, exiting`, { level: "error" });
675
+ logForDiagnosticsNoPII("error", "cli_worker_auth_failures_exhausted");
676
+ this.onEpochMismatch();
677
+ }
678
+ }
679
+ logForDebugging(`CCRClient: ${label} returned ${response.status}`, {
680
+ level: "warn"
681
+ });
682
+ logForDiagnosticsNoPII("warn", "cli_worker_request_failed", {
683
+ method,
684
+ path,
685
+ status: response.status
686
+ });
687
+ if (response.status === 429) {
688
+ const raw = response.headers?.["retry-after"];
689
+ const seconds = typeof raw === "string" ? parseInt(raw, 10) : NaN;
690
+ if (!isNaN(seconds) && seconds >= 0) {
691
+ return { ok: false, retryAfterMs: seconds * 1000 };
692
+ }
693
+ }
694
+ return { ok: false };
695
+ } catch (error) {
696
+ logForDebugging(`CCRClient: ${label} failed: ${errorMessage(error)}`, {
697
+ level: "warn"
698
+ });
699
+ logForDiagnosticsNoPII("warn", "cli_worker_request_error", {
700
+ method,
701
+ path,
702
+ error_code: getErrnoCode(error)
703
+ });
704
+ return { ok: false };
705
+ }
706
+ }
707
+ reportState(state, details) {
708
+ if (state === this.currentState && !details)
709
+ return;
710
+ this.currentState = state;
711
+ this.workerState.enqueue({
712
+ worker_status: state,
713
+ requires_action_details: details ? {
714
+ tool_name: details.tool_name,
715
+ action_description: details.action_description,
716
+ request_id: details.request_id
717
+ } : null
718
+ });
719
+ }
720
+ reportMetadata(metadata) {
721
+ this.workerState.enqueue({ external_metadata: metadata });
722
+ }
723
+ handleEpochMismatch() {
724
+ logForDebugging("CCRClient: Epoch mismatch (409), shutting down", {
725
+ level: "error"
726
+ });
727
+ logForDiagnosticsNoPII("error", "cli_worker_epoch_mismatch");
728
+ this.onEpochMismatch();
729
+ }
730
+ startHeartbeat() {
731
+ this.stopHeartbeat();
732
+ const schedule = () => {
733
+ const jitter = this.heartbeatIntervalMs * this.heartbeatJitterFraction * (2 * Math.random() - 1);
734
+ this.heartbeatTimer = setTimeout(tick, this.heartbeatIntervalMs + jitter);
735
+ };
736
+ const tick = () => {
737
+ this.sendHeartbeat();
738
+ if (this.heartbeatTimer === null)
739
+ return;
740
+ schedule();
741
+ };
742
+ schedule();
743
+ }
744
+ stopHeartbeat() {
745
+ if (this.heartbeatTimer) {
746
+ clearTimeout(this.heartbeatTimer);
747
+ this.heartbeatTimer = null;
748
+ }
749
+ }
750
+ async sendHeartbeat() {
751
+ if (this.heartbeatInFlight)
752
+ return;
753
+ this.heartbeatInFlight = true;
754
+ try {
755
+ const result = await this.request("post", "/worker/heartbeat", { session_id: this.sessionId, worker_epoch: this.workerEpoch }, "Heartbeat", { timeout: 5000 });
756
+ if (result.ok) {
757
+ logForDebugging("CCRClient: Heartbeat sent");
758
+ }
759
+ } finally {
760
+ this.heartbeatInFlight = false;
761
+ }
762
+ }
763
+ async writeEvent(message) {
764
+ if (message.type === "stream_event") {
765
+ this.streamEventBuffer.push(message);
766
+ if (!this.streamEventTimer) {
767
+ this.streamEventTimer = setTimeout(() => void this.flushStreamEventBuffer(), STREAM_EVENT_FLUSH_INTERVAL_MS);
768
+ }
769
+ return;
770
+ }
771
+ await this.flushStreamEventBuffer();
772
+ if (message.type === "assistant") {
773
+ clearStreamAccumulatorForMessage(this.streamTextAccumulator, message);
774
+ }
775
+ await this.eventUploader.enqueue(this.toClientEvent(message));
776
+ }
777
+ toClientEvent(message) {
778
+ const msg = message;
779
+ return {
780
+ payload: {
781
+ ...msg,
782
+ uuid: typeof msg.uuid === "string" ? msg.uuid : randomUUID()
783
+ }
784
+ };
785
+ }
786
+ async flushStreamEventBuffer() {
787
+ if (this.streamEventTimer) {
788
+ clearTimeout(this.streamEventTimer);
789
+ this.streamEventTimer = null;
790
+ }
791
+ if (this.streamEventBuffer.length === 0)
792
+ return;
793
+ const buffered = this.streamEventBuffer;
794
+ this.streamEventBuffer = [];
795
+ const payloads = accumulateStreamEvents(buffered, this.streamTextAccumulator);
796
+ await this.eventUploader.enqueue(payloads.map((payload) => ({ payload, ephemeral: true })));
797
+ }
798
+ async writeInternalEvent(eventType, payload, {
799
+ isCompaction = false,
800
+ agentId
801
+ } = {}) {
802
+ const event = {
803
+ payload: {
804
+ type: eventType,
805
+ ...payload,
806
+ uuid: typeof payload.uuid === "string" ? payload.uuid : randomUUID()
807
+ },
808
+ ...isCompaction && { is_compaction: true },
809
+ ...agentId && { agent_id: agentId }
810
+ };
811
+ await this.internalEventUploader.enqueue(event);
812
+ }
813
+ flushInternalEvents() {
814
+ return this.internalEventUploader.flush();
815
+ }
816
+ async flush() {
817
+ await this.flushStreamEventBuffer();
818
+ return this.eventUploader.flush();
819
+ }
820
+ async readInternalEvents() {
821
+ return this.paginatedGet("/worker/internal-events", {}, "internal_events");
822
+ }
823
+ async readSubagentInternalEvents() {
824
+ return this.paginatedGet("/worker/internal-events", { subagents: "true" }, "subagent_events");
825
+ }
826
+ async paginatedGet(path, params, context) {
827
+ const authHeaders = this.getAuthHeaders();
828
+ if (Object.keys(authHeaders).length === 0)
829
+ return null;
830
+ const allEvents = [];
831
+ let cursor;
832
+ do {
833
+ const url = new URL(`${this.sessionBaseUrl}${path}`);
834
+ for (const [k, v] of Object.entries(params)) {
835
+ url.searchParams.set(k, v);
836
+ }
837
+ if (cursor) {
838
+ url.searchParams.set("cursor", cursor);
839
+ }
840
+ const page = await this.getWithRetry(url.toString(), authHeaders, context);
841
+ if (!page)
842
+ return null;
843
+ allEvents.push(...page.data ?? []);
844
+ cursor = page.next_cursor;
845
+ } while (cursor);
846
+ logForDebugging(`CCRClient: Read ${allEvents.length} internal events from ${path}${params.subagents ? " (subagents)" : ""}`);
847
+ return allEvents;
848
+ }
849
+ async getWithRetry(url, authHeaders, context) {
850
+ for (let attempt = 1;attempt <= 10; attempt++) {
851
+ let response;
852
+ try {
853
+ response = await this.http.get(url, {
854
+ headers: {
855
+ ...authHeaders,
856
+ "anthropic-version": "2023-06-01",
857
+ "User-Agent": getClaudeCodeUserAgent()
858
+ },
859
+ validateStatus: alwaysValidStatus,
860
+ timeout: 30000
861
+ });
862
+ } catch (error) {
863
+ logForDebugging(`CCRClient: GET ${url} failed (attempt ${attempt}/10): ${errorMessage(error)}`, { level: "warn" });
864
+ if (attempt < 10) {
865
+ const delay = Math.min(500 * 2 ** (attempt - 1), 30000) + Math.random() * 500;
866
+ await sleep(delay);
867
+ }
868
+ continue;
869
+ }
870
+ if (response.status >= 200 && response.status < 300) {
871
+ return response.data;
872
+ }
873
+ if (response.status === 409) {
874
+ this.handleEpochMismatch();
875
+ }
876
+ logForDebugging(`CCRClient: GET ${url} returned ${response.status} (attempt ${attempt}/10)`, { level: "warn" });
877
+ if (attempt < 10) {
878
+ const delay = Math.min(500 * 2 ** (attempt - 1), 30000) + Math.random() * 500;
879
+ await sleep(delay);
880
+ }
881
+ }
882
+ logForDebugging("CCRClient: GET retries exhausted", { level: "error" });
883
+ logForDiagnosticsNoPII("error", "cli_worker_get_retries_exhausted", {
884
+ context
885
+ });
886
+ return null;
887
+ }
888
+ reportDelivery(eventId, status) {
889
+ this.deliveryUploader.enqueue({ eventId, status });
890
+ }
891
+ getWorkerEpoch() {
892
+ return this.workerEpoch;
893
+ }
894
+ get internalEventsPending() {
895
+ return this.internalEventUploader.pendingCount;
896
+ }
897
+ close() {
898
+ this.closed = true;
899
+ this.stopHeartbeat();
900
+ unregisterSessionActivityCallback();
901
+ if (this.streamEventTimer) {
902
+ clearTimeout(this.streamEventTimer);
903
+ this.streamEventTimer = null;
904
+ }
905
+ this.streamEventBuffer = [];
906
+ this.streamTextAccumulator.byMessage.clear();
907
+ this.streamTextAccumulator.scopeToMessage.clear();
908
+ this.workerState.close();
909
+ this.eventUploader.close();
910
+ this.internalEventUploader.close();
911
+ this.deliveryUploader.close();
912
+ }
913
+ }
914
+
915
+ export { createTokenRefreshScheduler, SerialBatchEventUploader, CCRInitError, CCRClient };