@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,244 @@
1
+ import {
2
+ employeeSessionName,
3
+ ensureEmployee,
4
+ markAsReadByTaskFile,
5
+ notifyParentExe,
6
+ resolveExeSession,
7
+ sendIntercom
8
+ } from "./chunk-K5ZO532Q.js";
9
+ import {
10
+ getTransport
11
+ } from "./chunk-KOO3J5PV.js";
12
+ import {
13
+ recordOrchestrationEventBestEffort
14
+ } from "./chunk-NLZHVIOP.js";
15
+ import {
16
+ getAgentRuntime
17
+ } from "./chunk-QRTJNSKU.js";
18
+ import {
19
+ getSessionKey
20
+ } from "./chunk-CVYC6DUW.js";
21
+ import {
22
+ isCoordinatorName,
23
+ isMultiInstance,
24
+ shouldAutoInstance
25
+ } from "./chunk-WUKHLCBE.js";
26
+
27
+ // src/lib/tasks-notify.ts
28
+ var VERIFY_DELAY_MS = 1e4;
29
+ var ACK_PATTERNS = [
30
+ /New task assigned/,
31
+ /START WORKING NOW/,
32
+ /marked in_progress/,
33
+ /Reading.*\.md/
34
+ ];
35
+ function resolveDispatchRuntime(agentId, override) {
36
+ if (override) return override;
37
+ try {
38
+ return getAgentRuntime(agentId).runtime ?? null;
39
+ } catch {
40
+ return null;
41
+ }
42
+ }
43
+ async function verifyDispatch(sessionName, delayMs = VERIFY_DELAY_MS) {
44
+ const transport = getTransport();
45
+ await new Promise((r) => setTimeout(r, delayMs));
46
+ if (!transport.isAlive(sessionName)) {
47
+ return "session_dead";
48
+ }
49
+ try {
50
+ const output = transport.capturePane(sessionName, 20);
51
+ const acked = ACK_PATTERNS.some((p) => p.test(output));
52
+ return acked ? "verified" : "sent_unverified";
53
+ } catch {
54
+ return "sent_unverified";
55
+ }
56
+ }
57
+ async function dispatchTaskToEmployee(input) {
58
+ if (isCoordinatorName(input.assignedTo)) return { dispatched: "skipped" };
59
+ const dispatchRuntime = resolveDispatchRuntime(input.assignedTo, input.spawnRuntime);
60
+ recordOrchestrationEventBestEffort({
61
+ eventType: "dispatch.attempted",
62
+ source: "tasks-notify.dispatchTaskToEmployee",
63
+ taskId: input.taskId ?? null,
64
+ agentId: input.assignedTo,
65
+ runtime: dispatchRuntime,
66
+ payload: { priority: input.priority, projectName: input.projectName }
67
+ });
68
+ let crossProject = false;
69
+ if (input.projectName) {
70
+ try {
71
+ const { assertSessionScope } = await import("./session-scope-3XDBWV65.js");
72
+ const check = assertSessionScope("dispatch_task", input.projectName);
73
+ if (check.reason === "cross_session_denied") {
74
+ crossProject = true;
75
+ recordOrchestrationEventBestEffort({
76
+ eventType: "dispatch.failed",
77
+ source: "tasks-notify.dispatchTaskToEmployee",
78
+ taskId: input.taskId ?? null,
79
+ agentId: input.assignedTo,
80
+ runtime: dispatchRuntime,
81
+ errorCode: "cross_session_denied",
82
+ payload: { projectName: input.projectName }
83
+ });
84
+ return { dispatched: "skipped", crossProject: true };
85
+ }
86
+ } catch {
87
+ }
88
+ }
89
+ try {
90
+ const transport = getTransport();
91
+ const exeSession = resolveExeSession();
92
+ if (!exeSession) {
93
+ recordOrchestrationEventBestEffort({
94
+ eventType: "dispatch.failed",
95
+ source: "tasks-notify.dispatchTaskToEmployee",
96
+ taskId: input.taskId ?? null,
97
+ agentId: input.assignedTo,
98
+ runtime: dispatchRuntime,
99
+ errorCode: "no_exe_session"
100
+ });
101
+ return { dispatched: "session_missing" };
102
+ }
103
+ const multiInstance = isMultiInstance(input.assignedTo);
104
+ if (multiInstance) {
105
+ const projectDir = input.projectDir ?? process.cwd();
106
+ const autoOpts = shouldAutoInstance(input.assignedTo);
107
+ const result = ensureEmployee(input.assignedTo, exeSession, projectDir, {
108
+ ...autoOpts,
109
+ runtimeOverride: input.spawnRuntime,
110
+ modelOverride: input.spawnModel
111
+ });
112
+ if (result.status === "failed") {
113
+ process.stderr.write(
114
+ `[dispatch-audit] SPAWN FAILED \u2192 ${input.assignedTo} | task="${input.title}" [${input.priority}] | error=${result.error}
115
+ `
116
+ );
117
+ recordOrchestrationEventBestEffort({
118
+ eventType: "dispatch.failed",
119
+ source: "tasks-notify.dispatchTaskToEmployee",
120
+ taskId: input.taskId ?? null,
121
+ agentId: input.assignedTo,
122
+ sessionScope: exeSession,
123
+ runtime: dispatchRuntime,
124
+ errorCode: "spawn_failed",
125
+ payload: { path: "multi_instance", error: result.error }
126
+ });
127
+ return { dispatched: "session_missing" };
128
+ }
129
+ const dispatched = result.status === "intercom_sent" || result.status === "intercom_unprocessed" ? "sent_unverified" : "spawned";
130
+ process.stderr.write(
131
+ `[dispatch-audit] ${dispatched === "spawned" ? "SPAWNED" : "INTERCOM"} \u2192 ${result.sessionName} | task="${input.title}" [${input.priority}]
132
+ `
133
+ );
134
+ recordOrchestrationEventBestEffort({
135
+ eventType: "dispatch.completed",
136
+ source: "tasks-notify.dispatchTaskToEmployee",
137
+ taskId: input.taskId ?? null,
138
+ agentId: input.assignedTo,
139
+ sessionScope: exeSession,
140
+ tmuxSession: result.sessionName,
141
+ runtime: dispatchRuntime,
142
+ result: dispatched,
143
+ payload: { path: "multi_instance", priority: input.priority }
144
+ });
145
+ return { dispatched, session: result.sessionName, crossProject };
146
+ }
147
+ const sessionName = employeeSessionName(input.assignedTo, exeSession);
148
+ if (transport.isAlive(sessionName)) {
149
+ const result = sendIntercom(sessionName, { force: true });
150
+ const dispatched = result === "acknowledged" || result === "debounced" || result === "queued" ? "verified" : result === "delivered" ? "sent_unverified" : "session_dead";
151
+ process.stderr.write(
152
+ `[dispatch-audit] intercom \u2192 ${sessionName} | task="${input.title}" [${input.priority}] | result=${dispatched} (sendIntercom=${result})
153
+ `
154
+ );
155
+ recordOrchestrationEventBestEffort({
156
+ eventType: "dispatch.completed",
157
+ source: "tasks-notify.dispatchTaskToEmployee",
158
+ taskId: input.taskId ?? null,
159
+ agentId: input.assignedTo,
160
+ sessionScope: exeSession,
161
+ tmuxSession: sessionName,
162
+ runtime: dispatchRuntime,
163
+ result: dispatched,
164
+ payload: { path: "single_instance_intercom", priority: input.priority }
165
+ });
166
+ return { dispatched, session: sessionName, crossProject };
167
+ } else {
168
+ const projectDir = input.projectDir ?? process.cwd();
169
+ const result = ensureEmployee(input.assignedTo, exeSession, projectDir, {
170
+ runtimeOverride: input.spawnRuntime,
171
+ modelOverride: input.spawnModel
172
+ });
173
+ if (result.status === "failed") {
174
+ process.stderr.write(
175
+ `[dispatch-audit] SPAWN FAILED \u2192 ${input.assignedTo} | task="${input.title}" [${input.priority}] | error=${result.error}
176
+ `
177
+ );
178
+ recordOrchestrationEventBestEffort({
179
+ eventType: "dispatch.failed",
180
+ source: "tasks-notify.dispatchTaskToEmployee",
181
+ taskId: input.taskId ?? null,
182
+ agentId: input.assignedTo,
183
+ sessionScope: exeSession,
184
+ runtime: dispatchRuntime,
185
+ errorCode: "spawn_failed",
186
+ payload: { path: "single_instance_spawn", error: result.error }
187
+ });
188
+ return { dispatched: "session_missing" };
189
+ }
190
+ process.stderr.write(
191
+ `[dispatch-audit] SPAWNED \u2192 ${result.sessionName} | task="${input.title}" [${input.priority}]
192
+ `
193
+ );
194
+ recordOrchestrationEventBestEffort({
195
+ eventType: "dispatch.completed",
196
+ source: "tasks-notify.dispatchTaskToEmployee",
197
+ taskId: input.taskId ?? null,
198
+ agentId: input.assignedTo,
199
+ sessionScope: exeSession,
200
+ tmuxSession: result.sessionName,
201
+ runtime: dispatchRuntime,
202
+ result: "spawned",
203
+ payload: { path: "single_instance_spawn", priority: input.priority }
204
+ });
205
+ return { dispatched: "spawned", session: result.sessionName, crossProject };
206
+ }
207
+ } catch {
208
+ recordOrchestrationEventBestEffort({
209
+ eventType: "dispatch.failed",
210
+ source: "tasks-notify.dispatchTaskToEmployee",
211
+ taskId: input.taskId ?? null,
212
+ agentId: input.assignedTo,
213
+ runtime: dispatchRuntime,
214
+ errorCode: "exception"
215
+ });
216
+ return { dispatched: "session_missing" };
217
+ }
218
+ }
219
+ function notifyTaskDone() {
220
+ try {
221
+ const key = getSessionKey();
222
+ if (key && !process.env.VITEST) {
223
+ notifyParentExe(key);
224
+ process.stderr.write(
225
+ `[dispatch-audit] notifyTaskDone \u2192 parent coordinator (session=${key})
226
+ `
227
+ );
228
+ }
229
+ } catch {
230
+ }
231
+ }
232
+ async function markTaskNotificationsRead(taskFile) {
233
+ try {
234
+ await markAsReadByTaskFile(taskFile);
235
+ } catch {
236
+ }
237
+ }
238
+
239
+ export {
240
+ verifyDispatch,
241
+ dispatchTaskToEmployee,
242
+ notifyTaskDone,
243
+ markTaskNotificationsRead
244
+ };
@@ -0,0 +1,30 @@
1
+ import {
2
+ createReminder
3
+ } from "./chunk-MEP7OUVZ.js";
4
+
5
+ // src/mcp/tools/create-reminder.ts
6
+ import { z } from "zod";
7
+ function registerCreateReminder(server) {
8
+ server.registerTool(
9
+ "create_reminder",
10
+ {
11
+ title: "Create Reminder",
12
+ description: "Set a reminder for the founder. Shown in the boot brief every session.",
13
+ inputSchema: {
14
+ text: z.string().describe("What to remind about"),
15
+ due_date: z.string().optional().describe("Optional due date \u2014 ISO date (2026-04-01) or null for persistent")
16
+ }
17
+ },
18
+ async ({ text, due_date }) => {
19
+ const reminder = await createReminder(text, due_date);
20
+ const dueStr = reminder.dueDate ? ` (due: ${reminder.dueDate})` : "";
21
+ return {
22
+ content: [{ type: "text", text: `Reminder set: "${reminder.text}"${dueStr}` }]
23
+ };
24
+ }
25
+ );
26
+ }
27
+
28
+ export {
29
+ registerCreateReminder
30
+ };
@@ -0,0 +1,85 @@
1
+ import {
2
+ deactivateBehavior
3
+ } from "./chunk-QIFUVZFW.js";
4
+ import {
5
+ getActiveAgent
6
+ } from "./chunk-AKV44JEH.js";
7
+ import {
8
+ canCoordinate,
9
+ getClient
10
+ } from "./chunk-WUKHLCBE.js";
11
+
12
+ // src/mcp/tools/deactivate-behavior.ts
13
+ import { z } from "zod";
14
+ function registerDeactivateBehavior(server) {
15
+ server.registerTool(
16
+ "deactivate_behavior",
17
+ {
18
+ title: "Deactivate Behavior",
19
+ description: "Soft-delete a behavior by setting active = 0. RESTRICTED: only coordinator or founder sessions can use this. Use list_behaviors to find the behavior ID first.",
20
+ inputSchema: {
21
+ behavior_id: z.string().describe("UUID of the behavior to deactivate")
22
+ }
23
+ },
24
+ async ({ behavior_id }) => {
25
+ const caller = getActiveAgent();
26
+ try {
27
+ const { StewardGate } = await import("./steward-gate-YF2CYXE7.js");
28
+ const steward = new StewardGate();
29
+ const gateDecision = await steward.checkAuthority(caller.agentId || "unknown", "deactivate_behavior", behavior_id);
30
+ if (!gateDecision.allowed) {
31
+ return { content: [{ type: "text", text: `Steward gate denied: ${gateDecision.reason}` }], isError: true };
32
+ }
33
+ } catch {
34
+ }
35
+ const allowed = canCoordinate(caller.agentId, caller.agentRole);
36
+ if (!allowed) {
37
+ return {
38
+ content: [{
39
+ type: "text",
40
+ text: `Permission denied. Only the coordinator or founder sessions can deactivate behaviors. You are "${caller.agentId}".`
41
+ }],
42
+ isError: true
43
+ };
44
+ }
45
+ const client = getClient();
46
+ const result = await client.execute({
47
+ sql: `SELECT id, agent_id, content, domain, priority FROM behaviors WHERE id = ?`,
48
+ args: [behavior_id]
49
+ });
50
+ if (result.rows.length === 0) {
51
+ return {
52
+ content: [{
53
+ type: "text",
54
+ text: `Behavior not found: ${behavior_id}`
55
+ }],
56
+ isError: true
57
+ };
58
+ }
59
+ const row = result.rows[0];
60
+ const wasActive = await deactivateBehavior(behavior_id);
61
+ if (!wasActive) {
62
+ return {
63
+ content: [{
64
+ type: "text",
65
+ text: `Behavior ${behavior_id} was already inactive.`
66
+ }]
67
+ };
68
+ }
69
+ return {
70
+ content: [{
71
+ type: "text",
72
+ text: `Deactivated behavior for ${row.agent_id}.
73
+ ID: ${row.id}
74
+ Domain: ${row.domain ?? "none"}
75
+ Priority: ${row.priority}
76
+ Content: ${row.content}`
77
+ }]
78
+ };
79
+ }
80
+ );
81
+ }
82
+
83
+ export {
84
+ registerDeactivateBehavior
85
+ };