@askexenow/exe-os 0.9.294 → 0.9.296

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 (279) hide show
  1. package/deploy/compose/cloudflared/config.yml.example +14 -9
  2. package/deploy/compose/docker-compose.yml +86 -8
  3. package/deploy/compose/sso-edge/default.conf.template +87 -0
  4. package/deploy/compose/sso-edge/entrypoint.sh +23 -0
  5. package/deploy/compose/sso-edge/sso-redirect.conf +63 -0
  6. package/deploy/stack-manifests/v0.9.json +2 -2
  7. package/dist/active-agent-AFX2FODG.js +28 -0
  8. package/dist/active-agent-E2IJA7YX.js +27 -0
  9. package/dist/agentic-ontology-A2YUZK5O.js +25 -0
  10. package/dist/assets/com.askexe.exed.plist +4 -1
  11. package/dist/backfill-metadata-OC7EOD5U.js +600 -0
  12. package/dist/behaviors-H5ZOVHDH.js +46 -0
  13. package/dist/bin/agentic-ontology-backfill.js +5 -5
  14. package/dist/bin/agentic-reflection-backfill.js +6 -6
  15. package/dist/bin/agentic-semantic-label.js +5 -5
  16. package/dist/bin/backfill-conversations.js +6 -6
  17. package/dist/bin/backfill-responses.js +6 -6
  18. package/dist/bin/backfill-vectors.js +8 -8
  19. package/dist/bin/bulk-sync-postgres.js +7 -7
  20. package/dist/bin/cc-doctor.js +4 -4
  21. package/dist/bin/cleanup-stale-review-tasks.js +11 -11
  22. package/dist/bin/cli.js +16 -16
  23. package/dist/bin/deferred-daemon-restart.js +1 -1
  24. package/dist/bin/exe-agent-config.js +2 -2
  25. package/dist/bin/exe-agent.js +4 -4
  26. package/dist/bin/exe-assign.js +8 -8
  27. package/dist/bin/exe-boot.js +21 -18
  28. package/dist/bin/exe-call.js +4 -4
  29. package/dist/bin/exe-cloud.js +7 -7
  30. package/dist/bin/exe-dispatch.js +11 -11
  31. package/dist/bin/exe-doctor.js +3 -2
  32. package/dist/bin/exe-export-behaviors.js +7 -7
  33. package/dist/bin/exe-forget.js +6 -6
  34. package/dist/bin/exe-gateway.js +7 -7
  35. package/dist/bin/exe-healthcheck.js +6 -4
  36. package/dist/bin/exe-heartbeat.js +11 -11
  37. package/dist/bin/exe-kill.js +14 -14
  38. package/dist/bin/exe-launch-agent.js +18 -18
  39. package/dist/bin/exe-new-employee.js +6 -6
  40. package/dist/bin/exe-pending-messages.js +12 -12
  41. package/dist/bin/exe-pending-notifications.js +11 -11
  42. package/dist/bin/exe-pending-reviews.js +11 -11
  43. package/dist/bin/exe-rename.js +4 -4
  44. package/dist/bin/exe-review.js +13 -13
  45. package/dist/bin/exe-search.js +5 -5
  46. package/dist/bin/exe-session-cleanup.js +16 -16
  47. package/dist/bin/exe-settings.js +39 -9
  48. package/dist/bin/exe-start-codex.js +11 -11
  49. package/dist/bin/exe-start-opencode.js +8 -8
  50. package/dist/bin/exe-status.js +12 -12
  51. package/dist/bin/exe-team.js +3 -3
  52. package/dist/bin/git-sweep.js +12 -12
  53. package/dist/bin/graph-backfill.js +4 -4
  54. package/dist/bin/graph-export.js +5 -5
  55. package/dist/bin/import-history.js +7 -7
  56. package/dist/bin/install-launchd.js +13 -6
  57. package/dist/bin/install.js +26 -14
  58. package/dist/bin/intercom-check.js +4 -4
  59. package/dist/bin/mcp-sessions.js +2 -2
  60. package/dist/bin/orchestration-metrics.js +4 -4
  61. package/dist/bin/postgres-agentic-reflection-backfill.js +2 -2
  62. package/dist/bin/postgres-agentic-semantic-backfill.js +1 -1
  63. package/dist/bin/scan-tasks.js +11 -11
  64. package/dist/bin/setup.js +1 -1
  65. package/dist/bin/shard-migrate.js +4 -4
  66. package/dist/bin/stack-update.js +2 -2
  67. package/dist/bin/vps-health-gate.js +1 -1
  68. package/dist/capability-cards-4USI7CUW.js +89 -0
  69. package/dist/capacity-monitor-WLCBTEYR.js +51 -0
  70. package/dist/catchup-brief-ZR3NX6LZ.js +175 -0
  71. package/dist/chunk-22TVSRQQ.js +226 -0
  72. package/dist/chunk-2E43UXRH.js +395 -0
  73. package/dist/chunk-2PIGT6UJ.js +460 -0
  74. package/dist/chunk-3XTMW2MZ.js +535 -0
  75. package/dist/chunk-465PQFTH.js +262 -0
  76. package/dist/chunk-5CCXU2AW.js +129 -0
  77. package/dist/chunk-5D6MPWR7.js +1094 -0
  78. package/dist/chunk-5Q4MR6SL.js +123 -0
  79. package/dist/chunk-6327RBWR.js +345 -0
  80. package/dist/chunk-6MZZREZY.js +199 -0
  81. package/dist/chunk-7DI2Q4O5.js +1186 -0
  82. package/dist/chunk-7PW5VNIY.js +122 -0
  83. package/dist/chunk-7T7Y56HW.js +43 -0
  84. package/dist/chunk-7UHCWCLT.js +128 -0
  85. package/dist/chunk-A2ZUMF6L.js +1350 -0
  86. package/dist/chunk-AKV44JEH.js +185 -0
  87. package/dist/chunk-ANHWGX5N.js +735 -0
  88. package/dist/chunk-BQ3P4TKD.js +97 -0
  89. package/dist/chunk-BUZMT3KZ.js +604 -0
  90. package/dist/chunk-C2SBESBO.js +210 -0
  91. package/dist/chunk-CLSXZUZW.js +51 -0
  92. package/dist/chunk-CONHLVAR.js +1079 -0
  93. package/dist/chunk-D3WTZPFX.js +456 -0
  94. package/dist/chunk-DE6SOIYL.js +197 -0
  95. package/dist/chunk-EIVNMA3Q.js +284 -0
  96. package/dist/chunk-EJIF4FNT.js +12 -0
  97. package/dist/chunk-FDFOW564.js +171 -0
  98. package/dist/chunk-GZUBJ5EC.js +127 -0
  99. package/dist/chunk-HGZITN22.js +105 -0
  100. package/dist/chunk-HSRKDU6X.js +362 -0
  101. package/dist/chunk-IIEN2PHV.js +85 -0
  102. package/dist/chunk-JQ56VLMM.js +567 -0
  103. package/dist/chunk-JVHHXRFY.js +280 -0
  104. package/dist/chunk-JXCXGZ3S.js +55 -0
  105. package/dist/chunk-K5ZO532Q.js +4388 -0
  106. package/dist/chunk-K6CAAMXF.js +97 -0
  107. package/dist/chunk-KA26YTNU.js +81 -0
  108. package/dist/chunk-KMUW5C3R.js +381 -0
  109. package/dist/chunk-KOO3J5PV.js +20 -0
  110. package/dist/chunk-LSV7OFIH.js +290 -0
  111. package/dist/chunk-LSVFDVNY.js +1158 -0
  112. package/dist/chunk-LXDQTW32.js +230 -0
  113. package/dist/chunk-MEP7OUVZ.js +181 -0
  114. package/dist/chunk-MN2B2LKS.js +240 -0
  115. package/dist/chunk-N2EAYPYQ.js +1352 -0
  116. package/dist/chunk-N7I2A667.js +70 -0
  117. package/dist/chunk-NLZHVIOP.js +630 -0
  118. package/dist/chunk-NUH5TRZL.js +227 -0
  119. package/dist/chunk-OAHEIH3G.js +167 -0
  120. package/dist/chunk-OBHRQGCK.js +58 -0
  121. package/dist/chunk-ODFA7B2V.js +54 -0
  122. package/dist/chunk-OSNUP45F.js +731 -0
  123. package/dist/chunk-OTPRHBTO.js +33 -0
  124. package/dist/chunk-P6MUA4QU.js +157 -0
  125. package/dist/chunk-PGIOFKSK.js +2093 -0
  126. package/dist/chunk-PSE7VHWK.js +50 -0
  127. package/dist/chunk-QIFUVZFW.js +331 -0
  128. package/dist/chunk-RDPXKTVK.js +221 -0
  129. package/dist/chunk-RKYTYJGB.js +76 -0
  130. package/dist/chunk-RXLR6EFM.js +348 -0
  131. package/dist/chunk-SDB67PQJ.js +159 -0
  132. package/dist/chunk-SF2T7MP3.js +402 -0
  133. package/dist/chunk-SLU3FRFQ.js +2133 -0
  134. package/dist/chunk-SNDZJ5IV.js +214 -0
  135. package/dist/chunk-STEEAABW.js +448 -0
  136. package/dist/chunk-TUTWNHIQ.js +244 -0
  137. package/dist/chunk-UDP35QBR.js +30 -0
  138. package/dist/chunk-UKFHNJBI.js +85 -0
  139. package/dist/chunk-VC2DTK2X.js +382 -0
  140. package/dist/chunk-VRRAE5JX.js +836 -0
  141. package/dist/chunk-VVJTBQPR.js +38 -0
  142. package/dist/chunk-W3EQ362K.js +581 -0
  143. package/dist/chunk-WHIXIFHC.js +2242 -0
  144. package/dist/chunk-WRNGJJNR.js +377 -0
  145. package/dist/chunk-WUKHLCBE.js +3313 -0
  146. package/dist/chunk-WVPLHGDG.js +150 -0
  147. package/dist/chunk-XJZBSTL5.js +204 -0
  148. package/dist/chunk-Y3PMNUM5.js +304 -0
  149. package/dist/chunk-YHVS4QOV.js +14597 -0
  150. package/dist/chunk-YJ2OYAOC.js +668 -0
  151. package/dist/chunk-YYAD2GXX.js +128 -0
  152. package/dist/chunk-ZQML7EWE.js +333 -0
  153. package/dist/co-activation-XJLH46OX.js +74 -0
  154. package/dist/co-occurrence-GNN2X526.js +95 -0
  155. package/dist/code-context-index-OCPRLFG5.js +30 -0
  156. package/dist/core-memory-J4W2IYOF.js +110 -0
  157. package/dist/crdt-sync-QCBTSHIH.js +33 -0
  158. package/dist/crm-webhook-EM442VUW.js +10 -0
  159. package/dist/cto-delegation-gate-MLJMVHBK.js +280 -0
  160. package/dist/daemon-orchestration-2VNLZVTW.js +139 -0
  161. package/dist/db-backup-VUGFTPJ4.js +43 -0
  162. package/dist/doc-graph-extractor-PNRSFPSS.js +133 -0
  163. package/dist/dreaming-SK5VEQRF.js +34 -0
  164. package/dist/entity-boost-TQWWJUC2.js +375 -0
  165. package/dist/exe-drift-N34UPO7S.js +70 -0
  166. package/dist/exe-export-KACBKGVV.js +77 -0
  167. package/dist/exe-import-GXGDWACG.js +80 -0
  168. package/dist/exe-key-XPDOZBWW.js +673 -0
  169. package/dist/exe-snapshot-32GQKGQ5.js +338 -0
  170. package/dist/fast-db-init-F3TDD5VV.js +7 -0
  171. package/dist/gateway/index.js +8 -8
  172. package/dist/git-staleness-J45WNYRF.js +112 -0
  173. package/dist/git-task-sweep-BTGVQPFB.js +42 -0
  174. package/dist/global-procedures-6JCQWU4D.js +22 -0
  175. package/dist/graph-auto-extract-3ZQNXTPC.js +183 -0
  176. package/dist/hooks/bug-report-worker.js +13 -13
  177. package/dist/hooks/codex-stop-task-finalizer.js +13 -13
  178. package/dist/hooks/commit-complete.js +13 -13
  179. package/dist/hooks/error-recall.js +6 -6
  180. package/dist/hooks/exe-heartbeat-hook.js +3 -3
  181. package/dist/hooks/ingest-worker.js +3 -3
  182. package/dist/hooks/ingest.js +6 -6
  183. package/dist/hooks/instructions-loaded.js +4 -4
  184. package/dist/hooks/manifest.json +20 -20
  185. package/dist/hooks/notification.js +4 -4
  186. package/dist/hooks/post-compact.js +12 -12
  187. package/dist/hooks/post-tool-combined.js +6 -6
  188. package/dist/hooks/pre-compact.js +16 -16
  189. package/dist/hooks/pre-tool-use.js +16 -16
  190. package/dist/hooks/prompt-submit.js +24 -24
  191. package/dist/hooks/session-end.js +21 -21
  192. package/dist/hooks/session-start.js +12 -12
  193. package/dist/hooks/stop.js +19 -19
  194. package/dist/hooks/subagent-stop.js +12 -12
  195. package/dist/hooks/summary-worker.js +19 -19
  196. package/dist/index.js +19 -19
  197. package/dist/installer-5VPFY7SB.js +298 -0
  198. package/dist/installer-OENFPMA2.js +344 -0
  199. package/dist/installer-OIX4QOG5.js +40 -0
  200. package/dist/lib/cloud-sync.js +7 -7
  201. package/dist/lib/consolidation.js +6 -5
  202. package/dist/lib/database.js +2 -2
  203. package/dist/lib/db-daemon-client.js +2 -2
  204. package/dist/lib/db.js +2 -2
  205. package/dist/lib/embed-worker.js +1 -0
  206. package/dist/lib/embedder.js +7 -3
  207. package/dist/lib/employee-templates.js +4 -4
  208. package/dist/lib/employees.js +2 -2
  209. package/dist/lib/exe-daemon-client.js +2 -2
  210. package/dist/lib/exe-daemon.js +160 -79
  211. package/dist/lib/hybrid-search.js +5 -5
  212. package/dist/lib/identity.js +2 -2
  213. package/dist/lib/messaging.js +11 -11
  214. package/dist/lib/reminders.js +3 -3
  215. package/dist/lib/schedules.js +5 -5
  216. package/dist/lib/session-registry.js +4 -4
  217. package/dist/lib/skill-learning.js +6 -6
  218. package/dist/lib/store.js +4 -4
  219. package/dist/lib/task-router.js +3 -3
  220. package/dist/lib/tasks.js +12 -12
  221. package/dist/lib/tmux-routing.js +12 -10
  222. package/dist/lib/tmux-transport.js +1 -1
  223. package/dist/lib/token-spend.js +3 -3
  224. package/dist/lib/transport.js +2 -2
  225. package/dist/mcp/register-tools.js +62 -61
  226. package/dist/mcp/server.js +63 -62
  227. package/dist/mcp/tools/complete-reminder.js +4 -4
  228. package/dist/mcp/tools/create-reminder.js +4 -4
  229. package/dist/mcp/tools/create-task.js +14 -14
  230. package/dist/mcp/tools/deactivate-behavior.js +7 -7
  231. package/dist/mcp/tools/list-reminders.js +4 -4
  232. package/dist/mcp/tools/list-tasks.js +14 -14
  233. package/dist/mcp/tools/send-message.js +13 -13
  234. package/dist/mcp/tools/update-task.js +13 -13
  235. package/dist/mcp-http-config-PQTOLCTP.js +29 -0
  236. package/dist/memory-cards-4RVDZIY2.js +180 -0
  237. package/dist/memory-graph-extractor-L6YC7G4M.js +22 -0
  238. package/dist/memory-poisoning-defense-4YVJYH4G.js +224 -0
  239. package/dist/memory-queue-client-MVAUOZNJ.js +16 -0
  240. package/dist/memory-reflection-SHHDQNOH.js +244 -0
  241. package/dist/message-queue-client-DCKZT6X2.js +92 -0
  242. package/dist/notifications-JFR3G42W.js +47 -0
  243. package/dist/orchestration-events-MGCGPTDN.js +27 -0
  244. package/dist/orchestrator-DAFL2YZB.js +35 -0
  245. package/dist/pipeline-router-WWSZVPCH.js +15 -0
  246. package/dist/plan-limits-C7XCSDZC.js +28 -0
  247. package/dist/project-boot-N3NTBVLE.js +299 -0
  248. package/dist/projection-worker-MTPAPCWX.js +1084 -0
  249. package/dist/prospective-memory-BTIVUJSB.js +232 -0
  250. package/dist/reranker-UA6WVESJ.js +19 -0
  251. package/dist/retrieval-health-7XNZJEBF.js +12 -0
  252. package/dist/review-polling-4ALGMXC3.js +126 -0
  253. package/dist/runtime/index.js +13 -13
  254. package/dist/self-query-router-MROFQLQB.js +192 -0
  255. package/dist/session-events-CK44XOU4.js +38 -0
  256. package/dist/session-kill-telemetry-MT6ITDOG.js +31 -0
  257. package/dist/session-scope-3XDBWV65.js +88 -0
  258. package/dist/setup-wizard-X6DOD7MC.js +12 -0
  259. package/dist/skill-refinement-G2CCY3GM.js +159 -0
  260. package/dist/stack-update-JF7F56AS.js +84 -0
  261. package/dist/steward-gate-YF2CYXE7.js +15 -0
  262. package/dist/task-enforcement-YN6HK7NE.js +506 -0
  263. package/dist/task-scope-CVK6ISCZ.js +37 -0
  264. package/dist/tasks-crud-NTNET4JE.js +79 -0
  265. package/dist/tasks-notify-4LJVFPCV.js +40 -0
  266. package/dist/tasks-review-3V4WOIRG.js +49 -0
  267. package/dist/telemetry-upload-5PNUKGTM.js +741 -0
  268. package/dist/token-budget-E46G7ZAQ.js +86 -0
  269. package/dist/tool-capability-index-JDSMKJER.js +10 -0
  270. package/dist/tool-telemetry-J3NLS3LJ.js +17 -0
  271. package/dist/tui/App.js +18 -18
  272. package/dist/tui-data-6DOMUUCM.js +260 -0
  273. package/dist/wiki-acl-5UK37LKF.js +111 -0
  274. package/dist/worker-gate-FM7AEC7G.js +21 -0
  275. package/dist/workflow-engine-2EDUHUIY.js +28 -0
  276. package/dist/worktree-7YKKJIYR.js +28 -0
  277. package/dist/worktree-sweep-C3ELFGDN.js +21 -0
  278. package/package.json +1 -1
  279. package/release-notes.json +88 -88
