@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,110 @@
|
|
|
1
|
+
import "./chunk-MLKGABMK.js";
|
|
2
|
+
|
|
3
|
+
// src/lib/core-memory.ts
|
|
4
|
+
var MAX_CORE_ENTRIES = 10;
|
|
5
|
+
var MAX_ENTRY_LENGTH = 500;
|
|
6
|
+
var MAX_TOTAL_CHARS = 5e3;
|
|
7
|
+
async function getCoreMemory(agentId) {
|
|
8
|
+
try {
|
|
9
|
+
const { getClient } = await import("./lib/database.js");
|
|
10
|
+
const client = getClient();
|
|
11
|
+
const result = await client.execute({
|
|
12
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
13
|
+
WHERE agent_id = ? ORDER BY key ASC`,
|
|
14
|
+
args: [agentId]
|
|
15
|
+
});
|
|
16
|
+
return result.rows.map((r) => ({
|
|
17
|
+
key: String(r.key),
|
|
18
|
+
value: String(r.value),
|
|
19
|
+
updatedAt: String(r.updated_at)
|
|
20
|
+
}));
|
|
21
|
+
} catch {
|
|
22
|
+
return [];
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async function setCoreMemory(agentId, key, value) {
|
|
26
|
+
if (value.length > MAX_ENTRY_LENGTH) {
|
|
27
|
+
throw new Error(`Core memory value too long (${value.length}/${MAX_ENTRY_LENGTH} chars). Core memory is for key facts, not documents.`);
|
|
28
|
+
}
|
|
29
|
+
const { getClient } = await import("./lib/database.js");
|
|
30
|
+
const client = getClient();
|
|
31
|
+
const countResult = await client.execute({
|
|
32
|
+
sql: `SELECT COUNT(*) as cnt FROM core_memory WHERE agent_id = ?`,
|
|
33
|
+
args: [agentId]
|
|
34
|
+
});
|
|
35
|
+
const count = Number(countResult.rows[0]?.cnt ?? 0);
|
|
36
|
+
const existing = await client.execute({
|
|
37
|
+
sql: `SELECT key FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
38
|
+
args: [agentId, key]
|
|
39
|
+
});
|
|
40
|
+
if (existing.rows.length === 0 && count >= MAX_CORE_ENTRIES) {
|
|
41
|
+
const oldest = await client.execute({
|
|
42
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
43
|
+
WHERE agent_id = ? ORDER BY updated_at ASC LIMIT 1`,
|
|
44
|
+
args: [agentId]
|
|
45
|
+
});
|
|
46
|
+
if (oldest.rows.length > 0) {
|
|
47
|
+
const oldKey = String(oldest.rows[0].key);
|
|
48
|
+
const oldValue = String(oldest.rows[0].value);
|
|
49
|
+
try {
|
|
50
|
+
const { randomUUID } = await import("crypto");
|
|
51
|
+
const { writeMemory } = await import("./lib/store.js");
|
|
52
|
+
await writeMemory({
|
|
53
|
+
id: randomUUID(),
|
|
54
|
+
agent_id: agentId,
|
|
55
|
+
agent_role: "core-demotion",
|
|
56
|
+
session_id: "core-memory-demotion",
|
|
57
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
58
|
+
tool_name: "core_memory_demotion",
|
|
59
|
+
project_name: "exe-os",
|
|
60
|
+
has_error: false,
|
|
61
|
+
raw_text: `[Demoted from core memory] ${oldKey}: ${oldValue}`,
|
|
62
|
+
vector: null
|
|
63
|
+
});
|
|
64
|
+
} catch {
|
|
65
|
+
}
|
|
66
|
+
await client.execute({
|
|
67
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
68
|
+
args: [agentId, oldKey]
|
|
69
|
+
});
|
|
70
|
+
process.stderr.write(`[core-memory] Auto-demoted "${oldKey}" to regular memory (core full at ${MAX_CORE_ENTRIES})
|
|
71
|
+
`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const sizeResult = await client.execute({
|
|
75
|
+
sql: `SELECT COALESCE(SUM(LENGTH(value)), 0) as total FROM core_memory WHERE agent_id = ? AND key != ?`,
|
|
76
|
+
args: [agentId, key]
|
|
77
|
+
});
|
|
78
|
+
const currentSize = Number(sizeResult.rows[0]?.total ?? 0);
|
|
79
|
+
if (currentSize + value.length > MAX_TOTAL_CHARS) {
|
|
80
|
+
throw new Error(`Core memory would exceed ${MAX_TOTAL_CHARS} char limit. Delete entries or shorten values.`);
|
|
81
|
+
}
|
|
82
|
+
await client.execute({
|
|
83
|
+
sql: `INSERT OR REPLACE INTO core_memory (agent_id, key, value, updated_at)
|
|
84
|
+
VALUES (?, ?, ?, ?)`,
|
|
85
|
+
args: [agentId, key, value, (/* @__PURE__ */ new Date()).toISOString()]
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
async function deleteCoreMemory(agentId, key) {
|
|
89
|
+
const { getClient } = await import("./lib/database.js");
|
|
90
|
+
const client = getClient();
|
|
91
|
+
const result = await client.execute({
|
|
92
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
93
|
+
args: [agentId, key]
|
|
94
|
+
});
|
|
95
|
+
return (result.rowsAffected ?? 0) > 0;
|
|
96
|
+
}
|
|
97
|
+
function formatCoreMemoryBlock(entries) {
|
|
98
|
+
if (entries.length === 0) return null;
|
|
99
|
+
const lines = ["## Core Memory (always in context)", ""];
|
|
100
|
+
for (const e of entries) {
|
|
101
|
+
lines.push(`- **${e.key}:** ${e.value}`);
|
|
102
|
+
}
|
|
103
|
+
return lines.join("\n");
|
|
104
|
+
}
|
|
105
|
+
export {
|
|
106
|
+
deleteCoreMemory,
|
|
107
|
+
formatCoreMemoryBlock,
|
|
108
|
+
getCoreMemory,
|
|
109
|
+
setCoreMemory
|
|
110
|
+
};
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import "./chunk-MLKGABMK.js";
|
|
2
|
+
|
|
3
|
+
// src/lib/core-memory.ts
|
|
4
|
+
var MAX_CORE_ENTRIES = 10;
|
|
5
|
+
var MAX_ENTRY_LENGTH = 500;
|
|
6
|
+
var MAX_TOTAL_CHARS = 5e3;
|
|
7
|
+
async function getCoreMemory(agentId) {
|
|
8
|
+
try {
|
|
9
|
+
const { getClient } = await import("./lib/database.js");
|
|
10
|
+
const client = getClient();
|
|
11
|
+
const result = await client.execute({
|
|
12
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
13
|
+
WHERE agent_id = ? ORDER BY key ASC`,
|
|
14
|
+
args: [agentId]
|
|
15
|
+
});
|
|
16
|
+
return result.rows.map((r) => ({
|
|
17
|
+
key: String(r.key),
|
|
18
|
+
value: String(r.value),
|
|
19
|
+
updatedAt: String(r.updated_at)
|
|
20
|
+
}));
|
|
21
|
+
} catch {
|
|
22
|
+
return [];
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async function setCoreMemory(agentId, key, value) {
|
|
26
|
+
if (value.length > MAX_ENTRY_LENGTH) {
|
|
27
|
+
throw new Error(`Core memory value too long (${value.length}/${MAX_ENTRY_LENGTH} chars). Core memory is for key facts, not documents.`);
|
|
28
|
+
}
|
|
29
|
+
const { getClient } = await import("./lib/database.js");
|
|
30
|
+
const client = getClient();
|
|
31
|
+
const countResult = await client.execute({
|
|
32
|
+
sql: `SELECT COUNT(*) as cnt FROM core_memory WHERE agent_id = ?`,
|
|
33
|
+
args: [agentId]
|
|
34
|
+
});
|
|
35
|
+
const count = Number(countResult.rows[0]?.cnt ?? 0);
|
|
36
|
+
const existing = await client.execute({
|
|
37
|
+
sql: `SELECT key FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
38
|
+
args: [agentId, key]
|
|
39
|
+
});
|
|
40
|
+
if (existing.rows.length === 0 && count >= MAX_CORE_ENTRIES) {
|
|
41
|
+
const oldest = await client.execute({
|
|
42
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
43
|
+
WHERE agent_id = ? ORDER BY updated_at ASC LIMIT 1`,
|
|
44
|
+
args: [agentId]
|
|
45
|
+
});
|
|
46
|
+
if (oldest.rows.length > 0) {
|
|
47
|
+
const oldKey = String(oldest.rows[0].key);
|
|
48
|
+
const oldValue = String(oldest.rows[0].value);
|
|
49
|
+
try {
|
|
50
|
+
const { randomUUID } = await import("crypto");
|
|
51
|
+
const { writeMemory } = await import("./lib/store.js");
|
|
52
|
+
await writeMemory({
|
|
53
|
+
id: randomUUID(),
|
|
54
|
+
agent_id: agentId,
|
|
55
|
+
agent_role: "core-demotion",
|
|
56
|
+
session_id: "core-memory-demotion",
|
|
57
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
58
|
+
tool_name: "core_memory_demotion",
|
|
59
|
+
project_name: "exe-os",
|
|
60
|
+
has_error: false,
|
|
61
|
+
raw_text: `[Demoted from core memory] ${oldKey}: ${oldValue}`,
|
|
62
|
+
vector: null
|
|
63
|
+
});
|
|
64
|
+
} catch {
|
|
65
|
+
}
|
|
66
|
+
await client.execute({
|
|
67
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
68
|
+
args: [agentId, oldKey]
|
|
69
|
+
});
|
|
70
|
+
process.stderr.write(`[core-memory] Auto-demoted "${oldKey}" to regular memory (core full at ${MAX_CORE_ENTRIES})
|
|
71
|
+
`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const sizeResult = await client.execute({
|
|
75
|
+
sql: `SELECT COALESCE(SUM(LENGTH(value)), 0) as total FROM core_memory WHERE agent_id = ? AND key != ?`,
|
|
76
|
+
args: [agentId, key]
|
|
77
|
+
});
|
|
78
|
+
const currentSize = Number(sizeResult.rows[0]?.total ?? 0);
|
|
79
|
+
if (currentSize + value.length > MAX_TOTAL_CHARS) {
|
|
80
|
+
throw new Error(`Core memory would exceed ${MAX_TOTAL_CHARS} char limit. Delete entries or shorten values.`);
|
|
81
|
+
}
|
|
82
|
+
await client.execute({
|
|
83
|
+
sql: `INSERT OR REPLACE INTO core_memory (agent_id, key, value, updated_at)
|
|
84
|
+
VALUES (?, ?, ?, ?)`,
|
|
85
|
+
args: [agentId, key, value, (/* @__PURE__ */ new Date()).toISOString()]
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
async function deleteCoreMemory(agentId, key) {
|
|
89
|
+
const { getClient } = await import("./lib/database.js");
|
|
90
|
+
const client = getClient();
|
|
91
|
+
const result = await client.execute({
|
|
92
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
93
|
+
args: [agentId, key]
|
|
94
|
+
});
|
|
95
|
+
return (result.rowsAffected ?? 0) > 0;
|
|
96
|
+
}
|
|
97
|
+
function formatCoreMemoryBlock(entries) {
|
|
98
|
+
if (entries.length === 0) return null;
|
|
99
|
+
const lines = ["## Core Memory (always in context)", ""];
|
|
100
|
+
for (const e of entries) {
|
|
101
|
+
lines.push(`- **${e.key}:** ${e.value}`);
|
|
102
|
+
}
|
|
103
|
+
return lines.join("\n");
|
|
104
|
+
}
|
|
105
|
+
export {
|
|
106
|
+
deleteCoreMemory,
|
|
107
|
+
formatCoreMemoryBlock,
|
|
108
|
+
getCoreMemory,
|
|
109
|
+
setCoreMemory
|
|
110
|
+
};
|
|
@@ -0,0 +1,110 @@
|
|
|
1
|
+
import "./chunk-MLKGABMK.js";
|
|
2
|
+
|
|
3
|
+
// src/lib/core-memory.ts
|
|
4
|
+
var MAX_CORE_ENTRIES = 10;
|
|
5
|
+
var MAX_ENTRY_LENGTH = 500;
|
|
6
|
+
var MAX_TOTAL_CHARS = 5e3;
|
|
7
|
+
async function getCoreMemory(agentId) {
|
|
8
|
+
try {
|
|
9
|
+
const { getClient } = await import("./lib/database.js");
|
|
10
|
+
const client = getClient();
|
|
11
|
+
const result = await client.execute({
|
|
12
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
13
|
+
WHERE agent_id = ? ORDER BY key ASC`,
|
|
14
|
+
args: [agentId]
|
|
15
|
+
});
|
|
16
|
+
return result.rows.map((r) => ({
|
|
17
|
+
key: String(r.key),
|
|
18
|
+
value: String(r.value),
|
|
19
|
+
updatedAt: String(r.updated_at)
|
|
20
|
+
}));
|
|
21
|
+
} catch {
|
|
22
|
+
return [];
|
|
23
|
+
}
|
|
24
|
+
}
|
|
25
|
+
async function setCoreMemory(agentId, key, value) {
|
|
26
|
+
if (value.length > MAX_ENTRY_LENGTH) {
|
|
27
|
+
throw new Error(`Core memory value too long (${value.length}/${MAX_ENTRY_LENGTH} chars). Core memory is for key facts, not documents.`);
|
|
28
|
+
}
|
|
29
|
+
const { getClient } = await import("./lib/database.js");
|
|
30
|
+
const client = getClient();
|
|
31
|
+
const countResult = await client.execute({
|
|
32
|
+
sql: `SELECT COUNT(*) as cnt FROM core_memory WHERE agent_id = ?`,
|
|
33
|
+
args: [agentId]
|
|
34
|
+
});
|
|
35
|
+
const count = Number(countResult.rows[0]?.cnt ?? 0);
|
|
36
|
+
const existing = await client.execute({
|
|
37
|
+
sql: `SELECT key FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
38
|
+
args: [agentId, key]
|
|
39
|
+
});
|
|
40
|
+
if (existing.rows.length === 0 && count >= MAX_CORE_ENTRIES) {
|
|
41
|
+
const oldest = await client.execute({
|
|
42
|
+
sql: `SELECT key, value, updated_at FROM core_memory
|
|
43
|
+
WHERE agent_id = ? ORDER BY updated_at ASC LIMIT 1`,
|
|
44
|
+
args: [agentId]
|
|
45
|
+
});
|
|
46
|
+
if (oldest.rows.length > 0) {
|
|
47
|
+
const oldKey = String(oldest.rows[0].key);
|
|
48
|
+
const oldValue = String(oldest.rows[0].value);
|
|
49
|
+
try {
|
|
50
|
+
const { randomUUID } = await import("crypto");
|
|
51
|
+
const { writeMemory } = await import("./lib/store.js");
|
|
52
|
+
await writeMemory({
|
|
53
|
+
id: randomUUID(),
|
|
54
|
+
agent_id: agentId,
|
|
55
|
+
agent_role: "core-demotion",
|
|
56
|
+
session_id: "core-memory-demotion",
|
|
57
|
+
timestamp: (/* @__PURE__ */ new Date()).toISOString(),
|
|
58
|
+
tool_name: "core_memory_demotion",
|
|
59
|
+
project_name: "exe-os",
|
|
60
|
+
has_error: false,
|
|
61
|
+
raw_text: `[Demoted from core memory] ${oldKey}: ${oldValue}`,
|
|
62
|
+
vector: null
|
|
63
|
+
});
|
|
64
|
+
} catch {
|
|
65
|
+
}
|
|
66
|
+
await client.execute({
|
|
67
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
68
|
+
args: [agentId, oldKey]
|
|
69
|
+
});
|
|
70
|
+
process.stderr.write(`[core-memory] Auto-demoted "${oldKey}" to regular memory (core full at ${MAX_CORE_ENTRIES})
|
|
71
|
+
`);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const sizeResult = await client.execute({
|
|
75
|
+
sql: `SELECT COALESCE(SUM(LENGTH(value)), 0) as total FROM core_memory WHERE agent_id = ? AND key != ?`,
|
|
76
|
+
args: [agentId, key]
|
|
77
|
+
});
|
|
78
|
+
const currentSize = Number(sizeResult.rows[0]?.total ?? 0);
|
|
79
|
+
if (currentSize + value.length > MAX_TOTAL_CHARS) {
|
|
80
|
+
throw new Error(`Core memory would exceed ${MAX_TOTAL_CHARS} char limit. Delete entries or shorten values.`);
|
|
81
|
+
}
|
|
82
|
+
await client.execute({
|
|
83
|
+
sql: `INSERT OR REPLACE INTO core_memory (agent_id, key, value, updated_at)
|
|
84
|
+
VALUES (?, ?, ?, ?)`,
|
|
85
|
+
args: [agentId, key, value, (/* @__PURE__ */ new Date()).toISOString()]
|
|
86
|
+
});
|
|
87
|
+
}
|
|
88
|
+
async function deleteCoreMemory(agentId, key) {
|
|
89
|
+
const { getClient } = await import("./lib/database.js");
|
|
90
|
+
const client = getClient();
|
|
91
|
+
const result = await client.execute({
|
|
92
|
+
sql: `DELETE FROM core_memory WHERE agent_id = ? AND key = ?`,
|
|
93
|
+
args: [agentId, key]
|
|
94
|
+
});
|
|
95
|
+
return (result.rowsAffected ?? 0) > 0;
|
|
96
|
+
}
|
|
97
|
+
function formatCoreMemoryBlock(entries) {
|
|
98
|
+
if (entries.length === 0) return null;
|
|
99
|
+
const lines = ["## Core Memory (always in context)", ""];
|
|
100
|
+
for (const e of entries) {
|
|
101
|
+
lines.push(`- **${e.key}:** ${e.value}`);
|
|
102
|
+
}
|
|
103
|
+
return lines.join("\n");
|
|
104
|
+
}
|
|
105
|
+
export {
|
|
106
|
+
deleteCoreMemory,
|
|
107
|
+
formatCoreMemoryBlock,
|
|
108
|
+
getCoreMemory,
|
|
109
|
+
setCoreMemory
|
|
110
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
import {
|
|
2
|
+
_setStatePath,
|
|
3
|
+
applyRemoteUpdate,
|
|
4
|
+
destroyCrdtDoc,
|
|
5
|
+
getDiffUpdate,
|
|
6
|
+
getFullState,
|
|
7
|
+
getStateVector,
|
|
8
|
+
importExistingBehaviors,
|
|
9
|
+
importExistingMemories,
|
|
10
|
+
initCrdtDoc,
|
|
11
|
+
isCrdtSyncEnabled,
|
|
12
|
+
onUpdate,
|
|
13
|
+
readAllBehaviors,
|
|
14
|
+
readAllMemories,
|
|
15
|
+
rebuildFromDb
|
|
16
|
+
} from "./chunk-LVZW4WQY.js";
|
|
17
|
+
import "./chunk-MLKGABMK.js";
|
|
18
|
+
export {
|
|
19
|
+
_setStatePath,
|
|
20
|
+
applyRemoteUpdate,
|
|
21
|
+
destroyCrdtDoc,
|
|
22
|
+
getDiffUpdate,
|
|
23
|
+
getFullState,
|
|
24
|
+
getStateVector,
|
|
25
|
+
importExistingBehaviors,
|
|
26
|
+
importExistingMemories,
|
|
27
|
+
initCrdtDoc,
|
|
28
|
+
isCrdtSyncEnabled,
|
|
29
|
+
onUpdate,
|
|
30
|
+
readAllBehaviors,
|
|
31
|
+
readAllMemories,
|
|
32
|
+
rebuildFromDb
|
|
33
|
+
};
|
|
@@ -0,0 +1,206 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sessionScopeFilter
|
|
3
|
+
} from "./chunk-P2QTTEYP.js";
|
|
4
|
+
import "./chunk-A3G4UXNA.js";
|
|
5
|
+
import "./chunk-5CHYEKMH.js";
|
|
6
|
+
import "./chunk-4JERP7NT.js";
|
|
7
|
+
import "./chunk-TSBMSHMM.js";
|
|
8
|
+
import "./chunk-MVW62NIZ.js";
|
|
9
|
+
import "./chunk-OYNKIAVW.js";
|
|
10
|
+
import "./chunk-CX6GL3ZJ.js";
|
|
11
|
+
import "./chunk-XIT6ONPY.js";
|
|
12
|
+
import "./chunk-XJUUWHVN.js";
|
|
13
|
+
import "./chunk-NGP6LSV2.js";
|
|
14
|
+
import "./chunk-C4BIYP5C.js";
|
|
15
|
+
import "./chunk-CVYC6DUW.js";
|
|
16
|
+
import "./chunk-OPU3NYOO.js";
|
|
17
|
+
import "./chunk-GJV3WDWM.js";
|
|
18
|
+
import "./chunk-MP2AFCGL.js";
|
|
19
|
+
import "./chunk-VF6VT4MR.js";
|
|
20
|
+
import "./chunk-HYZV25LY.js";
|
|
21
|
+
import {
|
|
22
|
+
getClient,
|
|
23
|
+
getEmployeeByRole,
|
|
24
|
+
loadEmployeesSync
|
|
25
|
+
} from "./chunk-RHZ2CRJU.js";
|
|
26
|
+
import "./chunk-2I23RPSI.js";
|
|
27
|
+
import "./chunk-P2DOIWQG.js";
|
|
28
|
+
import "./chunk-FXU7JOXK.js";
|
|
29
|
+
import "./chunk-MOZ2YQ54.js";
|
|
30
|
+
import "./chunk-VXIMSRTO.js";
|
|
31
|
+
import "./chunk-LYH5HE24.js";
|
|
32
|
+
import "./chunk-MLKGABMK.js";
|
|
33
|
+
|
|
34
|
+
// src/lib/cto-delegation-gate.ts
|
|
35
|
+
import os from "os";
|
|
36
|
+
import path from "path";
|
|
37
|
+
import { existsSync, readFileSync, statSync } from "fs";
|
|
38
|
+
var GATED_ROLE = "CTO";
|
|
39
|
+
function resolveGatedAgent() {
|
|
40
|
+
try {
|
|
41
|
+
const employees = loadEmployeesSync();
|
|
42
|
+
const cto = getEmployeeByRole(employees, GATED_ROLE);
|
|
43
|
+
return cto?.name ?? "";
|
|
44
|
+
} catch {
|
|
45
|
+
return "";
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
var GATED_AGENT = resolveGatedAgent();
|
|
49
|
+
function getGatedAgent() {
|
|
50
|
+
return resolveGatedAgent() || GATED_AGENT;
|
|
51
|
+
}
|
|
52
|
+
var BLOCKED_PATH_PREFIXES = [
|
|
53
|
+
"src/",
|
|
54
|
+
"tests/",
|
|
55
|
+
"scripts/",
|
|
56
|
+
"bin/",
|
|
57
|
+
".github/workflows/",
|
|
58
|
+
".claude/skills/"
|
|
59
|
+
];
|
|
60
|
+
var BLOCKED_FILENAMES = [
|
|
61
|
+
"package.json",
|
|
62
|
+
"tsconfig.json",
|
|
63
|
+
"docker-compose.yml"
|
|
64
|
+
];
|
|
65
|
+
var BLOCKED_DOCKERFILE_PREFIX = "Dockerfile";
|
|
66
|
+
var BLOCKED_EXTENSIONS = [
|
|
67
|
+
".ts",
|
|
68
|
+
".js",
|
|
69
|
+
".tsx",
|
|
70
|
+
".jsx",
|
|
71
|
+
".rs",
|
|
72
|
+
".py",
|
|
73
|
+
".go",
|
|
74
|
+
".sh",
|
|
75
|
+
".yaml",
|
|
76
|
+
".yml",
|
|
77
|
+
".prisma",
|
|
78
|
+
".sql"
|
|
79
|
+
];
|
|
80
|
+
var EXEMPT_MD_DIR_PREFIXES = [
|
|
81
|
+
".planning/",
|
|
82
|
+
"exe/output/",
|
|
83
|
+
"exe/",
|
|
84
|
+
"docs/"
|
|
85
|
+
];
|
|
86
|
+
var RECENT_DISPATCH_WINDOW_MS = 5 * 60 * 1e3;
|
|
87
|
+
var SCRATCHPAD_MAX_AGE_MS = 10 * 60 * 1e3;
|
|
88
|
+
var SCRATCHPAD_ESCAPE_PATTERN = /^(?:ENGINEER|TOM)-CAPABLE:\s*NO\s*—\s*reason:\s*\S+/m;
|
|
89
|
+
function toWorkspaceRelative(filePath, cwd = process.cwd()) {
|
|
90
|
+
const normalized = path.normalize(filePath);
|
|
91
|
+
if (normalized.startsWith(cwd + path.sep)) {
|
|
92
|
+
return normalized.slice(cwd.length + 1);
|
|
93
|
+
}
|
|
94
|
+
if (path.isAbsolute(normalized)) {
|
|
95
|
+
return path.basename(normalized);
|
|
96
|
+
}
|
|
97
|
+
return normalized;
|
|
98
|
+
}
|
|
99
|
+
function isDockerfile(basename) {
|
|
100
|
+
return basename === BLOCKED_DOCKERFILE_PREFIX || basename.startsWith(`${BLOCKED_DOCKERFILE_PREFIX}.`);
|
|
101
|
+
}
|
|
102
|
+
function classifyPath(filePath, cwd) {
|
|
103
|
+
const rel = toWorkspaceRelative(filePath, cwd);
|
|
104
|
+
const basename = path.basename(rel);
|
|
105
|
+
const ext = path.extname(rel).toLowerCase();
|
|
106
|
+
if (ext === ".md") {
|
|
107
|
+
for (const prefix of EXEMPT_MD_DIR_PREFIXES) {
|
|
108
|
+
if (rel.startsWith(prefix)) return "exempt";
|
|
109
|
+
}
|
|
110
|
+
if (!BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) {
|
|
111
|
+
return "exempt";
|
|
112
|
+
}
|
|
113
|
+
}
|
|
114
|
+
if (BLOCKED_FILENAMES.includes(basename)) return "code";
|
|
115
|
+
if (isDockerfile(basename)) return "code";
|
|
116
|
+
if (BLOCKED_EXTENSIONS.includes(ext)) return "code";
|
|
117
|
+
if (BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) return "code";
|
|
118
|
+
return "exempt";
|
|
119
|
+
}
|
|
120
|
+
async function hasRecentEngineerDispatch(now = Date.now()) {
|
|
121
|
+
try {
|
|
122
|
+
const client = getClient();
|
|
123
|
+
const engineers = loadEmployeesSync().filter(
|
|
124
|
+
(e) => e.role.toLowerCase() === "principal engineer"
|
|
125
|
+
);
|
|
126
|
+
const engineerNames = engineers.map((e) => e.name);
|
|
127
|
+
const gatedAgent = getGatedAgent();
|
|
128
|
+
if (!gatedAgent) return false;
|
|
129
|
+
if (engineerNames.length === 0) return false;
|
|
130
|
+
const placeholders = engineerNames.map(() => "?").join(",");
|
|
131
|
+
const ydScope = sessionScopeFilter();
|
|
132
|
+
const result = await client.execute({
|
|
133
|
+
sql: `SELECT MAX(created_at) AS last_dispatch
|
|
134
|
+
FROM tasks
|
|
135
|
+
WHERE assigned_by = ? AND assigned_to IN (${placeholders})${ydScope.sql}`,
|
|
136
|
+
args: [gatedAgent, ...engineerNames, ...ydScope.args]
|
|
137
|
+
});
|
|
138
|
+
const raw = result.rows[0]?.last_dispatch;
|
|
139
|
+
if (raw === null || raw === void 0) return false;
|
|
140
|
+
const parsed = Date.parse(String(raw));
|
|
141
|
+
if (Number.isNaN(parsed)) return false;
|
|
142
|
+
return now - parsed <= RECENT_DISPATCH_WINDOW_MS;
|
|
143
|
+
} catch {
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
}
|
|
147
|
+
function scratchpadPath(sessionId, homeDir = os.homedir()) {
|
|
148
|
+
return path.join(
|
|
149
|
+
homeDir,
|
|
150
|
+
".exe-os",
|
|
151
|
+
"session-cache",
|
|
152
|
+
`cto-scratchpad-${sessionId}.txt`
|
|
153
|
+
);
|
|
154
|
+
}
|
|
155
|
+
function hasValidScratchpadEscape(sessionId, now = Date.now(), homeDir = os.homedir()) {
|
|
156
|
+
const paths = [scratchpadPath(sessionId, homeDir)];
|
|
157
|
+
for (const filePath of paths) {
|
|
158
|
+
if (!existsSync(filePath)) continue;
|
|
159
|
+
try {
|
|
160
|
+
const stat = statSync(filePath);
|
|
161
|
+
if (now - stat.mtimeMs > SCRATCHPAD_MAX_AGE_MS) continue;
|
|
162
|
+
const body = readFileSync(filePath, "utf-8");
|
|
163
|
+
if (SCRATCHPAD_ESCAPE_PATTERN.test(body)) return true;
|
|
164
|
+
} catch {
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
return false;
|
|
168
|
+
}
|
|
169
|
+
var GATE_BLOCK_MESSAGE = [
|
|
170
|
+
"ACTION BLOCKED by CTO delegation gate. Your Write/Edit was DENIED \u2014 it did NOT execute.",
|
|
171
|
+
"This edit looks implementable by an engineer. You MUST either:",
|
|
172
|
+
" 1. Dispatch create_task to an engineer, OR",
|
|
173
|
+
" 2. Add ENGINEER-CAPABLE: NO with explicit reason to proceed yourself.",
|
|
174
|
+
"Do NOT report this action as successful. It was blocked. No file was changed.",
|
|
175
|
+
"If you are a sub-agent, report this FAILURE to your parent agent."
|
|
176
|
+
].join("\n");
|
|
177
|
+
async function evaluateDelegationGate(opts) {
|
|
178
|
+
const gatedAgent = getGatedAgent();
|
|
179
|
+
if (!gatedAgent || opts.agentId !== gatedAgent) {
|
|
180
|
+
return { outcome: "allow", reason: "agent_not_gated" };
|
|
181
|
+
}
|
|
182
|
+
if (!/^(Write|Edit)$/.test(opts.toolName)) {
|
|
183
|
+
return { outcome: "allow", reason: "tool_not_gated" };
|
|
184
|
+
}
|
|
185
|
+
if (classifyPath(opts.filePath, opts.cwd) === "exempt") {
|
|
186
|
+
return { outcome: "allow", reason: "exempt_path" };
|
|
187
|
+
}
|
|
188
|
+
if (await hasRecentEngineerDispatch(opts.now)) {
|
|
189
|
+
return { outcome: "allow", reason: "recent_engineer_dispatch" };
|
|
190
|
+
}
|
|
191
|
+
if (hasValidScratchpadEscape(opts.sessionId, opts.now, opts.homeDir)) {
|
|
192
|
+
return { outcome: "allow", reason: "scratchpad_escape" };
|
|
193
|
+
}
|
|
194
|
+
return { outcome: "block", reason: "no_delegation_no_escape" };
|
|
195
|
+
}
|
|
196
|
+
export {
|
|
197
|
+
GATED_AGENT,
|
|
198
|
+
GATED_ROLE,
|
|
199
|
+
GATE_BLOCK_MESSAGE,
|
|
200
|
+
classifyPath,
|
|
201
|
+
evaluateDelegationGate,
|
|
202
|
+
getGatedAgent,
|
|
203
|
+
hasRecentEngineerDispatch,
|
|
204
|
+
hasValidScratchpadEscape,
|
|
205
|
+
scratchpadPath
|
|
206
|
+
};
|