@askexenow/exe-os 0.9.265 → 0.9.267
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/deploy/compose/.env.example +4 -2
- package/deploy/compose/docker-compose.yml +6 -4
- package/deploy/compose/generate-env.ts +5 -2
- package/dist/active-agent-2XJJZFEW.js +25 -0
- package/dist/active-agent-JZ4PHIAK.js +26 -0
- package/dist/agentic-ontology-J4B525DT.js +25 -0
- package/dist/backfill-metadata-TWEC6BJD.js +597 -0
- package/dist/backfill-metadata-VGZLCJWZ.js +597 -0
- package/dist/backfill-metadata-Y6EABP6Q.js +597 -0
- package/dist/behaviors-BPIVFAGY.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 +6 -1
- package/dist/bin/cleanup-stale-review-tasks.js +9 -9
- package/dist/bin/cli.js +15 -15
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +4 -4
- package/dist/bin/exe-assign.js +5 -5
- package/dist/bin/exe-boot.js +16 -16
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +4 -4
- package/dist/bin/exe-dispatch.js +9 -9
- 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 +6 -1
- package/dist/bin/exe-heartbeat.js +9 -9
- package/dist/bin/exe-kill.js +12 -12
- package/dist/bin/exe-launch-agent.js +16 -16
- package/dist/bin/exe-new-employee.js +6 -6
- package/dist/bin/exe-pending-messages.js +10 -10
- package/dist/bin/exe-pending-notifications.js +9 -9
- package/dist/bin/exe-pending-reviews.js +9 -9
- package/dist/bin/exe-rename.js +4 -4
- package/dist/bin/exe-review.js +11 -11
- package/dist/bin/exe-search.js +5 -5
- package/dist/bin/exe-session-cleanup.js +14 -14
- package/dist/bin/exe-settings.js +4 -4
- package/dist/bin/exe-start-codex.js +11 -11
- package/dist/bin/exe-start-opencode.js +8 -8
- package/dist/bin/exe-status.js +10 -10
- package/dist/bin/exe-team.js +3 -3
- package/dist/bin/git-sweep.js +10 -10
- 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 +9 -9
- package/dist/bin/setup.js +1 -1
- package/dist/bin/shard-migrate.js +5 -5
- package/dist/capacity-monitor-3QORC56J.js +49 -0
- package/dist/capacity-monitor-FWRBCZCZ.js +49 -0
- package/dist/capacity-monitor-MTYXZ7Q2.js +49 -0
- package/dist/catchup-brief-242H63OP.js +151 -0
- package/dist/catchup-brief-KNX6L2EN.js +151 -0
- package/dist/catchup-brief-T7W2ARRB.js +151 -0
- package/dist/catchup-brief-VJDLXJHJ.js +151 -0
- package/dist/chunk-2B6FH2QM.js +3951 -0
- package/dist/chunk-2FDYA3GS.js +75 -0
- package/dist/chunk-2V33IVZF.js +1148 -0
- package/dist/chunk-2W5NQOQJ.js +333 -0
- package/dist/chunk-32QR5EHE.js +244 -0
- package/dist/chunk-3DBROKA6.js +382 -0
- package/dist/chunk-3DS2YHAT.js +204 -0
- package/dist/chunk-3GP2QTXT.js +128 -0
- package/dist/chunk-3O2ZD7YV.js +227 -0
- package/dist/chunk-3Q2VWYTA.js +89 -0
- package/dist/chunk-43O2PZH7.js +214 -0
- package/dist/chunk-4AHL6I7X.js +284 -0
- package/dist/chunk-53IGC63J.js +54 -0
- package/dist/chunk-5GBPXJIH.js +50 -0
- package/dist/chunk-5IXN2532.js +58 -0
- package/dist/chunk-5KHVSGHP.js +330 -0
- package/dist/chunk-5SH5TR45.js +731 -0
- package/dist/chunk-5XGMTWKW.js +128 -0
- package/dist/chunk-6AQAILCS.js +13696 -0
- package/dist/chunk-6EIBIA3E.js +13696 -0
- package/dist/chunk-6KGRRZDA.js +81 -0
- package/dist/chunk-72KQJZBH.js +382 -0
- package/dist/chunk-7B2AENJ3.js +1345 -0
- package/dist/chunk-7GKMYFVR.js +551 -0
- package/dist/chunk-7HUGVJHW.js +1021 -0
- package/dist/chunk-7HWBGXDV.js +333 -0
- package/dist/chunk-7ROGPDW6.js +197 -0
- package/dist/chunk-7ZMLNURG.js +513 -0
- package/dist/chunk-A3G4UXNA.js +280 -0
- package/dist/chunk-A4T6U3XZ.js +371 -0
- package/dist/chunk-ADJNRFEK.js +13696 -0
- package/dist/chunk-AVJTW67M.js +513 -0
- package/dist/chunk-B6RC7DAC.js +1090 -0
- package/dist/chunk-BAOJLZVC.js +244 -0
- package/dist/chunk-BCUMPA7J.js +159 -0
- package/dist/chunk-BH2ST7KK.js +183 -0
- package/dist/chunk-C4BIYP5C.js +129 -0
- package/dist/chunk-CBUZG6OC.js +89 -0
- package/dist/chunk-CGQRWCCP.js +81 -0
- package/dist/chunk-CLX4WQHT.js +214 -0
- package/dist/chunk-CM32SM3U.js +127 -0
- package/dist/chunk-D4CQZL46.js +76 -0
- package/dist/chunk-DEBLYXA2.js +56 -0
- package/dist/chunk-E45SYT7G.js +617 -0
- package/dist/chunk-EDNUE5L3.js +38 -0
- package/dist/chunk-EMTXM73F.js +333 -0
- package/dist/chunk-ESNHLTLC.js +1073 -0
- package/dist/chunk-FICUAZEA.js +128 -0
- package/dist/chunk-FP6U5PSY.js +818 -0
- package/dist/chunk-G4WZIPDM.js +1921 -0
- package/dist/chunk-G55UTKFR.js +89 -0
- package/dist/chunk-GIJUXLK5.js +330 -0
- package/dist/chunk-GVSSEGIV.js +348 -0
- package/dist/chunk-GYOOZ725.js +330 -0
- package/dist/chunk-GZ3NZDS5.js +1090 -0
- package/dist/chunk-HCULUL4D.js +447 -0
- package/dist/chunk-HDRQKH7R.js +1051 -0
- package/dist/chunk-HHBN7Y7R.js +197 -0
- package/dist/chunk-IP7YSYZB.js +1073 -0
- package/dist/chunk-IQBXQ7GF.js +1073 -0
- package/dist/chunk-ITF6GEJI.js +2091 -0
- package/dist/chunk-IUY6I2CH.js +1148 -0
- package/dist/chunk-IXHVSWLM.js +58 -0
- package/dist/chunk-IXUGRCIM.js +58 -0
- package/dist/chunk-J3ZFONT4.js +1921 -0
- package/dist/chunk-JEOFG274.js +394 -0
- package/dist/chunk-JH7ISOIJ.js +33 -0
- package/dist/chunk-JVRMAVPN.js +731 -0
- package/dist/chunk-KBYRYSXT.js +3951 -0
- package/dist/chunk-KECNXWD6.js +1051 -0
- package/dist/chunk-KI5HUHVX.js +171 -0
- package/dist/chunk-KIYCHS35.js +128 -0
- package/dist/chunk-KUP3D6G2.js +1345 -0
- package/dist/chunk-KXS5HHDH.js +54 -0
- package/dist/chunk-LNY2DMEX.js +50 -0
- package/dist/chunk-LSI363EB.js +284 -0
- package/dist/chunk-LVZW4WQY.js +221 -0
- package/dist/chunk-LWOCCDSB.js +240 -0
- package/dist/chunk-M4HRKRSE.js +30 -0
- package/dist/chunk-MPG5DR3K.js +244 -0
- package/dist/chunk-NOG2LVBA.js +159 -0
- package/dist/chunk-NP3CYOEY.js +290 -0
- package/dist/chunk-OM5524LQ.js +204 -0
- package/dist/chunk-ONMXLCZ7.js +495 -0
- package/dist/chunk-OVQOKLYA.js +210 -0
- package/dist/chunk-OW26ML36.js +1148 -0
- package/dist/chunk-OZPTYL2D.js +244 -0
- package/dist/chunk-P2DOIWQG.js +260 -0
- package/dist/chunk-P2QTTEYP.js +3951 -0
- package/dist/chunk-P5IKFL7B.js +85 -0
- package/dist/chunk-PD2LUPHD.js +377 -0
- package/dist/chunk-PF5EFIAH.js +818 -0
- package/dist/chunk-PK3NFO76.js +551 -0
- package/dist/chunk-Q4NVLQHH.js +76 -0
- package/dist/chunk-QKMFMJTU.js +171 -0
- package/dist/chunk-R3ERWIOH.js +197 -0
- package/dist/chunk-R3FOMRWJ.js +731 -0
- package/dist/chunk-R77M74QM.js +13696 -0
- package/dist/chunk-RHZ2CRJU.js +3556 -0
- package/dist/chunk-RLR4LVO5.js +1090 -0
- package/dist/chunk-RMDDSWFH.js +495 -0
- package/dist/chunk-RPLEZ74B.js +95 -0
- package/dist/chunk-RXMVPGH2.js +346 -0
- package/dist/chunk-S2ARWNS6.js +135 -0
- package/dist/chunk-SHPIATX7.js +90 -0
- package/dist/chunk-SQUZ3TI2.js +668 -0
- package/dist/chunk-SUGBKORD.js +1148 -0
- package/dist/chunk-T2XD7XL2.js +346 -0
- package/dist/chunk-TAIYLROT.js +127 -0
- package/dist/chunk-TCD4XCBS.js +495 -0
- package/dist/chunk-TEVTA7JX.js +551 -0
- package/dist/chunk-TQVS4W2Y.js +346 -0
- package/dist/chunk-TSBMSHMM.js +163 -0
- package/dist/chunk-U776PBU6.js +488 -0
- package/dist/chunk-UQ27GW5L.js +377 -0
- package/dist/chunk-UQMIBSN4.js +159 -0
- package/dist/chunk-UTVNIAOF.js +284 -0
- package/dist/chunk-VF6VT4MR.js +70 -0
- package/dist/chunk-VZXLYUKS.js +171 -0
- package/dist/chunk-WHATWGUZ.js +447 -0
- package/dist/chunk-WIAHPJDS.js +58 -0
- package/dist/chunk-WM5ELLT4.js +54 -0
- package/dist/chunk-WUUSPOCC.js +1921 -0
- package/dist/chunk-WXHAMPK4.js +81 -0
- package/dist/chunk-WYNZ23XH.js +262 -0
- package/dist/chunk-WZOQLU2Y.js +127 -0
- package/dist/chunk-X24GBZKR.js +157 -0
- package/dist/chunk-X5FRF5MG.js +13696 -0
- package/dist/chunk-XBPLYFBA.js +204 -0
- package/dist/chunk-XDGKFXFW.js +363 -0
- package/dist/chunk-XIT6ONPY.js +630 -0
- package/dist/chunk-XK66XNN3.js +818 -0
- package/dist/chunk-XNRJ5JHU.js +377 -0
- package/dist/chunk-XREWTPZM.js +123 -0
- package/dist/chunk-XURCA5VD.js +297 -0
- package/dist/chunk-Y55VFZJB.js +50 -0
- package/dist/chunk-Y5SXCVET.js +214 -0
- package/dist/chunk-YIH2YMWP.js +76 -0
- package/dist/chunk-YZMCCT73.js +97 -0
- package/dist/chunk-Z4476ZEZ.js +513 -0
- package/dist/chunk-Z7VAUKRU.js +1345 -0
- package/dist/chunk-ZCDGAH7H.js +382 -0
- package/dist/chunk-ZTP3VV23.js +447 -0
- package/dist/co-activation-JOYR73H2.js +72 -0
- package/dist/co-occurrence-G7RRJ3DB.js +74 -0
- package/dist/core-memory-6KK55Z65.js +110 -0
- package/dist/core-memory-DRYQWHJU.js +110 -0
- package/dist/core-memory-QRS6GBXL.js +110 -0
- package/dist/crdt-sync-QWK65Z5A.js +33 -0
- package/dist/crm-webhook-BNUS3USD.js +10 -0
- package/dist/crm-webhook-BSN4TCCY.js +10 -0
- package/dist/crm-webhook-ZTIRFVAH.js +10 -0
- package/dist/cto-delegation-gate-DNZJGBS7.js +206 -0
- package/dist/cto-delegation-gate-IPQBZ3J2.js +206 -0
- package/dist/cto-delegation-gate-YI3LK7VY.js +206 -0
- package/dist/daemon-orchestration-6TIV6MMN.js +135 -0
- package/dist/daemon-orchestration-7LVOHYKA.js +135 -0
- package/dist/daemon-orchestration-SDQNWI3K.js +135 -0
- package/dist/db-backup-5ENHDNZI.js +33 -0
- package/dist/dreaming-5S4SSUIU.js +32 -0
- package/dist/dreaming-PGJOCGAM.js +32 -0
- package/dist/dreaming-UNHHGOU3.js +32 -0
- package/dist/exe-drift-QQJMUQXA.js +68 -0
- package/dist/exe-export-BEZZSQB4.js +73 -0
- package/dist/exe-export-JJJJDQE3.js +73 -0
- package/dist/exe-export-TQGI2VBT.js +73 -0
- package/dist/exe-import-2SR2UP3D.js +76 -0
- package/dist/exe-import-73Q4VLFK.js +76 -0
- package/dist/exe-import-G7VIUGLR.js +76 -0
- package/dist/exe-key-6JHEINOM.js +579 -0
- package/dist/exe-key-JS7OSDJP.js +579 -0
- package/dist/exe-key-RIRPIFK6.js +579 -0
- package/dist/exe-snapshot-DSPO4HHJ.js +164 -0
- package/dist/exe-snapshot-NDMDQJOH.js +164 -0
- package/dist/exe-snapshot-PVCBPMPJ.js +164 -0
- package/dist/fast-db-init-22OBOPTN.js +7 -0
- package/dist/fast-db-init-M6ZYYGAL.js +7 -0
- package/dist/fast-db-init-VLF46DR3.js +7 -0
- package/dist/gateway/index.js +8 -8
- package/dist/git-staleness-4DGYC3RY.js +110 -0
- package/dist/git-task-sweep-CUR7R2ZM.js +40 -0
- package/dist/git-task-sweep-VO2DVEXY.js +40 -0
- package/dist/git-task-sweep-YG3IVGK3.js +40 -0
- package/dist/global-procedures-TYDNKM7V.js +20 -0
- package/dist/graph-auto-extract-I6B5HWTP.js +162 -0
- package/dist/hooks/bug-report-worker.js +11 -11
- package/dist/hooks/codex-stop-task-finalizer.js +11 -11
- package/dist/hooks/commit-complete.js +11 -11
- 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 +10 -10
- package/dist/hooks/post-tool-combined.js +5 -5
- package/dist/hooks/pre-compact.js +11 -11
- package/dist/hooks/pre-tool-use.js +14 -14
- package/dist/hooks/prompt-submit.js +20 -20
- package/dist/hooks/session-end.js +15 -15
- package/dist/hooks/session-start.js +10 -10
- package/dist/hooks/stop.js +14 -14
- package/dist/hooks/subagent-stop.js +10 -10
- package/dist/hooks/summary-worker.js +14 -14
- package/dist/index.js +17 -17
- package/dist/installer-4LP73C3M.js +38 -0
- package/dist/installer-AUVLNS4D.js +296 -0
- package/dist/installer-KCRLQSQH.js +38 -0
- package/dist/installer-KGXYUOIV.js +296 -0
- package/dist/installer-UI6TNJGO.js +342 -0
- package/dist/installer-Z7NPD4PD.js +342 -0
- 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-daemon-client.js +6 -0
- 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 +41 -40
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/messaging.js +9 -9
- 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 +10 -10
- package/dist/lib/tmux-routing.js +8 -8
- package/dist/lib/token-spend.js +3 -3
- package/dist/mcp/register-tools.js +53 -52
- package/dist/mcp/server.js +54 -53
- 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 +12 -12
- 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 +12 -12
- package/dist/mcp/tools/send-message.js +11 -11
- package/dist/mcp/tools/update-task.js +11 -11
- package/dist/mcp-http-config-LN5ITKGS.js +27 -0
- package/dist/mcp-http-config-V43VHNEH.js +27 -0
- package/dist/memory-cards-S36DCEY4.js +174 -0
- package/dist/memory-graph-extractor-66YL4V4B.js +17 -0
- package/dist/memory-poisoning-defense-MXWE6CTY.js +225 -0
- package/dist/memory-reflection-W676LUX5.js +238 -0
- package/dist/notifications-NGKMOBKL.js +45 -0
- package/dist/notifications-OFLXZTDZ.js +45 -0
- package/dist/notifications-XAV4V7T5.js +45 -0
- package/dist/orchestration-events-MJLWJ2H2.js +25 -0
- package/dist/orchestrator-6MKGTKN7.js +33 -0
- package/dist/orchestrator-AIAKV5ST.js +33 -0
- package/dist/orchestrator-VK7D6I36.js +33 -0
- package/dist/pipeline-router-DXH5QVUH.js +13 -0
- package/dist/pipeline-router-EV6C5S33.js +13 -0
- package/dist/pipeline-router-G65CQ5EE.js +13 -0
- package/dist/plan-limits-TQMLKZBG.js +26 -0
- package/dist/project-boot-4XTXHDG4.js +299 -0
- package/dist/projection-worker-NAYVNSI4.js +964 -0
- package/dist/reranker-KHZI7HQK.js +19 -0
- package/dist/reranker-O6QYMIEA.js +19 -0
- package/dist/reranker-UPMS3OX7.js +19 -0
- package/dist/reranker-ZN73HWSB.js +19 -0
- package/dist/review-polling-3UEZSPNT.js +124 -0
- package/dist/review-polling-KBDX3ILL.js +124 -0
- package/dist/review-polling-ZWOO7QQJ.js +124 -0
- package/dist/runtime/index.js +11 -11
- package/dist/session-events-2CHOLA6D.js +36 -0
- package/dist/session-events-HM22KEHN.js +36 -0
- package/dist/session-events-YIUYMJKP.js +36 -0
- package/dist/session-kill-telemetry-LUPVYGZX.js +29 -0
- package/dist/session-scope-EPZZZHHJ.js +86 -0
- package/dist/session-scope-KZ25NMH3.js +86 -0
- package/dist/session-scope-ZGE6GHMS.js +86 -0
- package/dist/setup-wizard-KNWH54HW.js +12 -0
- package/dist/shard-manager-GFKF4AKT.js +30 -0
- package/dist/skill-refinement-A5S4KCS4.js +157 -0
- package/dist/skill-refinement-C4GNWV4F.js +157 -0
- package/dist/skill-refinement-CAUIE4YM.js +157 -0
- package/dist/steward-gate-MZ2DV36N.js +13 -0
- package/dist/task-enforcement-6OMXG6EA.js +333 -0
- package/dist/task-enforcement-D5AP7KJM.js +333 -0
- package/dist/task-enforcement-JFSF6QDD.js +333 -0
- package/dist/task-scope-4HJSCJ7L.js +35 -0
- package/dist/task-scope-7HYE4AS6.js +35 -0
- package/dist/task-scope-MP32TKL3.js +35 -0
- package/dist/tasks-crud-JJL6MMJF.js +77 -0
- package/dist/tasks-crud-KMIPDHBZ.js +77 -0
- package/dist/tasks-crud-NOMD6R4W.js +77 -0
- package/dist/tasks-notify-5D6LF52K.js +38 -0
- package/dist/tasks-notify-J3L2URRG.js +38 -0
- package/dist/tasks-notify-JNGGXFUY.js +38 -0
- package/dist/tasks-review-N6I5UC7G.js +47 -0
- package/dist/tasks-review-USHAMO5N.js +47 -0
- package/dist/tasks-review-WO2Y7F6V.js +47 -0
- package/dist/telemetry-upload-BV2M2NND.js +739 -0
- package/dist/telemetry-upload-O6R7W4CV.js +739 -0
- package/dist/telemetry-upload-Y7QPDJW4.js +739 -0
- package/dist/token-budget-2LUZOFO7.js +84 -0
- package/dist/tool-telemetry-5JT6DPVK.js +17 -0
- package/dist/tui/App.js +16 -16
- package/dist/tui-data-DMAKZMGD.js +258 -0
- package/dist/tui-data-X7NI6ZQ3.js +258 -0
- package/dist/tui-data-Z3KQW37O.js +258 -0
- package/dist/wiki-acl-QHGGWX63.js +111 -0
- package/dist/worker-gate-3AUE4IZX.js +21 -0
- package/dist/worker-gate-4XKUOFWO.js +21 -0
- package/dist/worker-gate-TPZBOXOA.js +21 -0
- package/dist/workflow-engine-F3URLOPA.js +28 -0
- package/dist/workflow-engine-OFOL446Z.js +28 -0
- package/dist/workflow-engine-VNPPUSNL.js +28 -0
- package/dist/worktree-V3NVP7MV.js +26 -0
- package/dist/worktree-sweep-2CADL43Y.js +19 -0
- package/package.json +1 -1
- package/release-notes.json +32 -26
|
@@ -0,0 +1,284 @@
|
|
|
1
|
+
import {
|
|
2
|
+
routeTask
|
|
3
|
+
} from "./chunk-S2ARWNS6.js";
|
|
4
|
+
import {
|
|
5
|
+
createTaskCore,
|
|
6
|
+
employeeSessionName,
|
|
7
|
+
ensureEmployee,
|
|
8
|
+
getSessionState,
|
|
9
|
+
isEmployeeAlive,
|
|
10
|
+
sessionScopeFilter,
|
|
11
|
+
updateTaskStatus
|
|
12
|
+
} from "./chunk-KBYRYSXT.js";
|
|
13
|
+
import {
|
|
14
|
+
DEFAULT_COORDINATOR_TEMPLATE_NAME,
|
|
15
|
+
getCoordinatorName
|
|
16
|
+
} from "./chunk-RHZ2CRJU.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,70 @@
|
|
|
1
|
+
import {
|
|
2
|
+
loadEmployees
|
|
3
|
+
} from "./chunk-RHZ2CRJU.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/agent-symlinks.ts
|
|
6
|
+
import os from "os";
|
|
7
|
+
import path from "path";
|
|
8
|
+
import {
|
|
9
|
+
existsSync,
|
|
10
|
+
lstatSync,
|
|
11
|
+
mkdirSync,
|
|
12
|
+
readlinkSync,
|
|
13
|
+
symlinkSync
|
|
14
|
+
} from "fs";
|
|
15
|
+
function claudeAgentsDir(homeDir) {
|
|
16
|
+
return path.join(homeDir, ".claude", "agents");
|
|
17
|
+
}
|
|
18
|
+
function identitySourcePath(homeDir, agentId) {
|
|
19
|
+
return path.join(homeDir, ".exe-os", "identity", `${agentId}.md`);
|
|
20
|
+
}
|
|
21
|
+
function claudeAgentLinkPath(homeDir, agentId) {
|
|
22
|
+
return path.join(claudeAgentsDir(homeDir), `${agentId}.md`);
|
|
23
|
+
}
|
|
24
|
+
function ensureAgentSymlink(agentId, homeDir = os.homedir()) {
|
|
25
|
+
const target = identitySourcePath(homeDir, agentId);
|
|
26
|
+
const link = claudeAgentLinkPath(homeDir, agentId);
|
|
27
|
+
mkdirSync(claudeAgentsDir(homeDir), { recursive: true });
|
|
28
|
+
if (existsSync(link)) {
|
|
29
|
+
let stat;
|
|
30
|
+
try {
|
|
31
|
+
stat = lstatSync(link);
|
|
32
|
+
} catch {
|
|
33
|
+
return { agentId, action: "conflict", target, link, conflict: "stat_failed" };
|
|
34
|
+
}
|
|
35
|
+
if (!stat.isSymbolicLink()) {
|
|
36
|
+
return { agentId, action: "conflict", target, link, conflict: "regular_file" };
|
|
37
|
+
}
|
|
38
|
+
let currentTarget;
|
|
39
|
+
try {
|
|
40
|
+
currentTarget = readlinkSync(link);
|
|
41
|
+
} catch {
|
|
42
|
+
return { agentId, action: "conflict", target, link, conflict: "readlink_failed" };
|
|
43
|
+
}
|
|
44
|
+
if (currentTarget === target) {
|
|
45
|
+
return { agentId, action: "already_correct", target, link };
|
|
46
|
+
}
|
|
47
|
+
return { agentId, action: "conflict", target, link, conflict: `points_to:${currentTarget}` };
|
|
48
|
+
}
|
|
49
|
+
try {
|
|
50
|
+
symlinkSync(target, link);
|
|
51
|
+
} catch (err) {
|
|
52
|
+
return {
|
|
53
|
+
agentId,
|
|
54
|
+
action: "conflict",
|
|
55
|
+
target,
|
|
56
|
+
link,
|
|
57
|
+
conflict: err instanceof Error ? err.message : String(err)
|
|
58
|
+
};
|
|
59
|
+
}
|
|
60
|
+
return { agentId, action: "created", target, link };
|
|
61
|
+
}
|
|
62
|
+
async function ensureAllAgentSymlinks(homeDir = os.homedir()) {
|
|
63
|
+
const employees = await loadEmployees();
|
|
64
|
+
return employees.map((emp) => ensureAgentSymlink(emp.name, homeDir));
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
export {
|
|
68
|
+
ensureAgentSymlink,
|
|
69
|
+
ensureAllAgentSymlinks
|
|
70
|
+
};
|
|
@@ -0,0 +1,171 @@
|
|
|
1
|
+
import {
|
|
2
|
+
writeMemoryViaDaemon
|
|
3
|
+
} from "./chunk-Q3GLQDZI.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
|
+
};
|