vibecodingmachine-core 2026.2.20-438 → 2026.2.26-1739
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +240 -0
- package/package.json +10 -2
- package/src/agents/Agent.js +300 -0
- package/src/agents/AgentAdditionService.js +311 -0
- package/src/agents/AgentCheckService.js +690 -0
- package/src/agents/AgentInstallationService.js +140 -0
- package/src/agents/AgentSetupService.js +467 -0
- package/src/agents/AgentStatus.js +183 -0
- package/src/agents/AgentVerificationService.js +634 -0
- package/src/agents/ConfigurationSchemaValidator.js +543 -0
- package/src/agents/EnvironmentConfigurationManager.js +602 -0
- package/src/agents/InstallationErrorHandler.js +372 -0
- package/src/agents/InstallationLog.js +363 -0
- package/src/agents/InstallationMethod.js +510 -0
- package/src/agents/InstallationOrchestrator.js +352 -0
- package/src/agents/InstallationProgressReporter.js +372 -0
- package/src/agents/InstallationRetryManager.js +322 -0
- package/src/agents/InstallationType.js +254 -0
- package/src/agents/OperationTypes.js +310 -0
- package/src/agents/PerformanceMetricsCollector.js +493 -0
- package/src/agents/SecurityValidationService.js +534 -0
- package/src/agents/VerificationTest.js +354 -0
- package/src/agents/VerificationType.js +226 -0
- package/src/agents/WindowsPermissionHandler.js +518 -0
- package/src/agents/config/AgentConfigManager.js +393 -0
- package/src/agents/config/AgentDefaultsRegistry.js +373 -0
- package/src/agents/config/ConfigValidator.js +281 -0
- package/src/agents/discovery/AgentDiscoveryService.js +707 -0
- package/src/agents/logging/AgentLogger.js +511 -0
- package/src/agents/status/AgentStatusManager.js +481 -0
- package/src/agents/storage/FileManager.js +454 -0
- package/src/agents/verification/AgentCommunicationTester.js +474 -0
- package/src/agents/verification/BaseVerifier.js +430 -0
- package/src/agents/verification/CommandVerifier.js +480 -0
- package/src/agents/verification/FileOperationVerifier.js +453 -0
- package/src/agents/verification/ResultAnalyzer.js +707 -0
- package/src/agents/verification/TestRequirementManager.js +495 -0
- package/src/agents/verification/VerificationRunner.js +433 -0
- package/src/agents/windows/BaseWindowsInstaller.js +441 -0
- package/src/agents/windows/ChocolateyInstaller.js +509 -0
- package/src/agents/windows/DirectInstaller.js +443 -0
- package/src/agents/windows/InstallerFactory.js +391 -0
- package/src/agents/windows/NpmInstaller.js +505 -0
- package/src/agents/windows/PowerShellInstaller.js +458 -0
- package/src/agents/windows/WinGetInstaller.js +390 -0
- package/src/analysis/analysis-reporter.js +132 -0
- package/src/analysis/boundary-detector.js +712 -0
- package/src/analysis/categorizer.js +340 -0
- package/src/analysis/codebase-scanner.js +384 -0
- package/src/analysis/line-counter.js +513 -0
- package/src/analysis/priority-calculator.js +679 -0
- package/src/analysis/report/analysis-report.js +250 -0
- package/src/analysis/report/package-analyzer.js +278 -0
- package/src/analysis/report/recommendation-generator.js +382 -0
- package/src/analysis/report/statistics-generator.js +515 -0
- package/src/analysis/reports/analysis-report-model.js +101 -0
- package/src/analysis/reports/recommendation-generator.js +283 -0
- package/src/analysis/reports/report-generators.js +191 -0
- package/src/analysis/reports/statistics-calculator.js +231 -0
- package/src/analysis/reports/trend-analyzer.js +219 -0
- package/src/analysis/strategy-generator.js +814 -0
- package/src/auto-mode/AutoModeBusinessLogic.js +836 -0
- package/src/config/refactoring-config.js +307 -0
- package/src/health-tracking/json-storage.js +38 -2
- package/src/ide-integration/applescript-manager-core.js +233 -0
- package/src/ide-integration/applescript-manager.cjs +357 -28
- package/src/ide-integration/applescript-manager.js +89 -3599
- package/src/ide-integration/cdp-manager.js +306 -0
- package/src/ide-integration/claude-code-cli-manager.cjs +1 -1
- package/src/ide-integration/continuation-handler.js +337 -0
- package/src/ide-integration/ide-status-checker.js +292 -0
- package/src/ide-integration/macos-ide-manager.js +627 -0
- package/src/ide-integration/macos-text-sender.js +528 -0
- package/src/ide-integration/response-reader.js +548 -0
- package/src/ide-integration/windows-automation-manager.js +121 -0
- package/src/ide-integration/windows-ide-manager.js +373 -0
- package/src/index.cjs +25 -3
- package/src/index.js +15 -1
- package/src/llm/direct-llm-manager.cjs +90 -2
- package/src/models/compliance-report.js +538 -0
- package/src/models/file-analysis.js +681 -0
- package/src/models/refactoring-plan.js +770 -0
- package/src/monitoring/alert-system.js +834 -0
- package/src/monitoring/compliance-progress-tracker.js +437 -0
- package/src/monitoring/continuous-scan-notifications.js +661 -0
- package/src/monitoring/continuous-scanner.js +279 -0
- package/src/monitoring/file-monitor/file-analyzer.js +262 -0
- package/src/monitoring/file-monitor/file-monitor.js +237 -0
- package/src/monitoring/file-monitor/watcher.js +194 -0
- package/src/monitoring/file-monitor.js +17 -0
- package/src/monitoring/notification-manager.js +437 -0
- package/src/monitoring/scanner-core.js +368 -0
- package/src/monitoring/scanner-events.js +214 -0
- package/src/monitoring/violation-notification-system.js +515 -0
- package/src/refactoring/boundaries/cohesion-analyzer.js +316 -0
- package/src/refactoring/boundaries/extraction-result.js +285 -0
- package/src/refactoring/boundaries/extraction-strategies.js +392 -0
- package/src/refactoring/boundaries/module-boundary.js +209 -0
- package/src/refactoring/boundary/boundary-detector.js +741 -0
- package/src/refactoring/boundary/boundary-types.js +405 -0
- package/src/refactoring/boundary/extraction-strategies.js +554 -0
- package/src/refactoring/boundary-extraction-result.js +77 -0
- package/src/refactoring/boundary-extraction-strategies.js +330 -0
- package/src/refactoring/boundary-extractor.js +384 -0
- package/src/refactoring/boundary-types.js +46 -0
- package/src/refactoring/circular/circular-dependency.js +88 -0
- package/src/refactoring/circular/cycle-detection.js +147 -0
- package/src/refactoring/circular/dependency-node.js +82 -0
- package/src/refactoring/circular/dependency-result.js +107 -0
- package/src/refactoring/circular/dependency-types.js +58 -0
- package/src/refactoring/circular/graph-builder.js +213 -0
- package/src/refactoring/circular/resolution-strategy.js +72 -0
- package/src/refactoring/circular/strategy-generator.js +229 -0
- package/src/refactoring/circular-dependency-resolver-original.js +809 -0
- package/src/refactoring/circular-dependency-resolver.js +200 -0
- package/src/refactoring/code-mover.js +761 -0
- package/src/refactoring/file-splitter.js +696 -0
- package/src/refactoring/functionality-validator.js +816 -0
- package/src/refactoring/import-manager.js +774 -0
- package/src/refactoring/module-boundary.js +107 -0
- package/src/refactoring/refactoring-executor.js +672 -0
- package/src/refactoring/refactoring-rollback.js +614 -0
- package/src/refactoring/test-validator.js +631 -0
- package/src/requirement-management/default-requirement-manager.js +321 -0
- package/src/requirement-management/requirement-file-parser.js +159 -0
- package/src/requirement-management/requirement-sequencer.js +221 -0
- package/src/rui/commands/AgentCommandParser.js +600 -0
- package/src/rui/commands/AgentCommands.js +487 -0
- package/src/rui/commands/AgentResponseFormatter.js +832 -0
- package/src/scripts/verify-full-compliance.js +269 -0
- package/src/sync/sync-engine-core.js +1 -0
- package/src/sync/sync-engine-remote-handlers.js +135 -0
- package/src/task-generation/automated-task-generator.js +351 -0
- package/src/task-generation/prioritizer.js +287 -0
- package/src/task-generation/task-list-updater.js +215 -0
- package/src/task-generation/task-management-integration.js +480 -0
- package/src/task-generation/task-manager-integration.js +270 -0
- package/src/task-generation/violation-task-generator.js +474 -0
- package/src/task-management/continuous-scan-integration.js +342 -0
- package/src/timeout-management/index.js +12 -3
- package/src/timeout-management/response-time-tracker.js +167 -0
- package/src/timeout-management/timeout-calculator.js +159 -0
- package/src/timeout-management/timeout-config-manager.js +172 -0
- package/src/utils/ast-analyzer.js +417 -0
- package/src/utils/current-requirement-manager.js +276 -0
- package/src/utils/current-requirement-operations.js +472 -0
- package/src/utils/dependency-mapper.js +456 -0
- package/src/utils/download-with-progress.js +4 -2
- package/src/utils/electron-update-checker.js +4 -1
- package/src/utils/file-size-analyzer.js +272 -0
- package/src/utils/import-updater.js +280 -0
- package/src/utils/refactoring-tools.js +512 -0
- package/src/utils/report-generator.js +569 -0
- package/src/utils/reports/report-analysis.js +218 -0
- package/src/utils/reports/report-types.js +55 -0
- package/src/utils/reports/summary-generators.js +102 -0
- package/src/utils/requirement-file-management.js +157 -0
- package/src/utils/requirement-helpers/requirement-file-ops.js +392 -0
- package/src/utils/requirement-helpers/requirement-mover.js +414 -0
- package/src/utils/requirement-helpers/requirement-parser.js +326 -0
- package/src/utils/requirement-helpers/requirement-status.js +320 -0
- package/src/utils/requirement-helpers-new.js +55 -0
- package/src/utils/requirement-helpers-refactored.js +367 -0
- package/src/utils/requirement-helpers.js +291 -1191
- package/src/utils/requirement-movement-operations.js +450 -0
- package/src/utils/requirement-movement.js +312 -0
- package/src/utils/requirement-parsing-helpers.js +56 -0
- package/src/utils/requirement-statistics.js +200 -0
- package/src/utils/requirement-text-utils.js +58 -0
- package/src/utils/rollback/rollback-handlers.js +125 -0
- package/src/utils/rollback/rollback-operation.js +63 -0
- package/src/utils/rollback/rollback-recorder.js +166 -0
- package/src/utils/rollback/rollback-state-manager.js +175 -0
- package/src/utils/rollback/rollback-types.js +33 -0
- package/src/utils/rollback/rollback-utils.js +110 -0
- package/src/utils/rollback-manager-original.js +569 -0
- package/src/utils/rollback-manager.js +202 -0
- package/src/utils/smoke-test-cli.js +362 -0
- package/src/utils/smoke-test-gui.js +351 -0
- package/src/utils/smoke-test-orchestrator.js +321 -0
- package/src/utils/smoke-test-runner.js +60 -0
- package/src/utils/smoke-test-web.js +347 -0
- package/src/utils/specification-helpers.js +39 -13
- package/src/utils/specification-migration.js +97 -0
- package/src/utils/test-runner.js +579 -0
- package/src/utils/validation-framework.js +518 -0
- package/src/validation/compliance-analyzer.js +197 -0
- package/src/validation/compliance-report-generator.js +343 -0
- package/src/validation/compliance-reporter.js +711 -0
- package/src/validation/compliance-rules.js +127 -0
- package/src/validation/constitution-validator-new.js +196 -0
- package/src/validation/constitution-validator.js +17 -0
- package/src/validation/file-validators.js +170 -0
- package/src/validation/line-limit/file-analyzer.js +201 -0
- package/src/validation/line-limit/line-limit-validator.js +208 -0
- package/src/validation/line-limit/validation-result.js +144 -0
- package/src/validation/line-limit-core.js +225 -0
- package/src/validation/line-limit-reporter.js +134 -0
- package/src/validation/line-limit-result.js +125 -0
- package/src/validation/line-limit-validator.js +41 -0
- package/src/validation/metrics-calculator.js +660 -0
- package/src/sync/sync-engine-backup.js +0 -559
|
@@ -0,0 +1,237 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File Monitor - Main Module
|
|
3
|
+
*
|
|
4
|
+
* Main orchestrator for file monitoring functionality.
|
|
5
|
+
* This file imports and coordinates the modular monitoring components.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
const { FileSystemWatcher } = require('./watcher');
|
|
9
|
+
const { MonitoringFileAnalyzer } = require('./file-analyzer');
|
|
10
|
+
const EventEmitter = require('events');
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* File monitoring daemon
|
|
14
|
+
*/
|
|
15
|
+
class FileMonitor extends EventEmitter {
|
|
16
|
+
constructor(options = {}) {
|
|
17
|
+
super();
|
|
18
|
+
|
|
19
|
+
this.options = {
|
|
20
|
+
lineLimit: 555,
|
|
21
|
+
checkConstitutional: true,
|
|
22
|
+
checkCommonIssues: true,
|
|
23
|
+
cacheTimeout: 30000,
|
|
24
|
+
...options
|
|
25
|
+
};
|
|
26
|
+
|
|
27
|
+
this.watcher = new FileSystemWatcher(options);
|
|
28
|
+
this.analyzer = new MonitoringFileAnalyzer(this.options);
|
|
29
|
+
this.isRunning = false;
|
|
30
|
+
this.monitoredPaths = new Set();
|
|
31
|
+
|
|
32
|
+
this.setupWatcherEvents();
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Start monitoring the specified paths
|
|
37
|
+
*/
|
|
38
|
+
async start(watchPaths) {
|
|
39
|
+
if (this.isRunning) {
|
|
40
|
+
throw new Error('Monitor is already running');
|
|
41
|
+
}
|
|
42
|
+
|
|
43
|
+
try {
|
|
44
|
+
await this.watcher.start(watchPaths);
|
|
45
|
+
this.isRunning = true;
|
|
46
|
+
watchPaths.forEach(p => this.monitoredPaths.add(p));
|
|
47
|
+
|
|
48
|
+
this.emit('started', {
|
|
49
|
+
paths: this.monitoredPaths,
|
|
50
|
+
options: this.options
|
|
51
|
+
});
|
|
52
|
+
|
|
53
|
+
} catch (error) {
|
|
54
|
+
throw new Error(`Failed to start file monitor: ${error.message}`);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
/**
|
|
59
|
+
* Stop monitoring
|
|
60
|
+
*/
|
|
61
|
+
async stop() {
|
|
62
|
+
if (!this.isRunning) {
|
|
63
|
+
return;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
try {
|
|
67
|
+
await this.watcher.stop();
|
|
68
|
+
this.isRunning = false;
|
|
69
|
+
this.monitoredPaths.clear();
|
|
70
|
+
|
|
71
|
+
this.emit('stopped');
|
|
72
|
+
} catch (error) {
|
|
73
|
+
throw new Error(`Failed to stop file monitor: ${error.message}`);
|
|
74
|
+
}
|
|
75
|
+
}
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* Add a path to monitor
|
|
79
|
+
*/
|
|
80
|
+
async addPath(watchPath) {
|
|
81
|
+
if (!this.isRunning) {
|
|
82
|
+
throw new Error('Monitor is not running');
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
try {
|
|
86
|
+
await this.watcher.addPath(watchPath);
|
|
87
|
+
this.monitoredPaths.add(watchPath);
|
|
88
|
+
|
|
89
|
+
this.emit('pathAdded', { path: watchPath });
|
|
90
|
+
} catch (error) {
|
|
91
|
+
throw new Error(`Failed to add path ${watchPath}: ${error.message}`);
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Remove a path from monitoring
|
|
97
|
+
*/
|
|
98
|
+
async removePath(watchPath) {
|
|
99
|
+
if (!this.isRunning) {
|
|
100
|
+
return;
|
|
101
|
+
}
|
|
102
|
+
|
|
103
|
+
try {
|
|
104
|
+
await this.watcher.removePath(watchPath);
|
|
105
|
+
this.monitoredPaths.delete(watchPath);
|
|
106
|
+
|
|
107
|
+
this.emit('pathRemoved', { path: watchPath });
|
|
108
|
+
} catch (error) {
|
|
109
|
+
throw new Error(`Failed to remove path ${watchPath}: ${error.message}`);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Get current monitoring status
|
|
115
|
+
*/
|
|
116
|
+
getStatus() {
|
|
117
|
+
return {
|
|
118
|
+
isRunning: this.isRunning,
|
|
119
|
+
monitoredPaths: Array.from(this.monitoredPaths),
|
|
120
|
+
options: this.options,
|
|
121
|
+
watcherStatus: this.watcher.getStatus(),
|
|
122
|
+
analyzerStats: this.analyzer.getCacheStats()
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
|
|
126
|
+
/**
|
|
127
|
+
* Setup event handlers for the watcher
|
|
128
|
+
*/
|
|
129
|
+
setupWatcherEvents() {
|
|
130
|
+
// Handle file changes
|
|
131
|
+
this.watcher.on('fileChanged', async (event) => {
|
|
132
|
+
try {
|
|
133
|
+
const analysis = await this.analyzer.analyzeFile(event.path, 'change');
|
|
134
|
+
|
|
135
|
+
this.emit('fileAnalyzed', {
|
|
136
|
+
...event,
|
|
137
|
+
analysis
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
// Emit specific events for issues
|
|
141
|
+
if (!analysis.compliant) {
|
|
142
|
+
this.emit('complianceIssue', {
|
|
143
|
+
...event,
|
|
144
|
+
analysis
|
|
145
|
+
});
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
} catch (error) {
|
|
149
|
+
this.emit('analysisError', {
|
|
150
|
+
...event,
|
|
151
|
+
error: error.message
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
});
|
|
155
|
+
|
|
156
|
+
// Handle new files
|
|
157
|
+
this.watcher.on('fileAdded', async (event) => {
|
|
158
|
+
try {
|
|
159
|
+
const analysis = await this.analyzer.analyzeFile(event.path, 'add');
|
|
160
|
+
|
|
161
|
+
this.emit('fileAnalyzed', {
|
|
162
|
+
...event,
|
|
163
|
+
analysis
|
|
164
|
+
});
|
|
165
|
+
|
|
166
|
+
if (!analysis.compliant) {
|
|
167
|
+
this.emit('complianceIssue', {
|
|
168
|
+
...event,
|
|
169
|
+
analysis
|
|
170
|
+
});
|
|
171
|
+
}
|
|
172
|
+
|
|
173
|
+
} catch (error) {
|
|
174
|
+
this.emit('analysisError', {
|
|
175
|
+
...event,
|
|
176
|
+
error: error.message
|
|
177
|
+
});
|
|
178
|
+
}
|
|
179
|
+
});
|
|
180
|
+
|
|
181
|
+
// Handle file removal
|
|
182
|
+
this.watcher.on('fileRemoved', (event) => {
|
|
183
|
+
this.emit('fileRemoved', event);
|
|
184
|
+
|
|
185
|
+
// Clear analysis cache for removed file
|
|
186
|
+
this.analyzer.clearCache();
|
|
187
|
+
});
|
|
188
|
+
|
|
189
|
+
// Handle watcher errors
|
|
190
|
+
this.watcher.on('error', (error) => {
|
|
191
|
+
this.emit('error', error);
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
// Handle watcher lifecycle events
|
|
195
|
+
this.watcher.on('started', (event) => {
|
|
196
|
+
this.emit('watcherStarted', event);
|
|
197
|
+
});
|
|
198
|
+
|
|
199
|
+
this.watcher.on('stopped', () => {
|
|
200
|
+
this.emit('watcherStopped');
|
|
201
|
+
});
|
|
202
|
+
}
|
|
203
|
+
|
|
204
|
+
/**
|
|
205
|
+
* Analyze a specific file on demand
|
|
206
|
+
*/
|
|
207
|
+
async analyzeFile(filePath) {
|
|
208
|
+
try {
|
|
209
|
+
const analysis = await this.analyzer.analyzeFile(filePath, 'manual');
|
|
210
|
+
|
|
211
|
+
this.emit('fileAnalyzed', {
|
|
212
|
+
path: filePath,
|
|
213
|
+
stats: null,
|
|
214
|
+
type: 'file',
|
|
215
|
+
analysis
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
return analysis;
|
|
219
|
+
} catch (error) {
|
|
220
|
+
this.emit('analysisError', {
|
|
221
|
+
path: filePath,
|
|
222
|
+
error: error.message
|
|
223
|
+
});
|
|
224
|
+
throw error;
|
|
225
|
+
}
|
|
226
|
+
}
|
|
227
|
+
|
|
228
|
+
/**
|
|
229
|
+
* Clear the analysis cache
|
|
230
|
+
*/
|
|
231
|
+
clearCache() {
|
|
232
|
+
this.analyzer.clearCache();
|
|
233
|
+
this.emit('cacheCleared');
|
|
234
|
+
}
|
|
235
|
+
}
|
|
236
|
+
|
|
237
|
+
module.exports = FileMonitor;
|
|
@@ -0,0 +1,194 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File System Watcher
|
|
3
|
+
*
|
|
4
|
+
* Handles the core file system watching functionality using chokidar.
|
|
5
|
+
*/
|
|
6
|
+
|
|
7
|
+
const chokidar = require('chokidar');
|
|
8
|
+
const EventEmitter = require('events');
|
|
9
|
+
const path = require('path');
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* File system watcher class
|
|
13
|
+
*/
|
|
14
|
+
class FileSystemWatcher extends EventEmitter {
|
|
15
|
+
constructor(options = {}) {
|
|
16
|
+
super();
|
|
17
|
+
|
|
18
|
+
this.options = {
|
|
19
|
+
ignored: [
|
|
20
|
+
'**/node_modules/**',
|
|
21
|
+
'**/.git/**',
|
|
22
|
+
'**/dist/**',
|
|
23
|
+
'**/build/**',
|
|
24
|
+
'**/coverage/**',
|
|
25
|
+
'**/.nyc_output/**',
|
|
26
|
+
'**/*.log',
|
|
27
|
+
'**/*.tmp',
|
|
28
|
+
'**/*.cache'
|
|
29
|
+
],
|
|
30
|
+
persistent: true,
|
|
31
|
+
ignoreInitial: false,
|
|
32
|
+
followSymlinks: false,
|
|
33
|
+
cwd: options.cwd || process.cwd(),
|
|
34
|
+
...options
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
this.watcher = null;
|
|
38
|
+
this.isWatching = false;
|
|
39
|
+
this.watchedPaths = new Set();
|
|
40
|
+
}
|
|
41
|
+
|
|
42
|
+
/**
|
|
43
|
+
* Start watching the specified paths
|
|
44
|
+
*/
|
|
45
|
+
async start(watchPaths) {
|
|
46
|
+
if (this.isWatching) {
|
|
47
|
+
throw new Error('Watcher is already running');
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const paths = Array.isArray(watchPaths) ? watchPaths : [watchPaths];
|
|
51
|
+
|
|
52
|
+
try {
|
|
53
|
+
this.watcher = chokidar.watch(paths, this.options);
|
|
54
|
+
|
|
55
|
+
this.setupEventHandlers();
|
|
56
|
+
|
|
57
|
+
await new Promise((resolve, reject) => {
|
|
58
|
+
this.watcher.on('ready', () => {
|
|
59
|
+
this.isWatching = true;
|
|
60
|
+
paths.forEach(p => this.watchedPaths.add(path.resolve(p)));
|
|
61
|
+
this.emit('started', { paths: this.watchedPaths });
|
|
62
|
+
resolve();
|
|
63
|
+
});
|
|
64
|
+
|
|
65
|
+
this.watcher.on('error', reject);
|
|
66
|
+
});
|
|
67
|
+
|
|
68
|
+
} catch (error) {
|
|
69
|
+
throw new Error(`Failed to start watcher: ${error.message}`);
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
/**
|
|
74
|
+
* Stop watching
|
|
75
|
+
*/
|
|
76
|
+
async stop() {
|
|
77
|
+
if (!this.isWatching || !this.watcher) {
|
|
78
|
+
return;
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
try {
|
|
82
|
+
await this.watcher.close();
|
|
83
|
+
this.isWatching = false;
|
|
84
|
+
this.watchedPaths.clear();
|
|
85
|
+
this.emit('stopped');
|
|
86
|
+
} catch (error) {
|
|
87
|
+
throw new Error(`Failed to stop watcher: ${error.message}`);
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
|
|
91
|
+
/**
|
|
92
|
+
* Add a path to watch
|
|
93
|
+
*/
|
|
94
|
+
async addPath(watchPath) {
|
|
95
|
+
if (!this.isWatching) {
|
|
96
|
+
throw new Error('Watcher is not running');
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
const resolvedPath = path.resolve(watchPath);
|
|
100
|
+
|
|
101
|
+
if (this.watchedPaths.has(resolvedPath)) {
|
|
102
|
+
return;
|
|
103
|
+
}
|
|
104
|
+
|
|
105
|
+
try {
|
|
106
|
+
await this.watcher.add(resolvedPath);
|
|
107
|
+
this.watchedPaths.add(resolvedPath);
|
|
108
|
+
this.emit('pathAdded', { path: resolvedPath });
|
|
109
|
+
} catch (error) {
|
|
110
|
+
throw new Error(`Failed to add path ${watchPath}: ${error.message}`);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
/**
|
|
115
|
+
* Remove a path from watching
|
|
116
|
+
*/
|
|
117
|
+
async removePath(watchPath) {
|
|
118
|
+
if (!this.isWatching) {
|
|
119
|
+
return;
|
|
120
|
+
}
|
|
121
|
+
|
|
122
|
+
const resolvedPath = path.resolve(watchPath);
|
|
123
|
+
|
|
124
|
+
if (!this.watchedPaths.has(resolvedPath)) {
|
|
125
|
+
return;
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
try {
|
|
129
|
+
await this.watcher.unwatch(resolvedPath);
|
|
130
|
+
this.watchedPaths.delete(resolvedPath);
|
|
131
|
+
this.emit('pathRemoved', { path: resolvedPath });
|
|
132
|
+
} catch (error) {
|
|
133
|
+
throw new Error(`Failed to remove path ${watchPath}: ${error.message}`);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Get current watch status
|
|
139
|
+
*/
|
|
140
|
+
getStatus() {
|
|
141
|
+
return {
|
|
142
|
+
isWatching: this.isWatching,
|
|
143
|
+
watchedPaths: Array.from(this.watchedPaths),
|
|
144
|
+
options: this.options
|
|
145
|
+
};
|
|
146
|
+
}
|
|
147
|
+
|
|
148
|
+
/**
|
|
149
|
+
* Setup event handlers for the chokidar watcher
|
|
150
|
+
*/
|
|
151
|
+
setupEventHandlers() {
|
|
152
|
+
this.watcher
|
|
153
|
+
.on('add', (filePath, stats) => {
|
|
154
|
+
this.emit('fileAdded', {
|
|
155
|
+
path: filePath,
|
|
156
|
+
stats,
|
|
157
|
+
type: 'file'
|
|
158
|
+
});
|
|
159
|
+
})
|
|
160
|
+
.on('addDir', (dirPath, stats) => {
|
|
161
|
+
this.emit('directoryAdded', {
|
|
162
|
+
path: dirPath,
|
|
163
|
+
stats,
|
|
164
|
+
type: 'directory'
|
|
165
|
+
});
|
|
166
|
+
})
|
|
167
|
+
.on('change', (filePath, stats) => {
|
|
168
|
+
this.emit('fileChanged', {
|
|
169
|
+
path: filePath,
|
|
170
|
+
stats,
|
|
171
|
+
type: 'file'
|
|
172
|
+
});
|
|
173
|
+
})
|
|
174
|
+
.on('unlink', (filePath) => {
|
|
175
|
+
this.emit('fileRemoved', {
|
|
176
|
+
path: filePath,
|
|
177
|
+
type: 'file'
|
|
178
|
+
});
|
|
179
|
+
})
|
|
180
|
+
.on('unlinkDir', (dirPath) => {
|
|
181
|
+
this.emit('directoryRemoved', {
|
|
182
|
+
path: dirPath,
|
|
183
|
+
type: 'directory'
|
|
184
|
+
});
|
|
185
|
+
})
|
|
186
|
+
.on('error', (error) => {
|
|
187
|
+
this.emit('error', error);
|
|
188
|
+
});
|
|
189
|
+
}
|
|
190
|
+
}
|
|
191
|
+
|
|
192
|
+
module.exports = {
|
|
193
|
+
FileSystemWatcher
|
|
194
|
+
};
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* File Monitor - Main Module
|
|
3
|
+
*
|
|
4
|
+
* Main orchestrator for file monitoring functionality.
|
|
5
|
+
* This file imports and coordinates the modular monitoring components.
|
|
6
|
+
*/
|
|
7
|
+
|
|
8
|
+
const FileMonitor = require('./file-monitor/file-monitor');
|
|
9
|
+
const { FileSystemWatcher } = require('./file-monitor/watcher');
|
|
10
|
+
const { MonitoringFileAnalyzer } = require('./file-monitor/file-analyzer');
|
|
11
|
+
|
|
12
|
+
// Re-export all classes for backward compatibility
|
|
13
|
+
module.exports = FileMonitor;
|
|
14
|
+
|
|
15
|
+
// Also export individual components for advanced usage
|
|
16
|
+
module.exports.FileSystemWatcher = FileSystemWatcher;
|
|
17
|
+
module.exports.MonitoringFileAnalyzer = MonitoringFileAnalyzer;
|