@litmers/cursorflow-orchestrator 0.1.20 → 0.1.28
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/CHANGELOG.md +20 -0
- package/commands/cursorflow-clean.md +19 -0
- package/commands/cursorflow-runs.md +59 -0
- package/commands/cursorflow-stop.md +55 -0
- package/dist/cli/clean.js +171 -0
- package/dist/cli/clean.js.map +1 -1
- package/dist/cli/index.js +7 -0
- package/dist/cli/index.js.map +1 -1
- package/dist/cli/init.js +1 -1
- package/dist/cli/init.js.map +1 -1
- package/dist/cli/logs.js +83 -42
- package/dist/cli/logs.js.map +1 -1
- package/dist/cli/monitor.d.ts +7 -0
- package/dist/cli/monitor.js +1007 -189
- package/dist/cli/monitor.js.map +1 -1
- package/dist/cli/prepare.js +87 -3
- package/dist/cli/prepare.js.map +1 -1
- package/dist/cli/resume.js +188 -236
- package/dist/cli/resume.js.map +1 -1
- package/dist/cli/run.js +125 -3
- package/dist/cli/run.js.map +1 -1
- package/dist/cli/runs.d.ts +5 -0
- package/dist/cli/runs.js +214 -0
- package/dist/cli/runs.js.map +1 -0
- package/dist/cli/setup-commands.js +0 -0
- package/dist/cli/signal.js +1 -1
- package/dist/cli/signal.js.map +1 -1
- package/dist/cli/stop.d.ts +5 -0
- package/dist/cli/stop.js +215 -0
- package/dist/cli/stop.js.map +1 -0
- package/dist/cli/tasks.d.ts +10 -0
- package/dist/cli/tasks.js +165 -0
- package/dist/cli/tasks.js.map +1 -0
- package/dist/core/auto-recovery.d.ts +212 -0
- package/dist/core/auto-recovery.js +737 -0
- package/dist/core/auto-recovery.js.map +1 -0
- package/dist/core/failure-policy.d.ts +156 -0
- package/dist/core/failure-policy.js +488 -0
- package/dist/core/failure-policy.js.map +1 -0
- package/dist/core/orchestrator.d.ts +15 -2
- package/dist/core/orchestrator.js +397 -15
- package/dist/core/orchestrator.js.map +1 -1
- package/dist/core/reviewer.d.ts +2 -0
- package/dist/core/reviewer.js +2 -0
- package/dist/core/reviewer.js.map +1 -1
- package/dist/core/runner.d.ts +33 -10
- package/dist/core/runner.js +321 -146
- package/dist/core/runner.js.map +1 -1
- package/dist/services/logging/buffer.d.ts +67 -0
- package/dist/services/logging/buffer.js +309 -0
- package/dist/services/logging/buffer.js.map +1 -0
- package/dist/services/logging/console.d.ts +89 -0
- package/dist/services/logging/console.js +169 -0
- package/dist/services/logging/console.js.map +1 -0
- package/dist/services/logging/file-writer.d.ts +71 -0
- package/dist/services/logging/file-writer.js +516 -0
- package/dist/services/logging/file-writer.js.map +1 -0
- package/dist/services/logging/formatter.d.ts +39 -0
- package/dist/services/logging/formatter.js +227 -0
- package/dist/services/logging/formatter.js.map +1 -0
- package/dist/services/logging/index.d.ts +11 -0
- package/dist/services/logging/index.js +30 -0
- package/dist/services/logging/index.js.map +1 -0
- package/dist/services/logging/parser.d.ts +31 -0
- package/dist/services/logging/parser.js +222 -0
- package/dist/services/logging/parser.js.map +1 -0
- package/dist/services/process/index.d.ts +59 -0
- package/dist/services/process/index.js +257 -0
- package/dist/services/process/index.js.map +1 -0
- package/dist/types/agent.d.ts +20 -0
- package/dist/types/agent.js +6 -0
- package/dist/types/agent.js.map +1 -0
- package/dist/types/config.d.ts +65 -0
- package/dist/types/config.js +6 -0
- package/dist/types/config.js.map +1 -0
- package/dist/types/events.d.ts +125 -0
- package/dist/types/events.js +6 -0
- package/dist/types/events.js.map +1 -0
- package/dist/types/index.d.ts +12 -0
- package/dist/types/index.js +37 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/lane.d.ts +43 -0
- package/dist/types/lane.js +6 -0
- package/dist/types/lane.js.map +1 -0
- package/dist/types/logging.d.ts +71 -0
- package/dist/types/logging.js +16 -0
- package/dist/types/logging.js.map +1 -0
- package/dist/types/review.d.ts +17 -0
- package/dist/types/review.js +6 -0
- package/dist/types/review.js.map +1 -0
- package/dist/types/run.d.ts +32 -0
- package/dist/types/run.js +6 -0
- package/dist/types/run.js.map +1 -0
- package/dist/types/task.d.ts +71 -0
- package/dist/types/task.js +6 -0
- package/dist/types/task.js.map +1 -0
- package/dist/ui/components.d.ts +134 -0
- package/dist/ui/components.js +389 -0
- package/dist/ui/components.js.map +1 -0
- package/dist/ui/log-viewer.d.ts +49 -0
- package/dist/ui/log-viewer.js +449 -0
- package/dist/ui/log-viewer.js.map +1 -0
- package/dist/utils/checkpoint.d.ts +87 -0
- package/dist/utils/checkpoint.js +317 -0
- package/dist/utils/checkpoint.js.map +1 -0
- package/dist/utils/config.d.ts +4 -0
- package/dist/utils/config.js +11 -2
- package/dist/utils/config.js.map +1 -1
- package/dist/utils/cursor-agent.js.map +1 -1
- package/dist/utils/dependency.d.ts +74 -0
- package/dist/utils/dependency.js +420 -0
- package/dist/utils/dependency.js.map +1 -0
- package/dist/utils/doctor.js +10 -5
- package/dist/utils/doctor.js.map +1 -1
- package/dist/utils/enhanced-logger.d.ts +10 -33
- package/dist/utils/enhanced-logger.js +94 -9
- package/dist/utils/enhanced-logger.js.map +1 -1
- package/dist/utils/git.d.ts +121 -0
- package/dist/utils/git.js +322 -2
- package/dist/utils/git.js.map +1 -1
- package/dist/utils/health.d.ts +91 -0
- package/dist/utils/health.js +556 -0
- package/dist/utils/health.js.map +1 -0
- package/dist/utils/lock.d.ts +95 -0
- package/dist/utils/lock.js +332 -0
- package/dist/utils/lock.js.map +1 -0
- package/dist/utils/log-buffer.d.ts +17 -0
- package/dist/utils/log-buffer.js +14 -0
- package/dist/utils/log-buffer.js.map +1 -0
- package/dist/utils/log-constants.d.ts +23 -0
- package/dist/utils/log-constants.js +28 -0
- package/dist/utils/log-constants.js.map +1 -0
- package/dist/utils/log-formatter.d.ts +9 -0
- package/dist/utils/log-formatter.js +113 -70
- package/dist/utils/log-formatter.js.map +1 -1
- package/dist/utils/log-service.d.ts +19 -0
- package/dist/utils/log-service.js +47 -0
- package/dist/utils/log-service.js.map +1 -0
- package/dist/utils/logger.d.ts +46 -27
- package/dist/utils/logger.js +82 -60
- package/dist/utils/logger.js.map +1 -1
- package/dist/utils/process-manager.d.ts +21 -0
- package/dist/utils/process-manager.js +138 -0
- package/dist/utils/process-manager.js.map +1 -0
- package/dist/utils/retry.d.ts +121 -0
- package/dist/utils/retry.js +374 -0
- package/dist/utils/retry.js.map +1 -0
- package/dist/utils/run-service.d.ts +88 -0
- package/dist/utils/run-service.js +412 -0
- package/dist/utils/run-service.js.map +1 -0
- package/dist/utils/state.d.ts +58 -2
- package/dist/utils/state.js +306 -3
- package/dist/utils/state.js.map +1 -1
- package/dist/utils/task-service.d.ts +82 -0
- package/dist/utils/task-service.js +348 -0
- package/dist/utils/task-service.js.map +1 -0
- package/dist/utils/types.d.ts +2 -272
- package/dist/utils/types.js +16 -0
- package/dist/utils/types.js.map +1 -1
- package/package.json +38 -23
- package/scripts/ai-security-check.js +0 -1
- package/scripts/local-security-gate.sh +0 -0
- package/scripts/monitor-lanes.sh +94 -0
- package/scripts/patches/test-cursor-agent.js +0 -1
- package/scripts/release.sh +0 -0
- package/scripts/setup-security.sh +0 -0
- package/scripts/stream-logs.sh +72 -0
- package/scripts/verify-and-fix.sh +0 -0
- package/src/cli/clean.ts +180 -0
- package/src/cli/index.ts +7 -0
- package/src/cli/init.ts +1 -1
- package/src/cli/logs.ts +79 -42
- package/src/cli/monitor.ts +1815 -899
- package/src/cli/prepare.ts +97 -3
- package/src/cli/resume.ts +220 -277
- package/src/cli/run.ts +154 -3
- package/src/cli/runs.ts +212 -0
- package/src/cli/setup-commands.ts +0 -0
- package/src/cli/signal.ts +1 -1
- package/src/cli/stop.ts +209 -0
- package/src/cli/tasks.ts +154 -0
- package/src/core/auto-recovery.ts +909 -0
- package/src/core/failure-policy.ts +592 -0
- package/src/core/orchestrator.ts +1136 -675
- package/src/core/reviewer.ts +4 -0
- package/src/core/runner.ts +1443 -1217
- package/src/services/logging/buffer.ts +326 -0
- package/src/services/logging/console.ts +193 -0
- package/src/services/logging/file-writer.ts +526 -0
- package/src/services/logging/formatter.ts +268 -0
- package/src/services/logging/index.ts +16 -0
- package/src/services/logging/parser.ts +232 -0
- package/src/services/process/index.ts +261 -0
- package/src/types/agent.ts +24 -0
- package/src/types/config.ts +79 -0
- package/src/types/events.ts +156 -0
- package/src/types/index.ts +29 -0
- package/src/types/lane.ts +56 -0
- package/src/types/logging.ts +96 -0
- package/src/types/review.ts +20 -0
- package/src/types/run.ts +37 -0
- package/src/types/task.ts +79 -0
- package/src/ui/components.ts +430 -0
- package/src/ui/log-viewer.ts +485 -0
- package/src/utils/checkpoint.ts +374 -0
- package/src/utils/config.ts +11 -2
- package/src/utils/cursor-agent.ts +1 -1
- package/src/utils/dependency.ts +482 -0
- package/src/utils/doctor.ts +11 -5
- package/src/utils/enhanced-logger.ts +108 -49
- package/src/utils/git.ts +871 -499
- package/src/utils/health.ts +596 -0
- package/src/utils/lock.ts +346 -0
- package/src/utils/log-buffer.ts +28 -0
- package/src/utils/log-constants.ts +26 -0
- package/src/utils/log-formatter.ts +120 -37
- package/src/utils/log-service.ts +49 -0
- package/src/utils/logger.ts +100 -51
- package/src/utils/process-manager.ts +100 -0
- package/src/utils/retry.ts +413 -0
- package/src/utils/run-service.ts +433 -0
- package/src/utils/state.ts +369 -3
- package/src/utils/task-service.ts +370 -0
- package/src/utils/types.ts +2 -315
|
@@ -0,0 +1,227 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Log Formatter - Human-readable log formatting
|
|
4
|
+
*
|
|
5
|
+
* Formats log messages for console display with various styles.
|
|
6
|
+
*
|
|
7
|
+
* Rules:
|
|
8
|
+
* - Box format only for: user, assistant, system, result
|
|
9
|
+
* - Compact format for: tool, tool_result, thinking (gray/dim)
|
|
10
|
+
* - Tool names simplified: ShellToolCall → Shell
|
|
11
|
+
*/
|
|
12
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
13
|
+
exports.stripAnsi = stripAnsi;
|
|
14
|
+
exports.formatMessageForConsole = formatMessageForConsole;
|
|
15
|
+
exports.formatReadableEntry = formatReadableEntry;
|
|
16
|
+
exports.formatTimestampISO = formatTimestampISO;
|
|
17
|
+
const console_1 = require("./console");
|
|
18
|
+
// Types that should use box format
|
|
19
|
+
const BOX_TYPES = new Set(['user', 'assistant', 'system', 'result']);
|
|
20
|
+
/**
|
|
21
|
+
* Strip ANSI escape sequences from text
|
|
22
|
+
*/
|
|
23
|
+
function stripAnsi(text) {
|
|
24
|
+
const EXTENDED_ANSI_REGEX = /(?:\x1B[@-Z\\-_]|\x1B\[[0-?]*[ -/]*[@-~]|\x1B\][^\x07]*(?:\x07|\x1B\\)|\x1B[PX^_][^\x1B]*\x1B\\|\x1B.)/g;
|
|
25
|
+
const ANSI_REGEX = /[\u001b\u009b][[()#;?]*(?:[0-9]{1,4}(?:;[0-9]{0,4})*)?[0-9A-ORZcf-nqry=><]/g;
|
|
26
|
+
return text
|
|
27
|
+
.replace(EXTENDED_ANSI_REGEX, '')
|
|
28
|
+
.replace(ANSI_REGEX, '')
|
|
29
|
+
.replace(/\r[^\n]/g, '\n')
|
|
30
|
+
.replace(/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/g, '');
|
|
31
|
+
}
|
|
32
|
+
/**
|
|
33
|
+
* Simplify tool names (ShellToolCall → Shell, etc.)
|
|
34
|
+
*/
|
|
35
|
+
function simplifyToolName(name) {
|
|
36
|
+
return name
|
|
37
|
+
.replace(/ToolCall$/i, '')
|
|
38
|
+
.replace(/Tool$/i, '')
|
|
39
|
+
.replace(/^run_terminal_cmd$/i, 'shell')
|
|
40
|
+
.replace(/^search_replace$/i, 'edit');
|
|
41
|
+
}
|
|
42
|
+
/**
|
|
43
|
+
* Format a parsed message for console display
|
|
44
|
+
*/
|
|
45
|
+
function formatMessageForConsole(msg, options = {}) {
|
|
46
|
+
const { includeTimestamp = true, laneLabel = '', compact = false, showBorders = true } = options;
|
|
47
|
+
const ts = includeTimestamp
|
|
48
|
+
? new Date(msg.timestamp).toLocaleTimeString('en-US', { hour12: false })
|
|
49
|
+
: '';
|
|
50
|
+
const tsPrefix = ts ? `${console_1.COLORS.gray}[${ts}]${console_1.COLORS.reset} ` : '';
|
|
51
|
+
// Lane label max 16 chars
|
|
52
|
+
const truncatedLabel = laneLabel.length > 16 ? laneLabel.substring(0, 16) : laneLabel;
|
|
53
|
+
const labelPrefix = truncatedLabel
|
|
54
|
+
? `${console_1.COLORS.magenta}${truncatedLabel.padEnd(16)}${console_1.COLORS.reset} `
|
|
55
|
+
: '';
|
|
56
|
+
// Determine if should use box format
|
|
57
|
+
const useBox = !compact && showBorders && BOX_TYPES.has(msg.type);
|
|
58
|
+
const { typePrefix, formattedContent } = formatMessageContent(msg, !useBox);
|
|
59
|
+
if (!typePrefix)
|
|
60
|
+
return `${tsPrefix}${labelPrefix}${formattedContent}`;
|
|
61
|
+
if (!useBox) {
|
|
62
|
+
return `${tsPrefix}${labelPrefix}${typePrefix.padEnd(12)} ${formattedContent}`;
|
|
63
|
+
}
|
|
64
|
+
// Multi-line box format (only for user, assistant, system, result)
|
|
65
|
+
// Emoji width is 2, so we need to account for that in indent calculation
|
|
66
|
+
const lines = formattedContent.split('\n');
|
|
67
|
+
const fullPrefix = `${tsPrefix}${labelPrefix}`;
|
|
68
|
+
const strippedPrefix = stripAnsi(typePrefix);
|
|
69
|
+
// Count emojis (they take 2 terminal columns but 1-2 chars in string)
|
|
70
|
+
const emojiCount = (strippedPrefix.match(/[\u{1F300}-\u{1F9FF}]|[\u{2600}-\u{26FF}]|[\u{2700}-\u{27BF}]|[\u{1F600}-\u{1F64F}]|[\u{1F680}-\u{1F6FF}]|[\u{1F1E0}-\u{1F1FF}]|[\u{2300}-\u{23FF}]|[\u{2B50}-\u{2B55}]|[\u{231A}-\u{231B}]|[\u{23E9}-\u{23F3}]|[\u{23F8}-\u{23FA}]|✅|❌|⚙️|ℹ️|⚠️|🔧|📄|🤔|🧑|🤖/gu) || []).length;
|
|
71
|
+
const visualWidth = strippedPrefix.length + emojiCount; // emoji adds 1 extra width
|
|
72
|
+
const boxWidth = 60;
|
|
73
|
+
const header = `${typePrefix}┌${'─'.repeat(boxWidth)}`;
|
|
74
|
+
let result = `${fullPrefix}${header}\n`;
|
|
75
|
+
const indent = ' '.repeat(visualWidth);
|
|
76
|
+
for (const line of lines) {
|
|
77
|
+
result += `${fullPrefix}${indent}│ ${line}\n`;
|
|
78
|
+
}
|
|
79
|
+
result += `${fullPrefix}${indent}└${'─'.repeat(boxWidth)}`;
|
|
80
|
+
return result;
|
|
81
|
+
}
|
|
82
|
+
function formatMessageContent(msg, forceCompact) {
|
|
83
|
+
let typePrefix = '';
|
|
84
|
+
let formattedContent = msg.content;
|
|
85
|
+
// For thinking: collapse multiple newlines
|
|
86
|
+
if (msg.type === 'thinking') {
|
|
87
|
+
formattedContent = formattedContent.replace(/\n\s*\n/g, ' ').replace(/\n/g, ' ').trim();
|
|
88
|
+
}
|
|
89
|
+
switch (msg.type) {
|
|
90
|
+
case 'user':
|
|
91
|
+
typePrefix = `${console_1.COLORS.cyan}🧑 USER${console_1.COLORS.reset}`;
|
|
92
|
+
if (forceCompact)
|
|
93
|
+
formattedContent = truncate(formattedContent.replace(/\n/g, ' '), 100);
|
|
94
|
+
break;
|
|
95
|
+
case 'assistant':
|
|
96
|
+
typePrefix = `${console_1.COLORS.green}🤖 ASST${console_1.COLORS.reset}`;
|
|
97
|
+
if (forceCompact)
|
|
98
|
+
formattedContent = truncate(formattedContent.replace(/\n/g, ' '), 100);
|
|
99
|
+
break;
|
|
100
|
+
case 'tool':
|
|
101
|
+
// Tool calls are always gray
|
|
102
|
+
typePrefix = `${console_1.COLORS.gray}🔧 TOOL${console_1.COLORS.reset}`;
|
|
103
|
+
formattedContent = formatToolCall(formattedContent);
|
|
104
|
+
break;
|
|
105
|
+
case 'tool_result':
|
|
106
|
+
// Tool results are always gray
|
|
107
|
+
typePrefix = `${console_1.COLORS.gray}📄 RESL${console_1.COLORS.reset}`;
|
|
108
|
+
const resMatch = formattedContent.match(/\[Tool Result: ([^\]]+)\]/);
|
|
109
|
+
if (resMatch) {
|
|
110
|
+
const simpleName = simplifyToolName(resMatch[1]);
|
|
111
|
+
formattedContent = `${console_1.COLORS.gray}${simpleName} OK${console_1.COLORS.reset}`;
|
|
112
|
+
}
|
|
113
|
+
else {
|
|
114
|
+
formattedContent = `${console_1.COLORS.gray}result${console_1.COLORS.reset}`;
|
|
115
|
+
}
|
|
116
|
+
break;
|
|
117
|
+
case 'result':
|
|
118
|
+
typePrefix = `${console_1.COLORS.green}✅ DONE${console_1.COLORS.reset}`;
|
|
119
|
+
break;
|
|
120
|
+
case 'system':
|
|
121
|
+
typePrefix = `${console_1.COLORS.gray}⚙️ SYS${console_1.COLORS.reset}`;
|
|
122
|
+
break;
|
|
123
|
+
case 'thinking':
|
|
124
|
+
// Thinking is always gray and compact
|
|
125
|
+
typePrefix = `${console_1.COLORS.gray}🤔 THNK${console_1.COLORS.reset}`;
|
|
126
|
+
formattedContent = `${console_1.COLORS.gray}${truncate(formattedContent, 100)}${console_1.COLORS.reset}`;
|
|
127
|
+
break;
|
|
128
|
+
}
|
|
129
|
+
return { typePrefix, formattedContent };
|
|
130
|
+
}
|
|
131
|
+
function formatToolCall(content) {
|
|
132
|
+
const toolMatch = content.match(/\[Tool: ([^\]]+)\] (.*)/);
|
|
133
|
+
if (!toolMatch)
|
|
134
|
+
return content;
|
|
135
|
+
const [, rawName, args] = toolMatch;
|
|
136
|
+
const name = simplifyToolName(rawName);
|
|
137
|
+
try {
|
|
138
|
+
const parsedArgs = JSON.parse(args);
|
|
139
|
+
let argStr = '';
|
|
140
|
+
if (rawName === 'read_file' && parsedArgs.target_file) {
|
|
141
|
+
argStr = parsedArgs.target_file;
|
|
142
|
+
}
|
|
143
|
+
else if (rawName === 'run_terminal_cmd' && parsedArgs.command) {
|
|
144
|
+
argStr = parsedArgs.command;
|
|
145
|
+
}
|
|
146
|
+
else if (rawName === 'write' && parsedArgs.file_path) {
|
|
147
|
+
argStr = parsedArgs.file_path;
|
|
148
|
+
}
|
|
149
|
+
else if (rawName === 'search_replace' && parsedArgs.file_path) {
|
|
150
|
+
argStr = parsedArgs.file_path;
|
|
151
|
+
}
|
|
152
|
+
else {
|
|
153
|
+
const keys = Object.keys(parsedArgs);
|
|
154
|
+
if (keys.length > 0) {
|
|
155
|
+
argStr = String(parsedArgs[keys[0]]).substring(0, 50);
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
return `${console_1.COLORS.gray}${name}${console_1.COLORS.reset}(${console_1.COLORS.gray}${argStr}${console_1.COLORS.reset})`;
|
|
159
|
+
}
|
|
160
|
+
catch {
|
|
161
|
+
return `${console_1.COLORS.gray}${name}${console_1.COLORS.reset}: ${args}`;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
function truncate(str, maxLength) {
|
|
165
|
+
if (str.length <= maxLength)
|
|
166
|
+
return str;
|
|
167
|
+
return str.substring(0, maxLength) + '...';
|
|
168
|
+
}
|
|
169
|
+
/**
|
|
170
|
+
* Format a readable log entry for display
|
|
171
|
+
*/
|
|
172
|
+
function formatReadableEntry(timestamp, laneName, type, content, options = {}) {
|
|
173
|
+
const { showLane = true, maxWidth = 100 } = options;
|
|
174
|
+
const ts = timestamp.toLocaleTimeString('en-US', { hour12: false });
|
|
175
|
+
const laneStr = showLane ? `[${laneName.padEnd(12)}] ` : '';
|
|
176
|
+
const typeInfo = getTypeInfo(type);
|
|
177
|
+
const truncatedContent = content.length > maxWidth
|
|
178
|
+
? content.substring(0, maxWidth - 3) + '...'
|
|
179
|
+
: content;
|
|
180
|
+
return `${console_1.COLORS.gray}[${ts}]${console_1.COLORS.reset} ${laneStr}${typeInfo.color}[${typeInfo.label}]${console_1.COLORS.reset} ${truncatedContent}`;
|
|
181
|
+
}
|
|
182
|
+
function getTypeInfo(type) {
|
|
183
|
+
const typeMap = {
|
|
184
|
+
user: { label: 'USER ', color: console_1.COLORS.cyan },
|
|
185
|
+
assistant: { label: 'ASST ', color: console_1.COLORS.green },
|
|
186
|
+
tool: { label: 'TOOL ', color: console_1.COLORS.yellow },
|
|
187
|
+
tool_result: { label: 'RESULT', color: console_1.COLORS.gray },
|
|
188
|
+
result: { label: 'DONE ', color: console_1.COLORS.green },
|
|
189
|
+
system: { label: 'SYSTEM', color: console_1.COLORS.gray },
|
|
190
|
+
thinking: { label: 'THINK ', color: console_1.COLORS.gray },
|
|
191
|
+
success: { label: 'OK ', color: console_1.COLORS.green },
|
|
192
|
+
info: { label: 'INFO ', color: console_1.COLORS.cyan },
|
|
193
|
+
warn: { label: 'WARN ', color: console_1.COLORS.yellow },
|
|
194
|
+
error: { label: 'ERROR ', color: console_1.COLORS.red },
|
|
195
|
+
stdout: { label: 'STDOUT', color: console_1.COLORS.white },
|
|
196
|
+
stderr: { label: 'STDERR', color: console_1.COLORS.red },
|
|
197
|
+
};
|
|
198
|
+
return typeMap[type] || { label: type.toUpperCase().padEnd(6), color: console_1.COLORS.white };
|
|
199
|
+
}
|
|
200
|
+
/**
|
|
201
|
+
* Format a timestamp for log files
|
|
202
|
+
*/
|
|
203
|
+
function formatTimestampISO(format, startTime) {
|
|
204
|
+
const now = Date.now();
|
|
205
|
+
switch (format) {
|
|
206
|
+
case 'iso':
|
|
207
|
+
return new Date(now).toISOString();
|
|
208
|
+
case 'relative':
|
|
209
|
+
if (startTime) {
|
|
210
|
+
const elapsed = now - startTime;
|
|
211
|
+
const seconds = Math.floor(elapsed / 1000);
|
|
212
|
+
const minutes = Math.floor(seconds / 60);
|
|
213
|
+
const hours = Math.floor(minutes / 60);
|
|
214
|
+
if (hours > 0)
|
|
215
|
+
return `+${hours}h${minutes % 60}m${seconds % 60}s`;
|
|
216
|
+
if (minutes > 0)
|
|
217
|
+
return `+${minutes}m${seconds % 60}s`;
|
|
218
|
+
return `+${seconds}s`;
|
|
219
|
+
}
|
|
220
|
+
return new Date(now).toISOString();
|
|
221
|
+
case 'short':
|
|
222
|
+
return new Date(now).toLocaleTimeString('en-US', { hour12: false });
|
|
223
|
+
default:
|
|
224
|
+
return new Date(now).toISOString();
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
//# sourceMappingURL=formatter.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"formatter.js","sourceRoot":"","sources":["../../../src/services/logging/formatter.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Logging Service - Unified logging module for CursorFlow
|
|
3
|
+
*
|
|
4
|
+
* Re-exports all logging-related functionality from a single entry point.
|
|
5
|
+
*/
|
|
6
|
+
export * from './console';
|
|
7
|
+
export * from './formatter';
|
|
8
|
+
export * from './parser';
|
|
9
|
+
export * from './buffer';
|
|
10
|
+
export * from './file-writer';
|
|
11
|
+
export * from '../../types/logging';
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Logging Service - Unified logging module for CursorFlow
|
|
4
|
+
*
|
|
5
|
+
* Re-exports all logging-related functionality from a single entry point.
|
|
6
|
+
*/
|
|
7
|
+
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
|
|
8
|
+
if (k2 === undefined) k2 = k;
|
|
9
|
+
var desc = Object.getOwnPropertyDescriptor(m, k);
|
|
10
|
+
if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
|
|
11
|
+
desc = { enumerable: true, get: function() { return m[k]; } };
|
|
12
|
+
}
|
|
13
|
+
Object.defineProperty(o, k2, desc);
|
|
14
|
+
}) : (function(o, m, k, k2) {
|
|
15
|
+
if (k2 === undefined) k2 = k;
|
|
16
|
+
o[k2] = m[k];
|
|
17
|
+
}));
|
|
18
|
+
var __exportStar = (this && this.__exportStar) || function(m, exports) {
|
|
19
|
+
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
|
|
20
|
+
};
|
|
21
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
22
|
+
// Core logging utilities
|
|
23
|
+
__exportStar(require("./console"), exports);
|
|
24
|
+
__exportStar(require("./formatter"), exports);
|
|
25
|
+
__exportStar(require("./parser"), exports);
|
|
26
|
+
__exportStar(require("./buffer"), exports);
|
|
27
|
+
__exportStar(require("./file-writer"), exports);
|
|
28
|
+
// Re-export types
|
|
29
|
+
__exportStar(require("../../types/logging"), exports);
|
|
30
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/services/logging/index.ts"],"names":[],"mappings":";AAAA;;;;GAIG;;;;;;;;;;;;;;;;AAEH,yBAAyB;AACzB,4CAA0B;AAC1B,8CAA4B;AAC5B,2CAAyB;AACzB,2CAAyB;AACzB,gDAA8B;AAE9B,kBAAkB;AAClB,sDAAoC"}
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Log Parser - Parse cursor-agent streaming output
|
|
3
|
+
*
|
|
4
|
+
* Parses JSON output from cursor-agent and combines tokens into readable messages.
|
|
5
|
+
*/
|
|
6
|
+
import { ParsedMessage } from '../../types/logging';
|
|
7
|
+
/**
|
|
8
|
+
* Streaming message parser for cursor-agent output
|
|
9
|
+
*/
|
|
10
|
+
export declare class StreamingMessageParser {
|
|
11
|
+
private currentMessage;
|
|
12
|
+
private currentRole;
|
|
13
|
+
private messageStartTime;
|
|
14
|
+
private onMessage;
|
|
15
|
+
constructor(onMessage: (msg: ParsedMessage) => void);
|
|
16
|
+
/**
|
|
17
|
+
* Parse a line of JSON output
|
|
18
|
+
*/
|
|
19
|
+
parseLine(line: string): void;
|
|
20
|
+
private handleJsonMessage;
|
|
21
|
+
private extractTextContent;
|
|
22
|
+
/**
|
|
23
|
+
* Flush accumulated message
|
|
24
|
+
*/
|
|
25
|
+
flush(): void;
|
|
26
|
+
private emitMessage;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Parse a raw JSON log file line by line
|
|
30
|
+
*/
|
|
31
|
+
export declare function parseJsonLogLine(line: string): ParsedMessage | null;
|
|
@@ -0,0 +1,222 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
/**
|
|
3
|
+
* Log Parser - Parse cursor-agent streaming output
|
|
4
|
+
*
|
|
5
|
+
* Parses JSON output from cursor-agent and combines tokens into readable messages.
|
|
6
|
+
*/
|
|
7
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
8
|
+
exports.StreamingMessageParser = void 0;
|
|
9
|
+
exports.parseJsonLogLine = parseJsonLogLine;
|
|
10
|
+
/**
|
|
11
|
+
* Streaming message parser for cursor-agent output
|
|
12
|
+
*/
|
|
13
|
+
class StreamingMessageParser {
|
|
14
|
+
currentMessage = '';
|
|
15
|
+
currentRole = '';
|
|
16
|
+
messageStartTime = 0;
|
|
17
|
+
onMessage;
|
|
18
|
+
constructor(onMessage) {
|
|
19
|
+
this.onMessage = onMessage;
|
|
20
|
+
}
|
|
21
|
+
/**
|
|
22
|
+
* Parse a line of JSON output
|
|
23
|
+
*/
|
|
24
|
+
parseLine(line) {
|
|
25
|
+
const trimmed = line.trim();
|
|
26
|
+
if (!trimmed || !trimmed.startsWith('{'))
|
|
27
|
+
return;
|
|
28
|
+
try {
|
|
29
|
+
const json = JSON.parse(trimmed);
|
|
30
|
+
this.handleJsonMessage(json);
|
|
31
|
+
}
|
|
32
|
+
catch {
|
|
33
|
+
// Not valid JSON, ignore
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
handleJsonMessage(json) {
|
|
37
|
+
const type = json.type;
|
|
38
|
+
switch (type) {
|
|
39
|
+
case 'system':
|
|
40
|
+
this.emitMessage({
|
|
41
|
+
type: 'system',
|
|
42
|
+
role: 'system',
|
|
43
|
+
content: `[System] Model: ${json.model || 'unknown'}, Mode: ${json.permissionMode || 'default'}`,
|
|
44
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
45
|
+
});
|
|
46
|
+
break;
|
|
47
|
+
case 'user':
|
|
48
|
+
if (json.message?.content) {
|
|
49
|
+
const textContent = this.extractTextContent(json.message.content);
|
|
50
|
+
this.emitMessage({
|
|
51
|
+
type: 'user',
|
|
52
|
+
role: 'user',
|
|
53
|
+
content: textContent,
|
|
54
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
55
|
+
});
|
|
56
|
+
}
|
|
57
|
+
break;
|
|
58
|
+
case 'assistant':
|
|
59
|
+
if (json.message?.content) {
|
|
60
|
+
const textContent = this.extractTextContent(json.message.content);
|
|
61
|
+
if (this.currentRole !== 'assistant') {
|
|
62
|
+
this.flush();
|
|
63
|
+
this.currentRole = 'assistant';
|
|
64
|
+
this.messageStartTime = json.timestamp_ms || Date.now();
|
|
65
|
+
}
|
|
66
|
+
this.currentMessage += textContent;
|
|
67
|
+
}
|
|
68
|
+
break;
|
|
69
|
+
case 'tool_call':
|
|
70
|
+
if (json.subtype === 'started' && json.tool_call) {
|
|
71
|
+
const toolName = Object.keys(json.tool_call)[0] || 'unknown';
|
|
72
|
+
const toolArgs = json.tool_call[toolName]?.args || {};
|
|
73
|
+
this.flush();
|
|
74
|
+
this.emitMessage({
|
|
75
|
+
type: 'tool',
|
|
76
|
+
role: 'tool',
|
|
77
|
+
content: `[Tool: ${toolName}] ${JSON.stringify(toolArgs)}`,
|
|
78
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
79
|
+
metadata: { callId: json.call_id, toolName },
|
|
80
|
+
});
|
|
81
|
+
}
|
|
82
|
+
else if (json.subtype === 'completed' && json.tool_call) {
|
|
83
|
+
const toolName = Object.keys(json.tool_call)[0] || 'unknown';
|
|
84
|
+
const result = json.tool_call[toolName]?.result;
|
|
85
|
+
if (result?.success) {
|
|
86
|
+
const content = result.success.content || '';
|
|
87
|
+
const truncated = content.length > 500
|
|
88
|
+
? content.substring(0, 500) + '... (truncated)'
|
|
89
|
+
: content;
|
|
90
|
+
this.emitMessage({
|
|
91
|
+
type: 'tool_result',
|
|
92
|
+
role: 'tool',
|
|
93
|
+
content: `[Tool Result: ${toolName}] ${truncated}`,
|
|
94
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
95
|
+
metadata: { callId: json.call_id, toolName, lines: result.success.totalLines },
|
|
96
|
+
});
|
|
97
|
+
}
|
|
98
|
+
}
|
|
99
|
+
break;
|
|
100
|
+
case 'result':
|
|
101
|
+
this.flush();
|
|
102
|
+
this.emitMessage({
|
|
103
|
+
type: 'result',
|
|
104
|
+
role: 'assistant',
|
|
105
|
+
content: json.result || '',
|
|
106
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
107
|
+
metadata: {
|
|
108
|
+
duration_ms: json.duration_ms,
|
|
109
|
+
is_error: json.is_error,
|
|
110
|
+
subtype: json.subtype,
|
|
111
|
+
},
|
|
112
|
+
});
|
|
113
|
+
break;
|
|
114
|
+
case 'thinking':
|
|
115
|
+
if (json.subtype === 'delta' && json.text) {
|
|
116
|
+
if (this.currentRole !== 'thinking') {
|
|
117
|
+
this.flush();
|
|
118
|
+
this.currentRole = 'thinking';
|
|
119
|
+
this.messageStartTime = json.timestamp_ms || Date.now();
|
|
120
|
+
}
|
|
121
|
+
this.currentMessage += json.text;
|
|
122
|
+
}
|
|
123
|
+
else if (json.subtype === 'completed') {
|
|
124
|
+
this.flush();
|
|
125
|
+
}
|
|
126
|
+
break;
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
extractTextContent(content) {
|
|
130
|
+
return content
|
|
131
|
+
.filter((c) => c.type === 'text')
|
|
132
|
+
.map((c) => c.text)
|
|
133
|
+
.join('');
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Flush accumulated message
|
|
137
|
+
*/
|
|
138
|
+
flush() {
|
|
139
|
+
if (this.currentMessage && this.currentRole) {
|
|
140
|
+
this.emitMessage({
|
|
141
|
+
type: this.currentRole,
|
|
142
|
+
role: this.currentRole,
|
|
143
|
+
content: this.currentMessage,
|
|
144
|
+
timestamp: this.messageStartTime,
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
this.currentMessage = '';
|
|
148
|
+
this.currentRole = '';
|
|
149
|
+
this.messageStartTime = 0;
|
|
150
|
+
}
|
|
151
|
+
emitMessage(msg) {
|
|
152
|
+
if (msg.content.trim()) {
|
|
153
|
+
this.onMessage(msg);
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
exports.StreamingMessageParser = StreamingMessageParser;
|
|
158
|
+
/**
|
|
159
|
+
* Parse a raw JSON log file line by line
|
|
160
|
+
*/
|
|
161
|
+
function parseJsonLogLine(line) {
|
|
162
|
+
const trimmed = line.trim();
|
|
163
|
+
if (!trimmed || !trimmed.startsWith('{'))
|
|
164
|
+
return null;
|
|
165
|
+
try {
|
|
166
|
+
const json = JSON.parse(trimmed);
|
|
167
|
+
return parseJsonToMessage(json);
|
|
168
|
+
}
|
|
169
|
+
catch {
|
|
170
|
+
return null;
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
function parseJsonToMessage(json) {
|
|
174
|
+
const type = json.type;
|
|
175
|
+
if (!type)
|
|
176
|
+
return null;
|
|
177
|
+
let messageType;
|
|
178
|
+
let content = '';
|
|
179
|
+
if (type === 'thinking' && (json.text || json.thought)) {
|
|
180
|
+
content = json.text || json.thought;
|
|
181
|
+
messageType = 'thinking';
|
|
182
|
+
}
|
|
183
|
+
else if (type === 'assistant' && json.message?.content) {
|
|
184
|
+
content = json.message.content
|
|
185
|
+
.filter((c) => c.type === 'text')
|
|
186
|
+
.map((c) => c.text)
|
|
187
|
+
.join('');
|
|
188
|
+
messageType = 'assistant';
|
|
189
|
+
}
|
|
190
|
+
else if (type === 'user' && json.message?.content) {
|
|
191
|
+
content = json.message.content
|
|
192
|
+
.filter((c) => c.type === 'text')
|
|
193
|
+
.map((c) => c.text)
|
|
194
|
+
.join('');
|
|
195
|
+
messageType = 'user';
|
|
196
|
+
}
|
|
197
|
+
else if (type === 'tool_call' && json.subtype === 'started') {
|
|
198
|
+
const toolName = Object.keys(json.tool_call)[0] || 'unknown';
|
|
199
|
+
const args = json.tool_call[toolName]?.args || {};
|
|
200
|
+
content = `[Tool: ${toolName}] ${JSON.stringify(args)}`;
|
|
201
|
+
messageType = 'tool';
|
|
202
|
+
}
|
|
203
|
+
else if (type === 'tool_call' && json.subtype === 'completed') {
|
|
204
|
+
const toolName = Object.keys(json.tool_call)[0] || 'unknown';
|
|
205
|
+
content = `[Tool Result: ${toolName}]`;
|
|
206
|
+
messageType = 'tool_result';
|
|
207
|
+
}
|
|
208
|
+
else if (type === 'result') {
|
|
209
|
+
content = json.result || 'Task completed';
|
|
210
|
+
messageType = 'result';
|
|
211
|
+
}
|
|
212
|
+
else {
|
|
213
|
+
return null;
|
|
214
|
+
}
|
|
215
|
+
return {
|
|
216
|
+
type: messageType,
|
|
217
|
+
role: messageType,
|
|
218
|
+
content,
|
|
219
|
+
timestamp: json.timestamp_ms || Date.now(),
|
|
220
|
+
};
|
|
221
|
+
}
|
|
222
|
+
//# sourceMappingURL=parser.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"parser.js","sourceRoot":"","sources":["../../../src/services/logging/parser.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,59 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Process Management Service
|
|
3
|
+
*
|
|
4
|
+
* Utilities for detecting and managing lane processes.
|
|
5
|
+
*/
|
|
6
|
+
export interface ProcessInfo {
|
|
7
|
+
pid: number;
|
|
8
|
+
exists: boolean;
|
|
9
|
+
isRunning: boolean;
|
|
10
|
+
command?: string;
|
|
11
|
+
uptime?: number;
|
|
12
|
+
cpuPercent?: number;
|
|
13
|
+
memoryMb?: number;
|
|
14
|
+
}
|
|
15
|
+
export interface LaneProcessStatus {
|
|
16
|
+
laneName: string;
|
|
17
|
+
pid: number | null;
|
|
18
|
+
processExists: boolean;
|
|
19
|
+
processRunning: boolean;
|
|
20
|
+
stateStatus: string;
|
|
21
|
+
actualStatus: 'running' | 'dead' | 'unknown' | 'completed' | 'failed' | 'pending';
|
|
22
|
+
startTime: number | null;
|
|
23
|
+
endTime: number | null;
|
|
24
|
+
duration: number;
|
|
25
|
+
isStale: boolean;
|
|
26
|
+
processInfo?: ProcessInfo;
|
|
27
|
+
}
|
|
28
|
+
/**
|
|
29
|
+
* Check if a process exists and is running
|
|
30
|
+
*/
|
|
31
|
+
export declare function checkProcess(pid: number): ProcessInfo;
|
|
32
|
+
/**
|
|
33
|
+
* Get accurate lane process status
|
|
34
|
+
*/
|
|
35
|
+
export declare function getLaneProcessStatus(lanePath: string, laneName: string): LaneProcessStatus;
|
|
36
|
+
/**
|
|
37
|
+
* Get all lane process statuses for a run directory
|
|
38
|
+
*/
|
|
39
|
+
export declare function getAllLaneProcessStatuses(runDir: string): LaneProcessStatus[];
|
|
40
|
+
/**
|
|
41
|
+
* Check if any flow process is alive
|
|
42
|
+
*/
|
|
43
|
+
export declare function isFlowAlive(runDir: string): boolean;
|
|
44
|
+
/**
|
|
45
|
+
* Get flow status summary
|
|
46
|
+
*/
|
|
47
|
+
export declare function getFlowSummary(runDir: string): {
|
|
48
|
+
total: number;
|
|
49
|
+
running: number;
|
|
50
|
+
completed: number;
|
|
51
|
+
failed: number;
|
|
52
|
+
pending: number;
|
|
53
|
+
dead: number;
|
|
54
|
+
isAlive: boolean;
|
|
55
|
+
};
|
|
56
|
+
/**
|
|
57
|
+
* Kill a lane process
|
|
58
|
+
*/
|
|
59
|
+
export declare function killLaneProcess(pid: number, signal?: NodeJS.Signals): boolean;
|