@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,620 @@
1
+ // @bun
2
+ import {
3
+ init_channelNotification,
4
+ init_omit,
5
+ omit_default
6
+ } from "./chunk-bsa118r4.js";
7
+ import {
8
+ clearClaudeAIMcpConfigsCache,
9
+ clearServerCache,
10
+ commandBelongsToServer,
11
+ dedupClaudeAiMcpServers,
12
+ doesEnterpriseMcpConfigExist,
13
+ excludeStalePluginClients,
14
+ fetchClaudeAIMcpConfigsIfEligible,
15
+ fetchCommandsForClient,
16
+ fetchResourcesForClient,
17
+ fetchToolsForClient,
18
+ filterMcpServersByPolicy,
19
+ getClaudeCodeMcpConfigs,
20
+ getMcpToolsCommandsAndResources,
21
+ init_AppState,
22
+ init_claudeai,
23
+ init_client,
24
+ init_config,
25
+ init_elicitationHandler,
26
+ init_messageQueueManager,
27
+ init_notifications,
28
+ init_reject,
29
+ init_utils,
30
+ isMcpServerDisabled,
31
+ reconnectMcpServerImpl,
32
+ registerElicitationHandler,
33
+ reject_default,
34
+ setMcpServerEnabled,
35
+ useAppState,
36
+ useAppStateStore,
37
+ useNotifications,
38
+ useSetAppState
39
+ } from "./chunk-hknbjky3.js";
40
+ import {
41
+ getMcpPrefix,
42
+ init_growthbook,
43
+ init_mcpStringUtils
44
+ } from "./chunk-7b6bg1r4.js";
45
+ import {
46
+ PromptListChangedNotificationSchema,
47
+ ResourceListChangedNotificationSchema,
48
+ ToolListChangedNotificationSchema,
49
+ init_types
50
+ } from "./chunk-4cp6193g.js";
51
+ import {
52
+ require_jsx_dev_runtime,
53
+ require_react
54
+ } from "./chunk-g338npwr.js";
55
+ import {
56
+ init_analytics,
57
+ logEvent
58
+ } from "./chunk-h0rbjg6x.js";
59
+ import {
60
+ init_log,
61
+ logMCPDebug,
62
+ logMCPError
63
+ } from "./chunk-y3r7v9pq.js";
64
+ import {
65
+ errorMessage,
66
+ init_debug,
67
+ init_errors,
68
+ init_slowOperations,
69
+ logForDebugging
70
+ } from "./chunk-404qm8xt.js";
71
+ import {
72
+ getSessionId,
73
+ init_state
74
+ } from "./chunk-h4b85amj.js";
75
+ import {
76
+ __esm,
77
+ __toESM
78
+ } from "./chunk-qp2qdcda.js";
79
+
80
+ // src/services/mcp/channelPermissions.ts
81
+ var init_channelPermissions = __esm(() => {
82
+ init_slowOperations();
83
+ init_growthbook();
84
+ });
85
+
86
+ // src/services/mcp/useManageMCPConnections.ts
87
+ import { basename } from "path";
88
+ function getErrorKey(error) {
89
+ const plugin = "plugin" in error ? error.plugin : "no-plugin";
90
+ return `${error.type}:${error.source}:${plugin}`;
91
+ }
92
+ function addErrorsToAppState(setAppState, newErrors) {
93
+ if (newErrors.length === 0)
94
+ return;
95
+ setAppState((prevState) => {
96
+ const existingKeys = new Set(prevState.plugins.errors.map((e) => getErrorKey(e)));
97
+ const uniqueNewErrors = newErrors.filter((error) => !existingKeys.has(getErrorKey(error)));
98
+ if (uniqueNewErrors.length === 0) {
99
+ return prevState;
100
+ }
101
+ return {
102
+ ...prevState,
103
+ plugins: {
104
+ ...prevState.plugins,
105
+ errors: [...prevState.plugins.errors, ...uniqueNewErrors]
106
+ }
107
+ };
108
+ });
109
+ }
110
+ function useManageMCPConnections(dynamicMcpConfig, isStrictMcpConfig = false) {
111
+ const store = useAppStateStore();
112
+ const _authVersion = useAppState((s) => s.authVersion);
113
+ const _pluginReconnectKey = useAppState((s) => s.mcp.pluginReconnectKey);
114
+ const setAppState = useSetAppState();
115
+ const reconnectTimersRef = import_react.useRef(new Map);
116
+ const channelWarnedKindsRef = import_react.useRef(new Set);
117
+ const channelPermCallbacksRef = import_react.useRef(null);
118
+ if (false) {}
119
+ import_react.useEffect(() => {
120
+ if (false) {}
121
+ }, [setAppState]);
122
+ const { addNotification } = useNotifications();
123
+ const MCP_BATCH_FLUSH_MS = 16;
124
+ const pendingUpdatesRef = import_react.useRef([]);
125
+ const flushTimerRef = import_react.useRef(null);
126
+ const flushPendingUpdates = import_react.useCallback(() => {
127
+ flushTimerRef.current = null;
128
+ const updates = pendingUpdatesRef.current;
129
+ if (updates.length === 0)
130
+ return;
131
+ pendingUpdatesRef.current = [];
132
+ setAppState((prevState) => {
133
+ let mcp = prevState.mcp;
134
+ for (const update of updates) {
135
+ const {
136
+ tools: rawTools,
137
+ commands: rawCmds,
138
+ resources: rawRes,
139
+ ...client
140
+ } = update;
141
+ const tools = client.type === "disabled" || client.type === "failed" ? rawTools ?? [] : rawTools;
142
+ const commands = client.type === "disabled" || client.type === "failed" ? rawCmds ?? [] : rawCmds;
143
+ const resources = client.type === "disabled" || client.type === "failed" ? rawRes ?? [] : rawRes;
144
+ const prefix = getMcpPrefix(client.name);
145
+ const existingClientIndex = mcp.clients.findIndex((c) => c.name === client.name);
146
+ const updatedClients = existingClientIndex === -1 ? [...mcp.clients, client] : mcp.clients.map((c) => c.name === client.name ? client : c);
147
+ const updatedTools = tools === undefined ? mcp.tools : [...reject_default(mcp.tools, (t) => t.name?.startsWith(prefix)), ...tools];
148
+ const updatedCommands = commands === undefined ? mcp.commands : [
149
+ ...reject_default(mcp.commands, (c) => commandBelongsToServer(c, client.name)),
150
+ ...commands
151
+ ];
152
+ const updatedResources = resources === undefined ? mcp.resources : {
153
+ ...mcp.resources,
154
+ ...resources.length > 0 ? { [client.name]: resources } : omit_default(mcp.resources, client.name)
155
+ };
156
+ mcp = {
157
+ ...mcp,
158
+ clients: updatedClients,
159
+ tools: updatedTools,
160
+ commands: updatedCommands,
161
+ resources: updatedResources
162
+ };
163
+ }
164
+ return { ...prevState, mcp };
165
+ });
166
+ }, [setAppState]);
167
+ const updateServer = import_react.useCallback((update) => {
168
+ pendingUpdatesRef.current.push(update);
169
+ if (flushTimerRef.current === null) {
170
+ flushTimerRef.current = setTimeout(flushPendingUpdates, MCP_BATCH_FLUSH_MS);
171
+ }
172
+ }, [flushPendingUpdates]);
173
+ const onConnectionAttempt = import_react.useCallback(({
174
+ client,
175
+ tools,
176
+ commands,
177
+ resources
178
+ }) => {
179
+ updateServer({ ...client, tools, commands, resources });
180
+ switch (client.type) {
181
+ case "connected": {
182
+ registerElicitationHandler(client.client, client.name, setAppState);
183
+ client.client.onclose = () => {
184
+ const configType = client.config.type ?? "stdio";
185
+ clearServerCache(client.name, client.config).catch(() => {
186
+ logForDebugging(`Failed to invalidate the server cache: ${client.name}`);
187
+ });
188
+ if (isMcpServerDisabled(client.name)) {
189
+ logMCPDebug(client.name, `Server is disabled, skipping automatic reconnection`);
190
+ return;
191
+ }
192
+ if (configType !== "stdio" && configType !== "sdk") {
193
+ const transportType = getTransportDisplayName(configType);
194
+ logMCPDebug(client.name, `${transportType} transport closed/disconnected, attempting automatic reconnection`);
195
+ const existingTimer = reconnectTimersRef.current.get(client.name);
196
+ if (existingTimer) {
197
+ clearTimeout(existingTimer);
198
+ reconnectTimersRef.current.delete(client.name);
199
+ }
200
+ const reconnectWithBackoff = async () => {
201
+ for (let attempt = 1;attempt <= MAX_RECONNECT_ATTEMPTS; attempt++) {
202
+ if (isMcpServerDisabled(client.name)) {
203
+ logMCPDebug(client.name, `Server disabled during reconnection, stopping retry`);
204
+ reconnectTimersRef.current.delete(client.name);
205
+ return;
206
+ }
207
+ updateServer({
208
+ ...client,
209
+ type: "pending",
210
+ reconnectAttempt: attempt,
211
+ maxReconnectAttempts: MAX_RECONNECT_ATTEMPTS
212
+ });
213
+ const reconnectStartTime = Date.now();
214
+ try {
215
+ const result = await reconnectMcpServerImpl(client.name, client.config);
216
+ const elapsed = Date.now() - reconnectStartTime;
217
+ if (result.client.type === "connected") {
218
+ logMCPDebug(client.name, `${transportType} reconnection successful after ${elapsed}ms (attempt ${attempt})`);
219
+ reconnectTimersRef.current.delete(client.name);
220
+ onConnectionAttempt(result);
221
+ return;
222
+ }
223
+ logMCPDebug(client.name, `${transportType} reconnection attempt ${attempt} completed with status: ${result.client.type}`);
224
+ if (attempt === MAX_RECONNECT_ATTEMPTS) {
225
+ logMCPDebug(client.name, `Max reconnection attempts (${MAX_RECONNECT_ATTEMPTS}) reached, giving up`);
226
+ reconnectTimersRef.current.delete(client.name);
227
+ onConnectionAttempt(result);
228
+ return;
229
+ }
230
+ } catch (error) {
231
+ const elapsed = Date.now() - reconnectStartTime;
232
+ logMCPError(client.name, `${transportType} reconnection attempt ${attempt} failed after ${elapsed}ms: ${error}`);
233
+ if (attempt === MAX_RECONNECT_ATTEMPTS) {
234
+ logMCPDebug(client.name, `Max reconnection attempts (${MAX_RECONNECT_ATTEMPTS}) reached, giving up`);
235
+ reconnectTimersRef.current.delete(client.name);
236
+ updateServer({ ...client, type: "failed" });
237
+ return;
238
+ }
239
+ }
240
+ const backoffMs = Math.min(INITIAL_BACKOFF_MS * Math.pow(2, attempt - 1), MAX_BACKOFF_MS);
241
+ logMCPDebug(client.name, `Scheduling reconnection attempt ${attempt + 1} in ${backoffMs}ms`);
242
+ await new Promise((resolve) => {
243
+ const timer = setTimeout(resolve, backoffMs);
244
+ reconnectTimersRef.current.set(client.name, timer);
245
+ });
246
+ }
247
+ };
248
+ reconnectWithBackoff();
249
+ } else {
250
+ updateServer({ ...client, type: "failed" });
251
+ }
252
+ };
253
+ if (false) {
254
+ switch (gate.action) {
255
+ case "register":
256
+ case "skip":
257
+ }
258
+ }
259
+ if (client.capabilities?.tools?.listChanged) {
260
+ client.client.setNotificationHandler(ToolListChangedNotificationSchema, async () => {
261
+ logMCPDebug(client.name, `Received tools/list_changed notification, refreshing tools`);
262
+ try {
263
+ const previousToolsPromise = fetchToolsForClient.cache.get(client.name);
264
+ fetchToolsForClient.cache.delete(client.name);
265
+ const newTools = await fetchToolsForClient(client);
266
+ const newCount = newTools.length;
267
+ if (previousToolsPromise) {
268
+ previousToolsPromise.then((previousTools) => {
269
+ logEvent("tengu_mcp_list_changed", {
270
+ type: "tools",
271
+ previousCount: previousTools.length,
272
+ newCount
273
+ });
274
+ }, () => {
275
+ logEvent("tengu_mcp_list_changed", {
276
+ type: "tools",
277
+ newCount
278
+ });
279
+ });
280
+ } else {
281
+ logEvent("tengu_mcp_list_changed", {
282
+ type: "tools",
283
+ newCount
284
+ });
285
+ }
286
+ updateServer({ ...client, tools: newTools });
287
+ } catch (error) {
288
+ logMCPError(client.name, `Failed to refresh tools after list_changed notification: ${errorMessage(error)}`);
289
+ }
290
+ });
291
+ }
292
+ if (client.capabilities?.prompts?.listChanged) {
293
+ client.client.setNotificationHandler(PromptListChangedNotificationSchema, async () => {
294
+ logMCPDebug(client.name, `Received prompts/list_changed notification, refreshing prompts`);
295
+ logEvent("tengu_mcp_list_changed", {
296
+ type: "prompts"
297
+ });
298
+ try {
299
+ fetchCommandsForClient.cache.delete(client.name);
300
+ const [mcpPrompts, mcpSkills] = await Promise.all([
301
+ fetchCommandsForClient(client),
302
+ Promise.resolve([])
303
+ ]);
304
+ updateServer({
305
+ ...client,
306
+ commands: [...mcpPrompts, ...mcpSkills]
307
+ });
308
+ clearSkillIndexCache?.();
309
+ } catch (error) {
310
+ logMCPError(client.name, `Failed to refresh prompts after list_changed notification: ${errorMessage(error)}`);
311
+ }
312
+ });
313
+ }
314
+ if (client.capabilities?.resources?.listChanged) {
315
+ client.client.setNotificationHandler(ResourceListChangedNotificationSchema, async () => {
316
+ logMCPDebug(client.name, `Received resources/list_changed notification, refreshing resources`);
317
+ logEvent("tengu_mcp_list_changed", {
318
+ type: "resources"
319
+ });
320
+ try {
321
+ fetchResourcesForClient.cache.delete(client.name);
322
+ if (false) {} else {
323
+ const newResources = await fetchResourcesForClient(client);
324
+ updateServer({ ...client, resources: newResources });
325
+ }
326
+ } catch (error) {
327
+ logMCPError(client.name, `Failed to refresh resources after list_changed notification: ${errorMessage(error)}`);
328
+ }
329
+ });
330
+ }
331
+ break;
332
+ }
333
+ case "needs-auth":
334
+ case "failed":
335
+ case "pending":
336
+ case "disabled":
337
+ break;
338
+ }
339
+ }, [updateServer]);
340
+ const sessionId = getSessionId();
341
+ import_react.useEffect(() => {
342
+ async function initializeServersAsPending() {
343
+ const { servers: existingConfigs, errors: mcpErrors } = isStrictMcpConfig ? { servers: {}, errors: [] } : await getClaudeCodeMcpConfigs(dynamicMcpConfig);
344
+ const configs = { ...existingConfigs, ...dynamicMcpConfig };
345
+ addErrorsToAppState(setAppState, mcpErrors);
346
+ setAppState((prevState) => {
347
+ const { stale, ...mcpWithoutStale } = excludeStalePluginClients(prevState.mcp, configs);
348
+ for (const s of stale) {
349
+ const timer = reconnectTimersRef.current.get(s.name);
350
+ if (timer) {
351
+ clearTimeout(timer);
352
+ reconnectTimersRef.current.delete(s.name);
353
+ }
354
+ if (s.type === "connected") {
355
+ s.client.onclose = undefined;
356
+ clearServerCache(s.name, s.config).catch(() => {});
357
+ }
358
+ }
359
+ const existingServerNames = new Set(mcpWithoutStale.clients.map((c) => c.name));
360
+ const newClients = Object.entries(configs).filter(([name]) => !existingServerNames.has(name)).map(([name, config]) => ({
361
+ name,
362
+ type: isMcpServerDisabled(name) ? "disabled" : "pending",
363
+ config
364
+ }));
365
+ if (newClients.length === 0 && stale.length === 0) {
366
+ return prevState;
367
+ }
368
+ return {
369
+ ...prevState,
370
+ mcp: {
371
+ ...prevState.mcp,
372
+ ...mcpWithoutStale,
373
+ clients: [...mcpWithoutStale.clients, ...newClients]
374
+ }
375
+ };
376
+ });
377
+ }
378
+ initializeServersAsPending().catch((error) => {
379
+ logMCPError("useManageMCPConnections", `Failed to initialize servers as pending: ${errorMessage(error)}`);
380
+ });
381
+ }, [
382
+ isStrictMcpConfig,
383
+ dynamicMcpConfig,
384
+ setAppState,
385
+ sessionId,
386
+ _pluginReconnectKey
387
+ ]);
388
+ import_react.useEffect(() => {
389
+ let cancelled = false;
390
+ async function loadAndConnectMcpConfigs() {
391
+ let claudeaiPromise;
392
+ if (isStrictMcpConfig || doesEnterpriseMcpConfigExist()) {
393
+ claudeaiPromise = Promise.resolve({});
394
+ } else {
395
+ clearClaudeAIMcpConfigsCache();
396
+ claudeaiPromise = fetchClaudeAIMcpConfigsIfEligible();
397
+ }
398
+ const { servers: claudeCodeConfigs, errors: mcpErrors } = isStrictMcpConfig ? { servers: {}, errors: [] } : await getClaudeCodeMcpConfigs(dynamicMcpConfig, claudeaiPromise);
399
+ if (cancelled)
400
+ return;
401
+ addErrorsToAppState(setAppState, mcpErrors);
402
+ const configs = { ...claudeCodeConfigs, ...dynamicMcpConfig };
403
+ const enabledConfigs = Object.fromEntries(Object.entries(configs).filter(([name]) => !isMcpServerDisabled(name)));
404
+ getMcpToolsCommandsAndResources(onConnectionAttempt, enabledConfigs).catch((error) => {
405
+ logMCPError("useManageMcpConnections", `Failed to get MCP resources: ${errorMessage(error)}`);
406
+ });
407
+ let claudeaiConfigs = {};
408
+ if (!isStrictMcpConfig) {
409
+ claudeaiConfigs = filterMcpServersByPolicy(await claudeaiPromise).allowed;
410
+ if (cancelled)
411
+ return;
412
+ if (Object.keys(claudeaiConfigs).length > 0) {
413
+ const { servers: dedupedClaudeAi } = dedupClaudeAiMcpServers(claudeaiConfigs, configs);
414
+ claudeaiConfigs = dedupedClaudeAi;
415
+ }
416
+ if (Object.keys(claudeaiConfigs).length > 0) {
417
+ setAppState((prevState) => {
418
+ const existingServerNames = new Set(prevState.mcp.clients.map((c) => c.name));
419
+ const newClients = Object.entries(claudeaiConfigs).filter(([name]) => !existingServerNames.has(name)).map(([name, config]) => ({
420
+ name,
421
+ type: isMcpServerDisabled(name) ? "disabled" : "pending",
422
+ config
423
+ }));
424
+ if (newClients.length === 0)
425
+ return prevState;
426
+ return {
427
+ ...prevState,
428
+ mcp: {
429
+ ...prevState.mcp,
430
+ clients: [...prevState.mcp.clients, ...newClients]
431
+ }
432
+ };
433
+ });
434
+ const enabledClaudeaiConfigs = Object.fromEntries(Object.entries(claudeaiConfigs).filter(([name]) => !isMcpServerDisabled(name)));
435
+ getMcpToolsCommandsAndResources(onConnectionAttempt, enabledClaudeaiConfigs).catch((error) => {
436
+ logMCPError("useManageMcpConnections", `Failed to get claude.ai MCP resources: ${errorMessage(error)}`);
437
+ });
438
+ }
439
+ }
440
+ const allConfigs = { ...configs, ...claudeaiConfigs };
441
+ const counts = {
442
+ enterprise: 0,
443
+ global: 0,
444
+ project: 0,
445
+ user: 0,
446
+ plugin: 0,
447
+ claudeai: 0
448
+ };
449
+ const stdioCommands = [];
450
+ for (const [name, serverConfig] of Object.entries(allConfigs)) {
451
+ if (serverConfig.scope === "enterprise")
452
+ counts.enterprise++;
453
+ else if (serverConfig.scope === "user")
454
+ counts.global++;
455
+ else if (serverConfig.scope === "project")
456
+ counts.project++;
457
+ else if (serverConfig.scope === "local")
458
+ counts.user++;
459
+ else if (serverConfig.scope === "dynamic")
460
+ counts.plugin++;
461
+ else if (serverConfig.scope === "claudeai")
462
+ counts.claudeai++;
463
+ if (process.env.USER_TYPE === "ant" && !isMcpServerDisabled(name) && (serverConfig.type === undefined || serverConfig.type === "stdio") && "command" in serverConfig) {
464
+ stdioCommands.push(basename(serverConfig.command));
465
+ }
466
+ }
467
+ logEvent("tengu_mcp_servers", {
468
+ ...counts,
469
+ ...process.env.USER_TYPE === "ant" && stdioCommands.length > 0 ? {
470
+ stdio_commands: stdioCommands.sort().join(",")
471
+ } : {}
472
+ });
473
+ }
474
+ loadAndConnectMcpConfigs();
475
+ return () => {
476
+ cancelled = true;
477
+ };
478
+ }, [
479
+ isStrictMcpConfig,
480
+ dynamicMcpConfig,
481
+ onConnectionAttempt,
482
+ setAppState,
483
+ _authVersion,
484
+ sessionId,
485
+ _pluginReconnectKey
486
+ ]);
487
+ import_react.useEffect(() => {
488
+ const timers = reconnectTimersRef.current;
489
+ return () => {
490
+ for (const timer of timers.values()) {
491
+ clearTimeout(timer);
492
+ }
493
+ timers.clear();
494
+ if (flushTimerRef.current !== null) {
495
+ clearTimeout(flushTimerRef.current);
496
+ flushTimerRef.current = null;
497
+ flushPendingUpdates();
498
+ }
499
+ };
500
+ }, [flushPendingUpdates]);
501
+ const reconnectMcpServer = import_react.useCallback(async (serverName) => {
502
+ const client = store.getState().mcp.clients.find((c) => c.name === serverName);
503
+ if (!client) {
504
+ throw new Error(`MCP server ${serverName} not found`);
505
+ }
506
+ const existingTimer = reconnectTimersRef.current.get(serverName);
507
+ if (existingTimer) {
508
+ clearTimeout(existingTimer);
509
+ reconnectTimersRef.current.delete(serverName);
510
+ }
511
+ const result = await reconnectMcpServerImpl(serverName, client.config);
512
+ onConnectionAttempt(result);
513
+ return result;
514
+ }, [store, onConnectionAttempt]);
515
+ const toggleMcpServer = import_react.useCallback(async (serverName) => {
516
+ const client = store.getState().mcp.clients.find((c) => c.name === serverName);
517
+ if (!client) {
518
+ throw new Error(`MCP server ${serverName} not found`);
519
+ }
520
+ const isCurrentlyDisabled = client.type === "disabled";
521
+ if (!isCurrentlyDisabled) {
522
+ const existingTimer = reconnectTimersRef.current.get(serverName);
523
+ if (existingTimer) {
524
+ clearTimeout(existingTimer);
525
+ reconnectTimersRef.current.delete(serverName);
526
+ }
527
+ setMcpServerEnabled(serverName, false);
528
+ if (client.type === "connected") {
529
+ await clearServerCache(serverName, client.config);
530
+ }
531
+ updateServer({
532
+ name: serverName,
533
+ type: "disabled",
534
+ config: client.config
535
+ });
536
+ } else {
537
+ setMcpServerEnabled(serverName, true);
538
+ updateServer({
539
+ name: serverName,
540
+ type: "pending",
541
+ config: client.config
542
+ });
543
+ const result = await reconnectMcpServerImpl(serverName, client.config);
544
+ onConnectionAttempt(result);
545
+ }
546
+ }, [store, updateServer, onConnectionAttempt]);
547
+ return { reconnectMcpServer, toggleMcpServer };
548
+ }
549
+ function getTransportDisplayName(type) {
550
+ switch (type) {
551
+ case "http":
552
+ return "HTTP";
553
+ case "ws":
554
+ case "ws-ide":
555
+ return "WebSocket";
556
+ default:
557
+ return "SSE";
558
+ }
559
+ }
560
+ var import_react, clearSkillIndexCache = null, MAX_RECONNECT_ATTEMPTS = 5, INITIAL_BACKOFF_MS = 1000, MAX_BACKOFF_MS = 30000;
561
+ var init_useManageMCPConnections = __esm(() => {
562
+ init_state();
563
+ init_client();
564
+ init_types();
565
+ init_omit();
566
+ init_reject();
567
+ init_analytics();
568
+ init_config();
569
+ init_debug();
570
+ init_state();
571
+ init_notifications();
572
+ init_AppState();
573
+ init_errors();
574
+ init_log();
575
+ init_messageQueueManager();
576
+ init_channelNotification();
577
+ init_channelPermissions();
578
+ init_claudeai();
579
+ init_elicitationHandler();
580
+ init_mcpStringUtils();
581
+ init_utils();
582
+ import_react = __toESM(require_react(), 1);
583
+ });
584
+
585
+ // src/services/mcp/MCPConnectionManager.tsx
586
+ function useMcpReconnect() {
587
+ const context = import_react2.useContext(MCPConnectionContext);
588
+ if (!context) {
589
+ throw new Error("useMcpReconnect must be used within MCPConnectionManager");
590
+ }
591
+ return context.reconnectMcpServer;
592
+ }
593
+ function useMcpToggleEnabled() {
594
+ const context = import_react2.useContext(MCPConnectionContext);
595
+ if (!context) {
596
+ throw new Error("useMcpToggleEnabled must be used within MCPConnectionManager");
597
+ }
598
+ return context.toggleMcpServer;
599
+ }
600
+ function MCPConnectionManager({
601
+ children,
602
+ dynamicMcpConfig,
603
+ isStrictMcpConfig
604
+ }) {
605
+ const { reconnectMcpServer, toggleMcpServer } = useManageMCPConnections(dynamicMcpConfig, isStrictMcpConfig);
606
+ const value = import_react2.useMemo(() => ({ reconnectMcpServer, toggleMcpServer }), [reconnectMcpServer, toggleMcpServer]);
607
+ return /* @__PURE__ */ jsx_dev_runtime.jsxDEV(MCPConnectionContext.Provider, {
608
+ value,
609
+ children
610
+ }, undefined, false, undefined, this);
611
+ }
612
+ var import_react2, jsx_dev_runtime, MCPConnectionContext;
613
+ var init_MCPConnectionManager = __esm(() => {
614
+ init_useManageMCPConnections();
615
+ import_react2 = __toESM(require_react(), 1);
616
+ jsx_dev_runtime = __toESM(require_jsx_dev_runtime(), 1);
617
+ MCPConnectionContext = import_react2.createContext(null);
618
+ });
619
+
620
+ export { init_channelPermissions, useMcpReconnect, useMcpToggleEnabled, MCPConnectionManager, init_MCPConnectionManager };