@wandoupeas/coding-forge 0.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +21 -0
- package/README.md +347 -0
- package/dist/agent/adapters/base.d.ts +9 -0
- package/dist/agent/adapters/base.d.ts.map +1 -0
- package/dist/agent/adapters/base.js +2 -0
- package/dist/agent/adapters/base.js.map +1 -0
- package/dist/agent/adapters/claude-code.d.ts +4 -0
- package/dist/agent/adapters/claude-code.d.ts.map +1 -0
- package/dist/agent/adapters/claude-code.js +25 -0
- package/dist/agent/adapters/claude-code.js.map +1 -0
- package/dist/agent/adapters/codex.d.ts +4 -0
- package/dist/agent/adapters/codex.d.ts.map +1 -0
- package/dist/agent/adapters/codex.js +27 -0
- package/dist/agent/adapters/codex.js.map +1 -0
- package/dist/agent/adapters/command-bridge.d.ts +67 -0
- package/dist/agent/adapters/command-bridge.d.ts.map +1 -0
- package/dist/agent/adapters/command-bridge.js +266 -0
- package/dist/agent/adapters/command-bridge.js.map +1 -0
- package/dist/agent/adapters/index.d.ts +7 -0
- package/dist/agent/adapters/index.d.ts.map +1 -0
- package/dist/agent/adapters/index.js +25 -0
- package/dist/agent/adapters/index.js.map +1 -0
- package/dist/agent/adapters/stub.d.ts +3 -0
- package/dist/agent/adapters/stub.d.ts.map +1 -0
- package/dist/agent/adapters/stub.js +66 -0
- package/dist/agent/adapters/stub.js.map +1 -0
- package/dist/agent/context.d.ts +36 -0
- package/dist/agent/context.d.ts.map +1 -0
- package/dist/agent/context.js +16 -0
- package/dist/agent/context.js.map +1 -0
- package/dist/agent/handlers/index.d.ts +6 -0
- package/dist/agent/handlers/index.d.ts.map +1 -0
- package/dist/agent/handlers/index.js +61 -0
- package/dist/agent/handlers/index.js.map +1 -0
- package/dist/agent/index.d.ts +18 -0
- package/dist/agent/index.d.ts.map +1 -0
- package/dist/agent/index.js +37 -0
- package/dist/agent/index.js.map +1 -0
- package/dist/agent/types.d.ts +21 -0
- package/dist/agent/types.d.ts.map +1 -0
- package/dist/agent/types.js +5 -0
- package/dist/agent/types.js.map +1 -0
- package/dist/cli/agent-briefing.d.ts +24 -0
- package/dist/cli/agent-briefing.d.ts.map +1 -0
- package/dist/cli/agent-briefing.js +133 -0
- package/dist/cli/agent-briefing.js.map +1 -0
- package/dist/cli/commands/checkpoint.d.ts +12 -0
- package/dist/cli/commands/checkpoint.d.ts.map +1 -0
- package/dist/cli/commands/checkpoint.js +86 -0
- package/dist/cli/commands/checkpoint.js.map +1 -0
- package/dist/cli/commands/dashboard.d.ts +14 -0
- package/dist/cli/commands/dashboard.d.ts.map +1 -0
- package/dist/cli/commands/dashboard.js +192 -0
- package/dist/cli/commands/dashboard.js.map +1 -0
- package/dist/cli/commands/doctor.d.ts +27 -0
- package/dist/cli/commands/doctor.d.ts.map +1 -0
- package/dist/cli/commands/doctor.js +425 -0
- package/dist/cli/commands/doctor.js.map +1 -0
- package/dist/cli/commands/init.d.ts +19 -0
- package/dist/cli/commands/init.d.ts.map +1 -0
- package/dist/cli/commands/init.js +303 -0
- package/dist/cli/commands/init.js.map +1 -0
- package/dist/cli/commands/knowledge.d.ts +6 -0
- package/dist/cli/commands/knowledge.d.ts.map +1 -0
- package/dist/cli/commands/knowledge.js +408 -0
- package/dist/cli/commands/knowledge.js.map +1 -0
- package/dist/cli/commands/logs.d.ts +50 -0
- package/dist/cli/commands/logs.d.ts.map +1 -0
- package/dist/cli/commands/logs.js +248 -0
- package/dist/cli/commands/logs.js.map +1 -0
- package/dist/cli/commands/mailbox.d.ts +12 -0
- package/dist/cli/commands/mailbox.d.ts.map +1 -0
- package/dist/cli/commands/mailbox.js +131 -0
- package/dist/cli/commands/mailbox.js.map +1 -0
- package/dist/cli/commands/onboard.d.ts +43 -0
- package/dist/cli/commands/onboard.d.ts.map +1 -0
- package/dist/cli/commands/onboard.js +313 -0
- package/dist/cli/commands/onboard.js.map +1 -0
- package/dist/cli/commands/plan.d.ts +16 -0
- package/dist/cli/commands/plan.d.ts.map +1 -0
- package/dist/cli/commands/plan.js +211 -0
- package/dist/cli/commands/plan.js.map +1 -0
- package/dist/cli/commands/resume.d.ts +102 -0
- package/dist/cli/commands/resume.d.ts.map +1 -0
- package/dist/cli/commands/resume.js +256 -0
- package/dist/cli/commands/resume.js.map +1 -0
- package/dist/cli/commands/review.d.ts +13 -0
- package/dist/cli/commands/review.d.ts.map +1 -0
- package/dist/cli/commands/review.js +91 -0
- package/dist/cli/commands/review.js.map +1 -0
- package/dist/cli/commands/run.d.ts +19 -0
- package/dist/cli/commands/run.d.ts.map +1 -0
- package/dist/cli/commands/run.js +161 -0
- package/dist/cli/commands/run.js.map +1 -0
- package/dist/cli/commands/superpowers.d.ts +21 -0
- package/dist/cli/commands/superpowers.d.ts.map +1 -0
- package/dist/cli/commands/superpowers.js +135 -0
- package/dist/cli/commands/superpowers.js.map +1 -0
- package/dist/cli/commands/ui.d.ts +14 -0
- package/dist/cli/commands/ui.d.ts.map +1 -0
- package/dist/cli/commands/ui.js +41 -0
- package/dist/cli/commands/ui.js.map +1 -0
- package/dist/cli/commands/verify.d.ts +11 -0
- package/dist/cli/commands/verify.d.ts.map +1 -0
- package/dist/cli/commands/verify.js +46 -0
- package/dist/cli/commands/verify.js.map +1 -0
- package/dist/cli/index.d.ts +9 -0
- package/dist/cli/index.d.ts.map +1 -0
- package/dist/cli/index.js +69 -0
- package/dist/cli/index.js.map +1 -0
- package/dist/cli/utils/logger.d.ts +18 -0
- package/dist/cli/utils/logger.d.ts.map +1 -0
- package/dist/cli/utils/logger.js +57 -0
- package/dist/cli/utils/logger.js.map +1 -0
- package/dist/core/checkpoint.d.ts +54 -0
- package/dist/core/checkpoint.d.ts.map +1 -0
- package/dist/core/checkpoint.js +227 -0
- package/dist/core/checkpoint.js.map +1 -0
- package/dist/core/context.d.ts +36 -0
- package/dist/core/context.d.ts.map +1 -0
- package/dist/core/context.js +71 -0
- package/dist/core/context.js.map +1 -0
- package/dist/core/deliverable.d.ts +34 -0
- package/dist/core/deliverable.d.ts.map +1 -0
- package/dist/core/deliverable.js +125 -0
- package/dist/core/deliverable.js.map +1 -0
- package/dist/core/harness-hints.d.ts +43 -0
- package/dist/core/harness-hints.d.ts.map +1 -0
- package/dist/core/harness-hints.js +162 -0
- package/dist/core/harness-hints.js.map +1 -0
- package/dist/core/logger.d.ts +104 -0
- package/dist/core/logger.d.ts.map +1 -0
- package/dist/core/logger.js +199 -0
- package/dist/core/logger.js.map +1 -0
- package/dist/core/mailbox.d.ts +69 -0
- package/dist/core/mailbox.d.ts.map +1 -0
- package/dist/core/mailbox.js +225 -0
- package/dist/core/mailbox.js.map +1 -0
- package/dist/core/planning.d.ts +110 -0
- package/dist/core/planning.d.ts.map +1 -0
- package/dist/core/planning.js +832 -0
- package/dist/core/planning.js.map +1 -0
- package/dist/core/runtime.d.ts +22 -0
- package/dist/core/runtime.d.ts.map +1 -0
- package/dist/core/runtime.js +364 -0
- package/dist/core/runtime.js.map +1 -0
- package/dist/core/session.d.ts +62 -0
- package/dist/core/session.d.ts.map +1 -0
- package/dist/core/session.js +266 -0
- package/dist/core/session.js.map +1 -0
- package/dist/core/superpowers-registry.d.ts +20 -0
- package/dist/core/superpowers-registry.d.ts.map +1 -0
- package/dist/core/superpowers-registry.js +180 -0
- package/dist/core/superpowers-registry.js.map +1 -0
- package/dist/core/superpowers-runs.d.ts +19 -0
- package/dist/core/superpowers-runs.d.ts.map +1 -0
- package/dist/core/superpowers-runs.js +231 -0
- package/dist/core/superpowers-runs.js.map +1 -0
- package/dist/core/task.d.ts +43 -0
- package/dist/core/task.d.ts.map +1 -0
- package/dist/core/task.js +232 -0
- package/dist/core/task.js.map +1 -0
- package/dist/core/threads.d.ts +23 -0
- package/dist/core/threads.d.ts.map +1 -0
- package/dist/core/threads.js +92 -0
- package/dist/core/threads.js.map +1 -0
- package/dist/core/worker.d.ts +48 -0
- package/dist/core/worker.d.ts.map +1 -0
- package/dist/core/worker.js +181 -0
- package/dist/core/worker.js.map +1 -0
- package/dist/core/workflow-context.d.ts +16 -0
- package/dist/core/workflow-context.d.ts.map +1 -0
- package/dist/core/workflow-context.js +102 -0
- package/dist/core/workflow-context.js.map +1 -0
- package/dist/core/workspace.d.ts +13 -0
- package/dist/core/workspace.d.ts.map +1 -0
- package/dist/core/workspace.js +208 -0
- package/dist/core/workspace.js.map +1 -0
- package/dist/testing/index.d.ts +21 -0
- package/dist/testing/index.d.ts.map +1 -0
- package/dist/testing/index.js +55 -0
- package/dist/testing/index.js.map +1 -0
- package/dist/types/index.d.ts +298 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +5 -0
- package/dist/types/index.js.map +1 -0
- package/dist/ui/assets/index-DLwnhrrc.css +1 -0
- package/dist/ui/assets/index-cDUGEuwi.js +234 -0
- package/dist/ui/http/handlers/project-artifacts.d.ts +3 -0
- package/dist/ui/http/handlers/project-artifacts.d.ts.map +1 -0
- package/dist/ui/http/handlers/project-artifacts.js +20 -0
- package/dist/ui/http/handlers/project-artifacts.js.map +1 -0
- package/dist/ui/http/handlers/project-overview.d.ts +3 -0
- package/dist/ui/http/handlers/project-overview.d.ts.map +1 -0
- package/dist/ui/http/handlers/project-overview.js +20 -0
- package/dist/ui/http/handlers/project-overview.js.map +1 -0
- package/dist/ui/http/handlers/project-recovery.d.ts +3 -0
- package/dist/ui/http/handlers/project-recovery.d.ts.map +1 -0
- package/dist/ui/http/handlers/project-recovery.js +20 -0
- package/dist/ui/http/handlers/project-recovery.js.map +1 -0
- package/dist/ui/http/handlers/project-runtime.d.ts +3 -0
- package/dist/ui/http/handlers/project-runtime.d.ts.map +1 -0
- package/dist/ui/http/handlers/project-runtime.js +20 -0
- package/dist/ui/http/handlers/project-runtime.js.map +1 -0
- package/dist/ui/http/handlers/project-tasks.d.ts +3 -0
- package/dist/ui/http/handlers/project-tasks.d.ts.map +1 -0
- package/dist/ui/http/handlers/project-tasks.js +20 -0
- package/dist/ui/http/handlers/project-tasks.js.map +1 -0
- package/dist/ui/http/handlers/projects.d.ts +23 -0
- package/dist/ui/http/handlers/projects.d.ts.map +1 -0
- package/dist/ui/http/handlers/projects.js +29 -0
- package/dist/ui/http/handlers/projects.js.map +1 -0
- package/dist/ui/http/router.d.ts +5 -0
- package/dist/ui/http/router.d.ts.map +1 -0
- package/dist/ui/http/router.js +81 -0
- package/dist/ui/http/router.js.map +1 -0
- package/dist/ui/http/server.d.ts +29 -0
- package/dist/ui/http/server.d.ts.map +1 -0
- package/dist/ui/http/server.js +143 -0
- package/dist/ui/http/server.js.map +1 -0
- package/dist/ui/index.html +13 -0
- package/dist/ui/project-registry.d.ts +9 -0
- package/dist/ui/project-registry.d.ts.map +1 -0
- package/dist/ui/project-registry.js +19 -0
- package/dist/ui/project-registry.js.map +1 -0
- package/dist/ui/project-scanner.d.ts +10 -0
- package/dist/ui/project-scanner.d.ts.map +1 -0
- package/dist/ui/project-scanner.js +135 -0
- package/dist/ui/project-scanner.js.map +1 -0
- package/dist/ui/read-models/artifacts.d.ts +58 -0
- package/dist/ui/read-models/artifacts.d.ts.map +1 -0
- package/dist/ui/read-models/artifacts.js +97 -0
- package/dist/ui/read-models/artifacts.js.map +1 -0
- package/dist/ui/read-models/overview.d.ts +38 -0
- package/dist/ui/read-models/overview.d.ts.map +1 -0
- package/dist/ui/read-models/overview.js +55 -0
- package/dist/ui/read-models/overview.js.map +1 -0
- package/dist/ui/read-models/recovery.d.ts +18 -0
- package/dist/ui/read-models/recovery.d.ts.map +1 -0
- package/dist/ui/read-models/recovery.js +26 -0
- package/dist/ui/read-models/recovery.js.map +1 -0
- package/dist/ui/read-models/runtime.d.ts +53 -0
- package/dist/ui/read-models/runtime.d.ts.map +1 -0
- package/dist/ui/read-models/runtime.js +86 -0
- package/dist/ui/read-models/runtime.js.map +1 -0
- package/dist/ui/read-models/tasks.d.ts +34 -0
- package/dist/ui/read-models/tasks.d.ts.map +1 -0
- package/dist/ui/read-models/tasks.js +46 -0
- package/dist/ui/read-models/tasks.js.map +1 -0
- package/dist/utils/config.d.ts +30 -0
- package/dist/utils/config.d.ts.map +1 -0
- package/dist/utils/config.js +152 -0
- package/dist/utils/config.js.map +1 -0
- package/dist/utils/file.d.ts +24 -0
- package/dist/utils/file.d.ts.map +1 -0
- package/dist/utils/file.js +42 -0
- package/dist/utils/file.js.map +1 -0
- package/dist/utils/lock.d.ts +7 -0
- package/dist/utils/lock.d.ts.map +1 -0
- package/dist/utils/lock.js +36 -0
- package/dist/utils/lock.js.map +1 -0
- package/package.json +78 -0
|
@@ -0,0 +1,248 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* logs 命令 - 查看 runtime 执行日志与观察事件
|
|
3
|
+
*/
|
|
4
|
+
import { Command } from 'commander';
|
|
5
|
+
import { inspectThreadLink } from '../../core/threads.js';
|
|
6
|
+
import { getRuntimeWorkflowContext, getSessionWorkflowContext, inspectWorkflowContext } from '../../core/workflow-context.js';
|
|
7
|
+
import { loadWorkspaceState } from '../../core/workspace.js';
|
|
8
|
+
import { getLatestRuntimeObservation, getRuntimeObservation } from '../../core/logger.js';
|
|
9
|
+
import { buildAgentBriefing } from '../agent-briefing.js';
|
|
10
|
+
import logger from '../utils/logger.js';
|
|
11
|
+
export function createLogsCommand(basePath = process.cwd()) {
|
|
12
|
+
const command = new Command('logs').description('查看 WebForge runtime 执行日志');
|
|
13
|
+
command
|
|
14
|
+
.command('runtime')
|
|
15
|
+
.description('查看最近一次或指定 session 的 runtime 观察日志')
|
|
16
|
+
.argument('[session-id]', 'runtime session id,默认使用最近一次 runtime 会话')
|
|
17
|
+
.option('--json', '输出结构化 runtime 日志摘要')
|
|
18
|
+
.action(async (sessionId, options) => {
|
|
19
|
+
try {
|
|
20
|
+
await runtimeLogsCommand(sessionId, options, basePath);
|
|
21
|
+
}
|
|
22
|
+
catch (error) {
|
|
23
|
+
logger.error(`读取 runtime 日志失败: ${error}`);
|
|
24
|
+
process.exit(1);
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
return command;
|
|
28
|
+
}
|
|
29
|
+
export async function runtimeLogsCommand(sessionId, options = {}, basePath = process.cwd()) {
|
|
30
|
+
let summary;
|
|
31
|
+
try {
|
|
32
|
+
summary = await buildRuntimeLogsSummary(sessionId, basePath);
|
|
33
|
+
}
|
|
34
|
+
catch (error) {
|
|
35
|
+
const message = error instanceof Error ? error.message : String(error);
|
|
36
|
+
logger.warning(message);
|
|
37
|
+
return null;
|
|
38
|
+
}
|
|
39
|
+
if (options.json) {
|
|
40
|
+
console.log(JSON.stringify(summary, null, 2));
|
|
41
|
+
return summary;
|
|
42
|
+
}
|
|
43
|
+
logger.h1('🪵 Runtime 日志');
|
|
44
|
+
logger.info(`session: ${summary.sessionId}`);
|
|
45
|
+
logger.info(`start: ${new Date(summary.startTime).toLocaleString()}`);
|
|
46
|
+
logger.info(`end: ${summary.endTime ? new Date(summary.endTime).toLocaleString() : 'running'}`);
|
|
47
|
+
logger.info(`result: completed=${summary.completed} | failed=${summary.failed} | blocked=${summary.blocked} | deliverables=${summary.deliverables}`);
|
|
48
|
+
logger.info(`permission profile: ${summary.permissionProfile ?? 'unknown'}`);
|
|
49
|
+
if (summary.signals) {
|
|
50
|
+
logger.info(`signals: ready=${summary.signals.readyTasks} | blocked=${summary.signals.blockedTasks} | pending_review=${summary.signals.pendingReview} | unread=${summary.signals.unreadMessages}`);
|
|
51
|
+
}
|
|
52
|
+
console.log();
|
|
53
|
+
logger.h2('日志恢复快照');
|
|
54
|
+
renderRecoverySnapshot(summary.workflowContext, summary.threadLinkage);
|
|
55
|
+
console.log();
|
|
56
|
+
logger.h2('当前工作区恢复快照');
|
|
57
|
+
renderRecoverySnapshot(summary.currentWorkflowContext, summary.currentThreadLinkage);
|
|
58
|
+
console.log();
|
|
59
|
+
logger.h2('上下文漂移');
|
|
60
|
+
logger.info(`status: ${summary.contextDrift.status}`);
|
|
61
|
+
if (summary.contextDrift.reasons.length > 0) {
|
|
62
|
+
logger.info(`reasons: ${summary.contextDrift.reasons.join(', ')}`);
|
|
63
|
+
}
|
|
64
|
+
console.log();
|
|
65
|
+
logger.h2('事件流');
|
|
66
|
+
if (summary.events.length === 0) {
|
|
67
|
+
logger.info('当前没有可展示的 runtime observation 事件。');
|
|
68
|
+
return summary;
|
|
69
|
+
}
|
|
70
|
+
for (const event of summary.events) {
|
|
71
|
+
console.log(` ${event.timestamp} :: ${event.message} :: ${event.taskId ?? 'no-task'} :: ${event.permissionProfile ?? 'unknown'}${event.reason ? ` :: ${event.reason}` : ''}`);
|
|
72
|
+
}
|
|
73
|
+
return summary;
|
|
74
|
+
}
|
|
75
|
+
export async function buildRuntimeLogsSummary(sessionId, basePath) {
|
|
76
|
+
const observation = sessionId
|
|
77
|
+
? await getRuntimeObservation(sessionId, basePath)
|
|
78
|
+
: await getLatestRuntimeObservation(basePath);
|
|
79
|
+
if (!observation) {
|
|
80
|
+
throw new Error(sessionId
|
|
81
|
+
? `没有找到 runtime 日志 ${sessionId}`
|
|
82
|
+
: '当前 workspace 没有 runtime 日志');
|
|
83
|
+
}
|
|
84
|
+
const workspace = await loadWorkspaceState(basePath);
|
|
85
|
+
const briefing = await buildAgentBriefing(basePath, workspace);
|
|
86
|
+
const workflowContext = resolveRuntimeLogsWorkflowContext(observation.sessionId, workspace, basePath);
|
|
87
|
+
const threadLinkage = resolveRuntimeLogsThreadLinkage(workflowContext?.threadId ?? null, workspace, basePath);
|
|
88
|
+
const currentWorkflowContext = summarizeWorkflowContext('current', briefing.workflowContext, basePath);
|
|
89
|
+
const currentThreadLinkage = resolveRuntimeLogsThreadLinkage(currentWorkflowContext?.threadId ?? null, workspace, basePath);
|
|
90
|
+
const contextDrift = buildContextDriftSummary(workflowContext, threadLinkage, currentWorkflowContext, currentThreadLinkage);
|
|
91
|
+
return {
|
|
92
|
+
...observation,
|
|
93
|
+
workflowContext,
|
|
94
|
+
threadLinkage,
|
|
95
|
+
currentWorkflowContext,
|
|
96
|
+
currentThreadLinkage,
|
|
97
|
+
contextDrift
|
|
98
|
+
};
|
|
99
|
+
}
|
|
100
|
+
function resolveRuntimeLogsWorkflowContext(sessionId, workspace, basePath) {
|
|
101
|
+
let source = null;
|
|
102
|
+
let context = null;
|
|
103
|
+
if (workspace.runtime.sessionId === sessionId) {
|
|
104
|
+
context = getRuntimeWorkflowContext(workspace.runtime);
|
|
105
|
+
source = context ? 'runtime' : null;
|
|
106
|
+
}
|
|
107
|
+
if (!context) {
|
|
108
|
+
const session = workspace.indexes.sessions.find((item) => item.id === sessionId) ?? null;
|
|
109
|
+
context = getSessionWorkflowContext(session);
|
|
110
|
+
source = context ? 'session' : null;
|
|
111
|
+
}
|
|
112
|
+
if (!context || !source) {
|
|
113
|
+
return null;
|
|
114
|
+
}
|
|
115
|
+
return summarizeWorkflowContext(source, context, basePath);
|
|
116
|
+
}
|
|
117
|
+
function summarizeWorkflowContext(source, context, basePath) {
|
|
118
|
+
if (!context) {
|
|
119
|
+
return null;
|
|
120
|
+
}
|
|
121
|
+
const readiness = inspectWorkflowContext(basePath, context);
|
|
122
|
+
return {
|
|
123
|
+
source,
|
|
124
|
+
status: readiness.missingArtifacts.length > 0 ||
|
|
125
|
+
readiness.missingWorktreePath !== null ||
|
|
126
|
+
readiness.missingCompactSessionId !== null
|
|
127
|
+
? 'blocked'
|
|
128
|
+
: 'ready',
|
|
129
|
+
workflow: context.workflow,
|
|
130
|
+
runId: context.runId ?? null,
|
|
131
|
+
owner: context.owner ?? null,
|
|
132
|
+
waveId: context.waveId ?? null,
|
|
133
|
+
threadId: context.threadId ?? null,
|
|
134
|
+
branch: context.branch ?? null,
|
|
135
|
+
worktreePath: context.worktreePath ?? null,
|
|
136
|
+
compactFromSession: context.compactFromSession ?? null,
|
|
137
|
+
artifacts: context.artifacts ?? [],
|
|
138
|
+
missingArtifacts: readiness.missingArtifacts,
|
|
139
|
+
missingWorktreePath: readiness.missingWorktreePath,
|
|
140
|
+
missingCompactSessionId: readiness.missingCompactSessionId
|
|
141
|
+
};
|
|
142
|
+
}
|
|
143
|
+
function resolveRuntimeLogsThreadLinkage(threadId, workspace, basePath) {
|
|
144
|
+
if (!threadId) {
|
|
145
|
+
return {
|
|
146
|
+
status: 'none',
|
|
147
|
+
threadId: null,
|
|
148
|
+
workflow: null,
|
|
149
|
+
runId: null,
|
|
150
|
+
branch: null,
|
|
151
|
+
worktreePath: null,
|
|
152
|
+
missingArtifacts: [],
|
|
153
|
+
missingWorktreePath: null,
|
|
154
|
+
missingThreadId: null
|
|
155
|
+
};
|
|
156
|
+
}
|
|
157
|
+
const threadLink = workspace.indexes.threads.find((item) => item.id === threadId) ?? null;
|
|
158
|
+
if (!threadLink) {
|
|
159
|
+
return {
|
|
160
|
+
status: 'blocked',
|
|
161
|
+
threadId,
|
|
162
|
+
workflow: null,
|
|
163
|
+
runId: null,
|
|
164
|
+
branch: null,
|
|
165
|
+
worktreePath: null,
|
|
166
|
+
missingArtifacts: [],
|
|
167
|
+
missingWorktreePath: null,
|
|
168
|
+
missingThreadId: threadId
|
|
169
|
+
};
|
|
170
|
+
}
|
|
171
|
+
const readiness = inspectThreadLink(basePath, threadLink);
|
|
172
|
+
return {
|
|
173
|
+
status: readiness.missingArtifacts.length > 0 || readiness.missingWorktreePath !== null
|
|
174
|
+
? 'blocked'
|
|
175
|
+
: 'ready',
|
|
176
|
+
threadId: threadLink.id,
|
|
177
|
+
workflow: threadLink.workflow,
|
|
178
|
+
runId: threadLink.runId ?? null,
|
|
179
|
+
branch: threadLink.branch ?? null,
|
|
180
|
+
worktreePath: threadLink.worktreePath ?? null,
|
|
181
|
+
missingArtifacts: readiness.missingArtifacts,
|
|
182
|
+
missingWorktreePath: readiness.missingWorktreePath,
|
|
183
|
+
missingThreadId: null
|
|
184
|
+
};
|
|
185
|
+
}
|
|
186
|
+
function renderRecoverySnapshot(workflowContext, threadLinkage) {
|
|
187
|
+
if (!workflowContext) {
|
|
188
|
+
logger.info('workflow context: none');
|
|
189
|
+
}
|
|
190
|
+
else {
|
|
191
|
+
logger.info(`workflow context: ${workflowContext.status} (${workflowContext.source})`);
|
|
192
|
+
logger.info(`workflow: ${workflowContext.workflow}`);
|
|
193
|
+
logger.info(`branch: ${workflowContext.branch ?? 'none'}`);
|
|
194
|
+
logger.info(`worktree: ${workflowContext.worktreePath ?? 'none'}`);
|
|
195
|
+
logger.info(`wave: ${workflowContext.waveId ?? 'none'}`);
|
|
196
|
+
logger.info(`thread: ${workflowContext.threadId ?? 'none'}`);
|
|
197
|
+
logger.info(`compact from: ${workflowContext.compactFromSession ?? 'none'}`);
|
|
198
|
+
logger.info(`readiness: artifacts=${workflowContext.missingArtifacts.length === 0 ? 'ok' : `missing:${workflowContext.missingArtifacts.length}`}, worktree=${workflowContext.missingWorktreePath ? 'missing' : 'ok'}, compact=${workflowContext.missingCompactSessionId ? 'missing' : 'ok'}`);
|
|
199
|
+
}
|
|
200
|
+
if (threadLinkage.status === 'none') {
|
|
201
|
+
logger.info('thread linkage: none');
|
|
202
|
+
return;
|
|
203
|
+
}
|
|
204
|
+
logger.info(`thread linkage: ${threadLinkage.status}`);
|
|
205
|
+
logger.info(`thread id: ${threadLinkage.threadId ?? 'none'}`);
|
|
206
|
+
logger.info(`thread workflow: ${threadLinkage.workflow ?? 'none'}`);
|
|
207
|
+
logger.info(`thread branch: ${threadLinkage.branch ?? 'none'}`);
|
|
208
|
+
logger.info(`thread worktree: ${threadLinkage.worktreePath ?? 'none'}`);
|
|
209
|
+
logger.info(`thread readiness: artifacts=${threadLinkage.missingArtifacts.length === 0 ? 'ok' : `missing:${threadLinkage.missingArtifacts.length}`}, worktree=${threadLinkage.missingWorktreePath ? 'missing' : 'ok'}${threadLinkage.missingThreadId ? `, thread=missing:${threadLinkage.missingThreadId}` : ''}`);
|
|
210
|
+
}
|
|
211
|
+
function buildContextDriftSummary(logWorkflowContext, logThreadLinkage, currentWorkflowContext, currentThreadLinkage) {
|
|
212
|
+
if (!logWorkflowContext && !currentWorkflowContext) {
|
|
213
|
+
return {
|
|
214
|
+
status: 'none',
|
|
215
|
+
reasons: []
|
|
216
|
+
};
|
|
217
|
+
}
|
|
218
|
+
const reasons = [];
|
|
219
|
+
if (!logWorkflowContext && currentWorkflowContext) {
|
|
220
|
+
reasons.push('missing log workflowContext');
|
|
221
|
+
}
|
|
222
|
+
else if (logWorkflowContext && !currentWorkflowContext) {
|
|
223
|
+
reasons.push('missing current workflowContext');
|
|
224
|
+
}
|
|
225
|
+
else if (logWorkflowContext && currentWorkflowContext) {
|
|
226
|
+
appendIfChanged(reasons, 'workflow', logWorkflowContext.workflow, currentWorkflowContext.workflow);
|
|
227
|
+
appendIfChanged(reasons, 'runId', logWorkflowContext.runId, currentWorkflowContext.runId);
|
|
228
|
+
appendIfChanged(reasons, 'threadId', logWorkflowContext.threadId, currentWorkflowContext.threadId);
|
|
229
|
+
appendIfChanged(reasons, 'branch', logWorkflowContext.branch, currentWorkflowContext.branch);
|
|
230
|
+
appendIfChanged(reasons, 'worktreePath', logWorkflowContext.worktreePath, currentWorkflowContext.worktreePath);
|
|
231
|
+
appendIfChanged(reasons, 'compactFromSession', logWorkflowContext.compactFromSession, currentWorkflowContext.compactFromSession);
|
|
232
|
+
}
|
|
233
|
+
appendIfChanged(reasons, 'threadLinkage.threadId', logThreadLinkage.threadId, currentThreadLinkage.threadId);
|
|
234
|
+
appendIfChanged(reasons, 'threadLinkage.workflow', logThreadLinkage.workflow, currentThreadLinkage.workflow);
|
|
235
|
+
appendIfChanged(reasons, 'threadLinkage.runId', logThreadLinkage.runId, currentThreadLinkage.runId);
|
|
236
|
+
appendIfChanged(reasons, 'threadLinkage.branch', logThreadLinkage.branch, currentThreadLinkage.branch);
|
|
237
|
+
appendIfChanged(reasons, 'threadLinkage.worktreePath', logThreadLinkage.worktreePath, currentThreadLinkage.worktreePath);
|
|
238
|
+
return {
|
|
239
|
+
status: reasons.length > 0 ? 'drifted' : 'aligned',
|
|
240
|
+
reasons
|
|
241
|
+
};
|
|
242
|
+
}
|
|
243
|
+
function appendIfChanged(reasons, label, left, right) {
|
|
244
|
+
if ((left ?? null) !== (right ?? null)) {
|
|
245
|
+
reasons.push(`${label}: ${left ?? 'none'} -> ${right ?? 'none'}`);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
//# sourceMappingURL=logs.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logs.js","sourceRoot":"","sources":["../../../src/cli/commands/logs.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* mailbox 命令 - mailbox 观察与维护入口
|
|
3
|
+
*/
|
|
4
|
+
import { Command } from 'commander';
|
|
5
|
+
export declare function createMailboxCommand(): Command;
|
|
6
|
+
export declare function listMailboxes(basePath?: string): Promise<void>;
|
|
7
|
+
export declare function readMailbox(workerId: string, options: {
|
|
8
|
+
all?: boolean;
|
|
9
|
+
markRead?: boolean;
|
|
10
|
+
}, basePath?: string): Promise<void>;
|
|
11
|
+
export declare function clearMailbox(workerId: string, basePath?: string): Promise<void>;
|
|
12
|
+
//# sourceMappingURL=mailbox.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mailbox.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/mailbox.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAUpC,wBAAgB,oBAAoB,IAAI,OAAO,CAM9C;AA6CD,wBAAsB,aAAa,CAAC,QAAQ,GAAE,MAAsB,GAAG,OAAO,CAAC,IAAI,CAAC,CAqBnF;AAED,wBAAsB,WAAW,CAC/B,QAAQ,EAAE,MAAM,EAChB,OAAO,EAAE;IAAE,GAAG,CAAC,EAAE,OAAO,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAE,EAC9C,QAAQ,GAAE,MAAsB,GAC/B,OAAO,CAAC,IAAI,CAAC,CA8Bf;AAED,wBAAsB,YAAY,CAChC,QAAQ,EAAE,MAAM,EAChB,QAAQ,GAAE,MAAsB,GAC/B,OAAO,CAAC,IAAI,CAAC,CAKf"}
|
|
@@ -0,0 +1,131 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* mailbox 命令 - mailbox 观察与维护入口
|
|
3
|
+
*/
|
|
4
|
+
import { Command } from 'commander';
|
|
5
|
+
import { readdir } from 'fs/promises';
|
|
6
|
+
import { existsSync } from 'fs';
|
|
7
|
+
import { join } from 'path';
|
|
8
|
+
import logger from '../utils/logger.js';
|
|
9
|
+
import { Mailbox } from '../../core/mailbox.js';
|
|
10
|
+
import { loadConfig } from '../../utils/config.js';
|
|
11
|
+
const MAILBOX_DIR = '.webforge/mailboxes';
|
|
12
|
+
export function createMailboxCommand() {
|
|
13
|
+
return new Command('mailbox')
|
|
14
|
+
.description('查看或维护 Worker mailbox')
|
|
15
|
+
.addCommand(createListCommand())
|
|
16
|
+
.addCommand(createReadCommand())
|
|
17
|
+
.addCommand(createClearCommand());
|
|
18
|
+
}
|
|
19
|
+
function createListCommand() {
|
|
20
|
+
return new Command('list')
|
|
21
|
+
.description('列出已发现的 mailbox')
|
|
22
|
+
.action(async () => {
|
|
23
|
+
try {
|
|
24
|
+
await listMailboxes();
|
|
25
|
+
}
|
|
26
|
+
catch (error) {
|
|
27
|
+
logger.error(`列出失败: ${error}`);
|
|
28
|
+
process.exit(1);
|
|
29
|
+
}
|
|
30
|
+
});
|
|
31
|
+
}
|
|
32
|
+
function createReadCommand() {
|
|
33
|
+
return new Command('read')
|
|
34
|
+
.description('读取指定 Worker 的 mailbox')
|
|
35
|
+
.argument('<worker>', 'Worker ID')
|
|
36
|
+
.option('-a, --all', '显示全部消息(默认仅显示未读)')
|
|
37
|
+
.option('-m, --mark-read', '将当前读取结果标记为已读')
|
|
38
|
+
.action(async (workerId, options) => {
|
|
39
|
+
try {
|
|
40
|
+
await readMailbox(workerId, options);
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
logger.error(`读取失败: ${error}`);
|
|
44
|
+
process.exit(1);
|
|
45
|
+
}
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
function createClearCommand() {
|
|
49
|
+
return new Command('clear')
|
|
50
|
+
.description('清空指定 Worker 的 mailbox')
|
|
51
|
+
.argument('<worker>', 'Worker ID')
|
|
52
|
+
.action(async (workerId) => {
|
|
53
|
+
try {
|
|
54
|
+
await clearMailbox(workerId);
|
|
55
|
+
}
|
|
56
|
+
catch (error) {
|
|
57
|
+
logger.error(`清空失败: ${error}`);
|
|
58
|
+
process.exit(1);
|
|
59
|
+
}
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
export async function listMailboxes(basePath = process.cwd()) {
|
|
63
|
+
logger.h1('📬 Worker 邮箱列表');
|
|
64
|
+
const workers = await discoverMailboxWorkers(basePath);
|
|
65
|
+
if (workers.length === 0) {
|
|
66
|
+
logger.info('当前没有发现任何 mailbox。');
|
|
67
|
+
return;
|
|
68
|
+
}
|
|
69
|
+
for (const workerId of workers) {
|
|
70
|
+
const mailbox = new Mailbox(workerId, basePath);
|
|
71
|
+
await mailbox.init();
|
|
72
|
+
const unreadCount = await mailbox.getUnreadCount();
|
|
73
|
+
const icon = unreadCount > 0 ? '🔔' : '📭';
|
|
74
|
+
console.log(` ${icon} ${workerId.padEnd(12)} ${unreadCount > 0 ? `(${unreadCount} 未读)` : '(0 未读)'}`);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
export async function readMailbox(workerId, options, basePath = process.cwd()) {
|
|
78
|
+
logger.h1(`📬 ${workerId} 的邮箱`);
|
|
79
|
+
const mailbox = new Mailbox(workerId, basePath);
|
|
80
|
+
await mailbox.init();
|
|
81
|
+
const messages = await mailbox.receive({
|
|
82
|
+
unreadOnly: !options.all,
|
|
83
|
+
markAsRead: options.markRead
|
|
84
|
+
});
|
|
85
|
+
if (messages.length === 0) {
|
|
86
|
+
logger.info(options.all ? '邮箱为空' : '没有未读消息');
|
|
87
|
+
return;
|
|
88
|
+
}
|
|
89
|
+
for (const message of messages) {
|
|
90
|
+
console.log(`\n${'─'.repeat(50)}`);
|
|
91
|
+
console.log(` ID: ${message.id}`);
|
|
92
|
+
console.log(` 来自: ${message.from}`);
|
|
93
|
+
console.log(` 类型: ${message.type}`);
|
|
94
|
+
console.log(` 时间: ${new Date(message.timestamp).toLocaleString()}`);
|
|
95
|
+
console.log(` 内容: ${message.content}`);
|
|
96
|
+
if (message.task_id) {
|
|
97
|
+
console.log(` 关联任务: ${message.task_id}`);
|
|
98
|
+
}
|
|
99
|
+
console.log(` 状态: ${message.read ? '已读' : '未读'}`);
|
|
100
|
+
}
|
|
101
|
+
console.log(`\n共 ${messages.length} 条消息`);
|
|
102
|
+
}
|
|
103
|
+
export async function clearMailbox(workerId, basePath = process.cwd()) {
|
|
104
|
+
const mailbox = new Mailbox(workerId, basePath);
|
|
105
|
+
await mailbox.init();
|
|
106
|
+
await mailbox.clear();
|
|
107
|
+
logger.success(`已清空 ${workerId} 的邮箱`);
|
|
108
|
+
}
|
|
109
|
+
async function discoverMailboxWorkers(basePath) {
|
|
110
|
+
const workers = new Set();
|
|
111
|
+
try {
|
|
112
|
+
const config = await loadConfig(basePath);
|
|
113
|
+
for (const workerId of config.workers) {
|
|
114
|
+
workers.add(workerId);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
catch {
|
|
118
|
+
// config 不是 mailbox 观察面的强依赖
|
|
119
|
+
}
|
|
120
|
+
const mailboxRoot = join(basePath, MAILBOX_DIR);
|
|
121
|
+
if (existsSync(mailboxRoot)) {
|
|
122
|
+
const entries = await readdir(mailboxRoot, { withFileTypes: true });
|
|
123
|
+
for (const entry of entries) {
|
|
124
|
+
if (entry.isFile() && entry.name.endsWith('.jsonl')) {
|
|
125
|
+
workers.add(entry.name.slice(0, -'.jsonl'.length));
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return Array.from(workers).sort();
|
|
130
|
+
}
|
|
131
|
+
//# sourceMappingURL=mailbox.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"mailbox.js","sourceRoot":"","sources":["../../../src/cli/commands/mailbox.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* onboard 命令 - 统一的 agent onboarding 入口
|
|
3
|
+
*/
|
|
4
|
+
import { Command } from 'commander';
|
|
5
|
+
import { type DoctorReport } from './doctor.js';
|
|
6
|
+
import { type ResumeSummary } from './resume.js';
|
|
7
|
+
export interface OnboardingRecoveryTarget {
|
|
8
|
+
status: 'none' | 'ready' | 'blocked';
|
|
9
|
+
workflow: string | null;
|
|
10
|
+
runId: string | null;
|
|
11
|
+
branch: string | null;
|
|
12
|
+
threadId: string | null;
|
|
13
|
+
worktreePath: string | null;
|
|
14
|
+
compactFromSession: string | null;
|
|
15
|
+
missingArtifacts: string[];
|
|
16
|
+
missingWorktreePath: string | null;
|
|
17
|
+
missingCompactSessionId: string | null;
|
|
18
|
+
missingThreadId: string | null;
|
|
19
|
+
}
|
|
20
|
+
export interface OnboardingRecoveryReadiness {
|
|
21
|
+
overallStatus: 'ready' | 'blocked';
|
|
22
|
+
workflowContext: OnboardingRecoveryTarget;
|
|
23
|
+
latestSuperpowersRun: OnboardingRecoveryTarget;
|
|
24
|
+
threadLinkage: OnboardingRecoveryTarget;
|
|
25
|
+
}
|
|
26
|
+
export interface OnboardingSummary {
|
|
27
|
+
canProceed: boolean;
|
|
28
|
+
status: 'ready' | 'blocked';
|
|
29
|
+
doctor: DoctorReport;
|
|
30
|
+
resume: ResumeSummary;
|
|
31
|
+
shouldRead: string[];
|
|
32
|
+
runtimeLogCommand: string | null;
|
|
33
|
+
suggestedWorkflow: string | null;
|
|
34
|
+
recoveryReadiness: OnboardingRecoveryReadiness;
|
|
35
|
+
recommendedActions: string[];
|
|
36
|
+
}
|
|
37
|
+
export interface OnboardCommandOptions {
|
|
38
|
+
json?: boolean;
|
|
39
|
+
}
|
|
40
|
+
export declare function createOnboardCommand(): Command;
|
|
41
|
+
export declare function buildOnboardingSummary(basePath?: string): Promise<OnboardingSummary>;
|
|
42
|
+
export declare function onboardCommand(optionsOrBasePath?: OnboardCommandOptions | string, maybeBasePath?: string): Promise<OnboardingSummary>;
|
|
43
|
+
//# sourceMappingURL=onboard.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"onboard.d.ts","sourceRoot":"","sources":["../../../src/cli/commands/onboard.ts"],"names":[],"mappings":"AAAA;;GAEG;AAEH,OAAO,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AAKpC,OAAO,EAAqB,KAAK,YAAY,EAAE,MAAM,aAAa,CAAC;AACnE,OAAO,EAAsB,KAAK,aAAa,EAAE,MAAM,aAAa,CAAC;AAErE,MAAM,WAAW,wBAAwB;IACvC,MAAM,EAAE,MAAM,GAAG,OAAO,GAAG,SAAS,CAAC;IACrC,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,KAAK,EAAE,MAAM,GAAG,IAAI,CAAC;IACrB,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,QAAQ,EAAE,MAAM,GAAG,IAAI,CAAC;IACxB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,kBAAkB,EAAE,MAAM,GAAG,IAAI,CAAC;IAClC,gBAAgB,EAAE,MAAM,EAAE,CAAC;IAC3B,mBAAmB,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,uBAAuB,EAAE,MAAM,GAAG,IAAI,CAAC;IACvC,eAAe,EAAE,MAAM,GAAG,IAAI,CAAC;CAChC;AAED,MAAM,WAAW,2BAA2B;IAC1C,aAAa,EAAE,OAAO,GAAG,SAAS,CAAC;IACnC,eAAe,EAAE,wBAAwB,CAAC;IAC1C,oBAAoB,EAAE,wBAAwB,CAAC;IAC/C,aAAa,EAAE,wBAAwB,CAAC;CACzC;AAED,MAAM,WAAW,iBAAiB;IAChC,UAAU,EAAE,OAAO,CAAC;IACpB,MAAM,EAAE,OAAO,GAAG,SAAS,CAAC;IAC5B,MAAM,EAAE,YAAY,CAAC;IACrB,MAAM,EAAE,aAAa,CAAC;IACtB,UAAU,EAAE,MAAM,EAAE,CAAC;IACrB,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,iBAAiB,EAAE,MAAM,GAAG,IAAI,CAAC;IACjC,iBAAiB,EAAE,2BAA2B,CAAC;IAC/C,kBAAkB,EAAE,MAAM,EAAE,CAAC;CAC9B;AAED,MAAM,WAAW,qBAAqB;IACpC,IAAI,CAAC,EAAE,OAAO,CAAC;CAChB;AAED,wBAAgB,oBAAoB,IAAI,OAAO,CAY9C;AAED,wBAAsB,sBAAsB,CAC1C,QAAQ,GAAE,MAAsB,GAC/B,OAAO,CAAC,iBAAiB,CAAC,CAoB5B;AAED,wBAAsB,cAAc,CAClC,iBAAiB,GAAE,qBAAqB,GAAG,MAAW,EACtD,aAAa,CAAC,EAAE,MAAM,GACrB,OAAO,CAAC,iBAAiB,CAAC,CAmD5B"}
|