 85bf1341f3
			
		
	
	85bf1341f3
	
	
	
		
			
			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>
		
			
				
	
	
		
			69 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			1.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| 'use strict';
 | |
| const path = require('path');
 | |
| const fs = require('fs');
 | |
| const {promisify} = require('util');
 | |
| const pLocate = require('p-locate');
 | |
| 
 | |
| const fsStat = promisify(fs.stat);
 | |
| const fsLStat = promisify(fs.lstat);
 | |
| 
 | |
| const typeMappings = {
 | |
| 	directory: 'isDirectory',
 | |
| 	file: 'isFile'
 | |
| };
 | |
| 
 | |
| function checkType({type}) {
 | |
| 	if (type in typeMappings) {
 | |
| 		return;
 | |
| 	}
 | |
| 
 | |
| 	throw new Error(`Invalid type specified: ${type}`);
 | |
| }
 | |
| 
 | |
| const matchType = (type, stat) => type === undefined || stat[typeMappings[type]]();
 | |
| 
 | |
| module.exports = async (paths, options) => {
 | |
| 	options = {
 | |
| 		cwd: process.cwd(),
 | |
| 		type: 'file',
 | |
| 		allowSymlinks: true,
 | |
| 		...options
 | |
| 	};
 | |
| 
 | |
| 	checkType(options);
 | |
| 
 | |
| 	const statFn = options.allowSymlinks ? fsStat : fsLStat;
 | |
| 
 | |
| 	return pLocate(paths, async path_ => {
 | |
| 		try {
 | |
| 			const stat = await statFn(path.resolve(options.cwd, path_));
 | |
| 			return matchType(options.type, stat);
 | |
| 		} catch {
 | |
| 			return false;
 | |
| 		}
 | |
| 	}, options);
 | |
| };
 | |
| 
 | |
| module.exports.sync = (paths, options) => {
 | |
| 	options = {
 | |
| 		cwd: process.cwd(),
 | |
| 		allowSymlinks: true,
 | |
| 		type: 'file',
 | |
| 		...options
 | |
| 	};
 | |
| 
 | |
| 	checkType(options);
 | |
| 
 | |
| 	const statFn = options.allowSymlinks ? fs.statSync : fs.lstatSync;
 | |
| 
 | |
| 	for (const path_ of paths) {
 | |
| 		try {
 | |
| 			const stat = statFn(path.resolve(options.cwd, path_));
 | |
| 
 | |
| 			if (matchType(options.type, stat)) {
 | |
| 				return path_;
 | |
| 			}
 | |
| 		} catch {}
 | |
| 	}
 | |
| };
 |