@askexenow/exe-os 0.9.264 → 0.9.265

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 (143) hide show
  1. package/dist/backfill-metadata-WM46YQZL.js +597 -0
  2. package/dist/bin/agentic-ontology-backfill.js +1 -1
  3. package/dist/bin/agentic-reflection-backfill.js +1 -1
  4. package/dist/bin/agentic-semantic-label.js +1 -1
  5. package/dist/bin/backfill-conversations.js +1 -1
  6. package/dist/bin/backfill-responses.js +1 -1
  7. package/dist/bin/backfill-vectors.js +2 -2
  8. package/dist/bin/bulk-sync-postgres.js +1 -1
  9. package/dist/bin/cleanup-stale-review-tasks.js +2 -2
  10. package/dist/bin/cli.js +5 -5
  11. package/dist/bin/exe-assign.js +1 -1
  12. package/dist/bin/exe-boot.js +3 -3
  13. package/dist/bin/exe-dispatch.js +2 -2
  14. package/dist/bin/exe-doctor.js +1 -1
  15. package/dist/bin/exe-export-behaviors.js +2 -2
  16. package/dist/bin/exe-forget.js +3 -3
  17. package/dist/bin/exe-gateway.js +5 -5
  18. package/dist/bin/exe-heartbeat.js +3 -3
  19. package/dist/bin/exe-kill.js +3 -3
  20. package/dist/bin/exe-launch-agent.js +3 -3
  21. package/dist/bin/exe-pending-messages.js +3 -3
  22. package/dist/bin/exe-pending-notifications.js +2 -2
  23. package/dist/bin/exe-pending-reviews.js +6 -4
  24. package/dist/bin/exe-review.js +3 -3
  25. package/dist/bin/exe-search.js +2 -2
  26. package/dist/bin/exe-session-cleanup.js +5 -5
  27. package/dist/bin/exe-start-codex.js +1 -1
  28. package/dist/bin/exe-start-opencode.js +1 -1
  29. package/dist/bin/exe-status.js +3 -3
  30. package/dist/bin/exe-team.js +1 -1
  31. package/dist/bin/git-sweep.js +2 -2
  32. package/dist/bin/graph-backfill.js +1 -1
  33. package/dist/bin/graph-export.js +2 -2
  34. package/dist/bin/import-history.js +2 -2
  35. package/dist/bin/intercom-check.js +5 -4
  36. package/dist/bin/mcp-sessions.js +2 -2
  37. package/dist/bin/orchestration-metrics.js +1 -1
  38. package/dist/bin/scan-tasks.js +2 -2
  39. package/dist/bin/shard-migrate.js +1 -1
  40. package/dist/capacity-monitor-FZORNXTA.js +49 -0
  41. package/dist/catchup-brief-PRKHIRWW.js +151 -0
  42. package/dist/chunk-2GU3NYMB.js +813 -0
  43. package/dist/chunk-2VT7Z2E2.js +197 -0
  44. package/dist/chunk-3L6XLN4V.js +1090 -0
  45. package/dist/chunk-3T4PNG5O.js +447 -0
  46. package/dist/chunk-3W324KN7.js +13696 -0
  47. package/dist/chunk-4IATAIAF.js +89 -0
  48. package/dist/chunk-5M4F2FVD.js +204 -0
  49. package/dist/chunk-5TANMPI4.js +377 -0
  50. package/dist/chunk-67E5WIMW.js +333 -0
  51. package/dist/chunk-6NRJIARA.js +346 -0
  52. package/dist/chunk-6O22GTSE.js +1148 -0
  53. package/dist/chunk-7O5CMDP6.js +1345 -0
  54. package/dist/chunk-7P2JKEO3.js +382 -0
  55. package/dist/chunk-A4UY44T7.js +486 -0
  56. package/dist/chunk-AZHPQGSI.js +159 -0
  57. package/dist/chunk-BQAC3GCO.js +127 -0
  58. package/dist/chunk-CIWJRYIC.js +244 -0
  59. package/dist/chunk-CZO2DGGF.js +214 -0
  60. package/dist/chunk-D55SXO3N.js +3951 -0
  61. package/dist/chunk-EPDSRI6O.js +284 -0
  62. package/dist/chunk-EU34R2A3.js +1073 -0
  63. package/dist/chunk-G4KEDLSM.js +488 -0
  64. package/dist/chunk-IODP4JNE.js +551 -0
  65. package/dist/chunk-IZ6LCET7.js +58 -0
  66. package/dist/chunk-LPG3U5UW.js +731 -0
  67. package/dist/chunk-NH6TPXZV.js +13696 -0
  68. package/dist/chunk-O5TZI7OZ.js +50 -0
  69. package/dist/chunk-Q3N4KHLM.js +330 -0
  70. package/dist/chunk-QHQTMWYH.js +54 -0
  71. package/dist/chunk-QNYOPM2L.js +1921 -0
  72. package/dist/chunk-SPOA7EOD.js +81 -0
  73. package/dist/chunk-TK23WXKB.js +128 -0
  74. package/dist/chunk-TOVXER6J.js +76 -0
  75. package/dist/chunk-UIPAZYP7.js +171 -0
  76. package/dist/chunk-WXW4GF6M.js +495 -0
  77. package/dist/{chunk-YGOUKUNX.js → chunk-XLYBSXWS.js} +2 -1
  78. package/dist/core-memory-QXMQ5I7S.js +110 -0
  79. package/dist/crm-webhook-CH5W633Y.js +10 -0
  80. package/dist/cto-delegation-gate-XY3NMGTE.js +206 -0
  81. package/dist/daemon-orchestration-LS62JMTI.js +135 -0
  82. package/dist/dreaming-ZBKE2GFX.js +32 -0
  83. package/dist/exe-export-JNSQRIWI.js +73 -0
  84. package/dist/exe-import-AVGWQZLU.js +76 -0
  85. package/dist/exe-key-WR6QEHYO.js +579 -0
  86. package/dist/exe-snapshot-U6K3J6BD.js +164 -0
  87. package/dist/fast-db-init-ZHRRYI7M.js +7 -0
  88. package/dist/gateway/index.js +6 -6
  89. package/dist/git-task-sweep-64KSWRUI.js +40 -0
  90. package/dist/hooks/bug-report-worker.js +4 -4
  91. package/dist/hooks/codex-stop-task-finalizer.js +4 -4
  92. package/dist/hooks/commit-complete.js +4 -4
  93. package/dist/hooks/error-recall.js +2 -2
  94. package/dist/hooks/ingest.js +2 -2
  95. package/dist/hooks/instructions-loaded.js +1 -1
  96. package/dist/hooks/manifest.json +18 -18
  97. package/dist/hooks/notification.js +1 -1
  98. package/dist/hooks/post-compact.js +2 -2
  99. package/dist/hooks/post-tool-combined.js +2 -2
  100. package/dist/hooks/pre-compact.js +3 -3
  101. package/dist/hooks/pre-tool-use.js +6 -6
  102. package/dist/hooks/prompt-submit.js +15 -10
  103. package/dist/hooks/session-end.js +5 -5
  104. package/dist/hooks/session-start.js +5 -5
  105. package/dist/hooks/stop.js +5 -5
  106. package/dist/hooks/subagent-stop.js +2 -2
  107. package/dist/hooks/summary-worker.js +5 -5
  108. package/dist/index.js +9 -9
  109. package/dist/lib/consolidation.js +2 -2
  110. package/dist/lib/exe-daemon.js +17 -17
  111. package/dist/lib/hybrid-search.js +2 -2
  112. package/dist/lib/messaging.js +2 -2
  113. package/dist/lib/schedules.js +2 -2
  114. package/dist/lib/store.js +1 -1
  115. package/dist/lib/tasks.js +3 -3
  116. package/dist/lib/tmux-routing.js +1 -1
  117. package/dist/mcp/register-tools.js +24 -24
  118. package/dist/mcp/server.js +25 -25
  119. package/dist/mcp/tools/create-task.js +4 -4
  120. package/dist/mcp/tools/list-tasks.js +4 -4
  121. package/dist/mcp/tools/send-message.js +3 -3
  122. package/dist/mcp/tools/update-task.js +4 -4
  123. package/dist/notifications-45QSHDFA.js +45 -0
  124. package/dist/orchestrator-7XBMFK7D.js +33 -0
  125. package/dist/pipeline-router-MQKRNCTR.js +13 -0
  126. package/dist/reranker-CJW3UYE2.js +19 -0
  127. package/dist/review-polling-RL75XLAY.js +124 -0
  128. package/dist/runtime/index.js +3 -3
  129. package/dist/session-events-ZULAN4XL.js +36 -0
  130. package/dist/session-scope-V2RSOTDU.js +86 -0
  131. package/dist/skill-refinement-BSX6Q6IN.js +157 -0
  132. package/dist/task-enforcement-JRTAOYZT.js +333 -0
  133. package/dist/task-scope-GNCB2GAM.js +35 -0
  134. package/dist/tasks-crud-MZIOYF3R.js +77 -0
  135. package/dist/tasks-notify-7KNZ4ULO.js +38 -0
  136. package/dist/tasks-review-U5VEV4Y7.js +47 -0
  137. package/dist/telemetry-upload-BIB5TJA4.js +739 -0
  138. package/dist/tui/App.js +7 -7
  139. package/dist/tui-data-ZSB5DDEY.js +258 -0
  140. package/dist/worker-gate-TXLX33PX.js +21 -0
  141. package/dist/workflow-engine-3PIT3Y56.js +28 -0
  142. package/package.json +1 -1
  143. package/release-notes.json +14 -13
