 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>
		
			
				
	
	
		
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			46 lines
		
	
	
		
			1.4 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // this spawns a child process that listens for SIGHUP when the
 | |
| // parent process exits, and after 200ms, sends a SIGKILL to the
 | |
| // child, in case it did not terminate.
 | |
| import { spawn } from 'child_process';
 | |
| const watchdogCode = String.raw `
 | |
| const pid = parseInt(process.argv[1], 10)
 | |
| process.title = 'node (foreground-child watchdog pid=' + pid + ')'
 | |
| if (!isNaN(pid)) {
 | |
|   let barked = false
 | |
|   // keepalive
 | |
|   const interval = setInterval(() => {}, 60000)
 | |
|   const bark = () => {
 | |
|     clearInterval(interval)
 | |
|     if (barked) return
 | |
|     barked = true
 | |
|     process.removeListener('SIGHUP', bark)
 | |
|     setTimeout(() => {
 | |
|       try {
 | |
|         process.kill(pid, 'SIGKILL')
 | |
|         setTimeout(() => process.exit(), 200)
 | |
|       } catch (_) {}
 | |
|     }, 500)
 | |
|   })
 | |
|   process.on('SIGHUP', bark)
 | |
| }
 | |
| `;
 | |
| /**
 | |
|  * Pass in a ChildProcess, and this will spawn a watchdog process that
 | |
|  * will make sure it exits if the parent does, thus preventing any
 | |
|  * dangling detached zombie processes.
 | |
|  *
 | |
|  * If the child ends before the parent, then the watchdog will terminate.
 | |
|  */
 | |
| export const watchdog = (child) => {
 | |
|     let dogExited = false;
 | |
|     const dog = spawn(process.execPath, ['-e', watchdogCode, String(child.pid)], {
 | |
|         stdio: 'ignore',
 | |
|     });
 | |
|     dog.on('exit', () => (dogExited = true));
 | |
|     child.on('exit', () => {
 | |
|         if (!dogExited)
 | |
|             dog.kill('SIGKILL');
 | |
|     });
 | |
|     return dog;
 | |
| };
 | |
| //# sourceMappingURL=watchdog.js.map
 |