@askexenow/exe-os 0.9.286 → 0.9.288
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 +10 -1
- package/deploy/compose/.env.example +8 -1
- package/deploy/compose/README.md +21 -0
- package/deploy/compose/docker-compose.yml +24 -1
- package/deploy/compose/generate-env.ts +16 -2
- package/deploy/compose/setup.sh +63 -0
- package/deploy/stack-manifests/v0.9.json +1 -1
- package/dist/active-agent-KB4346K6.js +26 -0
- package/dist/active-agent-LTYLGBJX.js +27 -0
- package/dist/active-agent-V4W557J4.js +26 -0
- package/dist/active-agent-XZVU5XBO.js +27 -0
- package/dist/agentic-ontology-4PNQX4YW.js +25 -0
- package/dist/agentic-ontology-WOTOTSR7.js +25 -0
- package/dist/backfill-metadata-O2BQIEVT.js +599 -0
- package/dist/backfill-metadata-PHXNTBNR.js +599 -0
- package/dist/background-jobs-RIECIYW5.js +25 -0
- package/dist/behaviors-MO5BWFPW.js +39 -0
- package/dist/behaviors-TMA2HRTL.js +39 -0
- package/dist/bin/age-ontology-load.js +2 -2
- package/dist/bin/agentic-ontology-backfill.js +7 -7
- package/dist/bin/agentic-reflection-backfill.js +8 -8
- package/dist/bin/agentic-semantic-label.js +7 -7
- package/dist/bin/backfill-conversations.js +7 -7
- package/dist/bin/backfill-responses.js +7 -7
- package/dist/bin/backfill-vectors.js +10 -10
- package/dist/bin/bulk-sync-postgres.js +8 -8
- package/dist/bin/cc-doctor.js +7 -6
- package/dist/bin/cleanup-stale-review-tasks.js +13 -13
- package/dist/bin/cli.js +20 -20
- package/dist/bin/exe-agent-config.js +4 -4
- package/dist/bin/exe-agent.js +9 -9
- package/dist/bin/exe-assign.js +9 -9
- package/dist/bin/exe-boot.js +32 -21
- package/dist/bin/exe-call.js +5 -5
- package/dist/bin/exe-cloud.js +7 -7
- package/dist/bin/exe-dispatch.js +13 -13
- package/dist/bin/exe-doctor.js +4 -1
- package/dist/bin/exe-export-behaviors.js +8 -8
- package/dist/bin/exe-forget.js +7 -7
- package/dist/bin/exe-gateway.js +8 -8
- package/dist/bin/exe-healthcheck.js +9 -6
- package/dist/bin/exe-heartbeat.js +13 -13
- package/dist/bin/exe-kill.js +16 -16
- package/dist/bin/exe-launch-agent.js +20 -20
- package/dist/bin/exe-new-employee.js +8 -8
- package/dist/bin/exe-pending-messages.js +14 -14
- package/dist/bin/exe-pending-notifications.js +13 -13
- package/dist/bin/exe-pending-reviews.js +13 -13
- package/dist/bin/exe-rename.js +5 -5
- package/dist/bin/exe-review.js +15 -15
- package/dist/bin/exe-search.js +6 -6
- package/dist/bin/exe-session-cleanup.js +18 -18
- package/dist/bin/exe-settings.js +7 -7
- package/dist/bin/exe-start-codex.js +12 -12
- package/dist/bin/exe-start-opencode.js +9 -9
- package/dist/bin/exe-status.js +14 -14
- package/dist/bin/exe-support.js +3 -3
- package/dist/bin/exe-team.js +4 -4
- package/dist/bin/git-sweep.js +14 -14
- package/dist/bin/graph-backfill.js +8 -8
- package/dist/bin/graph-export.js +6 -6
- package/dist/bin/import-history.js +10 -10
- package/dist/bin/install.js +7 -7
- package/dist/bin/intercom-check.js +4 -4
- package/dist/bin/mcp-sessions.js +2 -2
- package/dist/bin/orchestration-metrics.js +5 -5
- package/dist/bin/postgres-agentic-reflection-backfill.js +4 -4
- package/dist/bin/postgres-agentic-semantic-backfill.js +3 -3
- package/dist/bin/scan-tasks.js +13 -13
- package/dist/bin/setup.js +2 -2
- package/dist/bin/shard-migrate.js +6 -6
- package/dist/bin/stack-update.js +4 -4
- package/dist/bin/vps-health-gate.js +1 -1
- package/dist/branding-6PY5DNDC.js +97 -0
- package/dist/capability-cards-4NKVY6GD.js +88 -0
- package/dist/capability-cards-UD5TCSAZ.js +88 -0
- package/dist/capacity-monitor-AU7MVZED.js +50 -0
- package/dist/capacity-monitor-CV7PWPYR.js +50 -0
- package/dist/catchup-brief-AZND3EET.js +174 -0
- package/dist/catchup-brief-TFL6MYOZ.js +154 -0
- package/dist/chunk-22R3G3GD.js +297 -0
- package/dist/chunk-2CO47E5Q.js +210 -0
- package/dist/chunk-2F5UVNYP.js +167 -0
- package/dist/chunk-2IJCGYY2.js +30 -0
- package/dist/chunk-2V52EJI7.js +14365 -0
- package/dist/chunk-2WCXJVSN.js +456 -0
- package/dist/chunk-2X52UGP7.js +190 -0
- package/dist/chunk-3H5FNTXS.js +85 -0
- package/dist/chunk-3OC6MJIX.js +210 -0
- package/dist/chunk-3OSDE4Y2.js +1119 -0
- package/dist/chunk-43QFBQHT.js +1094 -0
- package/dist/chunk-4EBW3URQ.js +4318 -0
- package/dist/chunk-4KVMYS3U.js +280 -0
- package/dist/chunk-4UTH3H4H.js +128 -0
- package/dist/chunk-5BKYHLA3.js +411 -0
- package/dist/chunk-5RRYMKXN.js +150 -0
- package/dist/chunk-5TYYOPTD.js +50 -0
- package/dist/chunk-5XOAYMSU.js +4318 -0
- package/dist/chunk-6DQNLI55.js +240 -0
- package/dist/chunk-6GOT6FNJ.js +1352 -0
- package/dist/chunk-6KH24PJ7.js +221 -0
- package/dist/chunk-6TV66RAI.js +192 -0
- package/dist/chunk-6UD5CM2H.js +244 -0
- package/dist/chunk-6YR3J6WG.js +203 -0
- package/dist/chunk-77HA7ATH.js +89 -0
- package/dist/chunk-7G52QPUX.js +271 -0
- package/dist/chunk-7M5ZHD4E.js +214 -0
- package/dist/chunk-A3GC762G.js +333 -0
- package/dist/chunk-ALTFDYI6.js +97 -0
- package/dist/chunk-AN25OIRX.js +38 -0
- package/dist/chunk-AOWC2J6S.js +14225 -0
- package/dist/chunk-ASL5PHCT.js +1934 -0
- package/dist/chunk-AVTDW4L6.js +562 -0
- package/dist/chunk-BEQTE7GH.js +668 -0
- package/dist/chunk-BJTBA4XS.js +290 -0
- package/dist/chunk-BQBPNRUW.js +231 -0
- package/dist/chunk-BQD4XYWX.js +159 -0
- package/dist/chunk-BVFCZNJH.js +41 -0
- package/dist/chunk-BW7HTZMW.js +240 -0
- package/dist/chunk-BZP3ZSRI.js +97 -0
- package/dist/chunk-C2NCSKRZ.js +373 -0
- package/dist/chunk-C3AH5JAS.js +510 -0
- package/dist/chunk-CEKZ77KA.js +471 -0
- package/dist/chunk-CNTBRVYW.js +54 -0
- package/dist/chunk-CTJQX44O.js +271 -0
- package/dist/chunk-CVG2PBCO.js +1105 -0
- package/dist/chunk-CZ47BFAT.js +299 -0
- package/dist/chunk-CZHC3HIO.js +362 -0
- package/dist/chunk-DIZOFRZO.js +284 -0
- package/dist/chunk-DRX46W5O.js +1068 -0
- package/dist/chunk-DYICAAAM.js +630 -0
- package/dist/chunk-E4BXNYLD.js +128 -0
- package/dist/chunk-EKXOBH7F.js +227 -0
- package/dist/chunk-ELQZYKVN.js +394 -0
- package/dist/chunk-EVM22AGQ.js +382 -0
- package/dist/chunk-EY7TBDZ5.js +38 -0
- package/dist/chunk-FDOEMBUB.js +345 -0
- package/dist/chunk-FG2OXKU5.js +539 -0
- package/dist/chunk-FP6TDXIL.js +456 -0
- package/dist/chunk-FVWATWI2.js +377 -0
- package/dist/chunk-G2OW4LUS.js +55 -0
- package/dist/chunk-GAYD7KBH.js +836 -0
- package/dist/chunk-GETGWHCO.js +227 -0
- package/dist/chunk-GGLUKNFC.js +1350 -0
- package/dist/chunk-GLEE2MUJ.js +262 -0
- package/dist/chunk-GUODMEAR.js +42 -0
- package/dist/chunk-H6LA4UV5.js +735 -0
- package/dist/chunk-H6PW4LNY.js +129 -0
- package/dist/chunk-HEMJ5RDU.js +345 -0
- package/dist/chunk-HMP6KB4V.js +382 -0
- package/dist/chunk-I35KAK3E.js +458 -0
- package/dist/chunk-I4DA5D5Q.js +1922 -0
- package/dist/chunk-I53O26HI.js +1119 -0
- package/dist/chunk-IBLEQQDQ.js +181 -0
- package/dist/chunk-IS2BEXUC.js +2113 -0
- package/dist/chunk-ISCEGQHA.js +244 -0
- package/dist/chunk-JCERHH3L.js +85 -0
- package/dist/chunk-JCNCPBWU.js +97 -0
- package/dist/chunk-JEMLH7H2.js +1350 -0
- package/dist/chunk-JMR2X5FJ.js +630 -0
- package/dist/chunk-JR3MYBWG.js +2078 -0
- package/dist/chunk-JSEICUAL.js +197 -0
- package/dist/chunk-K3KOLZTH.js +123 -0
- package/dist/chunk-K4OH3B2I.js +14248 -0
- package/dist/chunk-KQ4Z2G24.js +260 -0
- package/dist/chunk-KVH5DSTA.js +369 -0
- package/dist/chunk-L4R5NOVT.js +81 -0
- package/dist/chunk-LCB6YCE6.js +70 -0
- package/dist/chunk-M543SLJZ.js +1352 -0
- package/dist/chunk-M6KDMU5P.js +2113 -0
- package/dist/chunk-MDAGRPZG.js +197 -0
- package/dist/chunk-MLNOSXRZ.js +402 -0
- package/dist/chunk-MNI5K34D.js +290 -0
- package/dist/chunk-MUDH7ZLR.js +129 -0
- package/dist/chunk-MUMBWV57.js +379 -0
- package/dist/chunk-NAQLGLOG.js +176 -0
- package/dist/chunk-NIBCUAEI.js +123 -0
- package/dist/chunk-NIZCTXYW.js +89 -0
- package/dist/chunk-NS5G36TN.js +712 -0
- package/dist/chunk-NSKQWLQL.js +76 -0
- package/dist/chunk-NUA3WRTO.js +1157 -0
- package/dist/chunk-O3IESEF6.js +85 -0
- package/dist/chunk-OAO2BK25.js +81 -0
- package/dist/chunk-OFY7RGLL.js +348 -0
- package/dist/chunk-OICU3UHF.js +181 -0
- package/dist/chunk-OK6HCC2Z.js +731 -0
- package/dist/chunk-ONTUBOYP.js +230 -0
- package/dist/chunk-OQB7TERT.js +54 -0
- package/dist/chunk-P362EYLO.js +106 -0
- package/dist/chunk-P4T4JOCE.js +192 -0
- package/dist/chunk-QAOWXQKA.js +333 -0
- package/dist/chunk-QEFT6G6J.js +2078 -0
- package/dist/chunk-QFVY5MHR.js +402 -0
- package/dist/chunk-QLMSROQC.js +604 -0
- package/dist/chunk-QNR4ZQDU.js +14365 -0
- package/dist/chunk-QQ3T45AO.js +348 -0
- package/dist/chunk-QV6HNEMH.js +230 -0
- package/dist/chunk-R5LCP56X.js +299 -0
- package/dist/chunk-RHTZA6X6.js +1922 -0
- package/dist/chunk-RL4RQIEI.js +731 -0
- package/dist/chunk-RW4EMKQF.js +185 -0
- package/dist/chunk-S35K4C6F.js +127 -0
- package/dist/chunk-SFQYQH5Z.js +50 -0
- package/dist/chunk-SLFB2RY6.js +133 -0
- package/dist/chunk-SSC7EKY2.js +133 -0
- package/dist/chunk-SWFFGWAF.js +262 -0
- package/dist/chunk-SXZCFZ5T.js +157 -0
- package/dist/chunk-T5LT62O5.js +14365 -0
- package/dist/chunk-TDGPZF5T.js +539 -0
- package/dist/chunk-TF6DEHEL.js +167 -0
- package/dist/chunk-TH7ZNVGB.js +33 -0
- package/dist/chunk-TTNYB6OH.js +33 -0
- package/dist/chunk-TUHR7Z7R.js +221 -0
- package/dist/chunk-UHKXYDBM.js +668 -0
- package/dist/chunk-UQBD2L52.js +128 -0
- package/dist/chunk-UTARH2WY.js +76 -0
- package/dist/chunk-UXYAQCIB.js +30 -0
- package/dist/chunk-UZHCPLB2.js +127 -0
- package/dist/chunk-VNJKA3K5.js +171 -0
- package/dist/chunk-VP4MDSUA.js +1156 -0
- package/dist/chunk-VWA7OCXI.js +58 -0
- package/dist/chunk-VWZZF3YB.js +70 -0
- package/dist/chunk-VYPKS352.js +214 -0
- package/dist/chunk-W6JB72KR.js +448 -0
- package/dist/chunk-WG4PSSI5.js +510 -0
- package/dist/chunk-WJPZPASS.js +373 -0
- package/dist/chunk-WLDBPKRL.js +3246 -0
- package/dist/chunk-WO2SPDUE.js +231 -0
- package/dist/chunk-WXEPPHDU.js +1094 -0
- package/dist/chunk-WXNSOT6K.js +82 -0
- package/dist/chunk-X2PSVVHB.js +448 -0
- package/dist/chunk-X5Y4JSD4.js +128 -0
- package/dist/chunk-X7VPB6Z5.js +621 -0
- package/dist/chunk-XA2GMH53.js +85 -0
- package/dist/chunk-XC2ZMYDN.js +204 -0
- package/dist/chunk-XFQJH67J.js +157 -0
- package/dist/chunk-XLF5F55U.js +230 -0
- package/dist/chunk-XQ5LT6UM.js +362 -0
- package/dist/chunk-XRMBKPIP.js +204 -0
- package/dist/chunk-XUC7YYW5.js +171 -0
- package/dist/chunk-XVDWHYIK.js +3276 -0
- package/dist/chunk-Y6CVAZ7T.js +97 -0
- package/dist/chunk-YA7WVZF5.js +377 -0
- package/dist/chunk-YACAOZVG.js +185 -0
- package/dist/chunk-YEHV3FN5.js +836 -0
- package/dist/chunk-YMZ6IGC3.js +284 -0
- package/dist/chunk-Z5P7AUFM.js +280 -0
- package/dist/chunk-Z5YFGOLZ.js +1068 -0
- package/dist/chunk-ZLYKY6GP.js +150 -0
- package/dist/chunk-ZOP7NAM2.js +58 -0
- package/dist/chunk-ZUNYZYKV.js +1157 -0
- package/dist/co-activation-54LO5GAA.js +73 -0
- package/dist/co-activation-ESPLEOMH.js +73 -0
- package/dist/co-occurrence-52ZTRX2I.js +94 -0
- package/dist/co-occurrence-O4G6VQUU.js +94 -0
- package/dist/code-context-index-OX3LN34G.js +30 -0
- package/dist/conversation-wiki-populator-IWSKIHQK.js +105 -0
- package/dist/core-memory-J6AEOYFN.js +110 -0
- package/dist/core-memory-XF4CLLDR.js +110 -0
- package/dist/cpu-steal-5YKTUPWF.js +23 -0
- package/dist/crdt-sync-5JOW6T2I.js +33 -0
- package/dist/crdt-sync-6L4OI4OA.js +33 -0
- package/dist/crm-webhook-BAXEYDPD.js +10 -0
- package/dist/crm-webhook-KVBGOUHU.js +10 -0
- package/dist/cto-delegation-gate-3WUTWBCT.js +279 -0
- package/dist/cto-delegation-gate-DZF3Z66I.js +279 -0
- package/dist/daemon-auth-M2G5PBME.js +13 -0
- package/dist/daemon-orchestration-3ANZVE7Y.js +138 -0
- package/dist/daemon-orchestration-APVUUNFB.js +138 -0
- package/dist/daemon-restart-report-F3P5AQS4.js +9 -0
- package/dist/db-backup-J7253HNV.js +33 -0
- package/dist/db-backup-M733ORYE.js +33 -0
- package/dist/db-restore-events-AIL6GSEK.js +76 -0
- package/dist/db-restore-events-LB3O46HH.js +76 -0
- package/dist/doc-graph-extractor-CF2WBSGL.js +132 -0
- package/dist/doc-graph-extractor-RSYHLOKD.js +132 -0
- package/dist/dreaming-L4FLJJO2.js +33 -0
- package/dist/dreaming-YKEKUE55.js +33 -0
- package/dist/entity-boost-ZKACOJKH.js +375 -0
- package/dist/exe-drift-AVJRXHCB.js +69 -0
- package/dist/exe-drift-MYT5NQ52.js +69 -0
- package/dist/exe-export-T2FHC5GC.js +75 -0
- package/dist/exe-export-TBV2JI4P.js +75 -0
- package/dist/exe-import-6UAKJF3Y.js +78 -0
- package/dist/exe-import-KJQO4PJX.js +78 -0
- package/dist/exe-key-KGQUC27D.js +580 -0
- package/dist/exe-key-Q772PMBM.js +580 -0
- package/dist/exe-org-KK22SSB3.js +73 -0
- package/dist/exe-snapshot-KF3HPOWJ.js +337 -0
- package/dist/exe-snapshot-SK6PMOFA.js +337 -0
- package/dist/fast-db-init-EXNYB2HK.js +7 -0
- package/dist/fast-db-init-FMECTLNS.js +7 -0
- package/dist/founder-context-N2VZ5MY2.js +96 -0
- package/dist/gateway/index.js +12 -12
- package/dist/git-staleness-2EOHIOMZ.js +111 -0
- package/dist/git-staleness-ZEYJXPFP.js +111 -0
- package/dist/git-task-sweep-I74JXGNT.js +41 -0
- package/dist/git-task-sweep-YKLOPYYV.js +41 -0
- package/dist/global-procedures-B23F4IQ3.js +21 -0
- package/dist/global-procedures-LUBLZ6WN.js +21 -0
- package/dist/graph-auto-extract-CSLZXRDY.js +182 -0
- package/dist/graph-auto-extract-DZRIETGW.js +182 -0
- package/dist/hook-integrity-HJBXTLQD.js +89 -0
- package/dist/hooks/bug-report-worker.js +15 -15
- package/dist/hooks/codex-stop-task-finalizer.js +15 -15
- package/dist/hooks/commit-complete.js +16 -16
- package/dist/hooks/error-recall.js +8 -8
- package/dist/hooks/exe-heartbeat-hook.js +5 -5
- package/dist/hooks/ingest-worker.js +5 -5
- package/dist/hooks/ingest.js +12 -12
- package/dist/hooks/instructions-loaded.js +6 -6
- package/dist/hooks/manifest.json +20 -20
- package/dist/hooks/notification.js +6 -6
- package/dist/hooks/post-compact.js +15 -15
- package/dist/hooks/post-tool-combined.js +7 -7
- package/dist/hooks/pre-compact.js +20 -20
- package/dist/hooks/pre-tool-use.js +19 -19
- package/dist/hooks/prompt-submit.js +27 -27
- package/dist/hooks/session-end.js +25 -25
- package/dist/hooks/session-start.js +37 -13
- package/dist/hooks/stop.js +22 -22
- package/dist/hooks/subagent-stop.js +15 -15
- package/dist/hooks/summary-worker.js +22 -22
- package/dist/index.js +23 -23
- package/dist/installer-AU5VMP4U.js +39 -0
- package/dist/installer-H7BIYSIK.js +39 -0
- package/dist/installer-L4NJWZGV.js +297 -0
- package/dist/installer-QE3LBMVF.js +343 -0
- package/dist/installer-QH75OOGL.js +297 -0
- package/dist/installer-XREYYGF2.js +343 -0
- package/dist/key-backup-status-IJCQT4NV.js +39 -0
- package/dist/lib/agent-config.js +2 -2
- package/dist/lib/cloud-sync.js +6 -6
- package/dist/lib/config.js +7 -3
- package/dist/lib/consolidation.js +8 -8
- package/dist/lib/database.js +3 -3
- package/dist/lib/db-daemon-client.js +3 -3
- package/dist/lib/db.js +3 -3
- package/dist/lib/device-registry.js +1 -1
- package/dist/lib/embed-worker.js +1 -1
- package/dist/lib/embedder.js +4 -4
- package/dist/lib/employee-templates.js +5 -5
- package/dist/lib/employees.js +3 -3
- package/dist/lib/exe-daemon-client.js +3 -3
- package/dist/lib/exe-daemon.js +51 -51
- package/dist/lib/hybrid-search.js +6 -6
- package/dist/lib/identity.js +3 -3
- package/dist/lib/license.js +2 -2
- package/dist/lib/messaging.js +13 -13
- package/dist/lib/reminders.js +4 -4
- package/dist/lib/schedules.js +6 -6
- package/dist/lib/session-registry.js +5 -5
- package/dist/lib/skill-learning.js +7 -7
- package/dist/lib/status-brief.js +1 -1
- package/dist/lib/store.js +5 -5
- package/dist/lib/task-router.js +4 -4
- package/dist/lib/tasks.js +14 -14
- package/dist/lib/tmux-routing.js +12 -12
- package/dist/lib/token-spend.js +4 -4
- package/dist/license-gate-X57APN2E.js +14 -0
- package/dist/mcp/register-tools.js +71 -69
- package/dist/mcp/server.js +73 -71
- package/dist/mcp/tools/complete-reminder.js +5 -5
- package/dist/mcp/tools/create-reminder.js +5 -5
- package/dist/mcp/tools/create-task.js +16 -16
- package/dist/mcp/tools/deactivate-behavior.js +8 -8
- package/dist/mcp/tools/list-reminders.js +5 -5
- package/dist/mcp/tools/list-tasks.js +16 -16
- package/dist/mcp/tools/send-message.js +15 -15
- package/dist/mcp/tools/update-task.js +15 -15
- package/dist/mcp-http-config-KMP55RXI.js +28 -0
- package/dist/mcp-http-config-XYHPQVRA.js +28 -0
- package/dist/memory-cards-AULW7ITU.js +179 -0
- package/dist/memory-cards-NLTRIBSD.js +179 -0
- package/dist/memory-graph-extractor-NGJQIKAA.js +21 -0
- package/dist/memory-graph-extractor-QWFPKSX5.js +21 -0
- package/dist/memory-poisoning-defense-5WWOLHUQ.js +223 -0
- package/dist/memory-poisoning-defense-742X4H52.js +223 -0
- package/dist/memory-queue-OXHHNDOC.js +19 -0
- package/dist/memory-queue-client-P4TZNVQB.js +16 -0
- package/dist/memory-reflection-6GF5OK2W.js +243 -0
- package/dist/memory-reflection-SGIE7OJ7.js +243 -0
- package/dist/message-queue-client-ELWCWKBO.js +92 -0
- package/dist/notifications-67M5SPLO.js +46 -0
- package/dist/notifications-HUH2H5WZ.js +46 -0
- package/dist/oauth-server-RKCMPBIP.js +437 -0
- package/dist/orchestration-events-MC3IZ46I.js +26 -0
- package/dist/orchestration-events-NZCUTMCJ.js +26 -0
- package/dist/orchestration-phase-FPAVQ57X.js +23 -0
- package/dist/orchestrator-3MJ6YJKT.js +34 -0
- package/dist/orchestrator-HOXFT4PP.js +34 -0
- package/dist/pipeline-router-NCUDK335.js +14 -0
- package/dist/pipeline-router-POLBFEBM.js +14 -0
- package/dist/plan-limits-DGAFE7V6.js +27 -0
- package/dist/plan-limits-J4WXJVDS.js +27 -0
- package/dist/project-boot-FRCQHQTF.js +299 -0
- package/dist/project-boot-QHXOUJGT.js +299 -0
- package/dist/projection-worker-QZW4DOY3.js +1034 -0
- package/dist/projection-worker-XDKC3GIZ.js +1034 -0
- package/dist/prospective-memory-JIGVZM2I.js +231 -0
- package/dist/push-notifications-ERC4SQSQ.js +15 -0
- package/dist/reranker-SF3LMYGY.js +19 -0
- package/dist/reranker-SOM2WMD6.js +19 -0
- package/dist/retrieval-health-7FRD2KLM.js +11 -0
- package/dist/retrieval-health-P6QHP263.js +11 -0
- package/dist/review-polling-66EJAMR3.js +125 -0
- package/dist/review-polling-SYKYNFRK.js +125 -0
- package/dist/runtime/index.js +19 -19
- package/dist/session-events-A6EDTM27.js +37 -0
- package/dist/session-events-DONPZ7DR.js +37 -0
- package/dist/session-kill-telemetry-NV2S2YZ2.js +30 -0
- package/dist/session-kill-telemetry-Y47QAFHP.js +30 -0
- package/dist/session-scope-H3FJVQ6E.js +87 -0
- package/dist/session-scope-I56DVQEY.js +87 -0
- package/dist/setup-wizard-MX3S3DVH.js +12 -0
- package/dist/setup-wizard-YRBCVPCU.js +12 -0
- package/dist/shard-manager-AX4W5B3N.js +30 -0
- package/dist/skill-refinement-57DCIDKT.js +158 -0
- package/dist/skill-refinement-XTBCHOMO.js +158 -0
- package/dist/stack-update-45SNTDZ6.js +76 -0
- package/dist/stack-update-CZ2QHS6T.js +76 -0
- package/dist/stack-update-XNEO4WQH.js +76 -0
- package/dist/steward-gate-J7VMPHEN.js +14 -0
- package/dist/steward-gate-PVUKWYED.js +14 -0
- package/dist/task-enforcement-G4MYUJ2E.js +439 -0
- package/dist/task-enforcement-QBF44BXN.js +439 -0
- package/dist/task-scope-D2VOYU3P.js +36 -0
- package/dist/task-scope-HGL6VACL.js +36 -0
- package/dist/tasks-crud-DFE4XOW7.js +78 -0
- package/dist/tasks-crud-J5TSLFQN.js +78 -0
- package/dist/tasks-notify-2VRKOK74.js +39 -0
- package/dist/tasks-notify-Q23MIKDA.js +39 -0
- package/dist/tasks-review-NRSVHN7V.js +48 -0
- package/dist/tasks-review-VV3RLPLT.js +48 -0
- package/dist/telemetry-upload-ISI6TEX4.js +740 -0
- package/dist/telemetry-upload-XML6WVPW.js +740 -0
- package/dist/token-budget-KVRHMY7V.js +85 -0
- package/dist/token-budget-WV2GIFYJ.js +85 -0
- package/dist/tool-capability-index-NOMFY27N.js +10 -0
- package/dist/tool-telemetry-6DGIQUV3.js +17 -0
- package/dist/tool-telemetry-NXPM2T5E.js +17 -0
- package/dist/tui/App.js +80 -38
- package/dist/tui-data-C4474APN.js +259 -0
- package/dist/tui-data-KP66NOW3.js +259 -0
- package/dist/webhook-pipe-ZAEPBTDB.js +114 -0
- package/dist/wiki-acl-4A3ZUPJK.js +111 -0
- package/dist/wiki-acl-DRTEVIHT.js +111 -0
- package/dist/wiki-client-AN52BINX.js +157 -0
- package/dist/worker-gate-EVSFKALM.js +21 -0
- package/dist/worker-gate-O2KXQN5T.js +21 -0
- package/dist/workflow-engine-MUO435MX.js +28 -0
- package/dist/workflow-engine-RV6JLGHQ.js +28 -0
- package/dist/worktree-36S7LYES.js +27 -0
- package/dist/worktree-WTNPY42O.js +27 -0
- package/dist/worktree-sweep-M5AXCSU7.js +20 -0
- package/dist/worktree-sweep-NKEGKQT3.js +20 -0
- package/package.json +1 -1
- package/release-notes.json +20 -20
|
@@ -0,0 +1,23 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CPU_STEAL_CRITICAL_PERCENT,
|
|
3
|
+
CPU_STEAL_WARN_PERCENT,
|
|
4
|
+
checkCpuSteal,
|
|
5
|
+
checkCpuStealSync,
|
|
6
|
+
cpuStealMessage,
|
|
7
|
+
cpuStealSeverity,
|
|
8
|
+
parseMpstat,
|
|
9
|
+
parseProcStat,
|
|
10
|
+
stealPercentBetween
|
|
11
|
+
} from "./chunk-SSC7EKY2.js";
|
|
12
|
+
import "./chunk-MLKGABMK.js";
|
|
13
|
+
export {
|
|
14
|
+
CPU_STEAL_CRITICAL_PERCENT,
|
|
15
|
+
CPU_STEAL_WARN_PERCENT,
|
|
16
|
+
checkCpuSteal,
|
|
17
|
+
checkCpuStealSync,
|
|
18
|
+
cpuStealMessage,
|
|
19
|
+
cpuStealSeverity,
|
|
20
|
+
parseMpstat,
|
|
21
|
+
parseProcStat,
|
|
22
|
+
stealPercentBetween
|
|
23
|
+
};
|
|
@@ -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-6KH24PJ7.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,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-TUHR7Z7R.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,279 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sessionScopeFilter
|
|
3
|
+
} from "./chunk-5XOAYMSU.js";
|
|
4
|
+
import "./chunk-Z5P7AUFM.js";
|
|
5
|
+
import "./chunk-4JERP7NT.js";
|
|
6
|
+
import "./chunk-4FVVJ7ME.js";
|
|
7
|
+
import "./chunk-WO2SPDUE.js";
|
|
8
|
+
import "./chunk-MVW62NIZ.js";
|
|
9
|
+
import "./chunk-OYNKIAVW.js";
|
|
10
|
+
import "./chunk-SSTLTIF3.js";
|
|
11
|
+
import "./chunk-JMR2X5FJ.js";
|
|
12
|
+
import "./chunk-PMVOUPTY.js";
|
|
13
|
+
import "./chunk-NGP6LSV2.js";
|
|
14
|
+
import "./chunk-MUDH7ZLR.js";
|
|
15
|
+
import "./chunk-CVYC6DUW.js";
|
|
16
|
+
import "./chunk-OPU3NYOO.js";
|
|
17
|
+
import "./chunk-GJV3WDWM.js";
|
|
18
|
+
import "./chunk-MP2AFCGL.js";
|
|
19
|
+
import "./chunk-VWZZF3YB.js";
|
|
20
|
+
import "./chunk-HYZV25LY.js";
|
|
21
|
+
import {
|
|
22
|
+
getClient,
|
|
23
|
+
getEmployeeByRole,
|
|
24
|
+
loadEmployeesSync
|
|
25
|
+
} from "./chunk-WLDBPKRL.js";
|
|
26
|
+
import "./chunk-2I23RPSI.js";
|
|
27
|
+
import "./chunk-R5LCP56X.js";
|
|
28
|
+
import "./chunk-5DNJPRDW.js";
|
|
29
|
+
import "./chunk-FXU7JOXK.js";
|
|
30
|
+
import "./chunk-YMKUXZIG.js";
|
|
31
|
+
import "./chunk-T3B5RK4H.js";
|
|
32
|
+
import "./chunk-LYH5HE24.js";
|
|
33
|
+
import "./chunk-MLKGABMK.js";
|
|
34
|
+
|
|
35
|
+
// src/lib/cto-delegation-gate.ts
|
|
36
|
+
import os from "os";
|
|
37
|
+
import path from "path";
|
|
38
|
+
import { existsSync, readFileSync, statSync } from "fs";
|
|
39
|
+
var GATED_ROLE = "CTO";
|
|
40
|
+
function resolveGatedAgent() {
|
|
41
|
+
try {
|
|
42
|
+
const employees = loadEmployeesSync();
|
|
43
|
+
const cto = getEmployeeByRole(employees, GATED_ROLE);
|
|
44
|
+
return cto?.name ?? "";
|
|
45
|
+
} catch {
|
|
46
|
+
return "";
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
var GATED_AGENT = resolveGatedAgent();
|
|
50
|
+
function getGatedAgent() {
|
|
51
|
+
return resolveGatedAgent() || GATED_AGENT;
|
|
52
|
+
}
|
|
53
|
+
var BLOCKED_PATH_PREFIXES = [
|
|
54
|
+
"src/",
|
|
55
|
+
"tests/",
|
|
56
|
+
"scripts/",
|
|
57
|
+
"bin/",
|
|
58
|
+
".github/workflows/",
|
|
59
|
+
".claude/skills/"
|
|
60
|
+
];
|
|
61
|
+
var BLOCKED_FILENAMES = [
|
|
62
|
+
"package.json",
|
|
63
|
+
"tsconfig.json",
|
|
64
|
+
"docker-compose.yml"
|
|
65
|
+
];
|
|
66
|
+
var BLOCKED_DOCKERFILE_PREFIX = "Dockerfile";
|
|
67
|
+
var BLOCKED_EXTENSIONS = [
|
|
68
|
+
".ts",
|
|
69
|
+
".js",
|
|
70
|
+
".tsx",
|
|
71
|
+
".jsx",
|
|
72
|
+
".rs",
|
|
73
|
+
".py",
|
|
74
|
+
".go",
|
|
75
|
+
".sh",
|
|
76
|
+
".yaml",
|
|
77
|
+
".yml",
|
|
78
|
+
".prisma",
|
|
79
|
+
".sql"
|
|
80
|
+
];
|
|
81
|
+
var EXEMPT_MD_DIR_PREFIXES = [
|
|
82
|
+
".planning/",
|
|
83
|
+
"exe/output/",
|
|
84
|
+
"exe/",
|
|
85
|
+
"docs/"
|
|
86
|
+
];
|
|
87
|
+
var RECENT_DISPATCH_WINDOW_MS = 5 * 60 * 1e3;
|
|
88
|
+
var SCRATCHPAD_MAX_AGE_MS = 10 * 60 * 1e3;
|
|
89
|
+
var SCRATCHPAD_ESCAPE_PATTERN = /^(?:ENGINEER|TOM)-CAPABLE:\s*NO\s*—\s*reason:\s*\S+/m;
|
|
90
|
+
function toWorkspaceRelative(filePath, cwd = process.cwd()) {
|
|
91
|
+
const normalized = path.normalize(filePath);
|
|
92
|
+
if (normalized.startsWith(cwd + path.sep)) {
|
|
93
|
+
return normalized.slice(cwd.length + 1);
|
|
94
|
+
}
|
|
95
|
+
if (path.isAbsolute(normalized)) {
|
|
96
|
+
return path.basename(normalized);
|
|
97
|
+
}
|
|
98
|
+
return normalized;
|
|
99
|
+
}
|
|
100
|
+
function isDockerfile(basename) {
|
|
101
|
+
return basename === BLOCKED_DOCKERFILE_PREFIX || basename.startsWith(`${BLOCKED_DOCKERFILE_PREFIX}.`);
|
|
102
|
+
}
|
|
103
|
+
function classifyPath(filePath, cwd) {
|
|
104
|
+
const rel = toWorkspaceRelative(filePath, cwd);
|
|
105
|
+
const basename = path.basename(rel);
|
|
106
|
+
const ext = path.extname(rel).toLowerCase();
|
|
107
|
+
if (ext === ".md") {
|
|
108
|
+
for (const prefix of EXEMPT_MD_DIR_PREFIXES) {
|
|
109
|
+
if (rel.startsWith(prefix)) return "exempt";
|
|
110
|
+
}
|
|
111
|
+
if (!BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) {
|
|
112
|
+
return "exempt";
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
if (BLOCKED_FILENAMES.includes(basename)) return "code";
|
|
116
|
+
if (isDockerfile(basename)) return "code";
|
|
117
|
+
if (BLOCKED_EXTENSIONS.includes(ext)) return "code";
|
|
118
|
+
if (BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) return "code";
|
|
119
|
+
return "exempt";
|
|
120
|
+
}
|
|
121
|
+
function buildPathTokens(filePath) {
|
|
122
|
+
const GENERIC_SEGMENTS = /* @__PURE__ */ new Set([
|
|
123
|
+
"src",
|
|
124
|
+
"app",
|
|
125
|
+
"api",
|
|
126
|
+
"lib",
|
|
127
|
+
"bin",
|
|
128
|
+
"tests",
|
|
129
|
+
"test",
|
|
130
|
+
"scripts",
|
|
131
|
+
"dist",
|
|
132
|
+
"build",
|
|
133
|
+
"out",
|
|
134
|
+
"pages",
|
|
135
|
+
"routes",
|
|
136
|
+
"components",
|
|
137
|
+
"utils",
|
|
138
|
+
"helpers",
|
|
139
|
+
"types",
|
|
140
|
+
"models"
|
|
141
|
+
]);
|
|
142
|
+
const normalized = path.normalize(filePath).replace(/\\/g, "/");
|
|
143
|
+
const segments = normalized.split("/").filter(Boolean);
|
|
144
|
+
const tokens = /* @__PURE__ */ new Set();
|
|
145
|
+
const basename = segments[segments.length - 1] ?? "";
|
|
146
|
+
if (basename) tokens.add(basename);
|
|
147
|
+
const parentDir = segments[segments.length - 2];
|
|
148
|
+
if (parentDir && parentDir.length >= 5 && !GENERIC_SEGMENTS.has(parentDir)) {
|
|
149
|
+
tokens.add(parentDir);
|
|
150
|
+
tokens.add(`${parentDir}/${basename}`);
|
|
151
|
+
}
|
|
152
|
+
for (let depth = 2; depth <= Math.min(4, segments.length); depth++) {
|
|
153
|
+
const suffix = segments.slice(segments.length - depth).join("/");
|
|
154
|
+
const leadSegment = segments[segments.length - depth] ?? "";
|
|
155
|
+
if (GENERIC_SEGMENTS.has(leadSegment)) continue;
|
|
156
|
+
tokens.add(suffix);
|
|
157
|
+
}
|
|
158
|
+
return [...tokens].filter((t) => t.length > 0);
|
|
159
|
+
}
|
|
160
|
+
async function isFileInTaskSpec(filePath, agentId) {
|
|
161
|
+
try {
|
|
162
|
+
const client = getClient();
|
|
163
|
+
const scope = sessionScopeFilter();
|
|
164
|
+
const result = await client.execute({
|
|
165
|
+
sql: `SELECT title, context FROM tasks
|
|
166
|
+
WHERE assigned_to = ? AND status = 'in_progress'${scope.sql}`,
|
|
167
|
+
args: [agentId, ...scope.args]
|
|
168
|
+
});
|
|
169
|
+
if (result.rows.length === 0) return false;
|
|
170
|
+
const tokens = buildPathTokens(filePath);
|
|
171
|
+
if (tokens.length === 0) return false;
|
|
172
|
+
for (const row of result.rows) {
|
|
173
|
+
const haystack = [
|
|
174
|
+
String(row.title ?? ""),
|
|
175
|
+
String(row.context ?? "")
|
|
176
|
+
].join(" ").toLowerCase();
|
|
177
|
+
for (const token of tokens) {
|
|
178
|
+
if (haystack.includes(token.toLowerCase())) {
|
|
179
|
+
return true;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
return false;
|
|
184
|
+
} catch {
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
async function hasRecentEngineerDispatch(now = Date.now()) {
|
|
189
|
+
try {
|
|
190
|
+
const client = getClient();
|
|
191
|
+
const engineers = loadEmployeesSync().filter(
|
|
192
|
+
(e) => e.role.toLowerCase() === "principal engineer"
|
|
193
|
+
);
|
|
194
|
+
const engineerNames = engineers.map((e) => e.name);
|
|
195
|
+
const gatedAgent = getGatedAgent();
|
|
196
|
+
if (!gatedAgent) return false;
|
|
197
|
+
if (engineerNames.length === 0) return false;
|
|
198
|
+
const placeholders = engineerNames.map(() => "?").join(",");
|
|
199
|
+
const ydScope = sessionScopeFilter();
|
|
200
|
+
const result = await client.execute({
|
|
201
|
+
sql: `SELECT MAX(created_at) AS last_dispatch
|
|
202
|
+
FROM tasks
|
|
203
|
+
WHERE assigned_by = ? AND assigned_to IN (${placeholders})${ydScope.sql}`,
|
|
204
|
+
args: [gatedAgent, ...engineerNames, ...ydScope.args]
|
|
205
|
+
});
|
|
206
|
+
const raw = result.rows[0]?.last_dispatch;
|
|
207
|
+
if (raw === null || raw === void 0) return false;
|
|
208
|
+
const parsed = Date.parse(String(raw));
|
|
209
|
+
if (Number.isNaN(parsed)) return false;
|
|
210
|
+
return now - parsed <= RECENT_DISPATCH_WINDOW_MS;
|
|
211
|
+
} catch {
|
|
212
|
+
return false;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
function scratchpadPath(sessionId, homeDir = os.homedir()) {
|
|
216
|
+
return path.join(
|
|
217
|
+
homeDir,
|
|
218
|
+
".exe-os",
|
|
219
|
+
"session-cache",
|
|
220
|
+
`cto-scratchpad-${sessionId}.txt`
|
|
221
|
+
);
|
|
222
|
+
}
|
|
223
|
+
function hasValidScratchpadEscape(sessionId, now = Date.now(), homeDir = os.homedir()) {
|
|
224
|
+
const paths = [scratchpadPath(sessionId, homeDir)];
|
|
225
|
+
for (const filePath of paths) {
|
|
226
|
+
if (!existsSync(filePath)) continue;
|
|
227
|
+
try {
|
|
228
|
+
const stat = statSync(filePath);
|
|
229
|
+
if (now - stat.mtimeMs > SCRATCHPAD_MAX_AGE_MS) continue;
|
|
230
|
+
const body = readFileSync(filePath, "utf-8");
|
|
231
|
+
if (SCRATCHPAD_ESCAPE_PATTERN.test(body)) return true;
|
|
232
|
+
} catch {
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return false;
|
|
236
|
+
}
|
|
237
|
+
var GATE_BLOCK_MESSAGE = [
|
|
238
|
+
"ACTION BLOCKED by CTO delegation gate. Your Write/Edit was DENIED \u2014 it did NOT execute.",
|
|
239
|
+
"This edit looks implementable by an engineer. You MUST either:",
|
|
240
|
+
" 1. Dispatch create_task to an engineer, OR",
|
|
241
|
+
" 2. Add ENGINEER-CAPABLE: NO with explicit reason to proceed yourself.",
|
|
242
|
+
"Do NOT report this action as successful. It was blocked. No file was changed.",
|
|
243
|
+
"If you are a sub-agent, report this FAILURE to your parent agent."
|
|
244
|
+
].join("\n");
|
|
245
|
+
async function evaluateDelegationGate(opts) {
|
|
246
|
+
const gatedAgent = getGatedAgent();
|
|
247
|
+
if (!gatedAgent || opts.agentId !== gatedAgent) {
|
|
248
|
+
return { outcome: "allow", reason: "agent_not_gated" };
|
|
249
|
+
}
|
|
250
|
+
if (!/^(Write|Edit)$/.test(opts.toolName)) {
|
|
251
|
+
return { outcome: "allow", reason: "tool_not_gated" };
|
|
252
|
+
}
|
|
253
|
+
if (classifyPath(opts.filePath, opts.cwd) === "exempt") {
|
|
254
|
+
return { outcome: "allow", reason: "exempt_path" };
|
|
255
|
+
}
|
|
256
|
+
if (await isFileInTaskSpec(opts.filePath, opts.agentId)) {
|
|
257
|
+
return { outcome: "allow", reason: "task_spec_authorized" };
|
|
258
|
+
}
|
|
259
|
+
if (await hasRecentEngineerDispatch(opts.now)) {
|
|
260
|
+
return { outcome: "allow", reason: "recent_engineer_dispatch" };
|
|
261
|
+
}
|
|
262
|
+
if (hasValidScratchpadEscape(opts.sessionId, opts.now, opts.homeDir)) {
|
|
263
|
+
return { outcome: "allow", reason: "scratchpad_escape" };
|
|
264
|
+
}
|
|
265
|
+
return { outcome: "block", reason: "no_delegation_no_escape" };
|
|
266
|
+
}
|
|
267
|
+
export {
|
|
268
|
+
GATED_AGENT,
|
|
269
|
+
GATED_ROLE,
|
|
270
|
+
GATE_BLOCK_MESSAGE,
|
|
271
|
+
buildPathTokens,
|
|
272
|
+
classifyPath,
|
|
273
|
+
evaluateDelegationGate,
|
|
274
|
+
getGatedAgent,
|
|
275
|
+
hasRecentEngineerDispatch,
|
|
276
|
+
hasValidScratchpadEscape,
|
|
277
|
+
isFileInTaskSpec,
|
|
278
|
+
scratchpadPath
|
|
279
|
+
};
|
|
@@ -0,0 +1,279 @@
|
|
|
1
|
+
import {
|
|
2
|
+
sessionScopeFilter
|
|
3
|
+
} from "./chunk-4EBW3URQ.js";
|
|
4
|
+
import "./chunk-4KVMYS3U.js";
|
|
5
|
+
import "./chunk-4JERP7NT.js";
|
|
6
|
+
import "./chunk-4FVVJ7ME.js";
|
|
7
|
+
import "./chunk-BQBPNRUW.js";
|
|
8
|
+
import "./chunk-MVW62NIZ.js";
|
|
9
|
+
import "./chunk-OYNKIAVW.js";
|
|
10
|
+
import "./chunk-SSTLTIF3.js";
|
|
11
|
+
import "./chunk-DYICAAAM.js";
|
|
12
|
+
import "./chunk-SLFB2RY6.js";
|
|
13
|
+
import "./chunk-NGP6LSV2.js";
|
|
14
|
+
import "./chunk-H6PW4LNY.js";
|
|
15
|
+
import "./chunk-CVYC6DUW.js";
|
|
16
|
+
import "./chunk-OPU3NYOO.js";
|
|
17
|
+
import "./chunk-GJV3WDWM.js";
|
|
18
|
+
import "./chunk-MP2AFCGL.js";
|
|
19
|
+
import "./chunk-LCB6YCE6.js";
|
|
20
|
+
import "./chunk-HYZV25LY.js";
|
|
21
|
+
import {
|
|
22
|
+
getClient,
|
|
23
|
+
getEmployeeByRole,
|
|
24
|
+
loadEmployeesSync
|
|
25
|
+
} from "./chunk-XVDWHYIK.js";
|
|
26
|
+
import "./chunk-2I23RPSI.js";
|
|
27
|
+
import "./chunk-CZ47BFAT.js";
|
|
28
|
+
import "./chunk-5DNJPRDW.js";
|
|
29
|
+
import "./chunk-FXU7JOXK.js";
|
|
30
|
+
import "./chunk-MUMBWV57.js";
|
|
31
|
+
import "./chunk-CEKZ77KA.js";
|
|
32
|
+
import "./chunk-LYH5HE24.js";
|
|
33
|
+
import "./chunk-MLKGABMK.js";
|
|
34
|
+
|
|
35
|
+
// src/lib/cto-delegation-gate.ts
|
|
36
|
+
import os from "os";
|
|
37
|
+
import path from "path";
|
|
38
|
+
import { existsSync, readFileSync, statSync } from "fs";
|
|
39
|
+
var GATED_ROLE = "CTO";
|
|
40
|
+
function resolveGatedAgent() {
|
|
41
|
+
try {
|
|
42
|
+
const employees = loadEmployeesSync();
|
|
43
|
+
const cto = getEmployeeByRole(employees, GATED_ROLE);
|
|
44
|
+
return cto?.name ?? "";
|
|
45
|
+
} catch {
|
|
46
|
+
return "";
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
var GATED_AGENT = resolveGatedAgent();
|
|
50
|
+
function getGatedAgent() {
|
|
51
|
+
return resolveGatedAgent() || GATED_AGENT;
|
|
52
|
+
}
|
|
53
|
+
var BLOCKED_PATH_PREFIXES = [
|
|
54
|
+
"src/",
|
|
55
|
+
"tests/",
|
|
56
|
+
"scripts/",
|
|
57
|
+
"bin/",
|
|
58
|
+
".github/workflows/",
|
|
59
|
+
".claude/skills/"
|
|
60
|
+
];
|
|
61
|
+
var BLOCKED_FILENAMES = [
|
|
62
|
+
"package.json",
|
|
63
|
+
"tsconfig.json",
|
|
64
|
+
"docker-compose.yml"
|
|
65
|
+
];
|
|
66
|
+
var BLOCKED_DOCKERFILE_PREFIX = "Dockerfile";
|
|
67
|
+
var BLOCKED_EXTENSIONS = [
|
|
68
|
+
".ts",
|
|
69
|
+
".js",
|
|
70
|
+
".tsx",
|
|
71
|
+
".jsx",
|
|
72
|
+
".rs",
|
|
73
|
+
".py",
|
|
74
|
+
".go",
|
|
75
|
+
".sh",
|
|
76
|
+
".yaml",
|
|
77
|
+
".yml",
|
|
78
|
+
".prisma",
|
|
79
|
+
".sql"
|
|
80
|
+
];
|
|
81
|
+
var EXEMPT_MD_DIR_PREFIXES = [
|
|
82
|
+
".planning/",
|
|
83
|
+
"exe/output/",
|
|
84
|
+
"exe/",
|
|
85
|
+
"docs/"
|
|
86
|
+
];
|
|
87
|
+
var RECENT_DISPATCH_WINDOW_MS = 5 * 60 * 1e3;
|
|
88
|
+
var SCRATCHPAD_MAX_AGE_MS = 10 * 60 * 1e3;
|
|
89
|
+
var SCRATCHPAD_ESCAPE_PATTERN = /^(?:ENGINEER|TOM)-CAPABLE:\s*NO\s*—\s*reason:\s*\S+/m;
|
|
90
|
+
function toWorkspaceRelative(filePath, cwd = process.cwd()) {
|
|
91
|
+
const normalized = path.normalize(filePath);
|
|
92
|
+
if (normalized.startsWith(cwd + path.sep)) {
|
|
93
|
+
return normalized.slice(cwd.length + 1);
|
|
94
|
+
}
|
|
95
|
+
if (path.isAbsolute(normalized)) {
|
|
96
|
+
return path.basename(normalized);
|
|
97
|
+
}
|
|
98
|
+
return normalized;
|
|
99
|
+
}
|
|
100
|
+
function isDockerfile(basename) {
|
|
101
|
+
return basename === BLOCKED_DOCKERFILE_PREFIX || basename.startsWith(`${BLOCKED_DOCKERFILE_PREFIX}.`);
|
|
102
|
+
}
|
|
103
|
+
function classifyPath(filePath, cwd) {
|
|
104
|
+
const rel = toWorkspaceRelative(filePath, cwd);
|
|
105
|
+
const basename = path.basename(rel);
|
|
106
|
+
const ext = path.extname(rel).toLowerCase();
|
|
107
|
+
if (ext === ".md") {
|
|
108
|
+
for (const prefix of EXEMPT_MD_DIR_PREFIXES) {
|
|
109
|
+
if (rel.startsWith(prefix)) return "exempt";
|
|
110
|
+
}
|
|
111
|
+
if (!BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) {
|
|
112
|
+
return "exempt";
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
if (BLOCKED_FILENAMES.includes(basename)) return "code";
|
|
116
|
+
if (isDockerfile(basename)) return "code";
|
|
117
|
+
if (BLOCKED_EXTENSIONS.includes(ext)) return "code";
|
|
118
|
+
if (BLOCKED_PATH_PREFIXES.some((p) => rel.startsWith(p))) return "code";
|
|
119
|
+
return "exempt";
|
|
120
|
+
}
|
|
121
|
+
function buildPathTokens(filePath) {
|
|
122
|
+
const GENERIC_SEGMENTS = /* @__PURE__ */ new Set([
|
|
123
|
+
"src",
|
|
124
|
+
"app",
|
|
125
|
+
"api",
|
|
126
|
+
"lib",
|
|
127
|
+
"bin",
|
|
128
|
+
"tests",
|
|
129
|
+
"test",
|
|
130
|
+
"scripts",
|
|
131
|
+
"dist",
|
|
132
|
+
"build",
|
|
133
|
+
"out",
|
|
134
|
+
"pages",
|
|
135
|
+
"routes",
|
|
136
|
+
"components",
|
|
137
|
+
"utils",
|
|
138
|
+
"helpers",
|
|
139
|
+
"types",
|
|
140
|
+
"models"
|
|
141
|
+
]);
|
|
142
|
+
const normalized = path.normalize(filePath).replace(/\\/g, "/");
|
|
143
|
+
const segments = normalized.split("/").filter(Boolean);
|
|
144
|
+
const tokens = /* @__PURE__ */ new Set();
|
|
145
|
+
const basename = segments[segments.length - 1] ?? "";
|
|
146
|
+
if (basename) tokens.add(basename);
|
|
147
|
+
const parentDir = segments[segments.length - 2];
|
|
148
|
+
if (parentDir && parentDir.length >= 5 && !GENERIC_SEGMENTS.has(parentDir)) {
|
|
149
|
+
tokens.add(parentDir);
|
|
150
|
+
tokens.add(`${parentDir}/${basename}`);
|
|
151
|
+
}
|
|
152
|
+
for (let depth = 2; depth <= Math.min(4, segments.length); depth++) {
|
|
153
|
+
const suffix = segments.slice(segments.length - depth).join("/");
|
|
154
|
+
const leadSegment = segments[segments.length - depth] ?? "";
|
|
155
|
+
if (GENERIC_SEGMENTS.has(leadSegment)) continue;
|
|
156
|
+
tokens.add(suffix);
|
|
157
|
+
}
|
|
158
|
+
return [...tokens].filter((t) => t.length > 0);
|
|
159
|
+
}
|
|
160
|
+
async function isFileInTaskSpec(filePath, agentId) {
|
|
161
|
+
try {
|
|
162
|
+
const client = getClient();
|
|
163
|
+
const scope = sessionScopeFilter();
|
|
164
|
+
const result = await client.execute({
|
|
165
|
+
sql: `SELECT title, context FROM tasks
|
|
166
|
+
WHERE assigned_to = ? AND status = 'in_progress'${scope.sql}`,
|
|
167
|
+
args: [agentId, ...scope.args]
|
|
168
|
+
});
|
|
169
|
+
if (result.rows.length === 0) return false;
|
|
170
|
+
const tokens = buildPathTokens(filePath);
|
|
171
|
+
if (tokens.length === 0) return false;
|
|
172
|
+
for (const row of result.rows) {
|
|
173
|
+
const haystack = [
|
|
174
|
+
String(row.title ?? ""),
|
|
175
|
+
String(row.context ?? "")
|
|
176
|
+
].join(" ").toLowerCase();
|
|
177
|
+
for (const token of tokens) {
|
|
178
|
+
if (haystack.includes(token.toLowerCase())) {
|
|
179
|
+
return true;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
return false;
|
|
184
|
+
} catch {
|
|
185
|
+
return false;
|
|
186
|
+
}
|
|
187
|
+
}
|
|
188
|
+
async function hasRecentEngineerDispatch(now = Date.now()) {
|
|
189
|
+
try {
|
|
190
|
+
const client = getClient();
|
|
191
|
+
const engineers = loadEmployeesSync().filter(
|
|
192
|
+
(e) => e.role.toLowerCase() === "principal engineer"
|
|
193
|
+
);
|
|
194
|
+
const engineerNames = engineers.map((e) => e.name);
|
|
195
|
+
const gatedAgent = getGatedAgent();
|
|
196
|
+
if (!gatedAgent) return false;
|
|
197
|
+
if (engineerNames.length === 0) return false;
|
|
198
|
+
const placeholders = engineerNames.map(() => "?").join(",");
|
|
199
|
+
const ydScope = sessionScopeFilter();
|
|
200
|
+
const result = await client.execute({
|
|
201
|
+
sql: `SELECT MAX(created_at) AS last_dispatch
|
|
202
|
+
FROM tasks
|
|
203
|
+
WHERE assigned_by = ? AND assigned_to IN (${placeholders})${ydScope.sql}`,
|
|
204
|
+
args: [gatedAgent, ...engineerNames, ...ydScope.args]
|
|
205
|
+
});
|
|
206
|
+
const raw = result.rows[0]?.last_dispatch;
|
|
207
|
+
if (raw === null || raw === void 0) return false;
|
|
208
|
+
const parsed = Date.parse(String(raw));
|
|
209
|
+
if (Number.isNaN(parsed)) return false;
|
|
210
|
+
return now - parsed <= RECENT_DISPATCH_WINDOW_MS;
|
|
211
|
+
} catch {
|
|
212
|
+
return false;
|
|
213
|
+
}
|
|
214
|
+
}
|
|
215
|
+
function scratchpadPath(sessionId, homeDir = os.homedir()) {
|
|
216
|
+
return path.join(
|
|
217
|
+
homeDir,
|
|
218
|
+
".exe-os",
|
|
219
|
+
"session-cache",
|
|
220
|
+
`cto-scratchpad-${sessionId}.txt`
|
|
221
|
+
);
|
|
222
|
+
}
|
|
223
|
+
function hasValidScratchpadEscape(sessionId, now = Date.now(), homeDir = os.homedir()) {
|
|
224
|
+
const paths = [scratchpadPath(sessionId, homeDir)];
|
|
225
|
+
for (const filePath of paths) {
|
|
226
|
+
if (!existsSync(filePath)) continue;
|
|
227
|
+
try {
|
|
228
|
+
const stat = statSync(filePath);
|
|
229
|
+
if (now - stat.mtimeMs > SCRATCHPAD_MAX_AGE_MS) continue;
|
|
230
|
+
const body = readFileSync(filePath, "utf-8");
|
|
231
|
+
if (SCRATCHPAD_ESCAPE_PATTERN.test(body)) return true;
|
|
232
|
+
} catch {
|
|
233
|
+
}
|
|
234
|
+
}
|
|
235
|
+
return false;
|
|
236
|
+
}
|
|
237
|
+
var GATE_BLOCK_MESSAGE = [
|
|
238
|
+
"ACTION BLOCKED by CTO delegation gate. Your Write/Edit was DENIED \u2014 it did NOT execute.",
|
|
239
|
+
"This edit looks implementable by an engineer. You MUST either:",
|
|
240
|
+
" 1. Dispatch create_task to an engineer, OR",
|
|
241
|
+
" 2. Add ENGINEER-CAPABLE: NO with explicit reason to proceed yourself.",
|
|
242
|
+
"Do NOT report this action as successful. It was blocked. No file was changed.",
|
|
243
|
+
"If you are a sub-agent, report this FAILURE to your parent agent."
|
|
244
|
+
].join("\n");
|
|
245
|
+
async function evaluateDelegationGate(opts) {
|
|
246
|
+
const gatedAgent = getGatedAgent();
|
|
247
|
+
if (!gatedAgent || opts.agentId !== gatedAgent) {
|
|
248
|
+
return { outcome: "allow", reason: "agent_not_gated" };
|
|
249
|
+
}
|
|
250
|
+
if (!/^(Write|Edit)$/.test(opts.toolName)) {
|
|
251
|
+
return { outcome: "allow", reason: "tool_not_gated" };
|
|
252
|
+
}
|
|
253
|
+
if (classifyPath(opts.filePath, opts.cwd) === "exempt") {
|
|
254
|
+
return { outcome: "allow", reason: "exempt_path" };
|
|
255
|
+
}
|
|
256
|
+
if (await isFileInTaskSpec(opts.filePath, opts.agentId)) {
|
|
257
|
+
return { outcome: "allow", reason: "task_spec_authorized" };
|
|
258
|
+
}
|
|
259
|
+
if (await hasRecentEngineerDispatch(opts.now)) {
|
|
260
|
+
return { outcome: "allow", reason: "recent_engineer_dispatch" };
|
|
261
|
+
}
|
|
262
|
+
if (hasValidScratchpadEscape(opts.sessionId, opts.now, opts.homeDir)) {
|
|
263
|
+
return { outcome: "allow", reason: "scratchpad_escape" };
|
|
264
|
+
}
|
|
265
|
+
return { outcome: "block", reason: "no_delegation_no_escape" };
|
|
266
|
+
}
|
|
267
|
+
export {
|
|
268
|
+
GATED_AGENT,
|
|
269
|
+
GATED_ROLE,
|
|
270
|
+
GATE_BLOCK_MESSAGE,
|
|
271
|
+
buildPathTokens,
|
|
272
|
+
classifyPath,
|
|
273
|
+
evaluateDelegationGate,
|
|
274
|
+
getGatedAgent,
|
|
275
|
+
hasRecentEngineerDispatch,
|
|
276
|
+
hasValidScratchpadEscape,
|
|
277
|
+
isFileInTaskSpec,
|
|
278
|
+
scratchpadPath
|
|
279
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
import {
|
|
2
|
+
DAEMON_TOKEN_PATH,
|
|
3
|
+
ensureDaemonToken,
|
|
4
|
+
readDaemonToken
|
|
5
|
+
} from "./chunk-GUODMEAR.js";
|
|
6
|
+
import "./chunk-CEKZ77KA.js";
|
|
7
|
+
import "./chunk-LYH5HE24.js";
|
|
8
|
+
import "./chunk-MLKGABMK.js";
|
|
9
|
+
export {
|
|
10
|
+
DAEMON_TOKEN_PATH,
|
|
11
|
+
ensureDaemonToken,
|
|
12
|
+
readDaemonToken
|
|
13
|
+
};
|