@@ -0,0 +1,333 @@
1
+ import {
2
+ sendIntercom,
3
+ updateTaskStatus
4
+ } from "./chunk-D55SXO3N.js";
5
+ import "./chunk-PWLX576L.js";
6
+ import "./chunk-5CHYEKMH.js";
7
+ import "./chunk-4JERP7NT.js";
8
+ import "./chunk-3XNYEGA5.js";
9
+ import "./chunk-MVW62NIZ.js";
10
+ import "./chunk-OYNKIAVW.js";
11
+ import "./chunk-CX6GL3ZJ.js";
12
+ import {
13
+ recordOrchestrationEventBestEffort
14
+ } from "./chunk-JTADPL6X.js";
15
+ import "./chunk-XJUUWHVN.js";
16
+ import "./chunk-NGP6LSV2.js";
17
+ import "./chunk-A3T5KDD3.js";
18
+ import "./chunk-CVYC6DUW.js";
19
+ import "./chunk-OPU3NYOO.js";
20
+ import "./chunk-GJV3WDWM.js";
21
+ import "./chunk-MP2AFCGL.js";
22
+ import "./chunk-25NFDJ3N.js";
23
+ import "./chunk-HYZV25LY.js";
24
+ import "./chunk-QQZMP6QL.js";
25
+ import "./chunk-2I23RPSI.js";
26
+ import "./chunk-ACBEUQR2.js";
27
+ import "./chunk-FXU7JOXK.js";
28
+ import "./chunk-MOZ2YQ54.js";
29
+ import "./chunk-VXIMSRTO.js";
30
+ import "./chunk-LYH5HE24.js";
31
+ import "./chunk-MLKGABMK.js";
32
+
33
+ // src/lib/task-enforcement.ts
34
+ import { appendFile } from "fs/promises";
35
+ import path from "path";
36
+ var TASK_ENFORCEMENT_INTERVAL_MS = 6e4;
37
+ var TASK_ENFORCEMENT_DEBOUNCE_MS = 18e4;
38
+ var MANAGER_GRACE_PERIOD_MS = 6e5;
39
+ var IDLE_PATTERNS = [
40
+ "Standing by",
41
+ "All tasks complete",
42
+ "No tasks found",
43
+ "Anything else?",
44
+ "What do you need?"
45
+ ];
46
+ var NUDGE_ECHO_PATTERNS = [
47
+ "You have pending notifications",
48
+ "You have open tasks. Run list_tasks",
49
+ "You have more open tasks to dispatch",
50
+ "Run list_tasks to check for assigned work",
51
+ "Run list_tasks to find them"
52
+ ];
53
+ var MANAGER_ROLES = ["COO", "CTO"];
54
+ var AUDIT_LOG_PATH = path.join(
55
+ process.env.HOME ?? process.env.USERPROFILE ?? "/tmp",
56
+ ".exe-os",
57
+ "enforcement-audit.jsonl"
58
+ );
59
+ function writeAuditEntry(entry) {
60
+ const line = JSON.stringify(entry) + "\n";
61
+ appendFile(AUDIT_LOG_PATH, line).catch(() => {
62
+ });
63
+ }
64
+ function decideManagerAction(counts, isIdle, withinGracePeriod, nudgeEcho) {
65
+ if (counts.openTasks === 0) return "skip";
66
+ if (withinGracePeriod) return "grace_period";
67
+ if (!isIdle) return "active";
68
+ if (nudgeEcho) return "active";
69
+ if ((counts.inProgressTasks ?? 0) > 0) return "active";
70
+ if (counts.activeSubtasks === 0) return "nudge";
71
+ return "soft_nudge";
72
+ }
73
+ function decideWorkerAction(taskCount, isIdle, nudgeEcho) {
74
+ if (taskCount === 0) return "skip";
75
+ if (nudgeEcho) return "idle";
76
+ return isIdle ? "nudge" : "idle";
77
+ }
78
+ function isIdlePane(paneText) {
79
+ return IDLE_PATTERNS.some((p) => paneText.includes(p));
80
+ }
81
+ function isNudgeEcho(paneText) {
82
+ return NUDGE_ECHO_PATTERNS.some((p) => paneText.includes(p));
83
+ }
84
+ function sendNudge(transport, session, runtime, action) {
85
+ const message = action === "nudge" ? "You have open tasks. Run list_tasks to find them." : "You have more open tasks to dispatch. Run list_tasks.";
86
+ if (transport.sendKeysLiteral) {
87
+ transport.sendKeysLiteral(session, message);
88
+ } else {
89
+ transport.sendKeys(session, message);
90
+ }
91
+ process.stderr.write(
92
+ `[enforcement-audit] SENT nudge to ${session} (${runtime}, ${action})
93
+ `
94
+ );
95
+ }
96
+ function _resetNudgeState() {
97
+ }
98
+ async function runTaskEnforcementTick(deps) {
99
+ const { transport, employees, client, scopeFilter } = deps;
100
+ const now = deps.now ?? Date.now();
101
+ const tickStartedAt = Date.now();
102
+ const sessions = transport.listSessions();
103
+ let processedAnyEmployee = false;
104
+ let processedSessions = 0;
105
+ let nudgesSent = 0;
106
+ recordOrchestrationEventBestEffort({
107
+ eventType: "daemon.tick.started",
108
+ source: "task-enforcement.runTaskEnforcementTick",
109
+ payload: { sessionCount: sessions.length }
110
+ });
111
+ for (const session of sessions) {
112
+ if (!session.includes("-")) continue;
113
+ const agentName = session.split("-")[0]?.replace(/\d+$/, "");
114
+ if (!agentName) continue;
115
+ if ("isAlive" in transport && typeof transport.isAlive === "function") {
116
+ if (!transport.isAlive(session)) continue;
117
+ }
118
+ const employee = employees.find((e) => e.name === agentName);
119
+ if (!employee) continue;
120
+ processedAnyEmployee = true;
121
+ processedSessions++;
122
+ let effectiveScope = scopeFilter;
123
+ const dashIndex = session.indexOf("-");
124
+ if (dashIndex > 0) {
125
+ const coordinatorSession = session.slice(dashIndex + 1);
126
+ if (coordinatorSession) {
127
+ effectiveScope = {
128
+ sql: " AND (session_scope IS NULL OR session_scope = ?)",
129
+ args: [coordinatorSession]
130
+ };
131
+ }
132
+ }
133
+ const isManager = MANAGER_ROLES.includes(employee.role);
134
+ try {
135
+ let action = "skip";
136
+ let reason = "";
137
+ let openTasks = 0;
138
+ let activeSubtasks = 0;
139
+ let paneIdle;
140
+ if (isManager) {
141
+ const openResult = await client.execute({
142
+ sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status = 'open'${effectiveScope.sql}`,
143
+ args: [agentName, ...effectiveScope.args]
144
+ });
145
+ openTasks = Number(openResult.rows[0]?.cnt ?? 0);
146
+ if (openTasks > 0) {
147
+ const subtaskResult = await client.execute({
148
+ sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_by = ? AND status = 'in_progress'${scopeFilter.sql}`,
149
+ args: [agentName, ...scopeFilter.args]
150
+ });
151
+ activeSubtasks = Number(subtaskResult.rows[0]?.cnt ?? 0);
152
+ }
153
+ let withinGracePeriod = false;
154
+ let graceRemaining = 0;
155
+ if (openTasks > 0) {
156
+ const newestResult = await client.execute({
157
+ sql: `SELECT created_at FROM tasks WHERE assigned_to = ? AND status = 'open'${scopeFilter.sql} ORDER BY created_at DESC LIMIT 1`,
158
+ args: [agentName, ...scopeFilter.args]
159
+ });
160
+ const newestCreatedAt = newestResult.rows[0]?.created_at;
161
+ if (newestCreatedAt) {
162
+ const taskAge = now - new Date(newestCreatedAt).getTime();
163
+ if (taskAge < MANAGER_GRACE_PERIOD_MS) {
164
+ withinGracePeriod = true;
165
+ graceRemaining = Math.round((MANAGER_GRACE_PERIOD_MS - taskAge) / 1e3);
166
+ }
167
+ }
168
+ }
169
+ let inProgressTasks = 0;
170
+ if (openTasks > 0) {
171
+ const ipResult = await client.execute({
172
+ sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status = 'in_progress'${effectiveScope.sql}`,
173
+ args: [agentName, ...effectiveScope.args]
174
+ });
175
+ inProgressTasks = Number(ipResult.rows[0]?.cnt ?? 0);
176
+ }
177
+ const pane = deps.paneCache?.get(session) ?? (deps.capturePaneAsync ? await deps.capturePaneAsync(session, 20) : transport.capturePane(session, 20));
178
+ paneIdle = isIdlePane(pane);
179
+ const nudgeEcho = isNudgeEcho(pane);
180
+ action = decideManagerAction({ openTasks, activeSubtasks, inProgressTasks }, paneIdle, withinGracePeriod, nudgeEcho);
181
+ if (action === "skip") reason = "no open tasks";
182
+ else if (action === "grace_period") reason = `task assigned <10min ago (${graceRemaining}s remaining)`;
183
+ else if (action === "active") reason = nudgeEcho ? "pane shows previous nudge (anti-loop)" : inProgressTasks > 0 ? `${inProgressTasks} tasks in_progress` : "pane shows active work";
184
+ else if (action === "nudge") reason = `${openTasks} open tasks, 0 delegated, pane idle`;
185
+ else if (action === "soft_nudge") reason = `${openTasks} open tasks, ${activeSubtasks} delegated, pane idle`;
186
+ writeAuditEntry({
187
+ timestamp: new Date(now).toISOString(),
188
+ session,
189
+ agent: agentName,
190
+ role: "manager",
191
+ action,
192
+ reason,
193
+ openTasks,
194
+ activeSubtasks,
195
+ paneIdle,
196
+ graceRemaining: withinGracePeriod ? graceRemaining : void 0
197
+ });
198
+ process.stderr.write(
199
+ `[exed] Task enforcement: ${agentName} (manager) ${openTasks} open, ${activeSubtasks} delegated, pane=${paneIdle ? "idle" : "active"}. Action: ${action} (${reason})
200
+ `
201
+ );
202
+ } else {
203
+ const taskResult = await client.execute({
204
+ sql: `SELECT COUNT(*) as cnt FROM tasks WHERE assigned_to = ? AND status IN ('open', 'in_progress')${effectiveScope.sql}`,
205
+ args: [agentName, ...effectiveScope.args]
206
+ });
207
+ const taskCount = Number(taskResult.rows[0]?.cnt ?? 0);
208
+ openTasks = taskCount;
209
+ if (taskCount > 0) {
210
+ const pane = deps.paneCache?.get(session) ?? (deps.capturePaneAsync ? await deps.capturePaneAsync(session, 20) : transport.capturePane(session, 20));
211
+ paneIdle = isIdlePane(pane);
212
+ const workerNudgeEcho = isNudgeEcho(pane);
213
+ action = decideWorkerAction(taskCount, paneIdle, workerNudgeEcho);
214
+ }
215
+ if (action === "skip") reason = "no tasks";
216
+ else if (action === "idle") reason = `${taskCount} tasks but pane active`;
217
+ else if (action === "nudge") reason = `${taskCount} tasks, pane idle`;
218
+ writeAuditEntry({
219
+ timestamp: new Date(now).toISOString(),
220
+ session,
221
+ agent: agentName,
222
+ role: "worker",
223
+ action,
224
+ reason,
225
+ openTasks: taskCount,
226
+ paneIdle
227
+ });
228
+ process.stderr.write(
229
+ `[exed] Task enforcement: ${agentName} (worker) ${taskCount} tasks, pane=${paneIdle ?? "n/a"}. Action: ${action} (${reason})
230
+ `
231
+ );
232
+ }
233
+ if (action === "skip" || action === "idle" || action === "grace_period" || action === "active") continue;
234
+ nudgesSent++;
235
+ sendIntercom(session);
236
+ } catch {
237
+ }
238
+ }
239
+ if (processedAnyEmployee) {
240
+ try {
241
+ const staleBlocked = await client.execute({
242
+ sql: `SELECT t.id, t.title, b.status as blocker_status
243
+ FROM tasks t
244
+ JOIN tasks b ON t.blocked_by = b.id
245
+ WHERE t.status = 'blocked'
246
+ AND b.status IN ('done', 'cancelled', 'closed')${scopeFilter.sql}`,
247
+ args: [...scopeFilter.args]
248
+ });
249
+ const nowIso = new Date(now).toISOString();
250
+ for (const row of staleBlocked.rows) {
251
+ try {
252
+ await updateTaskStatus({ taskId: String(row.id), status: "open" });
253
+ } catch {
254
+ await client.execute({
255
+ sql: `UPDATE tasks SET status = 'open', updated_at = ? WHERE id = ?`,
256
+ args: [nowIso, String(row.id)]
257
+ });
258
+ }
259
+ await client.execute({
260
+ sql: `UPDATE tasks SET blocked_by = NULL WHERE id = ?`,
261
+ args: [String(row.id)]
262
+ });
263
+ process.stderr.write(
264
+ `[exed] Auto-unblocked "${String(row.title)}" \u2014 blocker already ${String(row.blocker_status)}
265
+ `
266
+ );
267
+ }
268
+ } catch {
269
+ }
270
+ }
271
+ if (processedAnyEmployee && deps.reviewerSpawn) {
272
+ try {
273
+ const reviewerRows = await client.execute({
274
+ sql: `SELECT DISTINCT reviewer, session_scope FROM tasks
275
+ WHERE status = 'needs_review'
276
+ AND reviewer IS NOT NULL
277
+ AND reviewer != ''${scopeFilter.sql}`,
278
+ args: [...scopeFilter.args]
279
+ });
280
+ const liveSessionSet = new Set(sessions);
281
+ for (const row of reviewerRows.rows) {
282
+ const reviewerName = String(row.reviewer ?? "");
283
+ const sessionScope = row.session_scope ? String(row.session_scope) : null;
284
+ if (!reviewerName || !sessionScope) continue;
285
+ const reviewerSession = `${reviewerName}-${sessionScope}`;
286
+ if (liveSessionSet.has(reviewerSession)) continue;
287
+ try {
288
+ const result = deps.reviewerSpawn(reviewerName, sessionScope);
289
+ if (!result) continue;
290
+ if (result.status === "spawned") {
291
+ process.stderr.write(
292
+ `[exed] Reviewer auto-spawn: spawned ${reviewerName} in ${sessionScope} (has needs_review tasks)
293
+ `
294
+ );
295
+ } else if (result.status === "failed") {
296
+ process.stderr.write(
297
+ `[exed] Reviewer auto-spawn: failed to spawn ${reviewerName} in ${sessionScope}: ${result.error ?? "unknown"}
298
+ `
299
+ );
300
+ }
301
+ } catch (spawnErr) {
302
+ process.stderr.write(
303
+ `[exed] Reviewer auto-spawn error for ${reviewerName}: ${spawnErr instanceof Error ? spawnErr.message : String(spawnErr)}
304
+ `
305
+ );
306
+ }
307
+ }
308
+ } catch {
309
+ }
310
+ }
311
+ recordOrchestrationEventBestEffort({
312
+ eventType: "daemon.tick.completed",
313
+ source: "task-enforcement.runTaskEnforcementTick",
314
+ durationMs: Date.now() - tickStartedAt,
315
+ result: processedAnyEmployee ? "processed" : "no_employee_sessions",
316
+ payload: { sessionCount: sessions.length, processedSessions, nudgesSent }
317
+ });
318
+ }
319
+ export {
320
+ IDLE_PATTERNS,
321
+ MANAGER_GRACE_PERIOD_MS,
322
+ MANAGER_ROLES,
323
+ NUDGE_ECHO_PATTERNS,
324
+ TASK_ENFORCEMENT_DEBOUNCE_MS,
325
+ TASK_ENFORCEMENT_INTERVAL_MS,
326
+ _resetNudgeState,
327
+ decideManagerAction,
328
+ decideWorkerAction,
329
+ isIdlePane,
330
+ isNudgeEcho,
331
+ runTaskEnforcementTick,
332
+ sendNudge
333
+ };
@@ -0,0 +1,35 @@
1
+ import {
2
+ getCurrentSessionScope,
3
+ sessionScopeFilter,
4
+ strictSessionScopeFilter
5
+ } from "./chunk-D55SXO3N.js";
6
+ import "./chunk-PWLX576L.js";
7
+ import "./chunk-5CHYEKMH.js";
8
+ import "./chunk-4JERP7NT.js";
9
+ import "./chunk-3XNYEGA5.js";
10
+ import "./chunk-MVW62NIZ.js";
11
+ import "./chunk-OYNKIAVW.js";
12
+ import "./chunk-CX6GL3ZJ.js";
13
+ import "./chunk-JTADPL6X.js";
14
+ import "./chunk-XJUUWHVN.js";
15
+ import "./chunk-NGP6LSV2.js";
16
+ import "./chunk-A3T5KDD3.js";
17
+ import "./chunk-CVYC6DUW.js";
18
+ import "./chunk-OPU3NYOO.js";
19
+ import "./chunk-GJV3WDWM.js";
20
+ import "./chunk-MP2AFCGL.js";
21
+ import "./chunk-25NFDJ3N.js";
22
+ import "./chunk-HYZV25LY.js";
23
+ import "./chunk-QQZMP6QL.js";
24
+ import "./chunk-2I23RPSI.js";
25
+ import "./chunk-ACBEUQR2.js";
26
+ import "./chunk-FXU7JOXK.js";
27
+ import "./chunk-MOZ2YQ54.js";
28
+ import "./chunk-VXIMSRTO.js";
29
+ import "./chunk-LYH5HE24.js";
30
+ import "./chunk-MLKGABMK.js";
31
+ export {
32
+ getCurrentSessionScope,
33
+ sessionScopeFilter,
34
+ strictSessionScopeFilter
35
+ };
@@ -0,0 +1,77 @@
1
+ import {
2
+ TASK_ALREADY_CLAIMED_PREFIX,
3
+ buildTaskCompletionReport,
4
+ checkAndFireBarriers,
5
+ checkStaleCompletion,
6
+ checkTaskFileConsistency,
7
+ cleanOrphanedTaskFiles,
8
+ createTaskCore,
9
+ createTaskGroup,
10
+ deleteTaskCore,
11
+ ensureArchitectureDoc,
12
+ ensureGitignoreExe,
13
+ extractParentFromContext,
14
+ getAggregatedGroupResults,
15
+ getGroupResults,
16
+ getGroupStatus,
17
+ isStructuredTaskCompletionReport,
18
+ isTmuxSessionAlive,
19
+ listTasks,
20
+ queryTaskRows,
21
+ readLatestCheckpoint,
22
+ resolveTask,
23
+ slugify,
24
+ updateTaskStatus,
25
+ writeCheckpoint
26
+ } from "./chunk-D55SXO3N.js";
27
+ import "./chunk-PWLX576L.js";
28
+ import "./chunk-5CHYEKMH.js";
29
+ import "./chunk-4JERP7NT.js";
30
+ import "./chunk-3XNYEGA5.js";
31
+ import "./chunk-MVW62NIZ.js";
32
+ import "./chunk-OYNKIAVW.js";
33
+ import "./chunk-CX6GL3ZJ.js";
34
+ import "./chunk-JTADPL6X.js";
35
+ import "./chunk-XJUUWHVN.js";
36
+ import "./chunk-NGP6LSV2.js";
37
+ import "./chunk-A3T5KDD3.js";
38
+ import "./chunk-CVYC6DUW.js";
39
+ import "./chunk-OPU3NYOO.js";
40
+ import "./chunk-GJV3WDWM.js";
41
+ import "./chunk-MP2AFCGL.js";
42
+ import "./chunk-25NFDJ3N.js";
43
+ import "./chunk-HYZV25LY.js";
44
+ import "./chunk-QQZMP6QL.js";
45
+ import "./chunk-2I23RPSI.js";
46
+ import "./chunk-ACBEUQR2.js";
47
+ import "./chunk-FXU7JOXK.js";
48
+ import "./chunk-MOZ2YQ54.js";
49
+ import "./chunk-VXIMSRTO.js";
50
+ import "./chunk-LYH5HE24.js";
51
+ import "./chunk-MLKGABMK.js";
52
+ export {
53
+ TASK_ALREADY_CLAIMED_PREFIX,
54
+ buildTaskCompletionReport,
55
+ checkAndFireBarriers,
56
+ checkStaleCompletion,
57
+ checkTaskFileConsistency,
58
+ cleanOrphanedTaskFiles,
59
+ createTaskCore,
60
+ createTaskGroup,
61
+ deleteTaskCore,
62
+ ensureArchitectureDoc,
63
+ ensureGitignoreExe,
64
+ extractParentFromContext,
65
+ getAggregatedGroupResults,
66
+ getGroupResults,
67
+ getGroupStatus,
68
+ isStructuredTaskCompletionReport,
69
+ isTmuxSessionAlive,
70
+ listTasks,
71
+ queryTaskRows,
72
+ readLatestCheckpoint,
73
+ resolveTask,
74
+ slugify,
75
+ updateTaskStatus,
76
+ writeCheckpoint
77
+ };
@@ -0,0 +1,38 @@
1
+ import {
2
+ dispatchTaskToEmployee,
3
+ markTaskNotificationsRead,
4
+ notifyTaskDone,
5
+ verifyDispatch
6
+ } from "./chunk-CIWJRYIC.js";
7
+ import "./chunk-D55SXO3N.js";
8
+ import "./chunk-PWLX576L.js";
9
+ import "./chunk-5CHYEKMH.js";
10
+ import "./chunk-4JERP7NT.js";
11
+ import "./chunk-3XNYEGA5.js";
12
+ import "./chunk-MVW62NIZ.js";
13
+ import "./chunk-OYNKIAVW.js";
14
+ import "./chunk-CX6GL3ZJ.js";
15
+ import "./chunk-JTADPL6X.js";
16
+ import "./chunk-XJUUWHVN.js";
17
+ import "./chunk-NGP6LSV2.js";
18
+ import "./chunk-A3T5KDD3.js";
19
+ import "./chunk-CVYC6DUW.js";
20
+ import "./chunk-OPU3NYOO.js";
21
+ import "./chunk-GJV3WDWM.js";
22
+ import "./chunk-MP2AFCGL.js";
23
+ import "./chunk-25NFDJ3N.js";
24
+ import "./chunk-HYZV25LY.js";
25
+ import "./chunk-QQZMP6QL.js";
26
+ import "./chunk-2I23RPSI.js";
27
+ import "./chunk-ACBEUQR2.js";
28
+ import "./chunk-FXU7JOXK.js";
29
+ import "./chunk-MOZ2YQ54.js";
30
+ import "./chunk-VXIMSRTO.js";
31
+ import "./chunk-LYH5HE24.js";
32
+ import "./chunk-MLKGABMK.js";
33
+ export {
34
+ dispatchTaskToEmployee,
35
+ markTaskNotificationsRead,
36
+ notifyTaskDone,
37
+ verifyDispatch
38
+ };
@@ -0,0 +1,47 @@
1
+ import {
2
+ cleanupOrphanedReviews,
3
+ cleanupReviewFile,
4
+ countNewPendingReviewsSince,
5
+ countPendingReviews,
6
+ createReviewForCompletedTask,
7
+ formatAge,
8
+ getReviewChecklist,
9
+ isStale,
10
+ listPendingReviews
11
+ } from "./chunk-D55SXO3N.js";
12
+ import "./chunk-PWLX576L.js";
13
+ import "./chunk-5CHYEKMH.js";
14
+ import "./chunk-4JERP7NT.js";
15
+ import "./chunk-3XNYEGA5.js";
16
+ import "./chunk-MVW62NIZ.js";
17
+ import "./chunk-OYNKIAVW.js";
18
+ import "./chunk-CX6GL3ZJ.js";
19
+ import "./chunk-JTADPL6X.js";
20
+ import "./chunk-XJUUWHVN.js";
21
+ import "./chunk-NGP6LSV2.js";
22
+ import "./chunk-A3T5KDD3.js";
23
+ import "./chunk-CVYC6DUW.js";
24
+ import "./chunk-OPU3NYOO.js";
25
+ import "./chunk-GJV3WDWM.js";
26
+ import "./chunk-MP2AFCGL.js";
27
+ import "./chunk-25NFDJ3N.js";
28
+ import "./chunk-HYZV25LY.js";
29
+ import "./chunk-QQZMP6QL.js";
30
+ import "./chunk-2I23RPSI.js";
31
+ import "./chunk-ACBEUQR2.js";
32
+ import "./chunk-FXU7JOXK.js";
33
+ import "./chunk-MOZ2YQ54.js";
34
+ import "./chunk-VXIMSRTO.js";
35
+ import "./chunk-LYH5HE24.js";
36
+ import "./chunk-MLKGABMK.js";
37
+ export {
38
+ cleanupOrphanedReviews,
39
+ cleanupReviewFile,
40
+ countNewPendingReviewsSince,
41
+ countPendingReviews,
42
+ createReviewForCompletedTask,
43
+ formatAge,
44
+ getReviewChecklist,
45
+ isStale,
46
+ listPendingReviews
47
+ };