@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.
Files changed (224) hide show
  1. package/CHANGELOG.md +20 -0
  2. package/commands/cursorflow-clean.md +19 -0
  3. package/commands/cursorflow-runs.md +59 -0
  4. package/commands/cursorflow-stop.md +55 -0
  5. package/dist/cli/clean.js +171 -0
  6. package/dist/cli/clean.js.map +1 -1
  7. package/dist/cli/index.js +7 -0
  8. package/dist/cli/index.js.map +1 -1
  9. package/dist/cli/init.js +1 -1
  10. package/dist/cli/init.js.map +1 -1
  11. package/dist/cli/logs.js +83 -42
  12. package/dist/cli/logs.js.map +1 -1
  13. package/dist/cli/monitor.d.ts +7 -0
  14. package/dist/cli/monitor.js +1007 -189
  15. package/dist/cli/monitor.js.map +1 -1
  16. package/dist/cli/prepare.js +87 -3
  17. package/dist/cli/prepare.js.map +1 -1
  18. package/dist/cli/resume.js +188 -236
  19. package/dist/cli/resume.js.map +1 -1
  20. package/dist/cli/run.js +125 -3
  21. package/dist/cli/run.js.map +1 -1
  22. package/dist/cli/runs.d.ts +5 -0
  23. package/dist/cli/runs.js +214 -0
  24. package/dist/cli/runs.js.map +1 -0
  25. package/dist/cli/setup-commands.js +0 -0
  26. package/dist/cli/signal.js +1 -1
  27. package/dist/cli/signal.js.map +1 -1
  28. package/dist/cli/stop.d.ts +5 -0
  29. package/dist/cli/stop.js +215 -0
  30. package/dist/cli/stop.js.map +1 -0
  31. package/dist/cli/tasks.d.ts +10 -0
  32. package/dist/cli/tasks.js +165 -0
  33. package/dist/cli/tasks.js.map +1 -0
  34. package/dist/core/auto-recovery.d.ts +212 -0
  35. package/dist/core/auto-recovery.js +737 -0
  36. package/dist/core/auto-recovery.js.map +1 -0
  37. package/dist/core/failure-policy.d.ts +156 -0
  38. package/dist/core/failure-policy.js +488 -0
  39. package/dist/core/failure-policy.js.map +1 -0
  40. package/dist/core/orchestrator.d.ts +15 -2
  41. package/dist/core/orchestrator.js +397 -15
  42. package/dist/core/orchestrator.js.map +1 -1
  43. package/dist/core/reviewer.d.ts +2 -0
  44. package/dist/core/reviewer.js +2 -0
  45. package/dist/core/reviewer.js.map +1 -1
  46. package/dist/core/runner.d.ts +33 -10
  47. package/dist/core/runner.js +321 -146
  48. package/dist/core/runner.js.map +1 -1
  49. package/dist/services/logging/buffer.d.ts +67 -0
  50. package/dist/services/logging/buffer.js +309 -0
  51. package/dist/services/logging/buffer.js.map +1 -0
  52. package/dist/services/logging/console.d.ts +89 -0
  53. package/dist/services/logging/console.js +169 -0
  54. package/dist/services/logging/console.js.map +1 -0
  55. package/dist/services/logging/file-writer.d.ts +71 -0
  56. package/dist/services/logging/file-writer.js +516 -0
  57. package/dist/services/logging/file-writer.js.map +1 -0
  58. package/dist/services/logging/formatter.d.ts +39 -0
  59. package/dist/services/logging/formatter.js +227 -0
  60. package/dist/services/logging/formatter.js.map +1 -0
  61. package/dist/services/logging/index.d.ts +11 -0
  62. package/dist/services/logging/index.js +30 -0
  63. package/dist/services/logging/index.js.map +1 -0
  64. package/dist/services/logging/parser.d.ts +31 -0
  65. package/dist/services/logging/parser.js +222 -0
  66. package/dist/services/logging/parser.js.map +1 -0
  67. package/dist/services/process/index.d.ts +59 -0
  68. package/dist/services/process/index.js +257 -0
  69. package/dist/services/process/index.js.map +1 -0
  70. package/dist/types/agent.d.ts +20 -0
  71. package/dist/types/agent.js +6 -0
  72. package/dist/types/agent.js.map +1 -0
  73. package/dist/types/config.d.ts +65 -0
  74. package/dist/types/config.js +6 -0
  75. package/dist/types/config.js.map +1 -0
  76. package/dist/types/events.d.ts +125 -0
  77. package/dist/types/events.js +6 -0
  78. package/dist/types/events.js.map +1 -0
  79. package/dist/types/index.d.ts +12 -0
  80. package/dist/types/index.js +37 -0
  81. package/dist/types/index.js.map +1 -0
  82. package/dist/types/lane.d.ts +43 -0
  83. package/dist/types/lane.js +6 -0
  84. package/dist/types/lane.js.map +1 -0
  85. package/dist/types/logging.d.ts +71 -0
  86. package/dist/types/logging.js +16 -0
  87. package/dist/types/logging.js.map +1 -0
  88. package/dist/types/review.d.ts +17 -0
  89. package/dist/types/review.js +6 -0
  90. package/dist/types/review.js.map +1 -0
  91. package/dist/types/run.d.ts +32 -0
  92. package/dist/types/run.js +6 -0
  93. package/dist/types/run.js.map +1 -0
  94. package/dist/types/task.d.ts +71 -0
  95. package/dist/types/task.js +6 -0
  96. package/dist/types/task.js.map +1 -0
  97. package/dist/ui/components.d.ts +134 -0
  98. package/dist/ui/components.js +389 -0
  99. package/dist/ui/components.js.map +1 -0
  100. package/dist/ui/log-viewer.d.ts +49 -0
  101. package/dist/ui/log-viewer.js +449 -0
  102. package/dist/ui/log-viewer.js.map +1 -0
  103. package/dist/utils/checkpoint.d.ts +87 -0
  104. package/dist/utils/checkpoint.js +317 -0
  105. package/dist/utils/checkpoint.js.map +1 -0
  106. package/dist/utils/config.d.ts +4 -0
  107. package/dist/utils/config.js +11 -2
  108. package/dist/utils/config.js.map +1 -1
  109. package/dist/utils/cursor-agent.js.map +1 -1
  110. package/dist/utils/dependency.d.ts +74 -0
  111. package/dist/utils/dependency.js +420 -0
  112. package/dist/utils/dependency.js.map +1 -0
  113. package/dist/utils/doctor.js +10 -5
  114. package/dist/utils/doctor.js.map +1 -1
  115. package/dist/utils/enhanced-logger.d.ts +10 -33
  116. package/dist/utils/enhanced-logger.js +94 -9
  117. package/dist/utils/enhanced-logger.js.map +1 -1
  118. package/dist/utils/git.d.ts +121 -0
  119. package/dist/utils/git.js +322 -2
  120. package/dist/utils/git.js.map +1 -1
  121. package/dist/utils/health.d.ts +91 -0
  122. package/dist/utils/health.js +556 -0
  123. package/dist/utils/health.js.map +1 -0
  124. package/dist/utils/lock.d.ts +95 -0
  125. package/dist/utils/lock.js +332 -0
  126. package/dist/utils/lock.js.map +1 -0
  127. package/dist/utils/log-buffer.d.ts +17 -0
  128. package/dist/utils/log-buffer.js +14 -0
  129. package/dist/utils/log-buffer.js.map +1 -0
  130. package/dist/utils/log-constants.d.ts +23 -0
  131. package/dist/utils/log-constants.js +28 -0
  132. package/dist/utils/log-constants.js.map +1 -0
  133. package/dist/utils/log-formatter.d.ts +9 -0
  134. package/dist/utils/log-formatter.js +113 -70
  135. package/dist/utils/log-formatter.js.map +1 -1
  136. package/dist/utils/log-service.d.ts +19 -0
  137. package/dist/utils/log-service.js +47 -0
  138. package/dist/utils/log-service.js.map +1 -0
  139. package/dist/utils/logger.d.ts +46 -27
  140. package/dist/utils/logger.js +82 -60
  141. package/dist/utils/logger.js.map +1 -1
  142. package/dist/utils/process-manager.d.ts +21 -0
  143. package/dist/utils/process-manager.js +138 -0
  144. package/dist/utils/process-manager.js.map +1 -0
  145. package/dist/utils/retry.d.ts +121 -0
  146. package/dist/utils/retry.js +374 -0
  147. package/dist/utils/retry.js.map +1 -0
  148. package/dist/utils/run-service.d.ts +88 -0
  149. package/dist/utils/run-service.js +412 -0
  150. package/dist/utils/run-service.js.map +1 -0
  151. package/dist/utils/state.d.ts +58 -2
  152. package/dist/utils/state.js +306 -3
  153. package/dist/utils/state.js.map +1 -1
  154. package/dist/utils/task-service.d.ts +82 -0
  155. package/dist/utils/task-service.js +348 -0
  156. package/dist/utils/task-service.js.map +1 -0
  157. package/dist/utils/types.d.ts +2 -272
  158. package/dist/utils/types.js +16 -0
  159. package/dist/utils/types.js.map +1 -1
  160. package/package.json +38 -23
  161. package/scripts/ai-security-check.js +0 -1
  162. package/scripts/local-security-gate.sh +0 -0
  163. package/scripts/monitor-lanes.sh +94 -0
  164. package/scripts/patches/test-cursor-agent.js +0 -1
  165. package/scripts/release.sh +0 -0
  166. package/scripts/setup-security.sh +0 -0
  167. package/scripts/stream-logs.sh +72 -0
  168. package/scripts/verify-and-fix.sh +0 -0
  169. package/src/cli/clean.ts +180 -0
  170. package/src/cli/index.ts +7 -0
  171. package/src/cli/init.ts +1 -1
  172. package/src/cli/logs.ts +79 -42
  173. package/src/cli/monitor.ts +1815 -899
  174. package/src/cli/prepare.ts +97 -3
  175. package/src/cli/resume.ts +220 -277
  176. package/src/cli/run.ts +154 -3
  177. package/src/cli/runs.ts +212 -0
  178. package/src/cli/setup-commands.ts +0 -0
  179. package/src/cli/signal.ts +1 -1
  180. package/src/cli/stop.ts +209 -0
  181. package/src/cli/tasks.ts +154 -0
  182. package/src/core/auto-recovery.ts +909 -0
  183. package/src/core/failure-policy.ts +592 -0
  184. package/src/core/orchestrator.ts +1136 -675
  185. package/src/core/reviewer.ts +4 -0
  186. package/src/core/runner.ts +1443 -1217
  187. package/src/services/logging/buffer.ts +326 -0
  188. package/src/services/logging/console.ts +193 -0
  189. package/src/services/logging/file-writer.ts +526 -0
  190. package/src/services/logging/formatter.ts +268 -0
  191. package/src/services/logging/index.ts +16 -0
  192. package/src/services/logging/parser.ts +232 -0
  193. package/src/services/process/index.ts +261 -0
  194. package/src/types/agent.ts +24 -0
  195. package/src/types/config.ts +79 -0
  196. package/src/types/events.ts +156 -0
  197. package/src/types/index.ts +29 -0
  198. package/src/types/lane.ts +56 -0
  199. package/src/types/logging.ts +96 -0
  200. package/src/types/review.ts +20 -0
  201. package/src/types/run.ts +37 -0
  202. package/src/types/task.ts +79 -0
  203. package/src/ui/components.ts +430 -0
  204. package/src/ui/log-viewer.ts +485 -0
  205. package/src/utils/checkpoint.ts +374 -0
  206. package/src/utils/config.ts +11 -2
  207. package/src/utils/cursor-agent.ts +1 -1
  208. package/src/utils/dependency.ts +482 -0
  209. package/src/utils/doctor.ts +11 -5
  210. package/src/utils/enhanced-logger.ts +108 -49
  211. package/src/utils/git.ts +871 -499
  212. package/src/utils/health.ts +596 -0
  213. package/src/utils/lock.ts +346 -0
  214. package/src/utils/log-buffer.ts +28 -0
  215. package/src/utils/log-constants.ts +26 -0
  216. package/src/utils/log-formatter.ts +120 -37
  217. package/src/utils/log-service.ts +49 -0
  218. package/src/utils/logger.ts +100 -51
  219. package/src/utils/process-manager.ts +100 -0
  220. package/src/utils/retry.ts +413 -0
  221. package/src/utils/run-service.ts +433 -0
  222. package/src/utils/state.ts +369 -3
  223. package/src/utils/task-service.ts +370 -0
  224. 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;