mstro-app 0.3.8 → 0.3.9

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 (105) hide show
  1. package/dist/server/cli/headless/claude-invoker.d.ts.map +1 -1
  2. package/dist/server/cli/headless/claude-invoker.js +18 -9
  3. package/dist/server/cli/headless/claude-invoker.js.map +1 -1
  4. package/dist/server/cli/headless/headless-logger.d.ts +10 -0
  5. package/dist/server/cli/headless/headless-logger.d.ts.map +1 -0
  6. package/dist/server/cli/headless/headless-logger.js +66 -0
  7. package/dist/server/cli/headless/headless-logger.js.map +1 -0
  8. package/dist/server/cli/headless/mcp-config.d.ts.map +1 -1
  9. package/dist/server/cli/headless/mcp-config.js +6 -5
  10. package/dist/server/cli/headless/mcp-config.js.map +1 -1
  11. package/dist/server/cli/headless/runner.d.ts.map +1 -1
  12. package/dist/server/cli/headless/runner.js +4 -0
  13. package/dist/server/cli/headless/runner.js.map +1 -1
  14. package/dist/server/cli/headless/stall-assessor.d.ts +21 -0
  15. package/dist/server/cli/headless/stall-assessor.d.ts.map +1 -1
  16. package/dist/server/cli/headless/stall-assessor.js +70 -19
  17. package/dist/server/cli/headless/stall-assessor.js.map +1 -1
  18. package/dist/server/cli/headless/tool-watchdog.d.ts +0 -12
  19. package/dist/server/cli/headless/tool-watchdog.d.ts.map +1 -1
  20. package/dist/server/cli/headless/tool-watchdog.js +22 -9
  21. package/dist/server/cli/headless/tool-watchdog.js.map +1 -1
  22. package/dist/server/cli/headless/types.d.ts +8 -1
  23. package/dist/server/cli/headless/types.d.ts.map +1 -1
  24. package/dist/server/cli/improvisation-session-manager.d.ts +16 -0
  25. package/dist/server/cli/improvisation-session-manager.d.ts.map +1 -1
  26. package/dist/server/cli/improvisation-session-manager.js +94 -11
  27. package/dist/server/cli/improvisation-session-manager.js.map +1 -1
  28. package/dist/server/mcp/bouncer-cli.d.ts +3 -0
  29. package/dist/server/mcp/bouncer-cli.d.ts.map +1 -0
  30. package/dist/server/mcp/bouncer-cli.js +54 -0
  31. package/dist/server/mcp/bouncer-cli.js.map +1 -0
  32. package/dist/server/services/plan/composer.d.ts +4 -0
  33. package/dist/server/services/plan/composer.d.ts.map +1 -0
  34. package/dist/server/services/plan/composer.js +181 -0
  35. package/dist/server/services/plan/composer.js.map +1 -0
  36. package/dist/server/services/plan/dependency-resolver.d.ts +28 -0
  37. package/dist/server/services/plan/dependency-resolver.d.ts.map +1 -0
  38. package/dist/server/services/plan/dependency-resolver.js +152 -0
  39. package/dist/server/services/plan/dependency-resolver.js.map +1 -0
  40. package/dist/server/services/plan/executor.d.ts +91 -0
  41. package/dist/server/services/plan/executor.d.ts.map +1 -0
  42. package/dist/server/services/plan/executor.js +545 -0
  43. package/dist/server/services/plan/executor.js.map +1 -0
  44. package/dist/server/services/plan/parser.d.ts +11 -0
  45. package/dist/server/services/plan/parser.d.ts.map +1 -0
  46. package/dist/server/services/plan/parser.js +415 -0
  47. package/dist/server/services/plan/parser.js.map +1 -0
  48. package/dist/server/services/plan/state-reconciler.d.ts +2 -0
  49. package/dist/server/services/plan/state-reconciler.d.ts.map +1 -0
  50. package/dist/server/services/plan/state-reconciler.js +105 -0
  51. package/dist/server/services/plan/state-reconciler.js.map +1 -0
  52. package/dist/server/services/plan/types.d.ts +120 -0
  53. package/dist/server/services/plan/types.d.ts.map +1 -0
  54. package/dist/server/services/plan/types.js +4 -0
  55. package/dist/server/services/plan/types.js.map +1 -0
  56. package/dist/server/services/plan/watcher.d.ts +14 -0
  57. package/dist/server/services/plan/watcher.d.ts.map +1 -0
  58. package/dist/server/services/plan/watcher.js +69 -0
  59. package/dist/server/services/plan/watcher.js.map +1 -0
  60. package/dist/server/services/websocket/file-explorer-handlers.js +20 -0
  61. package/dist/server/services/websocket/file-explorer-handlers.js.map +1 -1
  62. package/dist/server/services/websocket/handler.d.ts.map +1 -1
  63. package/dist/server/services/websocket/handler.js +21 -0
  64. package/dist/server/services/websocket/handler.js.map +1 -1
  65. package/dist/server/services/websocket/plan-handlers.d.ts +6 -0
  66. package/dist/server/services/websocket/plan-handlers.d.ts.map +1 -0
  67. package/dist/server/services/websocket/plan-handlers.js +494 -0
  68. package/dist/server/services/websocket/plan-handlers.js.map +1 -0
  69. package/dist/server/services/websocket/quality-handlers.d.ts.map +1 -1
  70. package/dist/server/services/websocket/quality-handlers.js +375 -11
  71. package/dist/server/services/websocket/quality-handlers.js.map +1 -1
  72. package/dist/server/services/websocket/quality-persistence.d.ts +45 -0
  73. package/dist/server/services/websocket/quality-persistence.d.ts.map +1 -0
  74. package/dist/server/services/websocket/quality-persistence.js +187 -0
  75. package/dist/server/services/websocket/quality-persistence.js.map +1 -0
  76. package/dist/server/services/websocket/quality-service.d.ts +2 -2
  77. package/dist/server/services/websocket/quality-service.d.ts.map +1 -1
  78. package/dist/server/services/websocket/quality-service.js +62 -12
  79. package/dist/server/services/websocket/quality-service.js.map +1 -1
  80. package/dist/server/services/websocket/types.d.ts +2 -2
  81. package/dist/server/services/websocket/types.d.ts.map +1 -1
  82. package/package.json +2 -2
  83. package/server/cli/headless/claude-invoker.ts +21 -9
  84. package/server/cli/headless/headless-logger.ts +78 -0
  85. package/server/cli/headless/mcp-config.ts +6 -5
  86. package/server/cli/headless/runner.ts +4 -0
  87. package/server/cli/headless/stall-assessor.ts +97 -19
  88. package/server/cli/headless/tool-watchdog.ts +10 -9
  89. package/server/cli/headless/types.ts +10 -1
  90. package/server/cli/improvisation-session-manager.ts +118 -11
  91. package/server/mcp/bouncer-cli.ts +73 -0
  92. package/server/services/plan/composer.ts +199 -0
  93. package/server/services/plan/dependency-resolver.ts +179 -0
  94. package/server/services/plan/executor.ts +604 -0
  95. package/server/services/plan/parser.ts +459 -0
  96. package/server/services/plan/state-reconciler.ts +132 -0
  97. package/server/services/plan/types.ts +164 -0
  98. package/server/services/plan/watcher.ts +73 -0
  99. package/server/services/websocket/file-explorer-handlers.ts +20 -0
  100. package/server/services/websocket/handler.ts +21 -0
  101. package/server/services/websocket/plan-handlers.ts +592 -0
  102. package/server/services/websocket/quality-handlers.ts +441 -11
  103. package/server/services/websocket/quality-persistence.ts +250 -0
  104. package/server/services/websocket/quality-service.ts +65 -12
  105. package/server/services/websocket/types.ts +48 -2
