Frontend Enhancements: - Complete React TypeScript frontend with modern UI components - Distributed workflows management interface with real-time updates - Socket.IO integration for live agent status monitoring - Agent management dashboard with cluster visualization - Project management interface with metrics and task tracking - Responsive design with proper error handling and loading states Backend Infrastructure: - Distributed coordinator for multi-agent workflow orchestration - Cluster management API with comprehensive agent operations - Enhanced database models for agents and projects - Project service for filesystem-based project discovery - Performance monitoring and metrics collection - Comprehensive API documentation and error handling Documentation: - Complete distributed development guide (README_DISTRIBUTED.md) - Comprehensive development report with architecture insights - System configuration templates and deployment guides The platform now provides a complete web interface for managing the distributed AI cluster with real-time monitoring, workflow orchestration, and agent coordination capabilities. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
43 lines
1.3 KiB
JavaScript
43 lines
1.3 KiB
JavaScript
var path = require('path');
|
|
var parse = path.parse || require('path-parse'); // eslint-disable-line global-require
|
|
|
|
var getNodeModulesDirs = function getNodeModulesDirs(absoluteStart, modules) {
|
|
var prefix = '/';
|
|
if ((/^([A-Za-z]:)/).test(absoluteStart)) {
|
|
prefix = '';
|
|
} else if ((/^\\\\/).test(absoluteStart)) {
|
|
prefix = '\\\\';
|
|
}
|
|
|
|
var paths = [absoluteStart];
|
|
var parsed = parse(absoluteStart);
|
|
while (parsed.dir !== paths[paths.length - 1]) {
|
|
paths.push(parsed.dir);
|
|
parsed = parse(parsed.dir);
|
|
}
|
|
|
|
return paths.reduce(function (dirs, aPath) {
|
|
return dirs.concat(modules.map(function (moduleDir) {
|
|
return path.resolve(prefix, aPath, moduleDir);
|
|
}));
|
|
}, []);
|
|
};
|
|
|
|
module.exports = function nodeModulesPaths(start, opts, request) {
|
|
var modules = opts && opts.moduleDirectory
|
|
? [].concat(opts.moduleDirectory)
|
|
: ['node_modules'];
|
|
|
|
if (opts && typeof opts.paths === 'function') {
|
|
return opts.paths(
|
|
request,
|
|
start,
|
|
function () { return getNodeModulesDirs(start, modules); },
|
|
opts
|
|
);
|
|
}
|
|
|
|
var dirs = getNodeModulesDirs(start, modules);
|
|
return opts && opts.paths ? dirs.concat(opts.paths) : dirs;
|
|
};
|