@poncho-ai/cli 0.2.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/.turbo/turbo-build.log +19 -0
- package/.turbo/turbo-test.log +389 -0
- package/CHANGELOG.md +17 -0
- package/LICENSE +21 -0
- package/dist/chunk-22OMLQUR.js +1249 -0
- package/dist/chunk-24JFN5RM.js +1887 -0
- package/dist/chunk-24TAT3US.js +2137 -0
- package/dist/chunk-26YBLT7G.js +997 -0
- package/dist/chunk-2EJIC6UW.js +1893 -0
- package/dist/chunk-2JNCF37R.js +1156 -0
- package/dist/chunk-2LVMUHJX.js +1874 -0
- package/dist/chunk-2OVSD65B.js +1269 -0
- package/dist/chunk-2RQ45LI6.js +1251 -0
- package/dist/chunk-2SMIRDLI.js +1854 -0
- package/dist/chunk-2UXPHBFI.js +1862 -0
- package/dist/chunk-2VFM7SSZ.js +1135 -0
- package/dist/chunk-2ZAUADNG.js +1456 -0
- package/dist/chunk-2ZNUT5WA.js +1862 -0
- package/dist/chunk-33ZQ7WTP.js +1834 -0
- package/dist/chunk-34ARQX3O.js +1156 -0
- package/dist/chunk-3BEWSRFW.js +1893 -0
- package/dist/chunk-3DVE5AG6.js +1862 -0
- package/dist/chunk-3KE6MHO6.js +1608 -0
- package/dist/chunk-3MOLPB7Z.js +997 -0
- package/dist/chunk-3OZZOYAZ.js +1884 -0
- package/dist/chunk-3VJYNZEF.js +2181 -0
- package/dist/chunk-3W27LOUH.js +997 -0
- package/dist/chunk-3WMAW74D.js +1163 -0
- package/dist/chunk-3Z4AHBPF.js +1569 -0
- package/dist/chunk-43NK6MB4.js +1977 -0
- package/dist/chunk-4E5M2IGA.js +1300 -0
- package/dist/chunk-4FVI4LVI.js +1862 -0
- package/dist/chunk-4GNQQJUP.js +1156 -0
- package/dist/chunk-4PGZFTVC.js +1234 -0
- package/dist/chunk-4QE2HDNC.js +1355 -0
- package/dist/chunk-4S2EL4ED.js +1135 -0
- package/dist/chunk-536SSOJ3.js +1797 -0
- package/dist/chunk-5CNEGIC5.js +997 -0
- package/dist/chunk-5CWN43YL.js +1147 -0
- package/dist/chunk-5HZCYTUZ.js +997 -0
- package/dist/chunk-5ICNG6RX.js +1885 -0
- package/dist/chunk-5OUIRXMN.js +997 -0
- package/dist/chunk-5T34JOWH.js +1460 -0
- package/dist/chunk-5XBAIQX3.js +1862 -0
- package/dist/chunk-65AIX3CS.js +1441 -0
- package/dist/chunk-67NBW4NG.js +1355 -0
- package/dist/chunk-6AFIL35M.js +1414 -0
- package/dist/chunk-6B3XMBKA.js +1716 -0
- package/dist/chunk-6CEJO4OM.js +1242 -0
- package/dist/chunk-6DQZUP3B.js +1460 -0
- package/dist/chunk-6ET624OE.js +1441 -0
- package/dist/chunk-6I7WFMAU.js +1862 -0
- package/dist/chunk-6MOKAYCL.js +1449 -0
- package/dist/chunk-6RFUALWB.js +1845 -0
- package/dist/chunk-73E57JUS.js +1231 -0
- package/dist/chunk-73SU7GT4.js +816 -0
- package/dist/chunk-74IRETUF.js +997 -0
- package/dist/chunk-77BYFMUN.js +1924 -0
- package/dist/chunk-7DAC2XE5.js +1460 -0
- package/dist/chunk-7GBQ4YSB.js +1024 -0
- package/dist/chunk-7TOJGUQ5.js +1803 -0
- package/dist/chunk-7W7KPLEG.js +1163 -0
- package/dist/chunk-7Y7ZXEN2.js +817 -0
- package/dist/chunk-A5WKH7H2.js +852 -0
- package/dist/chunk-A775UYQB.js +1886 -0
- package/dist/chunk-AC4OGTSK.js +1313 -0
- package/dist/chunk-ACCRUQ6J.js +1271 -0
- package/dist/chunk-AEAZZFTT.js +1886 -0
- package/dist/chunk-AIAC5Z55.js +1147 -0
- package/dist/chunk-AN34PI2R.js +1238 -0
- package/dist/chunk-APIA7MHJ.js +1355 -0
- package/dist/chunk-AQGIIT7R.js +1347 -0
- package/dist/chunk-ATXKV2NH.js +2111 -0
- package/dist/chunk-AVBKQZYR.js +1010 -0
- package/dist/chunk-AWIXDCZF.js +1329 -0
- package/dist/chunk-AXFHQBKT.js +2128 -0
- package/dist/chunk-AYDSTU4P.js +1156 -0
- package/dist/chunk-AZ35PK7E.js +1271 -0
- package/dist/chunk-BE6HB4IO.js +2155 -0
- package/dist/chunk-BIX2FI3S.js +1625 -0
- package/dist/chunk-BPPM5YPG.js +997 -0
- package/dist/chunk-BRCIVYKE.js +1420 -0
- package/dist/chunk-BRK2KKTF.js +1236 -0
- package/dist/chunk-BU7R2TVT.js +1862 -0
- package/dist/chunk-BXJQ4G5F.js +1901 -0
- package/dist/chunk-C3KTCROR.js +1128 -0
- package/dist/chunk-C42IGDJW.js +1032 -0
- package/dist/chunk-CBRPO2FE.js +1886 -0
- package/dist/chunk-CDNITKC6.js +1163 -0
- package/dist/chunk-CDVWUDFM.js +1389 -0
- package/dist/chunk-CH2IE453.js +1147 -0
- package/dist/chunk-CIHC46FS.js +1010 -0
- package/dist/chunk-CIYO754K.js +1687 -0
- package/dist/chunk-CJFNJ7U3.js +918 -0
- package/dist/chunk-CJN66CJY.js +1024 -0
- package/dist/chunk-CLJFTDJQ.js +1667 -0
- package/dist/chunk-CLNCOQNI.js +997 -0
- package/dist/chunk-CN4AUQL4.js +1460 -0
- package/dist/chunk-CQYGUBY6.js +1854 -0
- package/dist/chunk-CRJUMKVB.js +1862 -0
- package/dist/chunk-CZHUYI2J.js +997 -0
- package/dist/chunk-DIBSIWSR.js +1256 -0
- package/dist/chunk-DJGC3R4O.js +1836 -0
- package/dist/chunk-DJR2PEAQ.js +1884 -0
- package/dist/chunk-DKE7NWBK.js +1862 -0
- package/dist/chunk-DXYDN2OS.js +1147 -0
- package/dist/chunk-DZ3FEUJ7.js +1147 -0
- package/dist/chunk-EC47SFY3.js +1113 -0
- package/dist/chunk-ECAALEAK.js +1239 -0
- package/dist/chunk-ECEYIAQZ.js +997 -0
- package/dist/chunk-EKX7AV7O.js +1024 -0
- package/dist/chunk-EN6CTYUN.js +634 -0
- package/dist/chunk-EXCH47WX.js +1460 -0
- package/dist/chunk-EY2JOCTM.js +1862 -0
- package/dist/chunk-EYHB3LTH.js +1818 -0
- package/dist/chunk-F2AC5PKU.js +1446 -0
- package/dist/chunk-F5RCUJ62.js +1156 -0
- package/dist/chunk-F6OM65VA.js +1460 -0
- package/dist/chunk-FAEJ5CQU.js +997 -0
- package/dist/chunk-FB7X4KBF.js +1460 -0
- package/dist/chunk-FBSEEW3H.js +1862 -0
- package/dist/chunk-FBYY3TE5.js +1862 -0
- package/dist/chunk-FEA3GBGG.js +997 -0
- package/dist/chunk-FHPRGTOJ.js +1131 -0
- package/dist/chunk-FLAY6YWY.js +1389 -0
- package/dist/chunk-FNXIVJ3B.js +997 -0
- package/dist/chunk-FWRVG7RM.js +2160 -0
- package/dist/chunk-G47UW452.js +916 -0
- package/dist/chunk-G6V5O5AV.js +997 -0
- package/dist/chunk-GACQBIOO.js +1613 -0
- package/dist/chunk-GBFHLBWT.js +881 -0
- package/dist/chunk-GLJLTQMZ.js +997 -0
- package/dist/chunk-GN7DDBAT.js +1872 -0
- package/dist/chunk-GPTI42MM.js +1355 -0
- package/dist/chunk-GPXGCPVY.js +1834 -0
- package/dist/chunk-GRASQSCU.js +1886 -0
- package/dist/chunk-GU2WWG5C.js +1314 -0
- package/dist/chunk-GW3SAYT3.js +1679 -0
- package/dist/chunk-GZ4F2VI5.js +1447 -0
- package/dist/chunk-GZYXND4U.js +1322 -0
- package/dist/chunk-H27BRPVI.js +1862 -0
- package/dist/chunk-H4JRTOW7.js +1862 -0
- package/dist/chunk-HDS72SRU.js +1138 -0
- package/dist/chunk-HEUGSUL5.js +757 -0
- package/dist/chunk-HMZN5GPS.js +1024 -0
- package/dist/chunk-HN5SVGQO.js +1163 -0
- package/dist/chunk-HN6VQ5FI.js +242 -0
- package/dist/chunk-HNTQ66EL.js +2054 -0
- package/dist/chunk-HSDL3YK5.js +1134 -0
- package/dist/chunk-HVMIMERW.js +997 -0
- package/dist/chunk-HVWCQS2B.js +1834 -0
- package/dist/chunk-HVYMSOXQ.js +2156 -0
- package/dist/chunk-HYQITTK3.js +1862 -0
- package/dist/chunk-I4CCYPAI.js +1239 -0
- package/dist/chunk-IDG3X4UL.js +1229 -0
- package/dist/chunk-IDVRTQJ3.js +1514 -0
- package/dist/chunk-IEER23NN.js +1862 -0
- package/dist/chunk-IKLRYA4W.js +785 -0
- package/dist/chunk-IQBUSFBY.js +1270 -0
- package/dist/chunk-IUXQDZIR.js +1862 -0
- package/dist/chunk-IV74RJFV.js +1862 -0
- package/dist/chunk-IVEMIXXO.js +1854 -0
- package/dist/chunk-J4PNCGSP.js +1460 -0
- package/dist/chunk-J7ULLJUI.js +1862 -0
- package/dist/chunk-J7WHTBOM.js +983 -0
- package/dist/chunk-JBN6D7EG.js +1757 -0
- package/dist/chunk-JDKSD54C.js +1366 -0
- package/dist/chunk-JGWTOS7A.js +1507 -0
- package/dist/chunk-JHJ6FMSI.js +1804 -0
- package/dist/chunk-JJSHCP32.js +1282 -0
- package/dist/chunk-JLMAMC3V.js +1625 -0
- package/dist/chunk-JMTF7VV5.js +1919 -0
- package/dist/chunk-JO56GKTV.js +1133 -0
- package/dist/chunk-JRN3P6CS.js +1441 -0
- package/dist/chunk-JTKPRRSM.js +1024 -0
- package/dist/chunk-JVTFCTGO.js +1868 -0
- package/dist/chunk-JXH452LK.js +956 -0
- package/dist/chunk-K4SW5SP4.js +1147 -0
- package/dist/chunk-KANVHOQK.js +1880 -0
- package/dist/chunk-KBJZJWPZ.js +1143 -0
- package/dist/chunk-KFC4ZVRH.js +1798 -0
- package/dist/chunk-KHG6MSLS.js +1885 -0
- package/dist/chunk-KJJE6V5N.js +1886 -0
- package/dist/chunk-KKLEILZP.js +1868 -0
- package/dist/chunk-KW5QXXEN.js +1641 -0
- package/dist/chunk-KWMTK4N7.js +1147 -0
- package/dist/chunk-KYOW6LIV.js +1231 -0
- package/dist/chunk-KYWIUH3M.js +1355 -0
- package/dist/chunk-KZEA3HJL.js +1833 -0
- package/dist/chunk-L3KONBJE.js +1355 -0
- package/dist/chunk-L47B3OMM.js +1156 -0
- package/dist/chunk-LCQFWI6S.js +997 -0
- package/dist/chunk-LFIUZUI5.js +1138 -0
- package/dist/chunk-LHSLPQR4.js +1854 -0
- package/dist/chunk-LJGVAOFP.js +647 -0
- package/dist/chunk-LKJDYQPA.js +1687 -0
- package/dist/chunk-LOY6PWTR.js +1336 -0
- package/dist/chunk-LPFN3GNV.js +1147 -0
- package/dist/chunk-LPM7AN7S.js +1147 -0
- package/dist/chunk-LU6ES63L.js +1249 -0
- package/dist/chunk-M73DE7AU.js +1389 -0
- package/dist/chunk-M7OJ52WK.js +1448 -0
- package/dist/chunk-MCSM3DAE.js +1024 -0
- package/dist/chunk-MEP7OYUL.js +1417 -0
- package/dist/chunk-MFH6MVWX.js +1441 -0
- package/dist/chunk-MIHU3TFJ.js +1156 -0
- package/dist/chunk-MIU5FMSV.js +1329 -0
- package/dist/chunk-MJQMHH7Z.js +1976 -0
- package/dist/chunk-MLR2HUUY.js +1255 -0
- package/dist/chunk-MSBZHMUV.js +997 -0
- package/dist/chunk-MV4DZQRB.js +1163 -0
- package/dist/chunk-MWBLZDYK.js +1854 -0
- package/dist/chunk-N2MEPDSA.js +675 -0
- package/dist/chunk-N36ATUZM.js +1863 -0
- package/dist/chunk-NEHLM4WN.js +1610 -0
- package/dist/chunk-NHOJZ7FZ.js +1138 -0
- package/dist/chunk-NLPQBHHH.js +1282 -0
- package/dist/chunk-NMY3FWV7.js +1236 -0
- package/dist/chunk-NN2WDNCO.js +1138 -0
- package/dist/chunk-NNC7LH2Y.js +1258 -0
- package/dist/chunk-NQRWXPJ5.js +1275 -0
- package/dist/chunk-NR3G3D6Q.js +1238 -0
- package/dist/chunk-NRUAFOL3.js +2121 -0
- package/dist/chunk-NSCG7F6H.js +1862 -0
- package/dist/chunk-NXHVG7ZI.js +1113 -0
- package/dist/chunk-NYKPTBXA.js +1258 -0
- package/dist/chunk-O4AE4MFX.js +920 -0
- package/dist/chunk-O7GTMG3C.js +1467 -0
- package/dist/chunk-OBUP5UIM.js +997 -0
- package/dist/chunk-ONI2DTTL.js +1156 -0
- package/dist/chunk-OQHLTSVD.js +1776 -0
- package/dist/chunk-OVV6SHTA.js +997 -0
- package/dist/chunk-PAPAMVNI.js +1156 -0
- package/dist/chunk-PH7OXFMJ.js +997 -0
- package/dist/chunk-PHFLPSZU.js +1608 -0
- package/dist/chunk-PTVSK5DV.js +1854 -0
- package/dist/chunk-PUHWX6PD.js +1156 -0
- package/dist/chunk-PYDU2HN2.js +1803 -0
- package/dist/chunk-Q2AMIXBY.js +1250 -0
- package/dist/chunk-Q2EARVB7.js +1414 -0
- package/dist/chunk-Q4HFSYSN.js +1024 -0
- package/dist/chunk-Q65PNALY.js +1024 -0
- package/dist/chunk-QBQNHCYH.js +1791 -0
- package/dist/chunk-QGI55HK3.js +1433 -0
- package/dist/chunk-QIAODEAT.js +1862 -0
- package/dist/chunk-QLRJ2X3B.js +1800 -0
- package/dist/chunk-QTLVBIBL.js +1147 -0
- package/dist/chunk-QUPLQ7O4.js +1862 -0
- package/dist/chunk-QZGUSWLN.js +1415 -0
- package/dist/chunk-R7N3T7YR.js +1130 -0
- package/dist/chunk-RFS3GC46.js +239 -0
- package/dist/chunk-RJA7HIQO.js +1823 -0
- package/dist/chunk-RJLU3F7G.js +1156 -0
- package/dist/chunk-RLBXW5AY.js +1156 -0
- package/dist/chunk-RMKHLIMU.js +1147 -0
- package/dist/chunk-RS7F3BLO.js +1255 -0
- package/dist/chunk-RYLDHQQT.js +997 -0
- package/dist/chunk-RYYTEAQ7.js +1147 -0
- package/dist/chunk-S2KNKYQJ.js +1815 -0
- package/dist/chunk-S5R5IZJH.js +2056 -0
- package/dist/chunk-S5S7OBDZ.js +1355 -0
- package/dist/chunk-S6YKNJQG.js +1868 -0
- package/dist/chunk-SBDVWSWM.js +1251 -0
- package/dist/chunk-SBXSREFV.js +1237 -0
- package/dist/chunk-SDZJV47M.js +1238 -0
- package/dist/chunk-SMBILO75.js +1024 -0
- package/dist/chunk-SUSLSP3P.js +1456 -0
- package/dist/chunk-T4GPZ2AG.js +1128 -0
- package/dist/chunk-TA7EDJXT.js +1460 -0
- package/dist/chunk-TAW2ISST.js +1024 -0
- package/dist/chunk-TB6KKWS2.js +1138 -0
- package/dist/chunk-TBZCEX5O.js +1355 -0
- package/dist/chunk-TDOPKFNW.js +756 -0
- package/dist/chunk-TGY3JSDQ.js +1460 -0
- package/dist/chunk-THOIGUSY.js +666 -0
- package/dist/chunk-TLSGQKLO.js +1836 -0
- package/dist/chunk-TQ2QEU3G.js +1460 -0
- package/dist/chunk-TRJODOZM.js +1232 -0
- package/dist/chunk-TSBMRYLQ.js +1717 -0
- package/dist/chunk-TUL3R6KB.js +1024 -0
- package/dist/chunk-TWCD6YPP.js +2129 -0
- package/dist/chunk-TWQDGVLI.js +1323 -0
- package/dist/chunk-TZQLWQTW.js +769 -0
- package/dist/chunk-U22K555L.js +1803 -0
- package/dist/chunk-U3VXLQTW.js +1707 -0
- package/dist/chunk-U5QM4SRB.js +2054 -0
- package/dist/chunk-UCZLOOAW.js +997 -0
- package/dist/chunk-UDA2OZLK.js +1242 -0
- package/dist/chunk-UDASJ4IC.js +1355 -0
- package/dist/chunk-UGU2KSOQ.js +1113 -0
- package/dist/chunk-UJHB3CLA.js +1130 -0
- package/dist/chunk-UNUTAECX.js +1238 -0
- package/dist/chunk-UUUJVWXA.js +1806 -0
- package/dist/chunk-UV4WM7Q5.js +2039 -0
- package/dist/chunk-UXPGPOQ3.js +2113 -0
- package/dist/chunk-UYVWNYFB.js +1434 -0
- package/dist/chunk-UYWI4MPU.js +1460 -0
- package/dist/chunk-V2FNBN3P.js +997 -0
- package/dist/chunk-V6CF5XXG.js +1862 -0
- package/dist/chunk-V6UUV2SZ.js +1156 -0
- package/dist/chunk-VARTDMWQ.js +1862 -0
- package/dist/chunk-VC7ZYKMP.js +1156 -0
- package/dist/chunk-VCJNX77B.js +2038 -0
- package/dist/chunk-VDE2I72J.js +650 -0
- package/dist/chunk-VEO7FKEL.js +1156 -0
- package/dist/chunk-VIJYIU7E.js +2124 -0
- package/dist/chunk-VJX4WETG.js +1136 -0
- package/dist/chunk-VO3QDFU2.js +1276 -0
- package/dist/chunk-VOX2Q2V2.js +1933 -0
- package/dist/chunk-W7J5XM2X.js +1862 -0
- package/dist/chunk-WONM6P4N.js +1862 -0
- package/dist/chunk-WW576PYD.js +1862 -0
- package/dist/chunk-XCZCCA2D.js +997 -0
- package/dist/chunk-XHQOG4X6.js +1871 -0
- package/dist/chunk-XIYLHBWA.js +1163 -0
- package/dist/chunk-XKZ6XWSE.js +1907 -0
- package/dist/chunk-XLHKOBSF.js +1815 -0
- package/dist/chunk-XMMFUBB5.js +1270 -0
- package/dist/chunk-XQLK777K.js +1442 -0
- package/dist/chunk-XRN47M65.js +997 -0
- package/dist/chunk-XVBKUEXA.js +1441 -0
- package/dist/chunk-XY4ISIAV.js +1639 -0
- package/dist/chunk-Y2SOII6F.js +1156 -0
- package/dist/chunk-Y5TJU6YZ.js +1163 -0
- package/dist/chunk-YBPCMSUU.js +1147 -0
- package/dist/chunk-YDAZ3YZT.js +1004 -0
- package/dist/chunk-YH2QPUWO.js +1621 -0
- package/dist/chunk-YJX4O5CY.js +1355 -0
- package/dist/chunk-YNJMS3VK.js +997 -0
- package/dist/chunk-YNRZMOC3.js +997 -0
- package/dist/chunk-YNUF5JNP.js +1163 -0
- package/dist/chunk-YO7TJ6SG.js +2135 -0
- package/dist/chunk-YTUUFYVS.js +1842 -0
- package/dist/chunk-YXCOG54V.js +997 -0
- package/dist/chunk-Z7V254BA.js +1432 -0
- package/dist/chunk-ZBHRR3RS.js +1256 -0
- package/dist/chunk-ZM47X5PT.js +1236 -0
- package/dist/chunk-ZO6JUCLC.js +917 -0
- package/dist/chunk-ZOF4ERNI.js +2039 -0
- package/dist/chunk-ZOTRZN3T.js +1238 -0
- package/dist/chunk-ZPBA4JGE.js +1234 -0
- package/dist/chunk-ZTKGRHNV.js +1138 -0
- package/dist/chunk-ZW2JM2OY.js +997 -0
- package/dist/chunk-ZXYHUC7C.js +1722 -0
- package/dist/cli.d.ts +1 -0
- package/dist/cli.js +8 -0
- package/dist/index.d.ts +47 -0
- package/dist/index.js +37 -0
- package/dist/run-interactive-ink-2CDKFV6C.js +783 -0
- package/dist/run-interactive-ink-2JULLCIS.js +461 -0
- package/dist/run-interactive-ink-2KIHEGXT.js +451 -0
- package/dist/run-interactive-ink-2LX2NZRL.js +737 -0
- package/dist/run-interactive-ink-2OH6AV3C.js +756 -0
- package/dist/run-interactive-ink-2PLJ5XST.js +423 -0
- package/dist/run-interactive-ink-2ZI75VMK.js +462 -0
- package/dist/run-interactive-ink-3BHGPZ4B.js +423 -0
- package/dist/run-interactive-ink-3IUV3456.js +777 -0
- package/dist/run-interactive-ink-3QZK5PWY.js +168 -0
- package/dist/run-interactive-ink-3VLL4FNN.js +423 -0
- package/dist/run-interactive-ink-47Y2KAFZ.js +668 -0
- package/dist/run-interactive-ink-4CBTS636.js +423 -0
- package/dist/run-interactive-ink-4CHDJRAK.js +423 -0
- package/dist/run-interactive-ink-4E6GM5ST.js +423 -0
- package/dist/run-interactive-ink-4EKHIHGU.js +462 -0
- package/dist/run-interactive-ink-4NO7O233.js +744 -0
- package/dist/run-interactive-ink-55IZU2EZ.js +741 -0
- package/dist/run-interactive-ink-5A7BER6J.js +423 -0
- package/dist/run-interactive-ink-5NEFKF3R.js +423 -0
- package/dist/run-interactive-ink-5TCBH3Z4.js +462 -0
- package/dist/run-interactive-ink-5WOLWMGH.js +747 -0
- package/dist/run-interactive-ink-66JFIG2P.js +462 -0
- package/dist/run-interactive-ink-6R77DKEV.js +744 -0
- package/dist/run-interactive-ink-7B6HI7XT.js +679 -0
- package/dist/run-interactive-ink-7ICZH4E3.js +423 -0
- package/dist/run-interactive-ink-7LWBJYQE.js +423 -0
- package/dist/run-interactive-ink-7Y7MVKPA.js +438 -0
- package/dist/run-interactive-ink-A264MR35.js +423 -0
- package/dist/run-interactive-ink-A3NCKFFM.js +423 -0
- package/dist/run-interactive-ink-A4FBMTZ5.js +563 -0
- package/dist/run-interactive-ink-A7YPXRXR.js +462 -0
- package/dist/run-interactive-ink-AAER2EXR.js +451 -0
- package/dist/run-interactive-ink-ADVQJ2GF.js +423 -0
- package/dist/run-interactive-ink-ALV34HZF.js +451 -0
- package/dist/run-interactive-ink-ARDK3CO6.js +462 -0
- package/dist/run-interactive-ink-AVMVDBQK.js +462 -0
- package/dist/run-interactive-ink-AWV7ZOTC.js +423 -0
- package/dist/run-interactive-ink-AWZLJJLH.js +423 -0
- package/dist/run-interactive-ink-B25V52JO.js +462 -0
- package/dist/run-interactive-ink-BC6RGDCH.js +451 -0
- package/dist/run-interactive-ink-BMWLPUEU.js +451 -0
- package/dist/run-interactive-ink-BRT2MMN6.js +423 -0
- package/dist/run-interactive-ink-CB42OWV4.js +572 -0
- package/dist/run-interactive-ink-COZSBQND.js +777 -0
- package/dist/run-interactive-ink-CQFV44HM.js +451 -0
- package/dist/run-interactive-ink-CQMG45KQ.js +462 -0
- package/dist/run-interactive-ink-CQP3B7JM.js +669 -0
- package/dist/run-interactive-ink-CUCLNJCF.js +451 -0
- package/dist/run-interactive-ink-DEEZYQK5.js +423 -0
- package/dist/run-interactive-ink-DF5P6WZX.js +423 -0
- package/dist/run-interactive-ink-DFITKRY4.js +423 -0
- package/dist/run-interactive-ink-DG6TTEQQ.js +462 -0
- package/dist/run-interactive-ink-DH7ECECB.js +438 -0
- package/dist/run-interactive-ink-DMTUJHP6.js +423 -0
- package/dist/run-interactive-ink-DNSBSWLT.js +451 -0
- package/dist/run-interactive-ink-DV3TZEM3.js +742 -0
- package/dist/run-interactive-ink-E4AYCUDK.js +451 -0
- package/dist/run-interactive-ink-E4GPBTSL.js +462 -0
- package/dist/run-interactive-ink-ECVTPOIE.js +462 -0
- package/dist/run-interactive-ink-ELPCCGT3.js +423 -0
- package/dist/run-interactive-ink-ELWVRJZS.js +451 -0
- package/dist/run-interactive-ink-ENBMPAV7.js +462 -0
- package/dist/run-interactive-ink-EOVWUC3C.js +451 -0
- package/dist/run-interactive-ink-EVHWEXM4.js +451 -0
- package/dist/run-interactive-ink-F7SBCWE3.js +423 -0
- package/dist/run-interactive-ink-FCHXZ3JW.js +423 -0
- package/dist/run-interactive-ink-G27WWB5V.js +423 -0
- package/dist/run-interactive-ink-GDFTNYRC.js +462 -0
- package/dist/run-interactive-ink-GHGZAYSM.js +533 -0
- package/dist/run-interactive-ink-GK4IVHVT.js +684 -0
- package/dist/run-interactive-ink-GNCZNR6W.js +423 -0
- package/dist/run-interactive-ink-GQ53M5SW.js +605 -0
- package/dist/run-interactive-ink-GT7R7X2P.js +762 -0
- package/dist/run-interactive-ink-GWZTEIEZ.js +462 -0
- package/dist/run-interactive-ink-HA45VNUD.js +703 -0
- package/dist/run-interactive-ink-HB44RGFJ.js +423 -0
- package/dist/run-interactive-ink-HCVGKG23.js +462 -0
- package/dist/run-interactive-ink-HYKJ4PZ3.js +462 -0
- package/dist/run-interactive-ink-IGEBXARA.js +423 -0
- package/dist/run-interactive-ink-IGU7UVL5.js +462 -0
- package/dist/run-interactive-ink-JNVKOJRV.js +462 -0
- package/dist/run-interactive-ink-JYON5JQQ.js +461 -0
- package/dist/run-interactive-ink-K47CRELE.js +423 -0
- package/dist/run-interactive-ink-KCHMEHVH.js +547 -0
- package/dist/run-interactive-ink-KEB6ENSZ.js +423 -0
- package/dist/run-interactive-ink-KEWSKPTE.js +451 -0
- package/dist/run-interactive-ink-KJUHMADH.js +423 -0
- package/dist/run-interactive-ink-KW5NPJ32.js +423 -0
- package/dist/run-interactive-ink-L3EDWKF6.js +687 -0
- package/dist/run-interactive-ink-L4BCC6WG.js +462 -0
- package/dist/run-interactive-ink-LQPEZ6PR.js +520 -0
- package/dist/run-interactive-ink-LQXS5GMO.js +253 -0
- package/dist/run-interactive-ink-M4SOBC5E.js +817 -0
- package/dist/run-interactive-ink-MJGAQA2R.js +423 -0
- package/dist/run-interactive-ink-MPJB6PCJ.js +451 -0
- package/dist/run-interactive-ink-MXWZBG3F.js +461 -0
- package/dist/run-interactive-ink-N4XIVCWV.js +562 -0
- package/dist/run-interactive-ink-ND3PWHDU.js +462 -0
- package/dist/run-interactive-ink-NJTAWS3L.js +462 -0
- package/dist/run-interactive-ink-OBWWSIZ5.js +423 -0
- package/dist/run-interactive-ink-OD7YJBYI.js +423 -0
- package/dist/run-interactive-ink-OE23JGIN.js +451 -0
- package/dist/run-interactive-ink-OJ4EUMR5.js +462 -0
- package/dist/run-interactive-ink-OOC74RCY.js +423 -0
- package/dist/run-interactive-ink-P2PHTOX6.js +462 -0
- package/dist/run-interactive-ink-PE3XWCVU.js +423 -0
- package/dist/run-interactive-ink-PJBWWQF3.js +423 -0
- package/dist/run-interactive-ink-PLLZW6BV.js +678 -0
- package/dist/run-interactive-ink-PTXNQZ57.js +451 -0
- package/dist/run-interactive-ink-PWN5Q6T6.js +423 -0
- package/dist/run-interactive-ink-PZK4RD77.js +423 -0
- package/dist/run-interactive-ink-QBSXVTCG.js +462 -0
- package/dist/run-interactive-ink-QHOQB55Q.js +727 -0
- package/dist/run-interactive-ink-QIAC6ZMT.js +451 -0
- package/dist/run-interactive-ink-QLLGPIUL.js +462 -0
- package/dist/run-interactive-ink-R5W3ZEMY.js +818 -0
- package/dist/run-interactive-ink-RHDW3EHS.js +462 -0
- package/dist/run-interactive-ink-RLRKPNTS.js +668 -0
- package/dist/run-interactive-ink-RORQKBWV.js +425 -0
- package/dist/run-interactive-ink-RS6OZ66I.js +423 -0
- package/dist/run-interactive-ink-RVGRYBNQ.js +684 -0
- package/dist/run-interactive-ink-S35BKUZB.js +423 -0
- package/dist/run-interactive-ink-SS6RAQDE.js +423 -0
- package/dist/run-interactive-ink-SVP37E33.js +451 -0
- package/dist/run-interactive-ink-T53KH7FU.js +423 -0
- package/dist/run-interactive-ink-TCQUCJVS.js +423 -0
- package/dist/run-interactive-ink-TLUBKTTN.js +423 -0
- package/dist/run-interactive-ink-U2BAAHUU.js +438 -0
- package/dist/run-interactive-ink-U2KXGJ5S.js +451 -0
- package/dist/run-interactive-ink-U73PEMAO.js +423 -0
- package/dist/run-interactive-ink-UFTOTXIX.js +669 -0
- package/dist/run-interactive-ink-UJNQ54ZU.js +451 -0
- package/dist/run-interactive-ink-V63D5IV5.js +423 -0
- package/dist/run-interactive-ink-VLBITT4H.js +451 -0
- package/dist/run-interactive-ink-VSAX3XFR.js +462 -0
- package/dist/run-interactive-ink-WBJOY622.js +729 -0
- package/dist/run-interactive-ink-WERR64KP.js +451 -0
- package/dist/run-interactive-ink-WHTQ5OV6.js +732 -0
- package/dist/run-interactive-ink-WJBK4XIO.js +423 -0
- package/dist/run-interactive-ink-WQLCJ34D.js +462 -0
- package/dist/run-interactive-ink-WRKQJIAG.js +733 -0
- package/dist/run-interactive-ink-XG3P25DM.js +423 -0
- package/dist/run-interactive-ink-XPVJ22HP.js +462 -0
- package/dist/run-interactive-ink-XS5I2CGI.js +423 -0
- package/dist/run-interactive-ink-XVK7DXPB.js +785 -0
- package/dist/run-interactive-ink-YB3USTSB.js +706 -0
- package/dist/run-interactive-ink-YCBRQCG2.js +423 -0
- package/dist/run-interactive-ink-YOPSMTYJ.js +423 -0
- package/dist/run-interactive-ink-YYPCL65X.js +665 -0
- package/dist/run-interactive-ink-YYZT5L4Z.js +462 -0
- package/dist/run-interactive-ink-ZBPYRTJK.js +462 -0
- package/dist/run-interactive-ink-ZCCKFR2A.js +451 -0
- package/dist/run-interactive-ink-ZKYQ4CJW.js +423 -0
- package/dist/run-interactive-ink-ZMO2352Q.js +685 -0
- package/dist/run-interactive-ink-ZTDQ773P.js +423 -0
- package/dist/run-interactive-ink-ZWH74XDY.js +674 -0
- package/package.json +50 -0
- package/src/cli.ts +4 -0
- package/src/index.ts +1800 -0
- package/src/init-feature-context.ts +153 -0
- package/src/init-onboarding.ts +529 -0
- package/src/interactive-ink.tsx +5 -0
- package/src/run-interactive-ink.ts +618 -0
- package/src/web-ui.ts +1975 -0
- package/test/cli.test.ts +587 -0
- package/test/init-onboarding.contract.test.ts +48 -0
- package/tsconfig.json +9 -0
|
@@ -0,0 +1,757 @@
|
|
|
1
|
+
// src/index.ts
|
|
2
|
+
import { spawn } from "child_process";
|
|
3
|
+
import { access, mkdir, readFile, writeFile } from "fs/promises";
|
|
4
|
+
import {
|
|
5
|
+
createServer
|
|
6
|
+
} from "http";
|
|
7
|
+
import { dirname, resolve } from "path";
|
|
8
|
+
import { createRequire } from "module";
|
|
9
|
+
import readline from "readline/promises";
|
|
10
|
+
import { fileURLToPath } from "url";
|
|
11
|
+
import {
|
|
12
|
+
AgentHarness,
|
|
13
|
+
TelemetryEmitter,
|
|
14
|
+
createStateStore,
|
|
15
|
+
loadAgentlConfig
|
|
16
|
+
} from "@agentl/harness";
|
|
17
|
+
import { Command } from "commander";
|
|
18
|
+
import dotenv from "dotenv";
|
|
19
|
+
import YAML from "yaml";
|
|
20
|
+
var __dirname = dirname(fileURLToPath(import.meta.url));
|
|
21
|
+
var require2 = createRequire(import.meta.url);
|
|
22
|
+
var writeJson = (response, statusCode, payload) => {
|
|
23
|
+
response.writeHead(statusCode, { "Content-Type": "application/json" });
|
|
24
|
+
response.end(JSON.stringify(payload));
|
|
25
|
+
};
|
|
26
|
+
var readRequestBody = async (request) => {
|
|
27
|
+
const chunks = [];
|
|
28
|
+
for await (const chunk of request) {
|
|
29
|
+
chunks.push(Buffer.from(chunk));
|
|
30
|
+
}
|
|
31
|
+
const body = Buffer.concat(chunks).toString("utf8");
|
|
32
|
+
return body.length > 0 ? JSON.parse(body) : {};
|
|
33
|
+
};
|
|
34
|
+
var parseParams = (values) => {
|
|
35
|
+
const params = {};
|
|
36
|
+
for (const value of values) {
|
|
37
|
+
const [key, ...rest] = value.split("=");
|
|
38
|
+
if (!key) {
|
|
39
|
+
continue;
|
|
40
|
+
}
|
|
41
|
+
params[key] = rest.join("=");
|
|
42
|
+
}
|
|
43
|
+
return params;
|
|
44
|
+
};
|
|
45
|
+
var AGENT_TEMPLATE = `---
|
|
46
|
+
name: my-agent
|
|
47
|
+
description: A helpful AgentL assistant
|
|
48
|
+
model:
|
|
49
|
+
provider: anthropic
|
|
50
|
+
name: claude-sonnet-4-20250514
|
|
51
|
+
temperature: 0.2
|
|
52
|
+
limits:
|
|
53
|
+
maxSteps: 50
|
|
54
|
+
timeout: 300
|
|
55
|
+
---
|
|
56
|
+
|
|
57
|
+
# My Agent
|
|
58
|
+
|
|
59
|
+
You are a helpful assistant built with AgentL.
|
|
60
|
+
|
|
61
|
+
Working directory: {{runtime.workingDir}}
|
|
62
|
+
Environment: {{runtime.environment}}
|
|
63
|
+
|
|
64
|
+
## Task Guidance
|
|
65
|
+
|
|
66
|
+
- Use tools when needed
|
|
67
|
+
- Explain your reasoning clearly
|
|
68
|
+
- Ask clarifying questions when requirements are ambiguous
|
|
69
|
+
`;
|
|
70
|
+
var CONFIG_TEMPLATE = `export default {
|
|
71
|
+
mcp: [],
|
|
72
|
+
auth: { required: false },
|
|
73
|
+
state: { provider: 'memory', ttl: 3600 },
|
|
74
|
+
telemetry: { enabled: true }
|
|
75
|
+
}
|
|
76
|
+
`;
|
|
77
|
+
var PACKAGE_TEMPLATE = (name) => JSON.stringify(
|
|
78
|
+
{
|
|
79
|
+
name,
|
|
80
|
+
private: true,
|
|
81
|
+
type: "module",
|
|
82
|
+
dependencies: {
|
|
83
|
+
"@agentl/harness": "^0.1.0"
|
|
84
|
+
}
|
|
85
|
+
},
|
|
86
|
+
null,
|
|
87
|
+
2
|
|
88
|
+
);
|
|
89
|
+
var ENV_TEMPLATE = "ANTHROPIC_API_KEY=sk-ant-...\n";
|
|
90
|
+
var GITIGNORE_TEMPLATE = ".env\nnode_modules\ndist\n";
|
|
91
|
+
var TEST_TEMPLATE = `tests:
|
|
92
|
+
- name: "Basic sanity"
|
|
93
|
+
task: "What is 2 + 2?"
|
|
94
|
+
expect:
|
|
95
|
+
contains: "4"
|
|
96
|
+
`;
|
|
97
|
+
var SKILL_TEMPLATE = `---
|
|
98
|
+
name: starter-skill
|
|
99
|
+
version: 1.0.0
|
|
100
|
+
description: Starter local skill template
|
|
101
|
+
tools:
|
|
102
|
+
- starter-echo
|
|
103
|
+
---
|
|
104
|
+
|
|
105
|
+
# Starter Skill
|
|
106
|
+
|
|
107
|
+
This is a starter local skill created by \`agentl init\`.
|
|
108
|
+
`;
|
|
109
|
+
var SKILL_TOOL_TEMPLATE = `import { defineTool } from "@agentl/sdk";
|
|
110
|
+
|
|
111
|
+
export default defineTool({
|
|
112
|
+
name: "starter-echo",
|
|
113
|
+
description: "Echoes a message for testing local skill wiring",
|
|
114
|
+
inputSchema: {
|
|
115
|
+
type: "object",
|
|
116
|
+
properties: {
|
|
117
|
+
message: { type: "string", description: "Message to echo" }
|
|
118
|
+
},
|
|
119
|
+
required: ["message"]
|
|
120
|
+
},
|
|
121
|
+
async handler(input) {
|
|
122
|
+
return { echoed: input.message };
|
|
123
|
+
}
|
|
124
|
+
});
|
|
125
|
+
`;
|
|
126
|
+
var ensureFile = async (path, content) => {
|
|
127
|
+
await mkdir(dirname(path), { recursive: true });
|
|
128
|
+
await writeFile(path, content, { encoding: "utf8", flag: "wx" });
|
|
129
|
+
};
|
|
130
|
+
var writeConfigFile = async (workingDir, config) => {
|
|
131
|
+
const serialized = `export default ${JSON.stringify(config, null, 2)}
|
|
132
|
+
`;
|
|
133
|
+
await writeFile(resolve(workingDir, "agentl.config.js"), serialized, "utf8");
|
|
134
|
+
};
|
|
135
|
+
var extractToken = (request, authConfig) => {
|
|
136
|
+
if (authConfig.type === "header") {
|
|
137
|
+
const headerName = (authConfig.headerName ?? "x-agent-api-key").toLowerCase();
|
|
138
|
+
const raw = request.headers[headerName];
|
|
139
|
+
return Array.isArray(raw) ? raw[0] ?? "" : raw ?? "";
|
|
140
|
+
}
|
|
141
|
+
const authHeader = request.headers.authorization ?? "";
|
|
142
|
+
if (authHeader.toLowerCase().startsWith("bearer ")) {
|
|
143
|
+
return authHeader.slice(7).trim();
|
|
144
|
+
}
|
|
145
|
+
return "";
|
|
146
|
+
};
|
|
147
|
+
var authorizeRequest = async (request, config) => {
|
|
148
|
+
const authConfig = config?.auth;
|
|
149
|
+
if (!authConfig?.required) {
|
|
150
|
+
return true;
|
|
151
|
+
}
|
|
152
|
+
const token = extractToken(request, authConfig);
|
|
153
|
+
if (!token) {
|
|
154
|
+
return false;
|
|
155
|
+
}
|
|
156
|
+
if (authConfig.validate) {
|
|
157
|
+
return await authConfig.validate(token, request);
|
|
158
|
+
}
|
|
159
|
+
return token === (process.env.AGENT_API_KEY ?? "");
|
|
160
|
+
};
|
|
161
|
+
var initProject = async (projectName, options) => {
|
|
162
|
+
const baseDir = options?.workingDir ?? process.cwd();
|
|
163
|
+
const projectDir = resolve(baseDir, projectName);
|
|
164
|
+
await mkdir(projectDir, { recursive: true });
|
|
165
|
+
await ensureFile(resolve(projectDir, "AGENT.md"), AGENT_TEMPLATE);
|
|
166
|
+
await ensureFile(resolve(projectDir, "agentl.config.js"), CONFIG_TEMPLATE);
|
|
167
|
+
await ensureFile(resolve(projectDir, "package.json"), PACKAGE_TEMPLATE(projectName));
|
|
168
|
+
await ensureFile(resolve(projectDir, ".env.example"), ENV_TEMPLATE);
|
|
169
|
+
await ensureFile(resolve(projectDir, ".gitignore"), GITIGNORE_TEMPLATE);
|
|
170
|
+
await ensureFile(resolve(projectDir, "tests", "basic.yaml"), TEST_TEMPLATE);
|
|
171
|
+
await ensureFile(resolve(projectDir, "skills", "starter", "SKILL.md"), SKILL_TEMPLATE);
|
|
172
|
+
await ensureFile(
|
|
173
|
+
resolve(projectDir, "skills", "starter", "tools", "starter-echo.ts"),
|
|
174
|
+
SKILL_TOOL_TEMPLATE
|
|
175
|
+
);
|
|
176
|
+
process.stdout.write(`Initialized AgentL project at ${projectDir}
|
|
177
|
+
`);
|
|
178
|
+
};
|
|
179
|
+
var formatSseEvent = (event) => `event: ${event.type}
|
|
180
|
+
data: ${JSON.stringify(event)}
|
|
181
|
+
|
|
182
|
+
`;
|
|
183
|
+
var startDevServer = async (port, options) => {
|
|
184
|
+
const workingDir = options?.workingDir ?? process.cwd();
|
|
185
|
+
dotenv.config({ path: resolve(workingDir, ".env") });
|
|
186
|
+
const config = await loadAgentlConfig(workingDir);
|
|
187
|
+
const harness = new AgentHarness({ workingDir });
|
|
188
|
+
await harness.initialize();
|
|
189
|
+
const telemetry = new TelemetryEmitter(config?.telemetry);
|
|
190
|
+
const stateStore = createStateStore(config?.state);
|
|
191
|
+
const server = createServer(async (request, response) => {
|
|
192
|
+
if (!request.url || !request.method) {
|
|
193
|
+
writeJson(response, 404, { error: "Not found" });
|
|
194
|
+
return;
|
|
195
|
+
}
|
|
196
|
+
const [pathname] = request.url.split("?");
|
|
197
|
+
if (pathname === "/health" && request.method === "GET") {
|
|
198
|
+
writeJson(response, 200, { status: "ok" });
|
|
199
|
+
return;
|
|
200
|
+
}
|
|
201
|
+
if (!await authorizeRequest(request, config)) {
|
|
202
|
+
writeJson(response, 401, {
|
|
203
|
+
code: "AUTH_ERROR",
|
|
204
|
+
message: "Authentication failed"
|
|
205
|
+
});
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
if (pathname === "/run/sync" && request.method === "POST") {
|
|
209
|
+
try {
|
|
210
|
+
const input = await readRequestBody(request);
|
|
211
|
+
const output = await harness.runToCompletion(input);
|
|
212
|
+
await stateStore.set({
|
|
213
|
+
runId: output.runId,
|
|
214
|
+
messages: output.messages,
|
|
215
|
+
updatedAt: Date.now()
|
|
216
|
+
});
|
|
217
|
+
for (const event of output.events) {
|
|
218
|
+
await telemetry.emit(event);
|
|
219
|
+
}
|
|
220
|
+
writeJson(response, 200, {
|
|
221
|
+
runId: output.runId,
|
|
222
|
+
status: output.result.status,
|
|
223
|
+
result: output.result
|
|
224
|
+
});
|
|
225
|
+
} catch (error) {
|
|
226
|
+
writeJson(response, 500, {
|
|
227
|
+
code: "RUN_ERROR",
|
|
228
|
+
message: error instanceof Error ? error.message : "Unknown error"
|
|
229
|
+
});
|
|
230
|
+
}
|
|
231
|
+
return;
|
|
232
|
+
}
|
|
233
|
+
if (pathname === "/run" && request.method === "POST") {
|
|
234
|
+
response.writeHead(200, {
|
|
235
|
+
"Content-Type": "text/event-stream",
|
|
236
|
+
"Cache-Control": "no-cache",
|
|
237
|
+
Connection: "keep-alive"
|
|
238
|
+
});
|
|
239
|
+
try {
|
|
240
|
+
const input = await readRequestBody(request);
|
|
241
|
+
let runId = "";
|
|
242
|
+
let finalResponse = "";
|
|
243
|
+
const baseMessages = [
|
|
244
|
+
...input.messages ?? [],
|
|
245
|
+
{ role: "user", content: input.task }
|
|
246
|
+
];
|
|
247
|
+
for await (const event of harness.run(input)) {
|
|
248
|
+
if (event.type === "run:started") {
|
|
249
|
+
runId = event.runId;
|
|
250
|
+
}
|
|
251
|
+
if (event.type === "run:completed") {
|
|
252
|
+
finalResponse = event.result.response ?? "";
|
|
253
|
+
}
|
|
254
|
+
await telemetry.emit(event);
|
|
255
|
+
response.write(formatSseEvent(event));
|
|
256
|
+
}
|
|
257
|
+
if (runId) {
|
|
258
|
+
await stateStore.set({
|
|
259
|
+
runId,
|
|
260
|
+
messages: [...baseMessages, { role: "assistant", content: finalResponse }],
|
|
261
|
+
updatedAt: Date.now()
|
|
262
|
+
});
|
|
263
|
+
}
|
|
264
|
+
} catch (error) {
|
|
265
|
+
response.write(
|
|
266
|
+
formatSseEvent({
|
|
267
|
+
type: "run:error",
|
|
268
|
+
runId: "run_unknown",
|
|
269
|
+
error: {
|
|
270
|
+
code: "RUN_ERROR",
|
|
271
|
+
message: error instanceof Error ? error.message : "Unknown error"
|
|
272
|
+
}
|
|
273
|
+
})
|
|
274
|
+
);
|
|
275
|
+
} finally {
|
|
276
|
+
response.end();
|
|
277
|
+
}
|
|
278
|
+
return;
|
|
279
|
+
}
|
|
280
|
+
if (pathname === "/continue" && request.method === "POST") {
|
|
281
|
+
try {
|
|
282
|
+
const body = await readRequestBody(request);
|
|
283
|
+
if (!body.runId || !body.message) {
|
|
284
|
+
writeJson(response, 400, {
|
|
285
|
+
code: "VALIDATION_ERROR",
|
|
286
|
+
message: "Both runId and message are required"
|
|
287
|
+
});
|
|
288
|
+
return;
|
|
289
|
+
}
|
|
290
|
+
const state = await stateStore.get(body.runId);
|
|
291
|
+
if (!state) {
|
|
292
|
+
writeJson(response, 404, {
|
|
293
|
+
code: "RUN_NOT_FOUND",
|
|
294
|
+
message: `No conversation found for runId ${body.runId}`
|
|
295
|
+
});
|
|
296
|
+
return;
|
|
297
|
+
}
|
|
298
|
+
const output = await harness.runToCompletion({
|
|
299
|
+
task: body.message,
|
|
300
|
+
parameters: body.parameters,
|
|
301
|
+
messages: state.messages
|
|
302
|
+
});
|
|
303
|
+
await stateStore.set({
|
|
304
|
+
runId: output.runId,
|
|
305
|
+
messages: output.messages,
|
|
306
|
+
updatedAt: Date.now()
|
|
307
|
+
});
|
|
308
|
+
for (const event of output.events) {
|
|
309
|
+
await telemetry.emit(event);
|
|
310
|
+
}
|
|
311
|
+
writeJson(response, 200, {
|
|
312
|
+
runId: output.runId,
|
|
313
|
+
status: output.result.status,
|
|
314
|
+
result: output.result
|
|
315
|
+
});
|
|
316
|
+
} catch (error) {
|
|
317
|
+
writeJson(response, 500, {
|
|
318
|
+
code: "CONTINUE_ERROR",
|
|
319
|
+
message: error instanceof Error ? error.message : "Unknown error"
|
|
320
|
+
});
|
|
321
|
+
}
|
|
322
|
+
return;
|
|
323
|
+
}
|
|
324
|
+
writeJson(response, 404, { error: "Not found" });
|
|
325
|
+
});
|
|
326
|
+
await new Promise((resolveStart) => {
|
|
327
|
+
server.listen(port, () => resolveStart());
|
|
328
|
+
});
|
|
329
|
+
process.stdout.write(`AgentL dev server running at http://localhost:${port}
|
|
330
|
+
`);
|
|
331
|
+
return server;
|
|
332
|
+
};
|
|
333
|
+
var runOnce = async (task, options) => {
|
|
334
|
+
const workingDir = options.workingDir ?? process.cwd();
|
|
335
|
+
dotenv.config({ path: resolve(workingDir, ".env") });
|
|
336
|
+
const config = await loadAgentlConfig(workingDir);
|
|
337
|
+
const harness = new AgentHarness({ workingDir });
|
|
338
|
+
const telemetry = new TelemetryEmitter(config?.telemetry);
|
|
339
|
+
await harness.initialize();
|
|
340
|
+
const fileBlobs = await Promise.all(
|
|
341
|
+
options.filePaths.map(async (path) => {
|
|
342
|
+
const content = await readFile(resolve(workingDir, path), "utf8");
|
|
343
|
+
return `# File: ${path}
|
|
344
|
+
${content}`;
|
|
345
|
+
})
|
|
346
|
+
);
|
|
347
|
+
const input = {
|
|
348
|
+
task: fileBlobs.length > 0 ? `${task}
|
|
349
|
+
|
|
350
|
+
${fileBlobs.join("\n\n")}` : task,
|
|
351
|
+
parameters: options.params
|
|
352
|
+
};
|
|
353
|
+
if (options.json) {
|
|
354
|
+
const output = await harness.runToCompletion(input);
|
|
355
|
+
for (const event of output.events) {
|
|
356
|
+
await telemetry.emit(event);
|
|
357
|
+
}
|
|
358
|
+
process.stdout.write(`${JSON.stringify(output, null, 2)}
|
|
359
|
+
`);
|
|
360
|
+
return;
|
|
361
|
+
}
|
|
362
|
+
for await (const event of harness.run(input)) {
|
|
363
|
+
await telemetry.emit(event);
|
|
364
|
+
if (event.type === "model:chunk") {
|
|
365
|
+
process.stdout.write(event.content);
|
|
366
|
+
}
|
|
367
|
+
if (event.type === "run:error") {
|
|
368
|
+
process.stderr.write(`
|
|
369
|
+
Error: ${event.error.message}
|
|
370
|
+
`);
|
|
371
|
+
}
|
|
372
|
+
if (event.type === "run:completed") {
|
|
373
|
+
process.stdout.write("\n");
|
|
374
|
+
}
|
|
375
|
+
}
|
|
376
|
+
};
|
|
377
|
+
var runInteractive = async (workingDir, params) => {
|
|
378
|
+
const harness = new AgentHarness({ workingDir });
|
|
379
|
+
await harness.initialize();
|
|
380
|
+
const rl = readline.createInterface({
|
|
381
|
+
input: process.stdin,
|
|
382
|
+
output: process.stdout
|
|
383
|
+
});
|
|
384
|
+
const messages = [];
|
|
385
|
+
process.stdout.write("Interactive mode. Type 'exit' to quit.\n");
|
|
386
|
+
while (true) {
|
|
387
|
+
const task = await rl.question("> ");
|
|
388
|
+
if (task.trim().toLowerCase() === "exit") {
|
|
389
|
+
break;
|
|
390
|
+
}
|
|
391
|
+
const output = await harness.runToCompletion({
|
|
392
|
+
task,
|
|
393
|
+
parameters: params,
|
|
394
|
+
messages
|
|
395
|
+
});
|
|
396
|
+
process.stdout.write(`${output.result.response ?? ""}
|
|
397
|
+
`);
|
|
398
|
+
messages.splice(0, messages.length, ...output.messages);
|
|
399
|
+
}
|
|
400
|
+
rl.close();
|
|
401
|
+
};
|
|
402
|
+
var listTools = async (workingDir) => {
|
|
403
|
+
dotenv.config({ path: resolve(workingDir, ".env") });
|
|
404
|
+
const harness = new AgentHarness({ workingDir });
|
|
405
|
+
await harness.initialize();
|
|
406
|
+
const tools = harness.listTools();
|
|
407
|
+
if (tools.length === 0) {
|
|
408
|
+
process.stdout.write("No tools registered.\n");
|
|
409
|
+
return;
|
|
410
|
+
}
|
|
411
|
+
process.stdout.write("Available tools:\n");
|
|
412
|
+
for (const tool of tools) {
|
|
413
|
+
process.stdout.write(`- ${tool.name}: ${tool.description}
|
|
414
|
+
`);
|
|
415
|
+
}
|
|
416
|
+
};
|
|
417
|
+
var runInstallCommand = async (workingDir, packageNameOrPath) => await new Promise((resolveInstall, rejectInstall) => {
|
|
418
|
+
const child = spawn("pnpm", ["add", packageNameOrPath], {
|
|
419
|
+
cwd: workingDir,
|
|
420
|
+
stdio: "inherit",
|
|
421
|
+
env: process.env
|
|
422
|
+
});
|
|
423
|
+
child.on("exit", (code) => {
|
|
424
|
+
if (code === 0) {
|
|
425
|
+
resolveInstall();
|
|
426
|
+
return;
|
|
427
|
+
}
|
|
428
|
+
rejectInstall(new Error(`pnpm add failed with exit code ${code ?? -1}`));
|
|
429
|
+
});
|
|
430
|
+
});
|
|
431
|
+
var validateSkillPackage = async (workingDir, packageNameOrPath) => {
|
|
432
|
+
const packageJsonPath = packageNameOrPath.startsWith(".") || packageNameOrPath.startsWith("/") ? resolve(workingDir, packageNameOrPath, "package.json") : require2.resolve(`${packageNameOrPath}/package.json`, {
|
|
433
|
+
paths: [workingDir]
|
|
434
|
+
});
|
|
435
|
+
const skillRoot = resolve(packageJsonPath, "..");
|
|
436
|
+
const skillManifest = resolve(skillRoot, "SKILL.md");
|
|
437
|
+
try {
|
|
438
|
+
await access(skillManifest);
|
|
439
|
+
} catch {
|
|
440
|
+
throw new Error(`Skill validation failed: missing SKILL.md in ${skillRoot}`);
|
|
441
|
+
}
|
|
442
|
+
};
|
|
443
|
+
var addSkill = async (workingDir, packageNameOrPath) => {
|
|
444
|
+
await runInstallCommand(workingDir, packageNameOrPath);
|
|
445
|
+
await validateSkillPackage(workingDir, packageNameOrPath);
|
|
446
|
+
process.stdout.write(`Added skill: ${packageNameOrPath}
|
|
447
|
+
`);
|
|
448
|
+
};
|
|
449
|
+
var runTests = async (workingDir, filePath) => {
|
|
450
|
+
dotenv.config({ path: resolve(workingDir, ".env") });
|
|
451
|
+
const testFilePath = filePath ?? resolve(workingDir, "tests", "basic.yaml");
|
|
452
|
+
const content = await readFile(testFilePath, "utf8");
|
|
453
|
+
const parsed = YAML.parse(content);
|
|
454
|
+
const tests = parsed.tests ?? [];
|
|
455
|
+
const harness = new AgentHarness({ workingDir });
|
|
456
|
+
await harness.initialize();
|
|
457
|
+
let passed = 0;
|
|
458
|
+
let failed = 0;
|
|
459
|
+
for (const testCase of tests) {
|
|
460
|
+
const output = await harness.runToCompletion({ task: testCase.task });
|
|
461
|
+
const response = output.result.response ?? "";
|
|
462
|
+
const events = output.events;
|
|
463
|
+
const expectation = testCase.expect ?? {};
|
|
464
|
+
const checks = [];
|
|
465
|
+
if (expectation.contains) {
|
|
466
|
+
checks.push(response.includes(expectation.contains));
|
|
467
|
+
}
|
|
468
|
+
if (typeof expectation.maxSteps === "number") {
|
|
469
|
+
checks.push(output.result.steps <= expectation.maxSteps);
|
|
470
|
+
}
|
|
471
|
+
if (typeof expectation.maxTokens === "number") {
|
|
472
|
+
checks.push(output.result.tokens.input + output.result.tokens.output <= expectation.maxTokens);
|
|
473
|
+
}
|
|
474
|
+
if (expectation.refusal) {
|
|
475
|
+
checks.push(response.toLowerCase().includes("can't") || response.toLowerCase().includes("cannot"));
|
|
476
|
+
}
|
|
477
|
+
if (expectation.toolCalled) {
|
|
478
|
+
checks.push(
|
|
479
|
+
events.some(
|
|
480
|
+
(event) => event.type === "tool:started" && event.tool === expectation.toolCalled
|
|
481
|
+
)
|
|
482
|
+
);
|
|
483
|
+
}
|
|
484
|
+
const ok = checks.length === 0 ? output.result.status === "completed" : checks.every(Boolean);
|
|
485
|
+
if (ok) {
|
|
486
|
+
passed += 1;
|
|
487
|
+
process.stdout.write(`PASS ${testCase.name}
|
|
488
|
+
`);
|
|
489
|
+
} else {
|
|
490
|
+
failed += 1;
|
|
491
|
+
process.stdout.write(`FAIL ${testCase.name}
|
|
492
|
+
`);
|
|
493
|
+
}
|
|
494
|
+
}
|
|
495
|
+
process.stdout.write(`
|
|
496
|
+
Test summary: ${passed} passed, ${failed} failed
|
|
497
|
+
`);
|
|
498
|
+
return { passed, failed };
|
|
499
|
+
};
|
|
500
|
+
var buildTarget = async (workingDir, target) => {
|
|
501
|
+
const outDir = resolve(workingDir, ".agentl-build", target);
|
|
502
|
+
await mkdir(outDir, { recursive: true });
|
|
503
|
+
const serverEntrypoint = `import { startDevServer } from "agentl";
|
|
504
|
+
|
|
505
|
+
const port = Number.parseInt(process.env.PORT ?? "3000", 10);
|
|
506
|
+
await startDevServer(Number.isNaN(port) ? 3000 : port, { workingDir: process.cwd() });
|
|
507
|
+
`;
|
|
508
|
+
const runtimePackageJson = JSON.stringify(
|
|
509
|
+
{
|
|
510
|
+
name: "agentl-runtime-bundle",
|
|
511
|
+
private: true,
|
|
512
|
+
type: "module",
|
|
513
|
+
scripts: {
|
|
514
|
+
start: "node server.js"
|
|
515
|
+
},
|
|
516
|
+
dependencies: {
|
|
517
|
+
agentl: "^0.1.0"
|
|
518
|
+
}
|
|
519
|
+
},
|
|
520
|
+
null,
|
|
521
|
+
2
|
|
522
|
+
);
|
|
523
|
+
if (target === "vercel") {
|
|
524
|
+
await mkdir(resolve(outDir, "api"), { recursive: true });
|
|
525
|
+
await writeFile(
|
|
526
|
+
resolve(outDir, "vercel.json"),
|
|
527
|
+
JSON.stringify(
|
|
528
|
+
{
|
|
529
|
+
version: 2,
|
|
530
|
+
functions: { "api/index.js": { runtime: "nodejs20.x", maxDuration: 60 } },
|
|
531
|
+
routes: [{ src: "/(.*)", dest: "/api/index.js" }]
|
|
532
|
+
},
|
|
533
|
+
null,
|
|
534
|
+
2
|
|
535
|
+
),
|
|
536
|
+
"utf8"
|
|
537
|
+
);
|
|
538
|
+
await writeFile(
|
|
539
|
+
resolve(outDir, "api", "index.js"),
|
|
540
|
+
`import { startDevServer } from "agentl";
|
|
541
|
+
|
|
542
|
+
let serverPromise;
|
|
543
|
+
export default async function handler(req, res) {
|
|
544
|
+
if (!serverPromise) {
|
|
545
|
+
serverPromise = startDevServer(0, { workingDir: process.cwd() });
|
|
546
|
+
}
|
|
547
|
+
const server = await serverPromise;
|
|
548
|
+
server.emit("request", req, res);
|
|
549
|
+
}
|
|
550
|
+
`,
|
|
551
|
+
"utf8"
|
|
552
|
+
);
|
|
553
|
+
} else if (target === "docker") {
|
|
554
|
+
await writeFile(
|
|
555
|
+
resolve(outDir, "Dockerfile"),
|
|
556
|
+
`FROM node:20-slim
|
|
557
|
+
WORKDIR /app
|
|
558
|
+
COPY package.json package.json
|
|
559
|
+
COPY AGENT.md AGENT.md
|
|
560
|
+
COPY agentl.config.js agentl.config.js
|
|
561
|
+
COPY skills skills
|
|
562
|
+
COPY tests tests
|
|
563
|
+
COPY .env.example .env.example
|
|
564
|
+
RUN corepack enable && npm install -g agentl
|
|
565
|
+
COPY server.js server.js
|
|
566
|
+
EXPOSE 3000
|
|
567
|
+
CMD ["node","server.js"]
|
|
568
|
+
`,
|
|
569
|
+
"utf8"
|
|
570
|
+
);
|
|
571
|
+
await writeFile(resolve(outDir, "server.js"), serverEntrypoint, "utf8");
|
|
572
|
+
await writeFile(resolve(outDir, "package.json"), runtimePackageJson, "utf8");
|
|
573
|
+
} else if (target === "lambda") {
|
|
574
|
+
await writeFile(
|
|
575
|
+
resolve(outDir, "lambda-handler.js"),
|
|
576
|
+
`import { startDevServer } from "agentl";
|
|
577
|
+
let serverPromise;
|
|
578
|
+
export const handler = async (event = {}) => {
|
|
579
|
+
if (!serverPromise) {
|
|
580
|
+
serverPromise = startDevServer(0, { workingDir: process.cwd() });
|
|
581
|
+
}
|
|
582
|
+
const body = JSON.stringify({
|
|
583
|
+
status: "ready",
|
|
584
|
+
route: event.rawPath ?? event.path ?? "/",
|
|
585
|
+
});
|
|
586
|
+
return { statusCode: 200, headers: { "content-type": "application/json" }, body };
|
|
587
|
+
};
|
|
588
|
+
`,
|
|
589
|
+
"utf8"
|
|
590
|
+
);
|
|
591
|
+
await writeFile(resolve(outDir, "package.json"), runtimePackageJson, "utf8");
|
|
592
|
+
} else if (target === "fly") {
|
|
593
|
+
await writeFile(
|
|
594
|
+
resolve(outDir, "fly.toml"),
|
|
595
|
+
`app = "agentl-app"
|
|
596
|
+
[env]
|
|
597
|
+
PORT = "3000"
|
|
598
|
+
[http_service]
|
|
599
|
+
internal_port = 3000
|
|
600
|
+
force_https = true
|
|
601
|
+
auto_start_machines = true
|
|
602
|
+
auto_stop_machines = "stop"
|
|
603
|
+
min_machines_running = 0
|
|
604
|
+
`,
|
|
605
|
+
"utf8"
|
|
606
|
+
);
|
|
607
|
+
await writeFile(
|
|
608
|
+
resolve(outDir, "Dockerfile"),
|
|
609
|
+
`FROM node:20-slim
|
|
610
|
+
WORKDIR /app
|
|
611
|
+
COPY package.json package.json
|
|
612
|
+
COPY AGENT.md AGENT.md
|
|
613
|
+
COPY agentl.config.js agentl.config.js
|
|
614
|
+
COPY skills skills
|
|
615
|
+
COPY tests tests
|
|
616
|
+
RUN npm install -g agentl
|
|
617
|
+
COPY server.js server.js
|
|
618
|
+
EXPOSE 3000
|
|
619
|
+
CMD ["node","server.js"]
|
|
620
|
+
`,
|
|
621
|
+
"utf8"
|
|
622
|
+
);
|
|
623
|
+
await writeFile(resolve(outDir, "server.js"), serverEntrypoint, "utf8");
|
|
624
|
+
await writeFile(resolve(outDir, "package.json"), runtimePackageJson, "utf8");
|
|
625
|
+
} else {
|
|
626
|
+
throw new Error(`Unsupported build target: ${target}`);
|
|
627
|
+
}
|
|
628
|
+
process.stdout.write(`Build artifacts generated at ${outDir}
|
|
629
|
+
`);
|
|
630
|
+
};
|
|
631
|
+
var normalizeMcpName = (entry) => entry.name ?? entry.url ?? `mcp_${Date.now()}`;
|
|
632
|
+
var mcpAdd = async (workingDir, options) => {
|
|
633
|
+
const config = await loadAgentlConfig(workingDir) ?? { mcp: [] };
|
|
634
|
+
const mcp = [...config.mcp ?? []];
|
|
635
|
+
if (!options.url) {
|
|
636
|
+
throw new Error("Remote MCP only: provide --url for a remote MCP server.");
|
|
637
|
+
}
|
|
638
|
+
mcp.push({
|
|
639
|
+
name: options.name ?? normalizeMcpName({ url: options.url }),
|
|
640
|
+
url: options.url,
|
|
641
|
+
env: options.envVars ?? []
|
|
642
|
+
});
|
|
643
|
+
await writeConfigFile(workingDir, { ...config, mcp });
|
|
644
|
+
process.stdout.write("MCP server added.\n");
|
|
645
|
+
};
|
|
646
|
+
var mcpList = async (workingDir) => {
|
|
647
|
+
const config = await loadAgentlConfig(workingDir);
|
|
648
|
+
const mcp = config?.mcp ?? [];
|
|
649
|
+
if (mcp.length === 0) {
|
|
650
|
+
process.stdout.write("No MCP servers configured.\n");
|
|
651
|
+
return;
|
|
652
|
+
}
|
|
653
|
+
process.stdout.write("Configured MCP servers:\n");
|
|
654
|
+
for (const entry of mcp) {
|
|
655
|
+
process.stdout.write(`- ${entry.name ?? entry.url} (remote: ${entry.url})
|
|
656
|
+
`);
|
|
657
|
+
}
|
|
658
|
+
};
|
|
659
|
+
var mcpRemove = async (workingDir, name) => {
|
|
660
|
+
const config = await loadAgentlConfig(workingDir) ?? { mcp: [] };
|
|
661
|
+
const before = config.mcp ?? [];
|
|
662
|
+
const filtered = before.filter((entry) => normalizeMcpName(entry) !== name);
|
|
663
|
+
await writeConfigFile(workingDir, { ...config, mcp: filtered });
|
|
664
|
+
process.stdout.write(`Removed MCP server: ${name}
|
|
665
|
+
`);
|
|
666
|
+
};
|
|
667
|
+
var buildCli = () => {
|
|
668
|
+
const program = new Command();
|
|
669
|
+
program.name("agentl").description("CLI for building and running AgentL agents").version("0.1.0");
|
|
670
|
+
program.command("init").argument("<name>", "project name").description("Scaffold a new AgentL project").action(async (name) => {
|
|
671
|
+
await initProject(name);
|
|
672
|
+
});
|
|
673
|
+
program.command("dev").description("Run local development server").option("--port <port>", "server port", "3000").action(async (options) => {
|
|
674
|
+
const port = Number.parseInt(options.port, 10);
|
|
675
|
+
await startDevServer(Number.isNaN(port) ? 3e3 : port);
|
|
676
|
+
});
|
|
677
|
+
program.command("run").argument("[task]", "task to run").description("Execute the agent once").option("--param <keyValue>", "parameter key=value", (value, all) => {
|
|
678
|
+
all.push(value);
|
|
679
|
+
return all;
|
|
680
|
+
}, []).option("--file <path>", "include file contents", (value, all) => {
|
|
681
|
+
all.push(value);
|
|
682
|
+
return all;
|
|
683
|
+
}, []).option("--json", "output json", false).option("--interactive", "run in interactive mode", false).action(
|
|
684
|
+
async (task, options) => {
|
|
685
|
+
const params = parseParams(options.param);
|
|
686
|
+
if (options.interactive) {
|
|
687
|
+
await runInteractive(process.cwd(), params);
|
|
688
|
+
return;
|
|
689
|
+
}
|
|
690
|
+
if (!task) {
|
|
691
|
+
throw new Error("Task is required unless --interactive is used.");
|
|
692
|
+
}
|
|
693
|
+
await runOnce(task, {
|
|
694
|
+
params,
|
|
695
|
+
json: options.json,
|
|
696
|
+
filePaths: options.file
|
|
697
|
+
});
|
|
698
|
+
}
|
|
699
|
+
);
|
|
700
|
+
program.command("tools").description("List all tools available to the agent").action(async () => {
|
|
701
|
+
await listTools(process.cwd());
|
|
702
|
+
});
|
|
703
|
+
program.command("add").argument("<packageOrPath>", "skill package name/path").description("Add a skill package and validate SKILL.md").action(async (packageOrPath) => {
|
|
704
|
+
await addSkill(process.cwd(), packageOrPath);
|
|
705
|
+
});
|
|
706
|
+
program.command("test").argument("[file]", "test file path (yaml)").description("Run yaml-defined agent tests").action(async (file) => {
|
|
707
|
+
const testFile = file ? resolve(process.cwd(), file) : void 0;
|
|
708
|
+
const result = await runTests(process.cwd(), testFile);
|
|
709
|
+
if (result.failed > 0) {
|
|
710
|
+
process.exitCode = 1;
|
|
711
|
+
}
|
|
712
|
+
});
|
|
713
|
+
program.command("build").argument("<target>", "vercel|docker|lambda|fly").description("Generate build artifacts for deployment target").action(async (target) => {
|
|
714
|
+
await buildTarget(process.cwd(), target);
|
|
715
|
+
});
|
|
716
|
+
const mcpCommand = program.command("mcp").description("Manage MCP servers");
|
|
717
|
+
mcpCommand.command("add").requiredOption("--url <url>", "remote MCP url").option("--name <name>", "server name").option("--env <name>", "env variable (repeatable)", (value, all) => {
|
|
718
|
+
all.push(value);
|
|
719
|
+
return all;
|
|
720
|
+
}, []).action(
|
|
721
|
+
async (options) => {
|
|
722
|
+
await mcpAdd(process.cwd(), {
|
|
723
|
+
url: options.url,
|
|
724
|
+
name: options.name,
|
|
725
|
+
envVars: options.env
|
|
726
|
+
});
|
|
727
|
+
}
|
|
728
|
+
);
|
|
729
|
+
mcpCommand.command("list").description("List configured MCP servers").action(async () => {
|
|
730
|
+
await mcpList(process.cwd());
|
|
731
|
+
});
|
|
732
|
+
mcpCommand.command("remove").argument("<name>", "server name").description("Remove an MCP server by name").action(async (name) => {
|
|
733
|
+
await mcpRemove(process.cwd(), name);
|
|
734
|
+
});
|
|
735
|
+
return program;
|
|
736
|
+
};
|
|
737
|
+
var main = async (argv = process.argv) => {
|
|
738
|
+
await buildCli().parseAsync(argv);
|
|
739
|
+
};
|
|
740
|
+
var packageRoot = resolve(__dirname, "..");
|
|
741
|
+
|
|
742
|
+
export {
|
|
743
|
+
initProject,
|
|
744
|
+
startDevServer,
|
|
745
|
+
runOnce,
|
|
746
|
+
runInteractive,
|
|
747
|
+
listTools,
|
|
748
|
+
addSkill,
|
|
749
|
+
runTests,
|
|
750
|
+
buildTarget,
|
|
751
|
+
mcpAdd,
|
|
752
|
+
mcpList,
|
|
753
|
+
mcpRemove,
|
|
754
|
+
buildCli,
|
|
755
|
+
main,
|
|
756
|
+
packageRoot
|
|
757
|
+
};
|