@askexenow/exe-os 0.9.271 → 0.9.273
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/dist/active-agent-BDYXURXQ.js +26 -0
- package/dist/active-agent-YWBGAKGU.js +25 -0
- package/dist/agentic-ontology-56VHSVS3.js +25 -0
- package/dist/backfill-metadata-A3534S32.js +597 -0
- package/dist/backfill-metadata-B6F2KJJV.js +597 -0
- package/dist/backfill-metadata-BOM2MXLI.js +597 -0
- package/dist/backfill-metadata-G46ABBVR.js +597 -0
- package/dist/backfill-metadata-TAU33HJS.js +597 -0
- package/dist/backfill-metadata-VAV27KJK.js +597 -0
- package/dist/behaviors-USUTDXVA.js +25 -0
- package/dist/bin/agentic-ontology-backfill.js +5 -5
- package/dist/bin/agentic-reflection-backfill.js +6 -6
- package/dist/bin/agentic-semantic-label.js +5 -5
- package/dist/bin/backfill-conversations.js +4 -4
- package/dist/bin/backfill-responses.js +4 -4
- package/dist/bin/backfill-vectors.js +5 -5
- package/dist/bin/bulk-sync-postgres.js +6 -6
- package/dist/bin/cc-doctor.js +4 -4
- package/dist/bin/cleanup-stale-review-tasks.js +10 -10
- package/dist/bin/cli.js +16 -16
- package/dist/bin/exe-agent-config.js +3 -3
- package/dist/bin/exe-agent.js +4 -4
- package/dist/bin/exe-assign.js +5 -5
- package/dist/bin/exe-boot.js +17 -17
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +4 -4
- package/dist/bin/exe-dispatch.js +10 -10
- package/dist/bin/exe-doctor.js +1 -1
- package/dist/bin/exe-export-behaviors.js +7 -7
- package/dist/bin/exe-forget.js +6 -6
- package/dist/bin/exe-gateway.js +7 -7
- package/dist/bin/exe-healthcheck.js +4 -4
- package/dist/bin/exe-heartbeat.js +10 -10
- package/dist/bin/exe-kill.js +13 -13
- package/dist/bin/exe-launch-agent.js +37 -19
- package/dist/bin/exe-new-employee.js +6 -6
- package/dist/bin/exe-pending-messages.js +11 -11
- package/dist/bin/exe-pending-notifications.js +33 -18
- package/dist/bin/exe-pending-reviews.js +10 -10
- package/dist/bin/exe-rename.js +4 -4
- package/dist/bin/exe-review.js +12 -12
- package/dist/bin/exe-search.js +5 -5
- package/dist/bin/exe-session-cleanup.js +15 -15
- package/dist/bin/exe-settings.js +5 -5
- package/dist/bin/exe-start-codex.js +11 -11
- package/dist/bin/exe-start-opencode.js +8 -8
- package/dist/bin/exe-status.js +11 -11
- package/dist/bin/exe-team.js +3 -3
- package/dist/bin/git-sweep.js +11 -11
- package/dist/bin/graph-backfill.js +4 -4
- package/dist/bin/graph-export.js +5 -5
- package/dist/bin/import-history.js +7 -7
- package/dist/bin/install.js +6 -6
- package/dist/bin/intercom-check.js +4 -4
- package/dist/bin/mcp-sessions.js +2 -2
- package/dist/bin/orchestration-metrics.js +4 -4
- package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
- package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
- package/dist/bin/scan-tasks.js +10 -10
- package/dist/bin/setup.js +1 -1
- package/dist/bin/shard-migrate.js +4 -4
- package/dist/capacity-monitor-2GJOFXGB.js +49 -0
- package/dist/capacity-monitor-3Z7W4K25.js +49 -0
- package/dist/capacity-monitor-BENS3N7B.js +49 -0
- package/dist/capacity-monitor-IFVRCIM7.js +49 -0
- package/dist/capacity-monitor-MQUUEZKB.js +49 -0
- package/dist/capacity-monitor-Q47GBDSY.js +49 -0
- package/dist/catchup-brief-B4KGAIPU.js +151 -0
- package/dist/catchup-brief-NMOV3SSP.js +151 -0
- package/dist/catchup-brief-RP4QHXNT.js +151 -0
- package/dist/catchup-brief-TKA6TEK4.js +151 -0
- package/dist/catchup-brief-VMF3ESTZ.js +151 -0
- package/dist/catchup-brief-ZL7V3BXC.js +151 -0
- package/dist/chunk-23KJ2LXY.js +58 -0
- package/dist/chunk-2KWVJV6I.js +171 -0
- package/dist/chunk-2NQQP3FF.js +630 -0
- package/dist/chunk-3A4SOC66.js +551 -0
- package/dist/chunk-3FU5I3KV.js +526 -0
- package/dist/chunk-3GSGDPLK.js +171 -0
- package/dist/chunk-3IM3JNQV.js +377 -0
- package/dist/chunk-3OM3V545.js +448 -0
- package/dist/chunk-3T27ZQT6.js +495 -0
- package/dist/chunk-3VI3QIHU.js +214 -0
- package/dist/chunk-3WG3RRWA.js +1345 -0
- package/dist/chunk-42A3JV3A.js +128 -0
- package/dist/chunk-46IEEKPU.js +13696 -0
- package/dist/chunk-46WLFLGP.js +1073 -0
- package/dist/chunk-4JMPQB7K.js +1148 -0
- package/dist/chunk-4L25LLQM.js +382 -0
- package/dist/chunk-4Q7X3SAM.js +204 -0
- package/dist/chunk-4UAUCFHA.js +526 -0
- package/dist/chunk-4VRJX2SP.js +495 -0
- package/dist/chunk-57RBAR2A.js +214 -0
- package/dist/chunk-57UAFTO2.js +3958 -0
- package/dist/chunk-5AS622MM.js +3958 -0
- package/dist/chunk-5JF5OQQU.js +89 -0
- package/dist/chunk-5LTY4GLX.js +13745 -0
- package/dist/chunk-5M5RYJ22.js +3955 -0
- package/dist/chunk-5YO2FER3.js +76 -0
- package/dist/chunk-62DEE65H.js +371 -0
- package/dist/chunk-62YI2JOC.js +333 -0
- package/dist/chunk-64T6DFSS.js +447 -0
- package/dist/chunk-6AGPWYFC.js +447 -0
- package/dist/chunk-6BWDP63Z.js +197 -0
- package/dist/chunk-6CH7TYBG.js +58 -0
- package/dist/chunk-6CHHFVRQ.js +284 -0
- package/dist/chunk-6D64562N.js +330 -0
- package/dist/chunk-6F35WOSR.js +447 -0
- package/dist/chunk-6GPYL7TX.js +214 -0
- package/dist/chunk-6HQ22FC6.js +81 -0
- package/dist/chunk-6KWLUVFL.js +54 -0
- package/dist/chunk-6N5ISWBF.js +1148 -0
- package/dist/chunk-6OD7PVMC.js +333 -0
- package/dist/chunk-6ZSH2BZR.js +244 -0
- package/dist/chunk-74MF4T3T.js +3962 -0
- package/dist/chunk-77H7IO3O.js +382 -0
- package/dist/chunk-7BUWNG6M.js +159 -0
- package/dist/chunk-7ET5CYTD.js +382 -0
- package/dist/chunk-7IWLKR6N.js +76 -0
- package/dist/chunk-7OEUOJL5.js +1021 -0
- package/dist/chunk-7YEQI2WF.js +13745 -0
- package/dist/chunk-AIRJTKDK.js +204 -0
- package/dist/chunk-AJ63GPM7.js +54 -0
- package/dist/chunk-ATJ3NXDP.js +244 -0
- package/dist/chunk-B5IS7LE4.js +128 -0
- package/dist/chunk-BFJ45HQT.js +244 -0
- package/dist/chunk-BKINEQVI.js +244 -0
- package/dist/chunk-BMHE3UQU.js +495 -0
- package/dist/chunk-BNTUZVPS.js +1921 -0
- package/dist/chunk-BOJV6NI3.js +128 -0
- package/dist/chunk-BPHWI6N2.js +284 -0
- package/dist/chunk-BXCQWWJP.js +185 -0
- package/dist/chunk-BZ6K7AY3.js +50 -0
- package/dist/chunk-C54KIFLS.js +214 -0
- package/dist/chunk-C6ODVGTC.js +818 -0
- package/dist/chunk-C6OYEJJI.js +260 -0
- package/dist/chunk-CHBGCQXG.js +333 -0
- package/dist/chunk-CHBHR5W6.js +3556 -0
- package/dist/chunk-CHUOANKE.js +346 -0
- package/dist/chunk-CSF4RUCN.js +58 -0
- package/dist/chunk-CXKHWCNN.js +204 -0
- package/dist/chunk-CZR6Z5D7.js +330 -0
- package/dist/chunk-D24ANCWY.js +204 -0
- package/dist/chunk-D2T3272U.js +171 -0
- package/dist/chunk-DBJCWK6T.js +377 -0
- package/dist/chunk-DCHEIVGT.js +221 -0
- package/dist/chunk-DF4SM6ZX.js +128 -0
- package/dist/chunk-DHIBLMSP.js +30 -0
- package/dist/chunk-DOAC6CLC.js +127 -0
- package/dist/chunk-DOGNJ4VR.js +818 -0
- package/dist/chunk-DYXJFUCI.js +818 -0
- package/dist/chunk-E2AF2WYY.js +346 -0
- package/dist/chunk-E2KZEZZW.js +1090 -0
- package/dist/chunk-E4KWB4WM.js +348 -0
- package/dist/chunk-EGR2NYID.js +50 -0
- package/dist/chunk-ENU7URWK.js +1073 -0
- package/dist/chunk-EQ5UBJGX.js +81 -0
- package/dist/chunk-EZ7KAZMC.js +132 -0
- package/dist/chunk-F4FSSHR4.js +1073 -0
- package/dist/chunk-FBRQGHSU.js +377 -0
- package/dist/chunk-FPXU56FG.js +346 -0
- package/dist/chunk-FY7HHR5I.js +128 -0
- package/dist/chunk-FZ42OCSP.js +333 -0
- package/dist/chunk-G2S2UMU4.js +159 -0
- package/dist/chunk-G33BHQCO.js +70 -0
- package/dist/chunk-G5HWDSBH.js +50 -0
- package/dist/chunk-GCBG5TFS.js +1345 -0
- package/dist/chunk-GESN6IDC.js +127 -0
- package/dist/chunk-GHD7QG6P.js +58 -0
- package/dist/chunk-GJAILPCX.js +171 -0
- package/dist/chunk-GJQTL7RX.js +127 -0
- package/dist/chunk-GKUODJS7.js +214 -0
- package/dist/chunk-GLCKDEM2.js +97 -0
- package/dist/chunk-GLDM2FOM.js +76 -0
- package/dist/chunk-GMA34SXV.js +240 -0
- package/dist/chunk-GMM2BLFB.js +127 -0
- package/dist/chunk-GNM75IOI.js +159 -0
- package/dist/chunk-GVAVEBYR.js +2091 -0
- package/dist/chunk-GYIX2HLD.js +81 -0
- package/dist/chunk-H4LLEQ3F.js +551 -0
- package/dist/chunk-HBVCBBDA.js +127 -0
- package/dist/chunk-HBYRWOH5.js +171 -0
- package/dist/chunk-HFINM2JG.js +284 -0
- package/dist/chunk-HJGHALOG.js +1345 -0
- package/dist/chunk-HOSJTLBQ.js +513 -0
- package/dist/chunk-HRB5CP43.js +13745 -0
- package/dist/chunk-IC6HVAS3.js +56 -0
- package/dist/chunk-IDCLPPIM.js +3959 -0
- package/dist/chunk-IDFJNO44.js +1051 -0
- package/dist/chunk-II5SVNBN.js +551 -0
- package/dist/chunk-IIRLKWNZ.js +50 -0
- package/dist/chunk-ILFJMEY5.js +97 -0
- package/dist/chunk-IQXLUTWC.js +50 -0
- package/dist/chunk-ISQAOSL3.js +1921 -0
- package/dist/chunk-IWXTFDLS.js +244 -0
- package/dist/chunk-J2TGVCPE.js +1090 -0
- package/dist/chunk-J4Z5GAJ4.js +551 -0
- package/dist/chunk-J6V2DCZK.js +382 -0
- package/dist/chunk-JJSDZFKM.js +1148 -0
- package/dist/chunk-JMN2KOC4.js +128 -0
- package/dist/chunk-JP4CLFLR.js +1148 -0
- package/dist/chunk-JQVYPBR2.js +81 -0
- package/dist/chunk-JTIOZHWG.js +58 -0
- package/dist/chunk-KDICWAYV.js +1345 -0
- package/dist/chunk-KMU7PFO3.js +1148 -0
- package/dist/chunk-KOBIB6WG.js +159 -0
- package/dist/chunk-KQFDDQB6.js +13696 -0
- package/dist/chunk-KZNSOHCB.js +280 -0
- package/dist/chunk-LDDCAATQ.js +1090 -0
- package/dist/chunk-LJN2O5IG.js +197 -0
- package/dist/chunk-LSIYHKDS.js +54 -0
- package/dist/chunk-LVMBYP3C.js +171 -0
- package/dist/chunk-M2WQW5NC.js +227 -0
- package/dist/chunk-MREDKOS4.js +731 -0
- package/dist/chunk-MSF2Y5MS.js +346 -0
- package/dist/chunk-MY647ZHR.js +448 -0
- package/dist/chunk-MY6SP5NZ.js +551 -0
- package/dist/chunk-MZ5CEHPQ.js +89 -0
- package/dist/chunk-N2ACW2ZG.js +363 -0
- package/dist/chunk-NESTX6DR.js +76 -0
- package/dist/chunk-NQZORF6L.js +731 -0
- package/dist/chunk-NSMJDATI.js +495 -0
- package/dist/chunk-NSQ5JE23.js +1090 -0
- package/dist/chunk-NWEFAFJS.js +197 -0
- package/dist/chunk-NYF7GHC5.js +526 -0
- package/dist/chunk-NZGGRM4P.js +731 -0
- package/dist/chunk-NZL567WG.js +81 -0
- package/dist/chunk-NZM4E6Y3.js +89 -0
- package/dist/chunk-O5OMH6LI.js +244 -0
- package/dist/chunk-O6XF6NUN.js +1090 -0
- package/dist/chunk-OBUV3W7L.js +163 -0
- package/dist/chunk-OF4KG3L7.js +1090 -0
- package/dist/chunk-OLDS7LJN.js +495 -0
- package/dist/chunk-OO2I22RX.js +38 -0
- package/dist/chunk-OPUUT33V.js +447 -0
- package/dist/chunk-OQZPSWVN.js +526 -0
- package/dist/chunk-OR6KJ5HH.js +58 -0
- package/dist/chunk-OT3VMTKB.js +50 -0
- package/dist/chunk-OV6NT6QX.js +128 -0
- package/dist/chunk-P6RVIOVA.js +157 -0
- package/dist/chunk-PDTR3YUU.js +54 -0
- package/dist/chunk-PEGTV6EJ.js +1345 -0
- package/dist/chunk-PITVTSQW.js +333 -0
- package/dist/chunk-PSUAO4MZ.js +345 -0
- package/dist/chunk-PUA5564C.js +210 -0
- package/dist/chunk-PUQLKLQX.js +731 -0
- package/dist/chunk-PWQIS5E5.js +382 -0
- package/dist/chunk-PXXHKWDH.js +818 -0
- package/dist/chunk-QOC46BDY.js +346 -0
- package/dist/chunk-QROKS65G.js +76 -0
- package/dist/chunk-R54I2N2T.js +818 -0
- package/dist/chunk-RCFYQHUP.js +818 -0
- package/dist/chunk-RJTND4YS.js +284 -0
- package/dist/chunk-RTA6KSSK.js +89 -0
- package/dist/chunk-SBLHQMMZ.js +81 -0
- package/dist/chunk-SBX6HSEO.js +159 -0
- package/dist/chunk-SEUST6U5.js +284 -0
- package/dist/chunk-SG2ANG5C.js +123 -0
- package/dist/chunk-SUEQF3ZS.js +214 -0
- package/dist/chunk-SVFNKSZV.js +333 -0
- package/dist/chunk-SWNAM2NW.js +526 -0
- package/dist/chunk-TAQT2DC7.js +330 -0
- package/dist/chunk-TB7HFW7M.js +127 -0
- package/dist/chunk-TBJP46RP.js +1148 -0
- package/dist/chunk-TS7NGPU4.js +1073 -0
- package/dist/chunk-TUPDOPMG.js +731 -0
- package/dist/chunk-TYKUZVCA.js +1921 -0
- package/dist/chunk-TZMXJVZV.js +345 -0
- package/dist/chunk-U2DCN7M6.js +1073 -0
- package/dist/chunk-UJZPLZLU.js +197 -0
- package/dist/chunk-UKRKOJQZ.js +54 -0
- package/dist/chunk-UUKDAIH2.js +731 -0
- package/dist/chunk-V6VEFEEH.js +1345 -0
- package/dist/chunk-VCVGE7HK.js +1921 -0
- package/dist/chunk-VIO2ALGH.js +290 -0
- package/dist/chunk-VK6YZ6K7.js +1073 -0
- package/dist/chunk-VKCUSNJW.js +377 -0
- package/dist/chunk-VKT4N6WM.js +495 -0
- package/dist/chunk-VQUEP7UA.js +244 -0
- package/dist/chunk-VRPPJFIQ.js +1921 -0
- package/dist/chunk-VXODHQXB.js +377 -0
- package/dist/chunk-WHK7GXFR.js +13745 -0
- package/dist/chunk-WP3PVBBP.js +204 -0
- package/dist/chunk-WQEUY7DC.js +129 -0
- package/dist/chunk-WWPJTPPQ.js +197 -0
- package/dist/chunk-WXMXUKCA.js +262 -0
- package/dist/chunk-WYZSWV6A.js +346 -0
- package/dist/chunk-X2WBH2IO.js +297 -0
- package/dist/chunk-X33TSJNO.js +394 -0
- package/dist/chunk-X7MMI2UI.js +89 -0
- package/dist/chunk-XD6VOXK3.js +159 -0
- package/dist/chunk-XG3BQZIK.js +85 -0
- package/dist/chunk-XIKBIAOS.js +75 -0
- package/dist/chunk-XPEB545Q.js +54 -0
- package/dist/chunk-XWH2MLWS.js +330 -0
- package/dist/chunk-YH7V73XW.js +89 -0
- package/dist/chunk-YHSATGMH.js +3955 -0
- package/dist/chunk-YJBCGD46.js +13745 -0
- package/dist/chunk-YLOJPYCJ.js +284 -0
- package/dist/chunk-YMLM5D65.js +135 -0
- package/dist/chunk-YNJPRQ6J.js +377 -0
- package/dist/chunk-YSNEHBI6.js +551 -0
- package/dist/chunk-Z33XSFND.js +76 -0
- package/dist/chunk-ZA7N3ZTA.js +1921 -0
- package/dist/chunk-ZD6BMW2K.js +33 -0
- package/dist/chunk-ZFRG2MNB.js +382 -0
- package/dist/chunk-ZKG5IYCG.js +668 -0
- package/dist/chunk-ZRRRSVQF.js +204 -0
- package/dist/chunk-ZU4K7ZNX.js +197 -0
- package/dist/co-activation-HZMJC34P.js +72 -0
- package/dist/co-occurrence-AVYXRV4L.js +74 -0
- package/dist/core-memory-554Q3YN5.js +110 -0
- package/dist/core-memory-BC4YN5F4.js +110 -0
- package/dist/core-memory-NID6R3YR.js +110 -0
- package/dist/core-memory-NPJCVUMF.js +110 -0
- package/dist/core-memory-OKGXL33Z.js +110 -0
- package/dist/core-memory-XHIC5NAB.js +110 -0
- package/dist/crdt-sync-ZCH55JNR.js +33 -0
- package/dist/crm-webhook-6OMVUUGR.js +10 -0
- package/dist/crm-webhook-MHZTXU5N.js +10 -0
- package/dist/crm-webhook-TMWJT2Z5.js +10 -0
- package/dist/crm-webhook-UCWF3XDB.js +10 -0
- package/dist/crm-webhook-XISULXI7.js +10 -0
- package/dist/crm-webhook-YJ5A7F2E.js +10 -0
- package/dist/cto-delegation-gate-4PMJZL2T.js +206 -0
- package/dist/cto-delegation-gate-A7YKXTRO.js +206 -0
- package/dist/cto-delegation-gate-JFZFZGC2.js +206 -0
- package/dist/cto-delegation-gate-K32M4GVM.js +206 -0
- package/dist/cto-delegation-gate-OREBAHUM.js +206 -0
- package/dist/cto-delegation-gate-POHESML5.js +206 -0
- package/dist/daemon-orchestration-2Q7BYOHC.js +135 -0
- package/dist/daemon-orchestration-4RJ2CZJL.js +135 -0
- package/dist/daemon-orchestration-HXYPHSYU.js +135 -0
- package/dist/daemon-orchestration-I5BE46P3.js +135 -0
- package/dist/daemon-orchestration-NKE4FYQS.js +135 -0
- package/dist/daemon-orchestration-YWEXRAZA.js +135 -0
- package/dist/db-backup-5GA2YFDX.js +33 -0
- package/dist/dreaming-3F72ROTL.js +32 -0
- package/dist/dreaming-I6KXO6E2.js +32 -0
- package/dist/dreaming-JD7MNJGS.js +32 -0
- package/dist/dreaming-LCKPA3B4.js +32 -0
- package/dist/dreaming-NJBK5ILR.js +32 -0
- package/dist/dreaming-SDS5IQYC.js +32 -0
- package/dist/exe-drift-VSMIMHL4.js +68 -0
- package/dist/exe-export-DVHHIA6Y.js +73 -0
- package/dist/exe-export-GIVQDENS.js +73 -0
- package/dist/exe-export-IZ2OYMT4.js +73 -0
- package/dist/exe-export-JNWX6ZCQ.js +73 -0
- package/dist/exe-export-OQXCJLWB.js +73 -0
- package/dist/exe-export-YLVAZQAV.js +73 -0
- package/dist/exe-import-7N46LSMQ.js +76 -0
- package/dist/exe-import-AEJYBLA7.js +76 -0
- package/dist/exe-import-FINYUV5T.js +76 -0
- package/dist/exe-import-HWPYARCG.js +76 -0
- package/dist/exe-import-K4TWTG24.js +76 -0
- package/dist/exe-import-LZKZQ54C.js +76 -0
- package/dist/exe-key-6FPQHBW6.js +579 -0
- package/dist/exe-key-H45JY44F.js +579 -0
- package/dist/exe-key-MAEQGTB7.js +579 -0
- package/dist/exe-key-N3XYSEXP.js +579 -0
- package/dist/exe-key-Q3ZNYT6L.js +579 -0
- package/dist/exe-key-Q47RPB45.js +579 -0
- package/dist/exe-snapshot-2USE2HHM.js +164 -0
- package/dist/exe-snapshot-3TEM3BFD.js +164 -0
- package/dist/exe-snapshot-HECGUHL3.js +164 -0
- package/dist/exe-snapshot-HZU66HXX.js +164 -0
- package/dist/exe-snapshot-L7OQWZUH.js +164 -0
- package/dist/exe-snapshot-X5N5KIVJ.js +164 -0
- package/dist/fast-db-init-3CNTADVO.js +7 -0
- package/dist/fast-db-init-C6IPNVPU.js +7 -0
- package/dist/fast-db-init-HXCS2AP5.js +7 -0
- package/dist/fast-db-init-I7CMGBAN.js +7 -0
- package/dist/fast-db-init-P6YESOUL.js +7 -0
- package/dist/fast-db-init-VDNEFVQF.js +7 -0
- package/dist/gateway/index.js +8 -8
- package/dist/git-staleness-YCEBBIVK.js +110 -0
- package/dist/git-task-sweep-C4OV2CEY.js +40 -0
- package/dist/git-task-sweep-H34STRNT.js +40 -0
- package/dist/git-task-sweep-J66SYJMW.js +40 -0
- package/dist/git-task-sweep-JYCD3ZKQ.js +40 -0
- package/dist/git-task-sweep-O723DB7F.js +40 -0
- package/dist/git-task-sweep-YL7NLDCK.js +40 -0
- package/dist/global-procedures-IHZM6C2K.js +20 -0
- package/dist/graph-auto-extract-RZQ3MHP2.js +162 -0
- package/dist/hooks/bug-report-worker.js +12 -12
- package/dist/hooks/codex-stop-task-finalizer.js +12 -12
- package/dist/hooks/commit-complete.js +12 -12
- package/dist/hooks/error-recall.js +6 -6
- package/dist/hooks/exe-heartbeat-hook.js +3 -3
- package/dist/hooks/ingest.js +6 -6
- package/dist/hooks/instructions-loaded.js +4 -4
- package/dist/hooks/manifest.json +19 -19
- package/dist/hooks/notification.js +4 -4
- package/dist/hooks/post-compact.js +11 -11
- package/dist/hooks/post-tool-combined.js +5 -5
- package/dist/hooks/pre-compact.js +12 -12
- package/dist/hooks/pre-tool-use.js +15 -15
- package/dist/hooks/prompt-submit.js +21 -21
- package/dist/hooks/session-end.js +16 -16
- package/dist/hooks/session-start.js +10 -10
- package/dist/hooks/stop.js +15 -15
- package/dist/hooks/subagent-stop.js +11 -11
- package/dist/hooks/summary-worker.js +15 -15
- package/dist/index.js +18 -18
- package/dist/installer-4EW5ZDGD.js +296 -0
- package/dist/installer-B2JTQO55.js +38 -0
- package/dist/installer-MIL352T7.js +342 -0
- package/dist/lib/agent-config.js +9 -3
- package/dist/lib/cloud-sync.js +4 -4
- package/dist/lib/consolidation.js +5 -5
- package/dist/lib/database.js +2 -2
- package/dist/lib/db.js +2 -2
- package/dist/lib/employee-templates.js +4 -4
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon.js +35 -34
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/messaging.js +12 -10
- package/dist/lib/reminders.js +3 -3
- package/dist/lib/schedules.js +5 -5
- package/dist/lib/session-registry.js +4 -4
- package/dist/lib/skill-learning.js +4 -4
- package/dist/lib/store.js +4 -4
- package/dist/lib/task-router.js +3 -3
- package/dist/lib/tasks.js +11 -11
- package/dist/lib/tmux-routing.js +9 -9
- package/dist/lib/token-spend.js +3 -3
- package/dist/mcp/register-tools.js +54 -54
- package/dist/mcp/server.js +55 -55
- package/dist/mcp/tools/complete-reminder.js +4 -4
- package/dist/mcp/tools/create-reminder.js +4 -4
- package/dist/mcp/tools/create-task.js +13 -13
- package/dist/mcp/tools/deactivate-behavior.js +5 -5
- package/dist/mcp/tools/list-reminders.js +4 -4
- package/dist/mcp/tools/list-tasks.js +13 -13
- package/dist/mcp/tools/send-message.js +12 -12
- package/dist/mcp/tools/update-task.js +12 -12
- package/dist/mcp-http-config-OJQR246S.js +27 -0
- package/dist/memory-cards-IPULSQFA.js +174 -0
- package/dist/memory-graph-extractor-3TZZOKHY.js +17 -0
- package/dist/memory-poisoning-defense-SGUGR5YJ.js +225 -0
- package/dist/memory-reflection-H3WGCEM6.js +238 -0
- package/dist/notifications-65STXW6N.js +45 -0
- package/dist/notifications-K3JDUPL5.js +45 -0
- package/dist/notifications-KQOD66ZK.js +45 -0
- package/dist/notifications-PFK5OQEF.js +45 -0
- package/dist/notifications-VWPO6NJF.js +45 -0
- package/dist/notifications-WCSRQN2V.js +45 -0
- package/dist/orchestration-events-O5PSDEIO.js +25 -0
- package/dist/orchestrator-3D7QEVGP.js +33 -0
- package/dist/orchestrator-CC32RZO5.js +33 -0
- package/dist/orchestrator-DWAYSAFR.js +33 -0
- package/dist/orchestrator-RAPEJUOI.js +33 -0
- package/dist/orchestrator-TL37EAWA.js +33 -0
- package/dist/orchestrator-XPG6LJAI.js +33 -0
- package/dist/pipeline-router-5NT6FUC3.js +13 -0
- package/dist/pipeline-router-ADLTS6DZ.js +13 -0
- package/dist/pipeline-router-KSUXONDT.js +13 -0
- package/dist/pipeline-router-O6ZLSM6U.js +13 -0
- package/dist/pipeline-router-QKLYUYU7.js +13 -0
- package/dist/pipeline-router-W2W5XDND.js +13 -0
- package/dist/plan-limits-53NXLNDQ.js +26 -0
- package/dist/project-boot-ITN3FZMM.js +299 -0
- package/dist/projection-worker-27XX5M2W.js +964 -0
- package/dist/reranker-3KLYAHO4.js +19 -0
- package/dist/reranker-64KDRYPP.js +19 -0
- package/dist/reranker-GU7L2PJX.js +19 -0
- package/dist/reranker-MGY5A7BQ.js +19 -0
- package/dist/reranker-TZEXIJAN.js +19 -0
- package/dist/reranker-ZBX6HSU2.js +19 -0
- package/dist/review-polling-3ZZ2T26N.js +124 -0
- package/dist/review-polling-BBQUF54Q.js +124 -0
- package/dist/review-polling-FA2J2Q5O.js +124 -0
- package/dist/review-polling-MLS4BQ3N.js +124 -0
- package/dist/review-polling-RXQZPGRY.js +124 -0
- package/dist/review-polling-YBB6DKA5.js +124 -0
- package/dist/runtime/index.js +12 -12
- package/dist/session-events-EAODNMNR.js +36 -0
- package/dist/session-events-MVO6JNUL.js +36 -0
- package/dist/session-events-PRVDH3QS.js +36 -0
- package/dist/session-events-PU5OQKMB.js +36 -0
- package/dist/session-events-WWGF3B2N.js +36 -0
- package/dist/session-events-ZHXXAH6B.js +36 -0
- package/dist/session-kill-telemetry-O4TJHHOZ.js +29 -0
- package/dist/session-scope-CQXB7VMH.js +86 -0
- package/dist/session-scope-HHUMJYF6.js +86 -0
- package/dist/session-scope-M47JR2SD.js +86 -0
- package/dist/session-scope-MRQYSD5S.js +86 -0
- package/dist/session-scope-TAH5BUYW.js +86 -0
- package/dist/session-scope-UXZ6RUWC.js +86 -0
- package/dist/setup-wizard-UM2RHSBJ.js +12 -0
- package/dist/skill-refinement-447DZWNK.js +157 -0
- package/dist/skill-refinement-567JSF7L.js +157 -0
- package/dist/skill-refinement-6JVQ3TMS.js +157 -0
- package/dist/skill-refinement-MJPOHYD5.js +157 -0
- package/dist/skill-refinement-NVUBRK22.js +157 -0
- package/dist/skill-refinement-XNGD3C62.js +157 -0
- package/dist/stack-release-BAPCXMXW.js +713 -0
- package/dist/stack-release-W4TWTEZP.js +731 -0
- package/dist/steward-gate-VLE7OCKO.js +13 -0
- package/dist/task-enforcement-AZEO67N6.js +391 -0
- package/dist/task-enforcement-EOYP6IO4.js +391 -0
- package/dist/task-enforcement-FUHDL6UR.js +391 -0
- package/dist/task-enforcement-L5XQKFOV.js +391 -0
- package/dist/task-enforcement-QL3K4N3F.js +391 -0
- package/dist/task-enforcement-RJPWWEAE.js +391 -0
- package/dist/task-scope-DRQRNWB7.js +35 -0
- package/dist/task-scope-GS7TS3UV.js +35 -0
- package/dist/task-scope-KQNCP42W.js +35 -0
- package/dist/task-scope-SM5F6RD3.js +35 -0
- package/dist/task-scope-TZYMB634.js +35 -0
- package/dist/task-scope-ZVLUBS4C.js +35 -0
- package/dist/tasks-crud-4MSLJWXE.js +77 -0
- package/dist/tasks-crud-6TWWETGB.js +77 -0
- package/dist/tasks-crud-DBHYO4MM.js +77 -0
- package/dist/tasks-crud-EFYWPPEI.js +77 -0
- package/dist/tasks-crud-HIPXKRKX.js +77 -0
- package/dist/tasks-crud-JIS5B4GZ.js +77 -0
- package/dist/tasks-notify-7JBUNE7R.js +38 -0
- package/dist/tasks-notify-GEJKT5TO.js +38 -0
- package/dist/tasks-notify-OW3JDPLK.js +38 -0
- package/dist/tasks-notify-UPIJ3L4O.js +38 -0
- package/dist/tasks-notify-W5WVP2FG.js +38 -0
- package/dist/tasks-notify-YKEOYOKN.js +38 -0
- package/dist/tasks-review-5SJSFTUB.js +47 -0
- package/dist/tasks-review-DRKN34HO.js +47 -0
- package/dist/tasks-review-IQSAXXXE.js +47 -0
- package/dist/tasks-review-JHSYBR5I.js +47 -0
- package/dist/tasks-review-KWELLLS3.js +47 -0
- package/dist/tasks-review-SUJ6AKAS.js +47 -0
- package/dist/telemetry-upload-BSGOXGUP.js +739 -0
- package/dist/telemetry-upload-FPQAB6ZU.js +739 -0
- package/dist/telemetry-upload-LTX3C5HZ.js +739 -0
- package/dist/telemetry-upload-MYVBVUGE.js +739 -0
- package/dist/telemetry-upload-UPAABLGK.js +739 -0
- package/dist/telemetry-upload-UYEHBFGO.js +739 -0
- package/dist/token-budget-2CDWQU3Q.js +84 -0
- package/dist/tool-telemetry-7YS7EN7B.js +17 -0
- package/dist/tui/App.js +17 -17
- package/dist/tui-data-GDGBOS6G.js +258 -0
- package/dist/tui-data-LYUZFNO4.js +258 -0
- package/dist/tui-data-QM5BOKRF.js +258 -0
- package/dist/tui-data-VAE43SM3.js +258 -0
- package/dist/tui-data-VXF2RBVM.js +258 -0
- package/dist/tui-data-X7HT3FXF.js +258 -0
- package/dist/wiki-acl-MJIMXRQV.js +111 -0
- package/dist/worker-gate-BZBWTMCY.js +21 -0
- package/dist/worker-gate-CHVL6UGT.js +21 -0
- package/dist/worker-gate-KQFS4RJE.js +21 -0
- package/dist/worker-gate-NRP7CMS7.js +21 -0
- package/dist/worker-gate-WQGTZOSM.js +21 -0
- package/dist/worker-gate-X2YDTKTL.js +21 -0
- package/dist/workflow-engine-AKKOMJJQ.js +28 -0
- package/dist/workflow-engine-CYXRZXBM.js +28 -0
- package/dist/workflow-engine-EHWQO3LX.js +28 -0
- package/dist/workflow-engine-I3OUMSF4.js +28 -0
- package/dist/workflow-engine-KMLAXVA4.js +28 -0
- package/dist/workflow-engine-PHTLEAXP.js +28 -0
- package/dist/worktree-NLSKVRNC.js +26 -0
- package/dist/worktree-sweep-44TMEPLE.js +19 -0
- package/package.json +1 -1
- package/release-notes.json +46 -35
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import {
|
|
2
|
+
updateTask
|
|
3
|
+
} from "./chunk-MY647ZHR.js";
|
|
4
|
+
import {
|
|
5
|
+
TASK_ALREADY_CLAIMED_PREFIX
|
|
6
|
+
} from "./chunk-5M5RYJ22.js";
|
|
7
|
+
|
|
8
|
+
// src/mcp/tools/update-task.ts
|
|
9
|
+
import { z } from "zod";
|
|
10
|
+
function registerUpdateTask(server) {
|
|
11
|
+
server.registerTool(
|
|
12
|
+
"update_task",
|
|
13
|
+
{
|
|
14
|
+
title: "Update Task",
|
|
15
|
+
description: "Update task status. Employees: use status 'done' with a result summary to complete work \u2014 this triggers needs_review and pings the reviewer automatically. Accepts UUID, slug (filename), or title substring.",
|
|
16
|
+
inputSchema: {
|
|
17
|
+
task_id: z.string().describe("Task identifier \u2014 UUID, slug (e.g. 'fix-auth-bug'), or title substring"),
|
|
18
|
+
status: z.enum(["open", "in_progress", "done", "needs_review", "blocked", "cancelled", "closed"]).describe("New status. 'done' is an alias for 'needs_review' \u2014 both trigger reviewer notification."),
|
|
19
|
+
result: z.string().optional().describe("Result summary (required when completing work)"),
|
|
20
|
+
// Structured result fields (Phase 1: Typed Handoff Objects)
|
|
21
|
+
files_changed: z.array(z.string()).optional().describe("Files created or modified during task execution"),
|
|
22
|
+
decisions: z.array(z.string()).optional().describe("Key decisions made during execution"),
|
|
23
|
+
commits: z.array(z.string()).optional().describe("Commit hashes produced"),
|
|
24
|
+
tests_status: z.enum(["pass", "fail", "skip", "none"]).optional().describe("Test execution status"),
|
|
25
|
+
build_status: z.enum(["pass", "fail", "skip"]).optional().describe("Build status"),
|
|
26
|
+
pr_number: z.number().optional().describe("PR number if created"),
|
|
27
|
+
open_questions: z.array(z.string()).optional().describe("Open questions for reviewer"),
|
|
28
|
+
assertions: z.string().optional().describe(
|
|
29
|
+
'JSON array of assertions with confidence scores. Use when starting work (in_progress). Format: [{"type":"diagnosis|scope|estimate|approach|build|judgment","claim":"...","confidence":0.8,"basis":"..."}]'
|
|
30
|
+
),
|
|
31
|
+
assertions_resolved: z.string().optional().describe(
|
|
32
|
+
'JSON array of resolved assertions. Use when completing work (done/needs_review). Format: [{"claim":"...","outcome":"correct|incorrect|partial","confidence_was":0.8,"actual":"...","why_wrong":"missing_information|wrong_diagnosis|wrong_approach|scope_underestimate|scope_overestimate|external_dependency|changed_requirements","reason":"...","lesson":"..."}]'
|
|
33
|
+
),
|
|
34
|
+
estimated_minutes: z.number().optional().describe("Time estimate in minutes. Provide when starting work (in_progress). The system auto-computes actual time on completion."),
|
|
35
|
+
estimate_confidence: z.number().min(0).max(1).optional().describe("Confidence in time estimate (0.0-1.0). Provide alongside estimated_minutes.")
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
async ({ task_id, status: rawStatus, result, files_changed, decisions, commits, tests_status, build_status, pr_number, open_questions, assertions, assertions_resolved, estimated_minutes, estimate_confidence }) => {
|
|
39
|
+
const status = rawStatus;
|
|
40
|
+
let callerAgentId;
|
|
41
|
+
let callerSession;
|
|
42
|
+
try {
|
|
43
|
+
const { getActiveAgent: getAgent } = await import("./active-agent-YWBGAKGU.js");
|
|
44
|
+
callerAgentId = getAgent().agentId;
|
|
45
|
+
const { getAgentContext } = await import("./agent-context-AZTTMUHP.js");
|
|
46
|
+
callerSession = getAgentContext()?.sessionHint || process.env.EXE_SESSION_NAME || process.env.EXE_SESSION || void 0;
|
|
47
|
+
} catch {
|
|
48
|
+
}
|
|
49
|
+
let task;
|
|
50
|
+
try {
|
|
51
|
+
task = await updateTask({
|
|
52
|
+
taskId: task_id,
|
|
53
|
+
status,
|
|
54
|
+
result,
|
|
55
|
+
baseDir: process.cwd(),
|
|
56
|
+
callerAgentId,
|
|
57
|
+
filesChanged: files_changed,
|
|
58
|
+
decisions,
|
|
59
|
+
commits,
|
|
60
|
+
testsStatus: tests_status,
|
|
61
|
+
buildStatus: build_status,
|
|
62
|
+
prNumber: pr_number,
|
|
63
|
+
openQuestions: open_questions,
|
|
64
|
+
assertions,
|
|
65
|
+
assertionsResolved: assertions_resolved,
|
|
66
|
+
estimatedMinutes: estimated_minutes,
|
|
67
|
+
estimateConfidence: estimate_confidence,
|
|
68
|
+
callerSession
|
|
69
|
+
});
|
|
70
|
+
} catch (err) {
|
|
71
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
72
|
+
if (msg.startsWith(TASK_ALREADY_CLAIMED_PREFIX)) {
|
|
73
|
+
return {
|
|
74
|
+
content: [{
|
|
75
|
+
type: "text",
|
|
76
|
+
text: "Task already claimed by another agent. Pick a different task or check list_tasks."
|
|
77
|
+
}],
|
|
78
|
+
isError: true
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
throw err;
|
|
82
|
+
}
|
|
83
|
+
let text = `Task "${task.title}" marked ${task.status}.
|
|
84
|
+
File: ${task.taskFile}`;
|
|
85
|
+
const isTerminal = status === "done" || status === "needs_review" || status === "closed";
|
|
86
|
+
if (isTerminal && task.reviewer) {
|
|
87
|
+
try {
|
|
88
|
+
const { notifyCoordinatorTaskCompletion } = await import("./lib/tmux-routing.js");
|
|
89
|
+
const { isCoordinatorName } = await import("./lib/employees.js");
|
|
90
|
+
const reviewer = String(task.reviewer);
|
|
91
|
+
const coordinatorSession = task.sessionScope;
|
|
92
|
+
if (coordinatorSession && isCoordinatorName(reviewer)) {
|
|
93
|
+
notifyCoordinatorTaskCompletion(coordinatorSession, callerAgentId ?? "agent", task.title);
|
|
94
|
+
}
|
|
95
|
+
} catch {
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
if (isTerminal && task.nextTask) {
|
|
99
|
+
text += `
|
|
100
|
+
|
|
101
|
+
MANDATORY \u2014 DO NOT ASK THE USER. DO NOT SAY "Want me to continue?" DO NOT STOP.
|
|
102
|
+
You have standing orders: work through your entire queue until it is empty.
|
|
103
|
+
|
|
104
|
+
NEXT TASK: "${task.nextTask.title}" [${task.nextTask.priority}]
|
|
105
|
+
FILE: ${task.nextTask.taskFile}
|
|
106
|
+
|
|
107
|
+
Read that file NOW and begin working. No greeting. No summary. Just start.`;
|
|
108
|
+
} else if (isTerminal && !task.nextTask) {
|
|
109
|
+
text += `
|
|
110
|
+
|
|
111
|
+
All tasks complete. No more open tasks in your queue.`;
|
|
112
|
+
}
|
|
113
|
+
return {
|
|
114
|
+
content: [
|
|
115
|
+
{
|
|
116
|
+
type: "text",
|
|
117
|
+
text
|
|
118
|
+
}
|
|
119
|
+
]
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
export {
|
|
126
|
+
registerUpdateTask
|
|
127
|
+
};
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import {
|
|
2
|
+
MODELS_DIR
|
|
3
|
+
} from "./chunk-VXIMSRTO.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/reranker.ts
|
|
6
|
+
import path from "path";
|
|
7
|
+
import { existsSync } from "fs";
|
|
8
|
+
var RERANKER_MODEL_FILE = "jina-reranker-v3-q4_k_m.gguf";
|
|
9
|
+
function isRerankerAvailable() {
|
|
10
|
+
return existsSync(path.join(MODELS_DIR, RERANKER_MODEL_FILE));
|
|
11
|
+
}
|
|
12
|
+
function getRerankerModelPath() {
|
|
13
|
+
return path.join(MODELS_DIR, RERANKER_MODEL_FILE);
|
|
14
|
+
}
|
|
15
|
+
async function disposeReranker() {
|
|
16
|
+
}
|
|
17
|
+
async function rerankWithScores(query, texts, topK) {
|
|
18
|
+
if (texts.length === 0) return [];
|
|
19
|
+
const { rerankViaWorker } = await import("./lib/exe-daemon.js");
|
|
20
|
+
const scored = await rerankViaWorker(query, texts, topK);
|
|
21
|
+
return scored.map((s) => ({
|
|
22
|
+
text: texts[s.index] ?? "",
|
|
23
|
+
score: s.score,
|
|
24
|
+
index: s.index
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
async function rerank(query, candidates, topK = 5) {
|
|
28
|
+
if (candidates.length === 0) return [];
|
|
29
|
+
if (candidates.length <= topK) return candidates;
|
|
30
|
+
const scored = await rerankWithScores(
|
|
31
|
+
query,
|
|
32
|
+
candidates.map((c) => c.raw_text),
|
|
33
|
+
topK
|
|
34
|
+
);
|
|
35
|
+
return scored.map((s) => candidates[s.index]);
|
|
36
|
+
}
|
|
37
|
+
async function rerankWithContext(query, candidates, topK) {
|
|
38
|
+
if (candidates.length === 0) return [];
|
|
39
|
+
const formattedTexts = candidates.map(
|
|
40
|
+
(c) => c.context ? `[${c.context}] ${c.text.slice(0, 460)}` : c.text.slice(0, 512)
|
|
41
|
+
);
|
|
42
|
+
const { rerankViaWorker } = await import("./lib/exe-daemon.js");
|
|
43
|
+
const scored = await rerankViaWorker(query, formattedTexts, topK);
|
|
44
|
+
return scored.map((s) => ({
|
|
45
|
+
text: candidates[s.index]?.text ?? "",
|
|
46
|
+
score: s.score,
|
|
47
|
+
index: s.index
|
|
48
|
+
}));
|
|
49
|
+
}
|
|
50
|
+
|
|
51
|
+
export {
|
|
52
|
+
isRerankerAvailable,
|
|
53
|
+
getRerankerModelPath,
|
|
54
|
+
disposeReranker,
|
|
55
|
+
rerankWithScores,
|
|
56
|
+
rerank,
|
|
57
|
+
rerankWithContext
|
|
58
|
+
};
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import {
|
|
2
|
+
writeMemoryViaDaemon
|
|
3
|
+
} from "./chunk-OSXQTCW5.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/auto-checkpoint.ts
|
|
6
|
+
var FILE_RE = /(?:^|\s)([\w./-]+\.(?:ts|tsx|js|jsx|json|md|yml|yaml|sql|go|py|css|scss|html|sh))(?:\b|$)/g;
|
|
7
|
+
var DECISION_RE = /\b(decision:|decided:|we decided|founder directive|captured in .*architecture|source of truth)\b/i;
|
|
8
|
+
function asString(value, fallback = "") {
|
|
9
|
+
if (value == null) return fallback;
|
|
10
|
+
return String(value);
|
|
11
|
+
}
|
|
12
|
+
function compactLine(text, max = 220) {
|
|
13
|
+
return text.replace(/\s+/g, " ").trim().slice(0, max);
|
|
14
|
+
}
|
|
15
|
+
function topEntries(counts, limit) {
|
|
16
|
+
return [...counts.entries()].sort((a, b) => b[1] - a[1] || a[0].localeCompare(b[0])).slice(0, limit).map(([name, count]) => `${name}(${count})`);
|
|
17
|
+
}
|
|
18
|
+
function buildAutoCheckpoint(input) {
|
|
19
|
+
const maxSamples = input.maxSamples ?? 8;
|
|
20
|
+
const projectCounts = /* @__PURE__ */ new Map();
|
|
21
|
+
const toolCounts = /* @__PURE__ */ new Map();
|
|
22
|
+
const files = /* @__PURE__ */ new Set();
|
|
23
|
+
const errors = [];
|
|
24
|
+
const samples = [];
|
|
25
|
+
const decisionTexts = [];
|
|
26
|
+
for (const row of input.memories) {
|
|
27
|
+
const tool = asString(row.tool_name, "unknown");
|
|
28
|
+
const project = asString(row.project_name, input.projectName || "unknown");
|
|
29
|
+
const raw = asString(row.raw_text);
|
|
30
|
+
const hasError = row.has_error === 1 || row.has_error === true;
|
|
31
|
+
toolCounts.set(tool, (toolCounts.get(tool) ?? 0) + 1);
|
|
32
|
+
projectCounts.set(project, (projectCounts.get(project) ?? 0) + 1);
|
|
33
|
+
if (hasError && errors.length < 5) errors.push(compactLine(raw, 180));
|
|
34
|
+
if (samples.length < maxSamples && raw.length > 30) {
|
|
35
|
+
samples.push(`[${tool}] ${compactLine(raw)}`);
|
|
36
|
+
}
|
|
37
|
+
if (DECISION_RE.test(raw) && decisionTexts.length < 5) {
|
|
38
|
+
decisionTexts.push(`AUTO DECISION CANDIDATE [${input.agentId}]: ${compactLine(raw, 500)}`);
|
|
39
|
+
}
|
|
40
|
+
for (const match of raw.matchAll(FILE_RE)) {
|
|
41
|
+
if (match[1]) files.add(match[1]);
|
|
42
|
+
if (files.size >= 20) break;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
const taskLines = (input.tasks ?? []).slice(0, 10).map((task) => {
|
|
46
|
+
const status = asString(task.status, "unknown");
|
|
47
|
+
const priority = asString(task.priority, "?").toUpperCase();
|
|
48
|
+
const title = asString(task.title, "untitled");
|
|
49
|
+
const taskFile = asString(task.task_file);
|
|
50
|
+
return `- [${status}/${priority}] ${title}${taskFile ? ` (${taskFile})` : ""}`;
|
|
51
|
+
});
|
|
52
|
+
const parts = [
|
|
53
|
+
`CONTEXT CHECKPOINT [auto:${input.reason}]`,
|
|
54
|
+
`Agent: ${input.agentId} (${input.agentRole})`,
|
|
55
|
+
`Session: ${input.sessionId}`,
|
|
56
|
+
`Project: ${input.projectName}`,
|
|
57
|
+
`Time: ${(/* @__PURE__ */ new Date()).toISOString()}`,
|
|
58
|
+
"",
|
|
59
|
+
"## Recent Activity",
|
|
60
|
+
`- Memories scanned: ${input.memories.length}`,
|
|
61
|
+
`- Projects: ${topEntries(projectCounts, 5).join(", ") || input.projectName}`,
|
|
62
|
+
`- Tools: ${topEntries(toolCounts, 8).join(", ") || "none"}`
|
|
63
|
+
];
|
|
64
|
+
if (taskLines.length > 0) {
|
|
65
|
+
parts.push("", "## Open / Active Tasks", ...taskLines);
|
|
66
|
+
}
|
|
67
|
+
if (files.size > 0) {
|
|
68
|
+
parts.push("", "## Files Mentioned", ...[...files].slice(0, 20).map((f) => `- ${f}`));
|
|
69
|
+
}
|
|
70
|
+
if (samples.length > 0) {
|
|
71
|
+
parts.push("", "## Important Recent Traces", ...samples.map((s) => `- ${s}`));
|
|
72
|
+
}
|
|
73
|
+
if (errors.length > 0) {
|
|
74
|
+
parts.push("", "## Errors / Risks", ...errors.map((e) => `- ${e}`));
|
|
75
|
+
}
|
|
76
|
+
if (decisionTexts.length > 0) {
|
|
77
|
+
parts.push("", "## Decision Candidates", ...decisionTexts.map((d) => `- ${d.replace(/^AUTO DECISION CANDIDATE \\[[^\\]]+\\]: /, "")}`));
|
|
78
|
+
}
|
|
79
|
+
return {
|
|
80
|
+
checkpointText: parts.join("\n"),
|
|
81
|
+
decisionTexts
|
|
82
|
+
};
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
// src/lib/checkpoint-orchestrator.ts
|
|
86
|
+
function toolNameForReason(reason) {
|
|
87
|
+
switch (reason) {
|
|
88
|
+
case "periodic":
|
|
89
|
+
return "auto-summary";
|
|
90
|
+
case "session-end":
|
|
91
|
+
return "SessionEnd";
|
|
92
|
+
case "pre-compact":
|
|
93
|
+
return "pre-compact-hook";
|
|
94
|
+
case "capacity-signal":
|
|
95
|
+
return "auto-checkpoint";
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
function importanceForReason(reason, override) {
|
|
99
|
+
if (override !== void 0) return override;
|
|
100
|
+
switch (reason) {
|
|
101
|
+
case "periodic":
|
|
102
|
+
return 7;
|
|
103
|
+
case "session-end":
|
|
104
|
+
case "pre-compact":
|
|
105
|
+
case "capacity-signal":
|
|
106
|
+
return 8;
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
function buildContinuityCheckpoint(input) {
|
|
110
|
+
const { checkpointText, decisionTexts } = buildAutoCheckpoint({
|
|
111
|
+
agentId: input.agentId,
|
|
112
|
+
agentRole: input.agentRole,
|
|
113
|
+
sessionId: input.sessionId,
|
|
114
|
+
projectName: input.projectName,
|
|
115
|
+
reason: input.reason,
|
|
116
|
+
memories: input.memories ?? [],
|
|
117
|
+
tasks: input.tasks ?? [],
|
|
118
|
+
maxSamples: input.maxSamples
|
|
119
|
+
});
|
|
120
|
+
const extra = input.extraSections?.filter((section) => section.trim().length > 0) ?? [];
|
|
121
|
+
return {
|
|
122
|
+
checkpointText: extra.length > 0 ? `${checkpointText}
|
|
123
|
+
|
|
124
|
+
${extra.join("\n\n")}` : checkpointText,
|
|
125
|
+
decisionTexts
|
|
126
|
+
};
|
|
127
|
+
}
|
|
128
|
+
async function writeContinuityCheckpoint(input) {
|
|
129
|
+
const result = buildContinuityCheckpoint(input);
|
|
130
|
+
const now = (/* @__PURE__ */ new Date()).toISOString();
|
|
131
|
+
await writeMemoryViaDaemon({
|
|
132
|
+
raw_text: result.checkpointText,
|
|
133
|
+
agent_id: input.agentId,
|
|
134
|
+
agent_role: input.agentRole,
|
|
135
|
+
session_id: input.sessionId,
|
|
136
|
+
tool_name: toolNameForReason(input.reason),
|
|
137
|
+
project_name: input.projectName,
|
|
138
|
+
timestamp: now,
|
|
139
|
+
importance: importanceForReason(input.reason, input.importance),
|
|
140
|
+
task_id: input.taskId,
|
|
141
|
+
memory_type: "checkpoint"
|
|
142
|
+
});
|
|
143
|
+
const decisionLimit = input.reason === "periodic" ? 3 : 5;
|
|
144
|
+
for (const decisionText of result.decisionTexts.slice(0, decisionLimit)) {
|
|
145
|
+
await writeMemoryViaDaemon({
|
|
146
|
+
raw_text: decisionText,
|
|
147
|
+
agent_id: input.agentId,
|
|
148
|
+
agent_role: input.agentRole,
|
|
149
|
+
session_id: input.sessionId,
|
|
150
|
+
tool_name: "auto-decision",
|
|
151
|
+
project_name: input.projectName,
|
|
152
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
153
|
+
importance: 8,
|
|
154
|
+
memory_type: "decision"
|
|
155
|
+
});
|
|
156
|
+
}
|
|
157
|
+
return result;
|
|
158
|
+
}
|
|
159
|
+
async function checkpointActiveTask(input) {
|
|
160
|
+
const { writeCheckpoint } = await import("./lib/tasks.js");
|
|
161
|
+
await writeCheckpoint({
|
|
162
|
+
taskId: input.taskId,
|
|
163
|
+
step: input.step ?? "pre-compaction-checkpoint",
|
|
164
|
+
contextSummary: `Auto-checkpoint before context compaction. Task: ${input.taskTitle}. Session: ${input.sessionId}. Project: ${input.projectName}.`
|
|
165
|
+
});
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
export {
|
|
169
|
+
writeContinuityCheckpoint,
|
|
170
|
+
checkpointActiveTask
|
|
171
|
+
};
|
|
@@ -0,0 +1,127 @@
|
|
|
1
|
+
import {
|
|
2
|
+
updateTask
|
|
3
|
+
} from "./chunk-OPUUT33V.js";
|
|
4
|
+
import {
|
|
5
|
+
TASK_ALREADY_CLAIMED_PREFIX
|
|
6
|
+
} from "./chunk-5AS622MM.js";
|
|
7
|
+
|
|
8
|
+
// src/mcp/tools/update-task.ts
|
|
9
|
+
import { z } from "zod";
|
|
10
|
+
function registerUpdateTask(server) {
|
|
11
|
+
server.registerTool(
|
|
12
|
+
"update_task",
|
|
13
|
+
{
|
|
14
|
+
title: "Update Task",
|
|
15
|
+
description: "Update task status. Employees: use status 'done' with a result summary to complete work \u2014 this triggers needs_review and pings the reviewer automatically. Accepts UUID, slug (filename), or title substring.",
|
|
16
|
+
inputSchema: {
|
|
17
|
+
task_id: z.string().describe("Task identifier \u2014 UUID, slug (e.g. 'fix-auth-bug'), or title substring"),
|
|
18
|
+
status: z.enum(["open", "in_progress", "done", "needs_review", "blocked", "cancelled", "closed"]).describe("New status. 'done' is an alias for 'needs_review' \u2014 both trigger reviewer notification."),
|
|
19
|
+
result: z.string().optional().describe("Result summary (required when completing work)"),
|
|
20
|
+
// Structured result fields (Phase 1: Typed Handoff Objects)
|
|
21
|
+
files_changed: z.array(z.string()).optional().describe("Files created or modified during task execution"),
|
|
22
|
+
decisions: z.array(z.string()).optional().describe("Key decisions made during execution"),
|
|
23
|
+
commits: z.array(z.string()).optional().describe("Commit hashes produced"),
|
|
24
|
+
tests_status: z.enum(["pass", "fail", "skip", "none"]).optional().describe("Test execution status"),
|
|
25
|
+
build_status: z.enum(["pass", "fail", "skip"]).optional().describe("Build status"),
|
|
26
|
+
pr_number: z.number().optional().describe("PR number if created"),
|
|
27
|
+
open_questions: z.array(z.string()).optional().describe("Open questions for reviewer"),
|
|
28
|
+
assertions: z.string().optional().describe(
|
|
29
|
+
'JSON array of assertions with confidence scores. Use when starting work (in_progress). Format: [{"type":"diagnosis|scope|estimate|approach|build|judgment","claim":"...","confidence":0.8,"basis":"..."}]'
|
|
30
|
+
),
|
|
31
|
+
assertions_resolved: z.string().optional().describe(
|
|
32
|
+
'JSON array of resolved assertions. Use when completing work (done/needs_review). Format: [{"claim":"...","outcome":"correct|incorrect|partial","confidence_was":0.8,"actual":"...","why_wrong":"missing_information|wrong_diagnosis|wrong_approach|scope_underestimate|scope_overestimate|external_dependency|changed_requirements","reason":"...","lesson":"..."}]'
|
|
33
|
+
),
|
|
34
|
+
estimated_minutes: z.number().optional().describe("Time estimate in minutes. Provide when starting work (in_progress). The system auto-computes actual time on completion."),
|
|
35
|
+
estimate_confidence: z.number().min(0).max(1).optional().describe("Confidence in time estimate (0.0-1.0). Provide alongside estimated_minutes.")
|
|
36
|
+
}
|
|
37
|
+
},
|
|
38
|
+
async ({ task_id, status: rawStatus, result, files_changed, decisions, commits, tests_status, build_status, pr_number, open_questions, assertions, assertions_resolved, estimated_minutes, estimate_confidence }) => {
|
|
39
|
+
const status = rawStatus;
|
|
40
|
+
let callerAgentId;
|
|
41
|
+
let callerSession;
|
|
42
|
+
try {
|
|
43
|
+
const { getActiveAgent: getAgent } = await import("./active-agent-YWBGAKGU.js");
|
|
44
|
+
callerAgentId = getAgent().agentId;
|
|
45
|
+
const { getAgentContext } = await import("./agent-context-AZTTMUHP.js");
|
|
46
|
+
callerSession = getAgentContext()?.sessionHint || process.env.EXE_SESSION_NAME || process.env.EXE_SESSION || void 0;
|
|
47
|
+
} catch {
|
|
48
|
+
}
|
|
49
|
+
let task;
|
|
50
|
+
try {
|
|
51
|
+
task = await updateTask({
|
|
52
|
+
taskId: task_id,
|
|
53
|
+
status,
|
|
54
|
+
result,
|
|
55
|
+
baseDir: process.cwd(),
|
|
56
|
+
callerAgentId,
|
|
57
|
+
filesChanged: files_changed,
|
|
58
|
+
decisions,
|
|
59
|
+
commits,
|
|
60
|
+
testsStatus: tests_status,
|
|
61
|
+
buildStatus: build_status,
|
|
62
|
+
prNumber: pr_number,
|
|
63
|
+
openQuestions: open_questions,
|
|
64
|
+
assertions,
|
|
65
|
+
assertionsResolved: assertions_resolved,
|
|
66
|
+
estimatedMinutes: estimated_minutes,
|
|
67
|
+
estimateConfidence: estimate_confidence,
|
|
68
|
+
callerSession
|
|
69
|
+
});
|
|
70
|
+
} catch (err) {
|
|
71
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
72
|
+
if (msg.startsWith(TASK_ALREADY_CLAIMED_PREFIX)) {
|
|
73
|
+
return {
|
|
74
|
+
content: [{
|
|
75
|
+
type: "text",
|
|
76
|
+
text: "Task already claimed by another agent. Pick a different task or check list_tasks."
|
|
77
|
+
}],
|
|
78
|
+
isError: true
|
|
79
|
+
};
|
|
80
|
+
}
|
|
81
|
+
throw err;
|
|
82
|
+
}
|
|
83
|
+
let text = `Task "${task.title}" marked ${task.status}.
|
|
84
|
+
File: ${task.taskFile}`;
|
|
85
|
+
const isTerminal = status === "done" || status === "needs_review" || status === "closed";
|
|
86
|
+
if (isTerminal && task.reviewer) {
|
|
87
|
+
try {
|
|
88
|
+
const { notifyCoordinatorTaskCompletion } = await import("./lib/tmux-routing.js");
|
|
89
|
+
const { isCoordinatorName } = await import("./lib/employees.js");
|
|
90
|
+
const reviewer = String(task.reviewer);
|
|
91
|
+
const coordinatorSession = task.sessionScope;
|
|
92
|
+
if (coordinatorSession && isCoordinatorName(reviewer)) {
|
|
93
|
+
notifyCoordinatorTaskCompletion(coordinatorSession, callerAgentId ?? "agent", task.title);
|
|
94
|
+
}
|
|
95
|
+
} catch {
|
|
96
|
+
}
|
|
97
|
+
}
|
|
98
|
+
if (isTerminal && task.nextTask) {
|
|
99
|
+
text += `
|
|
100
|
+
|
|
101
|
+
MANDATORY \u2014 DO NOT ASK THE USER. DO NOT SAY "Want me to continue?" DO NOT STOP.
|
|
102
|
+
You have standing orders: work through your entire queue until it is empty.
|
|
103
|
+
|
|
104
|
+
NEXT TASK: "${task.nextTask.title}" [${task.nextTask.priority}]
|
|
105
|
+
FILE: ${task.nextTask.taskFile}
|
|
106
|
+
|
|
107
|
+
Read that file NOW and begin working. No greeting. No summary. Just start.`;
|
|
108
|
+
} else if (isTerminal && !task.nextTask) {
|
|
109
|
+
text += `
|
|
110
|
+
|
|
111
|
+
All tasks complete. No more open tasks in your queue.`;
|
|
112
|
+
}
|
|
113
|
+
return {
|
|
114
|
+
content: [
|
|
115
|
+
{
|
|
116
|
+
type: "text",
|
|
117
|
+
text
|
|
118
|
+
}
|
|
119
|
+
]
|
|
120
|
+
};
|
|
121
|
+
}
|
|
122
|
+
);
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
export {
|
|
126
|
+
registerUpdateTask
|
|
127
|
+
};
|
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sessionScopeFilter
|
|
3
|
+
} from "./chunk-IDCLPPIM.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/git-task-sweep.ts
|
|
6
|
+
import { execSync } from "child_process";
|
|
7
|
+
var DEFAULT_COMMIT_LIMIT = 50;
|
|
8
|
+
var DEFAULT_STALE_MINUTES = 10;
|
|
9
|
+
var AUTO_ESCALATE_THRESHOLD = 0.6;
|
|
10
|
+
var EXACT_UUID_SCORE = 1;
|
|
11
|
+
var TITLE_KEYWORD_SCORE = 0.5;
|
|
12
|
+
var FILE_PATH_SCORE = 0.3;
|
|
13
|
+
var MIN_KEYWORD_OVERLAP = 3;
|
|
14
|
+
var STOP_WORDS = /* @__PURE__ */ new Set([
|
|
15
|
+
"a",
|
|
16
|
+
"an",
|
|
17
|
+
"the",
|
|
18
|
+
"and",
|
|
19
|
+
"or",
|
|
20
|
+
"but",
|
|
21
|
+
"in",
|
|
22
|
+
"on",
|
|
23
|
+
"at",
|
|
24
|
+
"to",
|
|
25
|
+
"for",
|
|
26
|
+
"of",
|
|
27
|
+
"with",
|
|
28
|
+
"by",
|
|
29
|
+
"from",
|
|
30
|
+
"is",
|
|
31
|
+
"it",
|
|
32
|
+
"as",
|
|
33
|
+
"be",
|
|
34
|
+
"was",
|
|
35
|
+
"are",
|
|
36
|
+
"this",
|
|
37
|
+
"that",
|
|
38
|
+
"not",
|
|
39
|
+
"no",
|
|
40
|
+
"if",
|
|
41
|
+
"so",
|
|
42
|
+
"do",
|
|
43
|
+
"up"
|
|
44
|
+
]);
|
|
45
|
+
function extractKeywords(text) {
|
|
46
|
+
return text.toLowerCase().replace(/[^a-z0-9\s-]/g, " ").split(/\s+/).filter((w) => w.length >= 3 && !STOP_WORDS.has(w));
|
|
47
|
+
}
|
|
48
|
+
function matchScore(task, commitMessage, changedFiles) {
|
|
49
|
+
if (task.id.length >= 8 && commitMessage.includes(task.id)) {
|
|
50
|
+
return EXACT_UUID_SCORE;
|
|
51
|
+
}
|
|
52
|
+
let score = 0;
|
|
53
|
+
const titleWords = extractKeywords(task.title);
|
|
54
|
+
const commitWords = new Set(extractKeywords(commitMessage));
|
|
55
|
+
const overlap = titleWords.filter((w) => commitWords.has(w));
|
|
56
|
+
if (overlap.length >= MIN_KEYWORD_OVERLAP) {
|
|
57
|
+
score += TITLE_KEYWORD_SCORE;
|
|
58
|
+
}
|
|
59
|
+
if (task.context && changedFiles.length > 0) {
|
|
60
|
+
const contextLower = task.context.toLowerCase();
|
|
61
|
+
const hasFileMatch = changedFiles.some(
|
|
62
|
+
(f) => contextLower.includes(f.toLowerCase())
|
|
63
|
+
);
|
|
64
|
+
if (hasFileMatch) {
|
|
65
|
+
score += FILE_PATH_SCORE;
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
return score;
|
|
69
|
+
}
|
|
70
|
+
function getRecentCommits(limit = DEFAULT_COMMIT_LIMIT) {
|
|
71
|
+
try {
|
|
72
|
+
const SEPARATOR = "<<SEP>>";
|
|
73
|
+
const output = execSync(
|
|
74
|
+
`git log --format="%h${SEPARATOR}%s${SEPARATOR}%aI" --name-only -n ${limit} -z`,
|
|
75
|
+
{ encoding: "utf8", timeout: 1e4 }
|
|
76
|
+
);
|
|
77
|
+
const entries = output.split("\0").filter(Boolean);
|
|
78
|
+
const commits = [];
|
|
79
|
+
let current = null;
|
|
80
|
+
for (const entry of entries) {
|
|
81
|
+
if (entry.includes(SEPARATOR)) {
|
|
82
|
+
const lines = entry.split("\n");
|
|
83
|
+
const headerLine = lines[0];
|
|
84
|
+
const parts = headerLine.split(SEPARATOR);
|
|
85
|
+
if (parts.length >= 3) {
|
|
86
|
+
if (current) commits.push(current);
|
|
87
|
+
current = {
|
|
88
|
+
hash: parts[0],
|
|
89
|
+
message: parts[1],
|
|
90
|
+
files: lines.slice(1).filter(Boolean),
|
|
91
|
+
date: new Date(parts[2])
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
} else if (current) {
|
|
95
|
+
const files = entry.split("\n").filter(Boolean);
|
|
96
|
+
current.files.push(...files);
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
if (current) commits.push(current);
|
|
100
|
+
return commits;
|
|
101
|
+
} catch {
|
|
102
|
+
return [];
|
|
103
|
+
}
|
|
104
|
+
}
|
|
105
|
+
function isStale(updatedAt, staleMinutes) {
|
|
106
|
+
const updated = new Date(updatedAt).getTime();
|
|
107
|
+
const threshold = Date.now() - staleMinutes * 6e4;
|
|
108
|
+
return updated < threshold;
|
|
109
|
+
}
|
|
110
|
+
function findBestMatch(task, commits) {
|
|
111
|
+
let best = null;
|
|
112
|
+
for (const commit of commits) {
|
|
113
|
+
const score = matchScore(task, commit.message, commit.files);
|
|
114
|
+
if (score >= AUTO_ESCALATE_THRESHOLD && (!best || score > best.score)) {
|
|
115
|
+
best = { commit, score };
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
return best;
|
|
119
|
+
}
|
|
120
|
+
async function sweepTasks(projectName, options = {}) {
|
|
121
|
+
const commitLimit = options.commitLimit ?? DEFAULT_COMMIT_LIMIT;
|
|
122
|
+
const staleMinutes = options.staleMinutes ?? DEFAULT_STALE_MINUTES;
|
|
123
|
+
const dryRun = options.dryRun ?? false;
|
|
124
|
+
const result = { escalated: [], unchanged: 0, errors: [] };
|
|
125
|
+
const commits = getRecentCommits(commitLimit);
|
|
126
|
+
if (commits.length === 0) {
|
|
127
|
+
result.errors.push("No git commits found (not a git repo or empty history)");
|
|
128
|
+
return result;
|
|
129
|
+
}
|
|
130
|
+
let tasks;
|
|
131
|
+
try {
|
|
132
|
+
const { initStore } = await import("./lib/store.js");
|
|
133
|
+
await initStore();
|
|
134
|
+
const { getClient } = await import("./lib/database.js");
|
|
135
|
+
const client = getClient();
|
|
136
|
+
const conditions = ["status = 'in_progress'"];
|
|
137
|
+
const args = [];
|
|
138
|
+
if (projectName) {
|
|
139
|
+
conditions.push("project_name = ?");
|
|
140
|
+
args.push(projectName);
|
|
141
|
+
}
|
|
142
|
+
const swScope = sessionScopeFilter();
|
|
143
|
+
if (swScope.sql) {
|
|
144
|
+
conditions.push("(session_scope IS NULL OR session_scope = ?)");
|
|
145
|
+
args.push(...swScope.args);
|
|
146
|
+
}
|
|
147
|
+
const queryResult = await client.execute({
|
|
148
|
+
sql: `SELECT id, title, assigned_to, project_name, status, updated_at, context
|
|
149
|
+
FROM tasks WHERE ${conditions.join(" AND ")}
|
|
150
|
+
ORDER BY updated_at ASC`,
|
|
151
|
+
args
|
|
152
|
+
});
|
|
153
|
+
tasks = queryResult.rows.map((r) => ({
|
|
154
|
+
id: String(r.id),
|
|
155
|
+
title: String(r.title),
|
|
156
|
+
assignedTo: String(r.assigned_to),
|
|
157
|
+
projectName: String(r.project_name),
|
|
158
|
+
status: String(r.status),
|
|
159
|
+
updatedAt: String(r.updated_at),
|
|
160
|
+
context: r.context ? String(r.context) : void 0
|
|
161
|
+
}));
|
|
162
|
+
} catch (err) {
|
|
163
|
+
result.errors.push(`DB query failed: ${err instanceof Error ? err.message : String(err)}`);
|
|
164
|
+
return result;
|
|
165
|
+
}
|
|
166
|
+
if (tasks.length === 0) {
|
|
167
|
+
return result;
|
|
168
|
+
}
|
|
169
|
+
for (const task of tasks) {
|
|
170
|
+
if (!isStale(task.updatedAt, staleMinutes)) {
|
|
171
|
+
result.unchanged++;
|
|
172
|
+
continue;
|
|
173
|
+
}
|
|
174
|
+
const match = findBestMatch(task, commits);
|
|
175
|
+
if (!match) {
|
|
176
|
+
result.unchanged++;
|
|
177
|
+
continue;
|
|
178
|
+
}
|
|
179
|
+
if (!dryRun) {
|
|
180
|
+
try {
|
|
181
|
+
const { updateTaskStatus } = await import("./tasks-crud-6TWWETGB.js");
|
|
182
|
+
await updateTaskStatus({
|
|
183
|
+
taskId: task.id,
|
|
184
|
+
status: "needs_review",
|
|
185
|
+
result: `Auto-escalated by git-sweep: matching commit ${match.commit.hash} found (score: ${match.score.toFixed(2)})`
|
|
186
|
+
});
|
|
187
|
+
} catch (err) {
|
|
188
|
+
result.errors.push(
|
|
189
|
+
`Failed to escalate task ${task.id}: ${err instanceof Error ? err.message : String(err)}`
|
|
190
|
+
);
|
|
191
|
+
continue;
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
result.escalated.push({
|
|
195
|
+
taskId: task.id,
|
|
196
|
+
title: task.title,
|
|
197
|
+
matchedCommit: match.commit.hash,
|
|
198
|
+
score: match.score
|
|
199
|
+
});
|
|
200
|
+
process.stderr.write(
|
|
201
|
+
`[git-sweep] ${dryRun ? "WOULD escalate" : "Escalated"} task ${task.id} \u2192 commit ${match.commit.hash} (score: ${match.score.toFixed(2)})
|
|
202
|
+
`
|
|
203
|
+
);
|
|
204
|
+
}
|
|
205
|
+
return result;
|
|
206
|
+
}
|
|
207
|
+
|
|
208
|
+
export {
|
|
209
|
+
extractKeywords,
|
|
210
|
+
matchScore,
|
|
211
|
+
getRecentCommits,
|
|
212
|
+
findBestMatch,
|
|
213
|
+
sweepTasks
|
|
214
|
+
};
|