@askexenow/exe-os 0.9.299 → 0.9.301
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.customer.example +1 -1
- package/deploy/compose/.env.example +1 -1
- package/deploy/compose/docker-compose.yml +31 -5
- package/deploy/compose/erp-nginx/nginx.conf +6 -3
- package/deploy/compose/generate-env.ts +1 -1
- package/deploy/compose/observability/otel-collector-config.yaml +10 -1
- package/deploy/compose/setup.sh +1 -1
- package/dist/active-agent-56J56WW5.js +27 -0
- package/dist/active-agent-UNJO6AJ2.js +27 -0
- package/dist/active-agent-VDWK7TES.js +28 -0
- package/dist/active-agent-Y5LSIMVC.js +28 -0
- package/dist/agentic-ontology-MZ4WHFDE.js +25 -0
- package/dist/agentic-ontology-QEV7GI3T.js +25 -0
- package/dist/assets/com.askexe.exed.plist +6 -5
- package/dist/backfill-metadata-IHKI5GXV.js +600 -0
- package/dist/backfill-metadata-RQZ4BN7G.js +600 -0
- package/dist/backfill-metadata-ZU3SZNBD.js +600 -0
- package/dist/behaviors-A3L5CWMK.js +46 -0
- package/dist/behaviors-G4KWGS24.js +46 -0
- package/dist/behaviors-WO67R6C4.js +46 -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 +6 -6
- package/dist/bin/backfill-responses.js +6 -6
- package/dist/bin/backfill-vectors.js +8 -8
- package/dist/bin/bulk-sync-postgres.js +13 -7
- package/dist/bin/cc-doctor.js +5 -5
- package/dist/bin/cleanup-stale-review-tasks.js +10 -10
- package/dist/bin/cli.js +16 -16
- package/dist/bin/deferred-daemon-restart.js +1 -1
- package/dist/bin/exe-agent-config.js +2 -2
- package/dist/bin/exe-agent.js +10 -10
- package/dist/bin/exe-assign.js +8 -8
- package/dist/bin/exe-boot.js +36 -21
- package/dist/bin/exe-call.js +4 -4
- package/dist/bin/exe-cloud.js +13 -7
- package/dist/bin/exe-dispatch.js +10 -10
- package/dist/bin/exe-doctor.js +2 -2
- 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 +5 -5
- package/dist/bin/exe-heartbeat.js +10 -10
- package/dist/bin/exe-kill.js +13 -13
- package/dist/bin/exe-launch-agent.js +29 -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 +10 -10
- 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 +13 -7
- 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/exe-watchdog.js +3 -3
- package/dist/bin/git-sweep.js +11 -11
- package/dist/bin/graph-backfill.js +6 -6
- package/dist/bin/graph-export.js +5 -5
- package/dist/bin/import-history.js +9 -9
- package/dist/bin/install-launchd.js +7 -3
- package/dist/bin/install.js +19 -15
- 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/pre-publish.js +24 -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/bin/stack-update.js +123 -3
- package/dist/bin/vps-health-gate.js +1 -1
- package/dist/capability-cards-VTGDTOZ4.js +89 -0
- package/dist/capability-cards-XAQSL26B.js +89 -0
- package/dist/capacity-monitor-6MQLFFQT.js +51 -0
- package/dist/capacity-monitor-BB3LKJLE.js +51 -0
- package/dist/capacity-monitor-G2MAJPRP.js +51 -0
- package/dist/catchup-brief-BQSL5M5S.js +175 -0
- package/dist/catchup-brief-COALBX6L.js +175 -0
- package/dist/catchup-brief-VBGEJQRS.js +175 -0
- package/dist/cc-binary-detect-B5JDCJ5J.js +19 -0
- package/dist/chunk-22LDUTY7.js +14597 -0
- package/dist/chunk-24JVDLQJ.js +345 -0
- package/dist/chunk-24M4AJPG.js +128 -0
- package/dist/chunk-2B7RCTPT.js +85 -0
- package/dist/chunk-2QBA6YE6.js +127 -0
- package/dist/chunk-2RGDEBZC.js +731 -0
- package/dist/chunk-2T3OYZMR.js +1158 -0
- package/dist/chunk-32DBQWR5.js +333 -0
- package/dist/chunk-3ABY3QDX.js +199 -0
- package/dist/chunk-3EOPMTG2.js +128 -0
- package/dist/chunk-3G3ECFB5.js +668 -0
- package/dist/chunk-3LHOFGHT.js +280 -0
- package/dist/chunk-3NS4V4JW.js +382 -0
- package/dist/chunk-3NYY2NZ3.js +836 -0
- package/dist/chunk-3RA62PNQ.js +58 -0
- package/dist/chunk-3ROUD5WA.js +97 -0
- package/dist/chunk-3RY2ARDN.js +129 -0
- package/dist/chunk-3XRS5AVV.js +567 -0
- package/dist/chunk-3Y5IRIRU.js +290 -0
- package/dist/chunk-3YK7X5FD.js +1186 -0
- package/dist/chunk-3ZWWUKBI.js +210 -0
- package/dist/chunk-463G3VAH.js +122 -0
- package/dist/chunk-4L6PVYFE.js +54 -0
- package/dist/chunk-4LC7BFI2.js +76 -0
- package/dist/chunk-4O67LBMK.js +377 -0
- package/dist/chunk-4OIU3N6U.js +167 -0
- package/dist/chunk-4Z3FWLOE.js +836 -0
- package/dist/chunk-5BAU4T5G.js +208 -0
- package/dist/chunk-5FP7YHCG.js +1158 -0
- package/dist/chunk-5SYYMNPE.js +30 -0
- package/dist/chunk-5TO5PH7O.js +304 -0
- package/dist/chunk-5U3JZP62.js +1352 -0
- package/dist/chunk-5VNFXIGF.js +85 -0
- package/dist/chunk-5XD2Y463.js +402 -0
- package/dist/chunk-63AENHJC.js +123 -0
- package/dist/chunk-673IFJYB.js +731 -0
- package/dist/chunk-6UVUJNLY.js +1186 -0
- package/dist/chunk-7AWH47AR.js +448 -0
- package/dist/chunk-7KPWYWYL.js +290 -0
- package/dist/chunk-7P4B6AEP.js +227 -0
- package/dist/chunk-7URNGDEY.js +2145 -0
- package/dist/chunk-7VHOALNC.js +244 -0
- package/dist/chunk-ADZQBZOX.js +122 -0
- package/dist/chunk-APSZAEDO.js +1186 -0
- package/dist/chunk-ASHF6VO4.js +2265 -0
- package/dist/chunk-ASJHCAVL.js +38 -0
- package/dist/chunk-BT2LEHIW.js +448 -0
- package/dist/chunk-BTS5QUWB.js +50 -0
- package/dist/chunk-BWJDJ3BS.js +604 -0
- package/dist/chunk-CME46VWP.js +150 -0
- package/dist/chunk-D3ICCKXY.js +54 -0
- package/dist/chunk-D3IOU3NO.js +377 -0
- package/dist/chunk-DFGXRKI2.js +221 -0
- package/dist/chunk-DICIFTCS.js +150 -0
- package/dist/chunk-DIFI5JDC.js +76 -0
- package/dist/chunk-DO65VHQZ.js +128 -0
- package/dist/chunk-DPOIJ5SM.js +284 -0
- package/dist/chunk-E2OMUBXQ.js +567 -0
- package/dist/chunk-ECMXIV6N.js +97 -0
- package/dist/chunk-EDMVA3PT.js +727 -0
- package/dist/chunk-F5OSXH4A.js +4388 -0
- package/dist/chunk-F5OWHPRG.js +236 -0
- package/dist/chunk-F7MZA3QP.js +199 -0
- package/dist/chunk-FAZNXNA5.js +33 -0
- package/dist/chunk-FCHG5RC4.js +197 -0
- package/dist/chunk-FFKSPZO2.js +157 -0
- package/dist/chunk-FNHYH5U6.js +331 -0
- package/dist/chunk-FRNXQSB4.js +134 -0
- package/dist/chunk-FTAASABV.js +362 -0
- package/dist/chunk-FWPDAQ6Q.js +1350 -0
- package/dist/chunk-FZB73QOI.js +210 -0
- package/dist/chunk-GBL5QSTM.js +197 -0
- package/dist/chunk-GJBR6QLD.js +630 -0
- package/dist/chunk-GRSYAHKI.js +535 -0
- package/dist/chunk-GRXWINOW.js +244 -0
- package/dist/chunk-GUPNVUG5.js +348 -0
- package/dist/chunk-GY66UPMX.js +167 -0
- package/dist/chunk-HCCG67BY.js +43 -0
- package/dist/chunk-HCSZZXZZ.js +197 -0
- package/dist/chunk-HNGNZU62.js +240 -0
- package/dist/chunk-HP2D5LIE.js +214 -0
- package/dist/chunk-HUABQHDC.js +1352 -0
- package/dist/chunk-HYKO2LNW.js +157 -0
- package/dist/chunk-IFL6DG2K.js +181 -0
- package/dist/chunk-IKPQRHVQ.js +304 -0
- package/dist/chunk-J5HFRVNW.js +362 -0
- package/dist/chunk-J6SD7LT2.js +171 -0
- package/dist/chunk-JCWA3X6A.js +402 -0
- package/dist/chunk-JHPK33IP.js +2162 -0
- package/dist/chunk-JURL2S27.js +128 -0
- package/dist/chunk-JWGDH5I2.js +127 -0
- package/dist/chunk-KBXQFXYM.js +567 -0
- package/dist/chunk-KGY5QIOJ.js +1350 -0
- package/dist/chunk-KLES22FB.js +1094 -0
- package/dist/chunk-KPUYYOFS.js +122 -0
- package/dist/chunk-KY43UELJ.js +331 -0
- package/dist/chunk-L32V4O5Z.js +58 -0
- package/dist/chunk-LAFARYU5.js +456 -0
- package/dist/chunk-LC7ETNTJ.js +1350 -0
- package/dist/chunk-LEJ5FKIK.js +55 -0
- package/dist/chunk-LNLLCAI4.js +377 -0
- package/dist/chunk-LQWZYMNU.js +448 -0
- package/dist/chunk-LSDXEHKL.js +381 -0
- package/dist/chunk-LY3SOO73.js +76 -0
- package/dist/chunk-M6CIHXXB.js +159 -0
- package/dist/chunk-MJOQ35DX.js +427 -0
- package/dist/chunk-MO5HER5Y.js +345 -0
- package/dist/chunk-MS2EOZJQ.js +290 -0
- package/dist/chunk-MUIMJGSQ.js +128 -0
- package/dist/chunk-MY4TGLT6.js +284 -0
- package/dist/chunk-N3ARGCVG.js +345 -0
- package/dist/chunk-N4XG2M2U.js +735 -0
- package/dist/chunk-N72JNFJ4.js +535 -0
- package/dist/chunk-NJMPNYBS.js +427 -0
- package/dist/chunk-NM3AUMFE.js +2145 -0
- package/dist/chunk-NPPQ3TR4.js +735 -0
- package/dist/chunk-NTWF4DAF.js +581 -0
- package/dist/chunk-NXL3VKXM.js +331 -0
- package/dist/chunk-OJACH2JF.js +128 -0
- package/dist/chunk-OMSLHEEF.js +456 -0
- package/dist/chunk-OO4IFABD.js +382 -0
- package/dist/chunk-OYIP3QVN.js +167 -0
- package/dist/chunk-P2IOW54H.js +668 -0
- package/dist/chunk-P5KXQ3RN.js +731 -0
- package/dist/chunk-P5UXP53T.js +81 -0
- package/dist/chunk-PH6VRRFR.js +395 -0
- package/dist/chunk-Q3GKOF7Z.js +85 -0
- package/dist/chunk-Q65NCNL4.js +1352 -0
- package/dist/chunk-QIGS2LRT.js +735 -0
- package/dist/chunk-QKBN3CY2.js +381 -0
- package/dist/chunk-QNNAVMQH.js +1094 -0
- package/dist/chunk-QODDW4YI.js +171 -0
- package/dist/chunk-QPAYPTSH.js +2162 -0
- package/dist/chunk-QRWDJ5RI.js +381 -0
- package/dist/chunk-RBFZCHVB.js +105 -0
- package/dist/chunk-RCEULTPF.js +185 -0
- package/dist/chunk-RCGHXBCX.js +630 -0
- package/dist/chunk-ROSCLRTH.js +204 -0
- package/dist/chunk-RYAOSGUW.js +227 -0
- package/dist/chunk-S2SPGHPY.js +38 -0
- package/dist/chunk-S73ZAJ2S.js +262 -0
- package/dist/chunk-SBPEWD7Z.js +171 -0
- package/dist/chunk-SDPUWZP5.js +333 -0
- package/dist/chunk-SJ4UF7YK.js +1094 -0
- package/dist/chunk-SOZ7D77I.js +204 -0
- package/dist/chunk-SVLSHDNL.js +54 -0
- package/dist/chunk-SVUYBT5N.js +262 -0
- package/dist/chunk-T7PTLVJV.js +284 -0
- package/dist/chunk-TDX2LK2M.js +240 -0
- package/dist/chunk-TGUSLO4B.js +50 -0
- package/dist/chunk-TPJH6PE6.js +1158 -0
- package/dist/chunk-TVW7EDOJ.js +382 -0
- package/dist/chunk-TYRUIE6P.js +58 -0
- package/dist/chunk-U5RKGLV6.js +50 -0
- package/dist/chunk-UFGTHBHP.js +127 -0
- package/dist/chunk-ULCYWCPI.js +1079 -0
- package/dist/chunk-UN5EPVBN.js +14597 -0
- package/dist/chunk-URLH7ZVR.js +70 -0
- package/dist/chunk-USYRTGR7.js +402 -0
- package/dist/chunk-V4ABCEHM.js +30 -0
- package/dist/chunk-V6LOEOXG.js +3372 -0
- package/dist/chunk-VAZOVAW4.js +2162 -0
- package/dist/chunk-VEUQVKKT.js +185 -0
- package/dist/chunk-VIDDJ5RF.js +214 -0
- package/dist/chunk-VKCNXOQ6.js +214 -0
- package/dist/chunk-VNB4ROYG.js +348 -0
- package/dist/chunk-VWUQFZFB.js +395 -0
- package/dist/chunk-W77GRCNA.js +85 -0
- package/dist/chunk-WB2B25UM.js +230 -0
- package/dist/chunk-WCUZX7F7.js +204 -0
- package/dist/chunk-WL5RMOZQ.js +362 -0
- package/dist/chunk-WPAXAOHD.js +1079 -0
- package/dist/chunk-WVMG4ZRH.js +14597 -0
- package/dist/chunk-WYVOTRRZ.js +129 -0
- package/dist/chunk-XABJRAUW.js +3346 -0
- package/dist/chunk-XQQ7D4I4.js +85 -0
- package/dist/chunk-YDFY6YCH.js +280 -0
- package/dist/chunk-YGUMRYCN.js +33 -0
- package/dist/chunk-YHJPTIPR.js +836 -0
- package/dist/chunk-YJSP5PPG.js +128 -0
- package/dist/chunk-YLKS7KKC.js +2145 -0
- package/dist/chunk-YOMETWOJ.js +4388 -0
- package/dist/chunk-YU3KEVCO.js +333 -0
- package/dist/chunk-Z4FVFSE3.js +81 -0
- package/dist/chunk-Z4TLSNUW.js +244 -0
- package/dist/chunk-ZDPU3JTF.js +221 -0
- package/dist/chunk-ZDY4LYAJ.js +81 -0
- package/dist/chunk-ZG33AACD.js +70 -0
- package/dist/chunk-ZKHPZ6KN.js +181 -0
- package/dist/chunk-ZO2TM5N5.js +97 -0
- package/dist/chunk-ZP6T5K6I.js +535 -0
- package/dist/chunk-ZR6ZJT32.js +123 -0
- package/dist/chunk-ZSUACDQC.js +4388 -0
- package/dist/co-activation-JGF5YIDU.js +74 -0
- package/dist/co-activation-XM25BLZM.js +74 -0
- package/dist/co-occurrence-CKEMDPWO.js +95 -0
- package/dist/co-occurrence-HLLC6GT2.js +95 -0
- package/dist/co-occurrence-W2LIAPHI.js +95 -0
- package/dist/code-context-index-FCL47WKE.js +30 -0
- package/dist/conversation-entity-extractor-WC2RU6RS.js +114 -0
- package/dist/core-memory-CRSR2PSL.js +110 -0
- package/dist/core-memory-VSKFRMEV.js +110 -0
- package/dist/core-memory-ZDA76EU3.js +110 -0
- package/dist/crdt-sync-6VH2YDVY.js +33 -0
- package/dist/crdt-sync-BJKZB6T6.js +33 -0
- package/dist/crm-webhook-E5PAFAUN.js +10 -0
- package/dist/crm-webhook-RXFPZJXP.js +10 -0
- package/dist/crm-webhook-Z26LEFKG.js +10 -0
- package/dist/cto-delegation-gate-45IBLPTK.js +280 -0
- package/dist/cto-delegation-gate-EMY6ZZ2F.js +280 -0
- package/dist/cto-delegation-gate-SF4EUB2Q.js +280 -0
- package/dist/daemon-orchestration-VB3BLYIT.js +143 -0
- package/dist/daemon-orchestration-W66UYGUD.js +143 -0
- package/dist/daemon-orchestration-Y5Y6YNE3.js +143 -0
- package/dist/db-backup-HFJ53IBU.js +43 -0
- package/dist/db-backup-NVUTS7L5.js +43 -0
- package/dist/doc-graph-extractor-ID45AQ2P.js +133 -0
- package/dist/doc-graph-extractor-MLYQYT4B.js +133 -0
- package/dist/doc-graph-extractor-SVFSXKL6.js +133 -0
- package/dist/dreaming-AZYRAGKA.js +34 -0
- package/dist/dreaming-N6B7KBIE.js +34 -0
- package/dist/dreaming-WG5CDUHX.js +34 -0
- package/dist/entity-boost-XAFCDDB6.js +375 -0
- package/dist/exe-drift-3SGA53CL.js +70 -0
- package/dist/exe-drift-CPUEAPIU.js +70 -0
- package/dist/exe-export-4RTGDV53.js +77 -0
- package/dist/exe-export-APUNLKWF.js +77 -0
- package/dist/exe-export-NM4SXB3P.js +77 -0
- package/dist/exe-import-6GLNCP62.js +80 -0
- package/dist/exe-import-AZMIF34Z.js +80 -0
- package/dist/exe-import-U4H4ES3Z.js +80 -0
- package/dist/exe-key-FIPXUTMF.js +673 -0
- package/dist/exe-key-LJV23AJI.js +673 -0
- package/dist/exe-key-WTLCMOYJ.js +673 -0
- package/dist/exe-snapshot-ILO3WSEC.js +338 -0
- package/dist/exe-snapshot-IODRQLBX.js +338 -0
- package/dist/exe-snapshot-ZOZBW7V6.js +338 -0
- package/dist/fast-db-init-7LYYUCSJ.js +7 -0
- package/dist/fast-db-init-ATRZGHOL.js +7 -0
- package/dist/fast-db-init-IU7GYFWB.js +7 -0
- package/dist/gateway/index.js +11 -11
- package/dist/git-staleness-GGCFPHQ5.js +112 -0
- package/dist/git-staleness-XNOKI4D3.js +112 -0
- package/dist/git-task-sweep-3MO4OVND.js +42 -0
- package/dist/git-task-sweep-M3SWXFKJ.js +42 -0
- package/dist/git-task-sweep-Y6KNWB67.js +42 -0
- package/dist/global-procedures-626WAU3I.js +22 -0
- package/dist/global-procedures-EBAPPWGZ.js +22 -0
- package/dist/graph-auto-extract-TKHQ4OR3.js +183 -0
- package/dist/graph-auto-extract-VGFEWFZX.js +183 -0
- package/dist/graph-auto-extract-VJOUQBPK.js +183 -0
- package/dist/graph-rag-KECA5TE4.js +35 -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-worker.js +3 -3
- package/dist/hooks/ingest.js +6 -6
- package/dist/hooks/instructions-loaded.js +4 -4
- package/dist/hooks/manifest.json +20 -20
- package/dist/hooks/notification.js +4 -4
- package/dist/hooks/post-compact.js +12 -12
- package/dist/hooks/post-tool-combined.js +6 -6
- package/dist/hooks/pre-compact.js +16 -16
- package/dist/hooks/pre-tool-use.js +15 -15
- package/dist/hooks/prompt-submit.js +28 -26
- package/dist/hooks/session-end.js +20 -20
- package/dist/hooks/session-start.js +12 -12
- package/dist/hooks/stop.js +18 -18
- package/dist/hooks/subagent-stop.js +11 -11
- package/dist/hooks/summary-worker.js +18 -18
- package/dist/index.js +20 -20
- package/dist/installer-37KFNAWE.js +344 -0
- package/dist/installer-3FB5EMPB.js +40 -0
- package/dist/installer-BRQ42CPB.js +344 -0
- package/dist/installer-F55NR4E2.js +298 -0
- package/dist/installer-KOYBUS4J.js +40 -0
- package/dist/installer-PXZJG256.js +298 -0
- package/dist/lib/cloud-sync.js +13 -7
- package/dist/lib/consolidation.js +7 -7
- package/dist/lib/database.js +6 -4
- package/dist/lib/db-daemon-client.js +11 -202
- package/dist/lib/db.js +6 -4
- package/dist/lib/embedder.js +3 -3
- package/dist/lib/employee-templates.js +4 -4
- package/dist/lib/employees.js +2 -2
- package/dist/lib/exe-daemon-client.js +2 -2
- package/dist/lib/exe-daemon.js +53 -51
- package/dist/lib/hybrid-search.js +5 -5
- package/dist/lib/identity.js +2 -2
- package/dist/lib/messaging.js +10 -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 +6 -6
- 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 +65 -63
- package/dist/mcp/server.js +66 -64
- 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 +7 -7
- 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-7KJZI7UD.js +31 -0
- package/dist/mcp-http-config-OF3MB7M5.js +31 -0
- package/dist/memory-cards-CPIZVXWI.js +180 -0
- package/dist/memory-cards-ZIT7ZKL5.js +180 -0
- package/dist/memory-graph-extractor-JIYWLBFF.js +22 -0
- package/dist/memory-graph-extractor-LY2VORZT.js +22 -0
- package/dist/memory-graph-extractor-MDPSLZDM.js +22 -0
- package/dist/memory-poisoning-defense-5UZT3WWA.js +224 -0
- package/dist/memory-poisoning-defense-SEM25TY5.js +224 -0
- package/dist/memory-queue-client-WKWRFERJ.js +16 -0
- package/dist/memory-reflection-J2W7CJ7C.js +244 -0
- package/dist/memory-reflection-TA2VQYPH.js +244 -0
- package/dist/message-queue-client-IFQQ2HI7.js +92 -0
- package/dist/notifications-CZBQ3H5T.js +47 -0
- package/dist/notifications-EIIL2EQV.js +47 -0
- package/dist/notifications-RLMSI4YE.js +47 -0
- package/dist/orchestration-events-TGQYA72K.js +27 -0
- package/dist/orchestration-events-VUYR6MXE.js +27 -0
- package/dist/orchestrator-JQD5G3CW.js +35 -0
- package/dist/orchestrator-MAMR4C37.js +35 -0
- package/dist/orchestrator-VE5WHEJH.js +35 -0
- package/dist/pipeline-router-3Q3YBYSM.js +15 -0
- package/dist/pipeline-router-DKXD6DJO.js +15 -0
- package/dist/pipeline-router-YNW63BY5.js +15 -0
- package/dist/plan-limits-YGXTYCW4.js +28 -0
- package/dist/plan-limits-ZM4MNZKY.js +28 -0
- package/dist/project-boot-E2TWYTAC.js +299 -0
- package/dist/project-boot-TDOZKKDR.js +299 -0
- package/dist/projection-worker-TMKUSVGD.js +1084 -0
- package/dist/projection-worker-WFPRM4AI.js +1084 -0
- package/dist/projection-worker-YKV3PFCV.js +1084 -0
- package/dist/prospective-memory-CNJDBNWF.js +232 -0
- package/dist/prospective-memory-OAFZUODU.js +232 -0
- package/dist/reranker-AFU75HEX.js +19 -0
- package/dist/reranker-RYNSJNDF.js +19 -0
- package/dist/reranker-YQIRNGDM.js +19 -0
- package/dist/retrieval-health-M5BVB7EV.js +12 -0
- package/dist/retrieval-health-RSQEIYIB.js +12 -0
- package/dist/review-polling-LGX7DUNT.js +126 -0
- package/dist/review-polling-MJBCYV4I.js +126 -0
- package/dist/review-polling-ZMB3OBPC.js +126 -0
- package/dist/runtime/index.js +16 -16
- package/dist/services/codex-reviewd/index.js +855 -0
- package/dist/session-events-5N47BRFK.js +38 -0
- package/dist/session-events-PT6SVS2P.js +38 -0
- package/dist/session-events-UTMCKDIN.js +38 -0
- package/dist/session-kill-telemetry-FRQA5MVD.js +31 -0
- package/dist/session-kill-telemetry-HKL2NQMR.js +31 -0
- package/dist/session-scope-2BD6QLNI.js +88 -0
- package/dist/session-scope-GQNCM6UQ.js +88 -0
- package/dist/session-scope-MMGM232A.js +88 -0
- package/dist/setup-wizard-SELXXVLD.js +12 -0
- package/dist/setup-wizard-W64I6SHC.js +12 -0
- package/dist/setup-wizard-X7YSRDNQ.js +12 -0
- package/dist/skill-refinement-CCP4ULZ3.js +159 -0
- package/dist/skill-refinement-FXCXTUS2.js +159 -0
- package/dist/skill-refinement-WCPDNHZ5.js +159 -0
- package/dist/stack-update-5VSGG36W.js +84 -0
- package/dist/steward-gate-JDR3SLH3.js +15 -0
- package/dist/steward-gate-PIXNK4BK.js +15 -0
- package/dist/task-enforcement-LEBWCYZT.js +506 -0
- package/dist/task-enforcement-VOSQRAQB.js +506 -0
- package/dist/task-enforcement-WCEA4FZI.js +506 -0
- package/dist/task-scope-CQZ33PRU.js +37 -0
- package/dist/task-scope-JTTEZKDU.js +37 -0
- package/dist/task-scope-L5GDL2AV.js +37 -0
- package/dist/tasks-crud-DC4GCXQQ.js +79 -0
- package/dist/tasks-crud-S36AFYYM.js +79 -0
- package/dist/tasks-crud-T32IRPXF.js +79 -0
- package/dist/tasks-notify-OBFVHJDP.js +40 -0
- package/dist/tasks-notify-OUQWUM6W.js +40 -0
- package/dist/tasks-notify-W2W2BJRB.js +40 -0
- package/dist/tasks-review-34WV7BX2.js +49 -0
- package/dist/tasks-review-N33MTHWJ.js +49 -0
- package/dist/tasks-review-OSBG2YN2.js +49 -0
- package/dist/telemetry-upload-3CSVO3J7.js +741 -0
- package/dist/telemetry-upload-EYHEWTKG.js +741 -0
- package/dist/telemetry-upload-XLBW4DRP.js +741 -0
- package/dist/token-budget-I6FMMDFX.js +86 -0
- package/dist/token-budget-ZG2MQ5GD.js +86 -0
- package/dist/tool-capability-index-IWQBQKM7.js +10 -0
- package/dist/tool-telemetry-2E3Z7CRV.js +17 -0
- package/dist/tool-telemetry-ODL4F2CW.js +17 -0
- package/dist/tui/App.js +17 -17
- package/dist/tui-data-VWT4Q5UT.js +260 -0
- package/dist/tui-data-XFBFBSBE.js +260 -0
- package/dist/tui-data-Z5UF7KEI.js +260 -0
- package/dist/wiki-acl-EUOPNUIQ.js +111 -0
- package/dist/wiki-acl-SZFHCEC4.js +111 -0
- package/dist/worker-gate-OOO6BWZ6.js +21 -0
- package/dist/worker-gate-OQMKAMP7.js +21 -0
- package/dist/worker-gate-ZPP3SZK6.js +21 -0
- package/dist/workflow-engine-P7WYJP2B.js +28 -0
- package/dist/workflow-engine-QY3IFFR2.js +28 -0
- package/dist/workflow-engine-UYNB5RTB.js +28 -0
- package/dist/worktree-CNOQZBNT.js +28 -0
- package/dist/worktree-H5C4LMQR.js +28 -0
- package/dist/worktree-sweep-KFWF3XZD.js +21 -0
- package/dist/worktree-sweep-SE7ITXC4.js +21 -0
- package/package.json +1 -1
- package/release-notes.json +117 -191
- package/src/commands/exe.md +18 -1
|
@@ -0,0 +1,81 @@
|
|
|
1
|
+
// src/bin/fast-db-init.ts
|
|
2
|
+
async function fastDbInit() {
|
|
3
|
+
const { isInitialized, getClient, setExternalClient } = await import("./lib/database.js");
|
|
4
|
+
if (isInitialized()) {
|
|
5
|
+
return getClient();
|
|
6
|
+
}
|
|
7
|
+
const forceDirect = process.env.EXE_DB_DIRECT === "1" || process.env.EXE_DB_READONLY === "1" || process.env.EXE_SKIP_DAEMON === "1";
|
|
8
|
+
if (!forceDirect) {
|
|
9
|
+
try {
|
|
10
|
+
const { connectEmbedDaemon, sendDaemonRequest, isClientConnected, disconnectClient } = await import("./lib/exe-daemon-client.js");
|
|
11
|
+
const { deserializeResultSet } = await import("./daemon-protocol-XW2OLNBS.js");
|
|
12
|
+
await Promise.race([
|
|
13
|
+
connectEmbedDaemon(),
|
|
14
|
+
new Promise((_, reject) => setTimeout(() => reject(new Error("Daemon socket timeout (2s)")), 2e3))
|
|
15
|
+
]);
|
|
16
|
+
if (isClientConnected()) {
|
|
17
|
+
const daemonClient = {
|
|
18
|
+
async execute(stmt) {
|
|
19
|
+
const sql = typeof stmt === "string" ? stmt : stmt.sql;
|
|
20
|
+
const args = typeof stmt === "string" ? [] : Array.isArray(stmt.args) ? stmt.args : [];
|
|
21
|
+
const resp = await sendDaemonRequest({ type: "db-execute", sql, args });
|
|
22
|
+
if (resp.error) throw new Error(String(resp.error));
|
|
23
|
+
if (resp.db) return deserializeResultSet(resp.db);
|
|
24
|
+
throw new Error("Unexpected daemon response");
|
|
25
|
+
},
|
|
26
|
+
async batch(stmts, mode) {
|
|
27
|
+
const statements = stmts.map((s) => {
|
|
28
|
+
const sql = typeof s === "string" ? s : s.sql;
|
|
29
|
+
const args = typeof s === "string" ? [] : Array.isArray(s.args) ? s.args : [];
|
|
30
|
+
return { sql, args };
|
|
31
|
+
});
|
|
32
|
+
const resp = await sendDaemonRequest({ type: "db-batch", statements, mode: mode ?? "deferred" });
|
|
33
|
+
if (resp.error) throw new Error(String(resp.error));
|
|
34
|
+
const batchResults = resp["db-batch"];
|
|
35
|
+
if (batchResults) return batchResults.map(deserializeResultSet);
|
|
36
|
+
throw new Error("Unexpected daemon batch response");
|
|
37
|
+
},
|
|
38
|
+
async transaction(_mode) {
|
|
39
|
+
throw new Error("Transactions not supported via daemon socket");
|
|
40
|
+
},
|
|
41
|
+
async executeMultiple(_sql) {
|
|
42
|
+
throw new Error("executeMultiple not supported via daemon socket");
|
|
43
|
+
},
|
|
44
|
+
async migrate(_stmts) {
|
|
45
|
+
throw new Error("migrate not supported via daemon socket");
|
|
46
|
+
},
|
|
47
|
+
sync() {
|
|
48
|
+
return Promise.resolve(void 0);
|
|
49
|
+
},
|
|
50
|
+
close() {
|
|
51
|
+
},
|
|
52
|
+
get closed() {
|
|
53
|
+
return false;
|
|
54
|
+
},
|
|
55
|
+
get protocol() {
|
|
56
|
+
return "file";
|
|
57
|
+
}
|
|
58
|
+
};
|
|
59
|
+
try {
|
|
60
|
+
await daemonClient.execute("SELECT 1");
|
|
61
|
+
} catch {
|
|
62
|
+
try {
|
|
63
|
+
disconnectClient();
|
|
64
|
+
} catch {
|
|
65
|
+
}
|
|
66
|
+
throw new Error("Daemon socket validation failed");
|
|
67
|
+
}
|
|
68
|
+
setExternalClient(daemonClient);
|
|
69
|
+
return daemonClient;
|
|
70
|
+
}
|
|
71
|
+
} catch {
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
const { initStore } = await import("./lib/store.js");
|
|
75
|
+
await initStore({ lightweight: true });
|
|
76
|
+
return getClient();
|
|
77
|
+
}
|
|
78
|
+
|
|
79
|
+
export {
|
|
80
|
+
fastDbInit
|
|
81
|
+
};
|
|
@@ -0,0 +1,395 @@
|
|
|
1
|
+
import {
|
|
2
|
+
EXE_AI_DIR
|
|
3
|
+
} from "./chunk-R36FAN53.js";
|
|
4
|
+
|
|
5
|
+
// src/lib/db-backup.ts
|
|
6
|
+
import { existsSync, readdirSync, unlinkSync, statSync, statfsSync } from "fs";
|
|
7
|
+
import { copyFile, mkdir, unlink, rename } from "fs/promises";
|
|
8
|
+
import path from "path";
|
|
9
|
+
var BACKUP_DIR = path.join(EXE_AI_DIR, "backups");
|
|
10
|
+
var DEFAULT_KEEP_DAYS = 3;
|
|
11
|
+
var DB_NAMES = ["memories.db", "exe-mem.db", "exe-os.db", "exe.db"];
|
|
12
|
+
var REASON_COUNT_CAP = {
|
|
13
|
+
// Bug 727b7b1e: a daemon OOM crash loop made a ~1.5GB pre-restart backup on
|
|
14
|
+
// EVERY restart. 22 crashes = 11GB of pre-restart snapshots with no rotation.
|
|
15
|
+
// Keep only the 2 newest — enough to recover, small enough not to fill disk.
|
|
16
|
+
"pre-restart": 2,
|
|
17
|
+
"pre-consolidation": 5,
|
|
18
|
+
"pre-fix": 5,
|
|
19
|
+
"pre-restore": 5,
|
|
20
|
+
// Bug 91b1b167: daily snapshots are full uncompressed SQLCipher copies
|
|
21
|
+
// (~2-3GB apiece on large enterprise DBs). Time-based rotation alone left
|
|
22
|
+
// 19GB accumulating when mtimes drifted / the disk guard tripped. A hard
|
|
23
|
+
// count cap is a belt-and-braces safety net on top of day-based rotation.
|
|
24
|
+
"daily": 3
|
|
25
|
+
};
|
|
26
|
+
var MIN_FREE_BYTES = 5 * 1024 * 1024 * 1024;
|
|
27
|
+
var STALE_TMP_MAX_AGE_MS = 60 * 60 * 1e3;
|
|
28
|
+
function findActiveDb() {
|
|
29
|
+
for (const name of DB_NAMES) {
|
|
30
|
+
const p = path.join(EXE_AI_DIR, name);
|
|
31
|
+
if (existsSync(p)) return p;
|
|
32
|
+
}
|
|
33
|
+
return null;
|
|
34
|
+
}
|
|
35
|
+
async function createBackup(reason = "manual") {
|
|
36
|
+
return createBackupAsync(reason);
|
|
37
|
+
}
|
|
38
|
+
async function createBackupAsync(reason = "manual", opts = {}) {
|
|
39
|
+
const dbPath = findActiveDb();
|
|
40
|
+
if (!dbPath) return null;
|
|
41
|
+
await mkdir(BACKUP_DIR, { recursive: true });
|
|
42
|
+
try {
|
|
43
|
+
let dbSize = 0;
|
|
44
|
+
try {
|
|
45
|
+
dbSize = statSync(dbPath).size;
|
|
46
|
+
} catch {
|
|
47
|
+
}
|
|
48
|
+
const freeBytes = getFreeBytes(BACKUP_DIR);
|
|
49
|
+
if (!hasEnoughDiskSpace(freeBytes, dbSize)) {
|
|
50
|
+
process.stderr.write(
|
|
51
|
+
`[db-backup] DISK GUARD: skipping "${reason}" backup \u2014 ${Math.round(freeBytes / 1024 / 1024)}MB free, need >${Math.round(Math.max(MIN_FREE_BYTES, dbSize * 2) / 1024 / 1024)}MB. Disk is nearly full; refusing to make it worse.
|
|
52
|
+
`
|
|
53
|
+
);
|
|
54
|
+
return null;
|
|
55
|
+
}
|
|
56
|
+
} catch {
|
|
57
|
+
}
|
|
58
|
+
const dbName = path.basename(dbPath, ".db");
|
|
59
|
+
const timestamp = (/* @__PURE__ */ new Date()).toISOString().replace(/[:.]/g, "-").slice(0, 19);
|
|
60
|
+
const backupName = `${dbName}-${reason}-${timestamp}.db`;
|
|
61
|
+
const backupPath = path.join(BACKUP_DIR, backupName);
|
|
62
|
+
const tmpBackupPath = `${backupPath}.tmp`;
|
|
63
|
+
const checkpointMode = opts.checkpointMode ?? "TRUNCATE";
|
|
64
|
+
try {
|
|
65
|
+
const { getClient } = await import("./lib/database.js");
|
|
66
|
+
const client = getClient();
|
|
67
|
+
await client.execute(`PRAGMA wal_checkpoint(${checkpointMode})`);
|
|
68
|
+
} catch {
|
|
69
|
+
try {
|
|
70
|
+
const { execFile: execFileCb } = await import("child_process");
|
|
71
|
+
const { promisify } = await import("util");
|
|
72
|
+
const execFileAsync = promisify(execFileCb);
|
|
73
|
+
await execFileAsync("sqlite3", [dbPath, `PRAGMA wal_checkpoint(${checkpointMode});`], { timeout: 3e4 });
|
|
74
|
+
} catch {
|
|
75
|
+
process.stderr.write(`[db-backup] WAL checkpoint skipped \u2014 proceeding with copy (backup may include stale WAL)
|
|
76
|
+
`);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
try {
|
|
80
|
+
await unlink(tmpBackupPath);
|
|
81
|
+
} catch {
|
|
82
|
+
}
|
|
83
|
+
await copyFile(dbPath, tmpBackupPath);
|
|
84
|
+
await rename(tmpBackupPath, backupPath);
|
|
85
|
+
try {
|
|
86
|
+
const { getClient } = await import("./lib/database.js");
|
|
87
|
+
const client = getClient();
|
|
88
|
+
const chk = await client.execute("PRAGMA quick_check;");
|
|
89
|
+
const result = String(chk.rows[0]?.quick_check ?? chk.rows[0]?.[0] ?? "").trim();
|
|
90
|
+
if (result && result !== "ok") {
|
|
91
|
+
process.stderr.write(`[db-backup] WARNING: backup source failed quick_check (${reason}): ${result}
|
|
92
|
+
`);
|
|
93
|
+
try {
|
|
94
|
+
await unlink(backupPath);
|
|
95
|
+
} catch {
|
|
96
|
+
}
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
} catch {
|
|
100
|
+
process.stderr.write(`[db-backup] Backup validation skipped (encrypted DB or CLI context) \u2014 proceeding with checkpoint-consistent copy.
|
|
101
|
+
`);
|
|
102
|
+
}
|
|
103
|
+
const walPath = dbPath + "-wal";
|
|
104
|
+
if (existsSync(walPath)) {
|
|
105
|
+
try {
|
|
106
|
+
await copyFile(walPath, backupPath + "-wal.tmp");
|
|
107
|
+
await rename(backupPath + "-wal.tmp", backupPath + "-wal");
|
|
108
|
+
} catch {
|
|
109
|
+
}
|
|
110
|
+
}
|
|
111
|
+
const shmPath = dbPath + "-shm";
|
|
112
|
+
if (existsSync(shmPath)) {
|
|
113
|
+
try {
|
|
114
|
+
await copyFile(shmPath, backupPath + "-shm.tmp");
|
|
115
|
+
await rename(backupPath + "-shm.tmp", backupPath + "-shm");
|
|
116
|
+
} catch {
|
|
117
|
+
}
|
|
118
|
+
}
|
|
119
|
+
return backupPath;
|
|
120
|
+
}
|
|
121
|
+
function rotateBackups(keepDays = DEFAULT_KEEP_DAYS) {
|
|
122
|
+
if (!existsSync(BACKUP_DIR)) return 0;
|
|
123
|
+
const cutoff = Date.now() - keepDays * 24 * 60 * 60 * 1e3;
|
|
124
|
+
let deleted = 0;
|
|
125
|
+
try {
|
|
126
|
+
const files = readdirSync(BACKUP_DIR);
|
|
127
|
+
for (const file of files) {
|
|
128
|
+
if (file.endsWith(".tmp")) continue;
|
|
129
|
+
if (!file.endsWith(".db") && !file.endsWith(".db-wal") && !file.endsWith(".db-shm")) continue;
|
|
130
|
+
const filePath = path.join(BACKUP_DIR, file);
|
|
131
|
+
try {
|
|
132
|
+
const stat = statSync(filePath);
|
|
133
|
+
if (stat.mtimeMs < cutoff) {
|
|
134
|
+
unlinkSync(filePath);
|
|
135
|
+
deleted++;
|
|
136
|
+
}
|
|
137
|
+
} catch {
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
} catch {
|
|
141
|
+
}
|
|
142
|
+
return deleted;
|
|
143
|
+
}
|
|
144
|
+
function selectBackupsToDelete(backups, keep) {
|
|
145
|
+
if (keep < 0) keep = 0;
|
|
146
|
+
const sorted = [...backups].sort((a, b) => b.mtimeMs - a.mtimeMs);
|
|
147
|
+
return sorted.slice(keep).map((b) => b.path);
|
|
148
|
+
}
|
|
149
|
+
function selectStaleTmpFiles(tmpFiles, cutoffMs) {
|
|
150
|
+
return tmpFiles.filter((f) => f.mtimeMs < cutoffMs).map((f) => f.path);
|
|
151
|
+
}
|
|
152
|
+
function cleanupStaleTmp(maxAgeMs = STALE_TMP_MAX_AGE_MS) {
|
|
153
|
+
if (!existsSync(BACKUP_DIR)) return 0;
|
|
154
|
+
const cutoffMs = Date.now() - maxAgeMs;
|
|
155
|
+
let deleted = 0;
|
|
156
|
+
try {
|
|
157
|
+
const candidates = [];
|
|
158
|
+
for (const file of readdirSync(BACKUP_DIR)) {
|
|
159
|
+
if (!file.endsWith(".tmp")) continue;
|
|
160
|
+
const filePath = path.join(BACKUP_DIR, file);
|
|
161
|
+
try {
|
|
162
|
+
candidates.push({ path: filePath, mtimeMs: statSync(filePath).mtimeMs });
|
|
163
|
+
} catch {
|
|
164
|
+
}
|
|
165
|
+
}
|
|
166
|
+
for (const target of selectStaleTmpFiles(candidates, cutoffMs)) {
|
|
167
|
+
try {
|
|
168
|
+
unlinkSync(target);
|
|
169
|
+
deleted++;
|
|
170
|
+
} catch {
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
} catch {
|
|
174
|
+
}
|
|
175
|
+
return deleted;
|
|
176
|
+
}
|
|
177
|
+
function hasEnoughDiskSpace(freeBytes, backupSizeBytes, minFreeBytes = MIN_FREE_BYTES) {
|
|
178
|
+
const required = Math.max(minFreeBytes, backupSizeBytes * 2);
|
|
179
|
+
return freeBytes >= required;
|
|
180
|
+
}
|
|
181
|
+
function getFreeBytes(dir) {
|
|
182
|
+
try {
|
|
183
|
+
const s = statfsSync(dir);
|
|
184
|
+
return s.bavail * s.bsize;
|
|
185
|
+
} catch {
|
|
186
|
+
return Number.POSITIVE_INFINITY;
|
|
187
|
+
}
|
|
188
|
+
}
|
|
189
|
+
async function quickCheckBackupSource(source) {
|
|
190
|
+
try {
|
|
191
|
+
const { execFile: execFileCb } = await import("child_process");
|
|
192
|
+
const { promisify } = await import("util");
|
|
193
|
+
const execFileAsync = promisify(execFileCb);
|
|
194
|
+
const { stdout } = await execFileAsync("sqlite3", [source, "PRAGMA quick_check;"], { timeout: 3e4 });
|
|
195
|
+
const result = String(stdout ?? "").trim();
|
|
196
|
+
if (result !== "ok") {
|
|
197
|
+
throw new Error(result || "quick_check returned no result");
|
|
198
|
+
}
|
|
199
|
+
} catch (err) {
|
|
200
|
+
const msg = err instanceof Error ? err.message : String(err);
|
|
201
|
+
if (/file is not a database|not an error/i.test(msg)) {
|
|
202
|
+
process.stderr.write(`[db-backup] Backup source quick_check unavailable for encrypted backup (${path.basename(source)}); proceeding with atomic restore.
|
|
203
|
+
`);
|
|
204
|
+
return;
|
|
205
|
+
}
|
|
206
|
+
throw new Error(`Backup source failed quick_check: ${msg}`);
|
|
207
|
+
}
|
|
208
|
+
}
|
|
209
|
+
function rotateBackupsByReason(reason, keep) {
|
|
210
|
+
if (!existsSync(BACKUP_DIR)) return 0;
|
|
211
|
+
let deleted = 0;
|
|
212
|
+
try {
|
|
213
|
+
const files = readdirSync(BACKUP_DIR);
|
|
214
|
+
const matches = [];
|
|
215
|
+
for (const file of files) {
|
|
216
|
+
if (file.endsWith(".tmp")) continue;
|
|
217
|
+
if (!file.endsWith(".db")) continue;
|
|
218
|
+
if (!file.includes(`-${reason}-`)) continue;
|
|
219
|
+
const filePath = path.join(BACKUP_DIR, file);
|
|
220
|
+
try {
|
|
221
|
+
matches.push({ path: filePath, mtimeMs: statSync(filePath).mtimeMs });
|
|
222
|
+
} catch {
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
for (const target of selectBackupsToDelete(matches, keep)) {
|
|
226
|
+
for (const p of [target, target + "-wal", target + "-shm"]) {
|
|
227
|
+
try {
|
|
228
|
+
if (existsSync(p)) {
|
|
229
|
+
unlinkSync(p);
|
|
230
|
+
if (p === target) deleted++;
|
|
231
|
+
}
|
|
232
|
+
} catch {
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
} catch {
|
|
237
|
+
}
|
|
238
|
+
return deleted;
|
|
239
|
+
}
|
|
240
|
+
function enforceRetention(reason, keepDays = DEFAULT_KEEP_DAYS) {
|
|
241
|
+
let deleted = rotateBackups(keepDays);
|
|
242
|
+
const cap = REASON_COUNT_CAP[reason];
|
|
243
|
+
if (typeof cap === "number") {
|
|
244
|
+
deleted += rotateBackupsByReason(reason, cap);
|
|
245
|
+
}
|
|
246
|
+
deleted += cleanupStaleTmp();
|
|
247
|
+
return deleted;
|
|
248
|
+
}
|
|
249
|
+
var QUARANTINE_KEEP = 2;
|
|
250
|
+
function pruneCorruptQuarantine(keep = QUARANTINE_KEEP) {
|
|
251
|
+
if (!existsSync(EXE_AI_DIR)) return 0;
|
|
252
|
+
let deleted = 0;
|
|
253
|
+
try {
|
|
254
|
+
const matches = [];
|
|
255
|
+
for (const file of readdirSync(EXE_AI_DIR)) {
|
|
256
|
+
if (!/\.corrupt-\d+$/.test(file)) continue;
|
|
257
|
+
const filePath = path.join(EXE_AI_DIR, file);
|
|
258
|
+
try {
|
|
259
|
+
matches.push({ path: filePath, mtimeMs: statSync(filePath).mtimeMs });
|
|
260
|
+
} catch {
|
|
261
|
+
}
|
|
262
|
+
}
|
|
263
|
+
for (const target of selectBackupsToDelete(matches, keep)) {
|
|
264
|
+
for (const p of [target, target + "-wal", target + "-shm"]) {
|
|
265
|
+
try {
|
|
266
|
+
if (existsSync(p)) {
|
|
267
|
+
unlinkSync(p);
|
|
268
|
+
if (p === target) deleted++;
|
|
269
|
+
}
|
|
270
|
+
} catch {
|
|
271
|
+
}
|
|
272
|
+
}
|
|
273
|
+
}
|
|
274
|
+
} catch {
|
|
275
|
+
}
|
|
276
|
+
return deleted;
|
|
277
|
+
}
|
|
278
|
+
function cleanupCrashDebris() {
|
|
279
|
+
let deleted = 0;
|
|
280
|
+
deleted += rotateBackupsByReason("pre-restart", REASON_COUNT_CAP["pre-restart"] ?? 2);
|
|
281
|
+
deleted += cleanupStaleTmp();
|
|
282
|
+
deleted += pruneCorruptQuarantine();
|
|
283
|
+
return deleted;
|
|
284
|
+
}
|
|
285
|
+
function listBackups() {
|
|
286
|
+
if (!existsSync(BACKUP_DIR)) return [];
|
|
287
|
+
try {
|
|
288
|
+
const files = readdirSync(BACKUP_DIR).filter((f) => f.endsWith(".db") && !f.endsWith(".tmp") && !f.endsWith("-wal") && !f.endsWith("-shm"));
|
|
289
|
+
return files.map((name) => {
|
|
290
|
+
const p = path.join(BACKUP_DIR, name);
|
|
291
|
+
const stat = statSync(p);
|
|
292
|
+
return { path: p, name, size: stat.size, date: stat.mtime };
|
|
293
|
+
}).sort((a, b) => b.date.getTime() - a.date.getTime());
|
|
294
|
+
} catch {
|
|
295
|
+
return [];
|
|
296
|
+
}
|
|
297
|
+
}
|
|
298
|
+
function hasBackupToday(reason) {
|
|
299
|
+
const today = (/* @__PURE__ */ new Date()).toISOString().slice(0, 10);
|
|
300
|
+
const backups = listBackups();
|
|
301
|
+
return backups.some((b) => b.name.includes(reason) && b.name.includes(today.replace(/-/g, "-")));
|
|
302
|
+
}
|
|
303
|
+
function hasRecentBackup(reason, withinMs) {
|
|
304
|
+
try {
|
|
305
|
+
if (!existsSync(BACKUP_DIR)) return false;
|
|
306
|
+
const now = Date.now();
|
|
307
|
+
for (const file of readdirSync(BACKUP_DIR)) {
|
|
308
|
+
if (file.endsWith(".tmp")) continue;
|
|
309
|
+
if (!file.endsWith(".db")) continue;
|
|
310
|
+
if (!file.includes(`-${reason}-`)) continue;
|
|
311
|
+
try {
|
|
312
|
+
if (now - statSync(path.join(BACKUP_DIR, file)).mtimeMs <= withinMs) return true;
|
|
313
|
+
} catch {
|
|
314
|
+
}
|
|
315
|
+
}
|
|
316
|
+
} catch {
|
|
317
|
+
}
|
|
318
|
+
return false;
|
|
319
|
+
}
|
|
320
|
+
function getLatestBackup() {
|
|
321
|
+
const backups = listBackups();
|
|
322
|
+
return backups.length > 0 ? backups[0].path : null;
|
|
323
|
+
}
|
|
324
|
+
async function restoreBackup(backupPath) {
|
|
325
|
+
const dbPath = findActiveDb();
|
|
326
|
+
if (!dbPath) {
|
|
327
|
+
const target = path.join(EXE_AI_DIR, DB_NAMES[0]);
|
|
328
|
+
const source2 = backupPath ?? getLatestBackup();
|
|
329
|
+
if (!source2 || !existsSync(source2)) return null;
|
|
330
|
+
await copyFile(source2, target);
|
|
331
|
+
return { restored: path.basename(source2), preRestoreBackup: null };
|
|
332
|
+
}
|
|
333
|
+
const source = backupPath ?? getLatestBackup();
|
|
334
|
+
if (!source || !existsSync(source)) return null;
|
|
335
|
+
if (path.resolve(source) === path.resolve(dbPath)) return null;
|
|
336
|
+
await quickCheckBackupSource(source);
|
|
337
|
+
const preRestoreBackup = await createBackup("pre-restore");
|
|
338
|
+
const stamp = (/* @__PURE__ */ new Date()).toISOString().replace(/[:.]/g, "-");
|
|
339
|
+
const tmpDb = `${dbPath}.restore-${stamp}.tmp`;
|
|
340
|
+
const oldDb = `${dbPath}.pre-restore-active-${stamp}`;
|
|
341
|
+
await copyFile(source, tmpDb);
|
|
342
|
+
const walPath = source + "-wal";
|
|
343
|
+
const shmPath = source + "-shm";
|
|
344
|
+
const tmpWal = `${tmpDb}-wal`;
|
|
345
|
+
const tmpShm = `${tmpDb}-shm`;
|
|
346
|
+
if (existsSync(walPath)) {
|
|
347
|
+
try {
|
|
348
|
+
await copyFile(walPath, tmpWal);
|
|
349
|
+
} catch {
|
|
350
|
+
}
|
|
351
|
+
}
|
|
352
|
+
if (existsSync(shmPath)) {
|
|
353
|
+
try {
|
|
354
|
+
await copyFile(shmPath, tmpShm);
|
|
355
|
+
} catch {
|
|
356
|
+
}
|
|
357
|
+
}
|
|
358
|
+
try {
|
|
359
|
+
unlinkSync(dbPath + "-wal");
|
|
360
|
+
} catch {
|
|
361
|
+
}
|
|
362
|
+
try {
|
|
363
|
+
unlinkSync(dbPath + "-shm");
|
|
364
|
+
} catch {
|
|
365
|
+
}
|
|
366
|
+
await rename(dbPath, oldDb);
|
|
367
|
+
await rename(tmpDb, dbPath);
|
|
368
|
+
if (existsSync(tmpWal)) await rename(tmpWal, dbPath + "-wal");
|
|
369
|
+
if (existsSync(tmpShm)) await rename(tmpShm, dbPath + "-shm");
|
|
370
|
+
return { restored: path.basename(source), preRestoreBackup };
|
|
371
|
+
}
|
|
372
|
+
function getBackupDir() {
|
|
373
|
+
return BACKUP_DIR;
|
|
374
|
+
}
|
|
375
|
+
|
|
376
|
+
export {
|
|
377
|
+
findActiveDb,
|
|
378
|
+
createBackup,
|
|
379
|
+
createBackupAsync,
|
|
380
|
+
rotateBackups,
|
|
381
|
+
selectBackupsToDelete,
|
|
382
|
+
selectStaleTmpFiles,
|
|
383
|
+
cleanupStaleTmp,
|
|
384
|
+
hasEnoughDiskSpace,
|
|
385
|
+
rotateBackupsByReason,
|
|
386
|
+
enforceRetention,
|
|
387
|
+
pruneCorruptQuarantine,
|
|
388
|
+
cleanupCrashDebris,
|
|
389
|
+
listBackups,
|
|
390
|
+
hasBackupToday,
|
|
391
|
+
hasRecentBackup,
|
|
392
|
+
getLatestBackup,
|
|
393
|
+
restoreBackup,
|
|
394
|
+
getBackupDir
|
|
395
|
+
};
|
|
@@ -0,0 +1,85 @@
|
|
|
1
|
+
import {
|
|
2
|
+
deactivateBehavior
|
|
3
|
+
} from "./chunk-KY43UELJ.js";
|
|
4
|
+
import {
|
|
5
|
+
getActiveAgent
|
|
6
|
+
} from "./chunk-RCEULTPF.js";
|
|
7
|
+
import {
|
|
8
|
+
canCoordinate,
|
|
9
|
+
getClient
|
|
10
|
+
} from "./chunk-XABJRAUW.js";
|
|
11
|
+
|
|
12
|
+
// src/mcp/tools/deactivate-behavior.ts
|
|
13
|
+
import { z } from "zod";
|
|
14
|
+
function registerDeactivateBehavior(server) {
|
|
15
|
+
server.registerTool(
|
|
16
|
+
"deactivate_behavior",
|
|
17
|
+
{
|
|
18
|
+
title: "Deactivate Behavior",
|
|
19
|
+
description: "Soft-delete a behavior by setting active = 0. RESTRICTED: only coordinator or founder sessions can use this. Use list_behaviors to find the behavior ID first.",
|
|
20
|
+
inputSchema: {
|
|
21
|
+
behavior_id: z.string().describe("UUID of the behavior to deactivate")
|
|
22
|
+
}
|
|
23
|
+
},
|
|
24
|
+
async ({ behavior_id }) => {
|
|
25
|
+
const caller = getActiveAgent();
|
|
26
|
+
try {
|
|
27
|
+
const { StewardGate } = await import("./steward-gate-PIXNK4BK.js");
|
|
28
|
+
const steward = new StewardGate();
|
|
29
|
+
const gateDecision = await steward.checkAuthority(caller.agentId || "unknown", "deactivate_behavior", behavior_id);
|
|
30
|
+
if (!gateDecision.allowed) {
|
|
31
|
+
return { content: [{ type: "text", text: `Steward gate denied: ${gateDecision.reason}` }], isError: true };
|
|
32
|
+
}
|
|
33
|
+
} catch {
|
|
34
|
+
}
|
|
35
|
+
const allowed = canCoordinate(caller.agentId, caller.agentRole);
|
|
36
|
+
if (!allowed) {
|
|
37
|
+
return {
|
|
38
|
+
content: [{
|
|
39
|
+
type: "text",
|
|
40
|
+
text: `Permission denied. Only the coordinator or founder sessions can deactivate behaviors. You are "${caller.agentId}".`
|
|
41
|
+
}],
|
|
42
|
+
isError: true
|
|
43
|
+
};
|
|
44
|
+
}
|
|
45
|
+
const client = getClient();
|
|
46
|
+
const result = await client.execute({
|
|
47
|
+
sql: `SELECT id, agent_id, content, domain, priority FROM behaviors WHERE id = ?`,
|
|
48
|
+
args: [behavior_id]
|
|
49
|
+
});
|
|
50
|
+
if (result.rows.length === 0) {
|
|
51
|
+
return {
|
|
52
|
+
content: [{
|
|
53
|
+
type: "text",
|
|
54
|
+
text: `Behavior not found: ${behavior_id}`
|
|
55
|
+
}],
|
|
56
|
+
isError: true
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
const row = result.rows[0];
|
|
60
|
+
const wasActive = await deactivateBehavior(behavior_id);
|
|
61
|
+
if (!wasActive) {
|
|
62
|
+
return {
|
|
63
|
+
content: [{
|
|
64
|
+
type: "text",
|
|
65
|
+
text: `Behavior ${behavior_id} was already inactive.`
|
|
66
|
+
}]
|
|
67
|
+
};
|
|
68
|
+
}
|
|
69
|
+
return {
|
|
70
|
+
content: [{
|
|
71
|
+
type: "text",
|
|
72
|
+
text: `Deactivated behavior for ${row.agent_id}.
|
|
73
|
+
ID: ${row.id}
|
|
74
|
+
Domain: ${row.domain ?? "none"}
|
|
75
|
+
Priority: ${row.priority}
|
|
76
|
+
Content: ${row.content}`
|
|
77
|
+
}]
|
|
78
|
+
};
|
|
79
|
+
}
|
|
80
|
+
);
|
|
81
|
+
}
|
|
82
|
+
|
|
83
|
+
export {
|
|
84
|
+
registerDeactivateBehavior
|
|
85
|
+
};
|