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>
31 lines
1.1 KiB
TypeScript
31 lines
1.1 KiB
TypeScript
/// <reference types="node" />
|
|
import { EventEmitter } from 'events';
|
|
import * as fsScandir from '@nodelib/fs.scandir';
|
|
import type Settings from '../settings';
|
|
import type { Entry, Errno } from '../types';
|
|
import Reader from './reader';
|
|
declare type EntryEventCallback = (entry: Entry) => void;
|
|
declare type ErrorEventCallback = (error: Errno) => void;
|
|
declare type EndEventCallback = () => void;
|
|
export default class AsyncReader extends Reader {
|
|
protected readonly _settings: Settings;
|
|
protected readonly _scandir: typeof fsScandir.scandir;
|
|
protected readonly _emitter: EventEmitter;
|
|
private readonly _queue;
|
|
private _isFatalError;
|
|
private _isDestroyed;
|
|
constructor(_root: string, _settings: Settings);
|
|
read(): EventEmitter;
|
|
get isDestroyed(): boolean;
|
|
destroy(): void;
|
|
onEntry(callback: EntryEventCallback): void;
|
|
onError(callback: ErrorEventCallback): void;
|
|
onEnd(callback: EndEventCallback): void;
|
|
private _pushToQueue;
|
|
private _worker;
|
|
private _handleError;
|
|
private _handleEntry;
|
|
private _emitEntry;
|
|
}
|
|
export {};
|