@@ -0,0 +1,105 @@
1
+ import {
2
+ connectEmbedDaemon,
3
+ disconnectClient,
4
+ embedViaClient
5
+ } from "./chunk-W3EQ362K.js";
6
+ import {
7
+ EMBEDDING_DIM
8
+ } from "./chunk-FXU7JOXK.js";
9
+ import {
10
+ MODELS_DIR,
11
+ loadConfigSync
12
+ } from "./chunk-R36FAN53.js";
13
+
14
+ // src/lib/embedder.ts
15
+ var MAX_EMBED_CHARS = 24e3;
16
+ var DOMAIN_PREFIXES = {
17
+ memory: { query: "search_query: agent memory: ", passage: "search_document: agent memory: " },
18
+ decision: { query: "search_query: decision record: ", passage: "search_document: decision: " },
19
+ code: { query: "search_query: source code: ", passage: "search_document: code: " },
20
+ document: { query: "search_query: document: ", passage: "search_document: document: " },
21
+ general: { query: "", passage: "" }
22
+ };
23
+ function prepareEmbeddingText(text, kind, domain) {
24
+ const cfg = loadConfigSync();
25
+ const truncated = text.length > MAX_EMBED_CHARS ? text.slice(0, MAX_EMBED_CHARS) : text;
26
+ if (domain && domain !== "general") {
27
+ const domainPrefix = DOMAIN_PREFIXES[domain];
28
+ const prefix2 = kind === "passage" ? domainPrefix.passage : domainPrefix.query;
29
+ return prefix2 ? `${prefix2}${truncated}` : truncated;
30
+ }
31
+ if (!kind || !cfg.embeddingPrefixes.enabled) return truncated;
32
+ const prefix = kind === "query" ? cfg.embeddingPrefixes.query : cfg.embeddingPrefixes.passage;
33
+ return prefix ? `${prefix}${truncated}` : truncated;
34
+ }
35
+ async function getEmbedder() {
36
+ const ok = await connectEmbedDaemon();
37
+ if (!ok) {
38
+ throw new Error(
39
+ "Could not connect to embedding daemon. Embeddings may be disabled or the daemon may be unreachable."
40
+ );
41
+ }
42
+ }
43
+ async function embed(text) {
44
+ const priority = process.env.EXE_EMBED_PRIORITY === "low" ? "low" : "high";
45
+ const vector = await embedViaClient(prepareEmbeddingText(text), priority);
46
+ if (!vector) {
47
+ throw new Error(
48
+ "Embedding failed: daemon unavailable or no embedding model is loaded."
49
+ );
50
+ }
51
+ const expectedDim = loadConfigSync().embeddingDim || EMBEDDING_DIM;
52
+ if (vector.length !== expectedDim) {
53
+ throw new Error(
54
+ `Embedding dimension mismatch: expected ${expectedDim}, got ${vector.length}. Ensure the configured embedding model matches config.embeddingDim.`
55
+ );
56
+ }
57
+ return vector;
58
+ }
59
+ async function disposeEmbedder() {
60
+ disconnectClient();
61
+ }
62
+ var EMBED_WORKER_CONTEXT_ENV = "EXE_EMBED_WORKER_CONTEXT";
63
+ function assertEmbedWorkerContext(caller) {
64
+ if (process.env[EMBED_WORKER_CONTEXT_ENV] !== "1") {
65
+ throw new Error(
66
+ `Refusing to load the embedding model in-process from ${caller}: the model must load ONLY in the dedicated embed-worker (bug 5de6e765). The current process is not the embed worker (${EMBED_WORKER_CONTEXT_ENV} != 1). This guard prevents the daemon from OOM-crashing on embeddings.`
67
+ );
68
+ }
69
+ }
70
+ async function embedDirect(text) {
71
+ assertEmbedWorkerContext("embedDirect");
72
+ const llamaCpp = await import("node-llama-cpp");
73
+ const { existsSync } = await import("fs");
74
+ const path = await import("path");
75
+ const cfg = loadConfigSync();
76
+ const modelPath = path.join(MODELS_DIR, cfg.modelFile);
77
+ if (!existsSync(modelPath)) {
78
+ throw new Error(`Embedding model not found at ${modelPath}. Install or configure an embedding model to validate it.`);
79
+ }
80
+ const llama = await llamaCpp.getLlama();
81
+ const model = await llama.loadModel({ modelPath });
82
+ const context = await model.createEmbeddingContext();
83
+ try {
84
+ const embedding = await context.getEmbeddingFor(prepareEmbeddingText(text));
85
+ const vector = Array.from(embedding.vector);
86
+ const expectedDim = cfg.embeddingDim || EMBEDDING_DIM;
87
+ if (vector.length !== expectedDim) {
88
+ throw new Error(
89
+ `Embedding dimension mismatch: expected ${expectedDim}, got ${vector.length}.`
90
+ );
91
+ }
92
+ return vector;
93
+ } finally {
94
+ }
95
+ }
96
+
97
+ export {
98
+ prepareEmbeddingText,
99
+ getEmbedder,
100
+ embed,
101
+ disposeEmbedder,
102
+ EMBED_WORKER_CONTEXT_ENV,
103
+ assertEmbedWorkerContext,
104
+ embedDirect
105
+ };
@@ -0,0 +1,362 @@
1
+ import {
2
+ recordSessionKill
3
+ } from "./chunk-5Q4MR6SL.js";
4
+ import {
5
+ sessionScopeFilter,
6
+ verifyPaneAtCapacity,
7
+ writeNotification
8
+ } from "./chunk-K5ZO532Q.js";
9
+ import {
10
+ listSessions
11
+ } from "./chunk-Y3PMNUM5.js";
12
+ import {
13
+ getTransport
14
+ } from "./chunk-KOO3J5PV.js";
15
+ import {
16
+ recordOrchestrationEventBestEffort
17
+ } from "./chunk-NLZHVIOP.js";
18
+ import {
19
+ getClient,
20
+ isCoordinatorName
21
+ } from "./chunk-WUKHLCBE.js";
22
+
23
+ // src/lib/capacity-monitor.ts
24
+ var CAPACITY_PATTERNS = [
25
+ /conversation is too long/i,
26
+ /maximum context length/i,
27
+ /context window.*(?:limit|exceed|full)/i,
28
+ /reached.*(?:token|context).*limit/i
29
+ ];
30
+ var CONTENT_LINE_PREFIX = /^[\s>#\-*[]/;
31
+ var CONTENT_LINE_MARKERS = [
32
+ "RESUME:",
33
+ "intercom",
34
+ "capacity-monitor",
35
+ "CAPACITY_PATTERNS",
36
+ "isAtCapacity",
37
+ "CONTENT_LINE_MARKERS",
38
+ "pollCapacityDead",
39
+ "confirmCapacityKill",
40
+ "session_kills",
41
+ "capacity-monitor.test"
42
+ ];
43
+ var SOURCE_CODE_MARKERS = [
44
+ /["'`/].*(?:maximum context length|conversation is too long)/i,
45
+ /(?:maximum context length|conversation is too long).*["'`/]/i
46
+ ];
47
+ var RELAUNCH_COOLDOWN_MS = 5 * 60 * 1e3;
48
+ var _lastRelaunch = /* @__PURE__ */ new Map();
49
+ var RESUME_TITLE_PREFIX = "RESUME:";
50
+ var RESUME_TITLE_LIKE_PATTERN = `${RESUME_TITLE_PREFIX} % hit context capacity%`;
51
+ var RESUME_ACTIVE_STATUSES = ["open", "in_progress"];
52
+ function resumeTaskTitle(agentId) {
53
+ return `${RESUME_TITLE_PREFIX} ${agentId} hit context capacity \u2014 continue open tasks`;
54
+ }
55
+ function buildResumeContext(agentId, openTasks) {
56
+ const taskList = openTasks.map(
57
+ (r, i) => `${i + 1}. [${String(r.priority).toUpperCase()}] ${String(r.title)} (${String(r.task_file)})`
58
+ ).join("\n");
59
+ return [
60
+ "## Context",
61
+ "",
62
+ `${agentId} hit context capacity and was auto-relaunched by the capacity monitor.`,
63
+ "Call recall_my_memory first \u2014 search for 'CONTEXT CHECKPOINT'. Pick up where the previous session stopped.",
64
+ "",
65
+ `You have ${openTasks.length} open task(s). Work through them in priority order:`,
66
+ "",
67
+ taskList,
68
+ "",
69
+ "Read each task file and chain through them. Build and commit after each one."
70
+ ].join("\n");
71
+ }
72
+ var CONFIRMATION_WINDOW_MS = 3 * 60 * 1e3;
73
+ var _pendingCapacityKill = /* @__PURE__ */ new Map();
74
+ function filterPaneContent(paneOutput) {
75
+ return paneOutput.split("\n").filter((line) => {
76
+ if (CONTENT_LINE_PREFIX.test(line)) return false;
77
+ for (const marker of CONTENT_LINE_MARKERS) {
78
+ if (line.includes(marker)) return false;
79
+ }
80
+ for (const re of SOURCE_CODE_MARKERS) {
81
+ if (re.test(line)) return false;
82
+ }
83
+ return true;
84
+ }).join("\n");
85
+ }
86
+ var CC_CONTEXT_BAR_RE = /([\u2588\u2591\u2592\u2593]{10})\s+(\d+)%/;
87
+ var CTX_FLOOR_PERCENT = 50;
88
+ function extractContextPercent(paneOutput) {
89
+ const match = paneOutput.match(CC_CONTEXT_BAR_RE);
90
+ if (!match) return null;
91
+ const parsed = Number.parseInt(match[2], 10);
92
+ return Number.isFinite(parsed) ? parsed : null;
93
+ }
94
+ function isAtCapacity(paneOutput) {
95
+ const filtered = filterPaneContent(paneOutput);
96
+ return CAPACITY_PATTERNS.some((p) => p.test(filtered));
97
+ }
98
+ function confirmCapacityKill(agentId, now = Date.now()) {
99
+ const pendingSince = _pendingCapacityKill.get(agentId);
100
+ if (pendingSince === void 0) {
101
+ _pendingCapacityKill.set(agentId, now);
102
+ return false;
103
+ }
104
+ if (now - pendingSince > CONFIRMATION_WINDOW_MS) {
105
+ _pendingCapacityKill.set(agentId, now);
106
+ return false;
107
+ }
108
+ _pendingCapacityKill.delete(agentId);
109
+ return true;
110
+ }
111
+ function _resetPendingCapacityKills() {
112
+ _pendingCapacityKill.clear();
113
+ }
114
+ function _resetLastRelaunchCache() {
115
+ _lastRelaunch.clear();
116
+ }
117
+ async function lastResumeCreatedAtMs(agentId, sessionScope) {
118
+ const client = getClient();
119
+ const cmScope = sessionScopeFilter(sessionScope ?? null);
120
+ const result = await client.execute({
121
+ sql: `SELECT MAX(created_at) AS last_created_at
122
+ FROM tasks
123
+ WHERE assigned_to = ? AND title LIKE ?${cmScope.sql}`,
124
+ args: [agentId, `${RESUME_TITLE_PREFIX} %`, ...cmScope.args]
125
+ });
126
+ const raw = result.rows[0]?.last_created_at;
127
+ if (raw === null || raw === void 0) return null;
128
+ const parsed = Date.parse(String(raw));
129
+ return Number.isNaN(parsed) ? null : parsed;
130
+ }
131
+ async function isWithinRelaunchCooldown(agentId, now = Date.now(), sessionScope) {
132
+ const cacheKey = sessionScope ? `${agentId}::${sessionScope}` : agentId;
133
+ const cached = _lastRelaunch.get(cacheKey);
134
+ if (cached !== void 0) return now - cached < RELAUNCH_COOLDOWN_MS;
135
+ const persisted = await lastResumeCreatedAtMs(agentId, sessionScope);
136
+ if (persisted === null) return false;
137
+ if (now - persisted >= RELAUNCH_COOLDOWN_MS) return false;
138
+ _lastRelaunch.set(cacheKey, persisted);
139
+ return true;
140
+ }
141
+ async function createOrRefreshResumeTask(agentId, projectDir, openTasks, sessionScope) {
142
+ const client = getClient();
143
+ const now = (/* @__PURE__ */ new Date()).toISOString();
144
+ const context = buildResumeContext(agentId, openTasks);
145
+ const rdScope = sessionScopeFilter(sessionScope ?? null);
146
+ const existing = await client.execute({
147
+ sql: `SELECT id FROM tasks
148
+ WHERE assigned_to = ?
149
+ AND title LIKE ?
150
+ AND status IN (${RESUME_ACTIVE_STATUSES.map(() => "?").join(", ")})${rdScope.sql}
151
+ ORDER BY created_at DESC
152
+ LIMIT 1`,
153
+ args: [agentId, RESUME_TITLE_LIKE_PATTERN, ...RESUME_ACTIVE_STATUSES, ...rdScope.args]
154
+ });
155
+ if (existing.rows.length > 0) {
156
+ const taskId = String(existing.rows[0].id);
157
+ await client.execute({
158
+ sql: `UPDATE tasks SET context = ?, updated_at = ? WHERE id = ?`,
159
+ args: [context, now, taskId]
160
+ });
161
+ recordOrchestrationEventBestEffort({
162
+ eventType: "session.resumed",
163
+ source: "capacity-monitor.createOrRefreshResumeTask",
164
+ agentId,
165
+ taskId,
166
+ payload: { created: false, action: "refreshed" }
167
+ });
168
+ return { created: false, taskId };
169
+ }
170
+ try {
171
+ const staleResumes = await client.execute({
172
+ sql: `SELECT id FROM tasks
173
+ WHERE assigned_to = ?
174
+ AND title LIKE ?
175
+ AND status IN (${RESUME_ACTIVE_STATUSES.map(() => "?").join(", ")})`,
176
+ args: [agentId, RESUME_TITLE_LIKE_PATTERN, ...RESUME_ACTIVE_STATUSES]
177
+ });
178
+ for (const row of staleResumes.rows) {
179
+ await client.execute({
180
+ sql: `UPDATE tasks SET status = 'cancelled', result = ?, updated_at = ? WHERE id = ?`,
181
+ args: ["Auto-cancelled: superseded by new RESUME task.", now, String(row.id)]
182
+ });
183
+ }
184
+ } catch {
185
+ }
186
+ const { createTask } = await import("./lib/tasks.js");
187
+ const task = await createTask({
188
+ title: resumeTaskTitle(agentId),
189
+ assignedTo: agentId,
190
+ assignedBy: "system",
191
+ projectName: projectDir.split("/").pop() ?? "unknown",
192
+ priority: "p0",
193
+ context,
194
+ baseDir: projectDir
195
+ });
196
+ recordOrchestrationEventBestEffort({
197
+ eventType: "session.resumed",
198
+ source: "capacity-monitor.createOrRefreshResumeTask",
199
+ agentId,
200
+ taskId: task.id,
201
+ payload: { created: true, action: "created", openTaskCount: openTasks.length }
202
+ });
203
+ return { created: true, taskId: task.id };
204
+ }
205
+ async function pollCapacityDead() {
206
+ const transport = getTransport();
207
+ const relaunched = [];
208
+ const registered = listSessions();
209
+ if (registered.length === 0) return [];
210
+ let liveSessions;
211
+ try {
212
+ liveSessions = transport.listSessions();
213
+ } catch {
214
+ return [];
215
+ }
216
+ for (const entry of registered) {
217
+ const { windowName, agentId, projectDir } = entry;
218
+ if (!liveSessions.includes(windowName)) continue;
219
+ const cmDashIdx = windowName.indexOf("-");
220
+ const cmDerivedScope = cmDashIdx >= 0 ? windowName.slice(cmDashIdx + 1) : null;
221
+ if (await isWithinRelaunchCooldown(agentId, Date.now(), cmDerivedScope)) continue;
222
+ let pane;
223
+ try {
224
+ pane = transport.capturePane(windowName, 15);
225
+ } catch {
226
+ continue;
227
+ }
228
+ if (!isAtCapacity(pane)) continue;
229
+ const ctxPct = extractContextPercent(pane);
230
+ if (ctxPct !== null && ctxPct < CTX_FLOOR_PERCENT) {
231
+ process.stderr.write(
232
+ `[capacity-monitor] ctx-floor: ${agentId} at ${ctxPct}% in ${windowName} \u2014 below ${CTX_FLOOR_PERCENT}%. Skipping capacity kill (likely self-referential content or false positive).
233
+ `
234
+ );
235
+ continue;
236
+ }
237
+ if (!confirmCapacityKill(agentId)) {
238
+ process.stderr.write(
239
+ `[capacity-monitor] ${agentId} matched capacity pattern once in ${windowName}. Awaiting confirmation on next tick.
240
+ `
241
+ );
242
+ continue;
243
+ }
244
+ const verify = await verifyPaneAtCapacity(windowName);
245
+ if (!verify.atCapacity) {
246
+ process.stderr.write(
247
+ `[capacity-monitor] verifyPaneAtCapacity rejected kill for ${agentId} in ${windowName} (reason: ${verify.reason}). Skipping.
248
+ `
249
+ );
250
+ void recordSessionKill({
251
+ sessionName: windowName,
252
+ agentId,
253
+ reason: "capacity_false_positive_blocked"
254
+ });
255
+ continue;
256
+ }
257
+ process.stderr.write(
258
+ `[capacity-monitor] Detected ${agentId} at capacity in session ${windowName} (confirmed). Auto-relaunching.
259
+ `
260
+ );
261
+ if (isCoordinatorName(agentId)) {
262
+ try {
263
+ const { loadConfigSync } = await import("./lib/config.js");
264
+ const cfg = loadConfigSync();
265
+ if (cfg.sessionLifecycle.autoRelaunchCoordinator !== false) {
266
+ const fs = await import("fs");
267
+ const path = await import("path");
268
+ const os = await import("os");
269
+ const markerDir = path.join(os.homedir(), ".exe-os", "session-cache");
270
+ fs.mkdirSync(markerDir, { recursive: true });
271
+ const markerPath = path.join(markerDir, `relaunch-${windowName}.json`);
272
+ fs.writeFileSync(markerPath, JSON.stringify({
273
+ reason: "context_full",
274
+ agentId,
275
+ projectDir,
276
+ timestamp: (/* @__PURE__ */ new Date()).toISOString()
277
+ }));
278
+ process.stderr.write(
279
+ `[capacity-monitor] Coordinator relaunch marker written: ${markerPath}
280
+ `
281
+ );
282
+ }
283
+ transport.kill(windowName);
284
+ void recordSessionKill({ sessionName: windowName, agentId, reason: "capacity" });
285
+ const coordCacheKey = cmDerivedScope ? `${agentId}::${cmDerivedScope}` : agentId;
286
+ _lastRelaunch.set(coordCacheKey, Date.now());
287
+ relaunched.push(agentId);
288
+ } catch (err) {
289
+ process.stderr.write(
290
+ `[capacity-monitor] Coordinator relaunch marker write failed: ${err instanceof Error ? err.message : String(err)}
291
+ `
292
+ );
293
+ }
294
+ continue;
295
+ }
296
+ try {
297
+ transport.kill(windowName);
298
+ void recordSessionKill({
299
+ sessionName: windowName,
300
+ agentId,
301
+ reason: "capacity"
302
+ });
303
+ const client = getClient();
304
+ const dashIdx = windowName.indexOf("-");
305
+ const derivedScope = dashIdx >= 0 ? windowName.slice(dashIdx + 1) : null;
306
+ const rlScope = sessionScopeFilter(derivedScope);
307
+ const openTasks = await client.execute({
308
+ sql: `SELECT id, title, priority, task_file, status
309
+ FROM tasks
310
+ WHERE assigned_to = ? AND status IN ('open', 'in_progress')${rlScope.sql}
311
+ ORDER BY
312
+ CASE priority WHEN 'p0' THEN 0 WHEN 'p1' THEN 1 WHEN 'p2' THEN 2 ELSE 3 END,
313
+ created_at ASC
314
+ LIMIT 10`,
315
+ args: [agentId, ...rlScope.args]
316
+ });
317
+ if (openTasks.rows.length === 0) {
318
+ process.stderr.write(
319
+ `[capacity-monitor] ${agentId} has no open tasks \u2014 skipping relaunch.
320
+ `
321
+ );
322
+ continue;
323
+ }
324
+ const { created } = await createOrRefreshResumeTask(
325
+ agentId,
326
+ projectDir,
327
+ openTasks.rows,
328
+ derivedScope
329
+ );
330
+ if (created) {
331
+ await writeNotification({
332
+ agentId: "system",
333
+ agentRole: "daemon",
334
+ event: "capacity_relaunch",
335
+ project: projectDir.split("/").pop() ?? "unknown",
336
+ summary: `${agentId} hit context capacity. Auto-relaunched with ${openTasks.rows.length} open task(s).`
337
+ });
338
+ }
339
+ const cacheKey = derivedScope ? `${agentId}::${derivedScope}` : agentId;
340
+ _lastRelaunch.set(cacheKey, Date.now());
341
+ if (created) relaunched.push(agentId);
342
+ } catch (err) {
343
+ process.stderr.write(
344
+ `[capacity-monitor] Failed to relaunch ${agentId}: ${err instanceof Error ? err.message : String(err)}
345
+ `
346
+ );
347
+ }
348
+ }
349
+ return relaunched;
350
+ }
351
+
352
+ export {
353
+ CTX_FLOOR_PERCENT,
354
+ extractContextPercent,
355
+ isAtCapacity,
356
+ confirmCapacityKill,
357
+ _resetPendingCapacityKills,
358
+ _resetLastRelaunchCache,
359
+ isWithinRelaunchCooldown,
360
+ createOrRefreshResumeTask,
361
+ pollCapacityDead
362
+ };
@@ -0,0 +1,85 @@
1
+ import {
2
+ PLATFORM_PROCEDURES,
3
+ PLATFORM_PROCEDURE_TITLES
4
+ } from "./chunk-VUH67PT4.js";
5
+ import {
6
+ getClient
7
+ } from "./chunk-WUKHLCBE.js";
8
+
9
+ // src/lib/global-procedures.ts
10
+ import { randomUUID } from "crypto";
11
+ var _customerCache = "";
12
+ var _cacheLoaded = false;
13
+ var _platformCache = PLATFORM_PROCEDURES.map((p) => `### ${p.title}
14
+ ${p.content}`).join("\n\n");
15
+ async function loadGlobalProcedures() {
16
+ const client = getClient();
17
+ const result = await client.execute({
18
+ sql: "SELECT * FROM company_procedures WHERE active = 1 ORDER BY priority ASC, created_at ASC",
19
+ args: []
20
+ });
21
+ const allRows = result.rows;
22
+ const customerOnly = allRows.filter((p) => {
23
+ if (PLATFORM_PROCEDURE_TITLES.has(p.title)) return false;
24
+ const title = (p.title ?? "").trim();
25
+ const content = (p.content ?? "").trim();
26
+ if (!title || title === "(untitled)") return false;
27
+ if (!content) return false;
28
+ return true;
29
+ });
30
+ const values = customerOnly.filter((p) => p.kind === "value");
31
+ const procedures = customerOnly.filter((p) => p.kind !== "value");
32
+ const parts = [];
33
+ if (values.length > 0) {
34
+ parts.push("### Company Values\n" + values.map((v) => `- **${v.title}:** ${v.content}`).join("\n"));
35
+ }
36
+ if (procedures.length > 0) {
37
+ parts.push(procedures.map((p) => `### ${p.title}
38
+ ${p.content}`).join("\n\n"));
39
+ }
40
+ _customerCache = parts.join("\n\n");
41
+ _cacheLoaded = true;
42
+ return customerOnly;
43
+ }
44
+ function getGlobalProceduresBlock() {
45
+ const sections = [];
46
+ if (_platformCache) sections.push(_platformCache);
47
+ if (_cacheLoaded && _customerCache) sections.push(_customerCache);
48
+ if (sections.length === 0) return "";
49
+ return `## Organization-Wide Procedures (MANDATORY \u2014 supersedes all other rules)
50
+
51
+ ${sections.join("\n\n")}
52
+ `;
53
+ }
54
+ async function storeGlobalProcedure(input) {
55
+ if (!input.title?.trim() || !input.content?.trim()) {
56
+ throw new Error("storeGlobalProcedure requires a non-empty title and content");
57
+ }
58
+ const id = randomUUID();
59
+ const now = (/* @__PURE__ */ new Date()).toISOString();
60
+ const client = getClient();
61
+ await client.execute({
62
+ sql: `INSERT INTO company_procedures (id, title, content, priority, domain, kind, active, created_at, updated_at)
63
+ VALUES (?, ?, ?, ?, ?, ?, 1, ?, ?)`,
64
+ args: [id, input.title, input.content, input.priority ?? "p0", input.domain ?? null, input.kind ?? "procedure", now, now]
65
+ });
66
+ await loadGlobalProcedures();
67
+ return id;
68
+ }
69
+ async function deactivateGlobalProcedure(id) {
70
+ const now = (/* @__PURE__ */ new Date()).toISOString();
71
+ const client = getClient();
72
+ const result = await client.execute({
73
+ sql: "UPDATE company_procedures SET active = 0, updated_at = ? WHERE id = ?",
74
+ args: [now, id]
75
+ });
76
+ await loadGlobalProcedures();
77
+ return result.rowsAffected > 0;
78
+ }
79
+
80
+ export {
81
+ loadGlobalProcedures,
82
+ getGlobalProceduresBlock,
83
+ storeGlobalProcedure,
84
+ deactivateGlobalProcedure
85
+ };