@askexenow/exe-os 0.9.276 → 0.9.277
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 +16 -21
- package/dist/active-agent-66LEIPUR.js +25 -0
- package/dist/active-agent-JCTHHJ2W.js +25 -0
- package/dist/active-agent-JH7BC6KY.js +26 -0
- package/dist/active-agent-LPJYRSTG.js +26 -0
- package/dist/active-agent-NCGJ3QXU.js +25 -0
- package/dist/active-agent-VEQ5SGTO.js +25 -0
- package/dist/active-agent-WJ7QDM72.js +26 -0
- package/dist/active-agent-ZZS2GYB6.js +26 -0
- package/dist/agent-context-3ZUEEDQK.js +9 -0
- package/dist/agent-heartbeat-5GCGY5HX.js +60 -0
- package/dist/agent-loop-4DFCSLOQ.js +10 -0
- package/dist/agent-loop-JUEI3YUS.js +10 -0
- package/dist/agentic-ontology-3OVJM6FA.js +25 -0
- package/dist/agentic-ontology-7KHZKT7S.js +25 -0
- package/dist/agentic-ontology-DBZK5FW7.js +25 -0
- package/dist/agentic-ontology-LNOFKQPG.js +25 -0
- package/dist/asana-NDUKYBVA.js +129 -0
- package/dist/assets/tmux.conf +7 -10
- package/dist/backfill-metadata-DO64RGBD.js +598 -0
- package/dist/backfill-metadata-GO7E4CCU.js +598 -0
- package/dist/backfill-metadata-M6EWLU7C.js +597 -0
- package/dist/backfill-metadata-OTDZ6XCE.js +598 -0
- package/dist/backfill-metadata-PVMQW5QG.js +598 -0
- package/dist/backfill-metadata-QYDB7UWL.js +598 -0
- package/dist/backfill-metadata-R7BNDZ3Y.js +598 -0
- package/dist/backfill-metadata-SKD6ZSDJ.js +598 -0
- package/dist/backfill-metadata-V3JRRFAU.js +597 -0
- package/dist/background-jobs-JL47DHDJ.js +25 -0
- package/dist/bash-M5BS35LM.js +8 -0
- package/dist/behavior-effectiveness-WT3ZATDP.js +344 -0
- package/dist/behaviors-4JYN6S3T.js +32 -0
- package/dist/behaviors-4SW3PTUF.js +32 -0
- package/dist/behaviors-ARYBWFNF.js +32 -0
- package/dist/behaviors-EVFSZMOC.js +32 -0
- package/dist/behaviors-GP45B7ZN.js +32 -0
- package/dist/behaviors-J2PUJFKO.js +32 -0
- package/dist/behaviors-NYUG7FGS.js +25 -0
- package/dist/behaviors-PX3XO42O.js +32 -0
- package/dist/bin/age-ontology-load.js +3 -3
- package/dist/bin/agentic-ontology-backfill.js +10 -9
- package/dist/bin/agentic-reflection-backfill.js +11 -10
- package/dist/bin/agentic-semantic-label.js +10 -9
- package/dist/bin/backfill-conversations.js +11 -10
- package/dist/bin/backfill-responses.js +11 -10
- package/dist/bin/backfill-vectors.js +61 -20
- package/dist/bin/bulk-sync-postgres.js +12 -11
- package/dist/bin/cc-doctor.js +7 -7
- package/dist/bin/cleanup-stale-review-tasks.js +15 -15
- package/dist/bin/cli.js +55 -28
- package/dist/bin/customer-readiness.js +29 -5
- package/dist/bin/deferred-daemon-restart.js +55 -8
- package/dist/bin/exe-agent-config.js +5 -5
- package/dist/bin/exe-agent.js +18 -18
- package/dist/bin/exe-assign.js +18 -13
- package/dist/bin/exe-boot.js +55 -29
- package/dist/bin/exe-call.js +7 -7
- package/dist/bin/exe-cloud.js +14 -12
- package/dist/bin/exe-dispatch.js +15 -15
- package/dist/bin/exe-doctor.js +3 -2
- package/dist/bin/exe-export-behaviors.js +11 -10
- package/dist/bin/exe-forget.js +11 -9
- package/dist/bin/exe-gateway.js +18 -18
- package/dist/bin/exe-healthcheck.js +7 -7
- package/dist/bin/exe-heartbeat.js +16 -16
- package/dist/bin/exe-kill.js +26 -26
- package/dist/bin/exe-launch-agent.js +33 -30
- package/dist/bin/exe-new-employee.js +10 -10
- package/dist/bin/exe-pending-messages.js +16 -16
- package/dist/bin/exe-pending-notifications.js +15 -15
- package/dist/bin/exe-pending-reviews.js +16 -16
- package/dist/bin/exe-rename.js +7 -7
- package/dist/bin/exe-review.js +19 -18
- package/dist/bin/exe-search.js +10 -8
- package/dist/bin/exe-session-cleanup.js +56 -21
- package/dist/bin/exe-settings.js +9 -9
- package/dist/bin/exe-start-codex.js +16 -15
- package/dist/bin/exe-start-opencode.js +12 -11
- package/dist/bin/exe-start.sh +7 -4
- package/dist/bin/exe-status.js +16 -16
- package/dist/bin/exe-support.js +4 -4
- package/dist/bin/exe-team.js +5 -5
- package/dist/bin/git-sweep.js +16 -16
- package/dist/bin/graph-backfill.js +10 -9
- package/dist/bin/graph-export.js +10 -9
- package/dist/bin/graph-layer-benchmark.js +1 -1
- package/dist/bin/import-history.js +14 -10
- package/dist/bin/install.js +149 -42
- package/dist/bin/intercom-check.js +6 -6
- package/dist/bin/list-providers.js +3 -2
- package/dist/bin/mcp-sessions.js +3 -3
- package/dist/bin/orchestration-metrics.js +6 -6
- package/dist/bin/postgres-agentic-reflection-backfill.js +5 -5
- package/dist/bin/postgres-agentic-semantic-backfill.js +4 -4
- package/dist/bin/pre-publish.js +2 -2
- package/dist/bin/registry-proxy.js +1 -1
- package/dist/bin/scan-tasks.js +15 -15
- package/dist/bin/setup.js +12 -5
- package/dist/bin/shard-migrate.js +9 -8
- package/dist/bin/stack-update.js +78 -10
- package/dist/bin/update.js +7 -2
- package/dist/bin/verify-stack.js +1 -1
- package/dist/bin/vps-backup.js +1 -1
- package/dist/bin/vps-health-gate.js +2 -2
- package/dist/branding-XF7QRMD4.js +97 -0
- package/dist/browser-sanitizer-VO6G6ZDX.js +229 -0
- package/dist/browser-session-store-AJ5ZYA3O.js +232 -0
- package/dist/capacity-monitor-ATOO7UFK.js +49 -0
- package/dist/capacity-monitor-CBHTNC2K.js +49 -0
- package/dist/capacity-monitor-D3YOKO3Z.js +49 -0
- package/dist/capacity-monitor-E3ORGBTU.js +49 -0
- package/dist/capacity-monitor-KJXWXPO6.js +49 -0
- package/dist/capacity-monitor-M257G26T.js +49 -0
- package/dist/capacity-monitor-P7JOBTQJ.js +49 -0
- package/dist/capacity-monitor-QTNQCKX5.js +49 -0
- package/dist/capacity-monitor-YMVZCELL.js +49 -0
- package/dist/catchup-brief-54VNGPOA.js +153 -0
- package/dist/catchup-brief-C2USUIQH.js +153 -0
- package/dist/catchup-brief-C54K2W5O.js +151 -0
- package/dist/catchup-brief-CET2O432.js +153 -0
- package/dist/catchup-brief-DJHGJRDQ.js +153 -0
- package/dist/catchup-brief-DOG5JJOC.js +153 -0
- package/dist/catchup-brief-DOVP34XL.js +153 -0
- package/dist/catchup-brief-EOSOUDYI.js +153 -0
- package/dist/catchup-brief-NE7Q6DFN.js +153 -0
- package/dist/catchup-brief-PLQ5REJZ.js +151 -0
- package/dist/catchup-brief-QSVMK7HU.js +153 -0
- package/dist/catchup-brief-QZM646YU.js +151 -0
- package/dist/catchup-brief-Z47HRQWE.js +153 -0
- package/dist/chunk-24FBBDZW.js +402 -0
- package/dist/chunk-27KKZKTM.js +363 -0
- package/dist/chunk-2AER4X7O.js +33 -0
- package/dist/chunk-2FR6GC4V.js +81 -0
- package/dist/chunk-2GPNL63V.js +85 -0
- package/dist/chunk-2I4F2LWU.js +347 -0
- package/dist/chunk-2IG3SN4Z.js +836 -0
- package/dist/chunk-2IS5BVJR.js +731 -0
- package/dist/chunk-2LBFTTH7.js +30 -0
- package/dist/chunk-2NWWIE6Q.js +382 -0
- package/dist/chunk-2O2UKMUE.js +92 -0
- package/dist/chunk-2OVYGAE4.js +1068 -0
- package/dist/chunk-2QHA7RAI.js +1597 -0
- package/dist/chunk-2R6XJB2M.js +58 -0
- package/dist/chunk-2RGCBSJO.js +1119 -0
- package/dist/chunk-2S2ZHH72.js +621 -0
- package/dist/chunk-2VL6O6HL.js +204 -0
- package/dist/chunk-2Y3LJCDA.js +668 -0
- package/dist/chunk-34ZL5QNL.js +1179 -0
- package/dist/chunk-3AV2S733.js +284 -0
- package/dist/chunk-3BNGOMKF.js +123 -0
- package/dist/chunk-3BWASDGT.js +81 -0
- package/dist/chunk-3DJBLYSC.js +204 -0
- package/dist/chunk-3DZUAHXH.js +333 -0
- package/dist/chunk-3IR6XFGW.js +630 -0
- package/dist/chunk-3JPIMD3G.js +510 -0
- package/dist/chunk-3KNTAZFW.js +818 -0
- package/dist/chunk-3LDYBHED.js +363 -0
- package/dist/chunk-3OEVDGIY.js +216 -0
- package/dist/chunk-3SNGPBS7.js +551 -0
- package/dist/chunk-3ZQEWJJV.js +290 -0
- package/dist/chunk-427QHA3M.js +668 -0
- package/dist/chunk-42BIRS4S.js +197 -0
- package/dist/chunk-43VQYRJU.js +127 -0
- package/dist/chunk-44OCBNLO.js +539 -0
- package/dist/chunk-4CCAWG37.js +167 -0
- package/dist/chunk-4DPMBKRN.js +58 -0
- package/dist/chunk-4FEDR4MZ.js +204 -0
- package/dist/chunk-4FVVJ7ME.js +193 -0
- package/dist/chunk-4H4HKOE4.js +70 -0
- package/dist/chunk-4HEIWBCQ.js +159 -0
- package/dist/chunk-4KMCIJQO.js +1090 -0
- package/dist/chunk-4LWY2DRY.js +377 -0
- package/dist/chunk-4MIYQQLW.js +157 -0
- package/dist/chunk-4SAWY5QP.js +1090 -0
- package/dist/chunk-4YO2VLHT.js +333 -0
- package/dist/chunk-52X5BQGG.js +56 -0
- package/dist/chunk-56KFNBZQ.js +50 -0
- package/dist/chunk-57AQDEHL.js +562 -0
- package/dist/chunk-57HLPPUR.js +230 -0
- package/dist/chunk-5C7N5MQY.js +731 -0
- package/dist/chunk-5CRUW5P3.js +13745 -0
- package/dist/chunk-5D2REL72.js +85 -0
- package/dist/chunk-5FDE527X.js +128 -0
- package/dist/chunk-5GBOON4R.js +231 -0
- package/dist/chunk-5JAY363D.js +58 -0
- package/dist/chunk-5KTHICDO.js +333 -0
- package/dist/chunk-5MFISAXY.js +376 -0
- package/dist/chunk-5OVQD3I6.js +448 -0
- package/dist/chunk-5PPRX6YB.js +1073 -0
- package/dist/chunk-5QMEXKGM.js +150 -0
- package/dist/chunk-5QWEU2U3.js +230 -0
- package/dist/chunk-5SE35WF5.js +731 -0
- package/dist/chunk-5ZNLPL6I.js +377 -0
- package/dist/chunk-64DSU376.js +50 -0
- package/dist/chunk-64WLXGS5.js +197 -0
- package/dist/chunk-66DGLO3J.js +171 -0
- package/dist/chunk-67TIKMU2.js +123 -0
- package/dist/chunk-6AIR7TG7.js +362 -0
- package/dist/chunk-6DGFLHST.js +456 -0
- package/dist/chunk-6ETC5MNQ.js +2078 -0
- package/dist/chunk-6NFIEJ3D.js +127 -0
- package/dist/chunk-6NJPSDF6.js +214 -0
- package/dist/chunk-6NQA6PTP.js +82 -0
- package/dist/chunk-6OQVLESX.js +4190 -0
- package/dist/chunk-6S7Q6HJK.js +1094 -0
- package/dist/chunk-6SP45XNB.js +363 -0
- package/dist/chunk-6TEPSJS6.js +551 -0
- package/dist/chunk-6V3NJX62.js +377 -0
- package/dist/chunk-6WETKYZQ.js +56 -0
- package/dist/chunk-6XF43GBI.js +197 -0
- package/dist/chunk-6Y7NS6JX.js +30 -0
- package/dist/chunk-6YD3SMHS.js +135 -0
- package/dist/chunk-6ZA2VY6T.js +13884 -0
- package/dist/chunk-73GFIGHE.js +394 -0
- package/dist/chunk-73ULNDS2.js +13745 -0
- package/dist/chunk-73VDNK2K.js +55 -0
- package/dist/chunk-75BXWOOS.js +345 -0
- package/dist/chunk-7AKPANCF.js +127 -0
- package/dist/chunk-7CC4ZR2B.js +244 -0
- package/dist/chunk-7GNB2VRR.js +151 -0
- package/dist/chunk-7GTM6ZIZ.js +227 -0
- package/dist/chunk-7HHODNWF.js +54 -0
- package/dist/chunk-7I2WJIFX.js +345 -0
- package/dist/chunk-7ID5M72W.js +171 -0
- package/dist/chunk-7M546F3F.js +333 -0
- package/dist/chunk-7NMR22YZ.js +89 -0
- package/dist/chunk-7O5LXSG5.js +345 -0
- package/dist/chunk-7QIV6DW7.js +197 -0
- package/dist/chunk-7R6VVC73.js +58 -0
- package/dist/chunk-7UZDDE3A.js +76 -0
- package/dist/chunk-7V2DVUH7.js +210 -0
- package/dist/chunk-7V5H4RED.js +403 -0
- package/dist/chunk-7VTDWARA.js +214 -0
- package/dist/chunk-7W4QORKL.js +244 -0
- package/dist/chunk-7XLUQT2M.js +1148 -0
- package/dist/chunk-7XXK6KGH.js +244 -0
- package/dist/chunk-7Y33Z5AF.js +13907 -0
- package/dist/chunk-7Y72AX73.js +97 -0
- package/dist/chunk-7YOMZG42.js +123 -0
- package/dist/chunk-A3D4LUJ7.js +97 -0
- package/dist/chunk-A54XDOZL.js +299 -0
- package/dist/chunk-A7OAENAP.js +551 -0
- package/dist/chunk-AB4PAQYK.js +123 -0
- package/dist/chunk-ADCNXWYD.js +50 -0
- package/dist/chunk-AEP5ZASD.js +260 -0
- package/dist/chunk-AG2SUE5I.js +76 -0
- package/dist/chunk-AGZTDNKL.js +262 -0
- package/dist/chunk-AHLCBUSE.js +2096 -0
- package/dist/chunk-AKHGOOHE.js +41 -0
- package/dist/chunk-AKNDMCYO.js +227 -0
- package/dist/chunk-AODLTRUV.js +81 -0
- package/dist/chunk-AQVA65YS.js +1090 -0
- package/dist/chunk-ATKV7X6L.js +630 -0
- package/dist/chunk-AYKESCX4.js +97 -0
- package/dist/chunk-AZ2ZTB4X.js +1073 -0
- package/dist/chunk-B2IBUKZE.js +1076 -0
- package/dist/chunk-B54EOLFG.js +1090 -0
- package/dist/chunk-B7OKCHWY.js +128 -0
- package/dist/chunk-B7STYXSM.js +75 -0
- package/dist/chunk-BA4DSSDL.js +290 -0
- package/dist/chunk-BDIW2SWC.js +1090 -0
- package/dist/chunk-BDZGY6NE.js +214 -0
- package/dist/chunk-BGRK66QV.js +89 -0
- package/dist/chunk-BLKJC7ZP.js +13884 -0
- package/dist/chunk-BNF3HAX7.js +85 -0
- package/dist/chunk-BNFJPW74.js +76 -0
- package/dist/chunk-BRLNOQ5X.js +363 -0
- package/dist/chunk-BT4SXS3L.js +387 -0
- package/dist/chunk-BWRQCODJ.js +363 -0
- package/dist/chunk-BZ47KTJP.js +668 -0
- package/dist/chunk-BZFAQXGO.js +185 -0
- package/dist/chunk-C3IND52T.js +3948 -0
- package/dist/chunk-C4ERV6GK.js +42 -0
- package/dist/chunk-CACT44QP.js +197 -0
- package/dist/chunk-CBJIFXLQ.js +97 -0
- package/dist/chunk-CBZGOB6K.js +89 -0
- package/dist/chunk-CC26AUFB.js +2078 -0
- package/dist/chunk-CDJZKLOF.js +394 -0
- package/dist/chunk-CGDPG3RS.js +171 -0
- package/dist/chunk-CI7FZMWH.js +1076 -0
- package/dist/chunk-CIVHLHHX.js +127 -0
- package/dist/chunk-CJNNVL4S.js +204 -0
- package/dist/chunk-CKXJKYYC.js +75 -0
- package/dist/chunk-CMCYL2JC.js +155 -0
- package/dist/chunk-CMWFSVLS.js +244 -0
- package/dist/chunk-COES3XSI.js +204 -0
- package/dist/chunk-CQ7OSDAZ.js +2078 -0
- package/dist/chunk-CRRGDN35.js +50 -0
- package/dist/chunk-CTH7YFD5.js +197 -0
- package/dist/chunk-CUH43MQI.js +377 -0
- package/dist/chunk-CXGYHSTJ.js +290 -0
- package/dist/chunk-CXQ2O4OZ.js +448 -0
- package/dist/chunk-D27752SB.js +333 -0
- package/dist/chunk-D3ERCF5Z.js +250 -0
- package/dist/chunk-D3IQYDC7.js +348 -0
- package/dist/chunk-D5HQ2CGU.js +1090 -0
- package/dist/chunk-D7TEMDOB.js +75 -0
- package/dist/chunk-DAQOBQ6G.js +30 -0
- package/dist/chunk-DBHUKYR2.js +58 -0
- package/dist/chunk-DBWXKSYA.js +85 -0
- package/dist/chunk-DCPBWU2H.js +127 -0
- package/dist/chunk-DDVFZEYS.js +448 -0
- package/dist/chunk-DI56MTUR.js +362 -0
- package/dist/chunk-DINRWRSR.js +159 -0
- package/dist/chunk-DLJOBAAP.js +818 -0
- package/dist/chunk-DPHQOCY2.js +403 -0
- package/dist/chunk-DS32WI6J.js +299 -0
- package/dist/chunk-DTOJYY3L.js +1345 -0
- package/dist/chunk-DWBMFE5O.js +1148 -0
- package/dist/chunk-E3F3KHQR.js +297 -0
- package/dist/chunk-E3S2VIEL.js +203 -0
- package/dist/chunk-E56TY3JN.js +1597 -0
- package/dist/chunk-E5G35PKU.js +1021 -0
- package/dist/chunk-E7H7O5U4.js +668 -0
- package/dist/chunk-E7TM3FL3.js +50 -0
- package/dist/chunk-EBCU3UYM.js +377 -0
- package/dist/chunk-ECIWBL3W.js +403 -0
- package/dist/chunk-EDPCNLYH.js +551 -0
- package/dist/chunk-EFDBASIU.js +214 -0
- package/dist/chunk-EFWH3LPO.js +731 -0
- package/dist/chunk-EGEE5267.js +157 -0
- package/dist/chunk-EKPSVC43.js +1068 -0
- package/dist/chunk-ES6MHO3D.js +510 -0
- package/dist/chunk-ESHIRCE7.js +128 -0
- package/dist/chunk-EXQGB4LT.js +290 -0
- package/dist/chunk-EYPTDVVX.js +54 -0
- package/dist/chunk-EZ7AXTA4.js +210 -0
- package/dist/chunk-EZYHMANJ.js +13759 -0
- package/dist/chunk-F4TYLQ2Z.js +262 -0
- package/dist/chunk-F546DZKW.js +2078 -0
- package/dist/chunk-F64DEXED.js +1076 -0
- package/dist/chunk-FAJ35OYH.js +97 -0
- package/dist/chunk-FBEITXWH.js +284 -0
- package/dist/chunk-FF3FDIUX.js +345 -0
- package/dist/chunk-FJ7AOQOJ.js +510 -0
- package/dist/chunk-FKALTHDJ.js +1173 -0
- package/dist/chunk-FL3B5TWW.js +244 -0
- package/dist/chunk-FLGD6PBG.js +539 -0
- package/dist/chunk-FN3BXCBC.js +297 -0
- package/dist/chunk-FPRQ5FFJ.js +510 -0
- package/dist/chunk-FTSXRVDR.js +262 -0
- package/dist/chunk-FUM7MMNF.js +75 -0
- package/dist/chunk-FWRWK3BW.js +167 -0
- package/dist/chunk-FWXQ37AC.js +1179 -0
- package/dist/chunk-FY4KF32G.js +1940 -0
- package/dist/chunk-FYP7C7U5.js +81 -0
- package/dist/chunk-FZ4IWPMH.js +227 -0
- package/dist/chunk-FZD2J4CZ.js +630 -0
- package/dist/chunk-GC7SNA6V.js +280 -0
- package/dist/chunk-GCIRX4XD.js +157 -0
- package/dist/chunk-GCLMPF4V.js +376 -0
- package/dist/chunk-GD6CJMKZ.js +2091 -0
- package/dist/chunk-GHBKLQY5.js +197 -0
- package/dist/chunk-GIFUVNEV.js +836 -0
- package/dist/chunk-GM6MCBIG.js +129 -0
- package/dist/chunk-GORJPWF7.js +333 -0
- package/dist/chunk-GQNJK444.js +128 -0
- package/dist/chunk-GRF6MG44.js +204 -0
- package/dist/chunk-GT5ZNXLO.js +185 -0
- package/dist/chunk-GTO6JPSH.js +1345 -0
- package/dist/chunk-GWONWNR5.js +377 -0
- package/dist/chunk-H3BJ7TYY.js +731 -0
- package/dist/chunk-H3GZ6Q23.js +345 -0
- package/dist/chunk-H6BUEZE7.js +731 -0
- package/dist/chunk-H6T7FQR5.js +1345 -0
- package/dist/chunk-HBUSGLCZ.js +2096 -0
- package/dist/chunk-HC57YON2.js +284 -0
- package/dist/chunk-HINWHX63.js +382 -0
- package/dist/chunk-HIUUSF3Z.js +284 -0
- package/dist/chunk-HIW2F33I.js +333 -0
- package/dist/chunk-HKMCZIKY.js +1119 -0
- package/dist/chunk-HKUDN7ZE.js +128 -0
- package/dist/chunk-HKXZ7CMP.js +81 -0
- package/dist/chunk-HMBELYNC.js +89 -0
- package/dist/chunk-HPX6N22J.js +76 -0
- package/dist/chunk-HSMBXYS5.js +159 -0
- package/dist/chunk-I2HPT3Z6.js +127 -0
- package/dist/chunk-I5IRWQEZ.js +204 -0
- package/dist/chunk-I7ZQVKQB.js +230 -0
- package/dist/chunk-IATEXT4R.js +3556 -0
- package/dist/chunk-IBQPDEPS.js +1119 -0
- package/dist/chunk-IDR7OARV.js +2113 -0
- package/dist/chunk-IENTMIBK.js +171 -0
- package/dist/chunk-IFOAFOVG.js +150 -0
- package/dist/chunk-IGNKHNAX.js +128 -0
- package/dist/chunk-IH6FJKII.js +362 -0
- package/dist/chunk-IHCMWFOI.js +348 -0
- package/dist/chunk-IIDD7OKH.js +54 -0
- package/dist/chunk-IIEJU2UJ.js +58 -0
- package/dist/chunk-IJYGU3RL.js +1076 -0
- package/dist/chunk-IKBOMF3W.js +448 -0
- package/dist/chunk-IKT4KQXB.js +128 -0
- package/dist/chunk-IQG6M2IV.js +128 -0
- package/dist/chunk-IRA45GFY.js +76 -0
- package/dist/chunk-IS46HZ6Z.js +33 -0
- package/dist/chunk-IULPSI5N.js +362 -0
- package/dist/chunk-IYCNQ776.js +4190 -0
- package/dist/chunk-J2EOGI66.js +250 -0
- package/dist/chunk-J3G7CG5U.js +1352 -0
- package/dist/chunk-J5BSWHFW.js +573 -0
- package/dist/chunk-J5XVJP2K.js +1119 -0
- package/dist/chunk-J6AGQTYF.js +1300 -0
- package/dist/chunk-J7F5GX7V.js +250 -0
- package/dist/chunk-JCZTUQRL.js +526 -0
- package/dist/chunk-JEP4T2SE.js +346 -0
- package/dist/chunk-JF2QOP4Y.js +363 -0
- package/dist/chunk-JHEWULYC.js +369 -0
- package/dist/chunk-JI3JDOO7.js +244 -0
- package/dist/chunk-JJO34C2H.js +377 -0
- package/dist/chunk-JLNXT57O.js +3200 -0
- package/dist/chunk-JM3W7VQF.js +106 -0
- package/dist/chunk-JNPJIC2C.js +510 -0
- package/dist/chunk-JPNZKEA7.js +240 -0
- package/dist/chunk-JRLNE3T2.js +133 -0
- package/dist/chunk-JSTW345C.js +1345 -0
- package/dist/chunk-JUSURN5O.js +13810 -0
- package/dist/chunk-JXA7BQYK.js +562 -0
- package/dist/chunk-JYW6VBNW.js +38 -0
- package/dist/chunk-K3FO5GIC.js +33 -0
- package/dist/chunk-K44R6TE7.js +1179 -0
- package/dist/chunk-K6ZDION2.js +13759 -0
- package/dist/chunk-K6ZU7HDE.js +128 -0
- package/dist/chunk-KBNMVPDE.js +690 -0
- package/dist/chunk-KCBH2GDF.js +214 -0
- package/dist/chunk-KDNFFRML.js +221 -0
- package/dist/chunk-KFVD6XWS.js +129 -0
- package/dist/chunk-KNC7CJEW.js +214 -0
- package/dist/chunk-KTNOLBA3.js +58 -0
- package/dist/chunk-L7FIWWCQ.js +76 -0
- package/dist/chunk-L7T4JRTJ.js +3200 -0
- package/dist/chunk-LA4VDGY2.js +81 -0
- package/dist/chunk-LAAB5EOU.js +380 -0
- package/dist/chunk-LCAOU6FP.js +290 -0
- package/dist/chunk-LDFMTAUB.js +362 -0
- package/dist/chunk-LE4B4G7E.js +1704 -0
- package/dist/chunk-LEVB4MS5.js +128 -0
- package/dist/chunk-LGEJHEI4.js +76 -0
- package/dist/chunk-LJ4X65MY.js +171 -0
- package/dist/chunk-LJOSW65B.js +221 -0
- package/dist/chunk-LKHVY5T3.js +1921 -0
- package/dist/chunk-LMHSLS7E.js +54 -0
- package/dist/chunk-LO6L5ADL.js +76 -0
- package/dist/chunk-LPM6BFCI.js +668 -0
- package/dist/chunk-LVK63ORA.js +81 -0
- package/dist/chunk-LWXF5ZH7.js +159 -0
- package/dist/chunk-M2C2Y5XK.js +1148 -0
- package/dist/chunk-M2SJ47QU.js +75 -0
- package/dist/chunk-M56AH6RW.js +448 -0
- package/dist/chunk-MDZUD5XS.js +157 -0
- package/dist/chunk-MFKRSCKB.js +128 -0
- package/dist/chunk-MJGJPQQK.js +54 -0
- package/dist/chunk-MJM4LWIL.js +348 -0
- package/dist/chunk-MO2SQPXM.js +402 -0
- package/dist/chunk-MOM6Y4G7.js +85 -0
- package/dist/chunk-MPTJ3VZ5.js +1090 -0
- package/dist/chunk-MUEKW5VE.js +214 -0
- package/dist/chunk-MVLTH55Y.js +668 -0
- package/dist/chunk-MX7DHYSC.js +133 -0
- package/dist/chunk-MYCA7ZJK.js +97 -0
- package/dist/chunk-MYP3IJC2.js +363 -0
- package/dist/chunk-N3IFYZLZ.js +210 -0
- package/dist/chunk-N3ULIVDL.js +363 -0
- package/dist/chunk-N4GTC3LL.js +382 -0
- package/dist/chunk-N4SNGJBN.js +1173 -0
- package/dist/chunk-N7BYUAHY.js +244 -0
- package/dist/chunk-NBGJVFQQ.js +382 -0
- package/dist/chunk-NC3RMVFZ.js +1051 -0
- package/dist/chunk-NGQL5CIL.js +1119 -0
- package/dist/chunk-NGSDGMKJ.js +70 -0
- package/dist/chunk-NJYRZZPW.js +836 -0
- package/dist/chunk-NLL3KI4Q.js +290 -0
- package/dist/chunk-NMSRDICL.js +510 -0
- package/dist/chunk-NOYW4CG2.js +58 -0
- package/dist/chunk-NRX6QNZW.js +230 -0
- package/dist/chunk-NWA4N36I.js +1921 -0
- package/dist/chunk-NWQEQVE4.js +97 -0
- package/dist/chunk-NZBZICLM.js +30 -0
- package/dist/chunk-O4DZIRYO.js +13907 -0
- package/dist/chunk-O7CSLCCS.js +128 -0
- package/dist/chunk-O7NHFUQA.js +13900 -0
- package/dist/chunk-ODGR4AYQ.js +214 -0
- package/dist/chunk-OE7D2FHD.js +210 -0
- package/dist/chunk-OF22ERHW.js +58 -0
- package/dist/chunk-OHHLHFSE.js +290 -0
- package/dist/chunk-OIDMCK47.js +250 -0
- package/dist/chunk-OKQ6GTJG.js +284 -0
- package/dist/chunk-OR4JAGFA.js +97 -0
- package/dist/chunk-OTVEIJUQ.js +22 -0
- package/dist/chunk-OTXKMOJ7.js +258 -0
- package/dist/chunk-OVXYP4PC.js +731 -0
- package/dist/chunk-OZ6ECOGL.js +13745 -0
- package/dist/chunk-P36R3JCT.js +731 -0
- package/dist/chunk-P55FPLOG.js +348 -0
- package/dist/chunk-P73F2MXS.js +128 -0
- package/dist/chunk-PAPQOO4S.js +70 -0
- package/dist/chunk-PARMEBCG.js +1076 -0
- package/dist/chunk-PCHTYFMF.js +1119 -0
- package/dist/chunk-PEHOG4T4.js +377 -0
- package/dist/chunk-PHMBHJJT.js +262 -0
- package/dist/chunk-PLTTSDSS.js +89 -0
- package/dist/chunk-PLYFTPOM.js +551 -0
- package/dist/chunk-PM6U6XPX.js +551 -0
- package/dist/chunk-PPLG2EIO.js +4190 -0
- package/dist/chunk-PR4XTDPM.js +3961 -0
- package/dist/chunk-PSKLMMM4.js +97 -0
- package/dist/chunk-PTGNAG64.js +668 -0
- package/dist/chunk-Q42QJRXM.js +668 -0
- package/dist/chunk-Q4CXVSMO.js +495 -0
- package/dist/chunk-Q4DSFR7Z.js +89 -0
- package/dist/chunk-Q55ZVW3T.js +85 -0
- package/dist/chunk-QAFPHTZX.js +1090 -0
- package/dist/chunk-QC2P5DML.js +836 -0
- package/dist/chunk-QCAOFKS3.js +97 -0
- package/dist/chunk-QCDTLQ47.js +75 -0
- package/dist/chunk-QDVGNYPS.js +240 -0
- package/dist/chunk-QFKQVTGA.js +38 -0
- package/dist/chunk-QJS6KKPB.js +54 -0
- package/dist/chunk-QMRHVWVG.js +539 -0
- package/dist/chunk-QNXEOU4N.js +1345 -0
- package/dist/chunk-QOK2QDW4.js +89 -0
- package/dist/chunk-QOWVOLWP.js +1345 -0
- package/dist/chunk-QPP6RTSO.js +129 -0
- package/dist/chunk-QRYYBFXG.js +70 -0
- package/dist/chunk-QXKDVF4N.js +836 -0
- package/dist/chunk-QYH2YHCH.js +284 -0
- package/dist/chunk-QZGVVTAN.js +250 -0
- package/dist/chunk-RDG733SE.js +85 -0
- package/dist/chunk-REGLESOJ.js +190 -0
- package/dist/chunk-RGYOSJQU.js +127 -0
- package/dist/chunk-RJWWFCS2.js +284 -0
- package/dist/chunk-RKTH342D.js +231 -0
- package/dist/chunk-RLOLC5OP.js +1090 -0
- package/dist/chunk-RM4TC5N5.js +1076 -0
- package/dist/chunk-RMNDZZG4.js +56 -0
- package/dist/chunk-RNPRULSY.js +402 -0
- package/dist/chunk-ROXPI6LI.js +290 -0
- package/dist/chunk-RRMXAR5E.js +377 -0
- package/dist/chunk-RSTJTQAR.js +123 -0
- package/dist/chunk-RTRL3H6R.js +394 -0
- package/dist/chunk-RV3BP7XM.js +167 -0
- package/dist/chunk-RV6DRGN7.js +13907 -0
- package/dist/chunk-RV7F4DAF.js +171 -0
- package/dist/chunk-RVGSVTE4.js +244 -0
- package/dist/chunk-RVHEST6Y.js +81 -0
- package/dist/chunk-RVQZUJC2.js +33 -0
- package/dist/chunk-RXSL6VMA.js +244 -0
- package/dist/chunk-SEJZKEQ2.js +382 -0
- package/dist/chunk-SFETK2K4.js +539 -0
- package/dist/chunk-SIAA4J6H.js +21 -0
- package/dist/chunk-SIR6JZV2.js +227 -0
- package/dist/chunk-SMTJ6XC6.js +56 -0
- package/dist/chunk-SOJDYRAV.js +97 -0
- package/dist/chunk-SSTLTIF3.js +282 -0
- package/dist/chunk-SWPM3OVT.js +185 -0
- package/dist/chunk-SY75INUL.js +69 -0
- package/dist/chunk-SYBHCD5Y.js +1352 -0
- package/dist/chunk-T363PS4E.js +13884 -0
- package/dist/chunk-T3DB2L7D.js +447 -0
- package/dist/chunk-T3NGHPYQ.js +551 -0
- package/dist/chunk-TC4DSSCG.js +54 -0
- package/dist/chunk-TFJMUHHT.js +240 -0
- package/dist/chunk-THJ7W7P5.js +604 -0
- package/dist/chunk-TKH3Z6MX.js +284 -0
- package/dist/chunk-TPSLW46F.js +1068 -0
- package/dist/chunk-TQDARPML.js +85 -0
- package/dist/chunk-TQGGGR3B.js +526 -0
- package/dist/chunk-TRN6Z263.js +448 -0
- package/dist/chunk-TSZUGTI3.js +171 -0
- package/dist/chunk-TVPOVHHB.js +382 -0
- package/dist/chunk-TWC34C2C.js +38 -0
- package/dist/chunk-TWUJBFIK.js +345 -0
- package/dist/chunk-TXLFZLCX.js +171 -0
- package/dist/chunk-TYIQK2ZV.js +284 -0
- package/dist/chunk-TZQP4KJ3.js +403 -0
- package/dist/chunk-U2Y7CBLR.js +89 -0
- package/dist/chunk-U66BRNNK.js +731 -0
- package/dist/chunk-U6LNXXQX.js +58 -0
- package/dist/chunk-UAMWGUBX.js +574 -0
- package/dist/chunk-UCCZF5N4.js +167 -0
- package/dist/chunk-UFJJJ3EB.js +55 -0
- package/dist/chunk-UIGKU2K4.js +50 -0
- package/dist/chunk-UPSID2HN.js +346 -0
- package/dist/chunk-USSO53YP.js +54 -0
- package/dist/chunk-UUCYTPXF.js +214 -0
- package/dist/chunk-UVWTI4VC.js +1352 -0
- package/dist/chunk-UXAPHDSV.js +240 -0
- package/dist/chunk-UXUCMX46.js +89 -0
- package/dist/chunk-UYN5XHQ5.js +510 -0
- package/dist/chunk-UYOMJVYP.js +50 -0
- package/dist/chunk-UZWSZ3C5.js +280 -0
- package/dist/chunk-V2KBVGTN.js +2097 -0
- package/dist/chunk-V44SEJIE.js +76 -0
- package/dist/chunk-V4NLMOYM.js +382 -0
- package/dist/chunk-V6IH2YVS.js +4190 -0
- package/dist/chunk-V6RTI73O.js +1179 -0
- package/dist/chunk-V75SLGIH.js +97 -0
- package/dist/chunk-V7VGYOCD.js +197 -0
- package/dist/chunk-VA2WDTBP.js +1345 -0
- package/dist/chunk-VHTBAKZH.js +371 -0
- package/dist/chunk-VIWJFFDF.js +346 -0
- package/dist/chunk-VJNCFZ2T.js +382 -0
- package/dist/chunk-VKVEBQLJ.js +836 -0
- package/dist/chunk-VLW5CNTP.js +1119 -0
- package/dist/chunk-VMPAJQUP.js +363 -0
- package/dist/chunk-VNRNAACY.js +4190 -0
- package/dist/chunk-VR4SVGCY.js +345 -0
- package/dist/chunk-VRU3ZI43.js +2078 -0
- package/dist/chunk-VYMK5VCO.js +539 -0
- package/dist/chunk-VZXJOTE5.js +4190 -0
- package/dist/chunk-W22KMCH3.js +1940 -0
- package/dist/chunk-W3MQYGPX.js +38 -0
- package/dist/chunk-W4WIRN5R.js +448 -0
- package/dist/chunk-WH7HLB4Z.js +76 -0
- package/dist/chunk-WI57OYT2.js +1345 -0
- package/dist/chunk-WJMFNT4M.js +357 -0
- package/dist/chunk-WOQD775A.js +50 -0
- package/dist/chunk-WPIETWVX.js +2078 -0
- package/dist/chunk-WR26WBWT.js +1076 -0
- package/dist/chunk-WTA6FCAA.js +1345 -0
- package/dist/chunk-WVWJB7BT.js +630 -0
- package/dist/chunk-WX55RQRU.js +58 -0
- package/dist/chunk-WYID6P6Y.js +333 -0
- package/dist/chunk-X4HA7IYX.js +129 -0
- package/dist/chunk-X4OY7C7R.js +382 -0
- package/dist/chunk-XB6YDG2A.js +167 -0
- package/dist/chunk-XBDHMCR5.js +1119 -0
- package/dist/chunk-XEFJKWV2.js +163 -0
- package/dist/chunk-XFPFACZX.js +13884 -0
- package/dist/chunk-XFYH5GKP.js +171 -0
- package/dist/chunk-XFYZ77DP.js +280 -0
- package/dist/chunk-XMAXDYFK.js +604 -0
- package/dist/chunk-XNQOJZNS.js +250 -0
- package/dist/chunk-XPWFBDHN.js +250 -0
- package/dist/chunk-XRNU6CD7.js +58 -0
- package/dist/chunk-XSC4BBLH.js +159 -0
- package/dist/chunk-XW43IEC3.js +4190 -0
- package/dist/chunk-XWI4AN5N.js +408 -0
- package/dist/chunk-XWM5HD4J.js +127 -0
- package/dist/chunk-Y3JP4PL5.js +54 -0
- package/dist/chunk-Y4QRUAVJ.js +81 -0
- package/dist/chunk-Y5OT5BAV.js +221 -0
- package/dist/chunk-Y6JIZWT3.js +551 -0
- package/dist/chunk-Y6RZRLZD.js +197 -0
- package/dist/chunk-Y75VXMBN.js +244 -0
- package/dist/chunk-YBDREOVN.js +3200 -0
- package/dist/chunk-YDJRLXXF.js +150 -0
- package/dist/chunk-YEN5ACVR.js +448 -0
- package/dist/chunk-YFPZUT6G.js +132 -0
- package/dist/chunk-YGJ6XKPE.js +346 -0
- package/dist/chunk-YHVZVCGR.js +280 -0
- package/dist/chunk-YIE4E647.js +185 -0
- package/dist/chunk-YIEQRBNO.js +221 -0
- package/dist/chunk-YPS5PE25.js +495 -0
- package/dist/chunk-YR5OIJRL.js +231 -0
- package/dist/chunk-YTBUMO6Z.js +448 -0
- package/dist/chunk-YUHYQPXY.js +345 -0
- package/dist/chunk-YWPTPTQW.js +75 -0
- package/dist/chunk-YXT3YCKS.js +551 -0
- package/dist/chunk-YYM3TCUP.js +345 -0
- package/dist/chunk-YYVL727V.js +50 -0
- package/dist/chunk-YZEI2XOK.js +333 -0
- package/dist/chunk-Z3A6VUYT.js +1702 -0
- package/dist/chunk-Z5BNE3L3.js +75 -0
- package/dist/chunk-Z5LVHAY4.js +159 -0
- package/dist/chunk-Z6ESQXFI.js +204 -0
- package/dist/chunk-Z6FOV4NA.js +204 -0
- package/dist/chunk-ZBCBANWK.js +836 -0
- package/dist/chunk-ZBLNGKO5.js +85 -0
- package/dist/chunk-ZDNYW3AR.js +299 -0
- package/dist/chunk-ZF7JKTLP.js +127 -0
- package/dist/chunk-ZGWAADSD.js +630 -0
- package/dist/chunk-ZLI3TUML.js +394 -0
- package/dist/chunk-ZPN5S7BE.js +526 -0
- package/dist/chunk-ZUNQIQWO.js +526 -0
- package/dist/co-activation-65ZWECEW.js +72 -0
- package/dist/co-activation-7H4LJXPH.js +72 -0
- package/dist/co-activation-D6VDOLPE.js +72 -0
- package/dist/co-activation-WVKDWUYB.js +72 -0
- package/dist/co-occurrence-L3QDWLFB.js +74 -0
- package/dist/co-occurrence-NQ6QYRI3.js +93 -0
- package/dist/co-occurrence-UHIY3TSP.js +93 -0
- package/dist/co-occurrence-VMDXY6XD.js +93 -0
- package/dist/code-context-index-RJCLTXID.js +30 -0
- package/dist/code-context-index-T4R26DRZ.js +30 -0
- package/dist/content-extractor-GRE72OF4.js +9 -0
- package/dist/conversation-entity-extractor-3NCBEVXR.js +114 -0
- package/dist/conversation-wiki-populator-LPL23GZR.js +105 -0
- package/dist/core-memory-2TPPHQWV.js +110 -0
- package/dist/core-memory-CVF72QJS.js +110 -0
- package/dist/core-memory-EZGDNOZW.js +110 -0
- package/dist/core-memory-LDYXGLHK.js +110 -0
- package/dist/core-memory-LOAMRQHE.js +110 -0
- package/dist/core-memory-LSDBJSWJ.js +110 -0
- package/dist/core-memory-Q5VQNVIQ.js +110 -0
- package/dist/core-memory-QNW5SLBJ.js +110 -0
- package/dist/core-memory-WX3WUT4S.js +110 -0
- package/dist/crdt-sync-4NMOGP44.js +33 -0
- package/dist/crdt-sync-6MTPAECL.js +33 -0
- package/dist/crdt-sync-ESTCLT7K.js +33 -0
- package/dist/crdt-sync-HSRDIGAM.js +33 -0
- package/dist/crm-bridge-4THGLPM2.js +19 -0
- package/dist/crm-webhook-BDZ6BHKO.js +10 -0
- package/dist/crm-webhook-H5O3DLQO.js +10 -0
- package/dist/crm-webhook-HQMYV6LS.js +10 -0
- package/dist/crm-webhook-ITS2M6UB.js +10 -0
- package/dist/crm-webhook-NEXXNFD3.js +10 -0
- package/dist/crm-webhook-NVLRAYZX.js +10 -0
- package/dist/crm-webhook-QWQF343F.js +10 -0
- package/dist/crm-webhook-SCVMSNA2.js +10 -0
- package/dist/crm-webhook-WN3STFME.js +10 -0
- package/dist/cto-delegation-gate-5I5NJKNG.js +206 -0
- package/dist/cto-delegation-gate-CZRM46V3.js +206 -0
- package/dist/cto-delegation-gate-GVXGK5PB.js +278 -0
- package/dist/cto-delegation-gate-JOQMH5SV.js +278 -0
- package/dist/cto-delegation-gate-NHYDWUQT.js +278 -0
- package/dist/cto-delegation-gate-NRSNMJIS.js +278 -0
- package/dist/cto-delegation-gate-SAQCC5DR.js +278 -0
- package/dist/cto-delegation-gate-ST4HUNJ2.js +278 -0
- package/dist/cto-delegation-gate-YIRKI4RC.js +206 -0
- package/dist/cto-delegation-gate-YU77OJRO.js +206 -0
- package/dist/daemon-auth-TAWO7TQX.js +13 -0
- package/dist/daemon-orchestration-CNANYOLN.js +135 -0
- package/dist/daemon-orchestration-D5UEPJ3I.js +137 -0
- package/dist/daemon-orchestration-JHYADASA.js +135 -0
- package/dist/daemon-orchestration-JMQQUF77.js +137 -0
- package/dist/daemon-orchestration-NL5TQ5VD.js +135 -0
- package/dist/daemon-orchestration-OFX5QOBD.js +137 -0
- package/dist/daemon-orchestration-OXH6YRRL.js +137 -0
- package/dist/daemon-orchestration-Q5FEEHYE.js +135 -0
- package/dist/daemon-orchestration-SCMTDRLW.js +137 -0
- package/dist/daemon-orchestration-TMT7VKKG.js +137 -0
- package/dist/daemon-protocol-MDSKFBVV.js +17 -0
- package/dist/db-backup-CMP5QJDL.js +33 -0
- package/dist/db-backup-H7FHQZAA.js +33 -0
- package/dist/db-backup-MDBTOF6H.js +33 -0
- package/dist/db-backup-RELPNM6R.js +33 -0
- package/dist/devtools-BZGOQHB2.js +8 -0
- package/dist/discord-E66EWJYC.js +7 -0
- package/dist/dispatch-ack-RP7773BV.js +13 -0
- package/dist/dreaming-7BLPR2BS.js +32 -0
- package/dist/dreaming-B2NPY73R.js +32 -0
- package/dist/dreaming-BULADGXO.js +32 -0
- package/dist/dreaming-F4UTV3AM.js +32 -0
- package/dist/dreaming-IDBV4AO2.js +32 -0
- package/dist/dreaming-LFR3245Y.js +32 -0
- package/dist/dreaming-LMYCFKQG.js +32 -0
- package/dist/dreaming-MI23NXDC.js +32 -0
- package/dist/dreaming-PK3J5HAI.js +32 -0
- package/dist/email-U7B2CV3A.js +137 -0
- package/dist/entity-boost-6OCDP2H2.js +356 -0
- package/dist/entity-boost-LI4H3PAZ.js +375 -0
- package/dist/exe-drift-EFXZRVIL.js +68 -0
- package/dist/exe-drift-GS3TTJGS.js +68 -0
- package/dist/exe-drift-NLUOUSJN.js +68 -0
- package/dist/exe-drift-SLH5IVNI.js +68 -0
- package/dist/exe-export-2XVHO2JL.js +73 -0
- package/dist/exe-export-3Q52HX6P.js +74 -0
- package/dist/exe-export-4JCIWNYJ.js +74 -0
- package/dist/exe-export-5NUDAPFN.js +74 -0
- package/dist/exe-export-DWDM4RGB.js +73 -0
- package/dist/exe-export-ELZNLM7I.js +74 -0
- package/dist/exe-export-OCNGBHIK.js +74 -0
- package/dist/exe-export-T4SJ4JZT.js +74 -0
- package/dist/exe-export-WBIVDGBJ.js +74 -0
- package/dist/exe-import-CEHEUVDV.js +77 -0
- package/dist/exe-import-J3IGSQGE.js +77 -0
- package/dist/exe-import-LBLVAZ2B.js +77 -0
- package/dist/exe-import-LWEXVW36.js +77 -0
- package/dist/exe-import-OMLYIICS.js +77 -0
- package/dist/exe-import-PPRIPBC4.js +77 -0
- package/dist/exe-import-R7A44HWI.js +76 -0
- package/dist/exe-import-SZ73K6VH.js +76 -0
- package/dist/exe-import-XKYDCRON.js +77 -0
- package/dist/exe-key-24SHOIG4.js +579 -0
- package/dist/exe-key-6OS5MFI5.js +579 -0
- package/dist/exe-key-A3LWIWG7.js +579 -0
- package/dist/exe-key-CG4J45GK.js +579 -0
- package/dist/exe-key-FASOWAOU.js +579 -0
- package/dist/exe-key-FGRYTEWE.js +579 -0
- package/dist/exe-key-MLVVZSM6.js +579 -0
- package/dist/exe-key-TSF4OCQ7.js +579 -0
- package/dist/exe-key-TZWHAO2M.js +579 -0
- package/dist/exe-key-ZP67KGXT.js +579 -0
- package/dist/exe-org-EVFQGM3D.js +73 -0
- package/dist/exe-snapshot-27S4ORVV.js +336 -0
- package/dist/exe-snapshot-3NFQ5T2E.js +336 -0
- package/dist/exe-snapshot-6FYTQIO3.js +164 -0
- package/dist/exe-snapshot-ESUNS5PK.js +336 -0
- package/dist/exe-snapshot-GOPSY6ET.js +335 -0
- package/dist/exe-snapshot-HE675GJX.js +336 -0
- package/dist/exe-snapshot-KXHQQ6IQ.js +336 -0
- package/dist/exe-snapshot-QELQK7UN.js +336 -0
- package/dist/exe-snapshot-WXMHCHMI.js +336 -0
- package/dist/factory-Q5ECXJAT.js +67 -0
- package/dist/fast-db-init-6HHMQQ7T.js +7 -0
- package/dist/fast-db-init-7UJZZKOC.js +7 -0
- package/dist/fast-db-init-BYTJ2LOT.js +7 -0
- package/dist/fast-db-init-CV6PSAHE.js +7 -0
- package/dist/fast-db-init-F7BYQ6ZK.js +7 -0
- package/dist/fast-db-init-IAV27AGE.js +7 -0
- package/dist/fast-db-init-KJFD5PBA.js +7 -0
- package/dist/fast-db-init-LJIR3OJC.js +7 -0
- package/dist/fast-db-init-NI2MIAC7.js +7 -0
- package/dist/file-edit-EYDPRZYY.js +8 -0
- package/dist/file-read-RJ7IL4DO.js +8 -0
- package/dist/file-write-4KTSU55Y.js +8 -0
- package/dist/founder-context-3NVGBMKF.js +96 -0
- package/dist/gateway/index.js +10 -10
- package/dist/gateway-client-AD4HMMSR.js +11 -0
- package/dist/git-staleness-3AF5334G.js +110 -0
- package/dist/git-staleness-KNUBMEZK.js +110 -0
- package/dist/git-staleness-MMMURDDO.js +110 -0
- package/dist/git-staleness-O3WY3BWN.js +110 -0
- package/dist/git-task-sweep-D5ZTKCB7.js +40 -0
- package/dist/git-task-sweep-G446367V.js +40 -0
- package/dist/git-task-sweep-KWQDOFSU.js +40 -0
- package/dist/git-task-sweep-Q2L5WVGV.js +40 -0
- package/dist/git-task-sweep-SFV4OB47.js +40 -0
- package/dist/git-task-sweep-TNKHC466.js +40 -0
- package/dist/git-task-sweep-XMTW4CVT.js +40 -0
- package/dist/git-task-sweep-YQ5IZCPG.js +40 -0
- package/dist/git-task-sweep-Z7WQMUKD.js +40 -0
- package/dist/glob-JF4RPRT3.js +7 -0
- package/dist/global-procedures-2XOKKLIE.js +20 -0
- package/dist/global-procedures-BXAXVIBL.js +20 -0
- package/dist/global-procedures-C7NNG4AX.js +20 -0
- package/dist/global-procedures-GXA5KWKW.js +20 -0
- package/dist/global-procedures-K3EC5AYI.js +20 -0
- package/dist/global-procedures-K6MCYCUP.js +20 -0
- package/dist/global-procedures-M4TTT7MV.js +20 -0
- package/dist/global-procedures-OWBRYXNN.js +20 -0
- package/dist/graph-auto-extract-IR672UEY.js +181 -0
- package/dist/graph-auto-extract-MBMDTX7B.js +181 -0
- package/dist/graph-auto-extract-NFXVT2IY.js +162 -0
- package/dist/graph-auto-extract-P4SYRJO7.js +181 -0
- package/dist/graph-query-UG4DAI33.js +26 -0
- package/dist/graph-rag-NK6J45SP.js +31 -0
- package/dist/grep-P6JSAZGP.js +7 -0
- package/dist/hook-integrity-TFBQQA2V.js +89 -0
- package/dist/hooks/bug-report-worker.js +17 -17
- package/dist/hooks/codex-stop-task-finalizer.js +18 -18
- package/dist/hooks/commit-complete.js +18 -18
- package/dist/hooks/error-recall.js +12 -10
- package/dist/hooks/exe-heartbeat-hook.js +6 -6
- package/dist/hooks/ingest-worker.js +7 -7
- package/dist/hooks/ingest.js +15 -15
- package/dist/hooks/instructions-loaded.js +7 -7
- package/dist/hooks/manifest.json +20 -20
- package/dist/hooks/notification.js +7 -7
- package/dist/hooks/post-compact.js +17 -17
- package/dist/hooks/post-tool-combined.js +9 -9
- package/dist/hooks/pre-compact.js +23 -23
- package/dist/hooks/pre-tool-use.js +22 -22
- package/dist/hooks/prompt-submit.js +35 -33
- package/dist/hooks/session-end.js +31 -31
- package/dist/hooks/session-start.js +18 -18
- package/dist/hooks/stop.js +24 -24
- package/dist/hooks/subagent-stop.js +17 -17
- package/dist/hooks/summary-worker.js +27 -26
- package/dist/hooks-ZGIUOVME.js +9 -0
- package/dist/imessage-ADODNZ44.js +7 -0
- package/dist/index.js +27 -27
- package/dist/installer-5ZCXVNKB.js +296 -0
- package/dist/installer-AT44REVO.js +38 -0
- package/dist/installer-D3SXDGWZ.js +38 -0
- package/dist/installer-EAGOJPWX.js +296 -0
- package/dist/installer-EPGQ4IZE.js +38 -0
- package/dist/installer-GCYGD7CD.js +38 -0
- package/dist/installer-I2CDOPH6.js +342 -0
- package/dist/installer-IFZKAVSA.js +296 -0
- package/dist/installer-KRS7PPFP.js +342 -0
- package/dist/installer-O3SU36CP.js +296 -0
- package/dist/installer-QRRDZJ5Q.js +342 -0
- package/dist/installer-VCKFYCTU.js +342 -0
- package/dist/intercom-queue-JCOWNDJ7.js +17 -0
- package/dist/investigation-tracker-AOCYNJAW.js +410 -0
- package/dist/key-backup-status-RCKYSYPV.js +39 -0
- package/dist/keyword-extractor-T5N4ISGM.js +11 -0
- package/dist/lib/agent-config.js +3 -3
- package/dist/lib/cloud-sync.js +8 -8
- package/dist/lib/cloudflare-dns.js +1 -1
- package/dist/lib/config.js +2 -2
- package/dist/lib/consolidation.js +12 -8
- package/dist/lib/crypto.js +2 -2
- package/dist/lib/database.js +8 -4
- package/dist/lib/db-daemon-client.js +27 -8
- package/dist/lib/db.js +8 -4
- package/dist/lib/device-registry.js +2 -2
- package/dist/lib/embed-worker.js +47 -25
- package/dist/lib/embedder.js +10 -8
- package/dist/lib/employee-templates.js +7 -7
- package/dist/lib/employees.js +8 -4
- package/dist/lib/error-detector.js +1 -1
- package/dist/lib/exe-daemon-client.js +5 -5
- package/dist/lib/exe-daemon.js +663 -199
- package/dist/lib/file-grep.js +1 -1
- package/dist/lib/hybrid-search.js +10 -8
- package/dist/lib/identity-templates.js +1 -1
- package/dist/lib/identity.js +4 -4
- package/dist/lib/keychain.js +2 -2
- package/dist/lib/license.js +5 -3
- package/dist/lib/messaging.js +15 -15
- package/dist/lib/post-tool-memory.js +1 -1
- package/dist/lib/registry-proxy.js +1 -1
- package/dist/lib/reminders.js +5 -5
- package/dist/lib/runtime-table.js +1 -1
- package/dist/lib/schedules.js +9 -8
- package/dist/lib/session-registry.js +6 -6
- package/dist/lib/session-wrappers.js +1 -1
- package/dist/lib/skill-learning.js +13 -6
- package/dist/lib/status-brief.js +2 -2
- package/dist/lib/store.js +10 -7
- package/dist/lib/task-router.js +5 -5
- package/dist/lib/tasks.js +16 -16
- package/dist/lib/tmux-routing.js +18 -14
- package/dist/lib/tmux-status.js +2 -2
- package/dist/lib/tmux-transport.js +1 -1
- package/dist/lib/token-spend.js +5 -5
- package/dist/lib/transport.js +1 -1
- package/dist/lib/ws-auth.js +1 -1
- package/dist/lib/ws-client.js +2 -2
- package/dist/license-gate-ZDWPYKVZ.js +14 -0
- package/dist/mcp/register-tools.js +79 -77
- package/dist/mcp/server.js +82 -80
- package/dist/mcp/tools/complete-reminder.js +6 -6
- package/dist/mcp/tools/create-reminder.js +6 -6
- package/dist/mcp/tools/create-task.js +18 -18
- package/dist/mcp/tools/deactivate-behavior.js +14 -7
- package/dist/mcp/tools/list-reminders.js +6 -6
- package/dist/mcp/tools/list-tasks.js +18 -18
- package/dist/mcp/tools/send-message.js +17 -17
- package/dist/mcp/tools/update-task.js +17 -17
- package/dist/mcp-diagnostics-RG7US2O3.js +200 -0
- package/dist/mcp-disconnect-tracker-FLC6WSON.js +79 -0
- package/dist/mcp-http-config-AETKVUCB.js +27 -0
- package/dist/mcp-http-config-HFFEJ7HE.js +27 -0
- package/dist/mcp-http-config-NOAYEXSD.js +27 -0
- package/dist/mcp-http-config-WEQLOERH.js +27 -0
- package/dist/memory-cards-ALMQQN2U.js +178 -0
- package/dist/memory-cards-HJ2VDTT3.js +174 -0
- package/dist/memory-cards-OAGVTZMZ.js +178 -0
- package/dist/memory-cards-S7PJ5TOQ.js +178 -0
- package/dist/memory-graph-extractor-5XXL4C7K.js +20 -0
- package/dist/memory-graph-extractor-ATUI7ZQG.js +17 -0
- package/dist/memory-graph-extractor-BE5SOGWH.js +17 -0
- package/dist/memory-graph-extractor-EG7BRRHD.js +20 -0
- package/dist/memory-graph-extractor-XYJ34VQC.js +20 -0
- package/dist/memory-poisoning-defense-AJREUW5D.js +222 -0
- package/dist/memory-poisoning-defense-CXV4TXSS.js +222 -0
- package/dist/memory-poisoning-defense-L43CRNBG.js +222 -0
- package/dist/memory-poisoning-defense-XDYHR6VO.js +225 -0
- package/dist/memory-queue-2B2BXIG4.js +19 -0
- package/dist/memory-queue-client-H4BM3XBQ.js +16 -0
- package/dist/memory-queue-client-MXVZQP7A.js +16 -0
- package/dist/memory-reflection-3J5RS2QO.js +238 -0
- package/dist/memory-reflection-I45L64MR.js +242 -0
- package/dist/memory-reflection-O3SGKM5N.js +242 -0
- package/dist/memory-reflection-SYRJRRKY.js +242 -0
- package/dist/message-queue-client-EKZ7EV3E.js +92 -0
- package/dist/message-queue-client-FWZVGHU7.js +92 -0
- package/dist/notifications-3NU4SUPR.js +45 -0
- package/dist/notifications-5GV32CG3.js +45 -0
- package/dist/notifications-7AQOX6ST.js +45 -0
- package/dist/notifications-CNV3NH6R.js +45 -0
- package/dist/notifications-M4Z2MS2T.js +45 -0
- package/dist/notifications-NYBLWVOU.js +45 -0
- package/dist/notifications-P7PDFFSJ.js +45 -0
- package/dist/notifications-UYS75Z6Y.js +45 -0
- package/dist/notifications-VEQQL4XQ.js +45 -0
- package/dist/oauth-server-MOITGCVQ.js +437 -0
- package/dist/orchestration-events-2AO73O5H.js +25 -0
- package/dist/orchestration-events-HKYXRQBG.js +25 -0
- package/dist/orchestration-events-JG2T7LQE.js +25 -0
- package/dist/orchestration-events-T53LWRWQ.js +25 -0
- package/dist/orchestration-phase-TE42UKHS.js +23 -0
- package/dist/orchestrator-266KJPKS.js +33 -0
- package/dist/orchestrator-2KUQEZWW.js +33 -0
- package/dist/orchestrator-F5B2I7RK.js +33 -0
- package/dist/orchestrator-MK6ZFPQB.js +33 -0
- package/dist/orchestrator-NGZITWOO.js +33 -0
- package/dist/orchestrator-SQCZ35QB.js +33 -0
- package/dist/orchestrator-UYHI7AHC.js +33 -0
- package/dist/orchestrator-YOOD52MI.js +33 -0
- package/dist/orchestrator-ZEKK4CU7.js +33 -0
- package/dist/permission-presets-3XIPJRD7.js +25 -0
- package/dist/permissions-I4S4VR3M.js +14 -0
- package/dist/pg-ssl-SBP4MZSN.js +7 -0
- package/dist/pipeline-router-4BV46AVP.js +13 -0
- package/dist/pipeline-router-6P6DEZWG.js +13 -0
- package/dist/pipeline-router-DSMEDREP.js +13 -0
- package/dist/pipeline-router-IM5MUH7T.js +13 -0
- package/dist/pipeline-router-LQXFGZAV.js +13 -0
- package/dist/pipeline-router-LZW4AB5L.js +13 -0
- package/dist/pipeline-router-Q7BK52OL.js +13 -0
- package/dist/pipeline-router-R5AN2GGH.js +13 -0
- package/dist/pipeline-router-XCYY3OV2.js +13 -0
- package/dist/plan-limits-6HZ72EAG.js +26 -0
- package/dist/plan-limits-KPTD6RMK.js +26 -0
- package/dist/plan-limits-VZBVPNFE.js +26 -0
- package/dist/plan-limits-ZCI3WNA7.js +26 -0
- package/dist/preferences-TKVPKQ3L.js +10 -0
- package/dist/project-boot-BQAB2UPB.js +299 -0
- package/dist/project-boot-FQLP3BKD.js +299 -0
- package/dist/project-boot-OBR4B6QL.js +299 -0
- package/dist/project-boot-SYUEI3UJ.js +299 -0
- package/dist/project-name-TMASZAKE.js +10 -0
- package/dist/projection-worker-AIWKWEUM.js +964 -0
- package/dist/projection-worker-UYJGMGNY.js +964 -0
- package/dist/projection-worker-XB4YADGF.js +964 -0
- package/dist/projection-worker-Z7QCJMN5.js +964 -0
- package/dist/push-notifications-Y2LMBOK7.js +15 -0
- package/dist/reranker-4JLM7T7U.js +19 -0
- package/dist/reranker-4LNQJ4KI.js +19 -0
- package/dist/reranker-7AWMZF4N.js +19 -0
- package/dist/reranker-FZCTTOFA.js +19 -0
- package/dist/reranker-GAMUI2WN.js +19 -0
- package/dist/reranker-KWBDYDPF.js +19 -0
- package/dist/reranker-NASCH4QP.js +19 -0
- package/dist/reranker-P4K77EHY.js +19 -0
- package/dist/reranker-UIHPCFBD.js +19 -0
- package/dist/reranker-VJ24SH2A.js +19 -0
- package/dist/reranker-VOPVN6MG.js +19 -0
- package/dist/reranker-VSGIRDI6.js +19 -0
- package/dist/review-gate-5PVXY47U.js +120 -0
- package/dist/review-polling-4KKF4QGY.js +124 -0
- package/dist/review-polling-7RYCO3LB.js +124 -0
- package/dist/review-polling-BJZZ6VN5.js +124 -0
- package/dist/review-polling-C2L7OUYZ.js +124 -0
- package/dist/review-polling-KXCRJGMP.js +124 -0
- package/dist/review-polling-LYMFSZZZ.js +124 -0
- package/dist/review-polling-MCJ5QR6R.js +124 -0
- package/dist/review-polling-QMTLNUHR.js +124 -0
- package/dist/review-polling-SAKMZEZM.js +124 -0
- package/dist/runtime/index.js +21 -21
- package/dist/self-query-router-7OKQJSTT.js +188 -0
- package/dist/session-events-75PGQHCQ.js +36 -0
- package/dist/session-events-7JWY6AJM.js +36 -0
- package/dist/session-events-CZXJFZKY.js +36 -0
- package/dist/session-events-HLUA7UQM.js +36 -0
- package/dist/session-events-KGOA2W3V.js +36 -0
- package/dist/session-events-NR22TNSK.js +36 -0
- package/dist/session-events-OE6S6EMW.js +36 -0
- package/dist/session-events-T6RCZ5PO.js +36 -0
- package/dist/session-events-U537QM65.js +36 -0
- package/dist/session-kill-telemetry-RRQ2FDZU.js +29 -0
- package/dist/session-kill-telemetry-UL56A72F.js +29 -0
- package/dist/session-kill-telemetry-USIEQKM3.js +29 -0
- package/dist/session-kill-telemetry-XQ4FIV6G.js +29 -0
- package/dist/session-scope-5UTK6ID3.js +86 -0
- package/dist/session-scope-6URIZ6JG.js +86 -0
- package/dist/session-scope-DTDZDLJM.js +86 -0
- package/dist/session-scope-G7MFBQDJ.js +86 -0
- package/dist/session-scope-IDUBL4CA.js +86 -0
- package/dist/session-scope-KPVPLK3F.js +86 -0
- package/dist/session-scope-L7PN4EUN.js +86 -0
- package/dist/session-scope-UI7ZDVOB.js +86 -0
- package/dist/session-scope-XN3YM2Q5.js +86 -0
- package/dist/setup-wizard-D2G54X2Y.js +12 -0
- package/dist/setup-wizard-FY3U54VV.js +12 -0
- package/dist/setup-wizard-I7SIIJKF.js +12 -0
- package/dist/setup-wizard-NCBDIDUZ.js +12 -0
- package/dist/setup-wizard-NOWL5GX4.js +12 -0
- package/dist/setup-wizard-POFPTSXA.js +12 -0
- package/dist/setup-wizard-SCXS6F2F.js +12 -0
- package/dist/setup-wizard-YBLGQDBS.js +12 -0
- package/dist/setup-wizard-ZELVKEK3.js +12 -0
- package/dist/shard-manager-PRRCZNBV.js +30 -0
- package/dist/signal-PWVUZ5A6.js +7 -0
- package/dist/signal-paths-AMTV6ANR.js +19 -0
- package/dist/skill-refinement-ACMMMAOK.js +157 -0
- package/dist/skill-refinement-EPGHRXJG.js +157 -0
- package/dist/skill-refinement-KYM27SD3.js +157 -0
- package/dist/skill-refinement-MZ3TJIDD.js +157 -0
- package/dist/skill-refinement-R7K5M542.js +157 -0
- package/dist/skill-refinement-TFHUECXP.js +157 -0
- package/dist/skill-refinement-VB6JYRWF.js +157 -0
- package/dist/skill-refinement-VTP44BW3.js +157 -0
- package/dist/skill-refinement-XAHLEDQM.js +157 -0
- package/dist/slack-NNKFYH7T.js +7 -0
- package/dist/stack-release-WZ2S5E4L.js +731 -0
- package/dist/stack-update-BH3VVEF7.js +54 -0
- package/dist/stack-update-K3RGO6EJ.js +56 -0
- package/dist/stack-update-KXUNY3FP.js +54 -0
- package/dist/stack-update-SW2KRYB5.js +56 -0
- package/dist/steward-gate-BKMRY6YO.js +13 -0
- package/dist/steward-gate-P7ZNTNUJ.js +13 -0
- package/dist/steward-gate-QFPCXV2S.js +13 -0
- package/dist/steward-gate-XZ6ODTZX.js +13 -0
- package/dist/support-outbox-6EIEBOIV.js +490 -0
- package/dist/task-enforcement-2XFGCOOA.js +438 -0
- package/dist/task-enforcement-DEJG4YUU.js +423 -0
- package/dist/task-enforcement-DRGNWQPQ.js +438 -0
- package/dist/task-enforcement-FJY25DT2.js +438 -0
- package/dist/task-enforcement-LLSY7IVX.js +438 -0
- package/dist/task-enforcement-OG6QMY3K.js +423 -0
- package/dist/task-enforcement-QE7ZND7P.js +391 -0
- package/dist/task-enforcement-THPJEUXE.js +438 -0
- package/dist/task-enforcement-WHPYHJSR.js +423 -0
- package/dist/task-scanner-B6DRXPJZ.js +11 -0
- package/dist/task-scope-3OJ3HXJH.js +35 -0
- package/dist/task-scope-4DYVYHRH.js +35 -0
- package/dist/task-scope-5ZHVJSQV.js +35 -0
- package/dist/task-scope-6LAMIT56.js +35 -0
- package/dist/task-scope-CGPDNA2R.js +35 -0
- package/dist/task-scope-CSW2JGVT.js +35 -0
- package/dist/task-scope-JXZSWIVH.js +35 -0
- package/dist/task-scope-M4QGLYOA.js +35 -0
- package/dist/task-scope-VPQCW7XQ.js +35 -0
- package/dist/tasks-crud-3ASFAGTY.js +77 -0
- package/dist/tasks-crud-4GBOUTEN.js +77 -0
- package/dist/tasks-crud-4IMD7XNA.js +77 -0
- package/dist/tasks-crud-5S6X2FBF.js +77 -0
- package/dist/tasks-crud-6X5G6NQW.js +77 -0
- package/dist/tasks-crud-JJQ3LMFL.js +77 -0
- package/dist/tasks-crud-KL37U3NC.js +77 -0
- package/dist/tasks-crud-SSNMCJIX.js +77 -0
- package/dist/tasks-crud-WXIN6F3N.js +77 -0
- package/dist/tasks-notify-2FP5XJD6.js +38 -0
- package/dist/tasks-notify-3DRL6XCO.js +38 -0
- package/dist/tasks-notify-5VZJ7SZP.js +38 -0
- package/dist/tasks-notify-7N3VZBGS.js +38 -0
- package/dist/tasks-notify-DQYASACT.js +38 -0
- package/dist/tasks-notify-FBJU2FBD.js +38 -0
- package/dist/tasks-notify-KDARFEOQ.js +38 -0
- package/dist/tasks-notify-R5LPF2Q5.js +38 -0
- package/dist/tasks-notify-VSRXPEVB.js +38 -0
- package/dist/tasks-review-4FLX3KDM.js +47 -0
- package/dist/tasks-review-62VRGXWB.js +47 -0
- package/dist/tasks-review-ARS7I6TW.js +47 -0
- package/dist/tasks-review-I5LRYM6F.js +47 -0
- package/dist/tasks-review-K7CQFARA.js +47 -0
- package/dist/tasks-review-L67U3SF5.js +47 -0
- package/dist/tasks-review-OVWBSWKY.js +47 -0
- package/dist/tasks-review-YK6JDFMD.js +47 -0
- package/dist/tasks-review-YL56BTFI.js +47 -0
- package/dist/telegram-CGHB3TEI.js +7 -0
- package/dist/telemetry-OPR3R6OA.js +9 -0
- package/dist/telemetry-upload-5ELNFLSF.js +739 -0
- package/dist/telemetry-upload-7R2ZXNJJ.js +739 -0
- package/dist/telemetry-upload-AIGZFQ3U.js +739 -0
- package/dist/telemetry-upload-D5VBUCNY.js +739 -0
- package/dist/telemetry-upload-JGPZKOAF.js +739 -0
- package/dist/telemetry-upload-RDXJTYTE.js +739 -0
- package/dist/telemetry-upload-UY36UB2D.js +739 -0
- package/dist/telemetry-upload-VRHQOFCN.js +739 -0
- package/dist/telemetry-upload-XLQKR75S.js +739 -0
- package/dist/token-budget-KEL5DNWK.js +84 -0
- package/dist/token-budget-QMAGSEP6.js +84 -0
- package/dist/token-budget-WXZIXSXO.js +84 -0
- package/dist/token-budget-XDWZ3WFD.js +84 -0
- package/dist/tool-capability-index-WAJWVJIG.js +10 -0
- package/dist/tool-capability-index-ZICRKTNB.js +10 -0
- package/dist/tool-gates-AB3437EY.js +13 -0
- package/dist/tool-gates-YX7VO3HE.js +14 -0
- package/dist/tool-registry-KD2EJJAU.js +11 -0
- package/dist/tool-telemetry-FJZD2JIA.js +17 -0
- package/dist/tool-telemetry-SWOUWOUD.js +17 -0
- package/dist/tool-telemetry-VVJO6LRY.js +17 -0
- package/dist/tool-telemetry-YS5TO42H.js +17 -0
- package/dist/tui/App.js +56 -54
- package/dist/tui-data-27GVVJOU.js +258 -0
- package/dist/tui-data-37TJ54VI.js +258 -0
- package/dist/tui-data-5HI2DOD7.js +258 -0
- package/dist/tui-data-AC3UKRRY.js +258 -0
- package/dist/tui-data-F77RGHDV.js +258 -0
- package/dist/tui-data-KSG6DSIF.js +258 -0
- package/dist/tui-data-Q4AK2VA4.js +258 -0
- package/dist/tui-data-VGRAJ53D.js +258 -0
- package/dist/tui-data-VM6RABX2.js +258 -0
- package/dist/typed-messages-XK4EOVO3.js +17 -0
- package/dist/undici-ECX23NOZ.js +18337 -0
- package/dist/update-check-SE6UHHYE.js +11 -0
- package/dist/webhook-67M5Z7XA.js +96 -0
- package/dist/webhook-pipe-MRIWVULE.js +114 -0
- package/dist/whatsapp-V5JVEKWU.js +9 -0
- package/dist/whatsapp-accounts-FZLU4U2I.js +15 -0
- package/dist/whatsapp-config-HDO6NWHL.js +132 -0
- package/dist/wiki-acl-ANADZMHB.js +111 -0
- package/dist/wiki-acl-COU5EHBI.js +111 -0
- package/dist/wiki-acl-J222LNOF.js +111 -0
- package/dist/wiki-acl-LBKYC4VX.js +111 -0
- package/dist/wiki-client-CMQVLPMK.js +157 -0
- package/dist/worker-gate-36DBI7NE.js +21 -0
- package/dist/worker-gate-56JYUFA7.js +21 -0
- package/dist/worker-gate-7QHUBCAG.js +21 -0
- package/dist/worker-gate-E7LMIOJL.js +21 -0
- package/dist/worker-gate-EI3XNEJL.js +21 -0
- package/dist/worker-gate-FVF4NWZU.js +21 -0
- package/dist/worker-gate-G7JJHKEB.js +21 -0
- package/dist/worker-gate-XF4YGPYK.js +21 -0
- package/dist/worker-gate-YMCYCTRZ.js +21 -0
- package/dist/workflow-engine-3S5TPIKU.js +28 -0
- package/dist/workflow-engine-7YIVAYB3.js +28 -0
- package/dist/workflow-engine-D6USONUH.js +28 -0
- package/dist/workflow-engine-GNOKDKPG.js +28 -0
- package/dist/workflow-engine-IFKN6EDI.js +28 -0
- package/dist/workflow-engine-JNI3WD3I.js +28 -0
- package/dist/workflow-engine-K73ZJREJ.js +28 -0
- package/dist/workflow-engine-KAIO4Q5U.js +28 -0
- package/dist/workflow-engine-S52UFIUW.js +28 -0
- package/dist/working-memory-HT4E77P5.js +77 -0
- package/dist/worktree-KQ7ZDA53.js +26 -0
- package/dist/worktree-SETZ7IEC.js +26 -0
- package/dist/worktree-UOCMI6D7.js +26 -0
- package/dist/worktree-ZRQ7Y6BK.js +26 -0
- package/dist/worktree-sweep-6R3C2VRP.js +19 -0
- package/dist/worktree-sweep-V34JKHD5.js +19 -0
- package/dist/worktree-sweep-VSXKUQBT.js +19 -0
- package/dist/worktree-sweep-YLO4Y2DH.js +19 -0
- package/package.json +4 -11
- package/release-notes.json +84 -37
- package/src/commands/exe/build-adv.md +1 -1
- package/src/commands/exe/heartbeat.md +24 -21
- package/src/commands/exe/setup.md +18 -14
- package/src/commands/exe.md +2 -1
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
import {
|
|
2
|
+
routeTask
|
|
3
|
+
} from "./chunk-6YD3SMHS.js";
|
|
4
|
+
import {
|
|
5
|
+
createTaskCore,
|
|
6
|
+
employeeSessionName,
|
|
7
|
+
ensureEmployee,
|
|
8
|
+
getSessionState,
|
|
9
|
+
isEmployeeAlive,
|
|
10
|
+
sessionScopeFilter,
|
|
11
|
+
updateTaskStatus
|
|
12
|
+
} from "./chunk-PR4XTDPM.js";
|
|
13
|
+
import {
|
|
14
|
+
DEFAULT_COORDINATOR_TEMPLATE_NAME,
|
|
15
|
+
getCoordinatorName
|
|
16
|
+
} from "./chunk-IATEXT4R.js";
|
|
17
|
+
|
|
18
|
+
// src/runtime/orchestrator.ts
|
|
19
|
+
var STALE_THRESHOLD_MS = 2 * 60 * 60 * 1e3;
|
|
20
|
+
var MultiAgentOrchestrator = class {
|
|
21
|
+
config;
|
|
22
|
+
constructor(config) {
|
|
23
|
+
this.config = config;
|
|
24
|
+
}
|
|
25
|
+
/**
|
|
26
|
+
* Route and dispatch a single task to the best-fit employee.
|
|
27
|
+
*/
|
|
28
|
+
async dispatchTask(task) {
|
|
29
|
+
let targetEmployee;
|
|
30
|
+
let routingScore = 0;
|
|
31
|
+
if (task.assignTo) {
|
|
32
|
+
const found = this.config.employees.find((e) => e.name === task.assignTo);
|
|
33
|
+
if (!found) {
|
|
34
|
+
return {
|
|
35
|
+
employee: task.assignTo,
|
|
36
|
+
sessionName: "",
|
|
37
|
+
status: "failed",
|
|
38
|
+
routingScore: 0,
|
|
39
|
+
error: `Employee "${task.assignTo}" not found`
|
|
40
|
+
};
|
|
41
|
+
}
|
|
42
|
+
targetEmployee = found;
|
|
43
|
+
routingScore = 1;
|
|
44
|
+
} else {
|
|
45
|
+
const routed = await routeTask(
|
|
46
|
+
`${task.title}
|
|
47
|
+
${task.context}`,
|
|
48
|
+
this.config.employees,
|
|
49
|
+
this.config.embedFn,
|
|
50
|
+
this.config.searchFn
|
|
51
|
+
);
|
|
52
|
+
targetEmployee = routed.employee;
|
|
53
|
+
routingScore = routed.score;
|
|
54
|
+
}
|
|
55
|
+
try {
|
|
56
|
+
await createTaskCore({
|
|
57
|
+
title: task.title,
|
|
58
|
+
assignedTo: targetEmployee.name,
|
|
59
|
+
assignedBy: getCoordinatorName(),
|
|
60
|
+
projectName: task.projectName,
|
|
61
|
+
priority: task.priority,
|
|
62
|
+
context: task.context,
|
|
63
|
+
baseDir: this.config.projectDir,
|
|
64
|
+
skipDispatch: true
|
|
65
|
+
});
|
|
66
|
+
} catch (err) {
|
|
67
|
+
return {
|
|
68
|
+
employee: targetEmployee.name,
|
|
69
|
+
sessionName: "",
|
|
70
|
+
status: "failed",
|
|
71
|
+
routingScore,
|
|
72
|
+
error: `Task creation failed: ${err instanceof Error ? err.message : String(err)}`
|
|
73
|
+
};
|
|
74
|
+
}
|
|
75
|
+
const result = ensureEmployee(
|
|
76
|
+
targetEmployee.name,
|
|
77
|
+
this.config.exeSession,
|
|
78
|
+
this.config.projectDir,
|
|
79
|
+
task.spawnOpts
|
|
80
|
+
);
|
|
81
|
+
return {
|
|
82
|
+
employee: targetEmployee.name,
|
|
83
|
+
sessionName: result.sessionName,
|
|
84
|
+
status: result.status === "failed" ? "failed" : result.status === "spawned" ? "dispatched" : "already_running",
|
|
85
|
+
routingScore,
|
|
86
|
+
error: result.error
|
|
87
|
+
};
|
|
88
|
+
}
|
|
89
|
+
/**
|
|
90
|
+
* Check health of all employees. Detect stuck and idle agents.
|
|
91
|
+
*/
|
|
92
|
+
async healthCheck() {
|
|
93
|
+
const { getClient } = await import("./lib/database.js");
|
|
94
|
+
const client = getClient();
|
|
95
|
+
const employees = [];
|
|
96
|
+
const stuckAgents = [];
|
|
97
|
+
const idleAgents = [];
|
|
98
|
+
const crashedSessions = [];
|
|
99
|
+
let totalOpen = 0;
|
|
100
|
+
let totalInProgress = 0;
|
|
101
|
+
for (const emp of this.config.employees) {
|
|
102
|
+
const sessionName = employeeSessionName(emp.name, this.config.exeSession);
|
|
103
|
+
const alive = isEmployeeAlive(sessionName);
|
|
104
|
+
const state = alive ? getSessionState(sessionName) : "offline";
|
|
105
|
+
const oScope = sessionScopeFilter();
|
|
106
|
+
const tasks = await client.execute({
|
|
107
|
+
sql: `SELECT title, status, updated_at FROM tasks
|
|
108
|
+
WHERE assigned_to = ? AND status IN ('open', 'in_progress')${oScope.sql}
|
|
109
|
+
ORDER BY priority ASC`,
|
|
110
|
+
args: [emp.name, ...oScope.args]
|
|
111
|
+
});
|
|
112
|
+
const openCount = tasks.rows.filter((r) => r.status === "open").length;
|
|
113
|
+
const inProgressCount = tasks.rows.filter((r) => r.status === "in_progress").length;
|
|
114
|
+
totalOpen += openCount;
|
|
115
|
+
totalInProgress += inProgressCount;
|
|
116
|
+
const staleTasks = [];
|
|
117
|
+
for (const row of tasks.rows) {
|
|
118
|
+
if (row.status === "in_progress" && row.updated_at) {
|
|
119
|
+
const age = Date.now() - new Date(String(row.updated_at)).getTime();
|
|
120
|
+
if (age > STALE_THRESHOLD_MS) {
|
|
121
|
+
staleTasks.push(String(row.title));
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
const crashed = !alive && inProgressCount > 0;
|
|
126
|
+
if (staleTasks.length > 0) {
|
|
127
|
+
stuckAgents.push(emp.name);
|
|
128
|
+
}
|
|
129
|
+
if (crashed) {
|
|
130
|
+
crashedSessions.push(emp.name);
|
|
131
|
+
}
|
|
132
|
+
if (alive && state === "idle" && openCount + inProgressCount === 0) {
|
|
133
|
+
idleAgents.push(emp.name);
|
|
134
|
+
}
|
|
135
|
+
employees.push({
|
|
136
|
+
name: emp.name,
|
|
137
|
+
role: emp.role,
|
|
138
|
+
sessionName,
|
|
139
|
+
alive,
|
|
140
|
+
crashed,
|
|
141
|
+
state,
|
|
142
|
+
taskCount: openCount + inProgressCount,
|
|
143
|
+
inProgressCount,
|
|
144
|
+
staleTasks
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
return {
|
|
148
|
+
employees,
|
|
149
|
+
stuckAgents,
|
|
150
|
+
idleAgents,
|
|
151
|
+
crashedSessions,
|
|
152
|
+
totalOpenTasks: totalOpen,
|
|
153
|
+
totalInProgress
|
|
154
|
+
};
|
|
155
|
+
}
|
|
156
|
+
/**
|
|
157
|
+
* Process completed reviews. Auto-approve P2 tasks with passing results.
|
|
158
|
+
*/
|
|
159
|
+
async processReviews() {
|
|
160
|
+
const { getClient } = await import("./lib/database.js");
|
|
161
|
+
const client = getClient();
|
|
162
|
+
const autoApproved = [];
|
|
163
|
+
const needsReview = [];
|
|
164
|
+
const coordinatorName = getCoordinatorName();
|
|
165
|
+
const rScope = sessionScopeFilter();
|
|
166
|
+
const reviews = await client.execute({
|
|
167
|
+
sql: `SELECT id, title, assigned_to, priority, result, task_file FROM tasks
|
|
168
|
+
WHERE (assigned_to = ? OR assigned_to = ?)
|
|
169
|
+
AND status IN ('open', 'in_progress')
|
|
170
|
+
AND task_file LIKE '%review-%'${rScope.sql}
|
|
171
|
+
ORDER BY priority ASC
|
|
172
|
+
LIMIT 20`,
|
|
173
|
+
args: [coordinatorName, DEFAULT_COORDINATOR_TEMPLATE_NAME, ...rScope.args]
|
|
174
|
+
});
|
|
175
|
+
for (const row of reviews.rows) {
|
|
176
|
+
const item = {
|
|
177
|
+
taskId: String(row.id),
|
|
178
|
+
title: String(row.title),
|
|
179
|
+
assignedTo: String(row.assigned_to),
|
|
180
|
+
priority: String(row.priority),
|
|
181
|
+
result: String(row.result ?? ""),
|
|
182
|
+
taskFile: String(row.task_file)
|
|
183
|
+
};
|
|
184
|
+
if (this.config.autoApproveP2 && item.priority === "p2" && /tests?\s+pass/i.test(item.result)) {
|
|
185
|
+
try {
|
|
186
|
+
await updateTaskStatus({
|
|
187
|
+
taskId: item.taskId,
|
|
188
|
+
status: "done",
|
|
189
|
+
result: `[auto-approved] ${item.result}`,
|
|
190
|
+
skipReviewCreation: true
|
|
191
|
+
});
|
|
192
|
+
} catch {
|
|
193
|
+
await client.execute({
|
|
194
|
+
sql: `UPDATE tasks SET status = 'done', result = ? WHERE id = ?`,
|
|
195
|
+
args: [`[auto-approved] ${item.result}`, item.taskId]
|
|
196
|
+
});
|
|
197
|
+
}
|
|
198
|
+
autoApproved.push(item);
|
|
199
|
+
} else {
|
|
200
|
+
needsReview.push(item);
|
|
201
|
+
}
|
|
202
|
+
}
|
|
203
|
+
return {
|
|
204
|
+
autoApproved,
|
|
205
|
+
needsReview,
|
|
206
|
+
processed: autoApproved.length + needsReview.length
|
|
207
|
+
};
|
|
208
|
+
}
|
|
209
|
+
/**
|
|
210
|
+
* Run one full orchestration cycle: health check + process reviews.
|
|
211
|
+
* Does NOT dispatch tasks — call dispatchTask() explicitly.
|
|
212
|
+
*/
|
|
213
|
+
async tick() {
|
|
214
|
+
const health = await this.healthCheck();
|
|
215
|
+
const reviews = await this.processReviews();
|
|
216
|
+
for (const stuck of health.stuckAgents) {
|
|
217
|
+
const sessionName = employeeSessionName(stuck, this.config.exeSession);
|
|
218
|
+
if (isEmployeeAlive(sessionName)) {
|
|
219
|
+
const { sendIntercom } = await import("./lib/tmux-routing.js");
|
|
220
|
+
sendIntercom(sessionName);
|
|
221
|
+
}
|
|
222
|
+
}
|
|
223
|
+
for (const crashed of health.crashedSessions) {
|
|
224
|
+
this.recoverSession(crashed);
|
|
225
|
+
}
|
|
226
|
+
return {
|
|
227
|
+
dispatched: [],
|
|
228
|
+
health,
|
|
229
|
+
reviews,
|
|
230
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString()
|
|
231
|
+
};
|
|
232
|
+
}
|
|
233
|
+
/**
|
|
234
|
+
* Recover a crashed session by spawning a fresh CC session.
|
|
235
|
+
* The new session boots with identity via --system-prompt, finds existing in_progress tasks, and resumes.
|
|
236
|
+
*/
|
|
237
|
+
recoverSession(employeeName) {
|
|
238
|
+
const sessionName = employeeSessionName(employeeName, this.config.exeSession);
|
|
239
|
+
const result = ensureEmployee(
|
|
240
|
+
employeeName,
|
|
241
|
+
this.config.exeSession,
|
|
242
|
+
this.config.projectDir
|
|
243
|
+
);
|
|
244
|
+
if (result.status === "failed") {
|
|
245
|
+
return { status: "failed", sessionName, error: result.error };
|
|
246
|
+
}
|
|
247
|
+
return { status: "recovered", sessionName: result.sessionName };
|
|
248
|
+
}
|
|
249
|
+
/**
|
|
250
|
+
* Dispatch a batch of tasks, auto-routing each to the best employee.
|
|
251
|
+
*/
|
|
252
|
+
async dispatchBatch(tasks) {
|
|
253
|
+
const results = [];
|
|
254
|
+
for (const task of tasks) {
|
|
255
|
+
const result = await this.dispatchTask(task);
|
|
256
|
+
results.push(result);
|
|
257
|
+
}
|
|
258
|
+
return results;
|
|
259
|
+
}
|
|
260
|
+
/**
|
|
261
|
+
* Get a formatted status summary (matches exe boot brief style).
|
|
262
|
+
*/
|
|
263
|
+
async getStatusSummary() {
|
|
264
|
+
const health = await this.healthCheck();
|
|
265
|
+
const lines = [];
|
|
266
|
+
lines.push("\u25B8 ORCHESTRATOR STATUS");
|
|
267
|
+
lines.push(` Tasks: ${health.totalOpenTasks} open, ${health.totalInProgress} in progress`);
|
|
268
|
+
lines.push(` Crashed: ${health.crashedSessions.length > 0 ? health.crashedSessions.join(", ") : "none"}`);
|
|
269
|
+
lines.push(` Stuck: ${health.stuckAgents.length > 0 ? health.stuckAgents.join(", ") : "none"}`);
|
|
270
|
+
lines.push(` Idle: ${health.idleAgents.length > 0 ? health.idleAgents.join(", ") : "none"}`);
|
|
271
|
+
lines.push("");
|
|
272
|
+
for (const emp of health.employees) {
|
|
273
|
+
const stateIcon = emp.alive ? emp.state === "idle" ? "\u{1F7E2}" : emp.state === "thinking" ? "\u{1F7E1}" : emp.state === "tool" ? "\u{1F535}" : "\u26AA" : "\u{1F534}";
|
|
274
|
+
const taskInfo = emp.taskCount > 0 ? `${emp.taskCount} task${emp.taskCount > 1 ? "s" : ""} (${emp.inProgressCount} active)` : "idle";
|
|
275
|
+
const staleWarning = emp.staleTasks.length > 0 ? ` \u26A0 stale: ${emp.staleTasks[0]}` : "";
|
|
276
|
+
lines.push(` ${stateIcon} ${emp.name} (${emp.role}): ${taskInfo}${staleWarning}`);
|
|
277
|
+
}
|
|
278
|
+
return lines.join("\n");
|
|
279
|
+
}
|
|
280
|
+
};
|
|
281
|
+
|
|
282
|
+
export {
|
|
283
|
+
MultiAgentOrchestrator
|
|
284
|
+
};
|
|
@@ -0,0 +1,382 @@
|
|
|
1
|
+
// src/automation/trigger-engine.ts
|
|
2
|
+
import { readFileSync, writeFileSync, existsSync, mkdirSync } from "fs";
|
|
3
|
+
import { randomUUID } from "crypto";
|
|
4
|
+
import path from "path";
|
|
5
|
+
import os from "os";
|
|
6
|
+
var TRIGGERS_PATH = path.join(os.homedir(), ".exe-os", "triggers.json");
|
|
7
|
+
var GRAPH_API_VERSION = "v21.0";
|
|
8
|
+
var MAX_PARAM_LENGTH = 2e3;
|
|
9
|
+
var MAX_TRIGGER_DEPTH = 3;
|
|
10
|
+
var _currentTriggerDepth = 0;
|
|
11
|
+
var OUTBOUND_RATE_LIMIT_PER_HOUR = 100;
|
|
12
|
+
var _outboundWindows = /* @__PURE__ */ new Map();
|
|
13
|
+
function checkOutboundRateLimit(channel) {
|
|
14
|
+
const now = Date.now();
|
|
15
|
+
const cutoff = now - 36e5;
|
|
16
|
+
if (!_outboundWindows.has(channel)) _outboundWindows.set(channel, []);
|
|
17
|
+
const window = _outboundWindows.get(channel);
|
|
18
|
+
while (window.length > 0 && window[0] < cutoff) window.shift();
|
|
19
|
+
if (window.length >= OUTBOUND_RATE_LIMIT_PER_HOUR) return false;
|
|
20
|
+
window.push(now);
|
|
21
|
+
return true;
|
|
22
|
+
}
|
|
23
|
+
function sanitizeParam(value, maxLen = MAX_PARAM_LENGTH) {
|
|
24
|
+
const cleaned = value.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g, "");
|
|
25
|
+
return cleaned.length > maxLen ? cleaned.slice(0, maxLen) : cleaned;
|
|
26
|
+
}
|
|
27
|
+
function sanitizeExternalPayload(text) {
|
|
28
|
+
let sanitized = text;
|
|
29
|
+
sanitized = sanitized.replace(/^(system|SYSTEM|System)\s*:/gm, "[filtered]:");
|
|
30
|
+
sanitized = sanitized.replace(/<\/?system[^>]*>/gi, "[filtered]");
|
|
31
|
+
sanitized = sanitized.replace(/ignore\s+(all\s+)?previous\s+(instructions|prompts|rules)/gi, "[filtered]");
|
|
32
|
+
sanitized = sanitized.replace(/you\s+are\s+now\s+/gi, "[filtered] ");
|
|
33
|
+
return sanitized;
|
|
34
|
+
}
|
|
35
|
+
function substituteTemplate(template, record, sanitizeExternal = false) {
|
|
36
|
+
return template.replace(
|
|
37
|
+
/\{\{(\w+(?:\.\w+)*)\}\}/g,
|
|
38
|
+
(_match, dotPath) => {
|
|
39
|
+
const segments = dotPath.split(".");
|
|
40
|
+
if (segments[0] === "record") segments.shift();
|
|
41
|
+
let current = record;
|
|
42
|
+
for (const seg of segments) {
|
|
43
|
+
if (current == null || typeof current !== "object") return "";
|
|
44
|
+
current = current[seg];
|
|
45
|
+
}
|
|
46
|
+
if (current == null) return "";
|
|
47
|
+
const value = String(current);
|
|
48
|
+
return sanitizeExternal ? sanitizeExternalPayload(value) : value;
|
|
49
|
+
}
|
|
50
|
+
);
|
|
51
|
+
}
|
|
52
|
+
function resolveFieldValue(record, field) {
|
|
53
|
+
let current = record;
|
|
54
|
+
for (const segment of field.split(".")) {
|
|
55
|
+
if (current == null || typeof current !== "object") return void 0;
|
|
56
|
+
current = current[segment];
|
|
57
|
+
}
|
|
58
|
+
return current;
|
|
59
|
+
}
|
|
60
|
+
function evaluateCondition(condition, record) {
|
|
61
|
+
const fieldValue = resolveFieldValue(record, condition.field);
|
|
62
|
+
const target = condition.value;
|
|
63
|
+
switch (condition.op) {
|
|
64
|
+
case "eq":
|
|
65
|
+
return String(fieldValue) === String(target);
|
|
66
|
+
case "neq":
|
|
67
|
+
return String(fieldValue) !== String(target);
|
|
68
|
+
case "gt":
|
|
69
|
+
return Number(fieldValue) > Number(target);
|
|
70
|
+
case "lt":
|
|
71
|
+
return Number(fieldValue) < Number(target);
|
|
72
|
+
case "gte":
|
|
73
|
+
return Number(fieldValue) >= Number(target);
|
|
74
|
+
case "lte":
|
|
75
|
+
return Number(fieldValue) <= Number(target);
|
|
76
|
+
case "contains":
|
|
77
|
+
return String(fieldValue).toLowerCase().includes(String(target).toLowerCase());
|
|
78
|
+
case "not_contains":
|
|
79
|
+
return !String(fieldValue).toLowerCase().includes(String(target).toLowerCase());
|
|
80
|
+
default:
|
|
81
|
+
return false;
|
|
82
|
+
}
|
|
83
|
+
}
|
|
84
|
+
function evaluateConditions(conditions, record) {
|
|
85
|
+
if (conditions.length === 0) return true;
|
|
86
|
+
return conditions.every((c) => evaluateCondition(c, record));
|
|
87
|
+
}
|
|
88
|
+
function loadTriggers(project) {
|
|
89
|
+
if (!existsSync(TRIGGERS_PATH)) return [];
|
|
90
|
+
try {
|
|
91
|
+
const raw = readFileSync(TRIGGERS_PATH, "utf-8");
|
|
92
|
+
const all = JSON.parse(raw);
|
|
93
|
+
if (!Array.isArray(all)) return [];
|
|
94
|
+
if (project) {
|
|
95
|
+
return all.filter((t) => !t.project || t.project === project);
|
|
96
|
+
}
|
|
97
|
+
return all;
|
|
98
|
+
} catch {
|
|
99
|
+
return [];
|
|
100
|
+
}
|
|
101
|
+
}
|
|
102
|
+
function saveTriggers(triggers) {
|
|
103
|
+
const dir = path.dirname(TRIGGERS_PATH);
|
|
104
|
+
if (!existsSync(dir)) mkdirSync(dir, { recursive: true });
|
|
105
|
+
writeFileSync(TRIGGERS_PATH, JSON.stringify(triggers, null, 2), "utf-8");
|
|
106
|
+
}
|
|
107
|
+
function createNewTrigger(input) {
|
|
108
|
+
const triggers = loadTriggers();
|
|
109
|
+
const trigger = {
|
|
110
|
+
id: randomUUID().slice(0, 8),
|
|
111
|
+
...input
|
|
112
|
+
};
|
|
113
|
+
triggers.push(trigger);
|
|
114
|
+
saveTriggers(triggers);
|
|
115
|
+
return trigger;
|
|
116
|
+
}
|
|
117
|
+
async function executeSendWhatsapp(params) {
|
|
118
|
+
if (!checkOutboundRateLimit("whatsapp")) {
|
|
119
|
+
throw new Error(`Outbound rate limit exceeded for WhatsApp (max ${OUTBOUND_RATE_LIMIT_PER_HOUR}/hour)`);
|
|
120
|
+
}
|
|
121
|
+
const { getAccountByName, getDefaultAccount } = await import("./whatsapp-accounts-BWRZUY23.js");
|
|
122
|
+
const account = params.account ? getAccountByName(params.account) : getDefaultAccount();
|
|
123
|
+
if (!account) {
|
|
124
|
+
throw new Error(
|
|
125
|
+
`No WhatsApp account found${params.account ? ` (${params.account})` : ""}`
|
|
126
|
+
);
|
|
127
|
+
}
|
|
128
|
+
const to = params.to ?? params.recipient;
|
|
129
|
+
const message = params.message ?? params.text;
|
|
130
|
+
if (!to || !message)
|
|
131
|
+
throw new Error("send_whatsapp requires 'to' and 'message' params");
|
|
132
|
+
const url = `https://graph.facebook.com/${GRAPH_API_VERSION}/${account.phoneNumberId}/messages`;
|
|
133
|
+
const res = await fetch(url, {
|
|
134
|
+
method: "POST",
|
|
135
|
+
headers: {
|
|
136
|
+
"Content-Type": "application/json",
|
|
137
|
+
Authorization: `Bearer ${account.accessToken}`
|
|
138
|
+
},
|
|
139
|
+
body: JSON.stringify({
|
|
140
|
+
messaging_product: "whatsapp",
|
|
141
|
+
to,
|
|
142
|
+
type: "text",
|
|
143
|
+
text: { body: message }
|
|
144
|
+
}),
|
|
145
|
+
signal: AbortSignal.timeout(3e4)
|
|
146
|
+
});
|
|
147
|
+
if (!res.ok) {
|
|
148
|
+
const errBody = await res.text();
|
|
149
|
+
throw new Error(`WhatsApp send failed (${res.status}): ${errBody}`);
|
|
150
|
+
}
|
|
151
|
+
}
|
|
152
|
+
async function executeSendMessage(params) {
|
|
153
|
+
const { sendMessage } = await import("./lib/messaging.js");
|
|
154
|
+
const { getCoordinatorName } = await import("./lib/employees.js");
|
|
155
|
+
const rawTo = params.to ?? params.recipient;
|
|
156
|
+
const to = rawTo === "coordinator" ? getCoordinatorName() : rawTo;
|
|
157
|
+
const content = params.message ?? params.content ?? params.text;
|
|
158
|
+
if (!to || !content)
|
|
159
|
+
throw new Error("send_message requires 'to' and 'message' params");
|
|
160
|
+
await sendMessage({
|
|
161
|
+
fromAgent: params.from ?? "trigger-engine",
|
|
162
|
+
targetAgent: to,
|
|
163
|
+
content,
|
|
164
|
+
priority: params.priority ?? "normal"
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
async function executeCreateTask(params) {
|
|
168
|
+
const { createTask } = await import("./lib/tasks.js");
|
|
169
|
+
const { getCoordinatorName } = await import("./lib/employees.js");
|
|
170
|
+
const rawAssignedTo = params.assigned_to;
|
|
171
|
+
await createTask({
|
|
172
|
+
title: params.title ?? "Triggered task",
|
|
173
|
+
assignedTo: !rawAssignedTo || rawAssignedTo === "coordinator" ? getCoordinatorName() : rawAssignedTo,
|
|
174
|
+
assignedBy: "trigger-engine",
|
|
175
|
+
projectName: params.project ?? "exe-os",
|
|
176
|
+
priority: params.priority ?? "p1",
|
|
177
|
+
context: params.context ?? params.description ?? "",
|
|
178
|
+
baseDir: process.cwd()
|
|
179
|
+
});
|
|
180
|
+
}
|
|
181
|
+
async function executeUpdateWiki(params) {
|
|
182
|
+
const apiUrl = process.env.EXE_WIKI_API_URL;
|
|
183
|
+
const apiKey = process.env.EXE_WIKI_API_KEY;
|
|
184
|
+
if (!apiUrl || !apiKey) {
|
|
185
|
+
throw new Error("Wiki not configured: EXE_WIKI_API_URL / EXE_WIKI_API_KEY not set");
|
|
186
|
+
}
|
|
187
|
+
const workspace = params.workspace;
|
|
188
|
+
const content = params.content ?? params.text;
|
|
189
|
+
const mode = params.mode ?? "append";
|
|
190
|
+
const section = params.section;
|
|
191
|
+
if (!workspace || !content) {
|
|
192
|
+
throw new Error("update_wiki requires 'workspace' and 'content' params");
|
|
193
|
+
}
|
|
194
|
+
const documentId = params.document_id;
|
|
195
|
+
if (documentId && mode === "append") {
|
|
196
|
+
const readRes = await fetch(`${apiUrl}/v1/document/${documentId}`, {
|
|
197
|
+
headers: { Authorization: `Bearer ${apiKey}` },
|
|
198
|
+
signal: AbortSignal.timeout(15e3)
|
|
199
|
+
});
|
|
200
|
+
if (!readRes.ok) {
|
|
201
|
+
throw new Error(`Wiki read failed (${readRes.status})`);
|
|
202
|
+
}
|
|
203
|
+
const doc = await readRes.json();
|
|
204
|
+
const existingContent = String(doc.content ?? "");
|
|
205
|
+
const title = String(doc.title ?? "Untitled");
|
|
206
|
+
await fetch(`${apiUrl}/v1/document/${documentId}`, {
|
|
207
|
+
method: "DELETE",
|
|
208
|
+
headers: { Authorization: `Bearer ${apiKey}` },
|
|
209
|
+
signal: AbortSignal.timeout(15e3)
|
|
210
|
+
}).catch((err) => {
|
|
211
|
+
process.stderr.write(`[trigger-engine] wiki purge failed: ${err instanceof Error ? err.message : String(err)}
|
|
212
|
+
`);
|
|
213
|
+
});
|
|
214
|
+
const uploadRes = await fetch(`${apiUrl}/v1/document/raw-text`, {
|
|
215
|
+
method: "POST",
|
|
216
|
+
headers: {
|
|
217
|
+
"Content-Type": "application/json",
|
|
218
|
+
Authorization: `Bearer ${apiKey}`
|
|
219
|
+
},
|
|
220
|
+
body: JSON.stringify({
|
|
221
|
+
textContent: section ? existingContent + `
|
|
222
|
+
|
|
223
|
+
## ${section}
|
|
224
|
+
${content}` : existingContent + "\n\n" + content,
|
|
225
|
+
metadata: { title },
|
|
226
|
+
workspaceSlugs: [workspace]
|
|
227
|
+
}),
|
|
228
|
+
signal: AbortSignal.timeout(15e3)
|
|
229
|
+
});
|
|
230
|
+
if (!uploadRes.ok) throw new Error(`Wiki upload failed (${uploadRes.status})`);
|
|
231
|
+
} else {
|
|
232
|
+
const title = params.title ?? "Auto-generated";
|
|
233
|
+
const res = await fetch(`${apiUrl}/v1/document/raw-text`, {
|
|
234
|
+
method: "POST",
|
|
235
|
+
headers: {
|
|
236
|
+
"Content-Type": "application/json",
|
|
237
|
+
Authorization: `Bearer ${apiKey}`
|
|
238
|
+
},
|
|
239
|
+
body: JSON.stringify({
|
|
240
|
+
textContent: content,
|
|
241
|
+
metadata: { title },
|
|
242
|
+
workspaceSlugs: [workspace]
|
|
243
|
+
}),
|
|
244
|
+
signal: AbortSignal.timeout(15e3)
|
|
245
|
+
});
|
|
246
|
+
if (!res.ok) throw new Error(`Wiki create failed (${res.status})`);
|
|
247
|
+
}
|
|
248
|
+
}
|
|
249
|
+
async function routeToApproval(action, resolvedParams, triggerName) {
|
|
250
|
+
const { createTask } = await import("./lib/tasks.js");
|
|
251
|
+
const { getCoordinatorName } = await import("./lib/employees.js");
|
|
252
|
+
const actionSummary = action.type === "send_whatsapp" ? `Send WhatsApp to ${resolvedParams.to ?? resolvedParams.recipient ?? "unknown"}: "${(resolvedParams.message ?? resolvedParams.text ?? "").slice(0, 100)}"` : `${action.type}: ${JSON.stringify(resolvedParams).slice(0, 200)}`;
|
|
253
|
+
await createTask({
|
|
254
|
+
title: `[Approval Required] ${triggerName}: ${action.type}`,
|
|
255
|
+
assignedTo: getCoordinatorName(),
|
|
256
|
+
assignedBy: "trigger-engine",
|
|
257
|
+
projectName: resolvedParams.project ?? "exe-os",
|
|
258
|
+
priority: "p1",
|
|
259
|
+
context: `Trigger "${triggerName}" wants to execute this action but requires approval.
|
|
260
|
+
|
|
261
|
+
**Action:** ${action.type}
|
|
262
|
+
**Summary:** ${actionSummary}
|
|
263
|
+
**Full params:** ${JSON.stringify(resolvedParams, null, 2)}
|
|
264
|
+
|
|
265
|
+
To approve, manually run the action via MCP tools.`,
|
|
266
|
+
baseDir: process.cwd()
|
|
267
|
+
});
|
|
268
|
+
}
|
|
269
|
+
async function executeAction(action, record, executor, triggerName) {
|
|
270
|
+
if (executor) {
|
|
271
|
+
return executor(action, record);
|
|
272
|
+
}
|
|
273
|
+
const resolvedParams = {};
|
|
274
|
+
for (const [key, val] of Object.entries(action.params)) {
|
|
275
|
+
resolvedParams[key] = sanitizeParam(substituteTemplate(val, record));
|
|
276
|
+
}
|
|
277
|
+
if (action.requires_approval) {
|
|
278
|
+
try {
|
|
279
|
+
await routeToApproval(action, resolvedParams, triggerName ?? "Unknown trigger");
|
|
280
|
+
return { success: true };
|
|
281
|
+
} catch (err) {
|
|
282
|
+
return {
|
|
283
|
+
success: false,
|
|
284
|
+
error: `Approval routing failed: ${err instanceof Error ? err.message : String(err)}`
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
}
|
|
288
|
+
try {
|
|
289
|
+
switch (action.type) {
|
|
290
|
+
case "send_whatsapp":
|
|
291
|
+
await executeSendWhatsapp(resolvedParams);
|
|
292
|
+
break;
|
|
293
|
+
case "send_message":
|
|
294
|
+
await executeSendMessage(resolvedParams);
|
|
295
|
+
break;
|
|
296
|
+
case "create_task":
|
|
297
|
+
await executeCreateTask(resolvedParams);
|
|
298
|
+
break;
|
|
299
|
+
case "update_wiki":
|
|
300
|
+
await executeUpdateWiki(resolvedParams);
|
|
301
|
+
break;
|
|
302
|
+
case "asana": {
|
|
303
|
+
const { loadAsanaConfig, executeAsanaOperation } = await import("./asana-MRQ2OQMJ.js");
|
|
304
|
+
const asanaConfig = loadAsanaConfig();
|
|
305
|
+
if (!asanaConfig) throw new Error("Asana not configured: set ASANA_API_TOKEN env var");
|
|
306
|
+
const operation = resolvedParams.operation ?? resolvedParams._operation;
|
|
307
|
+
if (!operation) throw new Error("asana action requires 'operation' param");
|
|
308
|
+
await executeAsanaOperation(asanaConfig, operation, resolvedParams);
|
|
309
|
+
break;
|
|
310
|
+
}
|
|
311
|
+
case "mcp_tool":
|
|
312
|
+
console.log(
|
|
313
|
+
`[trigger-engine] mcp_tool action: ${JSON.stringify(resolvedParams)}`
|
|
314
|
+
);
|
|
315
|
+
break;
|
|
316
|
+
}
|
|
317
|
+
return { success: true };
|
|
318
|
+
} catch (err) {
|
|
319
|
+
return {
|
|
320
|
+
success: false,
|
|
321
|
+
error: err instanceof Error ? err.message : String(err)
|
|
322
|
+
};
|
|
323
|
+
}
|
|
324
|
+
}
|
|
325
|
+
async function processCRMEvent(event, executor, triggersOverride) {
|
|
326
|
+
if (_currentTriggerDepth >= MAX_TRIGGER_DEPTH) {
|
|
327
|
+
console.error(
|
|
328
|
+
`[trigger-engine] Recursion limit (${MAX_TRIGGER_DEPTH}) reached \u2014 skipping event ${event.objectType}.${event.eventType}`
|
|
329
|
+
);
|
|
330
|
+
return [];
|
|
331
|
+
}
|
|
332
|
+
_currentTriggerDepth++;
|
|
333
|
+
try {
|
|
334
|
+
return await _processCRMEventInner(event, executor, triggersOverride);
|
|
335
|
+
} finally {
|
|
336
|
+
_currentTriggerDepth--;
|
|
337
|
+
}
|
|
338
|
+
}
|
|
339
|
+
async function _processCRMEventInner(event, executor, triggersOverride) {
|
|
340
|
+
const eventString = `${event.objectType}.${event.eventType}`;
|
|
341
|
+
const triggers = triggersOverride ?? loadTriggers();
|
|
342
|
+
const logs = [];
|
|
343
|
+
for (const trigger of triggers) {
|
|
344
|
+
if (!trigger.enabled) continue;
|
|
345
|
+
if (trigger.event !== eventString && trigger.event !== "*") continue;
|
|
346
|
+
if (!evaluateConditions(trigger.conditions, event.record)) continue;
|
|
347
|
+
const actionResults = [];
|
|
348
|
+
for (const action of trigger.actions) {
|
|
349
|
+
const result = await executeAction(action, event.record, executor, trigger.name);
|
|
350
|
+
actionResults.push({
|
|
351
|
+
type: action.type,
|
|
352
|
+
success: result.success,
|
|
353
|
+
error: result.error
|
|
354
|
+
});
|
|
355
|
+
}
|
|
356
|
+
const log = {
|
|
357
|
+
triggerId: trigger.id,
|
|
358
|
+
triggerName: trigger.name,
|
|
359
|
+
event: eventString,
|
|
360
|
+
firedAt: (/* @__PURE__ */ new Date()).toISOString(),
|
|
361
|
+
actionsExecuted: actionResults
|
|
362
|
+
};
|
|
363
|
+
logs.push(log);
|
|
364
|
+
console.log(
|
|
365
|
+
`[trigger-engine] Fired "${trigger.name}" on ${eventString}: ${actionResults.filter((a) => a.success).length}/${actionResults.length} actions succeeded`
|
|
366
|
+
);
|
|
367
|
+
}
|
|
368
|
+
return logs;
|
|
369
|
+
}
|
|
370
|
+
function isScheduledTrigger(trigger) {
|
|
371
|
+
return "schedule" in trigger && "query" in trigger;
|
|
372
|
+
}
|
|
373
|
+
|
|
374
|
+
export {
|
|
375
|
+
sanitizeParam,
|
|
376
|
+
substituteTemplate,
|
|
377
|
+
loadTriggers,
|
|
378
|
+
createNewTrigger,
|
|
379
|
+
executeAction,
|
|
380
|
+
processCRMEvent,
|
|
381
|
+
isScheduledTrigger
|
|
382
|
+
};
|