@foxclicom/foxcli 2.1.89
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.
- package/README.md +398 -0
- package/bun.lock +2090 -0
- package/dist/chunk-003e621m.js +247 -0
- package/dist/chunk-04he5cyw.js +169 -0
- package/dist/chunk-05gpckd1.js +56 -0
- package/dist/chunk-06saje2v.js +39 -0
- package/dist/chunk-0731m51q.js +8 -0
- package/dist/chunk-098tvb6a.js +490 -0
- package/dist/chunk-0akzpfxc.js +117 -0
- package/dist/chunk-0dvq0q4g.js +780 -0
- package/dist/chunk-0e1xsncc.js +969 -0
- package/dist/chunk-0jp9x1pk.js +227 -0
- package/dist/chunk-0kep06pv.js +94 -0
- package/dist/chunk-0paqc2yw.js +15 -0
- package/dist/chunk-0vkfrmqm.js +690 -0
- package/dist/chunk-0xjaqda8.js +1124 -0
- package/dist/chunk-0yhfpays.js +116 -0
- package/dist/chunk-1141xmr4.js +8 -0
- package/dist/chunk-14cmss9n.js +655 -0
- package/dist/chunk-14nvhjrk.js +280 -0
- package/dist/chunk-15ah5bdg.js +17 -0
- package/dist/chunk-15tdhhv6.js +97 -0
- package/dist/chunk-1c5jv610.js +174 -0
- package/dist/chunk-1cbn5kxf.js +7 -0
- package/dist/chunk-1fvkskfd.js +432 -0
- package/dist/chunk-1fz2kv26.js +85 -0
- package/dist/chunk-1h2famwb.js +49 -0
- package/dist/chunk-1vwfagpe.js +83 -0
- package/dist/chunk-1xkekb9y.js +19 -0
- package/dist/chunk-1xy3xzsc.js +9300 -0
- package/dist/chunk-238g70xa.js +36 -0
- package/dist/chunk-24w0h1qk.js +339 -0
- package/dist/chunk-24z6z01r.js +40 -0
- package/dist/chunk-27xc1csx.js +104 -0
- package/dist/chunk-2a42s11t.js +412 -0
- package/dist/chunk-2eavn925.js +5011 -0
- package/dist/chunk-2eykm0j0.js +20 -0
- package/dist/chunk-2gzv8nrw.js +205 -0
- package/dist/chunk-2j3ydfmm.js +208 -0
- package/dist/chunk-2k995y2x.js +880 -0
- package/dist/chunk-2kg4d2c7.js +601 -0
- package/dist/chunk-2n877dxb.js +224 -0
- package/dist/chunk-2nayx6q1.js +63 -0
- package/dist/chunk-2t3vw4tx.js +22820 -0
- package/dist/chunk-2tw2ve8h.js +145 -0
- package/dist/chunk-2zsew1hs.js +73 -0
- package/dist/chunk-30rst83v.js +168 -0
- package/dist/chunk-341888tq.js +102 -0
- package/dist/chunk-348de018.js +26 -0
- package/dist/chunk-363p49h1.js +172719 -0
- package/dist/chunk-387ggdb2.js +195 -0
- package/dist/chunk-3be7ka25.js +56 -0
- package/dist/chunk-3c25bcsw.js +17 -0
- package/dist/chunk-3cyyhp8p.js +1151 -0
- package/dist/chunk-3gqdqmzb.js +75 -0
- package/dist/chunk-3h8a89gy.js +46 -0
- package/dist/chunk-3hk8rrwh.js +908 -0
- package/dist/chunk-3j33p45s.js +458 -0
- package/dist/chunk-3kc4kyk9.js +819 -0
- package/dist/chunk-3qv2jg1k.js +250 -0
- package/dist/chunk-3r24h7t6.js +113 -0
- package/dist/chunk-3sz3q1g8.js +104 -0
- package/dist/chunk-3w6s9m5w.js +16 -0
- package/dist/chunk-43251qh9.js +176 -0
- package/dist/chunk-44fpr6jq.js +434 -0
- package/dist/chunk-45kxdsp8.js +444 -0
- package/dist/chunk-466d7sxa.js +2057 -0
- package/dist/chunk-495d85x1.js +8066 -0
- package/dist/chunk-4cptw4qa.js +714 -0
- package/dist/chunk-4g3v8y12.js +23 -0
- package/dist/chunk-4jm600zv.js +13 -0
- package/dist/chunk-4t0ehd2z.js +89 -0
- package/dist/chunk-4x38ez67.js +128 -0
- package/dist/chunk-4zfkzkt6.js +37 -0
- package/dist/chunk-5157ex2s.js +104 -0
- package/dist/chunk-55wgxwa9.js +13877 -0
- package/dist/chunk-581q6r6y.js +229 -0
- package/dist/chunk-5bbsd66z.js +87 -0
- package/dist/chunk-5ctt9z6m.js +216 -0
- package/dist/chunk-5hfgayhz.js +153 -0
- package/dist/chunk-5kmnvh8h.js +112 -0
- package/dist/chunk-5tz6v8a5.js +5393 -0
- package/dist/chunk-5w5m8kq9.js +87 -0
- package/dist/chunk-5ztq67an.js +2333 -0
- package/dist/chunk-62gm8b8n.js +1322 -0
- package/dist/chunk-685fmb09.js +535 -0
- package/dist/chunk-6bd8brc4.js +48 -0
- package/dist/chunk-6dj5t602.js +341 -0
- package/dist/chunk-6f4sd6xc.js +127 -0
- package/dist/chunk-6gr3c3w9.js +378 -0
- package/dist/chunk-6n2qgm9v.js +8 -0
- package/dist/chunk-6ns6g3t9.js +1012 -0
- package/dist/chunk-6swe4a45.js +87 -0
- package/dist/chunk-6tq2v3rk.js +186 -0
- package/dist/chunk-6yf4a3pf.js +41 -0
- package/dist/chunk-7271bnfv.js +220 -0
- package/dist/chunk-72awppzy.js +16 -0
- package/dist/chunk-73gyam06.js +40 -0
- package/dist/chunk-73rpbt04.js +1947 -0
- package/dist/chunk-760252na.js +101 -0
- package/dist/chunk-7739pg2c.js +4261 -0
- package/dist/chunk-77g09znh.js +391 -0
- package/dist/chunk-781t965f.js +202 -0
- package/dist/chunk-7aw745vx.js +40175 -0
- package/dist/chunk-7br3j88y.js +141 -0
- package/dist/chunk-7fxy60g9.js +296 -0
- package/dist/chunk-7j3f4h1v.js +689 -0
- package/dist/chunk-7ke2txc2.js +309 -0
- package/dist/chunk-7m2nd8da.js +110 -0
- package/dist/chunk-7rpdgyyb.js +161 -0
- package/dist/chunk-7wj3b774.js +287 -0
- package/dist/chunk-7wm5s02e.js +216 -0
- package/dist/chunk-7yd6jttg.js +862 -0
- package/dist/chunk-7yfshpbj.js +1548 -0
- package/dist/chunk-7ymfj7m3.js +151 -0
- package/dist/chunk-7z8j9qfn.js +121 -0
- package/dist/chunk-7zccp7mt.js +91 -0
- package/dist/chunk-820bdvg4.js +184 -0
- package/dist/chunk-83hfzbx3.js +10 -0
- package/dist/chunk-88s6sc85.js +87 -0
- package/dist/chunk-8bedvdm1.js +32 -0
- package/dist/chunk-8gvdbsaq.js +22 -0
- package/dist/chunk-8hq5kk3y.js +44 -0
- package/dist/chunk-8nca9sgc.js +208 -0
- package/dist/chunk-8qeha1fz.js +103 -0
- package/dist/chunk-8qjtqhrr.js +165 -0
- package/dist/chunk-8tmegdjp.js +113 -0
- package/dist/chunk-8tnsngw2.js +31 -0
- package/dist/chunk-8twg4emd.js +71 -0
- package/dist/chunk-8vcyvvad.js +348 -0
- package/dist/chunk-8w3etwh3.js +601 -0
- package/dist/chunk-8y12jxg8.js +10 -0
- package/dist/chunk-8ymf4e6z.js +48 -0
- package/dist/chunk-90wp6wez.js +10510 -0
- package/dist/chunk-91awdvpf.js +61 -0
- package/dist/chunk-977kqw0c.js +466 -0
- package/dist/chunk-9gbamk79.js +93 -0
- package/dist/chunk-9s8v3j7m.js +38 -0
- package/dist/chunk-9xezt4wd.js +54 -0
- package/dist/chunk-9xzebfy5.js +671 -0
- package/dist/chunk-a8ejc632.js +3094 -0
- package/dist/chunk-a9ra6h3p.js +219 -0
- package/dist/chunk-a9vdeb6y.js +258 -0
- package/dist/chunk-a9zh40sj.js +48 -0
- package/dist/chunk-aaef8dpx.js +100 -0
- package/dist/chunk-aapmv7dy.js +44 -0
- package/dist/chunk-adgm4w5w.js +212 -0
- package/dist/chunk-ag0gc3th.js +88 -0
- package/dist/chunk-ah0w9kp8.js +173 -0
- package/dist/chunk-b4wg70y1.js +54 -0
- package/dist/chunk-b90bgrf7.js +24 -0
- package/dist/chunk-be5g3kd0.js +164 -0
- package/dist/chunk-bh8acr81.js +500 -0
- package/dist/chunk-bjqw6798.js +328 -0
- package/dist/chunk-bm1qb16p.js +17 -0
- package/dist/chunk-bqfnp99q.js +477 -0
- package/dist/chunk-bvx2gazj.js +304 -0
- package/dist/chunk-bwq5zxwv.js +306 -0
- package/dist/chunk-byf2zkne.js +524 -0
- package/dist/chunk-c0edra3v.js +437 -0
- package/dist/chunk-c0tfwbd2.js +723 -0
- package/dist/chunk-cbd6nwrj.js +111 -0
- package/dist/chunk-cc15x0zt.js +154 -0
- package/dist/chunk-cd1aese9.js +20 -0
- package/dist/chunk-cdz5yb0r.js +57 -0
- package/dist/chunk-cf5bj9j5.js +93 -0
- package/dist/chunk-cfv996bs.js +22 -0
- package/dist/chunk-cgfdkzhb.js +12 -0
- package/dist/chunk-cnkgrwpf.js +87 -0
- package/dist/chunk-cr6q93s5.js +42 -0
- package/dist/chunk-cspg0r9n.js +584 -0
- package/dist/chunk-ctw5jwcd.js +213 -0
- package/dist/chunk-cvge4pvp.js +122 -0
- package/dist/chunk-d18z9pna.js +106 -0
- package/dist/chunk-d1cfb0sj.js +98 -0
- package/dist/chunk-d1tp6sk7.js +90 -0
- package/dist/chunk-d3e1v3sq.js +344 -0
- package/dist/chunk-d7j0zted.js +114 -0
- package/dist/chunk-d7zmg667.js +192 -0
- package/dist/chunk-ddvhht3h.js +695 -0
- package/dist/chunk-dfeh5kmx.js +74 -0
- package/dist/chunk-dgjkb800.js +120 -0
- package/dist/chunk-dgqrcy74.js +48 -0
- package/dist/chunk-dmqarh6q.js +463 -0
- package/dist/chunk-dnh7jtpb.js +37 -0
- package/dist/chunk-dpeq9h27.js +128 -0
- package/dist/chunk-drgy3hh3.js +88 -0
- package/dist/chunk-dv1wfr85.js +6373 -0
- package/dist/chunk-dv2w9vpb.js +66 -0
- package/dist/chunk-dwfxgheg.js +270 -0
- package/dist/chunk-e3g8q4cn.js +1646 -0
- package/dist/chunk-e5pntxye.js +37 -0
- package/dist/chunk-e6v9mqg8.js +281 -0
- package/dist/chunk-e7393td6.js +42 -0
- package/dist/chunk-ef8r68ej.js +120 -0
- package/dist/chunk-ehtwnxpg.js +1591 -0
- package/dist/chunk-emhask7n.js +373 -0
- package/dist/chunk-eq75ekjx.js +97 -0
- package/dist/chunk-eqp1rfft.js +17 -0
- package/dist/chunk-ewadzrm8.js +103 -0
- package/dist/chunk-f2mt6b5j.js +198 -0
- package/dist/chunk-f3d9gb71.js +333 -0
- package/dist/chunk-f5ma3nh5.js +3436 -0
- package/dist/chunk-f8bgh5qc.js +86 -0
- package/dist/chunk-fbgxj8g3.js +1585 -0
- package/dist/chunk-fbv4apne.js +51 -0
- package/dist/chunk-fdj47yp8.js +108 -0
- package/dist/chunk-fer10z2s.js +89 -0
- package/dist/chunk-ffewbr1v.js +642 -0
- package/dist/chunk-fpzax6rw.js +225 -0
- package/dist/chunk-fyc5fepv.js +10 -0
- package/dist/chunk-g0j0t6qk.js +26 -0
- package/dist/chunk-g1kkd3xm.js +130 -0
- package/dist/chunk-g2dr9kyp.js +90 -0
- package/dist/chunk-g338npwr.js +1061 -0
- package/dist/chunk-g3fcqsc1.js +998 -0
- package/dist/chunk-g3t0act8.js +8 -0
- package/dist/chunk-g4bng3yk.js +140 -0
- package/dist/chunk-gax0fcbx.js +182 -0
- package/dist/chunk-gegyrhqa.js +277 -0
- package/dist/chunk-gejs9q9d.js +542 -0
- package/dist/chunk-gqazdwgf.js +40764 -0
- package/dist/chunk-gtayyc80.js +28 -0
- package/dist/chunk-gyj242zr.js +20 -0
- package/dist/chunk-h0qngp9w.js +157 -0
- package/dist/chunk-h0rbjg6x.js +55 -0
- package/dist/chunk-h4qybe96.js +531 -0
- package/dist/chunk-h8vttfbt.js +82 -0
- package/dist/chunk-hakdhagh.js +16606 -0
- package/dist/chunk-hb22hd9m.js +373 -0
- package/dist/chunk-hbjbyb2r.js +120 -0
- package/dist/chunk-henh8e8f.js +69 -0
- package/dist/chunk-heqbt4wp.js +43 -0
- package/dist/chunk-hf5v5wd0.js +2833 -0
- package/dist/chunk-hfzj1m07.js +118 -0
- package/dist/chunk-hh7cmy4k.js +20 -0
- package/dist/chunk-hhwpdnst.js +173 -0
- package/dist/chunk-hjhc4cpt.js +69 -0
- package/dist/chunk-hk9xz7gk.js +118 -0
- package/dist/chunk-hqmz36b3.js +552 -0
- package/dist/chunk-hrzerbfw.js +1299 -0
- package/dist/chunk-hvha3949.js +229 -0
- package/dist/chunk-hw9yapav.js +644 -0
- package/dist/chunk-hx2tr4ep.js +7189 -0
- package/dist/chunk-hz2e6s2n.js +384 -0
- package/dist/chunk-hzhe8ygc.js +547 -0
- package/dist/chunk-j2k4p94p.js +55 -0
- package/dist/chunk-j3a4p81y.js +184 -0
- package/dist/chunk-j5vj6wem.js +241 -0
- package/dist/chunk-j64ga6ta.js +8035 -0
- package/dist/chunk-j98bzjtw.js +21933 -0
- package/dist/chunk-jafes477.js +29 -0
- package/dist/chunk-jce5r25x.js +18 -0
- package/dist/chunk-jchz3ws1.js +756 -0
- package/dist/chunk-jd32zbps.js +15 -0
- package/dist/chunk-jdgeec04.js +4249 -0
- package/dist/chunk-jhzdk454.js +278 -0
- package/dist/chunk-jjxb16v1.js +691 -0
- package/dist/chunk-jmc0vfad.js +275 -0
- package/dist/chunk-jnhkref0.js +30 -0
- package/dist/chunk-jp85zv57.js +3198 -0
- package/dist/chunk-jx817w05.js +11 -0
- package/dist/chunk-jxgm95zx.js +802 -0
- package/dist/chunk-jzmz18nn.js +65 -0
- package/dist/chunk-k0p9w03v.js +4957 -0
- package/dist/chunk-kjv7vnsy.js +81 -0
- package/dist/chunk-kkt7vkyc.js +273 -0
- package/dist/chunk-ks57hmrt.js +98 -0
- package/dist/chunk-ksq785ca.js +109 -0
- package/dist/chunk-kwekc97v.js +18 -0
- package/dist/chunk-m06q12hg.js +61 -0
- package/dist/chunk-m1g8ywfk.js +84 -0
- package/dist/chunk-m42g016x.js +70 -0
- package/dist/chunk-m6m4jdbj.js +1918 -0
- package/dist/chunk-ma0h0h17.js +471 -0
- package/dist/chunk-mak6ckds.js +102 -0
- package/dist/chunk-mceesnzr.js +438 -0
- package/dist/chunk-mhs6c4fp.js +765 -0
- package/dist/chunk-mm7rd0jd.js +1578 -0
- package/dist/chunk-mt25echc.js +6157 -0
- package/dist/chunk-mv8hngk2.js +86 -0
- package/dist/chunk-mxn9djv2.js +152 -0
- package/dist/chunk-n0qaeaa5.js +256 -0
- package/dist/chunk-n7ttdtk0.js +641 -0
- package/dist/chunk-n83rnk8h.js +62 -0
- package/dist/chunk-n89dwhkm.js +69 -0
- package/dist/chunk-nj29pqp3.js +155 -0
- package/dist/chunk-njchshm5.js +99 -0
- package/dist/chunk-nka1g8f4.js +773 -0
- package/dist/chunk-npj6g78n.js +8956 -0
- package/dist/chunk-nq0fxyxh.js +752 -0
- package/dist/chunk-nrdckp85.js +809 -0
- package/dist/chunk-nswqqqdd.js +26840 -0
- package/dist/chunk-nt837qt9.js +21 -0
- package/dist/chunk-ntfnwa7w.js +328 -0
- package/dist/chunk-nxsh6de2.js +1711 -0
- package/dist/chunk-ny641a2t.js +96 -0
- package/dist/chunk-nymbd7tw.js +825 -0
- package/dist/chunk-nz9wqm63.js +262 -0
- package/dist/chunk-p2816w9z.js +1486 -0
- package/dist/chunk-p2d5nh3g.js +342 -0
- package/dist/chunk-p3c8dz92.js +3442 -0
- package/dist/chunk-p3m2gn04.js +1551 -0
- package/dist/chunk-p7g7pf3f.js +336 -0
- package/dist/chunk-p82dmx79.js +519 -0
- package/dist/chunk-p8t1v3qw.js +713 -0
- package/dist/chunk-pg6ke51s.js +60 -0
- package/dist/chunk-phc72ftz.js +61 -0
- package/dist/chunk-pm51hqt3.js +1863 -0
- package/dist/chunk-pngv409n.js +253 -0
- package/dist/chunk-pp83rz76.js +27 -0
- package/dist/chunk-pqcemkwx.js +640 -0
- package/dist/chunk-pqqf5gss.js +4521 -0
- package/dist/chunk-pqw1y4f8.js +524 -0
- package/dist/chunk-ps49ymvj.js +43 -0
- package/dist/chunk-pwwa7s62.js +11 -0
- package/dist/chunk-pxjqgrdk.js +59 -0
- package/dist/chunk-q1jvyh4z.js +41 -0
- package/dist/chunk-q25bjaev.js +15 -0
- package/dist/chunk-q6av622g.js +38 -0
- package/dist/chunk-qmvk0wr6.js +787 -0
- package/dist/chunk-qnfx3qtx.js +617 -0
- package/dist/chunk-qp2qdcda.js +100 -0
- package/dist/chunk-qpg0bm1g.js +441 -0
- package/dist/chunk-qqfa0dqg.js +2343 -0
- package/dist/chunk-qtvek1gy.js +466 -0
- package/dist/chunk-qz2x630m.js +49145 -0
- package/dist/chunk-r4vk0x64.js +674 -0
- package/dist/chunk-r4z1107v.js +88 -0
- package/dist/chunk-r66hz8j6.js +34 -0
- package/dist/chunk-r6b58y3x.js +17 -0
- package/dist/chunk-rhftek9r.js +156 -0
- package/dist/chunk-rn0v1hk8.js +34 -0
- package/dist/chunk-rq2ry4xa.js +648 -0
- package/dist/chunk-rqwnwe7k.js +87 -0
- package/dist/chunk-rs45skes.js +123 -0
- package/dist/chunk-rvqtbt9h.js +726 -0
- package/dist/chunk-rzq6ct1h.js +1095 -0
- package/dist/chunk-s3pzvdss.js +50 -0
- package/dist/chunk-s5cexe2j.js +10476 -0
- package/dist/chunk-s79s6rms.js +40 -0
- package/dist/chunk-sd36yzx8.js +954 -0
- package/dist/chunk-sdj9b9wh.js +782 -0
- package/dist/chunk-seaswa9a.js +745 -0
- package/dist/chunk-sgy4bnyd.js +496 -0
- package/dist/chunk-sjqtqj35.js +28 -0
- package/dist/chunk-sk5gyvdj.js +127 -0
- package/dist/chunk-skctedsv.js +15679 -0
- package/dist/chunk-spqaamnc.js +63 -0
- package/dist/chunk-szj5wvdy.js +28 -0
- package/dist/chunk-t0rgmccj.js +39 -0
- package/dist/chunk-t0zcygwt.js +63 -0
- package/dist/chunk-t1pqzjdb.js +400 -0
- package/dist/chunk-t20kqvm0.js +1493 -0
- package/dist/chunk-t60mq3jn.js +421 -0
- package/dist/chunk-t9ak7d0c.js +86 -0
- package/dist/chunk-tantc5sm.js +97 -0
- package/dist/chunk-tgvzn3q1.js +98 -0
- package/dist/chunk-tjaqa99q.js +125 -0
- package/dist/chunk-tka1kh41.js +32 -0
- package/dist/chunk-tm70zjhw.js +95 -0
- package/dist/chunk-ts2p6bv1.js +224 -0
- package/dist/chunk-ttk5dzz8.js +25 -0
- package/dist/chunk-ty0xmdf9.js +142 -0
- package/dist/chunk-v0j5s5w9.js +113 -0
- package/dist/chunk-v1kzp02e.js +785 -0
- package/dist/chunk-v1mgv1et.js +15 -0
- package/dist/chunk-v1vqpm16.js +151 -0
- package/dist/chunk-v2drem4p.js +3035 -0
- package/dist/chunk-v399mzxk.js +58 -0
- package/dist/chunk-v78fj8by.js +145 -0
- package/dist/chunk-v7yayd0e.js +102 -0
- package/dist/chunk-v9smspw2.js +4301 -0
- package/dist/chunk-vdxvgw28.js +5802 -0
- package/dist/chunk-vech0vdw.js +258 -0
- package/dist/chunk-vest0y6x.js +3830 -0
- package/dist/chunk-vf5sd1nq.js +12 -0
- package/dist/chunk-vfwbg2m3.js +3351 -0
- package/dist/chunk-vhpesgs8.js +193 -0
- package/dist/chunk-vjbr8wqg.js +849 -0
- package/dist/chunk-vratq94g.js +349 -0
- package/dist/chunk-vtchbjt5.js +284 -0
- package/dist/chunk-vw60ew4s.js +338 -0
- package/dist/chunk-vyc0rjyx.js +31 -0
- package/dist/chunk-vyjeh50y.js +2149 -0
- package/dist/chunk-w2z5pqd3.js +336 -0
- package/dist/chunk-w34c4pn6.js +417 -0
- package/dist/chunk-w7wgpqcp.js +157 -0
- package/dist/chunk-w9k8zntt.js +1391 -0
- package/dist/chunk-wb4p3ft4.js +130 -0
- package/dist/chunk-wejsw2n0.js +104 -0
- package/dist/chunk-wfz0qffj.js +3939 -0
- package/dist/chunk-wj4wyfpy.js +716 -0
- package/dist/chunk-ws1jdhta.js +315 -0
- package/dist/chunk-wsgyhhg2.js +91 -0
- package/dist/chunk-wspkwgra.js +1315 -0
- package/dist/chunk-wty0nm0a.js +749 -0
- package/dist/chunk-wzfbxdwn.js +71 -0
- package/dist/chunk-wzpdet3m.js +843 -0
- package/dist/chunk-x14dq3v1.js +722 -0
- package/dist/chunk-x7ynqhrv.js +266 -0
- package/dist/chunk-x8b7vft8.js +132 -0
- package/dist/chunk-xfft987g.js +47 -0
- package/dist/chunk-xjz3de9f.js +654 -0
- package/dist/chunk-xms0cc06.js +84 -0
- package/dist/chunk-xn20ta17.js +107 -0
- package/dist/chunk-xsq9ae7x.js +90 -0
- package/dist/chunk-xszk7n10.js +14358 -0
- package/dist/chunk-xvqpc205.js +159 -0
- package/dist/chunk-xx3qkvyg.js +606 -0
- package/dist/chunk-y1784krc.js +19 -0
- package/dist/chunk-y47cg3kz.js +42 -0
- package/dist/chunk-y5mfcqyc.js +254 -0
- package/dist/chunk-yhnzwtby.js +4389 -0
- package/dist/chunk-yj6dn49f.js +476 -0
- package/dist/chunk-yjkfkzxy.js +266 -0
- package/dist/chunk-yq0a6dk8.js +265 -0
- package/dist/chunk-yqs6zhes.js +6105 -0
- package/dist/chunk-ytx08xk9.js +87 -0
- package/dist/chunk-ywxd4qw4.js +22 -0
- package/dist/chunk-yxnffetf.js +6956 -0
- package/dist/chunk-z2dp53wn.js +17 -0
- package/dist/chunk-z3hcj5gd.js +372 -0
- package/dist/chunk-z3j9hdd8.js +32 -0
- package/dist/chunk-z57a5q6t.js +2641 -0
- package/dist/chunk-z5bg3c3b.js +54 -0
- package/dist/chunk-z74kky8g.js +160 -0
- package/dist/chunk-z9w0ffmw.js +99 -0
- package/dist/chunk-zhk3aav8.js +79 -0
- package/dist/chunk-zk2wsm7d.js +15 -0
- package/dist/chunk-zp0509kx.js +563 -0
- package/dist/chunk-zsfxha74.js +17655 -0
- package/dist/chunk-zw77xgjd.js +38 -0
- package/dist/chunk-zwps6dt3.js +83 -0
- package/dist/chunk-zx4s70cq.js +298 -0
- package/dist/chunk-zxse7h5w.js +71 -0
- package/dist/chunk-zz21rvr7.js +27 -0
- package/dist/cli.js +81 -0
- package/package.json +182 -0
- package/sdk-tools.d.ts +2719 -0
- package/vendor/audio-capture/arm64-darwin/audio-capture.node +0 -0
- package/vendor/audio-capture/arm64-linux/audio-capture.node +0 -0
- package/vendor/audio-capture/arm64-win32/audio-capture.node +0 -0
- package/vendor/audio-capture/x64-darwin/audio-capture.node +0 -0
- package/vendor/audio-capture/x64-linux/audio-capture.node +0 -0
- package/vendor/audio-capture/x64-win32/audio-capture.node +0 -0
- package/vendor/ripgrep/COPYING +3 -0
- package/vendor/ripgrep/arm64-darwin/rg +0 -0
- package/vendor/ripgrep/arm64-linux/rg +0 -0
- package/vendor/ripgrep/arm64-win32/rg.exe +0 -0
- package/vendor/ripgrep/x64-darwin/rg +0 -0
- package/vendor/ripgrep/x64-linux/rg +0 -0
- package/vendor/ripgrep/x64-win32/rg.exe +0 -0
|
@@ -0,0 +1,140 @@
|
|
|
1
|
+
// @bun
|
|
2
|
+
import {
|
|
3
|
+
clearAllCaches,
|
|
4
|
+
clearPluginCacheExclusions,
|
|
5
|
+
getAgentDefinitionsWithOverrides,
|
|
6
|
+
getPluginCommands,
|
|
7
|
+
init_cacheUtils,
|
|
8
|
+
init_loadAgentsDir,
|
|
9
|
+
init_loadPluginCommands,
|
|
10
|
+
init_loadPluginHooks,
|
|
11
|
+
init_lspPluginIntegration,
|
|
12
|
+
init_manager,
|
|
13
|
+
init_mcpPluginIntegration,
|
|
14
|
+
init_orphanedPluginFilter,
|
|
15
|
+
init_pluginLoader,
|
|
16
|
+
loadAllPlugins,
|
|
17
|
+
loadPluginHooks,
|
|
18
|
+
loadPluginLspServers,
|
|
19
|
+
loadPluginMcpServers,
|
|
20
|
+
reinitializeLspServerManager
|
|
21
|
+
} from "./chunk-363p49h1.js";
|
|
22
|
+
import {
|
|
23
|
+
init_log,
|
|
24
|
+
logError
|
|
25
|
+
} from "./chunk-p7g7pf3f.js";
|
|
26
|
+
import {
|
|
27
|
+
errorMessage,
|
|
28
|
+
init_debug,
|
|
29
|
+
init_errors,
|
|
30
|
+
logForDebugging
|
|
31
|
+
} from "./chunk-nxsh6de2.js";
|
|
32
|
+
import {
|
|
33
|
+
getOriginalCwd,
|
|
34
|
+
init_state
|
|
35
|
+
} from "./chunk-qqfa0dqg.js";
|
|
36
|
+
import {
|
|
37
|
+
__esm
|
|
38
|
+
} from "./chunk-qp2qdcda.js";
|
|
39
|
+
|
|
40
|
+
// src/utils/plugins/refresh.ts
|
|
41
|
+
async function refreshActivePlugins(setAppState) {
|
|
42
|
+
logForDebugging("refreshActivePlugins: clearing all plugin caches");
|
|
43
|
+
clearAllCaches();
|
|
44
|
+
clearPluginCacheExclusions();
|
|
45
|
+
const pluginResult = await loadAllPlugins();
|
|
46
|
+
const [pluginCommands, agentDefinitions] = await Promise.all([
|
|
47
|
+
getPluginCommands(),
|
|
48
|
+
getAgentDefinitionsWithOverrides(getOriginalCwd())
|
|
49
|
+
]);
|
|
50
|
+
const { enabled, disabled, errors } = pluginResult;
|
|
51
|
+
const [mcpCounts, lspCounts] = await Promise.all([
|
|
52
|
+
Promise.all(enabled.map(async (p) => {
|
|
53
|
+
if (p.mcpServers)
|
|
54
|
+
return Object.keys(p.mcpServers).length;
|
|
55
|
+
const servers = await loadPluginMcpServers(p, errors);
|
|
56
|
+
if (servers)
|
|
57
|
+
p.mcpServers = servers;
|
|
58
|
+
return servers ? Object.keys(servers).length : 0;
|
|
59
|
+
})),
|
|
60
|
+
Promise.all(enabled.map(async (p) => {
|
|
61
|
+
if (p.lspServers)
|
|
62
|
+
return Object.keys(p.lspServers).length;
|
|
63
|
+
const servers = await loadPluginLspServers(p, errors);
|
|
64
|
+
if (servers)
|
|
65
|
+
p.lspServers = servers;
|
|
66
|
+
return servers ? Object.keys(servers).length : 0;
|
|
67
|
+
}))
|
|
68
|
+
]);
|
|
69
|
+
const mcp_count = mcpCounts.reduce((sum, n) => sum + n, 0);
|
|
70
|
+
const lsp_count = lspCounts.reduce((sum, n) => sum + n, 0);
|
|
71
|
+
setAppState((prev) => ({
|
|
72
|
+
...prev,
|
|
73
|
+
plugins: {
|
|
74
|
+
...prev.plugins,
|
|
75
|
+
enabled,
|
|
76
|
+
disabled,
|
|
77
|
+
commands: pluginCommands,
|
|
78
|
+
errors: mergePluginErrors(prev.plugins.errors, errors),
|
|
79
|
+
needsRefresh: false
|
|
80
|
+
},
|
|
81
|
+
agentDefinitions,
|
|
82
|
+
mcp: {
|
|
83
|
+
...prev.mcp,
|
|
84
|
+
pluginReconnectKey: prev.mcp.pluginReconnectKey + 1
|
|
85
|
+
}
|
|
86
|
+
}));
|
|
87
|
+
reinitializeLspServerManager();
|
|
88
|
+
let hook_load_failed = false;
|
|
89
|
+
try {
|
|
90
|
+
await loadPluginHooks();
|
|
91
|
+
} catch (e) {
|
|
92
|
+
hook_load_failed = true;
|
|
93
|
+
logError(e);
|
|
94
|
+
logForDebugging(`refreshActivePlugins: loadPluginHooks failed: ${errorMessage(e)}`);
|
|
95
|
+
}
|
|
96
|
+
const hook_count = enabled.reduce((sum, p) => {
|
|
97
|
+
if (!p.hooksConfig)
|
|
98
|
+
return sum;
|
|
99
|
+
return sum + Object.values(p.hooksConfig).reduce((s, matchers) => s + (matchers?.reduce((h, m) => h + m.hooks.length, 0) ?? 0), 0);
|
|
100
|
+
}, 0);
|
|
101
|
+
logForDebugging(`refreshActivePlugins: ${enabled.length} enabled, ${pluginCommands.length} commands, ${agentDefinitions.allAgents.length} agents, ${hook_count} hooks, ${mcp_count} MCP, ${lsp_count} LSP`);
|
|
102
|
+
return {
|
|
103
|
+
enabled_count: enabled.length,
|
|
104
|
+
disabled_count: disabled.length,
|
|
105
|
+
command_count: pluginCommands.length,
|
|
106
|
+
agent_count: agentDefinitions.allAgents.length,
|
|
107
|
+
hook_count,
|
|
108
|
+
mcp_count,
|
|
109
|
+
lsp_count,
|
|
110
|
+
error_count: errors.length + (hook_load_failed ? 1 : 0),
|
|
111
|
+
agentDefinitions,
|
|
112
|
+
pluginCommands
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
function mergePluginErrors(existing, fresh) {
|
|
116
|
+
const preserved = existing.filter((e) => e.source === "lsp-manager" || e.source.startsWith("plugin:"));
|
|
117
|
+
const freshKeys = new Set(fresh.map(errorKey));
|
|
118
|
+
const deduped = preserved.filter((e) => !freshKeys.has(errorKey(e)));
|
|
119
|
+
return [...deduped, ...fresh];
|
|
120
|
+
}
|
|
121
|
+
function errorKey(e) {
|
|
122
|
+
return e.type === "generic-error" ? `generic-error:${e.source}:${e.error}` : `${e.type}:${e.source}`;
|
|
123
|
+
}
|
|
124
|
+
var init_refresh = __esm(() => {
|
|
125
|
+
init_state();
|
|
126
|
+
init_manager();
|
|
127
|
+
init_loadAgentsDir();
|
|
128
|
+
init_debug();
|
|
129
|
+
init_errors();
|
|
130
|
+
init_log();
|
|
131
|
+
init_cacheUtils();
|
|
132
|
+
init_loadPluginCommands();
|
|
133
|
+
init_loadPluginHooks();
|
|
134
|
+
init_lspPluginIntegration();
|
|
135
|
+
init_mcpPluginIntegration();
|
|
136
|
+
init_orphanedPluginFilter();
|
|
137
|
+
init_pluginLoader();
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
export { refreshActivePlugins, init_refresh };
|
|
@@ -0,0 +1,182 @@
|
|
|
1
|
+
// @bun
|
|
2
|
+
import {
|
|
3
|
+
init_path
|
|
4
|
+
} from "./chunk-ctw5jwcd.js";
|
|
5
|
+
import {
|
|
6
|
+
sanitizePath
|
|
7
|
+
} from "./chunk-vratq94g.js";
|
|
8
|
+
import {
|
|
9
|
+
createBufferedWriter,
|
|
10
|
+
getFsImplementation,
|
|
11
|
+
init_bufferedWriter,
|
|
12
|
+
init_cleanupRegistry,
|
|
13
|
+
init_debug,
|
|
14
|
+
init_fsOperations,
|
|
15
|
+
init_slowOperations,
|
|
16
|
+
jsonStringify,
|
|
17
|
+
logForDebugging,
|
|
18
|
+
registerCleanup
|
|
19
|
+
} from "./chunk-nxsh6de2.js";
|
|
20
|
+
import {
|
|
21
|
+
getClaudeConfigHomeDir,
|
|
22
|
+
init_envUtils,
|
|
23
|
+
isEnvTruthy
|
|
24
|
+
} from "./chunk-3r24h7t6.js";
|
|
25
|
+
import {
|
|
26
|
+
getOriginalCwd,
|
|
27
|
+
getSessionId,
|
|
28
|
+
init_state
|
|
29
|
+
} from "./chunk-qqfa0dqg.js";
|
|
30
|
+
|
|
31
|
+
// src/utils/asciicast.ts
|
|
32
|
+
init_state();
|
|
33
|
+
init_bufferedWriter();
|
|
34
|
+
init_cleanupRegistry();
|
|
35
|
+
init_debug();
|
|
36
|
+
init_envUtils();
|
|
37
|
+
init_fsOperations();
|
|
38
|
+
init_path();
|
|
39
|
+
init_slowOperations();
|
|
40
|
+
import { appendFile, rename } from "fs/promises";
|
|
41
|
+
import { basename, dirname, join } from "path";
|
|
42
|
+
var recordingState = {
|
|
43
|
+
filePath: null,
|
|
44
|
+
timestamp: 0
|
|
45
|
+
};
|
|
46
|
+
function getRecordFilePath() {
|
|
47
|
+
if (recordingState.filePath !== null) {
|
|
48
|
+
return recordingState.filePath;
|
|
49
|
+
}
|
|
50
|
+
if (process.env.USER_TYPE !== "ant") {
|
|
51
|
+
return null;
|
|
52
|
+
}
|
|
53
|
+
if (!isEnvTruthy(process.env.CLAUDE_CODE_TERMINAL_RECORDING)) {
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
const projectsDir = join(getClaudeConfigHomeDir(), "projects");
|
|
57
|
+
const projectDir = join(projectsDir, sanitizePath(getOriginalCwd()));
|
|
58
|
+
recordingState.timestamp = Date.now();
|
|
59
|
+
recordingState.filePath = join(projectDir, `${getSessionId()}-${recordingState.timestamp}.cast`);
|
|
60
|
+
return recordingState.filePath;
|
|
61
|
+
}
|
|
62
|
+
function _resetRecordingStateForTesting() {
|
|
63
|
+
recordingState.filePath = null;
|
|
64
|
+
recordingState.timestamp = 0;
|
|
65
|
+
}
|
|
66
|
+
function getSessionRecordingPaths() {
|
|
67
|
+
const sessionId = getSessionId();
|
|
68
|
+
const projectsDir = join(getClaudeConfigHomeDir(), "projects");
|
|
69
|
+
const projectDir = join(projectsDir, sanitizePath(getOriginalCwd()));
|
|
70
|
+
try {
|
|
71
|
+
const entries = getFsImplementation().readdirSync(projectDir);
|
|
72
|
+
const names = typeof entries[0] === "string" ? entries : entries.map((e) => e.name);
|
|
73
|
+
const files = names.filter((f) => f.startsWith(sessionId) && f.endsWith(".cast")).sort();
|
|
74
|
+
return files.map((f) => join(projectDir, f));
|
|
75
|
+
} catch {
|
|
76
|
+
return [];
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
async function renameRecordingForSession() {
|
|
80
|
+
const oldPath = recordingState.filePath;
|
|
81
|
+
if (!oldPath || recordingState.timestamp === 0) {
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
const projectsDir = join(getClaudeConfigHomeDir(), "projects");
|
|
85
|
+
const projectDir = join(projectsDir, sanitizePath(getOriginalCwd()));
|
|
86
|
+
const newPath = join(projectDir, `${getSessionId()}-${recordingState.timestamp}.cast`);
|
|
87
|
+
if (oldPath === newPath) {
|
|
88
|
+
return;
|
|
89
|
+
}
|
|
90
|
+
await recorder?.flush();
|
|
91
|
+
const oldName = basename(oldPath);
|
|
92
|
+
const newName = basename(newPath);
|
|
93
|
+
try {
|
|
94
|
+
await rename(oldPath, newPath);
|
|
95
|
+
recordingState.filePath = newPath;
|
|
96
|
+
logForDebugging(`[asciicast] Renamed recording: ${oldName} \u2192 ${newName}`);
|
|
97
|
+
} catch {
|
|
98
|
+
logForDebugging(`[asciicast] Failed to rename recording from ${oldName} to ${newName}`);
|
|
99
|
+
}
|
|
100
|
+
}
|
|
101
|
+
var recorder = null;
|
|
102
|
+
function getTerminalSize() {
|
|
103
|
+
const cols = process.stdout.columns || 80;
|
|
104
|
+
const rows = process.stdout.rows || 24;
|
|
105
|
+
return { cols, rows };
|
|
106
|
+
}
|
|
107
|
+
async function flushAsciicastRecorder() {
|
|
108
|
+
await recorder?.flush();
|
|
109
|
+
}
|
|
110
|
+
function installAsciicastRecorder() {
|
|
111
|
+
const filePath = getRecordFilePath();
|
|
112
|
+
if (!filePath) {
|
|
113
|
+
return;
|
|
114
|
+
}
|
|
115
|
+
const { cols, rows } = getTerminalSize();
|
|
116
|
+
const startTime = performance.now();
|
|
117
|
+
const header = jsonStringify({
|
|
118
|
+
version: 2,
|
|
119
|
+
width: cols,
|
|
120
|
+
height: rows,
|
|
121
|
+
timestamp: Math.floor(Date.now() / 1000),
|
|
122
|
+
env: {
|
|
123
|
+
SHELL: process.env.SHELL || "",
|
|
124
|
+
TERM: process.env.TERM || ""
|
|
125
|
+
}
|
|
126
|
+
});
|
|
127
|
+
try {
|
|
128
|
+
getFsImplementation().mkdirSync(dirname(filePath));
|
|
129
|
+
} catch {}
|
|
130
|
+
getFsImplementation().appendFileSync(filePath, header + `
|
|
131
|
+
`, { mode: 384 });
|
|
132
|
+
let pendingWrite = Promise.resolve();
|
|
133
|
+
const writer = createBufferedWriter({
|
|
134
|
+
writeFn(content) {
|
|
135
|
+
const currentPath = recordingState.filePath;
|
|
136
|
+
if (!currentPath) {
|
|
137
|
+
return;
|
|
138
|
+
}
|
|
139
|
+
pendingWrite = pendingWrite.then(() => appendFile(currentPath, content)).catch(() => {});
|
|
140
|
+
},
|
|
141
|
+
flushIntervalMs: 500,
|
|
142
|
+
maxBufferSize: 50,
|
|
143
|
+
maxBufferBytes: 10 * 1024 * 1024
|
|
144
|
+
});
|
|
145
|
+
const originalWrite = process.stdout.write.bind(process.stdout);
|
|
146
|
+
process.stdout.write = function(chunk, encodingOrCb, cb) {
|
|
147
|
+
const elapsed = (performance.now() - startTime) / 1000;
|
|
148
|
+
const text = typeof chunk === "string" ? chunk : Buffer.from(chunk).toString("utf-8");
|
|
149
|
+
writer.write(jsonStringify([elapsed, "o", text]) + `
|
|
150
|
+
`);
|
|
151
|
+
if (typeof encodingOrCb === "function") {
|
|
152
|
+
return originalWrite(chunk, encodingOrCb);
|
|
153
|
+
}
|
|
154
|
+
return originalWrite(chunk, encodingOrCb, cb);
|
|
155
|
+
};
|
|
156
|
+
function onResize() {
|
|
157
|
+
const elapsed = (performance.now() - startTime) / 1000;
|
|
158
|
+
const { cols: newCols, rows: newRows } = getTerminalSize();
|
|
159
|
+
writer.write(jsonStringify([elapsed, "r", `${newCols}x${newRows}`]) + `
|
|
160
|
+
`);
|
|
161
|
+
}
|
|
162
|
+
process.stdout.on("resize", onResize);
|
|
163
|
+
recorder = {
|
|
164
|
+
async flush() {
|
|
165
|
+
writer.flush();
|
|
166
|
+
await pendingWrite;
|
|
167
|
+
},
|
|
168
|
+
async dispose() {
|
|
169
|
+
writer.dispose();
|
|
170
|
+
await pendingWrite;
|
|
171
|
+
process.stdout.removeListener("resize", onResize);
|
|
172
|
+
process.stdout.write = originalWrite;
|
|
173
|
+
}
|
|
174
|
+
};
|
|
175
|
+
registerCleanup(async () => {
|
|
176
|
+
await recorder?.dispose();
|
|
177
|
+
recorder = null;
|
|
178
|
+
});
|
|
179
|
+
logForDebugging(`[asciicast] Recording to ${filePath}`);
|
|
180
|
+
}
|
|
181
|
+
|
|
182
|
+
export { getRecordFilePath, _resetRecordingStateForTesting, getSessionRecordingPaths, renameRecordingForSession, flushAsciicastRecorder, installAsciicastRecorder };
|
|
@@ -0,0 +1,277 @@
|
|
|
1
|
+
// @bun
|
|
2
|
+
import {
|
|
3
|
+
normalizeControlMessageKeys
|
|
4
|
+
} from "./chunk-nt837qt9.js";
|
|
5
|
+
import {
|
|
6
|
+
EMPTY_USAGE,
|
|
7
|
+
init_emptyUsage
|
|
8
|
+
} from "./chunk-2n877dxb.js";
|
|
9
|
+
import {
|
|
10
|
+
init_analytics,
|
|
11
|
+
logEvent
|
|
12
|
+
} from "./chunk-h0rbjg6x.js";
|
|
13
|
+
import {
|
|
14
|
+
init_displayTags,
|
|
15
|
+
stripDisplayTagsAllowEmpty
|
|
16
|
+
} from "./chunk-p7g7pf3f.js";
|
|
17
|
+
import {
|
|
18
|
+
errorMessage,
|
|
19
|
+
init_debug,
|
|
20
|
+
init_errors,
|
|
21
|
+
init_slowOperations,
|
|
22
|
+
jsonParse,
|
|
23
|
+
logForDebugging
|
|
24
|
+
} from "./chunk-nxsh6de2.js";
|
|
25
|
+
|
|
26
|
+
// src/bridge/bridgeMessaging.ts
|
|
27
|
+
init_analytics();
|
|
28
|
+
init_emptyUsage();
|
|
29
|
+
import { randomUUID } from "crypto";
|
|
30
|
+
init_debug();
|
|
31
|
+
init_displayTags();
|
|
32
|
+
init_errors();
|
|
33
|
+
init_slowOperations();
|
|
34
|
+
function isSDKMessage(value) {
|
|
35
|
+
return value !== null && typeof value === "object" && "type" in value && typeof value.type === "string";
|
|
36
|
+
}
|
|
37
|
+
function isSDKControlResponse(value) {
|
|
38
|
+
return value !== null && typeof value === "object" && "type" in value && value.type === "control_response" && "response" in value;
|
|
39
|
+
}
|
|
40
|
+
function isSDKControlRequest(value) {
|
|
41
|
+
return value !== null && typeof value === "object" && "type" in value && value.type === "control_request" && "request_id" in value && "request" in value;
|
|
42
|
+
}
|
|
43
|
+
function isEligibleBridgeMessage(m) {
|
|
44
|
+
if ((m.type === "user" || m.type === "assistant") && m.isVirtual) {
|
|
45
|
+
return false;
|
|
46
|
+
}
|
|
47
|
+
return m.type === "user" || m.type === "assistant" || m.type === "system" && m.subtype === "local_command";
|
|
48
|
+
}
|
|
49
|
+
function extractTitleText(m) {
|
|
50
|
+
if (m.type !== "user" || m.isMeta || m.toolUseResult || m.isCompactSummary)
|
|
51
|
+
return;
|
|
52
|
+
if (m.origin && m.origin.kind !== "human")
|
|
53
|
+
return;
|
|
54
|
+
const content = m.message.content;
|
|
55
|
+
let raw;
|
|
56
|
+
if (typeof content === "string") {
|
|
57
|
+
raw = content;
|
|
58
|
+
} else {
|
|
59
|
+
for (const block of content) {
|
|
60
|
+
if (block.type === "text") {
|
|
61
|
+
raw = block.text;
|
|
62
|
+
break;
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
if (!raw)
|
|
67
|
+
return;
|
|
68
|
+
const clean = stripDisplayTagsAllowEmpty(raw);
|
|
69
|
+
return clean || undefined;
|
|
70
|
+
}
|
|
71
|
+
function handleIngressMessage(data, recentPostedUUIDs, recentInboundUUIDs, onInboundMessage, onPermissionResponse, onControlRequest) {
|
|
72
|
+
try {
|
|
73
|
+
const parsed = normalizeControlMessageKeys(jsonParse(data));
|
|
74
|
+
if (isSDKControlResponse(parsed)) {
|
|
75
|
+
logForDebugging("[bridge:repl] Ingress message type=control_response");
|
|
76
|
+
onPermissionResponse?.(parsed);
|
|
77
|
+
return;
|
|
78
|
+
}
|
|
79
|
+
if (isSDKControlRequest(parsed)) {
|
|
80
|
+
logForDebugging(`[bridge:repl] Inbound control_request subtype=${parsed.request.subtype}`);
|
|
81
|
+
onControlRequest?.(parsed);
|
|
82
|
+
return;
|
|
83
|
+
}
|
|
84
|
+
if (!isSDKMessage(parsed))
|
|
85
|
+
return;
|
|
86
|
+
const uuid = "uuid" in parsed && typeof parsed.uuid === "string" ? parsed.uuid : undefined;
|
|
87
|
+
if (uuid && recentPostedUUIDs.has(uuid)) {
|
|
88
|
+
logForDebugging(`[bridge:repl] Ignoring echo: type=${parsed.type} uuid=${uuid}`);
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
if (uuid && recentInboundUUIDs.has(uuid)) {
|
|
92
|
+
logForDebugging(`[bridge:repl] Ignoring re-delivered inbound: type=${parsed.type} uuid=${uuid}`);
|
|
93
|
+
return;
|
|
94
|
+
}
|
|
95
|
+
logForDebugging(`[bridge:repl] Ingress message type=${parsed.type}${uuid ? ` uuid=${uuid}` : ""}`);
|
|
96
|
+
if (parsed.type === "user") {
|
|
97
|
+
if (uuid)
|
|
98
|
+
recentInboundUUIDs.add(uuid);
|
|
99
|
+
logEvent("tengu_bridge_message_received", {
|
|
100
|
+
is_repl: true
|
|
101
|
+
});
|
|
102
|
+
onInboundMessage?.(parsed);
|
|
103
|
+
} else {
|
|
104
|
+
logForDebugging(`[bridge:repl] Ignoring non-user inbound message: type=${parsed.type}`);
|
|
105
|
+
}
|
|
106
|
+
} catch (err) {
|
|
107
|
+
logForDebugging(`[bridge:repl] Failed to parse ingress message: ${errorMessage(err)}`);
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
var OUTBOUND_ONLY_ERROR = "This session is outbound-only. Enable Remote Control locally to allow inbound control.";
|
|
111
|
+
function handleServerControlRequest(request, handlers) {
|
|
112
|
+
const {
|
|
113
|
+
transport,
|
|
114
|
+
sessionId,
|
|
115
|
+
outboundOnly,
|
|
116
|
+
onInterrupt,
|
|
117
|
+
onSetModel,
|
|
118
|
+
onSetMaxThinkingTokens,
|
|
119
|
+
onSetPermissionMode
|
|
120
|
+
} = handlers;
|
|
121
|
+
if (!transport) {
|
|
122
|
+
logForDebugging("[bridge:repl] Cannot respond to control_request: transport not configured");
|
|
123
|
+
return;
|
|
124
|
+
}
|
|
125
|
+
let response;
|
|
126
|
+
const req = request.request;
|
|
127
|
+
if (outboundOnly && req.subtype !== "initialize") {
|
|
128
|
+
response = {
|
|
129
|
+
type: "control_response",
|
|
130
|
+
response: {
|
|
131
|
+
subtype: "error",
|
|
132
|
+
request_id: request.request_id,
|
|
133
|
+
error: OUTBOUND_ONLY_ERROR
|
|
134
|
+
}
|
|
135
|
+
};
|
|
136
|
+
const event2 = { ...response, session_id: sessionId };
|
|
137
|
+
transport.write(event2);
|
|
138
|
+
logForDebugging(`[bridge:repl] Rejected ${req.subtype} (outbound-only) request_id=${request.request_id}`);
|
|
139
|
+
return;
|
|
140
|
+
}
|
|
141
|
+
switch (req.subtype) {
|
|
142
|
+
case "initialize":
|
|
143
|
+
response = {
|
|
144
|
+
type: "control_response",
|
|
145
|
+
response: {
|
|
146
|
+
subtype: "success",
|
|
147
|
+
request_id: request.request_id,
|
|
148
|
+
response: {
|
|
149
|
+
commands: [],
|
|
150
|
+
output_style: "normal",
|
|
151
|
+
available_output_styles: ["normal"],
|
|
152
|
+
models: [],
|
|
153
|
+
account: {},
|
|
154
|
+
pid: process.pid
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
};
|
|
158
|
+
break;
|
|
159
|
+
case "set_model":
|
|
160
|
+
onSetModel?.(req.model);
|
|
161
|
+
response = {
|
|
162
|
+
type: "control_response",
|
|
163
|
+
response: {
|
|
164
|
+
subtype: "success",
|
|
165
|
+
request_id: request.request_id
|
|
166
|
+
}
|
|
167
|
+
};
|
|
168
|
+
break;
|
|
169
|
+
case "set_max_thinking_tokens":
|
|
170
|
+
onSetMaxThinkingTokens?.(req.max_thinking_tokens ?? null);
|
|
171
|
+
response = {
|
|
172
|
+
type: "control_response",
|
|
173
|
+
response: {
|
|
174
|
+
subtype: "success",
|
|
175
|
+
request_id: request.request_id
|
|
176
|
+
}
|
|
177
|
+
};
|
|
178
|
+
break;
|
|
179
|
+
case "set_permission_mode": {
|
|
180
|
+
const verdict = onSetPermissionMode?.(req.mode) ?? {
|
|
181
|
+
ok: false,
|
|
182
|
+
error: "set_permission_mode is not supported in this context (onSetPermissionMode callback not registered)"
|
|
183
|
+
};
|
|
184
|
+
if (verdict.ok) {
|
|
185
|
+
response = {
|
|
186
|
+
type: "control_response",
|
|
187
|
+
response: {
|
|
188
|
+
subtype: "success",
|
|
189
|
+
request_id: request.request_id
|
|
190
|
+
}
|
|
191
|
+
};
|
|
192
|
+
} else {
|
|
193
|
+
response = {
|
|
194
|
+
type: "control_response",
|
|
195
|
+
response: {
|
|
196
|
+
subtype: "error",
|
|
197
|
+
request_id: request.request_id,
|
|
198
|
+
error: verdict.error
|
|
199
|
+
}
|
|
200
|
+
};
|
|
201
|
+
}
|
|
202
|
+
break;
|
|
203
|
+
}
|
|
204
|
+
case "interrupt":
|
|
205
|
+
onInterrupt?.();
|
|
206
|
+
response = {
|
|
207
|
+
type: "control_response",
|
|
208
|
+
response: {
|
|
209
|
+
subtype: "success",
|
|
210
|
+
request_id: request.request_id
|
|
211
|
+
}
|
|
212
|
+
};
|
|
213
|
+
break;
|
|
214
|
+
default:
|
|
215
|
+
response = {
|
|
216
|
+
type: "control_response",
|
|
217
|
+
response: {
|
|
218
|
+
subtype: "error",
|
|
219
|
+
request_id: request.request_id,
|
|
220
|
+
error: `REPL bridge does not handle control_request subtype: ${req.subtype}`
|
|
221
|
+
}
|
|
222
|
+
};
|
|
223
|
+
}
|
|
224
|
+
const event = { ...response, session_id: sessionId };
|
|
225
|
+
transport.write(event);
|
|
226
|
+
logForDebugging(`[bridge:repl] Sent control_response for ${req.subtype} request_id=${request.request_id} result=${response.response.subtype}`);
|
|
227
|
+
}
|
|
228
|
+
function makeResultMessage(sessionId) {
|
|
229
|
+
return {
|
|
230
|
+
type: "result_success",
|
|
231
|
+
subtype: "success",
|
|
232
|
+
duration_ms: 0,
|
|
233
|
+
duration_api_ms: 0,
|
|
234
|
+
is_error: false,
|
|
235
|
+
num_turns: 0,
|
|
236
|
+
result: "",
|
|
237
|
+
stop_reason: null,
|
|
238
|
+
total_cost_usd: 0,
|
|
239
|
+
usage: { ...EMPTY_USAGE },
|
|
240
|
+
modelUsage: {},
|
|
241
|
+
permission_denials: [],
|
|
242
|
+
session_id: sessionId,
|
|
243
|
+
uuid: randomUUID()
|
|
244
|
+
};
|
|
245
|
+
}
|
|
246
|
+
|
|
247
|
+
class BoundedUUIDSet {
|
|
248
|
+
capacity;
|
|
249
|
+
ring;
|
|
250
|
+
set = new Set;
|
|
251
|
+
writeIdx = 0;
|
|
252
|
+
constructor(capacity) {
|
|
253
|
+
this.capacity = capacity;
|
|
254
|
+
this.ring = new Array(capacity);
|
|
255
|
+
}
|
|
256
|
+
add(uuid) {
|
|
257
|
+
if (this.set.has(uuid))
|
|
258
|
+
return;
|
|
259
|
+
const evicted = this.ring[this.writeIdx];
|
|
260
|
+
if (evicted !== undefined) {
|
|
261
|
+
this.set.delete(evicted);
|
|
262
|
+
}
|
|
263
|
+
this.ring[this.writeIdx] = uuid;
|
|
264
|
+
this.set.add(uuid);
|
|
265
|
+
this.writeIdx = (this.writeIdx + 1) % this.capacity;
|
|
266
|
+
}
|
|
267
|
+
has(uuid) {
|
|
268
|
+
return this.set.has(uuid);
|
|
269
|
+
}
|
|
270
|
+
clear() {
|
|
271
|
+
this.set.clear();
|
|
272
|
+
this.ring.fill(undefined);
|
|
273
|
+
this.writeIdx = 0;
|
|
274
|
+
}
|
|
275
|
+
}
|
|
276
|
+
|
|
277
|
+
export { isEligibleBridgeMessage, extractTitleText, handleIngressMessage, handleServerControlRequest, makeResultMessage, BoundedUUIDSet };
|