 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>
		
			
				
	
	
		
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
			
		
		
	
	
			44 lines
		
	
	
		
			1.8 KiB
		
	
	
	
		
			JavaScript
		
	
	
	
	
	
| // imported from https://github.com/socketio/base64-arraybuffer
 | |
| const chars = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/';
 | |
| // Use a lookup table to find the index.
 | |
| const lookup = typeof Uint8Array === 'undefined' ? [] : new Uint8Array(256);
 | |
| for (let i = 0; i < chars.length; i++) {
 | |
|     lookup[chars.charCodeAt(i)] = i;
 | |
| }
 | |
| export const encode = (arraybuffer) => {
 | |
|     let bytes = new Uint8Array(arraybuffer), i, len = bytes.length, base64 = '';
 | |
|     for (i = 0; i < len; i += 3) {
 | |
|         base64 += chars[bytes[i] >> 2];
 | |
|         base64 += chars[((bytes[i] & 3) << 4) | (bytes[i + 1] >> 4)];
 | |
|         base64 += chars[((bytes[i + 1] & 15) << 2) | (bytes[i + 2] >> 6)];
 | |
|         base64 += chars[bytes[i + 2] & 63];
 | |
|     }
 | |
|     if (len % 3 === 2) {
 | |
|         base64 = base64.substring(0, base64.length - 1) + '=';
 | |
|     }
 | |
|     else if (len % 3 === 1) {
 | |
|         base64 = base64.substring(0, base64.length - 2) + '==';
 | |
|     }
 | |
|     return base64;
 | |
| };
 | |
| export const decode = (base64) => {
 | |
|     let bufferLength = base64.length * 0.75, len = base64.length, i, p = 0, encoded1, encoded2, encoded3, encoded4;
 | |
|     if (base64[base64.length - 1] === '=') {
 | |
|         bufferLength--;
 | |
|         if (base64[base64.length - 2] === '=') {
 | |
|             bufferLength--;
 | |
|         }
 | |
|     }
 | |
|     const arraybuffer = new ArrayBuffer(bufferLength), bytes = new Uint8Array(arraybuffer);
 | |
|     for (i = 0; i < len; i += 4) {
 | |
|         encoded1 = lookup[base64.charCodeAt(i)];
 | |
|         encoded2 = lookup[base64.charCodeAt(i + 1)];
 | |
|         encoded3 = lookup[base64.charCodeAt(i + 2)];
 | |
|         encoded4 = lookup[base64.charCodeAt(i + 3)];
 | |
|         bytes[p++] = (encoded1 << 2) | (encoded2 >> 4);
 | |
|         bytes[p++] = ((encoded2 & 15) << 4) | (encoded3 >> 2);
 | |
|         bytes[p++] = ((encoded3 & 3) << 6) | (encoded4 & 63);
 | |
|     }
 | |
|     return arraybuffer;
 | |
| };
 |