@askexenow/exe-os 0.9.227 → 0.9.228
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/active-agent-TV77LOCD.js +24 -0
- package/dist/active-agent-ZAA4EQNM.js +25 -0
- package/dist/agent-context-ZPDQOAD2.js +9 -0
- package/dist/agent-heartbeat-AWTVGE4C.js +60 -0
- package/dist/agent-loop-7UM2ENGU.js +10 -0
- package/dist/agentic-ontology-QBHUIJPH.js +25 -0
- package/dist/asana-JN2UF47A.js +129 -0
- package/dist/assets/ghostty.conf +83 -0
- package/dist/assets/statusline-command.sh +44 -0
- package/dist/assets/tmux.conf +56 -0
- package/dist/assets/wezterm.lua +68 -0
- package/dist/backfill-metadata-R77LUJHF.js +596 -0
- package/dist/background-jobs-VTOMOTNA.js +25 -0
- package/dist/bash-XA65M6T6.js +8 -0
- package/dist/behaviors-P5SSPIVO.js +24 -0
- package/dist/bin/age-ontology-load.js +85 -0
- package/dist/bin/agentic-ontology-backfill.js +84 -0
- package/dist/bin/agentic-reflection-backfill.js +45 -0
- package/dist/bin/agentic-semantic-label.js +193 -0
- package/dist/bin/backfill-conversations.js +399 -0
- package/dist/bin/backfill-responses.js +227 -0
- package/dist/bin/backfill-vectors.js +149 -0
- package/dist/bin/bulk-sync-postgres.js +92 -0
- package/dist/bin/cc-doctor.js +51 -0
- package/dist/bin/cleanup-stale-review-tasks.js +139 -0
- package/dist/bin/cli.js +1076 -0
- package/dist/bin/customer-readiness.js +389 -0
- package/dist/bin/deferred-daemon-restart.js +123 -0
- package/dist/bin/exe-agent-config.js +87 -0
- package/dist/bin/exe-agent.js +190 -0
- package/dist/bin/exe-assign.js +93 -0
- package/dist/bin/exe-boot.js +1114 -0
- package/dist/bin/exe-call.js +127 -0
- package/dist/bin/exe-cloud.js +484 -0
- package/dist/bin/exe-dispatch.js +72 -0
- package/dist/bin/exe-doctor.js +48 -0
- package/dist/bin/exe-export-behaviors.js +48 -0
- package/dist/bin/exe-forget.js +204 -0
- package/dist/bin/exe-gateway.js +1137 -0
- package/dist/bin/exe-healthcheck.js +14 -0
- package/dist/bin/exe-heartbeat.js +233 -0
- package/dist/bin/exe-kill.js +126 -0
- package/dist/bin/exe-launch-agent.js +678 -0
- package/dist/bin/exe-new-employee.js +160 -0
- package/dist/bin/exe-pending-messages.js +60 -0
- package/dist/bin/exe-pending-notifications.js +107 -0
- package/dist/bin/exe-pending-reviews.js +81 -0
- package/dist/bin/exe-rename.js +219 -0
- package/dist/bin/exe-repo-drift.js +95 -0
- package/dist/bin/exe-review.js +251 -0
- package/dist/bin/exe-search.js +65 -0
- package/dist/bin/exe-session-cleanup.js +331 -0
- package/dist/bin/exe-settings.js +364 -0
- package/dist/bin/exe-start-codex.js +404 -0
- package/dist/bin/exe-start-opencode.js +233 -0
- package/dist/bin/exe-start.sh +194 -0
- package/dist/bin/exe-status.js +34 -0
- package/dist/bin/exe-support.js +17 -0
- package/dist/bin/exe-team.js +83 -0
- package/dist/bin/generate-hook-manifest.js +30 -0
- package/dist/bin/git-sweep.js +74 -0
- package/dist/bin/graph-backfill.js +78 -0
- package/dist/bin/graph-export.js +66 -0
- package/dist/bin/graph-layer-benchmark.js +113 -0
- package/dist/bin/import-history.js +84 -0
- package/dist/bin/install-launchd.js +41 -0
- package/dist/bin/install.js +422 -0
- package/dist/bin/intercom-check.js +137 -0
- package/dist/bin/list-providers.js +128 -0
- package/dist/bin/mcp-sessions.js +194 -0
- package/dist/bin/orchestration-metrics.js +61 -0
- package/dist/bin/postgres-agentic-reflection-backfill.js +123 -0
- package/dist/bin/postgres-agentic-semantic-backfill.js +126 -0
- package/dist/bin/pre-build-guard.js +98 -0
- package/dist/bin/pre-publish.js +224 -0
- package/dist/bin/registry-proxy.js +44 -0
- package/dist/bin/scan-tasks.js +265 -0
- package/dist/bin/setup.js +19 -0
- package/dist/bin/shard-migrate.js +162 -0
- package/dist/bin/stack-update.js +372 -0
- package/dist/bin/update.js +354 -0
- package/dist/bin/verify-stack.js +389 -0
- package/dist/bin/vps-backup.js +170 -0
- package/dist/bin/vps-health-gate.js +232 -0
- package/dist/branding-I2TDZFUH.js +97 -0
- package/dist/browser-sanitizer-MRSSEJZE.js +229 -0
- package/dist/browser-session-store-RF45DSJR.js +232 -0
- package/dist/capacity-monitor-VHBHMKF7.js +48 -0
- package/dist/catchup-brief-LBCPHOKB.js +150 -0
- package/dist/chunk-2VZ6SY2R.js +142 -0
- package/dist/chunk-3IRWSEMI.js +1088 -0
- package/dist/chunk-3JP3FY33.js +258 -0
- package/dist/chunk-3VJHNEPN.js +262 -0
- package/dist/chunk-426NVFWA.js +128 -0
- package/dist/chunk-46SQTBQW.js +207 -0
- package/dist/chunk-4JERP7NT.js +132 -0
- package/dist/chunk-557C2IGL.js +0 -0
- package/dist/chunk-5BS5ELMC.js +85 -0
- package/dist/chunk-5NFBE376.js +391 -0
- package/dist/chunk-6A7P74QV.js +53 -0
- package/dist/chunk-6ES7UEXD.js +77 -0
- package/dist/chunk-6KFICEAT.js +20 -0
- package/dist/chunk-6MP5NOOR.js +151 -0
- package/dist/chunk-6Y4B3QF6.js +19 -0
- package/dist/chunk-7GDCFV36.js +129 -0
- package/dist/chunk-7LKJBYBN.js +495 -0
- package/dist/chunk-7NNXBDOO.js +541 -0
- package/dist/chunk-7OM54FQY.js +627 -0
- package/dist/chunk-7WBEMFHW.js +1919 -0
- package/dist/chunk-A62JW3VH.js +382 -0
- package/dist/chunk-AHMUF6RO.js +147 -0
- package/dist/chunk-AJWFPKQS.js +573 -0
- package/dist/chunk-AR7J6K6W.js +363 -0
- package/dist/chunk-AVE2B4DQ.js +140 -0
- package/dist/chunk-AZSCW64F.js +190 -0
- package/dist/chunk-B3IPZ7DJ.js +38 -0
- package/dist/chunk-CDN4PWHZ.js +330 -0
- package/dist/chunk-CEGFVFT3.js +70 -0
- package/dist/chunk-CHCA3ZM2.js +167 -0
- package/dist/chunk-CHUGUZV3.js +90 -0
- package/dist/chunk-CLGB3FGL.js +48 -0
- package/dist/chunk-CVYC6DUW.js +78 -0
- package/dist/chunk-CX6GL3ZJ.js +274 -0
- package/dist/chunk-D2DRHXSV.js +197 -0
- package/dist/chunk-D4IVTUNN.js +377 -0
- package/dist/chunk-DD2ABSIG.js +348 -0
- package/dist/chunk-DGOGCPYU.js +390 -0
- package/dist/chunk-DHHTLRXE.js +1020 -0
- package/dist/chunk-E6ORBQHP.js +225 -0
- package/dist/chunk-ECDKU54I.js +240 -0
- package/dist/chunk-ECGTESAP.js +236 -0
- package/dist/chunk-ECSNSHZ7.js +431 -0
- package/dist/chunk-ECYFNBCU.js +290 -0
- package/dist/chunk-EGWPJQRQ.js +159 -0
- package/dist/chunk-EIT6J37V.js +119 -0
- package/dist/chunk-EQSQ4HBW.js +9 -0
- package/dist/chunk-ETSREHYC.js +55 -0
- package/dist/chunk-F6OEJ4AL.js +75 -0
- package/dist/chunk-F7LU65PQ.js +33 -0
- package/dist/chunk-FJV6WJS6.js +76 -0
- package/dist/chunk-FLSASUV3.js +177 -0
- package/dist/chunk-FV5FDWL3.js +121 -0
- package/dist/chunk-FWFFZGSC.js +94 -0
- package/dist/chunk-FXU7JOXK.js +6 -0
- package/dist/chunk-GAHM4SUR.js +171 -0
- package/dist/chunk-GFCQJZTO.js +1051 -0
- package/dist/chunk-GGV3PFUW.js +41 -0
- package/dist/chunk-GGZ4NTZH.js +333 -0
- package/dist/chunk-GJV3WDWM.js +14 -0
- package/dist/chunk-GMIXDGAT.js +280 -0
- package/dist/chunk-GNHN5HRQ.js +40 -0
- package/dist/chunk-GP6G6EQI.js +632 -0
- package/dist/chunk-GST2EPOG.js +2017 -0
- package/dist/chunk-GUMRIUI5.js +63 -0
- package/dist/chunk-GVP5U4WL.js +113 -0
- package/dist/chunk-H32Z73OY.js +81 -0
- package/dist/chunk-HF25XPZE.js +83 -0
- package/dist/chunk-HFRT4QZS.js +50 -0
- package/dist/chunk-HOKOOBDL.js +52 -0
- package/dist/chunk-HQMEOIUJ.js +69 -0
- package/dist/chunk-HYZV25LY.js +34 -0
- package/dist/chunk-I7AW4237.js +251 -0
- package/dist/chunk-IONVLDMB.js +297 -0
- package/dist/chunk-IPWTDGWM.js +356 -0
- package/dist/chunk-IQT43SDJ.js +357 -0
- package/dist/chunk-IUHWJRDM.js +614 -0
- package/dist/chunk-J4Y6FQ77.js +54 -0
- package/dist/chunk-JGGCKDMB.js +1090 -0
- package/dist/chunk-JGNCI7BA.js +159 -0
- package/dist/chunk-JQ6TLNIV.js +133 -0
- package/dist/chunk-JRXV6UES.js +214 -0
- package/dist/chunk-K2YWCFZ3.js +147 -0
- package/dist/chunk-KCUYRZSX.js +72 -0
- package/dist/chunk-KH5Y6RR4.js +360 -0
- package/dist/chunk-KQMP6TJZ.js +157 -0
- package/dist/chunk-KX6LS6XO.js +97 -0
- package/dist/chunk-L24HYX62.js +498 -0
- package/dist/chunk-L3TB7CC3.js +170 -0
- package/dist/chunk-LWVZLTMD.js +412 -0
- package/dist/chunk-LXDNFQNN.js +1073 -0
- package/dist/chunk-LYH5HE24.js +73 -0
- package/dist/chunk-M43RSLT4.js +213 -0
- package/dist/chunk-MLXJ5EZG.js +90 -0
- package/dist/chunk-MP2AFCGL.js +53 -0
- package/dist/chunk-MQPW7X4P.js +403 -0
- package/dist/chunk-MVW62NIZ.js +20 -0
- package/dist/chunk-MZIGUUDQ.js +42 -0
- package/dist/chunk-N2SIOC5S.js +463 -0
- package/dist/chunk-N5RRQOAC.js +134 -0
- package/dist/chunk-NB5HOHLB.js +135 -0
- package/dist/chunk-NBEX5NG6.js +284 -0
- package/dist/chunk-NC56276G.js +30 -0
- package/dist/chunk-NGJ5FIQV.js +3511 -0
- package/dist/chunk-NGP6LSV2.js +25 -0
- package/dist/chunk-NGVOA6ZQ.js +84 -0
- package/dist/chunk-NI2X6SFD.js +221 -0
- package/dist/chunk-NOSCT6NZ.js +210 -0
- package/dist/chunk-NRFVWJHP.js +575 -0
- package/dist/chunk-O377P7GM.js +100 -0
- package/dist/chunk-ONKIWA3R.js +249 -0
- package/dist/chunk-OPU3NYOO.js +55 -0
- package/dist/chunk-ORCCI2VV.js +140 -0
- package/dist/chunk-OYNKIAVW.js +181 -0
- package/dist/chunk-P7E37KXE.js +244 -0
- package/dist/chunk-PKJTWKKN.js +58 -0
- package/dist/chunk-PRKVT4KN.js +90 -0
- package/dist/chunk-PWMMIGVQ.js +332 -0
- package/dist/chunk-Q3V7K4ME.js +149 -0
- package/dist/chunk-Q7RGLXQO.js +574 -0
- package/dist/chunk-QGGH7LOU.js +93 -0
- package/dist/chunk-QI4IXJN7.js +132 -0
- package/dist/chunk-QNHI4XDN.js +346 -0
- package/dist/chunk-R4WMF32C.js +81 -0
- package/dist/chunk-R5U7XKVJ.js +16 -0
- package/dist/chunk-RJT7H2KR.js +349 -0
- package/dist/chunk-RKDATCH4.js +813 -0
- package/dist/chunk-SD6IDXF7.js +33 -0
- package/dist/chunk-SEPE2UMS.js +667 -0
- package/dist/chunk-SH45SJQW.js +0 -0
- package/dist/chunk-SUNYJ6YE.js +204 -0
- package/dist/chunk-SVXDCELZ.js +163 -0
- package/dist/chunk-TMEE7AT7.js +72 -0
- package/dist/chunk-TNTFEWU5.js +361 -0
- package/dist/chunk-TWR6EV57.js +3753 -0
- package/dist/chunk-U7XLP37W.js +85 -0
- package/dist/chunk-UBRE5MK7.js +183 -0
- package/dist/chunk-UBWE5LSJ.js +227 -0
- package/dist/chunk-UEBRQCJ7.js +1345 -0
- package/dist/chunk-UOI5DAYH.js +128 -0
- package/dist/chunk-V4TZI6EO.js +60 -0
- package/dist/chunk-VUVSYEGB.js +731 -0
- package/dist/chunk-X2Z5GT3V.js +118 -0
- package/dist/chunk-X2ZDES26.js +56 -0
- package/dist/chunk-X3AVWFWW.js +294 -0
- package/dist/chunk-XEKO37NM.js +43 -0
- package/dist/chunk-Y5AX66S3.js +1051 -0
- package/dist/chunk-YADYM2DE.js +42 -0
- package/dist/chunk-YGAAZN3E.js +47 -0
- package/dist/chunk-YIDLK73D.js +13097 -0
- package/dist/chunk-YLCSHPZE.js +123 -0
- package/dist/chunk-YSU7JB7H.js +0 -0
- package/dist/chunk-YZFZDJWZ.js +107 -0
- package/dist/chunk-YZKJLGWL.js +169 -0
- package/dist/chunk-ZCSI2XTD.js +204 -0
- package/dist/chunk-ZVSG2KKG.js +106 -0
- package/dist/co-activation-SEYZ6WBU.js +71 -0
- package/dist/co-occurrence-AO3AT5JK.js +73 -0
- package/dist/code-context-index-KHUYATRB.js +29 -0
- package/dist/content-extractor-CUJOBFBU.js +9 -0
- package/dist/conversation-entity-extractor-TW4W57K4.js +114 -0
- package/dist/conversation-wiki-populator-GNFRTS7X.js +105 -0
- package/dist/core-memory-SUM5RZX2.js +110 -0
- package/dist/crdt-sync-X53T4NUI.js +33 -0
- package/dist/crm-bridge-NG5WJMGF.js +19 -0
- package/dist/crm-webhook-3UMCZDFK.js +10 -0
- package/dist/cto-delegation-gate-R3BYZCXG.js +205 -0
- package/dist/daemon-auth-WFQMMNSD.js +13 -0
- package/dist/daemon-orchestration-JRA7CJGJ.js +133 -0
- package/dist/daemon-protocol-4FUHT5NH.js +17 -0
- package/dist/db-backup-STROKTGN.js +25 -0
- package/dist/devtools-J4QYYO7U.js +8 -0
- package/dist/discord-7UHIZNJ3.js +7 -0
- package/dist/dispatch-ack-RMVFHO4I.js +13 -0
- package/dist/dreaming-6POCE2CN.js +12 -0
- package/dist/email-T6PQUUY6.js +137 -0
- package/dist/entity-boost-7MB2IYAE.js +332 -0
- package/dist/exe-drift-FO4S2MIW.js +67 -0
- package/dist/exe-export-XRDCOZM2.js +72 -0
- package/dist/exe-import-QBTXHGTH.js +75 -0
- package/dist/exe-key-UGOHWRYG.js +573 -0
- package/dist/exe-org-JRBBON5H.js +73 -0
- package/dist/exe-snapshot-Z4AZPSGS.js +145 -0
- package/dist/factory-UQSRMKJW.js +67 -0
- package/dist/fast-db-init-CAC7HD5B.js +7 -0
- package/dist/file-edit-YORRFENG.js +8 -0
- package/dist/file-read-RMQFDE5L.js +8 -0
- package/dist/file-write-VO4MQW5Y.js +8 -0
- package/dist/founder-context-3N6BMG7B.js +96 -0
- package/dist/gateway/index.js +148 -0
- package/dist/gateway-client-V7NH35Q2.js +11 -0
- package/dist/git-staleness-UMHQDPQU.js +109 -0
- package/dist/git-task-sweep-WZ3LH6EV.js +39 -0
- package/dist/glob-2LXRC3F5.js +7 -0
- package/dist/global-procedures-NSZQNWXA.js +19 -0
- package/dist/graph-auto-extract-A5PHP3G3.js +161 -0
- package/dist/graph-query-YZ4RZEIL.js +26 -0
- package/dist/graph-rag-S5SBJW5J.js +29 -0
- package/dist/grep-OY7KCRLQ.js +7 -0
- package/dist/hook-integrity-OKSYTGVP.js +89 -0
- package/dist/hooks/bug-report-worker.js +179 -0
- package/dist/hooks/codex-stop-task-finalizer.js +258 -0
- package/dist/hooks/commit-complete.js +162 -0
- package/dist/hooks/error-recall.js +129 -0
- package/dist/hooks/exe-heartbeat-hook.js +78 -0
- package/dist/hooks/ingest-worker.js +51 -0
- package/dist/hooks/ingest.js +491 -0
- package/dist/hooks/instructions-loaded.js +119 -0
- package/dist/hooks/manifest.json +25 -0
- package/dist/hooks/notification.js +67 -0
- package/dist/hooks/post-compact.js +138 -0
- package/dist/hooks/post-tool-combined.js +152 -0
- package/dist/hooks/pre-compact.js +159 -0
- package/dist/hooks/pre-tool-use.js +512 -0
- package/dist/hooks/prompt-submit.js +699 -0
- package/dist/hooks/session-end.js +482 -0
- package/dist/hooks/session-start.js +362 -0
- package/dist/hooks/stop.js +332 -0
- package/dist/hooks/subagent-stop.js +85 -0
- package/dist/hooks/summary-worker.js +298 -0
- package/dist/hooks-RPTZV5KX.js +9 -0
- package/dist/imessage-CE5USLTI.js +7 -0
- package/dist/index.js +60 -0
- package/dist/installer-A5HRSX7C.js +37 -0
- package/dist/installer-JACODBI7.js +341 -0
- package/dist/installer-VWO4T7B6.js +295 -0
- package/dist/intercom-queue-USIXVVJQ.js +17 -0
- package/dist/key-backup-status-TVFMMWTT.js +39 -0
- package/dist/keyword-extractor-OGQRRVTB.js +11 -0
- package/dist/lib/agent-config.js +30 -0
- package/dist/lib/cloud-sync.js +103 -0
- package/dist/lib/cloudflare-dns.js +13 -0
- package/dist/lib/config.js +32 -0
- package/dist/lib/consolidation.js +38 -0
- package/dist/lib/crypto.js +13 -0
- package/dist/lib/database.js +31 -0
- package/dist/lib/db-daemon-client.js +141 -0
- package/dist/lib/db.js +31 -0
- package/dist/lib/device-registry.js +70 -0
- package/dist/lib/embed-worker.js +165 -0
- package/dist/lib/embedder.js +19 -0
- package/dist/lib/employee-templates.js +34 -0
- package/dist/lib/employees.js +63 -0
- package/dist/lib/error-detector.js +16 -0
- package/dist/lib/exe-daemon-client.js +25 -0
- package/dist/lib/exe-daemon.js +4417 -0
- package/dist/lib/file-grep.js +242 -0
- package/dist/lib/hybrid-search.js +28 -0
- package/dist/lib/identity-templates.js +650 -0
- package/dist/lib/identity.js +19 -0
- package/dist/lib/keychain.js +17 -0
- package/dist/lib/license.js +35 -0
- package/dist/lib/messaging.js +59 -0
- package/dist/lib/post-tool-memory.js +13 -0
- package/dist/lib/registry-proxy.js +15 -0
- package/dist/lib/reminders.js +16 -0
- package/dist/lib/runtime-table.js +9 -0
- package/dist/lib/schedules.js +24 -0
- package/dist/lib/session-registry.js +21 -0
- package/dist/lib/session-wrappers.js +7 -0
- package/dist/lib/skill-learning.js +29 -0
- package/dist/lib/status-brief.js +7 -0
- package/dist/lib/store.js +43 -0
- package/dist/lib/task-router.js +22 -0
- package/dist/lib/tasks.js +66 -0
- package/dist/lib/tmux-routing.js +70 -0
- package/dist/lib/tmux-status.js +29 -0
- package/dist/lib/tmux-transport.js +7 -0
- package/dist/lib/token-spend.js +12 -0
- package/dist/lib/transport.js +10 -0
- package/dist/lib/ws-auth.js +11 -0
- package/dist/lib/ws-client.js +190 -0
- package/dist/license-gate-7QVCYARF.js +14 -0
- package/dist/mcp/register-tools.js +102 -0
- package/dist/mcp/server.js +370 -0
- package/dist/mcp/tools/complete-reminder.js +13 -0
- package/dist/mcp/tools/create-reminder.js +13 -0
- package/dist/mcp/tools/create-task.js +34 -0
- package/dist/mcp/tools/deactivate-behavior.js +16 -0
- package/dist/mcp/tools/list-reminders.js +13 -0
- package/dist/mcp/tools/list-tasks.js +33 -0
- package/dist/mcp/tools/send-message.js +33 -0
- package/dist/mcp/tools/update-task.js +32 -0
- package/dist/mcp-diagnostics-5T5OZ52S.js +200 -0
- package/dist/mcp-disconnect-tracker-VINUVEZJ.js +79 -0
- package/dist/mcp-http-config-HMQWKLON.js +26 -0
- package/dist/memory-cards-N7LZUKHF.js +173 -0
- package/dist/memory-graph-extractor-GADBVHRC.js +16 -0
- package/dist/memory-poisoning-defense-LHAUEVKF.js +224 -0
- package/dist/memory-queue-WEVFXPZO.js +19 -0
- package/dist/memory-queue-client-5XBHYAQR.js +15 -0
- package/dist/memory-reflection-SHO2CV4L.js +237 -0
- package/dist/message-queue-client-FUKX43JD.js +92 -0
- package/dist/notifications-2UJNSWRB.js +44 -0
- package/dist/oauth-server-CCZPDTZJ.js +437 -0
- package/dist/orchestration-events-O7GWLTB2.js +24 -0
- package/dist/orchestration-phase-HXRKMZXM.js +23 -0
- package/dist/orchestrator-AXIBALJX.js +32 -0
- package/dist/permission-presets-UPVLJWZD.js +25 -0
- package/dist/permissions-C4EMHPDD.js +14 -0
- package/dist/pg-ssl-GD3332YS.js +7 -0
- package/dist/pipeline-router-3HUUYCV2.js +12 -0
- package/dist/plan-limits-TWD5VXMU.js +25 -0
- package/dist/prediction-log-C2BD3AHR.js +120 -0
- package/dist/preferences-5ARPMYE7.js +10 -0
- package/dist/preflight-TZOGLBZU.js +287 -0
- package/dist/project-boot-JIGOSGCN.js +254 -0
- package/dist/project-name-4SKOH2UO.js +10 -0
- package/dist/projection-worker-DUBKXKFL.js +877 -0
- package/dist/push-notifications-3GNJ5SZS.js +15 -0
- package/dist/reranker-4M6UVDRF.js +19 -0
- package/dist/review-gate-I66GDXNR.js +120 -0
- package/dist/review-polling-GCQV3TF6.js +123 -0
- package/dist/runtime/index.js +129 -0
- package/dist/self-query-router-QMK5ZSZR.js +188 -0
- package/dist/session-events-LW67P5MB.js +35 -0
- package/dist/session-kill-telemetry-JYEG7KSE.js +28 -0
- package/dist/session-scope-OOHP3EOV.js +85 -0
- package/dist/setup-wizard-XIPF5N2C.js +12 -0
- package/dist/shard-manager-ON2WWCRM.js +29 -0
- package/dist/signal-KF2LIO7Y.js +7 -0
- package/dist/signal-paths-5ZTWCBUX.js +19 -0
- package/dist/skill-refinement-I4UAAHLL.js +156 -0
- package/dist/slack-JRDUD5Z7.js +7 -0
- package/dist/stack-update-ZIMV4OEQ.js +50 -0
- package/dist/steward-gate-NZ5IUJFV.js +12 -0
- package/dist/support-outbox-HIJVUDA2.js +206 -0
- package/dist/task-enforcement-3DVLNFLX.js +292 -0
- package/dist/task-scanner-5OQBNC2N.js +11 -0
- package/dist/task-scope-NJIPLTZI.js +34 -0
- package/dist/tasks-crud-ET7MUU4V.js +76 -0
- package/dist/tasks-review-QPTYXCZX.js +46 -0
- package/dist/telegram-COCYUCT7.js +7 -0
- package/dist/telemetry-QKWQKAUC.js +9 -0
- package/dist/telemetry-upload-AL2IB3UE.js +609 -0
- package/dist/token-budget-TR2NN66K.js +83 -0
- package/dist/tool-capability-index-UUNF7VPA.js +10 -0
- package/dist/tool-gates-6A6LE4DZ.js +14 -0
- package/dist/tool-gates-RNWEH5IK.js +13 -0
- package/dist/tool-registry-KL24CAFR.js +11 -0
- package/dist/tool-telemetry-43ZIXZSK.js +17 -0
- package/dist/tui/App.js +10223 -0
- package/dist/tui-data-32PP76M6.js +161 -0
- package/dist/typed-messages-53Q7L3LB.js +17 -0
- package/dist/update-check-5IL5I3E2.js +11 -0
- package/dist/webhook-VXGIH7PN.js +96 -0
- package/dist/webhook-pipe-4WPFGGFD.js +114 -0
- package/dist/whatsapp-PSMKCDS7.js +9 -0
- package/dist/whatsapp-accounts-4OKWFRWL.js +15 -0
- package/dist/whatsapp-config-ZG5LX4O4.js +125 -0
- package/dist/wiki-acl-5OHOZNIX.js +111 -0
- package/dist/wiki-client-KE622HKY.js +157 -0
- package/dist/worker-gate-5ISRLLIM.js +21 -0
- package/dist/workflow-engine-UORUJRUR.js +28 -0
- package/dist/working-memory-Z3EB3FW6.js +77 -0
- package/dist/worktree-EPR6QDRF.js +25 -0
- package/package.json +1 -1
|
@@ -0,0 +1,573 @@
|
|
|
1
|
+
import {
|
|
2
|
+
partitionTools
|
|
3
|
+
} from "./chunk-JQ6TLNIV.js";
|
|
4
|
+
import {
|
|
5
|
+
checkPermission
|
|
6
|
+
} from "./chunk-PRKVT4KN.js";
|
|
7
|
+
|
|
8
|
+
// src/runtime/compact.ts
|
|
9
|
+
var COMPACTION_THRESHOLD = 0.85;
|
|
10
|
+
var KEEP_RECENT_MESSAGES = 10;
|
|
11
|
+
function estimateTokens(messages) {
|
|
12
|
+
let chars = 0;
|
|
13
|
+
for (const msg of messages) {
|
|
14
|
+
if (typeof msg.content === "string") {
|
|
15
|
+
chars += msg.content.length;
|
|
16
|
+
} else {
|
|
17
|
+
for (const block of msg.content) {
|
|
18
|
+
if (block.type === "text") chars += block.text.length;
|
|
19
|
+
else if (block.type === "tool_use") chars += JSON.stringify(block.input).length + block.name.length;
|
|
20
|
+
else if (block.type === "tool_result") chars += block.content.length;
|
|
21
|
+
}
|
|
22
|
+
}
|
|
23
|
+
}
|
|
24
|
+
return Math.ceil(chars / 4);
|
|
25
|
+
}
|
|
26
|
+
function needsCompaction(messages, contextLimit) {
|
|
27
|
+
return estimateTokens(messages) > contextLimit * COMPACTION_THRESHOLD;
|
|
28
|
+
}
|
|
29
|
+
function stripMediaBlocks(messages) {
|
|
30
|
+
return messages.map((msg) => {
|
|
31
|
+
if (typeof msg.content === "string") return msg;
|
|
32
|
+
const filtered = msg.content.filter(
|
|
33
|
+
(block) => block.type !== "tool_use" || !isMediaTool(block.name)
|
|
34
|
+
);
|
|
35
|
+
if (filtered.length === 0) {
|
|
36
|
+
return { ...msg, content: "[media content removed for compaction]" };
|
|
37
|
+
}
|
|
38
|
+
return { ...msg, content: filtered };
|
|
39
|
+
});
|
|
40
|
+
}
|
|
41
|
+
function isMediaTool(name) {
|
|
42
|
+
return ["upload_image", "screenshot", "render_image"].includes(name);
|
|
43
|
+
}
|
|
44
|
+
async function compactMessages(messages, provider, summaryModel) {
|
|
45
|
+
if (messages.length <= KEEP_RECENT_MESSAGES) {
|
|
46
|
+
return { messages, removedCount: 0 };
|
|
47
|
+
}
|
|
48
|
+
const toSummarize = messages.slice(0, -KEEP_RECENT_MESSAGES);
|
|
49
|
+
const toKeep = messages.slice(-KEEP_RECENT_MESSAGES);
|
|
50
|
+
const stripped = stripMediaBlocks(toSummarize);
|
|
51
|
+
const effectiveSummaryModel = summaryModel ?? provider.defaultModel;
|
|
52
|
+
if (!effectiveSummaryModel) {
|
|
53
|
+
return {
|
|
54
|
+
messages: [
|
|
55
|
+
{ role: "user", content: "[Earlier conversation history was compacted due to context limits]" },
|
|
56
|
+
{ role: "assistant", content: "Understood. Continuing with recent context." },
|
|
57
|
+
...toKeep
|
|
58
|
+
],
|
|
59
|
+
removedCount: toSummarize.length
|
|
60
|
+
};
|
|
61
|
+
}
|
|
62
|
+
const serialized = stripped.map((m) => {
|
|
63
|
+
const content = typeof m.content === "string" ? m.content : m.content.map((b) => {
|
|
64
|
+
if (b.type === "text") return b.text;
|
|
65
|
+
if (b.type === "tool_use") return `[tool: ${b.name}(${JSON.stringify(b.input).slice(0, 200)})]`;
|
|
66
|
+
if (b.type === "tool_result") return `[result: ${b.content.slice(0, 200)}]`;
|
|
67
|
+
return "";
|
|
68
|
+
}).join("\n");
|
|
69
|
+
return `${m.role}: ${content}`;
|
|
70
|
+
}).join("\n\n");
|
|
71
|
+
try {
|
|
72
|
+
const summary = await provider.createMessage({
|
|
73
|
+
model: effectiveSummaryModel,
|
|
74
|
+
system: "Summarize this conversation concisely. Preserve: decisions made, files modified, current task status, blockers, key findings. Be specific about file paths and tool results.",
|
|
75
|
+
messages: [{ role: "user", content: serialized.slice(0, 5e4) }],
|
|
76
|
+
// Cap input
|
|
77
|
+
maxTokens: 2e3
|
|
78
|
+
});
|
|
79
|
+
const summaryText = summary.content.filter((b) => b.type === "text").map((b) => b.text).join("\n");
|
|
80
|
+
return {
|
|
81
|
+
messages: [
|
|
82
|
+
{ role: "user", content: `[Previous conversation summary]
|
|
83
|
+
${summaryText}` },
|
|
84
|
+
{ role: "assistant", content: "Understood. I have context from the summary. Continuing." },
|
|
85
|
+
...toKeep
|
|
86
|
+
],
|
|
87
|
+
removedCount: toSummarize.length
|
|
88
|
+
};
|
|
89
|
+
} catch {
|
|
90
|
+
return {
|
|
91
|
+
messages: [
|
|
92
|
+
{ role: "user", content: "[Earlier conversation history was compacted due to context limits]" },
|
|
93
|
+
{ role: "assistant", content: "Understood. Continuing with recent context." },
|
|
94
|
+
...toKeep
|
|
95
|
+
],
|
|
96
|
+
removedCount: toSummarize.length
|
|
97
|
+
};
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
// src/runtime/context-manager.ts
|
|
102
|
+
var MODEL_CONTEXT_LIMITS = {
|
|
103
|
+
// Anthropic
|
|
104
|
+
"claude-opus-4": 2e5,
|
|
105
|
+
"claude-sonnet-4": 2e5,
|
|
106
|
+
"claude-haiku-4": 2e5,
|
|
107
|
+
// Extended context variants
|
|
108
|
+
"claude-opus-4-6": 1e6,
|
|
109
|
+
"claude-sonnet-4-6": 1e6,
|
|
110
|
+
// OpenAI
|
|
111
|
+
"gpt-4o": 128e3,
|
|
112
|
+
"gpt-4-turbo": 128e3,
|
|
113
|
+
"gpt-4": 8192,
|
|
114
|
+
"o3": 2e5,
|
|
115
|
+
"o4-mini": 2e5,
|
|
116
|
+
// Google
|
|
117
|
+
"gemini-2.0": 1e6,
|
|
118
|
+
"gemini-2.5-pro": 1e6,
|
|
119
|
+
"gemini-2.5-flash": 1e6,
|
|
120
|
+
// Local / small models
|
|
121
|
+
"llama": 8192,
|
|
122
|
+
"mistral": 32768,
|
|
123
|
+
"qwen": 32768,
|
|
124
|
+
"deepseek": 64e3
|
|
125
|
+
};
|
|
126
|
+
var DEFAULT_CONTEXT_LIMIT = 2e5;
|
|
127
|
+
var PRESSURE_THRESHOLDS = [50, 70, 90];
|
|
128
|
+
function getContextLimit(model) {
|
|
129
|
+
if (model in MODEL_CONTEXT_LIMITS) {
|
|
130
|
+
return MODEL_CONTEXT_LIMITS[model];
|
|
131
|
+
}
|
|
132
|
+
let bestMatch = "";
|
|
133
|
+
let bestLimit = DEFAULT_CONTEXT_LIMIT;
|
|
134
|
+
for (const [prefix, limit] of Object.entries(MODEL_CONTEXT_LIMITS)) {
|
|
135
|
+
if (model.startsWith(prefix) && prefix.length > bestMatch.length) {
|
|
136
|
+
bestMatch = prefix;
|
|
137
|
+
bestLimit = limit;
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
return bestLimit;
|
|
141
|
+
}
|
|
142
|
+
function createContextManager(model, hooks) {
|
|
143
|
+
return new ContextManager(model, hooks);
|
|
144
|
+
}
|
|
145
|
+
var ContextManager = class {
|
|
146
|
+
state;
|
|
147
|
+
hooks;
|
|
148
|
+
constructor(model, hooks) {
|
|
149
|
+
this.hooks = hooks;
|
|
150
|
+
this.state = {
|
|
151
|
+
inputTokens: 0,
|
|
152
|
+
outputTokens: 0,
|
|
153
|
+
estimatedTokens: 0,
|
|
154
|
+
maxTokens: getContextLimit(model),
|
|
155
|
+
thresholdsEmitted: /* @__PURE__ */ new Set(),
|
|
156
|
+
model
|
|
157
|
+
};
|
|
158
|
+
}
|
|
159
|
+
/** Get current context state (read-only snapshot) */
|
|
160
|
+
getState() {
|
|
161
|
+
return { ...this.state, thresholdsEmitted: new Set(this.state.thresholdsEmitted) };
|
|
162
|
+
}
|
|
163
|
+
/** Get current token usage (best available: API data or estimate) */
|
|
164
|
+
get usedTokens() {
|
|
165
|
+
if (this.state.inputTokens > 0) {
|
|
166
|
+
return this.state.inputTokens;
|
|
167
|
+
}
|
|
168
|
+
return this.state.estimatedTokens;
|
|
169
|
+
}
|
|
170
|
+
/** Get percent of context used */
|
|
171
|
+
get percentUsed() {
|
|
172
|
+
return Math.round(this.usedTokens / this.state.maxTokens * 100);
|
|
173
|
+
}
|
|
174
|
+
/**
|
|
175
|
+
* Update with API usage data (from LLM response).
|
|
176
|
+
* This is the most accurate source of token counts.
|
|
177
|
+
*/
|
|
178
|
+
updateFromApiUsage(inputTokens, outputTokens) {
|
|
179
|
+
this.state.inputTokens = inputTokens;
|
|
180
|
+
this.state.outputTokens = outputTokens;
|
|
181
|
+
}
|
|
182
|
+
/**
|
|
183
|
+
* Update with estimated tokens from message content.
|
|
184
|
+
* Used as fallback when API doesn't report cache-aware usage.
|
|
185
|
+
*/
|
|
186
|
+
updateFromMessages(messages) {
|
|
187
|
+
this.state.estimatedTokens = estimateTokens(messages);
|
|
188
|
+
}
|
|
189
|
+
/**
|
|
190
|
+
* Check context pressure and emit threshold events.
|
|
191
|
+
* Should be called after each turn.
|
|
192
|
+
*/
|
|
193
|
+
async checkPressure() {
|
|
194
|
+
const percent = this.percentUsed;
|
|
195
|
+
for (const threshold of PRESSURE_THRESHOLDS) {
|
|
196
|
+
if (percent >= threshold && !this.state.thresholdsEmitted.has(threshold)) {
|
|
197
|
+
this.state.thresholdsEmitted.add(threshold);
|
|
198
|
+
const event = {
|
|
199
|
+
threshold,
|
|
200
|
+
usedTokens: this.usedTokens,
|
|
201
|
+
maxTokens: this.state.maxTokens,
|
|
202
|
+
percentUsed: percent
|
|
203
|
+
};
|
|
204
|
+
if (this.hooks.onContextPressure) {
|
|
205
|
+
try {
|
|
206
|
+
await this.hooks.onContextPressure(event);
|
|
207
|
+
} catch {
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
}
|
|
211
|
+
}
|
|
212
|
+
}
|
|
213
|
+
/** Should compaction run? (85% threshold, matching compact.ts) */
|
|
214
|
+
shouldCompact() {
|
|
215
|
+
return this.usedTokens > this.state.maxTokens * 0.85;
|
|
216
|
+
}
|
|
217
|
+
/**
|
|
218
|
+
* Pre-compaction: fire hooks and extract critical context to protect.
|
|
219
|
+
* Returns strings that must survive compaction.
|
|
220
|
+
*/
|
|
221
|
+
async preCompact(messages) {
|
|
222
|
+
const protectedContext = [];
|
|
223
|
+
const memoriesToExtract = [];
|
|
224
|
+
if (this.hooks.onCompact) {
|
|
225
|
+
try {
|
|
226
|
+
await this.hooks.onCompact(messages.length, 0);
|
|
227
|
+
} catch {
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
const DECISION_PATTERNS = /\b(decided|chose|selected|fixed|resolved|implemented|created|deleted|changed|updated|configured)\b/i;
|
|
231
|
+
const FILE_PATTERNS = /(?:(?:src|lib|bin|tests?)\/[\w/.-]+\.(?:ts|js|json|md))/g;
|
|
232
|
+
for (const msg of messages) {
|
|
233
|
+
const text = typeof msg.content === "string" ? msg.content : msg.content.filter((b) => b.type === "text").map((b) => b.text).join("\n");
|
|
234
|
+
if (text.length > 50 && DECISION_PATTERNS.test(text)) {
|
|
235
|
+
const firstSentence = text.split(/[.\n]/).find((s) => DECISION_PATTERNS.test(s));
|
|
236
|
+
if (firstSentence) {
|
|
237
|
+
memoriesToExtract.push(firstSentence.trim().slice(0, 200));
|
|
238
|
+
}
|
|
239
|
+
}
|
|
240
|
+
const files = text.match(FILE_PATTERNS);
|
|
241
|
+
if (files && files.length > 0) {
|
|
242
|
+
protectedContext.push(`Files referenced: ${[...new Set(files)].join(", ")}`);
|
|
243
|
+
}
|
|
244
|
+
}
|
|
245
|
+
return { protectedContext, memoriesToExtract };
|
|
246
|
+
}
|
|
247
|
+
/**
|
|
248
|
+
* Post-compaction: fire hooks and verify state.
|
|
249
|
+
*/
|
|
250
|
+
async postCompact(removedCount, summaryLength) {
|
|
251
|
+
this.state.estimatedTokens = 0;
|
|
252
|
+
const currentPercent = this.percentUsed;
|
|
253
|
+
for (const threshold of PRESSURE_THRESHOLDS) {
|
|
254
|
+
if (currentPercent < threshold) {
|
|
255
|
+
this.state.thresholdsEmitted.delete(threshold);
|
|
256
|
+
}
|
|
257
|
+
}
|
|
258
|
+
if (this.hooks.onPostCompact) {
|
|
259
|
+
try {
|
|
260
|
+
await this.hooks.onPostCompact(removedCount, `Compacted ${removedCount} messages into ${summaryLength} chars`);
|
|
261
|
+
} catch {
|
|
262
|
+
}
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
/**
|
|
266
|
+
* Switch model mid-session (e.g., failover).
|
|
267
|
+
* Recalculates context limit.
|
|
268
|
+
*/
|
|
269
|
+
switchModel(newModel) {
|
|
270
|
+
this.state.model = newModel;
|
|
271
|
+
this.state.maxTokens = getContextLimit(newModel);
|
|
272
|
+
this.state.thresholdsEmitted.clear();
|
|
273
|
+
}
|
|
274
|
+
};
|
|
275
|
+
|
|
276
|
+
// src/runtime/denial-tracking.ts
|
|
277
|
+
var DENIAL_LIMITS = {
|
|
278
|
+
maxConsecutive: 3,
|
|
279
|
+
maxTotal: 10
|
|
280
|
+
};
|
|
281
|
+
function createDenialTrackingState() {
|
|
282
|
+
return {
|
|
283
|
+
consecutiveDenials: 0,
|
|
284
|
+
totalDenials: 0
|
|
285
|
+
};
|
|
286
|
+
}
|
|
287
|
+
function recordDenial(state) {
|
|
288
|
+
return {
|
|
289
|
+
consecutiveDenials: state.consecutiveDenials + 1,
|
|
290
|
+
totalDenials: state.totalDenials + 1
|
|
291
|
+
};
|
|
292
|
+
}
|
|
293
|
+
function recordSuccess(state) {
|
|
294
|
+
if (state.consecutiveDenials === 0) return state;
|
|
295
|
+
return {
|
|
296
|
+
...state,
|
|
297
|
+
consecutiveDenials: 0
|
|
298
|
+
};
|
|
299
|
+
}
|
|
300
|
+
function shouldFallbackToAsk(state) {
|
|
301
|
+
return state.consecutiveDenials >= DENIAL_LIMITS.maxConsecutive || state.totalDenials >= DENIAL_LIMITS.maxTotal;
|
|
302
|
+
}
|
|
303
|
+
function shouldWarnDenials(state) {
|
|
304
|
+
return state.consecutiveDenials === DENIAL_LIMITS.maxConsecutive;
|
|
305
|
+
}
|
|
306
|
+
|
|
307
|
+
// src/runtime/agent-loop.ts
|
|
308
|
+
async function* agentLoop(userMessage, history, config) {
|
|
309
|
+
const messages = [
|
|
310
|
+
...history,
|
|
311
|
+
{ role: "user", content: userMessage }
|
|
312
|
+
];
|
|
313
|
+
const totalUsage = { inputTokens: 0, outputTokens: 0 };
|
|
314
|
+
const abortController = config.abortController ?? new AbortController();
|
|
315
|
+
const context = {
|
|
316
|
+
cwd: config.cwd,
|
|
317
|
+
agentId: config.agentId,
|
|
318
|
+
abortSignal: abortController.signal,
|
|
319
|
+
sessionState: /* @__PURE__ */ new Map()
|
|
320
|
+
};
|
|
321
|
+
const allowedTools = config.tools.toAllowedNormalizedTools(config.permissions);
|
|
322
|
+
const contextManager = createContextManager(config.model, config.hooks);
|
|
323
|
+
let denialState = createDenialTrackingState();
|
|
324
|
+
let turns = 0;
|
|
325
|
+
while (turns < config.maxTurns) {
|
|
326
|
+
turns++;
|
|
327
|
+
if (abortController.signal.aborted) {
|
|
328
|
+
yield { type: "aborted", reason: "Agent stopped by user" };
|
|
329
|
+
break;
|
|
330
|
+
}
|
|
331
|
+
if (config.maxTokenBudget && totalUsage.inputTokens + totalUsage.outputTokens >= config.maxTokenBudget) {
|
|
332
|
+
yield { type: "error", error: new Error("Token budget exceeded") };
|
|
333
|
+
break;
|
|
334
|
+
}
|
|
335
|
+
let response;
|
|
336
|
+
try {
|
|
337
|
+
response = await config.provider.createMessage({
|
|
338
|
+
model: config.model,
|
|
339
|
+
system: config.systemPrompt,
|
|
340
|
+
messages,
|
|
341
|
+
tools: allowedTools.length > 0 ? allowedTools : void 0,
|
|
342
|
+
maxTokens: 4096
|
|
343
|
+
});
|
|
344
|
+
} catch (err) {
|
|
345
|
+
const error = err instanceof Error ? err : new Error(String(err));
|
|
346
|
+
yield { type: "error", error };
|
|
347
|
+
if (config.hooks.onError) await config.hooks.onError(error, context);
|
|
348
|
+
break;
|
|
349
|
+
}
|
|
350
|
+
totalUsage.inputTokens += response.usage.inputTokens;
|
|
351
|
+
totalUsage.outputTokens += response.usage.outputTokens;
|
|
352
|
+
if (config.tokenBudgetMiddleware) {
|
|
353
|
+
const result = await config.tokenBudgetMiddleware.onTokenUsed(
|
|
354
|
+
response.usage.inputTokens,
|
|
355
|
+
response.usage.outputTokens
|
|
356
|
+
);
|
|
357
|
+
if (result.warned && config.hooks.onNotification) {
|
|
358
|
+
await config.hooks.onNotification(
|
|
359
|
+
`\u26A0\uFE0F Token budget at ${result.percentUsed}%. Fallback model: ${result.fallback ?? "none (task will terminate at 100%)"}.`
|
|
360
|
+
);
|
|
361
|
+
}
|
|
362
|
+
if (result.exceeded) {
|
|
363
|
+
if (config.hooks.onTokenBudgetExceeded) {
|
|
364
|
+
await config.hooks.onTokenBudgetExceeded(context, result.fallback);
|
|
365
|
+
}
|
|
366
|
+
abortController.abort();
|
|
367
|
+
yield { type: "error", error: new Error("Token budget exceeded. Task requires manual continuation.") };
|
|
368
|
+
break;
|
|
369
|
+
}
|
|
370
|
+
}
|
|
371
|
+
contextManager.updateFromApiUsage(response.usage.inputTokens, response.usage.outputTokens);
|
|
372
|
+
contextManager.updateFromMessages(messages);
|
|
373
|
+
await contextManager.checkPressure();
|
|
374
|
+
if (contextManager.shouldCompact() && messages.length > 12) {
|
|
375
|
+
const { memoriesToExtract } = await contextManager.preCompact(
|
|
376
|
+
messages.slice(0, -10)
|
|
377
|
+
);
|
|
378
|
+
if (memoriesToExtract.length > 0 && config.hooks.onNotification) {
|
|
379
|
+
await config.hooks.onNotification(
|
|
380
|
+
`Pre-compaction: extracted ${memoriesToExtract.length} key decisions to memory`
|
|
381
|
+
);
|
|
382
|
+
}
|
|
383
|
+
const compacted = await compactMessages(messages, config.provider, config.model);
|
|
384
|
+
const removedCount = compacted.removedCount;
|
|
385
|
+
if (removedCount > 0) {
|
|
386
|
+
messages.length = 0;
|
|
387
|
+
messages.push(...compacted.messages);
|
|
388
|
+
await contextManager.postCompact(removedCount, messages[0]?.content?.toString().length ?? 0);
|
|
389
|
+
}
|
|
390
|
+
}
|
|
391
|
+
for (const block of response.content) {
|
|
392
|
+
if (block.type === "text" && block.text) {
|
|
393
|
+
yield { type: "text", text: block.text };
|
|
394
|
+
}
|
|
395
|
+
}
|
|
396
|
+
messages.push({ role: "assistant", content: response.content });
|
|
397
|
+
if (response.stopReason === "end_turn" || response.stopReason === "max_tokens") {
|
|
398
|
+
yield { type: "turn_complete", turn: turns, usage: response.usage };
|
|
399
|
+
break;
|
|
400
|
+
}
|
|
401
|
+
const toolUseBlocks = response.content.filter(
|
|
402
|
+
(b) => b.type === "tool_use"
|
|
403
|
+
);
|
|
404
|
+
if (toolUseBlocks.length === 0) {
|
|
405
|
+
yield { type: "turn_complete", turn: turns, usage: response.usage };
|
|
406
|
+
break;
|
|
407
|
+
}
|
|
408
|
+
const { concurrent, sequential } = partitionTools(toolUseBlocks, config.tools);
|
|
409
|
+
const toolResults = [];
|
|
410
|
+
if (concurrent.length > 0) {
|
|
411
|
+
const concurrentResults = await Promise.all(
|
|
412
|
+
concurrent.map(
|
|
413
|
+
(block) => executeToolBlock(
|
|
414
|
+
block,
|
|
415
|
+
config,
|
|
416
|
+
context,
|
|
417
|
+
denialState
|
|
418
|
+
)
|
|
419
|
+
)
|
|
420
|
+
);
|
|
421
|
+
for (let i = 0; i < concurrent.length; i++) {
|
|
422
|
+
const block = concurrent[i];
|
|
423
|
+
const execResult = concurrentResults[i];
|
|
424
|
+
denialState = execResult.denialState;
|
|
425
|
+
yield execResult.event;
|
|
426
|
+
if (execResult.permissionEvent) yield execResult.permissionEvent;
|
|
427
|
+
yield { type: "tool_result", name: block.name, id: block.id, result: execResult.result };
|
|
428
|
+
toolResults.push({
|
|
429
|
+
type: "tool_result",
|
|
430
|
+
tool_use_id: block.id,
|
|
431
|
+
content: execResult.result.content,
|
|
432
|
+
is_error: execResult.result.isError
|
|
433
|
+
});
|
|
434
|
+
}
|
|
435
|
+
}
|
|
436
|
+
for (const block of sequential) {
|
|
437
|
+
const typedBlock = block;
|
|
438
|
+
const execResult = await executeToolBlock(typedBlock, config, context, denialState);
|
|
439
|
+
denialState = execResult.denialState;
|
|
440
|
+
yield execResult.event;
|
|
441
|
+
if (execResult.permissionEvent) yield execResult.permissionEvent;
|
|
442
|
+
yield { type: "tool_result", name: typedBlock.name, id: typedBlock.id, result: execResult.result };
|
|
443
|
+
toolResults.push({
|
|
444
|
+
type: "tool_result",
|
|
445
|
+
tool_use_id: typedBlock.id,
|
|
446
|
+
content: execResult.result.content,
|
|
447
|
+
is_error: execResult.result.isError
|
|
448
|
+
});
|
|
449
|
+
}
|
|
450
|
+
messages.push({ role: "user", content: toolResults });
|
|
451
|
+
yield { type: "turn_complete", turn: turns, usage: response.usage };
|
|
452
|
+
}
|
|
453
|
+
yield { type: "done", totalUsage, turns };
|
|
454
|
+
}
|
|
455
|
+
async function executeToolBlock(block, config, context, denialState) {
|
|
456
|
+
const startEvent = { type: "tool_use_start", name: block.name, id: block.id };
|
|
457
|
+
let permissionEvent;
|
|
458
|
+
const tool = config.tools.get(block.name);
|
|
459
|
+
if (!tool) {
|
|
460
|
+
return {
|
|
461
|
+
result: { content: `Unknown tool: "${block.name}"`, isError: true },
|
|
462
|
+
event: startEvent,
|
|
463
|
+
denialState
|
|
464
|
+
};
|
|
465
|
+
}
|
|
466
|
+
if (!tool.isReadOnly) {
|
|
467
|
+
if (tool.checkPermissions) {
|
|
468
|
+
try {
|
|
469
|
+
const toolPerm = await tool.checkPermissions(block.input, context);
|
|
470
|
+
if (toolPerm.behavior === "deny") {
|
|
471
|
+
denialState = recordDenial(denialState);
|
|
472
|
+
if (shouldWarnDenials(denialState)) {
|
|
473
|
+
process.stderr.write(
|
|
474
|
+
`[agent] WARNING: ${denialState.consecutiveDenials} consecutive tool denials
|
|
475
|
+
`
|
|
476
|
+
);
|
|
477
|
+
}
|
|
478
|
+
return {
|
|
479
|
+
result: {
|
|
480
|
+
content: `Permission denied${toolPerm.bypassImmune ? " (safety check)" : ""}: ${toolPerm.reason ?? "blocked by tool policy"}`,
|
|
481
|
+
isError: true
|
|
482
|
+
},
|
|
483
|
+
event: { type: "tool_denied", name: block.name, id: block.id, reason: toolPerm.reason ?? "denied" },
|
|
484
|
+
denialState
|
|
485
|
+
};
|
|
486
|
+
}
|
|
487
|
+
} catch {
|
|
488
|
+
denialState = recordDenial(denialState);
|
|
489
|
+
return {
|
|
490
|
+
result: { content: "Permission check failed (fail-closed)", isError: true },
|
|
491
|
+
event: { type: "tool_denied", name: block.name, id: block.id, reason: "permission check error (fail-closed)" },
|
|
492
|
+
denialState
|
|
493
|
+
};
|
|
494
|
+
}
|
|
495
|
+
}
|
|
496
|
+
const effectivePermissions = shouldFallbackToAsk(denialState) ? { ...config.permissions, defaultMode: "ask" } : config.permissions;
|
|
497
|
+
const perm = checkPermission(block.name, effectivePermissions);
|
|
498
|
+
if (!perm.allowed) {
|
|
499
|
+
if (perm.mode === "ask" && config.permissionHandler) {
|
|
500
|
+
const inp = block.input;
|
|
501
|
+
const filePath = inp.file_path ?? inp.filePath;
|
|
502
|
+
const description = tool.description;
|
|
503
|
+
const permReq = { name: block.name, id: block.id, description, filePath };
|
|
504
|
+
const decision = await config.permissionHandler(permReq);
|
|
505
|
+
permissionEvent = { type: "permission_request", name: block.name, id: block.id, description, filePath };
|
|
506
|
+
if (decision === "allow") {
|
|
507
|
+
} else {
|
|
508
|
+
denialState = recordDenial(denialState);
|
|
509
|
+
return {
|
|
510
|
+
result: { content: `Permission denied by user`, isError: true },
|
|
511
|
+
event: { type: "tool_denied", name: block.name, id: block.id, reason: "denied by user" },
|
|
512
|
+
denialState,
|
|
513
|
+
permissionEvent: { type: "permission_request", name: block.name, id: block.id, description, filePath }
|
|
514
|
+
};
|
|
515
|
+
}
|
|
516
|
+
} else {
|
|
517
|
+
denialState = recordDenial(denialState);
|
|
518
|
+
return {
|
|
519
|
+
result: { content: `Permission denied: ${perm.reason}`, isError: true },
|
|
520
|
+
event: { type: "tool_denied", name: block.name, id: block.id, reason: perm.reason ?? "denied" },
|
|
521
|
+
denialState
|
|
522
|
+
};
|
|
523
|
+
}
|
|
524
|
+
}
|
|
525
|
+
}
|
|
526
|
+
if (context.abortSignal.aborted) {
|
|
527
|
+
return {
|
|
528
|
+
result: { content: "Interrupted by user", isError: true },
|
|
529
|
+
event: { type: "aborted", reason: "Agent stopped by user" },
|
|
530
|
+
denialState
|
|
531
|
+
};
|
|
532
|
+
}
|
|
533
|
+
if (config.hooks.beforeToolUse) {
|
|
534
|
+
const intercepted = await config.hooks.beforeToolUse(block, context);
|
|
535
|
+
if (intercepted) {
|
|
536
|
+
return { result: intercepted, event: startEvent, denialState };
|
|
537
|
+
}
|
|
538
|
+
}
|
|
539
|
+
let result;
|
|
540
|
+
try {
|
|
541
|
+
result = await tool.call(block.input, context);
|
|
542
|
+
denialState = recordSuccess(denialState);
|
|
543
|
+
} catch (err) {
|
|
544
|
+
result = {
|
|
545
|
+
content: `Tool error: ${err instanceof Error ? err.message : String(err)}`,
|
|
546
|
+
isError: true
|
|
547
|
+
};
|
|
548
|
+
if (config.hooks.onError) {
|
|
549
|
+
await config.hooks.onError(
|
|
550
|
+
err instanceof Error ? err : new Error(String(err)),
|
|
551
|
+
context
|
|
552
|
+
);
|
|
553
|
+
}
|
|
554
|
+
}
|
|
555
|
+
if (config.hooks.afterToolUse) {
|
|
556
|
+
await config.hooks.afterToolUse(block, result, context);
|
|
557
|
+
}
|
|
558
|
+
return { result, event: startEvent, denialState, permissionEvent };
|
|
559
|
+
}
|
|
560
|
+
|
|
561
|
+
export {
|
|
562
|
+
estimateTokens,
|
|
563
|
+
needsCompaction,
|
|
564
|
+
compactMessages,
|
|
565
|
+
getContextLimit,
|
|
566
|
+
createContextManager,
|
|
567
|
+
ContextManager,
|
|
568
|
+
createDenialTrackingState,
|
|
569
|
+
recordDenial,
|
|
570
|
+
recordSuccess,
|
|
571
|
+
shouldFallbackToAsk,
|
|
572
|
+
agentLoop
|
|
573
|
+
};
|