@@ -1,13 +1,54 @@
1
1
  // Copyright (c) 2025-present Mstro, Inc. All rights reserved.
2
2
  // Licensed under the MIT License. See LICENSE file for details.
3
3
  import { join } from 'node:path';
4
+ import { runWithFileLogger } from '../../cli/headless/headless-logger.js';
5
+ import { HeadlessRunner } from '../../cli/headless/index.js';
6
+ import { QualityPersistence } from './quality-persistence.js';
4
7
  import { detectTools, installTools, runQualityScan } from './quality-service.js';
8
+ const TOOL_MESSAGES = {
9
+ Read: 'Reading files to understand issues...',
10
+ Edit: 'Applying fixes...',
11
+ Write: 'Writing fixes...',
12
+ Grep: 'Searching for related code...',
13
+ Bash: 'Running verification...',
14
+ };
15
+ function createToolProgressCallback(ctx, ws, reportPath) {
16
+ const seenTools = new Set();
17
+ return (event) => {
18
+ if (event.type === 'tool_start' && event.toolName && !seenTools.has(event.toolName)) {
19
+ seenTools.add(event.toolName);
20
+ const message = TOOL_MESSAGES[event.toolName];
21
+ if (message) {
22
+ ctx.send(ws, { type: 'qualityFixProgress', data: { path: reportPath, message } });
23
+ }
24
+ }
25
+ if (event.type === 'tool_complete' && event.toolName === 'Edit' && event.completeInput?.file_path) {
26
+ ctx.send(ws, {
27
+ type: 'qualityFixProgress',
28
+ data: { path: reportPath, message: `Fixed ${String(event.completeInput.file_path).split('/').slice(-2).join('/')}` },
29
+ });
30
+ }
31
+ };
32
+ }
33
+ const persistenceCache = new Map();
34
+ const activeReviews = new Set();
35
+ function getPersistence(workingDir) {
36
+ let persistence = persistenceCache.get(workingDir);
37
+ if (!persistence) {
38
+ persistence = new QualityPersistence(workingDir);
39
+ persistenceCache.set(workingDir, persistence);
40
+ }
41
+ return persistence;
42
+ }
5
43
  export function handleQualityMessage(ctx, ws, msg, _tabId, workingDir) {
6
44
  const handlers = {
7
45
  qualityDetectTools: () => handleDetectTools(ctx, ws, msg, workingDir),
8
46
  qualityScan: () => handleScan(ctx, ws, msg, workingDir),
9
47
  qualityInstallTools: () => handleInstallTools(ctx, ws, msg, workingDir),
10
48
  qualityCodeReview: () => handleCodeReview(ctx, ws, msg, workingDir),
49
+ qualityFixIssues: () => handleFixIssues(ctx, ws, msg, workingDir),
50
+ qualityLoadState: () => handleLoadState(ctx, ws, workingDir),
51
+ qualitySaveDirectories: () => handleSaveDirectories(ctx, ws, msg, workingDir),
11
52
  };
12
53
  const handler = handlers[msg.type];
13
54
  if (!handler)
@@ -30,6 +71,35 @@ function resolvePath(workingDir, dirPath) {
30
71
  return dirPath;
31
72
  return join(workingDir, dirPath);
32
73
  }
74
+ async function handleLoadState(ctx, ws, workingDir) {
75
+ try {
76
+ const persistence = getPersistence(workingDir);
77
+ const state = persistence.loadState();
78
+ ctx.send(ws, {
79
+ type: 'qualityStateLoaded',
80
+ data: state,
81
+ });
82
+ }
83
+ catch (error) {
84
+ ctx.send(ws, {
85
+ type: 'qualityError',
86
+ data: { path: '.', error: error instanceof Error ? error.message : String(error) },
87
+ });
88
+ }
89
+ }
90
+ async function handleSaveDirectories(ctx, ws, msg, workingDir) {
91
+ try {
92
+ const persistence = getPersistence(workingDir);
93
+ const directories = msg.data?.directories || [];
94
+ persistence.saveConfig(directories);
95
+ }
96
+ catch (error) {
97
+ ctx.send(ws, {
98
+ type: 'qualityError',
99
+ data: { path: '.', error: error instanceof Error ? error.message : String(error) },
100
+ });
101
+ }
102
+ }
33
103
  async function handleDetectTools(ctx, ws, msg, workingDir) {
34
104
  const dirPath = resolvePath(workingDir, msg.data?.path);
35
105
  try {
@@ -50,16 +120,28 @@ async function handleScan(ctx, ws, msg, workingDir) {
50
120
  const dirPath = resolvePath(workingDir, msg.data?.path);
51
121
  const reportPath = msg.data?.path || '.';
52
122
  try {
123
+ // Detect installed tools so the scan can skip unavailable categories
124
+ const { tools: detectedTools } = await detectTools(dirPath);
125
+ const installedToolNames = detectedTools.filter((t) => t.installed).map((t) => t.name);
53
126
  const results = await runQualityScan(dirPath, (progress) => {
54
127
  ctx.send(ws, {
55
128
  type: 'qualityScanProgress',
56
129
  data: { path: reportPath, progress },
57
130
  });
58
- });
131
+ }, installedToolNames);
59
132
  ctx.send(ws, {
60
133
  type: 'qualityScanResults',
61
134
  data: { path: reportPath, results },
62
135
  });
136
+ // Persist report and append to history
137
+ try {
138
+ const persistence = getPersistence(workingDir);
139
+ persistence.saveReport(reportPath, results);
140
+ persistence.appendHistory(results, reportPath);
141
+ }
142
+ catch {
143
+ // Persistence failure should not break the scan flow
144
+ }
63
145
  }
64
146
  catch (error) {
65
147
  ctx.send(ws, {
@@ -90,17 +172,299 @@ async function handleInstallTools(ctx, ws, msg, workingDir) {
90
172
  });
91
173
  }
92
174
  }
93
- async function handleCodeReview(ctx, ws, msg, _workingDir) {
175
+ // ============================================================================
176
+ // Code Review Agent
177
+ // ============================================================================
178
+ function buildCodeReviewPrompt(dirPath) {
179
+ return `You are an expert code review agent. Your task is to perform a comprehensive, language-agnostic code review of the project in the current working directory.
180
+
181
+ IMPORTANT: Your current working directory is "${dirPath}". Only review files within this directory. Do NOT traverse parent directories or review files outside this path.
182
+
183
+ ## Review Process
184
+
185
+ 1. **Discover**: Use Glob to find source files (e.g. "**/*.{ts,tsx,js,py,rs,go,java,rb,php}"). Understand the project structure. Only search within the current directory.
186
+ 2. **Read**: Read the most important files — entry points, core modules, handlers, services. Prioritize files with recent git changes (\`git diff --name-only HEAD~5\` via Bash if available).
187
+ 3. **Analyze**: Look for real, actionable issues across these categories:
188
+ - **security**: Injection vulnerabilities (SQL, XSS, command), hardcoded secrets/credentials, auth bypasses, insecure crypto, path traversal, SSRF, unsafe deserialization
189
+ - **bugs**: Null/undefined errors, race conditions, logic errors, unhandled edge cases, off-by-one errors, resource leaks, incorrect error handling
190
+ - **performance**: N+1 queries, unnecessary re-renders, missing memoization, blocking I/O in hot paths, unbounded data structures, missing pagination
191
+ - **maintainability**: God functions (>100 lines), deep nesting (>4 levels), duplicated logic, missing error handling at system boundaries, tight coupling
192
+
193
+ ## Rules
194
+
195
+ - Only report findings you are >80% confident about. No speculative or low-confidence issues.
196
+ - Focus on bugs and security over style. Skip formatting, naming preferences, and minor nits.
197
+ - Each finding MUST reference a specific file and line number. Do not report vague or file-level issues.
198
+ - Limit to the 20 most important findings, ranked by severity.
199
+ - Do NOT modify any files. This is a read-only review.
200
+
201
+ ## Output
202
+
203
+ After your analysis, output EXACTLY one JSON code block with your findings. No other text after the JSON block.
204
+
205
+ \`\`\`json
206
+ {
207
+ "findings": [
208
+ {
209
+ "severity": "critical|high|medium|low",
210
+ "category": "security|bugs|performance|maintainability",
211
+ "file": "relative/path/to/file.ts",
212
+ "line": 42,
213
+ "title": "Short title describing the issue",
214
+ "description": "What the problem is and why it matters.",
215
+ "suggestion": "How to fix it."
216
+ }
217
+ ],
218
+ "summary": "Brief 1-2 sentence summary of overall code quality."
219
+ }
220
+ \`\`\``;
221
+ }
222
+ const VALID_SEVERITIES = new Set(['critical', 'high', 'medium', 'low']);
223
+ const VALID_CATEGORIES = new Set(['security', 'bugs', 'performance', 'maintainability']);
224
+ function normalizeFinding(f) {
225
+ if (typeof f.file !== 'string' || typeof f.title !== 'string')
226
+ return null;
227
+ return {
228
+ severity: VALID_SEVERITIES.has(f.severity) ? f.severity : 'medium',
229
+ category: VALID_CATEGORIES.has(f.category) ? f.category : 'maintainability',
230
+ file: f.file,
231
+ line: typeof f.line === 'number' ? f.line : null,
232
+ title: f.title,
233
+ description: typeof f.description === 'string' ? f.description : '',
234
+ suggestion: typeof f.suggestion === 'string' ? f.suggestion : undefined,
235
+ };
236
+ }
237
+ function extractJson(response) {
238
+ // Try ```json ... ``` first, then plain ``` ... ```, then largest {...} block
239
+ const fencedJson = response.match(/```json\s*([\s\S]*?)```/);
240
+ if (fencedJson)
241
+ return fencedJson[1].trim();
242
+ const fencedPlain = response.match(/```\s*([\s\S]*?)```/);
243
+ if (fencedPlain)
244
+ return fencedPlain[1].trim();
245
+ const braceMatch = response.match(/\{[\s\S]*\}/);
246
+ if (braceMatch)
247
+ return braceMatch[0].trim();
248
+ return response.trim();
249
+ }
250
+ function parseCodeReviewResponse(response) {
251
+ const jsonStr = extractJson(response);
252
+ try {
253
+ const parsed = JSON.parse(jsonStr);
254
+ const rawFindings = Array.isArray(parsed.findings) ? parsed.findings : [];
255
+ const findings = rawFindings.map(normalizeFinding).filter((f) => f !== null);
256
+ const summary = typeof parsed.summary === 'string' ? parsed.summary : `Found ${findings.length} issue(s).`;
257
+ return { findings, summary };
258
+ }
259
+ catch {
260
+ return { findings: [], summary: 'Failed to parse code review results.' };
261
+ }
262
+ }
263
+ const TOOL_START_MESSAGES = {
264
+ Glob: 'Discovering project files...',
265
+ Read: 'Reading source files...',
266
+ Grep: 'Searching codebase...',
267
+ Bash: 'Running analysis command...',
268
+ };
269
+ function getToolCompleteMessage(event) {
270
+ const input = event.completeInput;
271
+ if (!input)
272
+ return null;
273
+ if (event.toolName === 'Read' && input.file_path) {
274
+ return `Reviewed ${String(input.file_path).split('/').slice(-2).join('/')}`;
275
+ }
276
+ if (event.toolName === 'Grep' && input.pattern) {
277
+ return `Searched for "${String(input.pattern).slice(0, 40)}"`;
278
+ }
279
+ return null;
280
+ }
281
+ function createCodeReviewProgressTracker() {
282
+ const seenToolStarts = new Set();
283
+ return (event) => {
284
+ if (event.type === 'tool_start' && event.toolName) {
285
+ if (seenToolStarts.has(event.toolName))
286
+ return null;
287
+ seenToolStarts.add(event.toolName);
288
+ return TOOL_START_MESSAGES[event.toolName] ?? null;
289
+ }
290
+ if (event.type === 'tool_complete')
291
+ return getToolCompleteMessage(event);
292
+ return null;
293
+ };
294
+ }
295
+ async function handleCodeReview(ctx, ws, msg, workingDir) {
296
+ const dirPath = resolvePath(workingDir, msg.data?.path);
94
297
  const reportPath = msg.data?.path || '.';
95
- // Code review via headless Claude will be implemented in a follow-up.
96
- // For now, send an empty result to unblock the UI.
97
- ctx.send(ws, {
98
- type: 'qualityCodeReview',
99
- data: {
100
- path: reportPath,
101
- findings: [],
102
- summary: 'Code review requires a Claude Code session. Run from the Chat view for a detailed code review.',
103
- },
298
+ if (activeReviews.has(dirPath)) {
299
+ ctx.send(ws, {
300
+ type: 'qualityError',
301
+ data: { path: reportPath, error: 'A code review is already running for this directory.' },
302
+ });
303
+ return;
304
+ }
305
+ activeReviews.add(dirPath);
306
+ try {
307
+ // Send initial progress
308
+ ctx.send(ws, {
309
+ type: 'qualityCodeReviewProgress',
310
+ data: { path: reportPath, message: 'Starting AI code review...' },
311
+ });
312
+ const runner = new HeadlessRunner({
313
+ workingDir: dirPath,
314
+ directPrompt: buildCodeReviewPrompt(dirPath),
315
+ stallWarningMs: 120_000,
316
+ stallKillMs: 600_000,
317
+ stallHardCapMs: 900_000,
318
+ toolUseCallback: (() => {
319
+ const getProgressMessage = createCodeReviewProgressTracker();
320
+ return (event) => {
321
+ const message = getProgressMessage(event);
322
+ if (message) {
323
+ ctx.send(ws, {
324
+ type: 'qualityCodeReviewProgress',
325
+ data: { path: reportPath, message },
326
+ });
327
+ }
328
+ };
329
+ })(),
330
+ });
331
+ ctx.send(ws, {
332
+ type: 'qualityCodeReviewProgress',
333
+ data: { path: reportPath, message: 'Claude is analyzing your codebase...' },
334
+ });
335
+ const result = await runWithFileLogger('code-review', () => runner.run());
336
+ ctx.send(ws, {
337
+ type: 'qualityCodeReviewProgress',
338
+ data: { path: reportPath, message: 'Generating review report...' },
339
+ });
340
+ const responseText = result.assistantResponse || '';
341
+ const { findings, summary } = parseCodeReviewResponse(responseText);
342
+ ctx.send(ws, {
343
+ type: 'qualityCodeReview',
344
+ data: { path: reportPath, findings, summary },
345
+ });
346
+ // Persist code review results
347
+ try {
348
+ const persistence = getPersistence(workingDir);
349
+ persistence.saveCodeReview(reportPath, findings, summary);
350
+ }
351
+ catch {
352
+ // Persistence failure should not break the review flow
353
+ }
354
+ }
355
+ catch (error) {
356
+ ctx.send(ws, {
357
+ type: 'qualityError',
358
+ data: { path: reportPath, error: error instanceof Error ? error.message : String(error) },
359
+ });
360
+ }
361
+ finally {
362
+ activeReviews.delete(dirPath);
363
+ }
364
+ }
365
+ function buildFixPrompt(findings, section) {
366
+ const filtered = section ? findings.filter((f) => f.category === section) : findings;
367
+ const sorted = filtered.sort((a, b) => {
368
+ const order = { critical: 0, high: 1, medium: 2, low: 3 };
369
+ return (order[a.severity] ?? 4) - (order[b.severity] ?? 4);
104
370
  });
371
+ const issueList = sorted.slice(0, 30).map((f, i) => {
372
+ const loc = f.line ? `${f.file}:${f.line}` : f.file;
373
+ const parts = [`${i + 1}. [${f.severity.toUpperCase()}] ${loc} — ${f.title}`];
374
+ if (f.description)
375
+ parts.push(` ${f.description}`);
376
+ if (f.suggestion)
377
+ parts.push(` Suggestion: ${f.suggestion}`);
378
+ return parts.join('\n');
379
+ }).join('\n\n');
380
+ return `You are a code quality fix agent. Fix the following quality issues in the codebase.
381
+
382
+ ## Issues to Fix (${sorted.length} total, showing top ${Math.min(30, sorted.length)})
383
+
384
+ ${issueList}
385
+
386
+ ## Rules
387
+
388
+ - Fix each issue by editing the relevant file at the specified location.
389
+ - For complexity issues: refactor into smaller functions. For long files: split or extract modules. For long functions: break into smaller functions.
390
+ - For security issues: apply the suggested fix or use secure coding best practices.
391
+ - For bugs: fix the root cause, not just the symptom.
392
+ - For linting/formatting: apply the standard for the project.
393
+ - Do NOT introduce new issues. Make minimal, focused changes.
394
+ - After fixing, verify the changes compile/pass linting if tools are available.
395
+ - Work through the issues systematically from most to least severe.`;
396
+ }
397
+ const activeFixes = new Set();
398
+ async function handleFixIssues(ctx, ws, msg, workingDir) {
399
+ const dirPath = resolvePath(workingDir, msg.data?.path);
400
+ const reportPath = msg.data?.path || '.';
401
+ const section = msg.data?.section;
402
+ const findings = msg.data?.findings || [];
403
+ if (activeFixes.has(dirPath)) {
404
+ ctx.send(ws, {
405
+ type: 'qualityError',
406
+ data: { path: reportPath, error: 'A fix operation is already running for this directory.' },
407
+ });
408
+ return;
409
+ }
410
+ if (findings.length === 0) {
411
+ ctx.send(ws, {
412
+ type: 'qualityError',
413
+ data: { path: reportPath, error: 'No findings to fix.' },
414
+ });
415
+ return;
416
+ }
417
+ activeFixes.add(dirPath);
418
+ try {
419
+ ctx.send(ws, {
420
+ type: 'qualityFixProgress',
421
+ data: { path: reportPath, message: 'Starting Claude Code to fix issues...' },
422
+ });
423
+ const prompt = buildFixPrompt(findings, section);
424
+ const runner = new HeadlessRunner({
425
+ workingDir: dirPath,
426
+ directPrompt: prompt,
427
+ stallWarningMs: 120_000,
428
+ stallKillMs: 600_000,
429
+ stallHardCapMs: 900_000,
430
+ toolUseCallback: createToolProgressCallback(ctx, ws, reportPath),
431
+ });
432
+ await runWithFileLogger('code-review-fix', () => runner.run());
433
+ ctx.send(ws, {
434
+ type: 'qualityFixProgress',
435
+ data: { path: reportPath, message: 'Fixes applied. Re-running quality checks...' },
436
+ });
437
+ // Re-run quality scan after fixing
438
+ const { tools: detectedTools } = await detectTools(dirPath);
439
+ const installedToolNames = detectedTools.filter((t) => t.installed).map((t) => t.name);
440
+ const results = await runQualityScan(dirPath, (progress) => {
441
+ ctx.send(ws, {
442
+ type: 'qualityScanProgress',
443
+ data: { path: reportPath, progress },
444
+ });
445
+ }, installedToolNames);
446
+ ctx.send(ws, {
447
+ type: 'qualityFixComplete',
448
+ data: { path: reportPath, results },
449
+ });
450
+ // Persist
451
+ try {
452
+ const persistence = getPersistence(workingDir);
453
+ persistence.saveReport(reportPath, results);
454
+ persistence.appendHistory(results, reportPath);
455
+ }
456
+ catch {
457
+ // Persistence failure should not break the fix flow
458
+ }
459
+ }
460
+ catch (error) {
461
+ ctx.send(ws, {
462
+ type: 'qualityError',
463
+ data: { path: reportPath, error: error instanceof Error ? error.message : String(error) },
464
+ });
465
+ }
466
+ finally {
467
+ activeFixes.delete(dirPath);
468
+ }
105
469
  }
106
470
  //# sourceMappingURL=quality-handlers.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"quality-handlers.js","sourceRoot":"","sources":["../../../../server/services/websocket/quality-handlers.ts"],"names":[],"mappings":"AAAA,8DAA8D;AAC9D,gEAAgE;AAEhE,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AAEjC,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAGjF,MAAM,UAAU,oBAAoB,CAClC,GAAmB,EACnB,EAAa,EACb,GAAqB,EACrB,MAAc,EACd,UAAkB;IAElB,MAAM,QAAQ,GAA+B;QAC3C,kBAAkB,EAAE,GAAG,EAAE,CAAC,iBAAiB,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,UAAU,CAAC;QACrE,WAAW,EAAE,GAAG,EAAE,CAAC,UAAU,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,UAAU,CAAC;QACvD,mBAAmB,EAAE,GAAG,EAAE,CAAC,kBAAkB,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,UAAU,CAAC;QACvE,iBAAiB,EAAE,GAAG,EAAE,CAAC,gBAAgB,CAAC,GAAG,EAAE,EAAE,EAAE,GAAG,EAAE,UAAU,CAAC;KACpE,CAAC;IAEF,MAAM,OAAO,GAAG,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;IACnC,IAAI,CAAC,OAAO;QAAE,OAAO;IAErB,IAAI,CAAC;QACH,OAAO,EAAE,CAAC;IACZ,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,MAAM,MAAM,GAAG,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QACtE,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,UAAU,EAAE,KAAK,EAAE,MAAM,EAAE;SAC5D,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED,SAAS,WAAW,CAAC,UAAkB,EAAE,OAAgB;IACvD,IAAI,CAAC,OAAO,IAAI,OAAO,KAAK,GAAG,IAAI,OAAO,KAAK,IAAI;QAAE,OAAO,UAAU,CAAC;IACvE,IAAI,OAAO,CAAC,UAAU,CAAC,GAAG,CAAC;QAAE,OAAO,OAAO,CAAC;IAC5C,OAAO,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,CAAC;AACnC,CAAC;AAED,KAAK,UAAU,iBAAiB,CAC9B,GAAmB,EACnB,EAAa,EACb,GAAqB,EACrB,UAAkB;IAElB,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACxD,IAAI,CAAC;QACH,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,MAAM,WAAW,CAAC,OAAO,CAAC,CAAC;QACxD,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,sBAAsB;YAC5B,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE;SACxD,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,GAAG,EAAE,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;SACrG,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED,KAAK,UAAU,UAAU,CACvB,GAAmB,EACnB,EAAa,EACb,GAAqB,EACrB,UAAkB;IAElB,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACxD,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,GAAG,CAAC;IAEzC,IAAI,CAAC;QACH,MAAM,OAAO,GAAG,MAAM,cAAc,CAAC,OAAO,EAAE,CAAC,QAAQ,EAAE,EAAE;YACzD,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;gBACX,IAAI,EAAE,qBAAqB;gBAC3B,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,QAAQ,EAAE;aACrC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,oBAAoB;YAC1B,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,OAAO,EAAE;SACpC,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;SAC1F,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED,KAAK,UAAU,kBAAkB,CAC/B,GAAmB,EACnB,EAAa,EACb,GAAqB,EACrB,UAAkB;IAElB,MAAM,OAAO,GAAG,WAAW,CAAC,UAAU,EAAE,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC,CAAC;IACxD,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,GAAG,CAAC;IACzC,MAAM,SAAS,GAAyB,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC;IAExD,IAAI,CAAC;QACH,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,wBAAwB;YAC9B,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,IAAI,EAAE;SAC7C,CAAC,CAAC;QAEH,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,MAAM,YAAY,CAAC,OAAO,EAAE,SAAS,CAAC,CAAC;QAEpE,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,wBAAwB;YAC9B,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,SAAS,EAAE;SAC7C,CAAC,CAAC;IACL,CAAC;IAAC,OAAO,KAAK,EAAE,CAAC;QACf,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;YACX,IAAI,EAAE,cAAc;YACpB,IAAI,EAAE,EAAE,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,KAAK,YAAY,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE;SAC1F,CAAC,CAAC;IACL,CAAC;AACH,CAAC;AAED,KAAK,UAAU,gBAAgB,CAC7B,GAAmB,EACnB,EAAa,EACb,GAAqB,EACrB,WAAmB;IAEnB,MAAM,UAAU,GAAG,GAAG,CAAC,IAAI,EAAE,IAAI,IAAI,GAAG,CAAC;IAEzC,sEAAsE;IACtE,mDAAmD;IACnD,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE;QACX,IAAI,EAAE,mBAAmB;QACzB,IAAI,EAAE;YACJ,IAAI,EAAE,UAAU;YAChB,QAAQ,EAAE,EAAE;YACZ,OAAO,EAAE,gGAAgG;SAC1G;KACF,CAAC,CAAC;AACL,CAAC"}
1
+ {"version":3,"file":"quality-handlers.js","sourceRoot":"","sources":["../../../../server/services/websocket/quality-handlers.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,45 @@
1
+ import type { QualityResults } from './quality-service.js';
2
+ export interface QualityDirectoryConfig {
3
+ path: string;
4
+ label: string;
5
+ }
6
+ export interface HistoryDirectoryEntry {
7
+ path: string;
8
+ score: number;
9
+ grade: string;
10
+ }
11
+ export interface QualityHistoryEntry {
12
+ timestamp: string;
13
+ overall: number;
14
+ grade: string;
15
+ directories: HistoryDirectoryEntry[];
16
+ }
17
+ export interface QualityPersistedState {
18
+ directories: QualityDirectoryConfig[];
19
+ reports: Record<string, QualityResults>;
20
+ history: QualityHistoryEntry[];
21
+ }
22
+ export declare class QualityPersistence {
23
+ private qualityDir;
24
+ private reportsDir;
25
+ private configPath;
26
+ private historyPath;
27
+ constructor(workingDir: string);
28
+ loadConfig(): QualityDirectoryConfig[];
29
+ saveConfig(directories: QualityDirectoryConfig[]): void;
30
+ addDirectory(path: string, label: string): void;
31
+ removeDirectory(path: string): void;
32
+ loadReport(dirPath: string): QualityResults | null;
33
+ saveReport(dirPath: string, results: QualityResults): void;
34
+ loadAllReports(directories: QualityDirectoryConfig[]): Record<string, QualityResults>;
35
+ loadHistory(): QualityHistoryEntry[];
36
+ appendHistory(results: QualityResults, dirPath: string): void;
37
+ loadCodeReview(dirPath: string): {
38
+ findings: Record<string, unknown>[];
39
+ summary: string;
40
+ timestamp: string;
41
+ } | null;
42
+ saveCodeReview(dirPath: string, findings: Record<string, unknown>[], summary: string): void;
43
+ loadState(): QualityPersistedState;
44
+ }
45
+ //# sourceMappingURL=quality-persistence.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"quality-persistence.d.ts","sourceRoot":"","sources":["../../../../server/services/websocket/quality-persistence.ts"],"names":[],"mappings":"AAeA,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC;AAM3D,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;CACf;AAMD,MAAM,WAAW,qBAAqB;IACpC,IAAI,EAAE,MAAM,CAAC;IACb,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,mBAAmB;IAClC,SAAS,EAAE,MAAM,CAAC;IAClB,OAAO,EAAE,MAAM,CAAC;IAChB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,qBAAqB,EAAE,CAAC;CACtC;AAMD,MAAM,WAAW,qBAAqB;IACpC,WAAW,EAAE,sBAAsB,EAAE,CAAC;IACtC,OAAO,EAAE,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC;IACxC,OAAO,EAAE,mBAAmB,EAAE,CAAC;CAChC;AA0CD,qBAAa,kBAAkB;IAC7B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,UAAU,CAAS;IAC3B,OAAO,CAAC,WAAW,CAAS;gBAEhB,UAAU,EAAE,MAAM;IAU9B,UAAU,IAAI,sBAAsB,EAAE;IAKtC,UAAU,CAAC,WAAW,EAAE,sBAAsB,EAAE,GAAG,IAAI;IAIvD,YAAY,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAQ/C,eAAe,CAAC,IAAI,EAAE,MAAM,GAAG,IAAI;IAOnC,UAAU,CAAC,OAAO,EAAE,MAAM,GAAG,cAAc,GAAG,IAAI;IAMlD,UAAU,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,EAAE,cAAc,GAAG,IAAI;IAM1D,cAAc,CAAC,WAAW,EAAE,sBAAsB,EAAE,GAAG,MAAM,CAAC,MAAM,EAAE,cAAc,CAAC;IAarF,WAAW,IAAI,mBAAmB,EAAE;IAKpC,aAAa,CAAC,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAiD7D,cAAc,CAAC,OAAO,EAAE,MAAM,GAAG;QAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;QAAC,OAAO,EAAE,MAAM,CAAC;QAAC,SAAS,EAAE,MAAM,CAAA;KAAE,GAAG,IAAI;IAMnH,cAAc,CAAC,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,EAAE,OAAO,EAAE,MAAM,GAAG,IAAI;IAQ3F,SAAS,IAAI,qBAAqB;CAenC"}