@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,516 @@
1
+ "use strict";
2
+ /**
3
+ * Log File Writer - Write logs to files with rotation
4
+ *
5
+ * Manages log file writing with support for multiple formats.
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 __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
19
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
20
+ }) : function(o, v) {
21
+ o["default"] = v;
22
+ });
23
+ var __importStar = (this && this.__importStar) || (function () {
24
+ var ownKeys = function(o) {
25
+ ownKeys = Object.getOwnPropertyNames || function (o) {
26
+ var ar = [];
27
+ for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k;
28
+ return ar;
29
+ };
30
+ return ownKeys(o);
31
+ };
32
+ return function (mod) {
33
+ if (mod && mod.__esModule) return mod;
34
+ var result = {};
35
+ if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]);
36
+ __setModuleDefault(result, mod);
37
+ return result;
38
+ };
39
+ })();
40
+ Object.defineProperty(exports, "__esModule", { value: true });
41
+ exports.EnhancedLogManager = exports.CleanLogTransform = exports.DEFAULT_LOG_CONFIG = void 0;
42
+ exports.createLogManager = createLogManager;
43
+ const fs = __importStar(require("fs"));
44
+ const path = __importStar(require("path"));
45
+ const stream_1 = require("stream");
46
+ const parser_1 = require("./parser");
47
+ const formatter_1 = require("./formatter");
48
+ exports.DEFAULT_LOG_CONFIG = {
49
+ enabled: true,
50
+ stripAnsi: true,
51
+ addTimestamps: true,
52
+ maxFileSize: 50 * 1024 * 1024,
53
+ maxFiles: 5,
54
+ keepRawLogs: true,
55
+ writeJsonLog: true,
56
+ timestampFormat: 'iso',
57
+ };
58
+ /**
59
+ * Transform stream for clean log output
60
+ */
61
+ class CleanLogTransform extends stream_1.Transform {
62
+ config;
63
+ session;
64
+ buffer = '';
65
+ constructor(config, session) {
66
+ super({ encoding: 'utf8' });
67
+ this.config = config;
68
+ this.session = session;
69
+ }
70
+ _transform(chunk, _encoding, callback) {
71
+ let text = chunk.toString();
72
+ this.buffer += text;
73
+ const lines = this.buffer.split('\n');
74
+ this.buffer = lines.pop() || '';
75
+ for (const line of lines) {
76
+ let processed = line;
77
+ if (this.config.stripAnsi)
78
+ processed = (0, formatter_1.stripAnsi)(processed);
79
+ if (this.config.addTimestamps && processed.trim() && !this.hasTimestamp(processed)) {
80
+ const ts = (0, formatter_1.formatTimestampISO)(this.config.timestampFormat, this.session.startTime);
81
+ processed = `[${ts}] ${processed}`;
82
+ }
83
+ this.push(processed + '\n');
84
+ }
85
+ callback();
86
+ }
87
+ _flush(callback) {
88
+ if (this.buffer.trim()) {
89
+ let processed = this.buffer;
90
+ if (this.config.stripAnsi)
91
+ processed = (0, formatter_1.stripAnsi)(processed);
92
+ if (this.config.addTimestamps && processed.trim() && !this.hasTimestamp(processed)) {
93
+ const ts = (0, formatter_1.formatTimestampISO)(this.config.timestampFormat, this.session.startTime);
94
+ processed = `[${ts}] ${processed}`;
95
+ }
96
+ this.push(processed + '\n');
97
+ }
98
+ callback();
99
+ }
100
+ hasTimestamp(line) {
101
+ return /^\[\d{4}-\d{2}-\d{2}T\d{2}:\d{2}:\d{2}/.test(line.trim());
102
+ }
103
+ }
104
+ exports.CleanLogTransform = CleanLogTransform;
105
+ /**
106
+ * Enhanced Log Manager - Handles all log file operations
107
+ */
108
+ class EnhancedLogManager {
109
+ config;
110
+ session;
111
+ logDir;
112
+ cleanLogPath;
113
+ rawLogPath;
114
+ jsonLogPath;
115
+ readableLogPath;
116
+ cleanLogFd = null;
117
+ rawLogFd = null;
118
+ jsonLogFd = null;
119
+ readableLogFd = null;
120
+ cleanLogSize = 0;
121
+ rawLogSize = 0;
122
+ cleanTransform = null;
123
+ streamingParser = null;
124
+ lineBuffer = '';
125
+ onParsedMessage;
126
+ constructor(logDir, session, config = {}, onParsedMessage) {
127
+ this.config = { ...exports.DEFAULT_LOG_CONFIG, ...config };
128
+ this.session = session;
129
+ this.logDir = logDir;
130
+ this.onParsedMessage = onParsedMessage;
131
+ fs.mkdirSync(logDir, { recursive: true });
132
+ this.cleanLogPath = path.join(logDir, 'terminal.log');
133
+ this.rawLogPath = path.join(logDir, 'terminal-raw.log');
134
+ this.jsonLogPath = path.join(logDir, 'terminal.jsonl');
135
+ this.readableLogPath = path.join(logDir, 'terminal-readable.log');
136
+ this.initLogFiles();
137
+ }
138
+ initLogFiles() {
139
+ this.rotateIfNeeded(this.cleanLogPath);
140
+ if (this.config.keepRawLogs)
141
+ this.rotateIfNeeded(this.rawLogPath);
142
+ this.cleanLogFd = fs.openSync(this.cleanLogPath, 'a');
143
+ if (this.config.keepRawLogs)
144
+ this.rawLogFd = fs.openSync(this.rawLogPath, 'a');
145
+ if (this.config.writeJsonLog)
146
+ this.jsonLogFd = fs.openSync(this.jsonLogPath, 'a');
147
+ this.readableLogFd = fs.openSync(this.readableLogPath, 'a');
148
+ try {
149
+ this.cleanLogSize = fs.statSync(this.cleanLogPath).size;
150
+ if (this.config.keepRawLogs)
151
+ this.rawLogSize = fs.statSync(this.rawLogPath).size;
152
+ }
153
+ catch {
154
+ this.cleanLogSize = 0;
155
+ this.rawLogSize = 0;
156
+ }
157
+ this.writeSessionHeader();
158
+ this.cleanTransform = new CleanLogTransform(this.config, this.session);
159
+ this.cleanTransform.on('data', (data) => this.writeToCleanLog(data));
160
+ this.streamingParser = new parser_1.StreamingMessageParser(msg => {
161
+ this.writeReadableMessage(msg);
162
+ if (this.onParsedMessage)
163
+ this.onParsedMessage(msg);
164
+ });
165
+ }
166
+ writeSessionHeader() {
167
+ const header = `
168
+ ╔══════════════════════════════════════════════════════════════════════════════╗
169
+ ║ CursorFlow Session Log ║
170
+ ╠══════════════════════════════════════════════════════════════════════════════╣
171
+ ║ Session ID: ${this.session.id.padEnd(62)}║
172
+ ║ Lane: ${this.session.laneName.padEnd(62)}║
173
+ ║ Task: ${(this.session.taskName || '-').padEnd(62)}║
174
+ ║ Model: ${(this.session.model || 'default').padEnd(62)}║
175
+ ║ Started: ${new Date(this.session.startTime).toISOString().padEnd(62)}║
176
+ ╚══════════════════════════════════════════════════════════════════════════════╝
177
+
178
+ `;
179
+ this.writeToCleanLog(header);
180
+ if (this.config.keepRawLogs && this.rawLogFd !== null) {
181
+ fs.writeSync(this.rawLogFd, header);
182
+ }
183
+ this.writeJsonEntry({
184
+ timestamp: new Date(this.session.startTime).toISOString(),
185
+ level: 'session',
186
+ source: 'system',
187
+ lane: this.session.laneName,
188
+ task: this.session.taskName,
189
+ message: 'Session started',
190
+ metadata: { sessionId: this.session.id, model: this.session.model, ...this.session.metadata },
191
+ });
192
+ }
193
+ writeReadableMessage(msg) {
194
+ if (this.readableLogFd === null)
195
+ return;
196
+ const ts = new Date(msg.timestamp).toISOString();
197
+ let formatted;
198
+ switch (msg.type) {
199
+ case 'system':
200
+ formatted = `[${ts}] ⚙️ SYSTEM: ${msg.content}\n`;
201
+ break;
202
+ case 'user':
203
+ case 'assistant':
204
+ case 'result': {
205
+ const isUser = msg.type === 'user';
206
+ const isResult = msg.type === 'result';
207
+ const headerText = isUser ? '🧑 USER' : isResult ? '🤖 ASSISTANT (Final)' : '🤖 ASSISTANT';
208
+ const duration = msg.metadata?.duration_ms ? ` (${Math.round(msg.metadata.duration_ms / 1000)}s)` : '';
209
+ const label = `[ ${headerText}${duration} ] `;
210
+ const totalWidth = 80;
211
+ const topBorder = `┌─${label}${'─'.repeat(Math.max(0, totalWidth - label.length - 2))}`;
212
+ const bottomBorder = `└─${'─'.repeat(totalWidth - 2)}`;
213
+ formatted = `[${ts}] ${topBorder}\n`;
214
+ for (const line of msg.content.split('\n')) {
215
+ formatted += `[${ts}] │ ${line}\n`;
216
+ }
217
+ formatted += `[${ts}] ${bottomBorder}\n`;
218
+ break;
219
+ }
220
+ case 'tool':
221
+ formatted = `[${ts}] 🔧 TOOL: ${msg.content}\n`;
222
+ break;
223
+ case 'tool_result': {
224
+ const lines = msg.metadata?.lines ? ` (${msg.metadata.lines} lines)` : '';
225
+ formatted = `[${ts}] 📄 RESL: ${msg.metadata?.toolName || 'Tool'}${lines}\n`;
226
+ break;
227
+ }
228
+ case 'thinking': {
229
+ const thinkLabel = `[ 🤔 THINKING ] `;
230
+ const thinkWidth = 80;
231
+ const thinkTop = `┌─${thinkLabel}${'─'.repeat(Math.max(0, thinkWidth - thinkLabel.length - 2))}`;
232
+ const thinkBottom = `└─${'─'.repeat(thinkWidth - 2)}`;
233
+ formatted = `[${ts}] ${thinkTop}\n`;
234
+ for (const line of msg.content.trim().split('\n')) {
235
+ formatted += `[${ts}] │ ${line}\n`;
236
+ }
237
+ formatted += `[${ts}] ${thinkBottom}\n`;
238
+ break;
239
+ }
240
+ default:
241
+ formatted = `[${ts}] ${msg.content}\n`;
242
+ }
243
+ try {
244
+ fs.writeSync(this.readableLogFd, formatted);
245
+ }
246
+ catch { /* Ignore write errors */ }
247
+ }
248
+ rotateIfNeeded(logPath) {
249
+ if (!fs.existsSync(logPath))
250
+ return;
251
+ try {
252
+ if (fs.statSync(logPath).size >= this.config.maxFileSize) {
253
+ this.rotateLog(logPath);
254
+ }
255
+ }
256
+ catch { /* Ignore */ }
257
+ }
258
+ rotateLog(logPath) {
259
+ const dir = path.dirname(logPath);
260
+ const ext = path.extname(logPath);
261
+ const base = path.basename(logPath, ext);
262
+ for (let i = this.config.maxFiles - 1; i >= 1; i--) {
263
+ const oldPath = path.join(dir, `${base}.${i}${ext}`);
264
+ const newPath = path.join(dir, `${base}.${i + 1}${ext}`);
265
+ if (fs.existsSync(oldPath)) {
266
+ if (i === this.config.maxFiles - 1) {
267
+ fs.unlinkSync(oldPath);
268
+ }
269
+ else {
270
+ fs.renameSync(oldPath, newPath);
271
+ }
272
+ }
273
+ }
274
+ fs.renameSync(logPath, path.join(dir, `${base}.1${ext}`));
275
+ }
276
+ writeToCleanLog(data) {
277
+ if (this.cleanLogFd === null)
278
+ return;
279
+ const buffer = Buffer.from(data);
280
+ fs.writeSync(this.cleanLogFd, buffer);
281
+ this.cleanLogSize += buffer.length;
282
+ if (this.cleanLogSize >= this.config.maxFileSize) {
283
+ fs.closeSync(this.cleanLogFd);
284
+ this.rotateLog(this.cleanLogPath);
285
+ this.cleanLogFd = fs.openSync(this.cleanLogPath, 'a');
286
+ this.cleanLogSize = 0;
287
+ }
288
+ }
289
+ writeToRawLog(data) {
290
+ if (this.rawLogFd === null)
291
+ return;
292
+ const buffer = Buffer.from(data);
293
+ fs.writeSync(this.rawLogFd, buffer);
294
+ this.rawLogSize += buffer.length;
295
+ if (this.rawLogSize >= this.config.maxFileSize) {
296
+ fs.closeSync(this.rawLogFd);
297
+ this.rotateLog(this.rawLogPath);
298
+ this.rawLogFd = fs.openSync(this.rawLogPath, 'a');
299
+ this.rawLogSize = 0;
300
+ }
301
+ }
302
+ writeJsonEntry(entry) {
303
+ if (this.jsonLogFd === null)
304
+ return;
305
+ fs.writeSync(this.jsonLogFd, JSON.stringify(entry) + '\n');
306
+ }
307
+ writeStdout(data) {
308
+ const text = data.toString();
309
+ if (this.config.keepRawLogs)
310
+ this.writeToRawLog(text);
311
+ if (this.cleanTransform)
312
+ this.cleanTransform.write(data);
313
+ this.lineBuffer += text;
314
+ const lines = this.lineBuffer.split('\n');
315
+ this.lineBuffer = lines.pop() || '';
316
+ for (const line of lines) {
317
+ const cleanLine = (0, formatter_1.stripAnsi)(line).trim();
318
+ if (!cleanLine)
319
+ continue;
320
+ if (cleanLine.startsWith('{')) {
321
+ if (this.streamingParser)
322
+ this.streamingParser.parseLine(cleanLine);
323
+ if (this.config.writeJsonLog) {
324
+ try {
325
+ const json = JSON.parse(cleanLine);
326
+ this.writeJsonEntry({
327
+ timestamp: new Date().toISOString(),
328
+ level: 'stdout',
329
+ lane: this.session.laneName,
330
+ task: this.session.taskName,
331
+ message: cleanLine.substring(0, 2000),
332
+ metadata: json,
333
+ });
334
+ continue;
335
+ }
336
+ catch { /* Not JSON */ }
337
+ }
338
+ }
339
+ if (this.config.writeJsonLog && !this.isNoise(cleanLine)) {
340
+ this.writeJsonEntry({
341
+ timestamp: new Date().toISOString(),
342
+ level: 'stdout',
343
+ lane: this.session.laneName,
344
+ task: this.session.taskName,
345
+ message: cleanLine.substring(0, 1000),
346
+ });
347
+ }
348
+ }
349
+ }
350
+ writeStderr(data) {
351
+ const text = data.toString();
352
+ if (this.config.keepRawLogs)
353
+ this.writeToRawLog(text);
354
+ if (this.cleanTransform)
355
+ this.cleanTransform.write(data);
356
+ if (this.readableLogFd !== null) {
357
+ for (const line of text.split('\n')) {
358
+ const cleanLine = (0, formatter_1.stripAnsi)(line).trim();
359
+ if (cleanLine && !this.isNoise(cleanLine)) {
360
+ try {
361
+ fs.writeSync(this.readableLogFd, `[${new Date().toISOString()}] ❌ STDERR: ${cleanLine}\n`);
362
+ }
363
+ catch { /* Ignore */ }
364
+ }
365
+ }
366
+ }
367
+ if (this.config.writeJsonLog) {
368
+ const cleanText = (0, formatter_1.stripAnsi)(text).trim();
369
+ if (cleanText) {
370
+ this.writeJsonEntry({
371
+ timestamp: new Date().toISOString(),
372
+ level: 'stderr',
373
+ lane: this.session.laneName,
374
+ task: this.session.taskName,
375
+ message: cleanText.substring(0, 1000),
376
+ });
377
+ }
378
+ }
379
+ }
380
+ log(level, message, metadata) {
381
+ const ts = (0, formatter_1.formatTimestampISO)(this.config.timestampFormat, this.session.startTime);
382
+ const line = `[${ts}] [${level.toUpperCase().padEnd(5)}] ${message}\n`;
383
+ this.writeToCleanLog(line);
384
+ if (this.config.keepRawLogs)
385
+ this.writeToRawLog(line);
386
+ if (this.readableLogFd !== null) {
387
+ const icon = level === 'error' ? '❌ ERROR' : level === 'info' ? 'ℹ️ INFO' : '🔍 DEBUG';
388
+ try {
389
+ fs.writeSync(this.readableLogFd, `${new Date().toISOString()} ${icon}: ${message}\n`);
390
+ }
391
+ catch { /* Ignore */ }
392
+ }
393
+ if (this.config.writeJsonLog) {
394
+ this.writeJsonEntry({
395
+ timestamp: new Date().toISOString(),
396
+ level,
397
+ lane: this.session.laneName,
398
+ task: this.session.taskName,
399
+ message,
400
+ metadata,
401
+ });
402
+ }
403
+ }
404
+ section(title) {
405
+ const divider = '═'.repeat(78);
406
+ const line = `\n${divider}\n ${title}\n${divider}\n`;
407
+ this.writeToCleanLog(line);
408
+ if (this.config.keepRawLogs)
409
+ this.writeToRawLog(line);
410
+ if (this.readableLogFd !== null) {
411
+ const ts = new Date().toISOString();
412
+ try {
413
+ fs.writeSync(this.readableLogFd, `[${ts}] ━━━ ${title} ${'━'.repeat(60)}\n`);
414
+ }
415
+ catch { /* Ignore */ }
416
+ }
417
+ }
418
+ setTask(taskName, model) {
419
+ this.session.taskName = taskName;
420
+ if (model)
421
+ this.session.model = model;
422
+ this.section(`Task: ${taskName}${model ? ` (Model: ${model})` : ''}`);
423
+ if (this.config.writeJsonLog) {
424
+ this.writeJsonEntry({
425
+ timestamp: new Date().toISOString(),
426
+ level: 'info',
427
+ source: 'system',
428
+ lane: this.session.laneName,
429
+ task: taskName,
430
+ message: `Task started: ${taskName}`,
431
+ metadata: { model },
432
+ });
433
+ }
434
+ }
435
+ isNoise(text) {
436
+ if (!text.trim())
437
+ return true;
438
+ const patterns = [/^[\s│├└─┌┐┘┴┬┤]+$/, /^[.\s]+$/, /^[=>\s-]+$/, /^\d+%$/, /^⠋|⠙|⠹|⠸|⠼|⠴|⠦|⠧|⠇|⠏/];
439
+ return patterns.some(p => p.test(text));
440
+ }
441
+ getLogPaths() {
442
+ return {
443
+ clean: this.cleanLogPath,
444
+ raw: this.config.keepRawLogs ? this.rawLogPath : undefined,
445
+ json: this.config.writeJsonLog ? this.jsonLogPath : undefined,
446
+ readable: this.readableLogPath,
447
+ };
448
+ }
449
+ getFileDescriptors() {
450
+ const fd = this.rawLogFd !== null ? this.rawLogFd : this.cleanLogFd;
451
+ return { stdout: fd, stderr: fd };
452
+ }
453
+ close() {
454
+ if (this.cleanTransform)
455
+ this.cleanTransform.end();
456
+ if (this.streamingParser) {
457
+ if (this.lineBuffer.trim())
458
+ this.streamingParser.parseLine(this.lineBuffer);
459
+ this.streamingParser.flush();
460
+ }
461
+ const endMarker = `
462
+ ╔══════════════════════════════════════════════════════════════════════════════╗
463
+ ║ Session Ended: ${new Date().toISOString().padEnd(60)}║
464
+ ║ Duration: ${this.formatDuration(Date.now() - this.session.startTime).padEnd(65)}║
465
+ ╚══════════════════════════════════════════════════════════════════════════════╝
466
+
467
+ `;
468
+ if (this.cleanLogFd !== null) {
469
+ fs.writeSync(this.cleanLogFd, endMarker);
470
+ fs.closeSync(this.cleanLogFd);
471
+ this.cleanLogFd = null;
472
+ }
473
+ if (this.rawLogFd !== null) {
474
+ fs.writeSync(this.rawLogFd, endMarker);
475
+ fs.closeSync(this.rawLogFd);
476
+ this.rawLogFd = null;
477
+ }
478
+ if (this.jsonLogFd !== null) {
479
+ this.writeJsonEntry({
480
+ timestamp: new Date().toISOString(),
481
+ level: 'session',
482
+ source: 'system',
483
+ lane: this.session.laneName,
484
+ message: 'Session ended',
485
+ metadata: { sessionId: this.session.id, duration: Date.now() - this.session.startTime },
486
+ });
487
+ fs.closeSync(this.jsonLogFd);
488
+ this.jsonLogFd = null;
489
+ }
490
+ if (this.readableLogFd !== null) {
491
+ fs.writeSync(this.readableLogFd, endMarker);
492
+ fs.closeSync(this.readableLogFd);
493
+ this.readableLogFd = null;
494
+ }
495
+ }
496
+ formatDuration(ms) {
497
+ const seconds = Math.floor((ms / 1000) % 60);
498
+ const minutes = Math.floor((ms / (1000 * 60)) % 60);
499
+ const hours = Math.floor(ms / (1000 * 60 * 60));
500
+ if (hours > 0)
501
+ return `${hours}h ${minutes}m ${seconds}s`;
502
+ if (minutes > 0)
503
+ return `${minutes}m ${seconds}s`;
504
+ return `${seconds}s`;
505
+ }
506
+ }
507
+ exports.EnhancedLogManager = EnhancedLogManager;
508
+ function createLogManager(laneRunDir, laneName, config, onParsedMessage) {
509
+ const session = {
510
+ id: `${laneName}-${Date.now().toString(36)}`,
511
+ laneName,
512
+ startTime: Date.now(),
513
+ };
514
+ return new EnhancedLogManager(laneRunDir, session, config, onParsedMessage);
515
+ }
516
+ //# sourceMappingURL=file-writer.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"file-writer.js","sourceRoot":"","sources":["../../../src/services/logging/file-writer.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,39 @@
1
+ /**
2
+ * Log Formatter - Human-readable log formatting
3
+ *
4
+ * Formats log messages for console display with various styles.
5
+ *
6
+ * Rules:
7
+ * - Box format only for: user, assistant, system, result
8
+ * - Compact format for: tool, tool_result, thinking (gray/dim)
9
+ * - Tool names simplified: ShellToolCall → Shell
10
+ */
11
+ import { ParsedMessage, MessageType } from '../../types/logging';
12
+ /**
13
+ * Strip ANSI escape sequences from text
14
+ */
15
+ export declare function stripAnsi(text: string): string;
16
+ /**
17
+ * Format options for console display
18
+ */
19
+ export interface FormatOptions {
20
+ includeTimestamp?: boolean;
21
+ laneLabel?: string;
22
+ compact?: boolean;
23
+ showBorders?: boolean;
24
+ }
25
+ /**
26
+ * Format a parsed message for console display
27
+ */
28
+ export declare function formatMessageForConsole(msg: ParsedMessage, options?: FormatOptions): string;
29
+ /**
30
+ * Format a readable log entry for display
31
+ */
32
+ export declare function formatReadableEntry(timestamp: Date, laneName: string, type: MessageType, content: string, options?: {
33
+ showLane?: boolean;
34
+ maxWidth?: number;
35
+ }): string;
36
+ /**
37
+ * Format a timestamp for log files
38
+ */
39
+ export declare function formatTimestampISO(format: 'iso' | 'relative' | 'short', startTime?: number): string;