@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.
Files changed (446) hide show
  1. package/dist/active-agent-TV77LOCD.js +24 -0
  2. package/dist/active-agent-ZAA4EQNM.js +25 -0
  3. package/dist/agent-context-ZPDQOAD2.js +9 -0
  4. package/dist/agent-heartbeat-AWTVGE4C.js +60 -0
  5. package/dist/agent-loop-7UM2ENGU.js +10 -0
  6. package/dist/agentic-ontology-QBHUIJPH.js +25 -0
  7. package/dist/asana-JN2UF47A.js +129 -0
  8. package/dist/assets/ghostty.conf +83 -0
  9. package/dist/assets/statusline-command.sh +44 -0
  10. package/dist/assets/tmux.conf +56 -0
  11. package/dist/assets/wezterm.lua +68 -0
  12. package/dist/backfill-metadata-R77LUJHF.js +596 -0
  13. package/dist/background-jobs-VTOMOTNA.js +25 -0
  14. package/dist/bash-XA65M6T6.js +8 -0
  15. package/dist/behaviors-P5SSPIVO.js +24 -0
  16. package/dist/bin/age-ontology-load.js +85 -0
  17. package/dist/bin/agentic-ontology-backfill.js +84 -0
  18. package/dist/bin/agentic-reflection-backfill.js +45 -0
  19. package/dist/bin/agentic-semantic-label.js +193 -0
  20. package/dist/bin/backfill-conversations.js +399 -0
  21. package/dist/bin/backfill-responses.js +227 -0
  22. package/dist/bin/backfill-vectors.js +149 -0
  23. package/dist/bin/bulk-sync-postgres.js +92 -0
  24. package/dist/bin/cc-doctor.js +51 -0
  25. package/dist/bin/cleanup-stale-review-tasks.js +139 -0
  26. package/dist/bin/cli.js +1076 -0
  27. package/dist/bin/customer-readiness.js +389 -0
  28. package/dist/bin/deferred-daemon-restart.js +123 -0
  29. package/dist/bin/exe-agent-config.js +87 -0
  30. package/dist/bin/exe-agent.js +190 -0
  31. package/dist/bin/exe-assign.js +93 -0
  32. package/dist/bin/exe-boot.js +1114 -0
  33. package/dist/bin/exe-call.js +127 -0
  34. package/dist/bin/exe-cloud.js +484 -0
  35. package/dist/bin/exe-dispatch.js +72 -0
  36. package/dist/bin/exe-doctor.js +48 -0
  37. package/dist/bin/exe-export-behaviors.js +48 -0
  38. package/dist/bin/exe-forget.js +204 -0
  39. package/dist/bin/exe-gateway.js +1137 -0
  40. package/dist/bin/exe-healthcheck.js +14 -0
  41. package/dist/bin/exe-heartbeat.js +233 -0
  42. package/dist/bin/exe-kill.js +126 -0
  43. package/dist/bin/exe-launch-agent.js +678 -0
  44. package/dist/bin/exe-new-employee.js +160 -0
  45. package/dist/bin/exe-pending-messages.js +60 -0
  46. package/dist/bin/exe-pending-notifications.js +107 -0
  47. package/dist/bin/exe-pending-reviews.js +81 -0
  48. package/dist/bin/exe-rename.js +219 -0
  49. package/dist/bin/exe-repo-drift.js +95 -0
  50. package/dist/bin/exe-review.js +251 -0
  51. package/dist/bin/exe-search.js +65 -0
  52. package/dist/bin/exe-session-cleanup.js +331 -0
  53. package/dist/bin/exe-settings.js +364 -0
  54. package/dist/bin/exe-start-codex.js +404 -0
  55. package/dist/bin/exe-start-opencode.js +233 -0
  56. package/dist/bin/exe-start.sh +194 -0
  57. package/dist/bin/exe-status.js +34 -0
  58. package/dist/bin/exe-support.js +17 -0
  59. package/dist/bin/exe-team.js +83 -0
  60. package/dist/bin/generate-hook-manifest.js +30 -0
  61. package/dist/bin/git-sweep.js +74 -0
  62. package/dist/bin/graph-backfill.js +78 -0
  63. package/dist/bin/graph-export.js +66 -0
  64. package/dist/bin/graph-layer-benchmark.js +113 -0
  65. package/dist/bin/import-history.js +84 -0
  66. package/dist/bin/install-launchd.js +41 -0
  67. package/dist/bin/install.js +422 -0
  68. package/dist/bin/intercom-check.js +137 -0
  69. package/dist/bin/list-providers.js +128 -0
  70. package/dist/bin/mcp-sessions.js +194 -0
  71. package/dist/bin/orchestration-metrics.js +61 -0
  72. package/dist/bin/postgres-agentic-reflection-backfill.js +123 -0
  73. package/dist/bin/postgres-agentic-semantic-backfill.js +126 -0
  74. package/dist/bin/pre-build-guard.js +98 -0
  75. package/dist/bin/pre-publish.js +224 -0
  76. package/dist/bin/registry-proxy.js +44 -0
  77. package/dist/bin/scan-tasks.js +265 -0
  78. package/dist/bin/setup.js +19 -0
  79. package/dist/bin/shard-migrate.js +162 -0
  80. package/dist/bin/stack-update.js +372 -0
  81. package/dist/bin/update.js +354 -0
  82. package/dist/bin/verify-stack.js +389 -0
  83. package/dist/bin/vps-backup.js +170 -0
  84. package/dist/bin/vps-health-gate.js +232 -0
  85. package/dist/branding-I2TDZFUH.js +97 -0
  86. package/dist/browser-sanitizer-MRSSEJZE.js +229 -0
  87. package/dist/browser-session-store-RF45DSJR.js +232 -0
  88. package/dist/capacity-monitor-VHBHMKF7.js +48 -0
  89. package/dist/catchup-brief-LBCPHOKB.js +150 -0
  90. package/dist/chunk-2VZ6SY2R.js +142 -0
  91. package/dist/chunk-3IRWSEMI.js +1088 -0
  92. package/dist/chunk-3JP3FY33.js +258 -0
  93. package/dist/chunk-3VJHNEPN.js +262 -0
  94. package/dist/chunk-426NVFWA.js +128 -0
  95. package/dist/chunk-46SQTBQW.js +207 -0
  96. package/dist/chunk-4JERP7NT.js +132 -0
  97. package/dist/chunk-557C2IGL.js +0 -0
  98. package/dist/chunk-5BS5ELMC.js +85 -0
  99. package/dist/chunk-5NFBE376.js +391 -0
  100. package/dist/chunk-6A7P74QV.js +53 -0
  101. package/dist/chunk-6ES7UEXD.js +77 -0
  102. package/dist/chunk-6KFICEAT.js +20 -0
  103. package/dist/chunk-6MP5NOOR.js +151 -0
  104. package/dist/chunk-6Y4B3QF6.js +19 -0
  105. package/dist/chunk-7GDCFV36.js +129 -0
  106. package/dist/chunk-7LKJBYBN.js +495 -0
  107. package/dist/chunk-7NNXBDOO.js +541 -0
  108. package/dist/chunk-7OM54FQY.js +627 -0
  109. package/dist/chunk-7WBEMFHW.js +1919 -0
  110. package/dist/chunk-A62JW3VH.js +382 -0
  111. package/dist/chunk-AHMUF6RO.js +147 -0
  112. package/dist/chunk-AJWFPKQS.js +573 -0
  113. package/dist/chunk-AR7J6K6W.js +363 -0
  114. package/dist/chunk-AVE2B4DQ.js +140 -0
  115. package/dist/chunk-AZSCW64F.js +190 -0
  116. package/dist/chunk-B3IPZ7DJ.js +38 -0
  117. package/dist/chunk-CDN4PWHZ.js +330 -0
  118. package/dist/chunk-CEGFVFT3.js +70 -0
  119. package/dist/chunk-CHCA3ZM2.js +167 -0
  120. package/dist/chunk-CHUGUZV3.js +90 -0
  121. package/dist/chunk-CLGB3FGL.js +48 -0
  122. package/dist/chunk-CVYC6DUW.js +78 -0
  123. package/dist/chunk-CX6GL3ZJ.js +274 -0
  124. package/dist/chunk-D2DRHXSV.js +197 -0
  125. package/dist/chunk-D4IVTUNN.js +377 -0
  126. package/dist/chunk-DD2ABSIG.js +348 -0
  127. package/dist/chunk-DGOGCPYU.js +390 -0
  128. package/dist/chunk-DHHTLRXE.js +1020 -0
  129. package/dist/chunk-E6ORBQHP.js +225 -0
  130. package/dist/chunk-ECDKU54I.js +240 -0
  131. package/dist/chunk-ECGTESAP.js +236 -0
  132. package/dist/chunk-ECSNSHZ7.js +431 -0
  133. package/dist/chunk-ECYFNBCU.js +290 -0
  134. package/dist/chunk-EGWPJQRQ.js +159 -0
  135. package/dist/chunk-EIT6J37V.js +119 -0
  136. package/dist/chunk-EQSQ4HBW.js +9 -0
  137. package/dist/chunk-ETSREHYC.js +55 -0
  138. package/dist/chunk-F6OEJ4AL.js +75 -0
  139. package/dist/chunk-F7LU65PQ.js +33 -0
  140. package/dist/chunk-FJV6WJS6.js +76 -0
  141. package/dist/chunk-FLSASUV3.js +177 -0
  142. package/dist/chunk-FV5FDWL3.js +121 -0
  143. package/dist/chunk-FWFFZGSC.js +94 -0
  144. package/dist/chunk-FXU7JOXK.js +6 -0
  145. package/dist/chunk-GAHM4SUR.js +171 -0
  146. package/dist/chunk-GFCQJZTO.js +1051 -0
  147. package/dist/chunk-GGV3PFUW.js +41 -0
  148. package/dist/chunk-GGZ4NTZH.js +333 -0
  149. package/dist/chunk-GJV3WDWM.js +14 -0
  150. package/dist/chunk-GMIXDGAT.js +280 -0
  151. package/dist/chunk-GNHN5HRQ.js +40 -0
  152. package/dist/chunk-GP6G6EQI.js +632 -0
  153. package/dist/chunk-GST2EPOG.js +2017 -0
  154. package/dist/chunk-GUMRIUI5.js +63 -0
  155. package/dist/chunk-GVP5U4WL.js +113 -0
  156. package/dist/chunk-H32Z73OY.js +81 -0
  157. package/dist/chunk-HF25XPZE.js +83 -0
  158. package/dist/chunk-HFRT4QZS.js +50 -0
  159. package/dist/chunk-HOKOOBDL.js +52 -0
  160. package/dist/chunk-HQMEOIUJ.js +69 -0
  161. package/dist/chunk-HYZV25LY.js +34 -0
  162. package/dist/chunk-I7AW4237.js +251 -0
  163. package/dist/chunk-IONVLDMB.js +297 -0
  164. package/dist/chunk-IPWTDGWM.js +356 -0
  165. package/dist/chunk-IQT43SDJ.js +357 -0
  166. package/dist/chunk-IUHWJRDM.js +614 -0
  167. package/dist/chunk-J4Y6FQ77.js +54 -0
  168. package/dist/chunk-JGGCKDMB.js +1090 -0
  169. package/dist/chunk-JGNCI7BA.js +159 -0
  170. package/dist/chunk-JQ6TLNIV.js +133 -0
  171. package/dist/chunk-JRXV6UES.js +214 -0
  172. package/dist/chunk-K2YWCFZ3.js +147 -0
  173. package/dist/chunk-KCUYRZSX.js +72 -0
  174. package/dist/chunk-KH5Y6RR4.js +360 -0
  175. package/dist/chunk-KQMP6TJZ.js +157 -0
  176. package/dist/chunk-KX6LS6XO.js +97 -0
  177. package/dist/chunk-L24HYX62.js +498 -0
  178. package/dist/chunk-L3TB7CC3.js +170 -0
  179. package/dist/chunk-LWVZLTMD.js +412 -0
  180. package/dist/chunk-LXDNFQNN.js +1073 -0
  181. package/dist/chunk-LYH5HE24.js +73 -0
  182. package/dist/chunk-M43RSLT4.js +213 -0
  183. package/dist/chunk-MLXJ5EZG.js +90 -0
  184. package/dist/chunk-MP2AFCGL.js +53 -0
  185. package/dist/chunk-MQPW7X4P.js +403 -0
  186. package/dist/chunk-MVW62NIZ.js +20 -0
  187. package/dist/chunk-MZIGUUDQ.js +42 -0
  188. package/dist/chunk-N2SIOC5S.js +463 -0
  189. package/dist/chunk-N5RRQOAC.js +134 -0
  190. package/dist/chunk-NB5HOHLB.js +135 -0
  191. package/dist/chunk-NBEX5NG6.js +284 -0
  192. package/dist/chunk-NC56276G.js +30 -0
  193. package/dist/chunk-NGJ5FIQV.js +3511 -0
  194. package/dist/chunk-NGP6LSV2.js +25 -0
  195. package/dist/chunk-NGVOA6ZQ.js +84 -0
  196. package/dist/chunk-NI2X6SFD.js +221 -0
  197. package/dist/chunk-NOSCT6NZ.js +210 -0
  198. package/dist/chunk-NRFVWJHP.js +575 -0
  199. package/dist/chunk-O377P7GM.js +100 -0
  200. package/dist/chunk-ONKIWA3R.js +249 -0
  201. package/dist/chunk-OPU3NYOO.js +55 -0
  202. package/dist/chunk-ORCCI2VV.js +140 -0
  203. package/dist/chunk-OYNKIAVW.js +181 -0
  204. package/dist/chunk-P7E37KXE.js +244 -0
  205. package/dist/chunk-PKJTWKKN.js +58 -0
  206. package/dist/chunk-PRKVT4KN.js +90 -0
  207. package/dist/chunk-PWMMIGVQ.js +332 -0
  208. package/dist/chunk-Q3V7K4ME.js +149 -0
  209. package/dist/chunk-Q7RGLXQO.js +574 -0
  210. package/dist/chunk-QGGH7LOU.js +93 -0
  211. package/dist/chunk-QI4IXJN7.js +132 -0
  212. package/dist/chunk-QNHI4XDN.js +346 -0
  213. package/dist/chunk-R4WMF32C.js +81 -0
  214. package/dist/chunk-R5U7XKVJ.js +16 -0
  215. package/dist/chunk-RJT7H2KR.js +349 -0
  216. package/dist/chunk-RKDATCH4.js +813 -0
  217. package/dist/chunk-SD6IDXF7.js +33 -0
  218. package/dist/chunk-SEPE2UMS.js +667 -0
  219. package/dist/chunk-SH45SJQW.js +0 -0
  220. package/dist/chunk-SUNYJ6YE.js +204 -0
  221. package/dist/chunk-SVXDCELZ.js +163 -0
  222. package/dist/chunk-TMEE7AT7.js +72 -0
  223. package/dist/chunk-TNTFEWU5.js +361 -0
  224. package/dist/chunk-TWR6EV57.js +3753 -0
  225. package/dist/chunk-U7XLP37W.js +85 -0
  226. package/dist/chunk-UBRE5MK7.js +183 -0
  227. package/dist/chunk-UBWE5LSJ.js +227 -0
  228. package/dist/chunk-UEBRQCJ7.js +1345 -0
  229. package/dist/chunk-UOI5DAYH.js +128 -0
  230. package/dist/chunk-V4TZI6EO.js +60 -0
  231. package/dist/chunk-VUVSYEGB.js +731 -0
  232. package/dist/chunk-X2Z5GT3V.js +118 -0
  233. package/dist/chunk-X2ZDES26.js +56 -0
  234. package/dist/chunk-X3AVWFWW.js +294 -0
  235. package/dist/chunk-XEKO37NM.js +43 -0
  236. package/dist/chunk-Y5AX66S3.js +1051 -0
  237. package/dist/chunk-YADYM2DE.js +42 -0
  238. package/dist/chunk-YGAAZN3E.js +47 -0
  239. package/dist/chunk-YIDLK73D.js +13097 -0
  240. package/dist/chunk-YLCSHPZE.js +123 -0
  241. package/dist/chunk-YSU7JB7H.js +0 -0
  242. package/dist/chunk-YZFZDJWZ.js +107 -0
  243. package/dist/chunk-YZKJLGWL.js +169 -0
  244. package/dist/chunk-ZCSI2XTD.js +204 -0
  245. package/dist/chunk-ZVSG2KKG.js +106 -0
  246. package/dist/co-activation-SEYZ6WBU.js +71 -0
  247. package/dist/co-occurrence-AO3AT5JK.js +73 -0
  248. package/dist/code-context-index-KHUYATRB.js +29 -0
  249. package/dist/content-extractor-CUJOBFBU.js +9 -0
  250. package/dist/conversation-entity-extractor-TW4W57K4.js +114 -0
  251. package/dist/conversation-wiki-populator-GNFRTS7X.js +105 -0
  252. package/dist/core-memory-SUM5RZX2.js +110 -0
  253. package/dist/crdt-sync-X53T4NUI.js +33 -0
  254. package/dist/crm-bridge-NG5WJMGF.js +19 -0
  255. package/dist/crm-webhook-3UMCZDFK.js +10 -0
  256. package/dist/cto-delegation-gate-R3BYZCXG.js +205 -0
  257. package/dist/daemon-auth-WFQMMNSD.js +13 -0
  258. package/dist/daemon-orchestration-JRA7CJGJ.js +133 -0
  259. package/dist/daemon-protocol-4FUHT5NH.js +17 -0
  260. package/dist/db-backup-STROKTGN.js +25 -0
  261. package/dist/devtools-J4QYYO7U.js +8 -0
  262. package/dist/discord-7UHIZNJ3.js +7 -0
  263. package/dist/dispatch-ack-RMVFHO4I.js +13 -0
  264. package/dist/dreaming-6POCE2CN.js +12 -0
  265. package/dist/email-T6PQUUY6.js +137 -0
  266. package/dist/entity-boost-7MB2IYAE.js +332 -0
  267. package/dist/exe-drift-FO4S2MIW.js +67 -0
  268. package/dist/exe-export-XRDCOZM2.js +72 -0
  269. package/dist/exe-import-QBTXHGTH.js +75 -0
  270. package/dist/exe-key-UGOHWRYG.js +573 -0
  271. package/dist/exe-org-JRBBON5H.js +73 -0
  272. package/dist/exe-snapshot-Z4AZPSGS.js +145 -0
  273. package/dist/factory-UQSRMKJW.js +67 -0
  274. package/dist/fast-db-init-CAC7HD5B.js +7 -0
  275. package/dist/file-edit-YORRFENG.js +8 -0
  276. package/dist/file-read-RMQFDE5L.js +8 -0
  277. package/dist/file-write-VO4MQW5Y.js +8 -0
  278. package/dist/founder-context-3N6BMG7B.js +96 -0
  279. package/dist/gateway/index.js +148 -0
  280. package/dist/gateway-client-V7NH35Q2.js +11 -0
  281. package/dist/git-staleness-UMHQDPQU.js +109 -0
  282. package/dist/git-task-sweep-WZ3LH6EV.js +39 -0
  283. package/dist/glob-2LXRC3F5.js +7 -0
  284. package/dist/global-procedures-NSZQNWXA.js +19 -0
  285. package/dist/graph-auto-extract-A5PHP3G3.js +161 -0
  286. package/dist/graph-query-YZ4RZEIL.js +26 -0
  287. package/dist/graph-rag-S5SBJW5J.js +29 -0
  288. package/dist/grep-OY7KCRLQ.js +7 -0
  289. package/dist/hook-integrity-OKSYTGVP.js +89 -0
  290. package/dist/hooks/bug-report-worker.js +179 -0
  291. package/dist/hooks/codex-stop-task-finalizer.js +258 -0
  292. package/dist/hooks/commit-complete.js +162 -0
  293. package/dist/hooks/error-recall.js +129 -0
  294. package/dist/hooks/exe-heartbeat-hook.js +78 -0
  295. package/dist/hooks/ingest-worker.js +51 -0
  296. package/dist/hooks/ingest.js +491 -0
  297. package/dist/hooks/instructions-loaded.js +119 -0
  298. package/dist/hooks/manifest.json +25 -0
  299. package/dist/hooks/notification.js +67 -0
  300. package/dist/hooks/post-compact.js +138 -0
  301. package/dist/hooks/post-tool-combined.js +152 -0
  302. package/dist/hooks/pre-compact.js +159 -0
  303. package/dist/hooks/pre-tool-use.js +512 -0
  304. package/dist/hooks/prompt-submit.js +699 -0
  305. package/dist/hooks/session-end.js +482 -0
  306. package/dist/hooks/session-start.js +362 -0
  307. package/dist/hooks/stop.js +332 -0
  308. package/dist/hooks/subagent-stop.js +85 -0
  309. package/dist/hooks/summary-worker.js +298 -0
  310. package/dist/hooks-RPTZV5KX.js +9 -0
  311. package/dist/imessage-CE5USLTI.js +7 -0
  312. package/dist/index.js +60 -0
  313. package/dist/installer-A5HRSX7C.js +37 -0
  314. package/dist/installer-JACODBI7.js +341 -0
  315. package/dist/installer-VWO4T7B6.js +295 -0
  316. package/dist/intercom-queue-USIXVVJQ.js +17 -0
  317. package/dist/key-backup-status-TVFMMWTT.js +39 -0
  318. package/dist/keyword-extractor-OGQRRVTB.js +11 -0
  319. package/dist/lib/agent-config.js +30 -0
  320. package/dist/lib/cloud-sync.js +103 -0
  321. package/dist/lib/cloudflare-dns.js +13 -0
  322. package/dist/lib/config.js +32 -0
  323. package/dist/lib/consolidation.js +38 -0
  324. package/dist/lib/crypto.js +13 -0
  325. package/dist/lib/database.js +31 -0
  326. package/dist/lib/db-daemon-client.js +141 -0
  327. package/dist/lib/db.js +31 -0
  328. package/dist/lib/device-registry.js +70 -0
  329. package/dist/lib/embed-worker.js +165 -0
  330. package/dist/lib/embedder.js +19 -0
  331. package/dist/lib/employee-templates.js +34 -0
  332. package/dist/lib/employees.js +63 -0
  333. package/dist/lib/error-detector.js +16 -0
  334. package/dist/lib/exe-daemon-client.js +25 -0
  335. package/dist/lib/exe-daemon.js +4417 -0
  336. package/dist/lib/file-grep.js +242 -0
  337. package/dist/lib/hybrid-search.js +28 -0
  338. package/dist/lib/identity-templates.js +650 -0
  339. package/dist/lib/identity.js +19 -0
  340. package/dist/lib/keychain.js +17 -0
  341. package/dist/lib/license.js +35 -0
  342. package/dist/lib/messaging.js +59 -0
  343. package/dist/lib/post-tool-memory.js +13 -0
  344. package/dist/lib/registry-proxy.js +15 -0
  345. package/dist/lib/reminders.js +16 -0
  346. package/dist/lib/runtime-table.js +9 -0
  347. package/dist/lib/schedules.js +24 -0
  348. package/dist/lib/session-registry.js +21 -0
  349. package/dist/lib/session-wrappers.js +7 -0
  350. package/dist/lib/skill-learning.js +29 -0
  351. package/dist/lib/status-brief.js +7 -0
  352. package/dist/lib/store.js +43 -0
  353. package/dist/lib/task-router.js +22 -0
  354. package/dist/lib/tasks.js +66 -0
  355. package/dist/lib/tmux-routing.js +70 -0
  356. package/dist/lib/tmux-status.js +29 -0
  357. package/dist/lib/tmux-transport.js +7 -0
  358. package/dist/lib/token-spend.js +12 -0
  359. package/dist/lib/transport.js +10 -0
  360. package/dist/lib/ws-auth.js +11 -0
  361. package/dist/lib/ws-client.js +190 -0
  362. package/dist/license-gate-7QVCYARF.js +14 -0
  363. package/dist/mcp/register-tools.js +102 -0
  364. package/dist/mcp/server.js +370 -0
  365. package/dist/mcp/tools/complete-reminder.js +13 -0
  366. package/dist/mcp/tools/create-reminder.js +13 -0
  367. package/dist/mcp/tools/create-task.js +34 -0
  368. package/dist/mcp/tools/deactivate-behavior.js +16 -0
  369. package/dist/mcp/tools/list-reminders.js +13 -0
  370. package/dist/mcp/tools/list-tasks.js +33 -0
  371. package/dist/mcp/tools/send-message.js +33 -0
  372. package/dist/mcp/tools/update-task.js +32 -0
  373. package/dist/mcp-diagnostics-5T5OZ52S.js +200 -0
  374. package/dist/mcp-disconnect-tracker-VINUVEZJ.js +79 -0
  375. package/dist/mcp-http-config-HMQWKLON.js +26 -0
  376. package/dist/memory-cards-N7LZUKHF.js +173 -0
  377. package/dist/memory-graph-extractor-GADBVHRC.js +16 -0
  378. package/dist/memory-poisoning-defense-LHAUEVKF.js +224 -0
  379. package/dist/memory-queue-WEVFXPZO.js +19 -0
  380. package/dist/memory-queue-client-5XBHYAQR.js +15 -0
  381. package/dist/memory-reflection-SHO2CV4L.js +237 -0
  382. package/dist/message-queue-client-FUKX43JD.js +92 -0
  383. package/dist/notifications-2UJNSWRB.js +44 -0
  384. package/dist/oauth-server-CCZPDTZJ.js +437 -0
  385. package/dist/orchestration-events-O7GWLTB2.js +24 -0
  386. package/dist/orchestration-phase-HXRKMZXM.js +23 -0
  387. package/dist/orchestrator-AXIBALJX.js +32 -0
  388. package/dist/permission-presets-UPVLJWZD.js +25 -0
  389. package/dist/permissions-C4EMHPDD.js +14 -0
  390. package/dist/pg-ssl-GD3332YS.js +7 -0
  391. package/dist/pipeline-router-3HUUYCV2.js +12 -0
  392. package/dist/plan-limits-TWD5VXMU.js +25 -0
  393. package/dist/prediction-log-C2BD3AHR.js +120 -0
  394. package/dist/preferences-5ARPMYE7.js +10 -0
  395. package/dist/preflight-TZOGLBZU.js +287 -0
  396. package/dist/project-boot-JIGOSGCN.js +254 -0
  397. package/dist/project-name-4SKOH2UO.js +10 -0
  398. package/dist/projection-worker-DUBKXKFL.js +877 -0
  399. package/dist/push-notifications-3GNJ5SZS.js +15 -0
  400. package/dist/reranker-4M6UVDRF.js +19 -0
  401. package/dist/review-gate-I66GDXNR.js +120 -0
  402. package/dist/review-polling-GCQV3TF6.js +123 -0
  403. package/dist/runtime/index.js +129 -0
  404. package/dist/self-query-router-QMK5ZSZR.js +188 -0
  405. package/dist/session-events-LW67P5MB.js +35 -0
  406. package/dist/session-kill-telemetry-JYEG7KSE.js +28 -0
  407. package/dist/session-scope-OOHP3EOV.js +85 -0
  408. package/dist/setup-wizard-XIPF5N2C.js +12 -0
  409. package/dist/shard-manager-ON2WWCRM.js +29 -0
  410. package/dist/signal-KF2LIO7Y.js +7 -0
  411. package/dist/signal-paths-5ZTWCBUX.js +19 -0
  412. package/dist/skill-refinement-I4UAAHLL.js +156 -0
  413. package/dist/slack-JRDUD5Z7.js +7 -0
  414. package/dist/stack-update-ZIMV4OEQ.js +50 -0
  415. package/dist/steward-gate-NZ5IUJFV.js +12 -0
  416. package/dist/support-outbox-HIJVUDA2.js +206 -0
  417. package/dist/task-enforcement-3DVLNFLX.js +292 -0
  418. package/dist/task-scanner-5OQBNC2N.js +11 -0
  419. package/dist/task-scope-NJIPLTZI.js +34 -0
  420. package/dist/tasks-crud-ET7MUU4V.js +76 -0
  421. package/dist/tasks-review-QPTYXCZX.js +46 -0
  422. package/dist/telegram-COCYUCT7.js +7 -0
  423. package/dist/telemetry-QKWQKAUC.js +9 -0
  424. package/dist/telemetry-upload-AL2IB3UE.js +609 -0
  425. package/dist/token-budget-TR2NN66K.js +83 -0
  426. package/dist/tool-capability-index-UUNF7VPA.js +10 -0
  427. package/dist/tool-gates-6A6LE4DZ.js +14 -0
  428. package/dist/tool-gates-RNWEH5IK.js +13 -0
  429. package/dist/tool-registry-KL24CAFR.js +11 -0
  430. package/dist/tool-telemetry-43ZIXZSK.js +17 -0
  431. package/dist/tui/App.js +10223 -0
  432. package/dist/tui-data-32PP76M6.js +161 -0
  433. package/dist/typed-messages-53Q7L3LB.js +17 -0
  434. package/dist/update-check-5IL5I3E2.js +11 -0
  435. package/dist/webhook-VXGIH7PN.js +96 -0
  436. package/dist/webhook-pipe-4WPFGGFD.js +114 -0
  437. package/dist/whatsapp-PSMKCDS7.js +9 -0
  438. package/dist/whatsapp-accounts-4OKWFRWL.js +15 -0
  439. package/dist/whatsapp-config-ZG5LX4O4.js +125 -0
  440. package/dist/wiki-acl-5OHOZNIX.js +111 -0
  441. package/dist/wiki-client-KE622HKY.js +157 -0
  442. package/dist/worker-gate-5ISRLLIM.js +21 -0
  443. package/dist/workflow-engine-UORUJRUR.js +28 -0
  444. package/dist/working-memory-Z3EB3FW6.js +77 -0
  445. package/dist/worktree-EPR6QDRF.js +25 -0
  446. 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
+ };