@redscope-ai/redscope 1.0.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.
- package/README.md +224 -0
- package/dist/chunk-090920rk.js +288 -0
- package/dist/chunk-0afb2r78.js +141 -0
- package/dist/chunk-0d4ekx1g.js +73 -0
- package/dist/chunk-0g6nwbhq.js +15 -0
- package/dist/chunk-0qj905nt.js +18 -0
- package/dist/chunk-0s5btnn1.js +186 -0
- package/dist/chunk-0s8fars0.js +91 -0
- package/dist/chunk-10ev3dvh.js +312 -0
- package/dist/chunk-10k5jfc5.js +1295 -0
- package/dist/chunk-12tspwqa.js +240 -0
- package/dist/chunk-13qesvnw.js +17 -0
- package/dist/chunk-143eh1e0.js +121 -0
- package/dist/chunk-14p6wvsq.js +39 -0
- package/dist/chunk-19f3zb1m.js +342 -0
- package/dist/chunk-1a5cep8h.js +145 -0
- package/dist/chunk-1abw9kkn.js +34 -0
- package/dist/chunk-1aer7c78.js +118 -0
- package/dist/chunk-1dazz4g6.js +154 -0
- package/dist/chunk-1fcf4ty1.js +142 -0
- package/dist/chunk-1gnxhyf8.js +62 -0
- package/dist/chunk-1he3944e.js +8124 -0
- package/dist/chunk-1jpayz7y.js +952 -0
- package/dist/chunk-1qd6f6vk.js +269 -0
- package/dist/chunk-1v0kpe62.js +2547 -0
- package/dist/chunk-1w20m7gw.js +445 -0
- package/dist/chunk-1y7kp51j.js +72 -0
- package/dist/chunk-1ycb5sxt.js +247 -0
- package/dist/chunk-1zbwhcbt.js +1124 -0
- package/dist/chunk-20psem54.js +116 -0
- package/dist/chunk-23h69r5b.js +30 -0
- package/dist/chunk-23x86ptv.js +473 -0
- package/dist/chunk-24fyv3jz.js +378 -0
- package/dist/chunk-24kv69g3.js +97 -0
- package/dist/chunk-2azx8zsc.js +125 -0
- package/dist/chunk-2d1gwzz9.js +524 -0
- package/dist/chunk-2g0ytd9d.js +29058 -0
- package/dist/chunk-2hfp9kat.js +21 -0
- package/dist/chunk-2j875eq6.js +37 -0
- package/dist/chunk-2kcgxnvp.js +39 -0
- package/dist/chunk-2kz09j2s.js +23 -0
- package/dist/chunk-2mwnwp0n.js +17 -0
- package/dist/chunk-2p1cqhcn.js +921 -0
- package/dist/chunk-2p369q9z.js +61 -0
- package/dist/chunk-2rf6asgf.js +151 -0
- package/dist/chunk-2vr7mqx1.js +384 -0
- package/dist/chunk-2xcg933e.js +205 -0
- package/dist/chunk-2ypwckbz.js +40310 -0
- package/dist/chunk-30wnahyg.js +626 -0
- package/dist/chunk-326zehp8.js +204 -0
- package/dist/chunk-32s6jzgw.js +183 -0
- package/dist/chunk-35yzt1a7.js +202 -0
- package/dist/chunk-38frkej6.js +62 -0
- package/dist/chunk-3abaq08g.js +34 -0
- package/dist/chunk-3h59ttr5.js +32 -0
- package/dist/chunk-3nk9q8dr.js +154 -0
- package/dist/chunk-3prrxevm.js +224 -0
- package/dist/chunk-3tv8p9xw.js +127 -0
- package/dist/chunk-3txyekes.js +19 -0
- package/dist/chunk-3vfxjn7g.js +19 -0
- package/dist/chunk-3w9sye8h.js +81 -0
- package/dist/chunk-3y69j7y8.js +24 -0
- package/dist/chunk-3zwjpkjh.js +1603 -0
- package/dist/chunk-40t1d75v.js +3442 -0
- package/dist/chunk-470kmby4.js +318 -0
- package/dist/chunk-47jc141z.js +335 -0
- package/dist/chunk-48rz50ct.js +868 -0
- package/dist/chunk-49wv03ts.js +232 -0
- package/dist/chunk-4a189mn2.js +103 -0
- package/dist/chunk-4c4fmh7a.js +15 -0
- package/dist/chunk-4ct8dsj5.js +49 -0
- package/dist/chunk-4kqt1pm1.js +100 -0
- package/dist/chunk-4ng0xy0e.js +802 -0
- package/dist/chunk-4spgkgr3.js +43 -0
- package/dist/chunk-4tjdwtyy.js +19 -0
- package/dist/chunk-4tr60273.js +370 -0
- package/dist/chunk-4vnaeng5.js +29 -0
- package/dist/chunk-4wbqpeaw.js +871 -0
- package/dist/chunk-4wgkv3fv.js +1140 -0
- package/dist/chunk-4yjskjb6.js +40 -0
- package/dist/chunk-50m3a23z.js +35 -0
- package/dist/chunk-511f79az.js +182 -0
- package/dist/chunk-51sgztvv.js +161 -0
- package/dist/chunk-563fcpv1.js +290 -0
- package/dist/chunk-564cnq6v.js +735 -0
- package/dist/chunk-569r8cxc.js +31 -0
- package/dist/chunk-570x55d4.js +12 -0
- package/dist/chunk-571556cm.js +80 -0
- package/dist/chunk-59t4c56e.js +63 -0
- package/dist/chunk-5axjhkma.js +36 -0
- package/dist/chunk-5b188q5e.js +157 -0
- package/dist/chunk-5dmn1865.js +439 -0
- package/dist/chunk-5ks4829r.js +267 -0
- package/dist/chunk-5mmhfbxb.js +1078 -0
- package/dist/chunk-5rdt14hy.js +742 -0
- package/dist/chunk-5ssryexj.js +121 -0
- package/dist/chunk-5v95pnq4.js +15 -0
- package/dist/chunk-5xvjt2t9.js +68 -0
- package/dist/chunk-5zyq6t1q.js +118 -0
- package/dist/chunk-60fkafk2.js +15 -0
- package/dist/chunk-62fjkf5q.js +46 -0
- package/dist/chunk-64gazrrb.js +8067 -0
- package/dist/chunk-65tq2yjx.js +126 -0
- package/dist/chunk-65zbgg1n.js +14 -0
- package/dist/chunk-66v8mty3.js +264 -0
- package/dist/chunk-6acx5heq.js +292 -0
- package/dist/chunk-6hr7742d.js +61 -0
- package/dist/chunk-6hygvrhn.js +143 -0
- package/dist/chunk-6kjh280m.js +128 -0
- package/dist/chunk-6s0q1s5r.js +66 -0
- package/dist/chunk-6x35ffpx.js +690 -0
- package/dist/chunk-71jfy1hh.js +570 -0
- package/dist/chunk-71sdcaq6.js +15 -0
- package/dist/chunk-754qdxs5.js +92 -0
- package/dist/chunk-79v5bkj4.js +1176 -0
- package/dist/chunk-7br0w7j5.js +151 -0
- package/dist/chunk-7cjgrzz1.js +298 -0
- package/dist/chunk-7d41ks0y.js +133 -0
- package/dist/chunk-7f40pmtr.js +71 -0
- package/dist/chunk-7g15x8hm.js +131 -0
- package/dist/chunk-7gtnzdet.js +120 -0
- package/dist/chunk-7h0z4aqx.js +702 -0
- package/dist/chunk-7h7e5a7d.js +25 -0
- package/dist/chunk-7m2cznwr.js +40 -0
- package/dist/chunk-7nvday0n.js +252 -0
- package/dist/chunk-7qey87th.js +145 -0
- package/dist/chunk-7qx3xhv3.js +9076 -0
- package/dist/chunk-7tfdhkpy.js +61 -0
- package/dist/chunk-80m511j6.js +121 -0
- package/dist/chunk-80ysxfe9.js +784 -0
- package/dist/chunk-8375zk8t.js +17200 -0
- package/dist/chunk-85bpkyy9.js +412 -0
- package/dist/chunk-85tcn547.js +876 -0
- package/dist/chunk-85vqgbc8.js +13 -0
- package/dist/chunk-86626jb4.js +49 -0
- package/dist/chunk-87ms17f6.js +444 -0
- package/dist/chunk-87mz239c.js +118 -0
- package/dist/chunk-89vdzt4e.js +254 -0
- package/dist/chunk-89z3e99z.js +159 -0
- package/dist/chunk-8cwrz1dd.js +1806 -0
- package/dist/chunk-8gv2pjby.js +21 -0
- package/dist/chunk-8hdevr3s.js +140 -0
- package/dist/chunk-8hdsk6qc.js +710 -0
- package/dist/chunk-8kct9arg.js +724 -0
- package/dist/chunk-8kf8h7xf.js +23 -0
- package/dist/chunk-8qed8ymj.js +605 -0
- package/dist/chunk-8sdgr592.js +101 -0
- package/dist/chunk-8we9w8pw.js +111 -0
- package/dist/chunk-8xnm5637.js +72 -0
- package/dist/chunk-8y3q0eqy.js +67 -0
- package/dist/chunk-8yvsnrkr.js +3449 -0
- package/dist/chunk-8zz4z1q3.js +42 -0
- package/dist/chunk-90eyff3k.js +119 -0
- package/dist/chunk-92bjkrf2.js +121 -0
- package/dist/chunk-92zrc7c6.js +327 -0
- package/dist/chunk-935nrvdb.js +13 -0
- package/dist/chunk-94pfyv6a.js +48 -0
- package/dist/chunk-9568p8se.js +115 -0
- package/dist/chunk-96km1ywr.js +37 -0
- package/dist/chunk-980bg4w4.js +163 -0
- package/dist/chunk-9a9g5hbj.js +205 -0
- package/dist/chunk-9cm4725d.js +4395 -0
- package/dist/chunk-9ds3vzq8.js +847 -0
- package/dist/chunk-9ffc9n60.js +618 -0
- package/dist/chunk-9fstrwv2.js +184 -0
- package/dist/chunk-9gt0g0qe.js +153 -0
- package/dist/chunk-9h9k5vz3.js +2761 -0
- package/dist/chunk-9he8bmhy.js +17 -0
- package/dist/chunk-9hn8e6h1.js +12 -0
- package/dist/chunk-9j0n3g8e.js +179 -0
- package/dist/chunk-9j6pa3ft.js +251 -0
- package/dist/chunk-9jpg9dn7.js +122 -0
- package/dist/chunk-9mycnwj5.js +46 -0
- package/dist/chunk-9npy2c17.js +517 -0
- package/dist/chunk-9p6sec8n.js +34 -0
- package/dist/chunk-9pnym83h.js +4584 -0
- package/dist/chunk-9skwrnd2.js +25 -0
- package/dist/chunk-9tsfaqr8.js +459 -0
- package/dist/chunk-9tsw3cqv.js +5924 -0
- package/dist/chunk-9w6ckyk4.js +49 -0
- package/dist/chunk-a15bwzv6.js +147 -0
- package/dist/chunk-a9t6cp69.js +28 -0
- package/dist/chunk-ad2yk19p.js +102 -0
- package/dist/chunk-ad4cw4nw.js +336 -0
- package/dist/chunk-ad69fbsk.js +347 -0
- package/dist/chunk-ae76ded0.js +30 -0
- package/dist/chunk-aeysytks.js +216 -0
- package/dist/chunk-ag81m9bq.js +61 -0
- package/dist/chunk-ahx7gp6r.js +4448 -0
- package/dist/chunk-aj4tk4tk.js +23 -0
- package/dist/chunk-an82t9jc.js +104 -0
- package/dist/chunk-apg95qd7.js +1393 -0
- package/dist/chunk-aq5n2adz.js +27 -0
- package/dist/chunk-aw4s3a99.js +208 -0
- package/dist/chunk-awgdfggg.js +14 -0
- package/dist/chunk-ayymxgn1.js +164 -0
- package/dist/chunk-azbab59e.js +637 -0
- package/dist/chunk-azdxq2a3.js +293 -0
- package/dist/chunk-b0tjx3k1.js +523 -0
- package/dist/chunk-b5pp4g2g.js +371 -0
- package/dist/chunk-b5zm8dt6.js +26 -0
- package/dist/chunk-bcnye5a0.js +109 -0
- package/dist/chunk-beqz3k49.js +190 -0
- package/dist/chunk-bf906wpw.js +147 -0
- package/dist/chunk-bgan4cpf.js +13 -0
- package/dist/chunk-bhzp13h7.js +1178 -0
- package/dist/chunk-bk403kpw.js +142 -0
- package/dist/chunk-bmq4c135.js +489 -0
- package/dist/chunk-bprbeda7.js +35 -0
- package/dist/chunk-bst7czdd.js +888 -0
- package/dist/chunk-bths4xgn.js +111 -0
- package/dist/chunk-btjn3qby.js +13 -0
- package/dist/chunk-bwb1vxnt.js +120 -0
- package/dist/chunk-bxa6tw4m.js +643 -0
- package/dist/chunk-bxfjr8qb.js +27 -0
- package/dist/chunk-bxpzhrej.js +73 -0
- package/dist/chunk-bzyzrq0k.js +51 -0
- package/dist/chunk-c0k7b0jw.js +4265 -0
- package/dist/chunk-c17f0h2s.js +16 -0
- package/dist/chunk-c1yc761e.js +6748 -0
- package/dist/chunk-c5g9shkw.js +298 -0
- package/dist/chunk-c696122m.js +69 -0
- package/dist/chunk-c92b3yxx.js +109 -0
- package/dist/chunk-c9aqz56y.js +143 -0
- package/dist/chunk-cba7c5w3.js +345 -0
- package/dist/chunk-cbcxbbe6.js +6543 -0
- package/dist/chunk-cdfjb87h.js +11 -0
- package/dist/chunk-ce8zjt1y.js +136 -0
- package/dist/chunk-cep7e37k.js +22740 -0
- package/dist/chunk-chs5qm8d.js +258 -0
- package/dist/chunk-ckydq33g.js +144 -0
- package/dist/chunk-cnge6wpj.js +514 -0
- package/dist/chunk-cpnsvqf1.js +13 -0
- package/dist/chunk-cqqebkv4.js +32 -0
- package/dist/chunk-cvqpp7dk.js +627 -0
- package/dist/chunk-cwc33j40.js +65 -0
- package/dist/chunk-cypvrq2a.js +155 -0
- package/dist/chunk-d1ha0swn.js +475 -0
- package/dist/chunk-d2an0138.js +35 -0
- package/dist/chunk-d2tt72ck.js +343 -0
- package/dist/chunk-d6wvcqrw.js +9507 -0
- package/dist/chunk-d7ys2kka.js +991 -0
- package/dist/chunk-dbts5q5p.js +122 -0
- package/dist/chunk-dct29ggs.js +295 -0
- package/dist/chunk-de0qnnf7.js +1059 -0
- package/dist/chunk-dep72ce4.js +513 -0
- package/dist/chunk-dgpvgy8x.js +47 -0
- package/dist/chunk-dhhd7dtc.js +20 -0
- package/dist/chunk-dhzpmxv6.js +594 -0
- package/dist/chunk-djes4da7.js +413 -0
- package/dist/chunk-dnhv3vx7.js +166 -0
- package/dist/chunk-dqtvafan.js +2365 -0
- package/dist/chunk-dr4a3tcp.js +60 -0
- package/dist/chunk-dz2xk9kb.js +100 -0
- package/dist/chunk-dz7nc6rf.js +15 -0
- package/dist/chunk-e3abfxpy.js +1486 -0
- package/dist/chunk-e3cq9z89.js +85 -0
- package/dist/chunk-e3j7m7k2.js +642 -0
- package/dist/chunk-e4dsy4g1.js +9951 -0
- package/dist/chunk-e5592pnn.js +197 -0
- package/dist/chunk-e55hdegh.js +129 -0
- package/dist/chunk-e5r5r04e.js +1030 -0
- package/dist/chunk-e60zztbt.js +442 -0
- package/dist/chunk-e7qq6vn0.js +372 -0
- package/dist/chunk-e9aat7xw.js +80 -0
- package/dist/chunk-e9d5v3zs.js +143 -0
- package/dist/chunk-eax32zk4.js +87 -0
- package/dist/chunk-ebfwmbx1.js +117 -0
- package/dist/chunk-ec71pb8t.js +971 -0
- package/dist/chunk-eemjb825.js +17252 -0
- package/dist/chunk-ees8xdhd.js +256 -0
- package/dist/chunk-eewg66y1.js +112 -0
- package/dist/chunk-eg22v12d.js +266 -0
- package/dist/chunk-enzzk67f.js +313 -0
- package/dist/chunk-eskhp70f.js +117 -0
- package/dist/chunk-ewx6z4g8.js +55 -0
- package/dist/chunk-eyvx461k.js +76 -0
- package/dist/chunk-eztq2b5f.js +94 -0
- package/dist/chunk-f0ffwzdd.js +321 -0
- package/dist/chunk-f80n68mf.js +119 -0
- package/dist/chunk-fae2hjxp.js +99 -0
- package/dist/chunk-fbtfp370.js +60 -0
- package/dist/chunk-fc6ndtgf.js +94 -0
- package/dist/chunk-fdwabr8p.js +13870 -0
- package/dist/chunk-fejeqe61.js +785 -0
- package/dist/chunk-fh0d6mvk.js +168 -0
- package/dist/chunk-fh19zcaf.js +304 -0
- package/dist/chunk-fh8bd39r.js +186 -0
- package/dist/chunk-fj2ebbpn.js +33 -0
- package/dist/chunk-fjn632v7.js +194 -0
- package/dist/chunk-fncpkzs5.js +1389 -0
- package/dist/chunk-fpd1gpt8.js +332 -0
- package/dist/chunk-fq9snrnh.js +295 -0
- package/dist/chunk-fqcfzg3j.js +207 -0
- package/dist/chunk-ftt3vqj2.js +1919 -0
- package/dist/chunk-g06pm4n9.js +395 -0
- package/dist/chunk-g4m5pf4g.js +8 -0
- package/dist/chunk-g72h52y6.js +36 -0
- package/dist/chunk-g79ej71s.js +1627 -0
- package/dist/chunk-g7fwk59d.js +19 -0
- package/dist/chunk-g9jnkrtm.js +663 -0
- package/dist/chunk-g9vg5d7t.js +38 -0
- package/dist/chunk-ga1jkyqy.js +1636 -0
- package/dist/chunk-gaaap2nk.js +676 -0
- package/dist/chunk-gc6erq5q.js +483 -0
- package/dist/chunk-gjrcmf0a.js +752 -0
- package/dist/chunk-gmdy2w3z.js +238999 -0
- package/dist/chunk-gsz4yrrk.js +81 -0
- package/dist/chunk-gy47rjy8.js +3830 -0
- package/dist/chunk-h12a4f4x.js +11 -0
- package/dist/chunk-h1yratmg.js +725 -0
- package/dist/chunk-h9y0jnsy.js +155 -0
- package/dist/chunk-hbhs3mwy.js +133 -0
- package/dist/chunk-hbs8cmb4.js +8 -0
- package/dist/chunk-hdk0t1ht.js +940 -0
- package/dist/chunk-hef8dx4s.js +178 -0
- package/dist/chunk-hgsca8mt.js +381 -0
- package/dist/chunk-hhsxm2yr.js +67 -0
- package/dist/chunk-hj5tzzpd.js +39 -0
- package/dist/chunk-hjxqmtg5.js +94 -0
- package/dist/chunk-hn4w9pkj.js +68 -0
- package/dist/chunk-hnprkjgp.js +25 -0
- package/dist/chunk-hq3n5ex7.js +183 -0
- package/dist/chunk-hqjspfma.js +158 -0
- package/dist/chunk-hqxp6b72.js +1198 -0
- package/dist/chunk-hs6nrmq6.js +94 -0
- package/dist/chunk-hwba5xdc.js +267 -0
- package/dist/chunk-hy566ev3.js +430 -0
- package/dist/chunk-hzmzwte2.js +153 -0
- package/dist/chunk-hzxzvzw8.js +274 -0
- package/dist/chunk-j139fzgs.js +114 -0
- package/dist/chunk-j1mep9ck.js +62 -0
- package/dist/chunk-j3xveeg4.js +273 -0
- package/dist/chunk-j5y1s11j.js +100 -0
- package/dist/chunk-j9475b46.js +26 -0
- package/dist/chunk-j9rgqs8m.js +1192 -0
- package/dist/chunk-jccjaddz.js +74 -0
- package/dist/chunk-jdkwfy9e.js +35 -0
- package/dist/chunk-jdqp0r4h.js +6157 -0
- package/dist/chunk-jdzk4zwn.js +587 -0
- package/dist/chunk-jfafmkte.js +49 -0
- package/dist/chunk-jg3r989b.js +16 -0
- package/dist/chunk-jhtccjc9.js +54 -0
- package/dist/chunk-jj2ff1pr.js +688 -0
- package/dist/chunk-jmv7k0jn.js +37 -0
- package/dist/chunk-jmxzmwpw.js +65 -0
- package/dist/chunk-jnjxdqyr.js +353 -0
- package/dist/chunk-jsbbez9j.js +138 -0
- package/dist/chunk-jvpt2dc0.js +424 -0
- package/dist/chunk-jwd7cka0.js +34 -0
- package/dist/chunk-jy5er3st.js +15 -0
- package/dist/chunk-jyby79z5.js +121 -0
- package/dist/chunk-jzyr6j5n.js +332 -0
- package/dist/chunk-k49xc781.js +63 -0
- package/dist/chunk-k7dt2g4a.js +41 -0
- package/dist/chunk-k7hexw3v.js +969 -0
- package/dist/chunk-k7wwkraa.js +117 -0
- package/dist/chunk-kb3758f7.js +51 -0
- package/dist/chunk-kc67kt75.js +3119 -0
- package/dist/chunk-kdhmfxmh.js +3149 -0
- package/dist/chunk-kejdd6zc.js +51 -0
- package/dist/chunk-kekrjeem.js +402 -0
- package/dist/chunk-kez5r0zz.js +280 -0
- package/dist/chunk-kfsvcs5t.js +75 -0
- package/dist/chunk-khtvffc4.js +285 -0
- package/dist/chunk-kkz4w1tv.js +64 -0
- package/dist/chunk-kmywng0j.js +272 -0
- package/dist/chunk-kq6vcpdr.js +224 -0
- package/dist/chunk-kqzdszcc.js +37 -0
- package/dist/chunk-ktxpp02w.js +435 -0
- package/dist/chunk-kwcvhbtz.js +26 -0
- package/dist/chunk-kx0cm9qr.js +128 -0
- package/dist/chunk-kxcmqz10.js +120 -0
- package/dist/chunk-kxwava1g.js +14 -0
- package/dist/chunk-kywtr3jg.js +825 -0
- package/dist/chunk-kzwg923p.js +8 -0
- package/dist/chunk-m1eq3sgv.js +255 -0
- package/dist/chunk-m21h5zb4.js +119 -0
- package/dist/chunk-m2c3bjv1.js +111 -0
- package/dist/chunk-m41e19ms.js +42 -0
- package/dist/chunk-m7ka36ex.js +97 -0
- package/dist/chunk-m81w8tbm.js +259 -0
- package/dist/chunk-m95ggkax.js +281 -0
- package/dist/chunk-manx26xa.js +145 -0
- package/dist/chunk-mdxh3pk2.js +298 -0
- package/dist/chunk-mhbfkcja.js +311 -0
- package/dist/chunk-mjnr5erm.js +173 -0
- package/dist/chunk-mngvnmwp.js +135 -0
- package/dist/chunk-mvfqanv5.js +63 -0
- package/dist/chunk-mw1nesq1.js +140 -0
- package/dist/chunk-mx168925.js +661 -0
- package/dist/chunk-mxwvj18g.js +795 -0
- package/dist/chunk-my7r5mba.js +257 -0
- package/dist/chunk-myaa1kkf.js +17 -0
- package/dist/chunk-myypc3tn.js +46 -0
- package/dist/chunk-mzcnmnpq.js +3379 -0
- package/dist/chunk-mznav6d1.js +194 -0
- package/dist/chunk-n0qxskpr.js +24 -0
- package/dist/chunk-n6a6hgtp.js +394 -0
- package/dist/chunk-n6d5fgx0.js +254 -0
- package/dist/chunk-n6ym3n03.js +120 -0
- package/dist/chunk-n9g24mwe.js +104 -0
- package/dist/chunk-naamqdf9.js +185 -0
- package/dist/chunk-nb2jk7zj.js +15 -0
- package/dist/chunk-nbkbq9en.js +67 -0
- package/dist/chunk-ndttd6es.js +38 -0
- package/dist/chunk-nfygaaxg.js +133 -0
- package/dist/chunk-ngdzpszd.js +454 -0
- package/dist/chunk-nmfwksa4.js +1297 -0
- package/dist/chunk-nt837qt9.js +21 -0
- package/dist/chunk-nwc3v0vp.js +691 -0
- package/dist/chunk-nz8ha95p.js +3610 -0
- package/dist/chunk-nzxfj0gq.js +2007 -0
- package/dist/chunk-p0r8887g.js +6932 -0
- package/dist/chunk-p1seyqdm.js +120 -0
- package/dist/chunk-p425zbgw.js +726 -0
- package/dist/chunk-p7hamd2c.js +146 -0
- package/dist/chunk-pdvg91cg.js +32 -0
- package/dist/chunk-pecy49yr.js +14649 -0
- package/dist/chunk-pfxrg89f.js +547 -0
- package/dist/chunk-pfyw3155.js +2750 -0
- package/dist/chunk-pr8m11pm.js +1192 -0
- package/dist/chunk-ptxteaeh.js +1591 -0
- package/dist/chunk-pv164mac.js +394 -0
- package/dist/chunk-pxxhtxf5.js +10154 -0
- package/dist/chunk-q0e485mg.js +61 -0
- package/dist/chunk-q1vrhh0q.js +458 -0
- package/dist/chunk-q2h79ncs.js +370 -0
- package/dist/chunk-q3b4n194.js +56 -0
- package/dist/chunk-q44zc68f.js +4301 -0
- package/dist/chunk-q8gknbdx.js +352 -0
- package/dist/chunk-q8xk3kdj.js +11 -0
- package/dist/chunk-qak46xtp.js +119 -0
- package/dist/chunk-qfq7absv.js +95 -0
- package/dist/chunk-qfsn720k.js +151 -0
- package/dist/chunk-qg4811f6.js +228 -0
- package/dist/chunk-qgzn3qps.js +90 -0
- package/dist/chunk-qhaggqkt.js +113 -0
- package/dist/chunk-qjjp27z8.js +195 -0
- package/dist/chunk-qxp0nye6.js +34 -0
- package/dist/chunk-qy3nagaq.js +4957 -0
- package/dist/chunk-qz2meav1.js +1452 -0
- package/dist/chunk-r50hne7m.js +63 -0
- package/dist/chunk-r6m0vgnv.js +80 -0
- package/dist/chunk-r7yw38vf.js +22864 -0
- package/dist/chunk-r8xc618w.js +42 -0
- package/dist/chunk-r961r5kj.js +87 -0
- package/dist/chunk-r9b5xrh0.js +66 -0
- package/dist/chunk-rcn2pd6q.js +477 -0
- package/dist/chunk-rdeh8p3y.js +148 -0
- package/dist/chunk-rg9x1742.js +542 -0
- package/dist/chunk-rgyzsbs3.js +39 -0
- package/dist/chunk-rk2fsxtz.js +16 -0
- package/dist/chunk-rkchkwv9.js +40 -0
- package/dist/chunk-rp8whpb3.js +478 -0
- package/dist/chunk-rpkxdtgr.js +68 -0
- package/dist/chunk-rpmntgyh.js +394 -0
- package/dist/chunk-rpshz4dy.js +614 -0
- package/dist/chunk-rqd60ay5.js +133 -0
- package/dist/chunk-rrsjf2ea.js +229 -0
- package/dist/chunk-rtjk8c8e.js +173 -0
- package/dist/chunk-rw0y2wdf.js +1017 -0
- package/dist/chunk-rx5w7ess.js +663 -0
- package/dist/chunk-rx8t9d35.js +1947 -0
- package/dist/chunk-rxcazxgf.js +195 -0
- package/dist/chunk-rxg6q3bp.js +1413 -0
- package/dist/chunk-rxrb7xnd.js +71 -0
- package/dist/chunk-rxrzxff3.js +118 -0
- package/dist/chunk-ryqjc943.js +71 -0
- package/dist/chunk-rzk9k2rf.js +81 -0
- package/dist/chunk-s2qv0nht.js +119 -0
- package/dist/chunk-s3hafnk3.js +2285 -0
- package/dist/chunk-s4a496tt.js +226 -0
- package/dist/chunk-s4d1h3ka.js +35 -0
- package/dist/chunk-sm3k3ze4.js +16525 -0
- package/dist/chunk-sn0bja82.js +385 -0
- package/dist/chunk-sngjggw1.js +4227 -0
- package/dist/chunk-sq047n34.js +364 -0
- package/dist/chunk-sttwe2tw.js +8584 -0
- package/dist/chunk-sw8qx1r0.js +86 -0
- package/dist/chunk-swstah6a.js +240 -0
- package/dist/chunk-syrkr0mf.js +63 -0
- package/dist/chunk-sz206bd9.js +26 -0
- package/dist/chunk-t09669cj.js +333 -0
- package/dist/chunk-t5f8e30k.js +602 -0
- package/dist/chunk-t5m78mc8.js +432 -0
- package/dist/chunk-t5x1dqwn.js +143 -0
- package/dist/chunk-t877ea0w.js +168 -0
- package/dist/chunk-t91hb71c.js +17 -0
- package/dist/chunk-tb636bcf.js +942 -0
- package/dist/chunk-tb8sykbr.js +426 -0
- package/dist/chunk-tbdkekz3.js +125 -0
- package/dist/chunk-td2gsz7s.js +225 -0
- package/dist/chunk-tenvxbyh.js +20 -0
- package/dist/chunk-texg4qqt.js +317 -0
- package/dist/chunk-teymzz80.js +266 -0
- package/dist/chunk-tj26qpf7.js +153 -0
- package/dist/chunk-tk85ec4p.js +395 -0
- package/dist/chunk-tq205h01.js +164 -0
- package/dist/chunk-tqzddjzg.js +61 -0
- package/dist/chunk-trqrj23e.js +134 -0
- package/dist/chunk-tw1hfsxv.js +2477 -0
- package/dist/chunk-txxdfq83.js +122 -0
- package/dist/chunk-v0yhe582.js +31 -0
- package/dist/chunk-v14184xm.js +15 -0
- package/dist/chunk-v1h9z4hw.js +138 -0
- package/dist/chunk-v3ey5j7f.js +329 -0
- package/dist/chunk-v3nh1sfn.js +208 -0
- package/dist/chunk-v3x8tcc0.js +45 -0
- package/dist/chunk-v4nqnvqq.js +3984 -0
- package/dist/chunk-v4ypszbb.js +15 -0
- package/dist/chunk-v7wbqcx9.js +63 -0
- package/dist/chunk-v8r5fev3.js +341 -0
- package/dist/chunk-v9zg5kzx.js +2810 -0
- package/dist/chunk-va1wh5ss.js +24 -0
- package/dist/chunk-vbfswhht.js +42 -0
- package/dist/chunk-ve7x2tfq.js +124 -0
- package/dist/chunk-vfz8k89y.js +485 -0
- package/dist/chunk-vgm5k14x.js +35678 -0
- package/dist/chunk-vh9pej3c.js +247 -0
- package/dist/chunk-vjxqyt6f.js +3820 -0
- package/dist/chunk-vpb1xstn.js +178 -0
- package/dist/chunk-vqt79tj8.js +110 -0
- package/dist/chunk-vr0n9pv9.js +152 -0
- package/dist/chunk-vrejmja5.js +90 -0
- package/dist/chunk-vrxasmdw.js +449 -0
- package/dist/chunk-vrxb946v.js +125 -0
- package/dist/chunk-vv4kj0q8.js +98 -0
- package/dist/chunk-vvpfng7w.js +8 -0
- package/dist/chunk-vw6ybyew.js +2007 -0
- package/dist/chunk-vwenx8ke.js +17 -0
- package/dist/chunk-vwfa0s5a.js +155 -0
- package/dist/chunk-vx71j8xe.js +63 -0
- package/dist/chunk-vxbjzggp.js +43 -0
- package/dist/chunk-vxjxtz8w.js +440 -0
- package/dist/chunk-vy0c1bwp.js +9 -0
- package/dist/chunk-w3zczyse.js +14 -0
- package/dist/chunk-w4p5t920.js +655 -0
- package/dist/chunk-w68wc625.js +287 -0
- package/dist/chunk-w9ddp3yf.js +96 -0
- package/dist/chunk-wcggm5ja.js +125 -0
- package/dist/chunk-wgnyph3q.js +1306 -0
- package/dist/chunk-wjm5pc1e.js +134 -0
- package/dist/chunk-wnve0drm.js +131 -0
- package/dist/chunk-wp27ev2k.js +135 -0
- package/dist/chunk-wyvy8a4x.js +131 -0
- package/dist/chunk-x671y4dk.js +129 -0
- package/dist/chunk-xbj5keyy.js +22 -0
- package/dist/chunk-xf4fzms8.js +39 -0
- package/dist/chunk-xf59k3zg.js +65 -0
- package/dist/chunk-xgzc4w49.js +204 -0
- package/dist/chunk-xhj7g13b.js +2149 -0
- package/dist/chunk-xjp0cd00.js +56 -0
- package/dist/chunk-xkhnmhqs.js +74 -0
- package/dist/chunk-xkrkqx61.js +55 -0
- package/dist/chunk-xmpgmeb8.js +114 -0
- package/dist/chunk-xrw80zgd.js +4249 -0
- package/dist/chunk-xrzc96g0.js +202 -0
- package/dist/chunk-xt76sm44.js +318 -0
- package/dist/chunk-xwet3awb.js +20 -0
- package/dist/chunk-xyg1sk2w.js +78 -0
- package/dist/chunk-y0jpkqb0.js +180 -0
- package/dist/chunk-y1q7rt9n.js +102 -0
- package/dist/chunk-y67ntyek.js +258 -0
- package/dist/chunk-ybk37qp9.js +37 -0
- package/dist/chunk-yc1stfve.js +5386 -0
- package/dist/chunk-ychjpjef.js +62 -0
- package/dist/chunk-yez8fa9g.js +276 -0
- package/dist/chunk-ygm7xszr.js +90 -0
- package/dist/chunk-ym11azkj.js +37 -0
- package/dist/chunk-ympz2h15.js +578 -0
- package/dist/chunk-yqx3az3n.js +129 -0
- package/dist/chunk-yt3nfhcc.js +152 -0
- package/dist/chunk-yy8q0n8s.js +120 -0
- package/dist/chunk-yzb92zxv.js +8 -0
- package/dist/chunk-yzet6xyr.js +119 -0
- package/dist/chunk-yzm97qp1.js +226 -0
- package/dist/chunk-z0jgeax8.js +35 -0
- package/dist/chunk-z1r3z6w6.js +29 -0
- package/dist/chunk-z2dp53wn.js +17 -0
- package/dist/chunk-z79355gz.js +308 -0
- package/dist/chunk-z7e94hxz.js +251 -0
- package/dist/chunk-z8cqdcec.js +173 -0
- package/dist/chunk-z99tbg45.js +148 -0
- package/dist/chunk-z9nsjcht.js +37 -0
- package/dist/chunk-za3k6h2h.js +470 -0
- package/dist/chunk-zacynq5p.js +265 -0
- package/dist/chunk-zb0x40az.js +1785 -0
- package/dist/chunk-zbxtzycc.js +274 -0
- package/dist/chunk-zga50181.js +342 -0
- package/dist/chunk-zhb2pns1.js +44 -0
- package/dist/chunk-zkch6trx.js +231 -0
- package/dist/chunk-znf3z4qt.js +954 -0
- package/dist/chunk-zp8zwdgq.js +72 -0
- package/dist/chunk-ztjd8pyf.js +120 -0
- package/dist/chunk-ztmb7geg.js +173 -0
- package/dist/chunk-zvr4snzv.js +887 -0
- package/dist/chunk-zw62m6n3.js +34858 -0
- package/dist/chunk-zwwdebd0.js +65 -0
- package/dist/chunk-zxc6x9w8.js +340 -0
- package/dist/chunk-zy2e7sz0.js +8 -0
- package/dist/chunk-zzf074w3.js +196 -0
- package/dist/chunk-zzz0nwb5.js +310 -0
- package/dist/cli-bun.js +2 -0
- package/dist/cli-node.js +2 -0
- package/dist/cli.js +218 -0
- package/dist/vendor/audio-capture/arm64-darwin/audio-capture.node +0 -0
- package/dist/vendor/audio-capture/arm64-linux/audio-capture.node +0 -0
- package/dist/vendor/audio-capture/arm64-win32/audio-capture.node +0 -0
- package/dist/vendor/audio-capture/x64-darwin/audio-capture.node +0 -0
- package/dist/vendor/audio-capture/x64-linux/audio-capture.node +0 -0
- package/dist/vendor/audio-capture/x64-win32/audio-capture.node +0 -0
- package/dist/vendor/ripgrep/x64-win32/rg.exe +0 -0
- package/package.json +243 -0
- package/scripts/chrome-mcp-bridge-resolver.mjs +43 -0
- package/scripts/chrome-mcp-env.mjs +19 -0
- package/scripts/postinstall.cjs +339 -0
- package/scripts/run-parallel.mjs +10 -0
- package/scripts/setup-chrome-mcp.mjs +69 -0
|
@@ -0,0 +1,1627 @@
|
|
|
1
|
+
// @bun
|
|
2
|
+
import {
|
|
3
|
+
normalizeControlMessageKeys
|
|
4
|
+
} from "./chunk-nt837qt9.js";
|
|
5
|
+
import {
|
|
6
|
+
AccountInfoSchema,
|
|
7
|
+
AgentDefinitionSchema,
|
|
8
|
+
AgentInfoSchema,
|
|
9
|
+
DEFAULT_CRON_JITTER_CONFIG,
|
|
10
|
+
FastModeStateSchema,
|
|
11
|
+
HookEventSchema,
|
|
12
|
+
HookInputSchema,
|
|
13
|
+
McpServerConfigForProcessTransportSchema,
|
|
14
|
+
McpServerStatusSchema,
|
|
15
|
+
ModelInfoSchema,
|
|
16
|
+
PermissionModeSchema,
|
|
17
|
+
PermissionUpdateSchema,
|
|
18
|
+
SDKMessageSchema,
|
|
19
|
+
SDKPostTurnSummaryMessageSchema,
|
|
20
|
+
SDKStreamlinedTextMessageSchema,
|
|
21
|
+
SDKStreamlinedToolUseSummaryMessageSchema,
|
|
22
|
+
SDKUserMessageSchema,
|
|
23
|
+
SlashCommandSchema,
|
|
24
|
+
Stream,
|
|
25
|
+
addMarketplaceSource,
|
|
26
|
+
applyPermissionUpdates,
|
|
27
|
+
cronToHuman,
|
|
28
|
+
detectImageFormatFromBase64,
|
|
29
|
+
executePermissionRequestHooks,
|
|
30
|
+
findMissedTasks,
|
|
31
|
+
getCronFilePaths,
|
|
32
|
+
getDeclaredMarketplaces,
|
|
33
|
+
hasCronTasksSync,
|
|
34
|
+
hasPermissionsToUseTool,
|
|
35
|
+
hookJSONOutputSchema,
|
|
36
|
+
init_PermissionUpdate,
|
|
37
|
+
init_PermissionUpdateSchema,
|
|
38
|
+
init_commandLifecycle,
|
|
39
|
+
init_coreSchemas,
|
|
40
|
+
init_cron,
|
|
41
|
+
init_cronTasks,
|
|
42
|
+
init_hooks,
|
|
43
|
+
init_hooks1 as init_hooks2,
|
|
44
|
+
init_imageResizer,
|
|
45
|
+
init_marketplaceManager,
|
|
46
|
+
init_permissions,
|
|
47
|
+
init_stream,
|
|
48
|
+
jitteredNextCronRunMs,
|
|
49
|
+
loadKnownMarketplacesConfig,
|
|
50
|
+
markCronTasksFired,
|
|
51
|
+
notifyCommandLifecycle,
|
|
52
|
+
oneShotJitteredNextCronRunMs,
|
|
53
|
+
permissionUpdateSchema,
|
|
54
|
+
persistPermissionUpdates,
|
|
55
|
+
readCronTasks,
|
|
56
|
+
removeCronTasks
|
|
57
|
+
} from "./chunk-gmdy2w3z.js";
|
|
58
|
+
import {
|
|
59
|
+
init_sessionState,
|
|
60
|
+
notifySessionStateChanged
|
|
61
|
+
} from "./chunk-nzxfj0gq.js";
|
|
62
|
+
import {
|
|
63
|
+
getFeatureValue_CACHED_WITH_REFRESH,
|
|
64
|
+
init_file,
|
|
65
|
+
init_growthbook,
|
|
66
|
+
init_isEqual,
|
|
67
|
+
init_schemas,
|
|
68
|
+
isEqual_default,
|
|
69
|
+
isLocalMarketplaceSource,
|
|
70
|
+
pathExists
|
|
71
|
+
} from "./chunk-eemjb825.js";
|
|
72
|
+
import {
|
|
73
|
+
init_json,
|
|
74
|
+
safeParseJSON
|
|
75
|
+
} from "./chunk-ga1jkyqy.js";
|
|
76
|
+
import {
|
|
77
|
+
init_lazySchema,
|
|
78
|
+
lazySchema
|
|
79
|
+
} from "./chunk-bgan4cpf.js";
|
|
80
|
+
import {
|
|
81
|
+
init_genericProcessUtils,
|
|
82
|
+
isProcessRunning
|
|
83
|
+
} from "./chunk-hjxqmtg5.js";
|
|
84
|
+
import {
|
|
85
|
+
init_v4,
|
|
86
|
+
v4_default
|
|
87
|
+
} from "./chunk-j9475b46.js";
|
|
88
|
+
import {
|
|
89
|
+
exports_external
|
|
90
|
+
} from "./chunk-fdwabr8p.js";
|
|
91
|
+
import {
|
|
92
|
+
init_analytics,
|
|
93
|
+
logEvent
|
|
94
|
+
} from "./chunk-j1mep9ck.js";
|
|
95
|
+
import {
|
|
96
|
+
findCanonicalGitRoot,
|
|
97
|
+
init_diagLogs,
|
|
98
|
+
init_git,
|
|
99
|
+
logForDiagnosticsNoPII
|
|
100
|
+
} from "./chunk-10k5jfc5.js";
|
|
101
|
+
import {
|
|
102
|
+
AbortError,
|
|
103
|
+
errorMessage,
|
|
104
|
+
getErrnoCode,
|
|
105
|
+
getPreferredProjectConfigDir,
|
|
106
|
+
init_cleanupRegistry,
|
|
107
|
+
init_debug,
|
|
108
|
+
init_errors,
|
|
109
|
+
init_log,
|
|
110
|
+
init_redscopeCompat,
|
|
111
|
+
init_slowOperations,
|
|
112
|
+
jsonParse,
|
|
113
|
+
jsonStringify,
|
|
114
|
+
logError,
|
|
115
|
+
logForDebugging,
|
|
116
|
+
registerCleanup
|
|
117
|
+
} from "./chunk-s3hafnk3.js";
|
|
118
|
+
import {
|
|
119
|
+
init_process,
|
|
120
|
+
writeToStdout
|
|
121
|
+
} from "./chunk-kb3758f7.js";
|
|
122
|
+
import {
|
|
123
|
+
getOriginalCwd,
|
|
124
|
+
getProjectRoot,
|
|
125
|
+
getScheduledTasksEnabled,
|
|
126
|
+
getSessionCronTasks,
|
|
127
|
+
getSessionId,
|
|
128
|
+
init_state,
|
|
129
|
+
removeSessionCronTasks,
|
|
130
|
+
setScheduledTasksEnabled
|
|
131
|
+
} from "./chunk-9h9k5vz3.js";
|
|
132
|
+
import {
|
|
133
|
+
__esm,
|
|
134
|
+
__export,
|
|
135
|
+
__require
|
|
136
|
+
} from "./chunk-hhsxm2yr.js";
|
|
137
|
+
|
|
138
|
+
// src/utils/cronJitterConfig.ts
|
|
139
|
+
var exports_cronJitterConfig = {};
|
|
140
|
+
__export(exports_cronJitterConfig, {
|
|
141
|
+
getCronJitterConfig: () => getCronJitterConfig
|
|
142
|
+
});
|
|
143
|
+
function getCronJitterConfig() {
|
|
144
|
+
const raw = getFeatureValue_CACHED_WITH_REFRESH("tengu_kairos_cron_config", DEFAULT_CRON_JITTER_CONFIG, JITTER_CONFIG_REFRESH_MS);
|
|
145
|
+
const parsed = cronJitterConfigSchema().safeParse(raw);
|
|
146
|
+
return parsed.success ? parsed.data : DEFAULT_CRON_JITTER_CONFIG;
|
|
147
|
+
}
|
|
148
|
+
var JITTER_CONFIG_REFRESH_MS, HALF_HOUR_MS, THIRTY_DAYS_MS, cronJitterConfigSchema;
|
|
149
|
+
var init_cronJitterConfig = __esm(() => {
|
|
150
|
+
init_v4();
|
|
151
|
+
init_growthbook();
|
|
152
|
+
init_cronTasks();
|
|
153
|
+
init_lazySchema();
|
|
154
|
+
JITTER_CONFIG_REFRESH_MS = 60 * 1000;
|
|
155
|
+
HALF_HOUR_MS = 30 * 60 * 1000;
|
|
156
|
+
THIRTY_DAYS_MS = 30 * 24 * 60 * 60 * 1000;
|
|
157
|
+
cronJitterConfigSchema = lazySchema(() => exports_external.object({
|
|
158
|
+
recurringFrac: exports_external.number().min(0).max(1),
|
|
159
|
+
recurringCapMs: exports_external.number().int().min(0).max(HALF_HOUR_MS),
|
|
160
|
+
oneShotMaxMs: exports_external.number().int().min(0).max(HALF_HOUR_MS),
|
|
161
|
+
oneShotFloorMs: exports_external.number().int().min(0).max(HALF_HOUR_MS),
|
|
162
|
+
oneShotMinuteMod: exports_external.number().int().min(1).max(60),
|
|
163
|
+
recurringMaxAgeMs: exports_external.number().int().min(0).max(THIRTY_DAYS_MS).default(DEFAULT_CRON_JITTER_CONFIG.recurringMaxAgeMs)
|
|
164
|
+
}).refine((c) => c.oneShotFloorMs <= c.oneShotMaxMs));
|
|
165
|
+
});
|
|
166
|
+
|
|
167
|
+
// src/utils/cronTasksLock.ts
|
|
168
|
+
import { mkdir, readFile, unlink, writeFile } from "fs/promises";
|
|
169
|
+
import { dirname, join } from "path";
|
|
170
|
+
function getLockPath(dir) {
|
|
171
|
+
const root = dir ?? getProjectRoot();
|
|
172
|
+
return join(getPreferredProjectConfigDir(root), LOCK_FILE_NAME);
|
|
173
|
+
}
|
|
174
|
+
async function readLock(dir) {
|
|
175
|
+
let raw;
|
|
176
|
+
try {
|
|
177
|
+
raw = await readFile(getLockPath(dir), "utf8");
|
|
178
|
+
} catch {
|
|
179
|
+
return;
|
|
180
|
+
}
|
|
181
|
+
const result = schedulerLockSchema().safeParse(safeParseJSON(raw, false));
|
|
182
|
+
return result.success ? result.data : undefined;
|
|
183
|
+
}
|
|
184
|
+
async function tryCreateExclusive(lock, dir) {
|
|
185
|
+
const path = getLockPath(dir);
|
|
186
|
+
const body = jsonStringify(lock);
|
|
187
|
+
try {
|
|
188
|
+
await writeFile(path, body, { flag: "wx" });
|
|
189
|
+
return true;
|
|
190
|
+
} catch (e) {
|
|
191
|
+
const code = getErrnoCode(e);
|
|
192
|
+
if (code === "EEXIST")
|
|
193
|
+
return false;
|
|
194
|
+
if (code === "ENOENT") {
|
|
195
|
+
await mkdir(dirname(path), { recursive: true });
|
|
196
|
+
try {
|
|
197
|
+
await writeFile(path, body, { flag: "wx" });
|
|
198
|
+
return true;
|
|
199
|
+
} catch (retryErr) {
|
|
200
|
+
if (getErrnoCode(retryErr) === "EEXIST")
|
|
201
|
+
return false;
|
|
202
|
+
throw retryErr;
|
|
203
|
+
}
|
|
204
|
+
}
|
|
205
|
+
throw e;
|
|
206
|
+
}
|
|
207
|
+
}
|
|
208
|
+
function registerLockCleanup(opts) {
|
|
209
|
+
unregisterCleanup?.();
|
|
210
|
+
unregisterCleanup = registerCleanup(async () => {
|
|
211
|
+
await releaseSchedulerLock(opts);
|
|
212
|
+
});
|
|
213
|
+
}
|
|
214
|
+
async function tryAcquireSchedulerLock(opts) {
|
|
215
|
+
const dir = opts?.dir;
|
|
216
|
+
const sessionId = opts?.lockIdentity ?? getSessionId();
|
|
217
|
+
const lock = {
|
|
218
|
+
sessionId,
|
|
219
|
+
pid: process.pid,
|
|
220
|
+
acquiredAt: Date.now()
|
|
221
|
+
};
|
|
222
|
+
if (await tryCreateExclusive(lock, dir)) {
|
|
223
|
+
lastBlockedBy = undefined;
|
|
224
|
+
registerLockCleanup(opts);
|
|
225
|
+
logForDebugging(`[ScheduledTasks] acquired scheduler lock (PID ${process.pid})`);
|
|
226
|
+
return true;
|
|
227
|
+
}
|
|
228
|
+
const existing = await readLock(dir);
|
|
229
|
+
if (existing?.sessionId === sessionId) {
|
|
230
|
+
if (existing.pid !== process.pid) {
|
|
231
|
+
await writeFile(getLockPath(dir), jsonStringify(lock));
|
|
232
|
+
registerLockCleanup(opts);
|
|
233
|
+
}
|
|
234
|
+
return true;
|
|
235
|
+
}
|
|
236
|
+
if (existing && isProcessRunning(existing.pid)) {
|
|
237
|
+
if (lastBlockedBy !== existing.sessionId) {
|
|
238
|
+
lastBlockedBy = existing.sessionId;
|
|
239
|
+
logForDebugging(`[ScheduledTasks] scheduler lock held by session ${existing.sessionId} (PID ${existing.pid})`);
|
|
240
|
+
}
|
|
241
|
+
return false;
|
|
242
|
+
}
|
|
243
|
+
if (existing) {
|
|
244
|
+
logForDebugging(`[ScheduledTasks] recovering stale scheduler lock from PID ${existing.pid}`);
|
|
245
|
+
}
|
|
246
|
+
await unlink(getLockPath(dir)).catch(() => {});
|
|
247
|
+
if (await tryCreateExclusive(lock, dir)) {
|
|
248
|
+
lastBlockedBy = undefined;
|
|
249
|
+
registerLockCleanup(opts);
|
|
250
|
+
return true;
|
|
251
|
+
}
|
|
252
|
+
return false;
|
|
253
|
+
}
|
|
254
|
+
async function releaseSchedulerLock(opts) {
|
|
255
|
+
unregisterCleanup?.();
|
|
256
|
+
unregisterCleanup = undefined;
|
|
257
|
+
lastBlockedBy = undefined;
|
|
258
|
+
const dir = opts?.dir;
|
|
259
|
+
const sessionId = opts?.lockIdentity ?? getSessionId();
|
|
260
|
+
const existing = await readLock(dir);
|
|
261
|
+
if (!existing || existing.sessionId !== sessionId)
|
|
262
|
+
return;
|
|
263
|
+
try {
|
|
264
|
+
await unlink(getLockPath(dir));
|
|
265
|
+
logForDebugging("[ScheduledTasks] released scheduler lock");
|
|
266
|
+
} catch {}
|
|
267
|
+
}
|
|
268
|
+
var LOCK_FILE_NAME = "scheduled_tasks.lock", schedulerLockSchema, unregisterCleanup, lastBlockedBy;
|
|
269
|
+
var init_cronTasksLock = __esm(() => {
|
|
270
|
+
init_v4();
|
|
271
|
+
init_state();
|
|
272
|
+
init_cleanupRegistry();
|
|
273
|
+
init_debug();
|
|
274
|
+
init_errors();
|
|
275
|
+
init_genericProcessUtils();
|
|
276
|
+
init_json();
|
|
277
|
+
init_lazySchema();
|
|
278
|
+
init_redscopeCompat();
|
|
279
|
+
init_slowOperations();
|
|
280
|
+
schedulerLockSchema = lazySchema(() => exports_external.object({
|
|
281
|
+
sessionId: exports_external.string(),
|
|
282
|
+
pid: exports_external.number(),
|
|
283
|
+
acquiredAt: exports_external.number()
|
|
284
|
+
}));
|
|
285
|
+
});
|
|
286
|
+
|
|
287
|
+
// src/utils/cronScheduler.ts
|
|
288
|
+
var exports_cronScheduler = {};
|
|
289
|
+
__export(exports_cronScheduler, {
|
|
290
|
+
isRecurringTaskAged: () => isRecurringTaskAged,
|
|
291
|
+
createCronScheduler: () => createCronScheduler,
|
|
292
|
+
buildMissedTaskNotification: () => buildMissedTaskNotification
|
|
293
|
+
});
|
|
294
|
+
function isRecurringTaskAged(t, nowMs, maxAgeMs) {
|
|
295
|
+
if (maxAgeMs === 0)
|
|
296
|
+
return false;
|
|
297
|
+
return Boolean(t.recurring && !t.permanent && nowMs - t.createdAt >= maxAgeMs);
|
|
298
|
+
}
|
|
299
|
+
function createCronScheduler(options) {
|
|
300
|
+
const {
|
|
301
|
+
onFire,
|
|
302
|
+
isLoading,
|
|
303
|
+
assistantMode = false,
|
|
304
|
+
onFireTask,
|
|
305
|
+
onMissed,
|
|
306
|
+
dir,
|
|
307
|
+
lockIdentity,
|
|
308
|
+
getJitterConfig,
|
|
309
|
+
isKilled,
|
|
310
|
+
filter
|
|
311
|
+
} = options;
|
|
312
|
+
const lockOpts = dir || lockIdentity ? { dir, lockIdentity } : undefined;
|
|
313
|
+
let tasks = [];
|
|
314
|
+
const nextFireAt = new Map;
|
|
315
|
+
const missedAsked = new Set;
|
|
316
|
+
const inFlight = new Set;
|
|
317
|
+
let enablePoll = null;
|
|
318
|
+
let checkTimer = null;
|
|
319
|
+
let lockProbeTimer = null;
|
|
320
|
+
let watcher = null;
|
|
321
|
+
let stopped = false;
|
|
322
|
+
let isOwner = false;
|
|
323
|
+
async function load(initial) {
|
|
324
|
+
const next = await readCronTasks(dir);
|
|
325
|
+
if (stopped)
|
|
326
|
+
return;
|
|
327
|
+
tasks = next;
|
|
328
|
+
if (!initial)
|
|
329
|
+
return;
|
|
330
|
+
const now = Date.now();
|
|
331
|
+
const missed = findMissedTasks(next, now).filter((t) => !t.recurring && !missedAsked.has(t.id) && (!filter || filter(t)));
|
|
332
|
+
if (missed.length > 0) {
|
|
333
|
+
for (const t of missed) {
|
|
334
|
+
missedAsked.add(t.id);
|
|
335
|
+
nextFireAt.set(t.id, Infinity);
|
|
336
|
+
}
|
|
337
|
+
logEvent("tengu_scheduled_task_missed", {
|
|
338
|
+
count: missed.length,
|
|
339
|
+
taskIds: missed.map((t) => t.id).join(",")
|
|
340
|
+
});
|
|
341
|
+
if (onMissed) {
|
|
342
|
+
onMissed(missed);
|
|
343
|
+
} else {
|
|
344
|
+
onFire(buildMissedTaskNotification(missed));
|
|
345
|
+
}
|
|
346
|
+
removeCronTasks(missed.map((t) => t.id), dir).catch((e) => logForDebugging(`[ScheduledTasks] failed to remove missed tasks: ${e}`));
|
|
347
|
+
logForDebugging(`[ScheduledTasks] surfaced ${missed.length} missed one-shot task(s)`);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
function check() {
|
|
351
|
+
if (isKilled?.())
|
|
352
|
+
return;
|
|
353
|
+
if (isLoading() && !assistantMode)
|
|
354
|
+
return;
|
|
355
|
+
const now = Date.now();
|
|
356
|
+
const seen = new Set;
|
|
357
|
+
const firedFileRecurring = [];
|
|
358
|
+
const jitterCfg = getJitterConfig?.() ?? DEFAULT_CRON_JITTER_CONFIG;
|
|
359
|
+
function process2(t, isSession) {
|
|
360
|
+
if (filter && !filter(t))
|
|
361
|
+
return;
|
|
362
|
+
seen.add(t.id);
|
|
363
|
+
if (inFlight.has(t.id))
|
|
364
|
+
return;
|
|
365
|
+
let next = nextFireAt.get(t.id);
|
|
366
|
+
if (next === undefined) {
|
|
367
|
+
next = t.recurring ? jitteredNextCronRunMs(t.cron, t.lastFiredAt ?? t.createdAt, t.id, jitterCfg) ?? Infinity : oneShotJitteredNextCronRunMs(t.cron, t.createdAt, t.id, jitterCfg) ?? Infinity;
|
|
368
|
+
nextFireAt.set(t.id, next);
|
|
369
|
+
logForDebugging(`[ScheduledTasks] scheduled ${t.id} for ${next === Infinity ? "never" : new Date(next).toISOString()}`);
|
|
370
|
+
}
|
|
371
|
+
if (now < next)
|
|
372
|
+
return;
|
|
373
|
+
logForDebugging(`[ScheduledTasks] firing ${t.id}${t.recurring ? " (recurring)" : ""}`);
|
|
374
|
+
logEvent("tengu_scheduled_task_fire", {
|
|
375
|
+
recurring: t.recurring ?? false,
|
|
376
|
+
taskId: t.id
|
|
377
|
+
});
|
|
378
|
+
if (onFireTask) {
|
|
379
|
+
onFireTask(t);
|
|
380
|
+
} else {
|
|
381
|
+
onFire(t.prompt);
|
|
382
|
+
}
|
|
383
|
+
const aged = isRecurringTaskAged(t, now, jitterCfg.recurringMaxAgeMs);
|
|
384
|
+
if (aged) {
|
|
385
|
+
const ageHours = Math.floor((now - t.createdAt) / 1000 / 60 / 60);
|
|
386
|
+
logForDebugging(`[ScheduledTasks] recurring task ${t.id} aged out (${ageHours}h since creation), deleting after final fire`);
|
|
387
|
+
logEvent("tengu_scheduled_task_expired", {
|
|
388
|
+
taskId: t.id,
|
|
389
|
+
ageHours
|
|
390
|
+
});
|
|
391
|
+
}
|
|
392
|
+
if (t.recurring && !aged) {
|
|
393
|
+
const newNext = jitteredNextCronRunMs(t.cron, now, t.id, jitterCfg) ?? Infinity;
|
|
394
|
+
nextFireAt.set(t.id, newNext);
|
|
395
|
+
if (!isSession)
|
|
396
|
+
firedFileRecurring.push(t.id);
|
|
397
|
+
} else if (isSession) {
|
|
398
|
+
removeSessionCronTasks([t.id]);
|
|
399
|
+
nextFireAt.delete(t.id);
|
|
400
|
+
} else {
|
|
401
|
+
inFlight.add(t.id);
|
|
402
|
+
removeCronTasks([t.id], dir).catch((e) => logForDebugging(`[ScheduledTasks] failed to remove task ${t.id}: ${e}`)).finally(() => inFlight.delete(t.id));
|
|
403
|
+
nextFireAt.delete(t.id);
|
|
404
|
+
}
|
|
405
|
+
}
|
|
406
|
+
if (isOwner) {
|
|
407
|
+
for (const t of tasks)
|
|
408
|
+
process2(t, false);
|
|
409
|
+
if (firedFileRecurring.length > 0) {
|
|
410
|
+
for (const id of firedFileRecurring)
|
|
411
|
+
inFlight.add(id);
|
|
412
|
+
markCronTasksFired(firedFileRecurring, now, dir).catch((e) => logForDebugging(`[ScheduledTasks] failed to persist lastFiredAt: ${e}`)).finally(() => {
|
|
413
|
+
for (const id of firedFileRecurring)
|
|
414
|
+
inFlight.delete(id);
|
|
415
|
+
});
|
|
416
|
+
}
|
|
417
|
+
}
|
|
418
|
+
if (dir === undefined) {
|
|
419
|
+
for (const t of getSessionCronTasks())
|
|
420
|
+
process2(t, true);
|
|
421
|
+
}
|
|
422
|
+
if (seen.size === 0) {
|
|
423
|
+
nextFireAt.clear();
|
|
424
|
+
return;
|
|
425
|
+
}
|
|
426
|
+
for (const id of nextFireAt.keys()) {
|
|
427
|
+
if (!seen.has(id))
|
|
428
|
+
nextFireAt.delete(id);
|
|
429
|
+
}
|
|
430
|
+
}
|
|
431
|
+
async function enable() {
|
|
432
|
+
if (stopped)
|
|
433
|
+
return;
|
|
434
|
+
if (enablePoll) {
|
|
435
|
+
clearInterval(enablePoll);
|
|
436
|
+
enablePoll = null;
|
|
437
|
+
}
|
|
438
|
+
const { default: chokidar } = await import("./chunk-2mwnwp0n.js");
|
|
439
|
+
if (stopped)
|
|
440
|
+
return;
|
|
441
|
+
isOwner = await tryAcquireSchedulerLock(lockOpts).catch(() => false);
|
|
442
|
+
if (stopped) {
|
|
443
|
+
if (isOwner) {
|
|
444
|
+
isOwner = false;
|
|
445
|
+
releaseSchedulerLock(lockOpts);
|
|
446
|
+
}
|
|
447
|
+
return;
|
|
448
|
+
}
|
|
449
|
+
if (!isOwner) {
|
|
450
|
+
lockProbeTimer = setInterval(() => {
|
|
451
|
+
tryAcquireSchedulerLock(lockOpts).then((owned) => {
|
|
452
|
+
if (stopped) {
|
|
453
|
+
if (owned)
|
|
454
|
+
releaseSchedulerLock(lockOpts);
|
|
455
|
+
return;
|
|
456
|
+
}
|
|
457
|
+
if (owned) {
|
|
458
|
+
isOwner = true;
|
|
459
|
+
if (lockProbeTimer) {
|
|
460
|
+
clearInterval(lockProbeTimer);
|
|
461
|
+
lockProbeTimer = null;
|
|
462
|
+
}
|
|
463
|
+
}
|
|
464
|
+
}).catch((e) => logForDebugging(String(e), { level: "error" }));
|
|
465
|
+
}, LOCK_PROBE_INTERVAL_MS);
|
|
466
|
+
lockProbeTimer.unref?.();
|
|
467
|
+
}
|
|
468
|
+
load(true);
|
|
469
|
+
const paths = getCronFilePaths(dir);
|
|
470
|
+
watcher = chokidar.watch(paths, {
|
|
471
|
+
persistent: false,
|
|
472
|
+
ignoreInitial: true,
|
|
473
|
+
awaitWriteFinish: { stabilityThreshold: FILE_STABILITY_MS },
|
|
474
|
+
ignorePermissionErrors: true
|
|
475
|
+
});
|
|
476
|
+
watcher.on("add", () => void load(false));
|
|
477
|
+
watcher.on("change", () => void load(false));
|
|
478
|
+
watcher.on("unlink", () => void load(false));
|
|
479
|
+
checkTimer = setInterval(check, CHECK_INTERVAL_MS);
|
|
480
|
+
checkTimer.unref?.();
|
|
481
|
+
}
|
|
482
|
+
return {
|
|
483
|
+
start() {
|
|
484
|
+
stopped = false;
|
|
485
|
+
if (dir !== undefined) {
|
|
486
|
+
logForDebugging(`[ScheduledTasks] scheduler start() \u2014 dir=${dir}, hasTasks=${hasCronTasksSync(dir)}`);
|
|
487
|
+
enable();
|
|
488
|
+
return;
|
|
489
|
+
}
|
|
490
|
+
logForDebugging(`[ScheduledTasks] scheduler start() \u2014 enabled=${getScheduledTasksEnabled()}, hasTasks=${hasCronTasksSync()}`);
|
|
491
|
+
if (!getScheduledTasksEnabled() && (assistantMode || hasCronTasksSync())) {
|
|
492
|
+
setScheduledTasksEnabled(true);
|
|
493
|
+
}
|
|
494
|
+
if (getScheduledTasksEnabled()) {
|
|
495
|
+
enable();
|
|
496
|
+
return;
|
|
497
|
+
}
|
|
498
|
+
enablePoll = setInterval((en) => {
|
|
499
|
+
if (getScheduledTasksEnabled())
|
|
500
|
+
en();
|
|
501
|
+
}, CHECK_INTERVAL_MS, enable);
|
|
502
|
+
enablePoll.unref?.();
|
|
503
|
+
},
|
|
504
|
+
stop() {
|
|
505
|
+
stopped = true;
|
|
506
|
+
if (enablePoll) {
|
|
507
|
+
clearInterval(enablePoll);
|
|
508
|
+
enablePoll = null;
|
|
509
|
+
}
|
|
510
|
+
if (checkTimer) {
|
|
511
|
+
clearInterval(checkTimer);
|
|
512
|
+
checkTimer = null;
|
|
513
|
+
}
|
|
514
|
+
if (lockProbeTimer) {
|
|
515
|
+
clearInterval(lockProbeTimer);
|
|
516
|
+
lockProbeTimer = null;
|
|
517
|
+
}
|
|
518
|
+
watcher?.close();
|
|
519
|
+
watcher = null;
|
|
520
|
+
if (isOwner) {
|
|
521
|
+
isOwner = false;
|
|
522
|
+
releaseSchedulerLock(lockOpts);
|
|
523
|
+
}
|
|
524
|
+
},
|
|
525
|
+
getNextFireTime() {
|
|
526
|
+
let min = Infinity;
|
|
527
|
+
for (const t of nextFireAt.values()) {
|
|
528
|
+
if (t < min)
|
|
529
|
+
min = t;
|
|
530
|
+
}
|
|
531
|
+
return min === Infinity ? null : min;
|
|
532
|
+
}
|
|
533
|
+
};
|
|
534
|
+
}
|
|
535
|
+
function buildMissedTaskNotification(missed) {
|
|
536
|
+
const plural = missed.length > 1;
|
|
537
|
+
const header = `The following one-shot scheduled task${plural ? "s were" : " was"} missed while Claude was not running. ${plural ? "They have" : "It has"} already been removed from scheduled_tasks.json.
|
|
538
|
+
|
|
539
|
+
Do NOT execute ${plural ? "these prompts" : "this prompt"} yet. First use the AskUserQuestion tool to ask whether to run ${plural ? "each one" : "it"} now. Only execute if the user confirms.`;
|
|
540
|
+
const blocks = missed.map((t) => {
|
|
541
|
+
const meta = `[${cronToHuman(t.cron)}, created ${new Date(t.createdAt).toLocaleString()}]`;
|
|
542
|
+
const longestRun = (t.prompt.match(/`+/g) ?? []).reduce((max, run) => Math.max(max, run.length), 0);
|
|
543
|
+
const fence = "`".repeat(Math.max(3, longestRun + 1));
|
|
544
|
+
return `${meta}
|
|
545
|
+
${fence}
|
|
546
|
+
${t.prompt}
|
|
547
|
+
${fence}`;
|
|
548
|
+
});
|
|
549
|
+
return `${header}
|
|
550
|
+
|
|
551
|
+
${blocks.join(`
|
|
552
|
+
|
|
553
|
+
`)}`;
|
|
554
|
+
}
|
|
555
|
+
var CHECK_INTERVAL_MS = 1000, FILE_STABILITY_MS = 300, LOCK_PROBE_INTERVAL_MS = 5000;
|
|
556
|
+
var init_cronScheduler = __esm(() => {
|
|
557
|
+
init_state();
|
|
558
|
+
init_analytics();
|
|
559
|
+
init_cron();
|
|
560
|
+
init_cronTasks();
|
|
561
|
+
init_cronTasksLock();
|
|
562
|
+
init_debug();
|
|
563
|
+
});
|
|
564
|
+
|
|
565
|
+
// src/bridge/inboundMessages.ts
|
|
566
|
+
init_imageResizer();
|
|
567
|
+
function extractInboundMessageFields(msg) {
|
|
568
|
+
if (msg.type !== "user")
|
|
569
|
+
return;
|
|
570
|
+
const content = msg.message?.content;
|
|
571
|
+
if (!content)
|
|
572
|
+
return;
|
|
573
|
+
if (Array.isArray(content) && content.length === 0)
|
|
574
|
+
return;
|
|
575
|
+
const uuid = "uuid" in msg && typeof msg.uuid === "string" ? msg.uuid : undefined;
|
|
576
|
+
return {
|
|
577
|
+
content: Array.isArray(content) ? normalizeImageBlocks(content) : content,
|
|
578
|
+
uuid
|
|
579
|
+
};
|
|
580
|
+
}
|
|
581
|
+
function normalizeImageBlocks(blocks) {
|
|
582
|
+
if (!blocks.some(isMalformedBase64Image))
|
|
583
|
+
return blocks;
|
|
584
|
+
return blocks.map((block) => {
|
|
585
|
+
if (!isMalformedBase64Image(block))
|
|
586
|
+
return block;
|
|
587
|
+
const src = block.source;
|
|
588
|
+
const mediaType = typeof src.mediaType === "string" && src.mediaType ? src.mediaType : detectImageFormatFromBase64(block.source.data);
|
|
589
|
+
return {
|
|
590
|
+
...block,
|
|
591
|
+
source: {
|
|
592
|
+
type: "base64",
|
|
593
|
+
media_type: mediaType,
|
|
594
|
+
data: block.source.data
|
|
595
|
+
}
|
|
596
|
+
};
|
|
597
|
+
});
|
|
598
|
+
}
|
|
599
|
+
function isMalformedBase64Image(block) {
|
|
600
|
+
if (block.type !== "image" || block.source?.type !== "base64")
|
|
601
|
+
return false;
|
|
602
|
+
return !block.source.media_type;
|
|
603
|
+
}
|
|
604
|
+
|
|
605
|
+
// src/utils/permissions/PermissionPromptToolResultSchema.ts
|
|
606
|
+
init_v4();
|
|
607
|
+
init_debug();
|
|
608
|
+
init_lazySchema();
|
|
609
|
+
init_PermissionUpdate();
|
|
610
|
+
init_PermissionUpdateSchema();
|
|
611
|
+
var inputSchema = lazySchema(() => v4_default.object({
|
|
612
|
+
tool_name: v4_default.string().describe("The name of the tool requesting permission"),
|
|
613
|
+
input: v4_default.record(v4_default.string(), v4_default.unknown()).describe("The input for the tool"),
|
|
614
|
+
tool_use_id: v4_default.string().optional().describe("The unique tool use request ID")
|
|
615
|
+
}));
|
|
616
|
+
var decisionClassificationField = lazySchema(() => v4_default.enum(["user_temporary", "user_permanent", "user_reject"]).optional().catch(undefined));
|
|
617
|
+
var PermissionAllowResultSchema = lazySchema(() => v4_default.object({
|
|
618
|
+
behavior: v4_default.literal("allow"),
|
|
619
|
+
updatedInput: v4_default.record(v4_default.string(), v4_default.unknown()),
|
|
620
|
+
updatedPermissions: v4_default.array(permissionUpdateSchema()).optional().catch((ctx) => {
|
|
621
|
+
logForDebugging(`Malformed updatedPermissions from SDK host ignored: ${ctx.error.issues[0]?.message ?? "unknown"}`, { level: "warn" });
|
|
622
|
+
return;
|
|
623
|
+
}),
|
|
624
|
+
toolUseID: v4_default.string().optional(),
|
|
625
|
+
decisionClassification: decisionClassificationField()
|
|
626
|
+
}));
|
|
627
|
+
var PermissionDenyResultSchema = lazySchema(() => v4_default.object({
|
|
628
|
+
behavior: v4_default.literal("deny"),
|
|
629
|
+
message: v4_default.string(),
|
|
630
|
+
interrupt: v4_default.boolean().optional(),
|
|
631
|
+
toolUseID: v4_default.string().optional(),
|
|
632
|
+
decisionClassification: decisionClassificationField()
|
|
633
|
+
}));
|
|
634
|
+
var outputSchema = lazySchema(() => v4_default.union([PermissionAllowResultSchema(), PermissionDenyResultSchema()]));
|
|
635
|
+
function permissionPromptToolResultToPermissionDecision(result, tool, input, toolUseContext) {
|
|
636
|
+
const decisionReason = {
|
|
637
|
+
type: "permissionPromptTool",
|
|
638
|
+
permissionPromptToolName: tool.name,
|
|
639
|
+
toolResult: result
|
|
640
|
+
};
|
|
641
|
+
if (result.behavior === "allow") {
|
|
642
|
+
const updatedPermissions = result.updatedPermissions;
|
|
643
|
+
if (updatedPermissions) {
|
|
644
|
+
toolUseContext.setAppState((prev) => ({
|
|
645
|
+
...prev,
|
|
646
|
+
toolPermissionContext: applyPermissionUpdates(prev.toolPermissionContext, updatedPermissions)
|
|
647
|
+
}));
|
|
648
|
+
persistPermissionUpdates(updatedPermissions);
|
|
649
|
+
}
|
|
650
|
+
const updatedInput = Object.keys(result.updatedInput).length > 0 ? result.updatedInput : input;
|
|
651
|
+
return {
|
|
652
|
+
...result,
|
|
653
|
+
updatedInput,
|
|
654
|
+
decisionReason
|
|
655
|
+
};
|
|
656
|
+
} else if (result.behavior === "deny" && result.interrupt) {
|
|
657
|
+
logForDebugging(`SDK permission prompt deny+interrupt: tool=${tool.name} message=${result.message}`);
|
|
658
|
+
toolUseContext.abortController.abort();
|
|
659
|
+
}
|
|
660
|
+
return {
|
|
661
|
+
...result,
|
|
662
|
+
decisionReason
|
|
663
|
+
};
|
|
664
|
+
}
|
|
665
|
+
|
|
666
|
+
// src/cli/structuredIO.ts
|
|
667
|
+
import { randomUUID } from "crypto";
|
|
668
|
+
|
|
669
|
+
// src/entrypoints/sdk/controlSchemas.ts
|
|
670
|
+
init_v4();
|
|
671
|
+
init_lazySchema();
|
|
672
|
+
init_coreSchemas();
|
|
673
|
+
var JSONRPCMessagePlaceholder = lazySchema(() => exports_external.unknown());
|
|
674
|
+
var SDKHookCallbackMatcherSchema = lazySchema(() => exports_external.object({
|
|
675
|
+
matcher: exports_external.string().optional(),
|
|
676
|
+
hookCallbackIds: exports_external.array(exports_external.string()),
|
|
677
|
+
timeout: exports_external.number().optional()
|
|
678
|
+
}).describe("Configuration for matching and routing hook callbacks."));
|
|
679
|
+
var SDKControlInitializeRequestSchema = lazySchema(() => exports_external.object({
|
|
680
|
+
subtype: exports_external.literal("initialize"),
|
|
681
|
+
hooks: exports_external.record(HookEventSchema(), exports_external.array(SDKHookCallbackMatcherSchema())).optional(),
|
|
682
|
+
sdkMcpServers: exports_external.array(exports_external.string()).optional(),
|
|
683
|
+
jsonSchema: exports_external.record(exports_external.string(), exports_external.unknown()).optional(),
|
|
684
|
+
systemPrompt: exports_external.string().optional(),
|
|
685
|
+
appendSystemPrompt: exports_external.string().optional(),
|
|
686
|
+
agents: exports_external.record(exports_external.string(), AgentDefinitionSchema()).optional(),
|
|
687
|
+
promptSuggestions: exports_external.boolean().optional(),
|
|
688
|
+
agentProgressSummaries: exports_external.boolean().optional()
|
|
689
|
+
}).describe("Initializes the SDK session with hooks, MCP servers, and agent configuration."));
|
|
690
|
+
var SDKControlInitializeResponseSchema = lazySchema(() => exports_external.object({
|
|
691
|
+
commands: exports_external.array(SlashCommandSchema()),
|
|
692
|
+
agents: exports_external.array(AgentInfoSchema()),
|
|
693
|
+
output_style: exports_external.string(),
|
|
694
|
+
available_output_styles: exports_external.array(exports_external.string()),
|
|
695
|
+
models: exports_external.array(ModelInfoSchema()),
|
|
696
|
+
account: AccountInfoSchema(),
|
|
697
|
+
pid: exports_external.number().optional().describe("@internal CLI process PID for tmux socket isolation"),
|
|
698
|
+
fast_mode_state: FastModeStateSchema().optional()
|
|
699
|
+
}).describe("Response from session initialization with available commands, models, and account info."));
|
|
700
|
+
var SDKControlInterruptRequestSchema = lazySchema(() => exports_external.object({
|
|
701
|
+
subtype: exports_external.literal("interrupt")
|
|
702
|
+
}).describe("Interrupts the currently running conversation turn."));
|
|
703
|
+
var SDKControlPermissionRequestSchema = lazySchema(() => exports_external.object({
|
|
704
|
+
subtype: exports_external.literal("can_use_tool"),
|
|
705
|
+
tool_name: exports_external.string(),
|
|
706
|
+
input: exports_external.record(exports_external.string(), exports_external.unknown()),
|
|
707
|
+
permission_suggestions: exports_external.array(PermissionUpdateSchema()).optional(),
|
|
708
|
+
blocked_path: exports_external.string().optional(),
|
|
709
|
+
decision_reason: exports_external.string().optional(),
|
|
710
|
+
title: exports_external.string().optional(),
|
|
711
|
+
display_name: exports_external.string().optional(),
|
|
712
|
+
tool_use_id: exports_external.string(),
|
|
713
|
+
agent_id: exports_external.string().optional(),
|
|
714
|
+
description: exports_external.string().optional()
|
|
715
|
+
}).describe("Requests permission to use a tool with the given input."));
|
|
716
|
+
var SDKControlSetPermissionModeRequestSchema = lazySchema(() => exports_external.object({
|
|
717
|
+
subtype: exports_external.literal("set_permission_mode"),
|
|
718
|
+
mode: PermissionModeSchema(),
|
|
719
|
+
ultraplan: exports_external.boolean().optional().describe("@internal CCR ultraplan session marker.")
|
|
720
|
+
}).describe("Sets the permission mode for tool execution handling."));
|
|
721
|
+
var SDKControlSetModelRequestSchema = lazySchema(() => exports_external.object({
|
|
722
|
+
subtype: exports_external.literal("set_model"),
|
|
723
|
+
model: exports_external.string().optional()
|
|
724
|
+
}).describe("Sets the model to use for subsequent conversation turns."));
|
|
725
|
+
var SDKControlSetMaxThinkingTokensRequestSchema = lazySchema(() => exports_external.object({
|
|
726
|
+
subtype: exports_external.literal("set_max_thinking_tokens"),
|
|
727
|
+
max_thinking_tokens: exports_external.number().nullable()
|
|
728
|
+
}).describe("Sets the maximum number of thinking tokens for extended thinking."));
|
|
729
|
+
var SDKControlMcpStatusRequestSchema = lazySchema(() => exports_external.object({
|
|
730
|
+
subtype: exports_external.literal("mcp_status")
|
|
731
|
+
}).describe("Requests the current status of all MCP server connections."));
|
|
732
|
+
var SDKControlMcpStatusResponseSchema = lazySchema(() => exports_external.object({
|
|
733
|
+
mcpServers: exports_external.array(McpServerStatusSchema())
|
|
734
|
+
}).describe("Response containing the current status of all MCP server connections."));
|
|
735
|
+
var SDKControlGetContextUsageRequestSchema = lazySchema(() => exports_external.object({
|
|
736
|
+
subtype: exports_external.literal("get_context_usage")
|
|
737
|
+
}).describe("Requests a breakdown of current context window usage by category."));
|
|
738
|
+
var ContextCategorySchema = lazySchema(() => exports_external.object({
|
|
739
|
+
name: exports_external.string(),
|
|
740
|
+
tokens: exports_external.number(),
|
|
741
|
+
color: exports_external.string(),
|
|
742
|
+
isDeferred: exports_external.boolean().optional()
|
|
743
|
+
}));
|
|
744
|
+
var ContextGridSquareSchema = lazySchema(() => exports_external.object({
|
|
745
|
+
color: exports_external.string(),
|
|
746
|
+
isFilled: exports_external.boolean(),
|
|
747
|
+
categoryName: exports_external.string(),
|
|
748
|
+
tokens: exports_external.number(),
|
|
749
|
+
percentage: exports_external.number(),
|
|
750
|
+
squareFullness: exports_external.number()
|
|
751
|
+
}));
|
|
752
|
+
var SDKControlGetContextUsageResponseSchema = lazySchema(() => exports_external.object({
|
|
753
|
+
categories: exports_external.array(ContextCategorySchema()),
|
|
754
|
+
totalTokens: exports_external.number(),
|
|
755
|
+
maxTokens: exports_external.number(),
|
|
756
|
+
rawMaxTokens: exports_external.number(),
|
|
757
|
+
percentage: exports_external.number(),
|
|
758
|
+
gridRows: exports_external.array(exports_external.array(ContextGridSquareSchema())),
|
|
759
|
+
model: exports_external.string(),
|
|
760
|
+
memoryFiles: exports_external.array(exports_external.object({
|
|
761
|
+
path: exports_external.string(),
|
|
762
|
+
type: exports_external.string(),
|
|
763
|
+
tokens: exports_external.number()
|
|
764
|
+
})),
|
|
765
|
+
mcpTools: exports_external.array(exports_external.object({
|
|
766
|
+
name: exports_external.string(),
|
|
767
|
+
serverName: exports_external.string(),
|
|
768
|
+
tokens: exports_external.number(),
|
|
769
|
+
isLoaded: exports_external.boolean().optional()
|
|
770
|
+
})),
|
|
771
|
+
deferredBuiltinTools: exports_external.array(exports_external.object({
|
|
772
|
+
name: exports_external.string(),
|
|
773
|
+
tokens: exports_external.number(),
|
|
774
|
+
isLoaded: exports_external.boolean()
|
|
775
|
+
})).optional(),
|
|
776
|
+
systemTools: exports_external.array(exports_external.object({ name: exports_external.string(), tokens: exports_external.number() })).optional(),
|
|
777
|
+
systemPromptSections: exports_external.array(exports_external.object({ name: exports_external.string(), tokens: exports_external.number() })).optional(),
|
|
778
|
+
agents: exports_external.array(exports_external.object({
|
|
779
|
+
agentType: exports_external.string(),
|
|
780
|
+
source: exports_external.string(),
|
|
781
|
+
tokens: exports_external.number()
|
|
782
|
+
})),
|
|
783
|
+
slashCommands: exports_external.object({
|
|
784
|
+
totalCommands: exports_external.number(),
|
|
785
|
+
includedCommands: exports_external.number(),
|
|
786
|
+
tokens: exports_external.number()
|
|
787
|
+
}).optional(),
|
|
788
|
+
skills: exports_external.object({
|
|
789
|
+
totalSkills: exports_external.number(),
|
|
790
|
+
includedSkills: exports_external.number(),
|
|
791
|
+
tokens: exports_external.number(),
|
|
792
|
+
skillFrontmatter: exports_external.array(exports_external.object({
|
|
793
|
+
name: exports_external.string(),
|
|
794
|
+
source: exports_external.string(),
|
|
795
|
+
tokens: exports_external.number()
|
|
796
|
+
}))
|
|
797
|
+
}).optional(),
|
|
798
|
+
autoCompactThreshold: exports_external.number().optional(),
|
|
799
|
+
isAutoCompactEnabled: exports_external.boolean(),
|
|
800
|
+
messageBreakdown: exports_external.object({
|
|
801
|
+
toolCallTokens: exports_external.number(),
|
|
802
|
+
toolResultTokens: exports_external.number(),
|
|
803
|
+
attachmentTokens: exports_external.number(),
|
|
804
|
+
assistantMessageTokens: exports_external.number(),
|
|
805
|
+
userMessageTokens: exports_external.number(),
|
|
806
|
+
toolCallsByType: exports_external.array(exports_external.object({
|
|
807
|
+
name: exports_external.string(),
|
|
808
|
+
callTokens: exports_external.number(),
|
|
809
|
+
resultTokens: exports_external.number()
|
|
810
|
+
})),
|
|
811
|
+
attachmentsByType: exports_external.array(exports_external.object({ name: exports_external.string(), tokens: exports_external.number() }))
|
|
812
|
+
}).optional(),
|
|
813
|
+
apiUsage: exports_external.object({
|
|
814
|
+
input_tokens: exports_external.number(),
|
|
815
|
+
output_tokens: exports_external.number(),
|
|
816
|
+
cache_creation_input_tokens: exports_external.number(),
|
|
817
|
+
cache_read_input_tokens: exports_external.number()
|
|
818
|
+
}).nullable()
|
|
819
|
+
}).describe("Breakdown of current context window usage by category (system prompt, tools, messages, etc.)."));
|
|
820
|
+
var SDKControlRewindFilesRequestSchema = lazySchema(() => exports_external.object({
|
|
821
|
+
subtype: exports_external.literal("rewind_files"),
|
|
822
|
+
user_message_id: exports_external.string(),
|
|
823
|
+
dry_run: exports_external.boolean().optional()
|
|
824
|
+
}).describe("Rewinds file changes made since a specific user message."));
|
|
825
|
+
var SDKControlRewindFilesResponseSchema = lazySchema(() => exports_external.object({
|
|
826
|
+
canRewind: exports_external.boolean(),
|
|
827
|
+
error: exports_external.string().optional(),
|
|
828
|
+
filesChanged: exports_external.array(exports_external.string()).optional(),
|
|
829
|
+
insertions: exports_external.number().optional(),
|
|
830
|
+
deletions: exports_external.number().optional()
|
|
831
|
+
}).describe("Result of a rewindFiles operation."));
|
|
832
|
+
var SDKControlCancelAsyncMessageRequestSchema = lazySchema(() => exports_external.object({
|
|
833
|
+
subtype: exports_external.literal("cancel_async_message"),
|
|
834
|
+
message_uuid: exports_external.string()
|
|
835
|
+
}).describe("Drops a pending async user message from the command queue by uuid. No-op if already dequeued for execution."));
|
|
836
|
+
var SDKControlCancelAsyncMessageResponseSchema = lazySchema(() => exports_external.object({
|
|
837
|
+
cancelled: exports_external.boolean()
|
|
838
|
+
}).describe("Result of a cancel_async_message operation. cancelled=false means the message was not in the queue (already dequeued or never enqueued)."));
|
|
839
|
+
var SDKControlSeedReadStateRequestSchema = lazySchema(() => exports_external.object({
|
|
840
|
+
subtype: exports_external.literal("seed_read_state"),
|
|
841
|
+
path: exports_external.string(),
|
|
842
|
+
mtime: exports_external.number()
|
|
843
|
+
}).describe("Seeds the readFileState cache with a path+mtime entry. Use when a prior Read was removed from context (e.g. by snip) so Edit validation would fail despite the client having observed the Read. The mtime lets the CLI detect if the file changed since the seeded Read \u2014 same staleness check as the normal path."));
|
|
844
|
+
var SDKHookCallbackRequestSchema = lazySchema(() => exports_external.object({
|
|
845
|
+
subtype: exports_external.literal("hook_callback"),
|
|
846
|
+
callback_id: exports_external.string(),
|
|
847
|
+
input: HookInputSchema(),
|
|
848
|
+
tool_use_id: exports_external.string().optional()
|
|
849
|
+
}).describe("Delivers a hook callback with its input data."));
|
|
850
|
+
var SDKControlMcpMessageRequestSchema = lazySchema(() => exports_external.object({
|
|
851
|
+
subtype: exports_external.literal("mcp_message"),
|
|
852
|
+
server_name: exports_external.string(),
|
|
853
|
+
message: JSONRPCMessagePlaceholder()
|
|
854
|
+
}).describe("Sends a JSON-RPC message to a specific MCP server."));
|
|
855
|
+
var SDKControlMcpSetServersRequestSchema = lazySchema(() => exports_external.object({
|
|
856
|
+
subtype: exports_external.literal("mcp_set_servers"),
|
|
857
|
+
servers: exports_external.record(exports_external.string(), McpServerConfigForProcessTransportSchema())
|
|
858
|
+
}).describe("Replaces the set of dynamically managed MCP servers."));
|
|
859
|
+
var SDKControlMcpSetServersResponseSchema = lazySchema(() => exports_external.object({
|
|
860
|
+
added: exports_external.array(exports_external.string()),
|
|
861
|
+
removed: exports_external.array(exports_external.string()),
|
|
862
|
+
errors: exports_external.record(exports_external.string(), exports_external.string())
|
|
863
|
+
}).describe("Result of replacing the set of dynamically managed MCP servers."));
|
|
864
|
+
var SDKControlReloadPluginsRequestSchema = lazySchema(() => exports_external.object({
|
|
865
|
+
subtype: exports_external.literal("reload_plugins")
|
|
866
|
+
}).describe("Reloads plugins from disk and returns the refreshed session components."));
|
|
867
|
+
var SDKControlReloadPluginsResponseSchema = lazySchema(() => exports_external.object({
|
|
868
|
+
commands: exports_external.array(SlashCommandSchema()),
|
|
869
|
+
agents: exports_external.array(AgentInfoSchema()),
|
|
870
|
+
plugins: exports_external.array(exports_external.object({
|
|
871
|
+
name: exports_external.string(),
|
|
872
|
+
path: exports_external.string(),
|
|
873
|
+
source: exports_external.string().optional()
|
|
874
|
+
})),
|
|
875
|
+
mcpServers: exports_external.array(McpServerStatusSchema()),
|
|
876
|
+
error_count: exports_external.number()
|
|
877
|
+
}).describe("Refreshed commands, agents, plugins, and MCP server status after reload."));
|
|
878
|
+
var SDKControlMcpReconnectRequestSchema = lazySchema(() => exports_external.object({
|
|
879
|
+
subtype: exports_external.literal("mcp_reconnect"),
|
|
880
|
+
serverName: exports_external.string()
|
|
881
|
+
}).describe("Reconnects a disconnected or failed MCP server."));
|
|
882
|
+
var SDKControlMcpToggleRequestSchema = lazySchema(() => exports_external.object({
|
|
883
|
+
subtype: exports_external.literal("mcp_toggle"),
|
|
884
|
+
serverName: exports_external.string(),
|
|
885
|
+
enabled: exports_external.boolean()
|
|
886
|
+
}).describe("Enables or disables an MCP server."));
|
|
887
|
+
var SDKControlStopTaskRequestSchema = lazySchema(() => exports_external.object({
|
|
888
|
+
subtype: exports_external.literal("stop_task"),
|
|
889
|
+
task_id: exports_external.string()
|
|
890
|
+
}).describe("Stops a running task."));
|
|
891
|
+
var SDKControlApplyFlagSettingsRequestSchema = lazySchema(() => exports_external.object({
|
|
892
|
+
subtype: exports_external.literal("apply_flag_settings"),
|
|
893
|
+
settings: exports_external.record(exports_external.string(), exports_external.unknown())
|
|
894
|
+
}).describe("Merges the provided settings into the flag settings layer, updating the active configuration."));
|
|
895
|
+
var SDKControlGetSettingsRequestSchema = lazySchema(() => exports_external.object({
|
|
896
|
+
subtype: exports_external.literal("get_settings")
|
|
897
|
+
}).describe("Returns the effective merged settings and the raw per-source settings."));
|
|
898
|
+
var SDKControlGetSettingsResponseSchema = lazySchema(() => exports_external.object({
|
|
899
|
+
effective: exports_external.record(exports_external.string(), exports_external.unknown()),
|
|
900
|
+
sources: exports_external.array(exports_external.object({
|
|
901
|
+
source: exports_external.enum([
|
|
902
|
+
"userSettings",
|
|
903
|
+
"projectSettings",
|
|
904
|
+
"localSettings",
|
|
905
|
+
"flagSettings",
|
|
906
|
+
"policySettings"
|
|
907
|
+
]),
|
|
908
|
+
settings: exports_external.record(exports_external.string(), exports_external.unknown())
|
|
909
|
+
})).describe("Ordered low-to-high priority \u2014 later entries override earlier ones."),
|
|
910
|
+
applied: exports_external.object({
|
|
911
|
+
model: exports_external.string(),
|
|
912
|
+
effort: exports_external.enum(["low", "medium", "high", "xhigh", "max"]).nullable()
|
|
913
|
+
}).optional().describe("Runtime-resolved values after env overrides, session state, and model-specific defaults are applied. Unlike `effective` (disk merge), these reflect what will actually be sent to the API.")
|
|
914
|
+
}).describe("Effective merged settings plus raw per-source settings in merge order."));
|
|
915
|
+
var SDKControlElicitationRequestSchema = lazySchema(() => exports_external.object({
|
|
916
|
+
subtype: exports_external.literal("elicitation"),
|
|
917
|
+
mcp_server_name: exports_external.string(),
|
|
918
|
+
message: exports_external.string(),
|
|
919
|
+
mode: exports_external.enum(["form", "url"]).optional(),
|
|
920
|
+
url: exports_external.string().optional(),
|
|
921
|
+
elicitation_id: exports_external.string().optional(),
|
|
922
|
+
requested_schema: exports_external.record(exports_external.string(), exports_external.unknown()).optional()
|
|
923
|
+
}).describe("Requests the SDK consumer to handle an MCP elicitation (user input request)."));
|
|
924
|
+
var SDKControlElicitationResponseSchema = lazySchema(() => exports_external.object({
|
|
925
|
+
action: exports_external.enum(["accept", "decline", "cancel"]),
|
|
926
|
+
content: exports_external.record(exports_external.string(), exports_external.unknown()).optional()
|
|
927
|
+
}).describe("Response from the SDK consumer for an elicitation request."));
|
|
928
|
+
var SDKControlRequestInnerSchema = lazySchema(() => exports_external.union([
|
|
929
|
+
SDKControlInterruptRequestSchema(),
|
|
930
|
+
SDKControlPermissionRequestSchema(),
|
|
931
|
+
SDKControlInitializeRequestSchema(),
|
|
932
|
+
SDKControlSetPermissionModeRequestSchema(),
|
|
933
|
+
SDKControlSetModelRequestSchema(),
|
|
934
|
+
SDKControlSetMaxThinkingTokensRequestSchema(),
|
|
935
|
+
SDKControlMcpStatusRequestSchema(),
|
|
936
|
+
SDKControlGetContextUsageRequestSchema(),
|
|
937
|
+
SDKHookCallbackRequestSchema(),
|
|
938
|
+
SDKControlMcpMessageRequestSchema(),
|
|
939
|
+
SDKControlRewindFilesRequestSchema(),
|
|
940
|
+
SDKControlCancelAsyncMessageRequestSchema(),
|
|
941
|
+
SDKControlSeedReadStateRequestSchema(),
|
|
942
|
+
SDKControlMcpSetServersRequestSchema(),
|
|
943
|
+
SDKControlReloadPluginsRequestSchema(),
|
|
944
|
+
SDKControlMcpReconnectRequestSchema(),
|
|
945
|
+
SDKControlMcpToggleRequestSchema(),
|
|
946
|
+
SDKControlStopTaskRequestSchema(),
|
|
947
|
+
SDKControlApplyFlagSettingsRequestSchema(),
|
|
948
|
+
SDKControlGetSettingsRequestSchema(),
|
|
949
|
+
SDKControlElicitationRequestSchema()
|
|
950
|
+
]));
|
|
951
|
+
var SDKControlRequestSchema = lazySchema(() => exports_external.object({
|
|
952
|
+
type: exports_external.literal("control_request"),
|
|
953
|
+
request_id: exports_external.string(),
|
|
954
|
+
request: SDKControlRequestInnerSchema()
|
|
955
|
+
}));
|
|
956
|
+
var ControlResponseSchema = lazySchema(() => exports_external.object({
|
|
957
|
+
subtype: exports_external.literal("success"),
|
|
958
|
+
request_id: exports_external.string(),
|
|
959
|
+
response: exports_external.record(exports_external.string(), exports_external.unknown()).optional()
|
|
960
|
+
}));
|
|
961
|
+
var ControlErrorResponseSchema = lazySchema(() => exports_external.object({
|
|
962
|
+
subtype: exports_external.literal("error"),
|
|
963
|
+
request_id: exports_external.string(),
|
|
964
|
+
error: exports_external.string(),
|
|
965
|
+
pending_permission_requests: exports_external.array(exports_external.lazy(() => SDKControlRequestSchema())).optional()
|
|
966
|
+
}));
|
|
967
|
+
var SDKControlResponseSchema = lazySchema(() => exports_external.object({
|
|
968
|
+
type: exports_external.literal("control_response"),
|
|
969
|
+
response: exports_external.union([ControlResponseSchema(), ControlErrorResponseSchema()])
|
|
970
|
+
}));
|
|
971
|
+
var SDKControlCancelRequestSchema = lazySchema(() => exports_external.object({
|
|
972
|
+
type: exports_external.literal("control_cancel_request"),
|
|
973
|
+
request_id: exports_external.string()
|
|
974
|
+
}).describe("Cancels a currently open control request."));
|
|
975
|
+
var SDKKeepAliveMessageSchema = lazySchema(() => exports_external.object({
|
|
976
|
+
type: exports_external.literal("keep_alive")
|
|
977
|
+
}).describe("Keep-alive message to maintain WebSocket connection."));
|
|
978
|
+
var SDKUpdateEnvironmentVariablesMessageSchema = lazySchema(() => exports_external.object({
|
|
979
|
+
type: exports_external.literal("update_environment_variables"),
|
|
980
|
+
variables: exports_external.record(exports_external.string(), exports_external.string())
|
|
981
|
+
}).describe("Updates environment variables at runtime."));
|
|
982
|
+
var StdoutMessageSchema = lazySchema(() => exports_external.union([
|
|
983
|
+
SDKMessageSchema(),
|
|
984
|
+
SDKStreamlinedTextMessageSchema(),
|
|
985
|
+
SDKStreamlinedToolUseSummaryMessageSchema(),
|
|
986
|
+
SDKPostTurnSummaryMessageSchema(),
|
|
987
|
+
SDKControlResponseSchema(),
|
|
988
|
+
SDKControlRequestSchema(),
|
|
989
|
+
SDKControlCancelRequestSchema(),
|
|
990
|
+
SDKKeepAliveMessageSchema()
|
|
991
|
+
]));
|
|
992
|
+
var StdinMessageSchema = lazySchema(() => exports_external.union([
|
|
993
|
+
SDKUserMessageSchema(),
|
|
994
|
+
SDKControlRequestSchema(),
|
|
995
|
+
SDKControlResponseSchema(),
|
|
996
|
+
SDKKeepAliveMessageSchema(),
|
|
997
|
+
SDKUpdateEnvironmentVariablesMessageSchema()
|
|
998
|
+
]));
|
|
999
|
+
|
|
1000
|
+
// src/cli/structuredIO.ts
|
|
1001
|
+
init_hooks();
|
|
1002
|
+
init_debug();
|
|
1003
|
+
init_diagLogs();
|
|
1004
|
+
init_errors();
|
|
1005
|
+
init_permissions();
|
|
1006
|
+
init_process();
|
|
1007
|
+
init_slowOperations();
|
|
1008
|
+
init_v4();
|
|
1009
|
+
init_commandLifecycle();
|
|
1010
|
+
init_hooks2();
|
|
1011
|
+
init_PermissionUpdate();
|
|
1012
|
+
init_sessionState();
|
|
1013
|
+
init_slowOperations();
|
|
1014
|
+
init_stream();
|
|
1015
|
+
|
|
1016
|
+
// src/cli/ndjsonSafeStringify.ts
|
|
1017
|
+
init_slowOperations();
|
|
1018
|
+
var JS_LINE_TERMINATORS = /\u2028|\u2029/g;
|
|
1019
|
+
function escapeJsLineTerminators(json) {
|
|
1020
|
+
return json.replace(JS_LINE_TERMINATORS, (c) => c === "\u2028" ? "\\u2028" : "\\u2029");
|
|
1021
|
+
}
|
|
1022
|
+
function ndjsonSafeStringify(value) {
|
|
1023
|
+
return escapeJsLineTerminators(jsonStringify(value));
|
|
1024
|
+
}
|
|
1025
|
+
|
|
1026
|
+
// src/cli/structuredIO.ts
|
|
1027
|
+
var SANDBOX_NETWORK_ACCESS_TOOL_NAME = "SandboxNetworkAccess";
|
|
1028
|
+
function serializeDecisionReason(reason) {
|
|
1029
|
+
if (!reason) {
|
|
1030
|
+
return;
|
|
1031
|
+
}
|
|
1032
|
+
if (reason.type === "classifier") {
|
|
1033
|
+
return reason.reason;
|
|
1034
|
+
}
|
|
1035
|
+
switch (reason.type) {
|
|
1036
|
+
case "rule":
|
|
1037
|
+
case "mode":
|
|
1038
|
+
case "subcommandResults":
|
|
1039
|
+
case "permissionPromptTool":
|
|
1040
|
+
return;
|
|
1041
|
+
case "hook":
|
|
1042
|
+
case "asyncAgent":
|
|
1043
|
+
case "sandboxOverride":
|
|
1044
|
+
case "workingDir":
|
|
1045
|
+
case "safetyCheck":
|
|
1046
|
+
case "other":
|
|
1047
|
+
return reason.reason;
|
|
1048
|
+
}
|
|
1049
|
+
}
|
|
1050
|
+
function buildRequiresActionDetails(tool, input, toolUseID, requestId) {
|
|
1051
|
+
let description;
|
|
1052
|
+
try {
|
|
1053
|
+
description = tool.getActivityDescription?.(input) ?? tool.getToolUseSummary?.(input) ?? tool.userFacingName(input);
|
|
1054
|
+
} catch {
|
|
1055
|
+
description = tool.name;
|
|
1056
|
+
}
|
|
1057
|
+
return {
|
|
1058
|
+
tool_name: tool.name,
|
|
1059
|
+
action_description: description,
|
|
1060
|
+
tool_use_id: toolUseID,
|
|
1061
|
+
request_id: requestId,
|
|
1062
|
+
input
|
|
1063
|
+
};
|
|
1064
|
+
}
|
|
1065
|
+
var MAX_RESOLVED_TOOL_USE_IDS = 1000;
|
|
1066
|
+
|
|
1067
|
+
class StructuredIO {
|
|
1068
|
+
input;
|
|
1069
|
+
replayUserMessages;
|
|
1070
|
+
structuredInput;
|
|
1071
|
+
pendingRequests = new Map;
|
|
1072
|
+
restoredWorkerState = Promise.resolve(null);
|
|
1073
|
+
inputClosed = false;
|
|
1074
|
+
unexpectedResponseCallback;
|
|
1075
|
+
resolvedToolUseIds = new Set;
|
|
1076
|
+
prependedLines = [];
|
|
1077
|
+
onControlRequestSent;
|
|
1078
|
+
onControlRequestResolved;
|
|
1079
|
+
outbound = new Stream;
|
|
1080
|
+
constructor(input, replayUserMessages) {
|
|
1081
|
+
this.input = input;
|
|
1082
|
+
this.replayUserMessages = replayUserMessages;
|
|
1083
|
+
this.input = input;
|
|
1084
|
+
this.structuredInput = this.read();
|
|
1085
|
+
}
|
|
1086
|
+
trackResolvedToolUseId(request) {
|
|
1087
|
+
const inner = request.request;
|
|
1088
|
+
if (inner.subtype === "can_use_tool") {
|
|
1089
|
+
this.resolvedToolUseIds.add(inner.tool_use_id);
|
|
1090
|
+
if (this.resolvedToolUseIds.size > MAX_RESOLVED_TOOL_USE_IDS) {
|
|
1091
|
+
const first = this.resolvedToolUseIds.values().next().value;
|
|
1092
|
+
if (first !== undefined) {
|
|
1093
|
+
this.resolvedToolUseIds.delete(first);
|
|
1094
|
+
}
|
|
1095
|
+
}
|
|
1096
|
+
}
|
|
1097
|
+
}
|
|
1098
|
+
flushInternalEvents() {
|
|
1099
|
+
return Promise.resolve();
|
|
1100
|
+
}
|
|
1101
|
+
get internalEventsPending() {
|
|
1102
|
+
return 0;
|
|
1103
|
+
}
|
|
1104
|
+
prependUserMessage(content) {
|
|
1105
|
+
this.prependedLines.push(jsonStringify({
|
|
1106
|
+
type: "user",
|
|
1107
|
+
content,
|
|
1108
|
+
uuid: "",
|
|
1109
|
+
session_id: "",
|
|
1110
|
+
message: { role: "user", content },
|
|
1111
|
+
parent_tool_use_id: null
|
|
1112
|
+
}) + `
|
|
1113
|
+
`);
|
|
1114
|
+
}
|
|
1115
|
+
async* read() {
|
|
1116
|
+
let content = "";
|
|
1117
|
+
const splitAndProcess = async function* () {
|
|
1118
|
+
for (;; ) {
|
|
1119
|
+
if (this.prependedLines.length > 0) {
|
|
1120
|
+
content = this.prependedLines.join("") + content;
|
|
1121
|
+
this.prependedLines = [];
|
|
1122
|
+
}
|
|
1123
|
+
const newline = content.indexOf(`
|
|
1124
|
+
`);
|
|
1125
|
+
if (newline === -1)
|
|
1126
|
+
break;
|
|
1127
|
+
const line = content.slice(0, newline);
|
|
1128
|
+
content = content.slice(newline + 1);
|
|
1129
|
+
const message = await this.processLine(line);
|
|
1130
|
+
if (message) {
|
|
1131
|
+
logForDiagnosticsNoPII("info", "cli_stdin_message_parsed", {
|
|
1132
|
+
type: message.type
|
|
1133
|
+
});
|
|
1134
|
+
yield message;
|
|
1135
|
+
}
|
|
1136
|
+
}
|
|
1137
|
+
}.bind(this);
|
|
1138
|
+
yield* splitAndProcess();
|
|
1139
|
+
for await (const block of this.input) {
|
|
1140
|
+
content += block;
|
|
1141
|
+
yield* splitAndProcess();
|
|
1142
|
+
}
|
|
1143
|
+
if (content) {
|
|
1144
|
+
const message = await this.processLine(content);
|
|
1145
|
+
if (message) {
|
|
1146
|
+
yield message;
|
|
1147
|
+
}
|
|
1148
|
+
}
|
|
1149
|
+
this.inputClosed = true;
|
|
1150
|
+
for (const request of this.pendingRequests.values()) {
|
|
1151
|
+
request.reject(new Error("Tool permission stream closed before response received"));
|
|
1152
|
+
}
|
|
1153
|
+
}
|
|
1154
|
+
getPendingPermissionRequests() {
|
|
1155
|
+
return Array.from(this.pendingRequests.values()).map((entry) => entry.request).filter((pr) => pr.request.subtype === "can_use_tool");
|
|
1156
|
+
}
|
|
1157
|
+
setUnexpectedResponseCallback(callback) {
|
|
1158
|
+
this.unexpectedResponseCallback = callback;
|
|
1159
|
+
}
|
|
1160
|
+
injectControlResponse(response) {
|
|
1161
|
+
const responseInner = response.response;
|
|
1162
|
+
const requestId = responseInner?.request_id;
|
|
1163
|
+
if (!requestId)
|
|
1164
|
+
return;
|
|
1165
|
+
const request = this.pendingRequests.get(requestId);
|
|
1166
|
+
if (!request)
|
|
1167
|
+
return;
|
|
1168
|
+
this.trackResolvedToolUseId(request.request);
|
|
1169
|
+
this.pendingRequests.delete(requestId);
|
|
1170
|
+
this.write({
|
|
1171
|
+
type: "control_cancel_request",
|
|
1172
|
+
request_id: requestId
|
|
1173
|
+
});
|
|
1174
|
+
if (responseInner.subtype === "error") {
|
|
1175
|
+
request.reject(new Error(responseInner.error));
|
|
1176
|
+
} else {
|
|
1177
|
+
const result = responseInner.response;
|
|
1178
|
+
if (request.schema) {
|
|
1179
|
+
try {
|
|
1180
|
+
request.resolve(request.schema.parse(result));
|
|
1181
|
+
} catch (error) {
|
|
1182
|
+
request.reject(error);
|
|
1183
|
+
}
|
|
1184
|
+
} else {
|
|
1185
|
+
request.resolve({});
|
|
1186
|
+
}
|
|
1187
|
+
}
|
|
1188
|
+
}
|
|
1189
|
+
setOnControlRequestSent(callback) {
|
|
1190
|
+
this.onControlRequestSent = callback;
|
|
1191
|
+
}
|
|
1192
|
+
setOnControlRequestResolved(callback) {
|
|
1193
|
+
this.onControlRequestResolved = callback;
|
|
1194
|
+
}
|
|
1195
|
+
async processLine(line) {
|
|
1196
|
+
if (!line) {
|
|
1197
|
+
return;
|
|
1198
|
+
}
|
|
1199
|
+
try {
|
|
1200
|
+
const message = normalizeControlMessageKeys(jsonParse(line));
|
|
1201
|
+
if (message.type === "keep_alive") {
|
|
1202
|
+
return;
|
|
1203
|
+
}
|
|
1204
|
+
if (message.type === "update_environment_variables") {
|
|
1205
|
+
const variables = message.variables ?? {};
|
|
1206
|
+
const keys = Object.keys(variables);
|
|
1207
|
+
for (const [key, value] of Object.entries(variables)) {
|
|
1208
|
+
process.env[key] = value;
|
|
1209
|
+
}
|
|
1210
|
+
logForDebugging(`[structuredIO] applied update_environment_variables: ${keys.join(", ")}`);
|
|
1211
|
+
return;
|
|
1212
|
+
}
|
|
1213
|
+
if (message.type === "control_response") {
|
|
1214
|
+
const uuid = "uuid" in message && typeof message.uuid === "string" ? message.uuid : undefined;
|
|
1215
|
+
if (uuid) {
|
|
1216
|
+
notifyCommandLifecycle(uuid, "completed");
|
|
1217
|
+
}
|
|
1218
|
+
const resp = message.response;
|
|
1219
|
+
const request = this.pendingRequests.get(resp.request_id);
|
|
1220
|
+
if (!request) {
|
|
1221
|
+
const responsePayload = resp.subtype === "success" ? resp.response : undefined;
|
|
1222
|
+
const toolUseID = responsePayload?.toolUseID;
|
|
1223
|
+
if (typeof toolUseID === "string" && this.resolvedToolUseIds.has(toolUseID)) {
|
|
1224
|
+
logForDebugging(`Ignoring duplicate control_response for already-resolved toolUseID=${toolUseID} request_id=${resp.request_id}`);
|
|
1225
|
+
return;
|
|
1226
|
+
}
|
|
1227
|
+
if (this.unexpectedResponseCallback) {
|
|
1228
|
+
await this.unexpectedResponseCallback(message);
|
|
1229
|
+
}
|
|
1230
|
+
return;
|
|
1231
|
+
}
|
|
1232
|
+
this.trackResolvedToolUseId(request.request);
|
|
1233
|
+
this.pendingRequests.delete(resp.request_id);
|
|
1234
|
+
if (request.request.request.subtype === "can_use_tool" && this.onControlRequestResolved) {
|
|
1235
|
+
this.onControlRequestResolved(resp.request_id);
|
|
1236
|
+
}
|
|
1237
|
+
if (resp.subtype === "error") {
|
|
1238
|
+
request.reject(new Error(resp.error ?? "Unknown error"));
|
|
1239
|
+
return;
|
|
1240
|
+
}
|
|
1241
|
+
const result = resp.response;
|
|
1242
|
+
if (request.schema) {
|
|
1243
|
+
try {
|
|
1244
|
+
request.resolve(request.schema.parse(result));
|
|
1245
|
+
} catch (error) {
|
|
1246
|
+
request.reject(error);
|
|
1247
|
+
}
|
|
1248
|
+
} else {
|
|
1249
|
+
request.resolve({});
|
|
1250
|
+
}
|
|
1251
|
+
if (this.replayUserMessages) {
|
|
1252
|
+
return message;
|
|
1253
|
+
}
|
|
1254
|
+
return;
|
|
1255
|
+
}
|
|
1256
|
+
if (message.type !== "user" && message.type !== "control_request" && message.type !== "assistant" && message.type !== "system") {
|
|
1257
|
+
logForDebugging(`Ignoring unknown message type: ${message.type}`, {
|
|
1258
|
+
level: "warn"
|
|
1259
|
+
});
|
|
1260
|
+
return;
|
|
1261
|
+
}
|
|
1262
|
+
if (message.type === "control_request") {
|
|
1263
|
+
if (!message.request) {
|
|
1264
|
+
exitWithMessage(`Error: Missing request on control_request`);
|
|
1265
|
+
}
|
|
1266
|
+
return message;
|
|
1267
|
+
}
|
|
1268
|
+
if (message.type === "assistant" || message.type === "system") {
|
|
1269
|
+
return message;
|
|
1270
|
+
}
|
|
1271
|
+
if (message.message?.role !== "user") {
|
|
1272
|
+
exitWithMessage(`Error: Expected message role 'user', got '${message.message?.role}'`);
|
|
1273
|
+
}
|
|
1274
|
+
return message;
|
|
1275
|
+
} catch (error) {
|
|
1276
|
+
console.error(`Error parsing streaming input line: ${line}: ${error}`);
|
|
1277
|
+
process.exit(1);
|
|
1278
|
+
}
|
|
1279
|
+
}
|
|
1280
|
+
async write(message) {
|
|
1281
|
+
writeToStdout(ndjsonSafeStringify(message) + `
|
|
1282
|
+
`);
|
|
1283
|
+
}
|
|
1284
|
+
async sendRequest(request, schema, signal, requestId = randomUUID()) {
|
|
1285
|
+
const message = {
|
|
1286
|
+
type: "control_request",
|
|
1287
|
+
request_id: requestId,
|
|
1288
|
+
request
|
|
1289
|
+
};
|
|
1290
|
+
if (this.inputClosed) {
|
|
1291
|
+
throw new Error("Stream closed");
|
|
1292
|
+
}
|
|
1293
|
+
if (signal?.aborted) {
|
|
1294
|
+
throw new Error("Request aborted");
|
|
1295
|
+
}
|
|
1296
|
+
this.outbound.enqueue(message);
|
|
1297
|
+
if (request.subtype === "can_use_tool" && this.onControlRequestSent) {
|
|
1298
|
+
this.onControlRequestSent(message);
|
|
1299
|
+
}
|
|
1300
|
+
const aborted = () => {
|
|
1301
|
+
this.outbound.enqueue({
|
|
1302
|
+
type: "control_cancel_request",
|
|
1303
|
+
request_id: requestId
|
|
1304
|
+
});
|
|
1305
|
+
const request2 = this.pendingRequests.get(requestId);
|
|
1306
|
+
if (request2) {
|
|
1307
|
+
this.trackResolvedToolUseId(request2.request);
|
|
1308
|
+
request2.reject(new AbortError);
|
|
1309
|
+
}
|
|
1310
|
+
};
|
|
1311
|
+
if (signal) {
|
|
1312
|
+
signal.addEventListener("abort", aborted, {
|
|
1313
|
+
once: true
|
|
1314
|
+
});
|
|
1315
|
+
}
|
|
1316
|
+
try {
|
|
1317
|
+
return await new Promise((resolve, reject) => {
|
|
1318
|
+
this.pendingRequests.set(requestId, {
|
|
1319
|
+
request: {
|
|
1320
|
+
type: "control_request",
|
|
1321
|
+
request_id: requestId,
|
|
1322
|
+
request
|
|
1323
|
+
},
|
|
1324
|
+
resolve: (result) => {
|
|
1325
|
+
resolve(result);
|
|
1326
|
+
},
|
|
1327
|
+
reject,
|
|
1328
|
+
schema
|
|
1329
|
+
});
|
|
1330
|
+
});
|
|
1331
|
+
} finally {
|
|
1332
|
+
if (signal) {
|
|
1333
|
+
signal.removeEventListener("abort", aborted);
|
|
1334
|
+
}
|
|
1335
|
+
this.pendingRequests.delete(requestId);
|
|
1336
|
+
}
|
|
1337
|
+
}
|
|
1338
|
+
createCanUseTool(onPermissionPrompt) {
|
|
1339
|
+
return async (tool, input, toolUseContext, assistantMessage, toolUseID, forceDecision) => {
|
|
1340
|
+
const mainPermissionResult = forceDecision ?? await hasPermissionsToUseTool(tool, input, toolUseContext, assistantMessage, toolUseID);
|
|
1341
|
+
if (mainPermissionResult.behavior === "allow" || mainPermissionResult.behavior === "deny") {
|
|
1342
|
+
return mainPermissionResult;
|
|
1343
|
+
}
|
|
1344
|
+
const hookAbortController = new AbortController;
|
|
1345
|
+
const parentSignal = toolUseContext.abortController.signal;
|
|
1346
|
+
const onParentAbort = () => hookAbortController.abort();
|
|
1347
|
+
parentSignal.addEventListener("abort", onParentAbort, { once: true });
|
|
1348
|
+
try {
|
|
1349
|
+
const hookPromise = executePermissionRequestHooksForSDK(tool.name, toolUseID, input, toolUseContext, mainPermissionResult.suggestions).then((decision) => ({ source: "hook", decision }));
|
|
1350
|
+
const requestId = randomUUID();
|
|
1351
|
+
onPermissionPrompt?.(buildRequiresActionDetails(tool, input, toolUseID, requestId));
|
|
1352
|
+
const sdkPromise = this.sendRequest({
|
|
1353
|
+
subtype: "can_use_tool",
|
|
1354
|
+
tool_name: tool.name,
|
|
1355
|
+
input,
|
|
1356
|
+
permission_suggestions: mainPermissionResult.suggestions,
|
|
1357
|
+
blocked_path: mainPermissionResult.blockedPath,
|
|
1358
|
+
decision_reason: serializeDecisionReason(mainPermissionResult.decisionReason),
|
|
1359
|
+
tool_use_id: toolUseID,
|
|
1360
|
+
agent_id: toolUseContext.agentId
|
|
1361
|
+
}, outputSchema(), hookAbortController.signal, requestId).then((result) => ({ source: "sdk", result }));
|
|
1362
|
+
const winner = await Promise.race([hookPromise, sdkPromise]);
|
|
1363
|
+
if (winner.source === "hook") {
|
|
1364
|
+
if (winner.decision) {
|
|
1365
|
+
sdkPromise.catch(() => {});
|
|
1366
|
+
hookAbortController.abort();
|
|
1367
|
+
return winner.decision;
|
|
1368
|
+
}
|
|
1369
|
+
const sdkResult = await sdkPromise;
|
|
1370
|
+
return permissionPromptToolResultToPermissionDecision(sdkResult.result, tool, input, toolUseContext);
|
|
1371
|
+
}
|
|
1372
|
+
return permissionPromptToolResultToPermissionDecision(winner.result, tool, input, toolUseContext);
|
|
1373
|
+
} catch (error) {
|
|
1374
|
+
return permissionPromptToolResultToPermissionDecision({
|
|
1375
|
+
behavior: "deny",
|
|
1376
|
+
message: `Tool permission request failed: ${error}`,
|
|
1377
|
+
toolUseID
|
|
1378
|
+
}, tool, input, toolUseContext);
|
|
1379
|
+
} finally {
|
|
1380
|
+
if (this.getPendingPermissionRequests().length === 0) {
|
|
1381
|
+
notifySessionStateChanged("running");
|
|
1382
|
+
}
|
|
1383
|
+
parentSignal.removeEventListener("abort", onParentAbort);
|
|
1384
|
+
}
|
|
1385
|
+
};
|
|
1386
|
+
}
|
|
1387
|
+
createHookCallback(callbackId, timeout) {
|
|
1388
|
+
return {
|
|
1389
|
+
type: "callback",
|
|
1390
|
+
timeout,
|
|
1391
|
+
callback: async (input, toolUseID, abort) => {
|
|
1392
|
+
try {
|
|
1393
|
+
const result = await this.sendRequest({
|
|
1394
|
+
subtype: "hook_callback",
|
|
1395
|
+
callback_id: callbackId,
|
|
1396
|
+
input,
|
|
1397
|
+
tool_use_id: toolUseID || undefined
|
|
1398
|
+
}, hookJSONOutputSchema(), abort);
|
|
1399
|
+
return result;
|
|
1400
|
+
} catch (error) {
|
|
1401
|
+
console.error(`Error in hook callback ${callbackId}:`, error);
|
|
1402
|
+
return {};
|
|
1403
|
+
}
|
|
1404
|
+
}
|
|
1405
|
+
};
|
|
1406
|
+
}
|
|
1407
|
+
async handleElicitation(serverName, message, requestedSchema, signal, mode, url, elicitationId) {
|
|
1408
|
+
try {
|
|
1409
|
+
const result = await this.sendRequest({
|
|
1410
|
+
subtype: "elicitation",
|
|
1411
|
+
mcp_server_name: serverName,
|
|
1412
|
+
message,
|
|
1413
|
+
mode,
|
|
1414
|
+
url,
|
|
1415
|
+
elicitation_id: elicitationId,
|
|
1416
|
+
requested_schema: requestedSchema
|
|
1417
|
+
}, SDKControlElicitationResponseSchema(), signal);
|
|
1418
|
+
return result;
|
|
1419
|
+
} catch {
|
|
1420
|
+
return { action: "cancel" };
|
|
1421
|
+
}
|
|
1422
|
+
}
|
|
1423
|
+
createSandboxAskCallback() {
|
|
1424
|
+
return async (hostPattern) => {
|
|
1425
|
+
try {
|
|
1426
|
+
const result = await this.sendRequest({
|
|
1427
|
+
subtype: "can_use_tool",
|
|
1428
|
+
tool_name: SANDBOX_NETWORK_ACCESS_TOOL_NAME,
|
|
1429
|
+
input: { host: hostPattern.host },
|
|
1430
|
+
tool_use_id: randomUUID(),
|
|
1431
|
+
description: `Allow network connection to ${hostPattern.host}?`
|
|
1432
|
+
}, outputSchema());
|
|
1433
|
+
return result.behavior === "allow";
|
|
1434
|
+
} catch {
|
|
1435
|
+
return false;
|
|
1436
|
+
}
|
|
1437
|
+
};
|
|
1438
|
+
}
|
|
1439
|
+
async sendMcpMessage(serverName, message) {
|
|
1440
|
+
const response = await this.sendRequest({
|
|
1441
|
+
subtype: "mcp_message",
|
|
1442
|
+
server_name: serverName,
|
|
1443
|
+
message
|
|
1444
|
+
}, exports_external.object({
|
|
1445
|
+
mcp_response: exports_external.any()
|
|
1446
|
+
}));
|
|
1447
|
+
return response.mcp_response;
|
|
1448
|
+
}
|
|
1449
|
+
}
|
|
1450
|
+
function exitWithMessage(message) {
|
|
1451
|
+
console.error(message);
|
|
1452
|
+
process.exit(1);
|
|
1453
|
+
}
|
|
1454
|
+
async function executePermissionRequestHooksForSDK(toolName, toolUseID, input, toolUseContext, suggestions) {
|
|
1455
|
+
const appState = toolUseContext.getAppState();
|
|
1456
|
+
const permissionMode = appState.toolPermissionContext.mode;
|
|
1457
|
+
const hookGenerator = executePermissionRequestHooks(toolName, toolUseID, input, toolUseContext, permissionMode, suggestions, toolUseContext.abortController.signal);
|
|
1458
|
+
for await (const hookResult of hookGenerator) {
|
|
1459
|
+
if (hookResult.permissionRequestResult && (hookResult.permissionRequestResult.behavior === "allow" || hookResult.permissionRequestResult.behavior === "deny")) {
|
|
1460
|
+
const decision = hookResult.permissionRequestResult;
|
|
1461
|
+
if (decision.behavior === "allow") {
|
|
1462
|
+
const finalInput = decision.updatedInput || input;
|
|
1463
|
+
const permissionUpdates = decision.updatedPermissions ?? [];
|
|
1464
|
+
if (permissionUpdates.length > 0) {
|
|
1465
|
+
persistPermissionUpdates(permissionUpdates);
|
|
1466
|
+
const currentAppState = toolUseContext.getAppState();
|
|
1467
|
+
const updatedContext = applyPermissionUpdates(currentAppState.toolPermissionContext, permissionUpdates);
|
|
1468
|
+
toolUseContext.setAppState((prev) => {
|
|
1469
|
+
if (prev.toolPermissionContext === updatedContext)
|
|
1470
|
+
return prev;
|
|
1471
|
+
return { ...prev, toolPermissionContext: updatedContext };
|
|
1472
|
+
});
|
|
1473
|
+
}
|
|
1474
|
+
return {
|
|
1475
|
+
behavior: "allow",
|
|
1476
|
+
updatedInput: finalInput,
|
|
1477
|
+
userModified: false,
|
|
1478
|
+
decisionReason: {
|
|
1479
|
+
type: "hook",
|
|
1480
|
+
hookName: "PermissionRequest"
|
|
1481
|
+
}
|
|
1482
|
+
};
|
|
1483
|
+
} else {
|
|
1484
|
+
return {
|
|
1485
|
+
behavior: "deny",
|
|
1486
|
+
message: decision.message || "Permission denied by PermissionRequest hook",
|
|
1487
|
+
decisionReason: {
|
|
1488
|
+
type: "hook",
|
|
1489
|
+
hookName: "PermissionRequest"
|
|
1490
|
+
}
|
|
1491
|
+
};
|
|
1492
|
+
}
|
|
1493
|
+
}
|
|
1494
|
+
}
|
|
1495
|
+
return;
|
|
1496
|
+
}
|
|
1497
|
+
|
|
1498
|
+
// src/utils/plugins/reconciler.ts
|
|
1499
|
+
init_isEqual();
|
|
1500
|
+
init_state();
|
|
1501
|
+
init_debug();
|
|
1502
|
+
init_errors();
|
|
1503
|
+
init_file();
|
|
1504
|
+
init_git();
|
|
1505
|
+
init_log();
|
|
1506
|
+
init_marketplaceManager();
|
|
1507
|
+
init_schemas();
|
|
1508
|
+
import { isAbsolute, resolve } from "path";
|
|
1509
|
+
function diffMarketplaces(declared, materialized, opts) {
|
|
1510
|
+
const missing = [];
|
|
1511
|
+
const sourceChanged = [];
|
|
1512
|
+
const upToDate = [];
|
|
1513
|
+
for (const [name, intent] of Object.entries(declared)) {
|
|
1514
|
+
const state = materialized[name];
|
|
1515
|
+
const normalizedIntent = normalizeSource(intent.source, opts?.projectRoot);
|
|
1516
|
+
if (!state) {
|
|
1517
|
+
missing.push(name);
|
|
1518
|
+
} else if (intent.sourceIsFallback) {
|
|
1519
|
+
upToDate.push(name);
|
|
1520
|
+
} else if (!isEqual_default(normalizedIntent, state.source)) {
|
|
1521
|
+
sourceChanged.push({
|
|
1522
|
+
name,
|
|
1523
|
+
declaredSource: normalizedIntent,
|
|
1524
|
+
materializedSource: state.source
|
|
1525
|
+
});
|
|
1526
|
+
} else {
|
|
1527
|
+
upToDate.push(name);
|
|
1528
|
+
}
|
|
1529
|
+
}
|
|
1530
|
+
return { missing, sourceChanged, upToDate };
|
|
1531
|
+
}
|
|
1532
|
+
async function reconcileMarketplaces(opts) {
|
|
1533
|
+
const declared = getDeclaredMarketplaces();
|
|
1534
|
+
if (Object.keys(declared).length === 0) {
|
|
1535
|
+
return { installed: [], updated: [], failed: [], upToDate: [], skipped: [] };
|
|
1536
|
+
}
|
|
1537
|
+
let materialized;
|
|
1538
|
+
try {
|
|
1539
|
+
materialized = await loadKnownMarketplacesConfig();
|
|
1540
|
+
} catch (e) {
|
|
1541
|
+
logError(e);
|
|
1542
|
+
materialized = {};
|
|
1543
|
+
}
|
|
1544
|
+
const diff = diffMarketplaces(declared, materialized, {
|
|
1545
|
+
projectRoot: getOriginalCwd()
|
|
1546
|
+
});
|
|
1547
|
+
const work = [
|
|
1548
|
+
...diff.missing.map((name) => ({
|
|
1549
|
+
name,
|
|
1550
|
+
source: normalizeSource(declared[name].source),
|
|
1551
|
+
action: "install"
|
|
1552
|
+
})),
|
|
1553
|
+
...diff.sourceChanged.map(({ name, declaredSource }) => ({
|
|
1554
|
+
name,
|
|
1555
|
+
source: declaredSource,
|
|
1556
|
+
action: "update"
|
|
1557
|
+
}))
|
|
1558
|
+
];
|
|
1559
|
+
const skipped = [];
|
|
1560
|
+
const toProcess = [];
|
|
1561
|
+
for (const item of work) {
|
|
1562
|
+
if (opts?.skip?.(item.name, item.source)) {
|
|
1563
|
+
skipped.push(item.name);
|
|
1564
|
+
continue;
|
|
1565
|
+
}
|
|
1566
|
+
if (item.action === "update" && isLocalMarketplaceSource(item.source) && !await pathExists(item.source.path)) {
|
|
1567
|
+
logForDebugging(`[reconcile] '${item.name}' declared path does not exist; keeping materialized entry`);
|
|
1568
|
+
skipped.push(item.name);
|
|
1569
|
+
continue;
|
|
1570
|
+
}
|
|
1571
|
+
toProcess.push(item);
|
|
1572
|
+
}
|
|
1573
|
+
if (toProcess.length === 0) {
|
|
1574
|
+
return {
|
|
1575
|
+
installed: [],
|
|
1576
|
+
updated: [],
|
|
1577
|
+
failed: [],
|
|
1578
|
+
upToDate: diff.upToDate,
|
|
1579
|
+
skipped
|
|
1580
|
+
};
|
|
1581
|
+
}
|
|
1582
|
+
logForDebugging(`[reconcile] ${toProcess.length} marketplace(s): ${toProcess.map((w) => `${w.name}(${w.action})`).join(", ")}`);
|
|
1583
|
+
const installed = [];
|
|
1584
|
+
const updated = [];
|
|
1585
|
+
const failed = [];
|
|
1586
|
+
for (let i = 0;i < toProcess.length; i++) {
|
|
1587
|
+
const { name, source, action } = toProcess[i];
|
|
1588
|
+
opts?.onProgress?.({
|
|
1589
|
+
type: "installing",
|
|
1590
|
+
name,
|
|
1591
|
+
action,
|
|
1592
|
+
index: i + 1,
|
|
1593
|
+
total: toProcess.length
|
|
1594
|
+
});
|
|
1595
|
+
try {
|
|
1596
|
+
const result = await addMarketplaceSource(source);
|
|
1597
|
+
if (action === "install")
|
|
1598
|
+
installed.push(name);
|
|
1599
|
+
else
|
|
1600
|
+
updated.push(name);
|
|
1601
|
+
opts?.onProgress?.({
|
|
1602
|
+
type: "installed",
|
|
1603
|
+
name,
|
|
1604
|
+
alreadyMaterialized: result.alreadyMaterialized
|
|
1605
|
+
});
|
|
1606
|
+
} catch (e) {
|
|
1607
|
+
const error = errorMessage(e);
|
|
1608
|
+
failed.push({ name, error });
|
|
1609
|
+
opts?.onProgress?.({ type: "failed", name, error });
|
|
1610
|
+
logError(e);
|
|
1611
|
+
}
|
|
1612
|
+
}
|
|
1613
|
+
return { installed, updated, failed, upToDate: diff.upToDate, skipped };
|
|
1614
|
+
}
|
|
1615
|
+
function normalizeSource(source, projectRoot) {
|
|
1616
|
+
if ((source.source === "directory" || source.source === "file") && !isAbsolute(source.path)) {
|
|
1617
|
+
const base = projectRoot ?? getOriginalCwd();
|
|
1618
|
+
const canonicalRoot = findCanonicalGitRoot(base);
|
|
1619
|
+
return {
|
|
1620
|
+
...source,
|
|
1621
|
+
path: resolve(canonicalRoot ?? base, source.path)
|
|
1622
|
+
};
|
|
1623
|
+
}
|
|
1624
|
+
return source;
|
|
1625
|
+
}
|
|
1626
|
+
|
|
1627
|
+
export { extractInboundMessageFields, outputSchema, permissionPromptToolResultToPermissionDecision, ndjsonSafeStringify, SANDBOX_NETWORK_ACCESS_TOOL_NAME, StructuredIO, diffMarketplaces, reconcileMarketplaces, getCronJitterConfig, exports_cronJitterConfig, init_cronJitterConfig, createCronScheduler, exports_cronScheduler, init_cronScheduler };
|