@claude-flow/shared 3.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.agentic-flow/intelligence.json +16 -0
- package/README.md +323 -0
- package/__tests__/coverage/base.css +224 -0
- package/__tests__/coverage/block-navigation.js +87 -0
- package/__tests__/coverage/coverage-final.json +50 -0
- package/__tests__/coverage/favicon.png +0 -0
- package/__tests__/coverage/index.html +326 -0
- package/__tests__/coverage/lcov-report/base.css +224 -0
- package/__tests__/coverage/lcov-report/block-navigation.js +87 -0
- package/__tests__/coverage/lcov-report/favicon.png +0 -0
- package/__tests__/coverage/lcov-report/index.html +326 -0
- package/__tests__/coverage/lcov-report/prettify.css +1 -0
- package/__tests__/coverage/lcov-report/prettify.js +2 -0
- package/__tests__/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/__tests__/coverage/lcov-report/sorter.js +210 -0
- package/__tests__/coverage/lcov-report/src/core/config/defaults.ts.html +706 -0
- package/__tests__/coverage/lcov-report/src/core/config/index.html +161 -0
- package/__tests__/coverage/lcov-report/src/core/config/loader.ts.html +898 -0
- package/__tests__/coverage/lcov-report/src/core/config/schema.ts.html +649 -0
- package/__tests__/coverage/lcov-report/src/core/config/validator.ts.html +712 -0
- package/__tests__/coverage/lcov-report/src/core/event-bus.ts.html +793 -0
- package/__tests__/coverage/lcov-report/src/core/index.html +116 -0
- package/__tests__/coverage/lcov-report/src/core/interfaces/event.interface.ts.html +886 -0
- package/__tests__/coverage/lcov-report/src/core/interfaces/index.html +116 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/event-coordinator.ts.html +451 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/health-monitor.ts.html +727 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/index.html +176 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/lifecycle-manager.ts.html +874 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/session-manager.ts.html +922 -0
- package/__tests__/coverage/lcov-report/src/core/orchestrator/task-manager.ts.html +1036 -0
- package/__tests__/coverage/lcov-report/src/events/domain-events.ts.html +1837 -0
- package/__tests__/coverage/lcov-report/src/events/event-store.ts.html +1849 -0
- package/__tests__/coverage/lcov-report/src/events/example-usage.ts.html +964 -0
- package/__tests__/coverage/lcov-report/src/events/index.html +176 -0
- package/__tests__/coverage/lcov-report/src/events/projections.ts.html +1768 -0
- package/__tests__/coverage/lcov-report/src/events/state-reconstructor.ts.html +1132 -0
- package/__tests__/coverage/lcov-report/src/events.ts.html +1186 -0
- package/__tests__/coverage/lcov-report/src/hooks/example-usage.ts.html +1582 -0
- package/__tests__/coverage/lcov-report/src/hooks/executor.ts.html +1222 -0
- package/__tests__/coverage/lcov-report/src/hooks/index.html +191 -0
- package/__tests__/coverage/lcov-report/src/hooks/registry.ts.html +1084 -0
- package/__tests__/coverage/lcov-report/src/hooks/safety/bash-safety.ts.html +1897 -0
- package/__tests__/coverage/lcov-report/src/hooks/safety/file-organization.ts.html +1504 -0
- package/__tests__/coverage/lcov-report/src/hooks/safety/git-commit.ts.html +1954 -0
- package/__tests__/coverage/lcov-report/src/hooks/safety/index.html +146 -0
- package/__tests__/coverage/lcov-report/src/hooks/session-hooks.ts.html +1762 -0
- package/__tests__/coverage/lcov-report/src/hooks/task-hooks.ts.html +1624 -0
- package/__tests__/coverage/lcov-report/src/hooks/types.ts.html +1156 -0
- package/__tests__/coverage/lcov-report/src/index.html +176 -0
- package/__tests__/coverage/lcov-report/src/mcp/connection-pool.ts.html +1399 -0
- package/__tests__/coverage/lcov-report/src/mcp/index.html +176 -0
- package/__tests__/coverage/lcov-report/src/mcp/server.ts.html +2407 -0
- package/__tests__/coverage/lcov-report/src/mcp/session-manager.ts.html +1369 -0
- package/__tests__/coverage/lcov-report/src/mcp/tool-registry.ts.html +1783 -0
- package/__tests__/coverage/lcov-report/src/mcp/transport/http.ts.html +1756 -0
- package/__tests__/coverage/lcov-report/src/mcp/transport/index.html +146 -0
- package/__tests__/coverage/lcov-report/src/mcp/transport/stdio.ts.html +1057 -0
- package/__tests__/coverage/lcov-report/src/mcp/transport/websocket.ts.html +1537 -0
- package/__tests__/coverage/lcov-report/src/mcp/types.ts.html +1780 -0
- package/__tests__/coverage/lcov-report/src/plugin-interface.ts.html +2074 -0
- package/__tests__/coverage/lcov-report/src/plugin-loader.ts.html +1999 -0
- package/__tests__/coverage/lcov-report/src/plugin-registry.ts.html +1897 -0
- package/__tests__/coverage/lcov-report/src/plugins/official/hive-mind-plugin.ts.html +1075 -0
- package/__tests__/coverage/lcov-report/src/plugins/official/index.html +131 -0
- package/__tests__/coverage/lcov-report/src/plugins/official/maestro-plugin.ts.html +1609 -0
- package/__tests__/coverage/lcov-report/src/resilience/bulkhead.ts.html +916 -0
- package/__tests__/coverage/lcov-report/src/resilience/circuit-breaker.ts.html +1063 -0
- package/__tests__/coverage/lcov-report/src/resilience/index.html +161 -0
- package/__tests__/coverage/lcov-report/src/resilience/rate-limiter.ts.html +1345 -0
- package/__tests__/coverage/lcov-report/src/resilience/retry.ts.html +757 -0
- package/__tests__/coverage/lcov-report/src/security/index.html +131 -0
- package/__tests__/coverage/lcov-report/src/security/input-validation.ts.html +880 -0
- package/__tests__/coverage/lcov-report/src/security/secure-random.ts.html +562 -0
- package/__tests__/coverage/lcov-report/src/types/index.html +131 -0
- package/__tests__/coverage/lcov-report/src/types/swarm.types.ts.html +850 -0
- package/__tests__/coverage/lcov-report/src/types/task.types.ts.html +700 -0
- package/__tests__/coverage/lcov-report/src/types.ts.html +1186 -0
- package/__tests__/coverage/lcov-report/src/utils/index.html +116 -0
- package/__tests__/coverage/lcov-report/src/utils/secure-logger.ts.html +856 -0
- package/__tests__/coverage/lcov.info +19877 -0
- package/__tests__/coverage/prettify.css +1 -0
- package/__tests__/coverage/prettify.js +2 -0
- package/__tests__/coverage/sort-arrow-sprite.png +0 -0
- package/__tests__/coverage/sorter.js +210 -0
- package/__tests__/coverage/src/core/config/defaults.ts.html +706 -0
- package/__tests__/coverage/src/core/config/index.html +161 -0
- package/__tests__/coverage/src/core/config/loader.ts.html +898 -0
- package/__tests__/coverage/src/core/config/schema.ts.html +649 -0
- package/__tests__/coverage/src/core/config/validator.ts.html +712 -0
- package/__tests__/coverage/src/core/event-bus.ts.html +793 -0
- package/__tests__/coverage/src/core/index.html +116 -0
- package/__tests__/coverage/src/core/interfaces/event.interface.ts.html +886 -0
- package/__tests__/coverage/src/core/interfaces/index.html +116 -0
- package/__tests__/coverage/src/core/orchestrator/event-coordinator.ts.html +451 -0
- package/__tests__/coverage/src/core/orchestrator/health-monitor.ts.html +727 -0
- package/__tests__/coverage/src/core/orchestrator/index.html +176 -0
- package/__tests__/coverage/src/core/orchestrator/lifecycle-manager.ts.html +874 -0
- package/__tests__/coverage/src/core/orchestrator/session-manager.ts.html +922 -0
- package/__tests__/coverage/src/core/orchestrator/task-manager.ts.html +1036 -0
- package/__tests__/coverage/src/events/domain-events.ts.html +1837 -0
- package/__tests__/coverage/src/events/event-store.ts.html +1849 -0
- package/__tests__/coverage/src/events/example-usage.ts.html +964 -0
- package/__tests__/coverage/src/events/index.html +176 -0
- package/__tests__/coverage/src/events/projections.ts.html +1768 -0
- package/__tests__/coverage/src/events/state-reconstructor.ts.html +1132 -0
- package/__tests__/coverage/src/events.ts.html +1186 -0
- package/__tests__/coverage/src/hooks/example-usage.ts.html +1582 -0
- package/__tests__/coverage/src/hooks/executor.ts.html +1222 -0
- package/__tests__/coverage/src/hooks/index.html +191 -0
- package/__tests__/coverage/src/hooks/registry.ts.html +1084 -0
- package/__tests__/coverage/src/hooks/safety/bash-safety.ts.html +1897 -0
- package/__tests__/coverage/src/hooks/safety/file-organization.ts.html +1504 -0
- package/__tests__/coverage/src/hooks/safety/git-commit.ts.html +1954 -0
- package/__tests__/coverage/src/hooks/safety/index.html +146 -0
- package/__tests__/coverage/src/hooks/session-hooks.ts.html +1762 -0
- package/__tests__/coverage/src/hooks/task-hooks.ts.html +1624 -0
- package/__tests__/coverage/src/hooks/types.ts.html +1156 -0
- package/__tests__/coverage/src/index.html +176 -0
- package/__tests__/coverage/src/mcp/connection-pool.ts.html +1399 -0
- package/__tests__/coverage/src/mcp/index.html +176 -0
- package/__tests__/coverage/src/mcp/server.ts.html +2407 -0
- package/__tests__/coverage/src/mcp/session-manager.ts.html +1369 -0
- package/__tests__/coverage/src/mcp/tool-registry.ts.html +1783 -0
- package/__tests__/coverage/src/mcp/transport/http.ts.html +1756 -0
- package/__tests__/coverage/src/mcp/transport/index.html +146 -0
- package/__tests__/coverage/src/mcp/transport/stdio.ts.html +1057 -0
- package/__tests__/coverage/src/mcp/transport/websocket.ts.html +1537 -0
- package/__tests__/coverage/src/mcp/types.ts.html +1780 -0
- package/__tests__/coverage/src/plugin-interface.ts.html +2074 -0
- package/__tests__/coverage/src/plugin-loader.ts.html +1999 -0
- package/__tests__/coverage/src/plugin-registry.ts.html +1897 -0
- package/__tests__/coverage/src/plugins/official/hive-mind-plugin.ts.html +1075 -0
- package/__tests__/coverage/src/plugins/official/index.html +131 -0
- package/__tests__/coverage/src/plugins/official/maestro-plugin.ts.html +1609 -0
- package/__tests__/coverage/src/resilience/bulkhead.ts.html +916 -0
- package/__tests__/coverage/src/resilience/circuit-breaker.ts.html +1063 -0
- package/__tests__/coverage/src/resilience/index.html +161 -0
- package/__tests__/coverage/src/resilience/rate-limiter.ts.html +1345 -0
- package/__tests__/coverage/src/resilience/retry.ts.html +757 -0
- package/__tests__/coverage/src/security/index.html +131 -0
- package/__tests__/coverage/src/security/input-validation.ts.html +880 -0
- package/__tests__/coverage/src/security/secure-random.ts.html +562 -0
- package/__tests__/coverage/src/types/index.html +131 -0
- package/__tests__/coverage/src/types/swarm.types.ts.html +850 -0
- package/__tests__/coverage/src/types/task.types.ts.html +700 -0
- package/__tests__/coverage/src/types.ts.html +1186 -0
- package/__tests__/coverage/src/utils/index.html +116 -0
- package/__tests__/coverage/src/utils/secure-logger.ts.html +856 -0
- package/__tests__/hooks/bash-safety.test.ts +289 -0
- package/__tests__/hooks/file-organization.test.ts +335 -0
- package/__tests__/hooks/git-commit.test.ts +336 -0
- package/__tests__/hooks/index.ts +23 -0
- package/__tests__/hooks/session-hooks.test.ts +357 -0
- package/__tests__/hooks/task-hooks.test.ts +193 -0
- package/dist/core/config/defaults.d.ts +41 -0
- package/dist/core/config/defaults.d.ts.map +1 -0
- package/dist/core/config/defaults.js +186 -0
- package/dist/core/config/defaults.js.map +1 -0
- package/dist/core/config/index.d.ts +8 -0
- package/dist/core/config/index.d.ts.map +1 -0
- package/dist/core/config/index.js +12 -0
- package/dist/core/config/index.js.map +1 -0
- package/dist/core/config/loader.d.ts +45 -0
- package/dist/core/config/loader.d.ts.map +1 -0
- package/dist/core/config/loader.js +222 -0
- package/dist/core/config/loader.js.map +1 -0
- package/dist/core/config/schema.d.ts +1134 -0
- package/dist/core/config/schema.d.ts.map +1 -0
- package/dist/core/config/schema.js +158 -0
- package/dist/core/config/schema.js.map +1 -0
- package/dist/core/config/validator.d.ts +92 -0
- package/dist/core/config/validator.d.ts.map +1 -0
- package/dist/core/config/validator.js +147 -0
- package/dist/core/config/validator.js.map +1 -0
- package/dist/core/event-bus.d.ts +31 -0
- package/dist/core/event-bus.d.ts.map +1 -0
- package/dist/core/event-bus.js +197 -0
- package/dist/core/event-bus.js.map +1 -0
- package/dist/core/index.d.ts +15 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +19 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/interfaces/agent.interface.d.ts +200 -0
- package/dist/core/interfaces/agent.interface.d.ts.map +1 -0
- package/dist/core/interfaces/agent.interface.js +6 -0
- package/dist/core/interfaces/agent.interface.js.map +1 -0
- package/dist/core/interfaces/coordinator.interface.d.ts +310 -0
- package/dist/core/interfaces/coordinator.interface.d.ts.map +1 -0
- package/dist/core/interfaces/coordinator.interface.js +7 -0
- package/dist/core/interfaces/coordinator.interface.js.map +1 -0
- package/dist/core/interfaces/event.interface.d.ts +224 -0
- package/dist/core/interfaces/event.interface.d.ts.map +1 -0
- package/dist/core/interfaces/event.interface.js +46 -0
- package/dist/core/interfaces/event.interface.js.map +1 -0
- package/dist/core/interfaces/index.d.ts +10 -0
- package/dist/core/interfaces/index.d.ts.map +1 -0
- package/dist/core/interfaces/index.js +15 -0
- package/dist/core/interfaces/index.js.map +1 -0
- package/dist/core/interfaces/memory.interface.d.ts +298 -0
- package/dist/core/interfaces/memory.interface.d.ts.map +1 -0
- package/dist/core/interfaces/memory.interface.js +7 -0
- package/dist/core/interfaces/memory.interface.js.map +1 -0
- package/dist/core/interfaces/task.interface.d.ts +185 -0
- package/dist/core/interfaces/task.interface.d.ts.map +1 -0
- package/dist/core/interfaces/task.interface.js +6 -0
- package/dist/core/interfaces/task.interface.js.map +1 -0
- package/dist/core/orchestrator/event-coordinator.d.ts +35 -0
- package/dist/core/orchestrator/event-coordinator.d.ts.map +1 -0
- package/dist/core/orchestrator/event-coordinator.js +101 -0
- package/dist/core/orchestrator/event-coordinator.js.map +1 -0
- package/dist/core/orchestrator/health-monitor.d.ts +60 -0
- package/dist/core/orchestrator/health-monitor.d.ts.map +1 -0
- package/dist/core/orchestrator/health-monitor.js +166 -0
- package/dist/core/orchestrator/health-monitor.js.map +1 -0
- package/dist/core/orchestrator/index.d.ts +46 -0
- package/dist/core/orchestrator/index.d.ts.map +1 -0
- package/dist/core/orchestrator/index.js +64 -0
- package/dist/core/orchestrator/index.js.map +1 -0
- package/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
- package/dist/core/orchestrator/lifecycle-manager.d.ts.map +1 -0
- package/dist/core/orchestrator/lifecycle-manager.js +195 -0
- package/dist/core/orchestrator/lifecycle-manager.js.map +1 -0
- package/dist/core/orchestrator/session-manager.d.ts +83 -0
- package/dist/core/orchestrator/session-manager.d.ts.map +1 -0
- package/dist/core/orchestrator/session-manager.js +193 -0
- package/dist/core/orchestrator/session-manager.js.map +1 -0
- package/dist/core/orchestrator/task-manager.d.ts +49 -0
- package/dist/core/orchestrator/task-manager.d.ts.map +1 -0
- package/dist/core/orchestrator/task-manager.js +253 -0
- package/dist/core/orchestrator/task-manager.js.map +1 -0
- package/dist/events/domain-events.d.ts +282 -0
- package/dist/events/domain-events.d.ts.map +1 -0
- package/dist/events/domain-events.js +165 -0
- package/dist/events/domain-events.js.map +1 -0
- package/dist/events/event-store.d.ts +126 -0
- package/dist/events/event-store.d.ts.map +1 -0
- package/dist/events/event-store.js +416 -0
- package/dist/events/event-store.js.map +1 -0
- package/dist/events/event-store.test.d.ts +8 -0
- package/dist/events/event-store.test.d.ts.map +1 -0
- package/dist/events/event-store.test.js +293 -0
- package/dist/events/event-store.test.js.map +1 -0
- package/dist/events/example-usage.d.ts +10 -0
- package/dist/events/example-usage.d.ts.map +1 -0
- package/dist/events/example-usage.js +193 -0
- package/dist/events/example-usage.js.map +1 -0
- package/dist/events/index.d.ts +19 -0
- package/dist/events/index.d.ts.map +1 -0
- package/dist/events/index.js +20 -0
- package/dist/events/index.js.map +1 -0
- package/dist/events/projections.d.ts +177 -0
- package/dist/events/projections.d.ts.map +1 -0
- package/dist/events/projections.js +421 -0
- package/dist/events/projections.js.map +1 -0
- package/dist/events/state-reconstructor.d.ts +101 -0
- package/dist/events/state-reconstructor.d.ts.map +1 -0
- package/dist/events/state-reconstructor.js +263 -0
- package/dist/events/state-reconstructor.js.map +1 -0
- package/dist/events.d.ts +80 -0
- package/dist/events.d.ts.map +1 -0
- package/dist/events.js +249 -0
- package/dist/events.js.map +1 -0
- package/dist/hooks/example-usage.d.ts +42 -0
- package/dist/hooks/example-usage.d.ts.map +1 -0
- package/dist/hooks/example-usage.js +351 -0
- package/dist/hooks/example-usage.js.map +1 -0
- package/dist/hooks/executor.d.ts +100 -0
- package/dist/hooks/executor.d.ts.map +1 -0
- package/dist/hooks/executor.js +264 -0
- package/dist/hooks/executor.js.map +1 -0
- package/dist/hooks/hooks.test.d.ts +9 -0
- package/dist/hooks/hooks.test.d.ts.map +1 -0
- package/dist/hooks/hooks.test.js +322 -0
- package/dist/hooks/hooks.test.js.map +1 -0
- package/dist/hooks/index.d.ts +52 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +51 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/registry.d.ts +133 -0
- package/dist/hooks/registry.d.ts.map +1 -0
- package/dist/hooks/registry.js +277 -0
- package/dist/hooks/registry.js.map +1 -0
- package/dist/hooks/safety/bash-safety.d.ts +105 -0
- package/dist/hooks/safety/bash-safety.d.ts.map +1 -0
- package/dist/hooks/safety/bash-safety.js +481 -0
- package/dist/hooks/safety/bash-safety.js.map +1 -0
- package/dist/hooks/safety/file-organization.d.ts +144 -0
- package/dist/hooks/safety/file-organization.d.ts.map +1 -0
- package/dist/hooks/safety/file-organization.js +328 -0
- package/dist/hooks/safety/file-organization.js.map +1 -0
- package/dist/hooks/safety/git-commit.d.ts +158 -0
- package/dist/hooks/safety/git-commit.d.ts.map +1 -0
- package/dist/hooks/safety/git-commit.js +450 -0
- package/dist/hooks/safety/git-commit.js.map +1 -0
- package/dist/hooks/safety/index.d.ts +17 -0
- package/dist/hooks/safety/index.d.ts.map +1 -0
- package/dist/hooks/safety/index.js +17 -0
- package/dist/hooks/safety/index.js.map +1 -0
- package/dist/hooks/session-hooks.d.ts +234 -0
- package/dist/hooks/session-hooks.d.ts.map +1 -0
- package/dist/hooks/session-hooks.js +334 -0
- package/dist/hooks/session-hooks.js.map +1 -0
- package/dist/hooks/task-hooks.d.ts +163 -0
- package/dist/hooks/task-hooks.d.ts.map +1 -0
- package/dist/hooks/task-hooks.js +326 -0
- package/dist/hooks/task-hooks.js.map +1 -0
- package/dist/hooks/types.d.ts +267 -0
- package/dist/hooks/types.d.ts.map +1 -0
- package/dist/hooks/types.js +62 -0
- package/dist/hooks/types.js.map +1 -0
- package/dist/hooks/verify-exports.test.d.ts +9 -0
- package/dist/hooks/verify-exports.test.d.ts.map +1 -0
- package/dist/hooks/verify-exports.test.js +93 -0
- package/dist/hooks/verify-exports.test.js.map +1 -0
- package/dist/index.d.ts +19 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +46 -0
- package/dist/index.js.map +1 -0
- package/dist/mcp/connection-pool.d.ts +98 -0
- package/dist/mcp/connection-pool.d.ts.map +1 -0
- package/dist/mcp/connection-pool.js +364 -0
- package/dist/mcp/connection-pool.js.map +1 -0
- package/dist/mcp/index.d.ts +69 -0
- package/dist/mcp/index.d.ts.map +1 -0
- package/dist/mcp/index.js +84 -0
- package/dist/mcp/index.js.map +1 -0
- package/dist/mcp/server.d.ts +166 -0
- package/dist/mcp/server.d.ts.map +1 -0
- package/dist/mcp/server.js +593 -0
- package/dist/mcp/server.js.map +1 -0
- package/dist/mcp/session-manager.d.ts +136 -0
- package/dist/mcp/session-manager.d.ts.map +1 -0
- package/dist/mcp/session-manager.js +335 -0
- package/dist/mcp/session-manager.js.map +1 -0
- package/dist/mcp/tool-registry.d.ts +178 -0
- package/dist/mcp/tool-registry.d.ts.map +1 -0
- package/dist/mcp/tool-registry.js +439 -0
- package/dist/mcp/tool-registry.js.map +1 -0
- package/dist/mcp/transport/http.d.ts +104 -0
- package/dist/mcp/transport/http.d.ts.map +1 -0
- package/dist/mcp/transport/http.js +476 -0
- package/dist/mcp/transport/http.js.map +1 -0
- package/dist/mcp/transport/index.d.ts +102 -0
- package/dist/mcp/transport/index.d.ts.map +1 -0
- package/dist/mcp/transport/index.js +238 -0
- package/dist/mcp/transport/index.js.map +1 -0
- package/dist/mcp/transport/stdio.d.ts +104 -0
- package/dist/mcp/transport/stdio.d.ts.map +1 -0
- package/dist/mcp/transport/stdio.js +263 -0
- package/dist/mcp/transport/stdio.js.map +1 -0
- package/dist/mcp/transport/websocket.d.ts +133 -0
- package/dist/mcp/transport/websocket.d.ts.map +1 -0
- package/dist/mcp/transport/websocket.js +396 -0
- package/dist/mcp/transport/websocket.js.map +1 -0
- package/dist/mcp/types.d.ts +438 -0
- package/dist/mcp/types.d.ts.map +1 -0
- package/dist/mcp/types.js +54 -0
- package/dist/mcp/types.js.map +1 -0
- package/dist/plugin-interface.d.ts +544 -0
- package/dist/plugin-interface.d.ts.map +1 -0
- package/dist/plugin-interface.js +23 -0
- package/dist/plugin-interface.js.map +1 -0
- package/dist/plugin-loader.d.ts +139 -0
- package/dist/plugin-loader.d.ts.map +1 -0
- package/dist/plugin-loader.js +434 -0
- package/dist/plugin-loader.js.map +1 -0
- package/dist/plugin-registry.d.ts +183 -0
- package/dist/plugin-registry.d.ts.map +1 -0
- package/dist/plugin-registry.js +457 -0
- package/dist/plugin-registry.js.map +1 -0
- package/dist/plugins/index.d.ts +10 -0
- package/dist/plugins/index.d.ts.map +1 -0
- package/dist/plugins/index.js +10 -0
- package/dist/plugins/index.js.map +1 -0
- package/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
- package/dist/plugins/official/hive-mind-plugin.d.ts.map +1 -0
- package/dist/plugins/official/hive-mind-plugin.js +241 -0
- package/dist/plugins/official/hive-mind-plugin.js.map +1 -0
- package/dist/plugins/official/index.d.ts +10 -0
- package/dist/plugins/official/index.d.ts.map +1 -0
- package/dist/plugins/official/index.js +10 -0
- package/dist/plugins/official/index.js.map +1 -0
- package/dist/plugins/official/maestro-plugin.d.ts +121 -0
- package/dist/plugins/official/maestro-plugin.d.ts.map +1 -0
- package/dist/plugins/official/maestro-plugin.js +355 -0
- package/dist/plugins/official/maestro-plugin.js.map +1 -0
- package/dist/plugins/types.d.ts +93 -0
- package/dist/plugins/types.d.ts.map +1 -0
- package/dist/plugins/types.js +9 -0
- package/dist/plugins/types.js.map +1 -0
- package/dist/resilience/bulkhead.d.ts +105 -0
- package/dist/resilience/bulkhead.d.ts.map +1 -0
- package/dist/resilience/bulkhead.js +206 -0
- package/dist/resilience/bulkhead.js.map +1 -0
- package/dist/resilience/circuit-breaker.d.ts +132 -0
- package/dist/resilience/circuit-breaker.d.ts.map +1 -0
- package/dist/resilience/circuit-breaker.js +233 -0
- package/dist/resilience/circuit-breaker.js.map +1 -0
- package/dist/resilience/index.d.ts +19 -0
- package/dist/resilience/index.d.ts.map +1 -0
- package/dist/resilience/index.js +19 -0
- package/dist/resilience/index.js.map +1 -0
- package/dist/resilience/rate-limiter.d.ts +168 -0
- package/dist/resilience/rate-limiter.d.ts.map +1 -0
- package/dist/resilience/rate-limiter.js +314 -0
- package/dist/resilience/rate-limiter.js.map +1 -0
- package/dist/resilience/retry.d.ts +91 -0
- package/dist/resilience/retry.d.ts.map +1 -0
- package/dist/resilience/retry.js +159 -0
- package/dist/resilience/retry.js.map +1 -0
- package/dist/security/index.d.ts +10 -0
- package/dist/security/index.d.ts.map +1 -0
- package/dist/security/index.js +12 -0
- package/dist/security/index.js.map +1 -0
- package/dist/security/input-validation.d.ts +73 -0
- package/dist/security/input-validation.d.ts.map +1 -0
- package/dist/security/input-validation.js +201 -0
- package/dist/security/input-validation.js.map +1 -0
- package/dist/security/secure-random.d.ts +92 -0
- package/dist/security/secure-random.d.ts.map +1 -0
- package/dist/security/secure-random.js +142 -0
- package/dist/security/secure-random.js.map +1 -0
- package/dist/types/agent.types.d.ts +137 -0
- package/dist/types/agent.types.d.ts.map +1 -0
- package/dist/types/agent.types.js +6 -0
- package/dist/types/agent.types.js.map +1 -0
- package/dist/types/index.d.ts +11 -0
- package/dist/types/index.d.ts.map +1 -0
- package/dist/types/index.js +17 -0
- package/dist/types/index.js.map +1 -0
- package/dist/types/mcp.types.d.ts +266 -0
- package/dist/types/mcp.types.d.ts.map +1 -0
- package/dist/types/mcp.types.js +7 -0
- package/dist/types/mcp.types.js.map +1 -0
- package/dist/types/memory.types.d.ts +236 -0
- package/dist/types/memory.types.d.ts.map +1 -0
- package/dist/types/memory.types.js +7 -0
- package/dist/types/memory.types.js.map +1 -0
- package/dist/types/swarm.types.d.ts +186 -0
- package/dist/types/swarm.types.d.ts.map +1 -0
- package/dist/types/swarm.types.js +65 -0
- package/dist/types/swarm.types.js.map +1 -0
- package/dist/types/task.types.d.ts +178 -0
- package/dist/types/task.types.d.ts.map +1 -0
- package/dist/types/task.types.js +32 -0
- package/dist/types/task.types.js.map +1 -0
- package/dist/types.d.ts +197 -0
- package/dist/types.d.ts.map +1 -0
- package/dist/types.js +21 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/secure-logger.d.ts +69 -0
- package/dist/utils/secure-logger.d.ts.map +1 -0
- package/dist/utils/secure-logger.js +208 -0
- package/dist/utils/secure-logger.js.map +1 -0
- package/docs/EVENTS_IMPLEMENTATION_SUMMARY.md +388 -0
- package/docs/EVENTS_QUICK_REFERENCE.md +470 -0
- package/docs/EVENTS_README.md +352 -0
- package/package.json +34 -0
- package/src/core/config/defaults.ts +207 -0
- package/src/core/config/index.ts +15 -0
- package/src/core/config/loader.ts +271 -0
- package/src/core/config/schema.ts +188 -0
- package/src/core/config/validator.ts +209 -0
- package/src/core/event-bus.ts +236 -0
- package/src/core/index.ts +22 -0
- package/src/core/interfaces/agent.interface.ts +251 -0
- package/src/core/interfaces/coordinator.interface.ts +363 -0
- package/src/core/interfaces/event.interface.ts +267 -0
- package/src/core/interfaces/index.ts +19 -0
- package/src/core/interfaces/memory.interface.ts +332 -0
- package/src/core/interfaces/task.interface.ts +223 -0
- package/src/core/orchestrator/event-coordinator.ts +122 -0
- package/src/core/orchestrator/health-monitor.ts +214 -0
- package/src/core/orchestrator/index.ts +89 -0
- package/src/core/orchestrator/lifecycle-manager.ts +263 -0
- package/src/core/orchestrator/session-manager.ts +279 -0
- package/src/core/orchestrator/task-manager.ts +317 -0
- package/src/events/domain-events.ts +584 -0
- package/src/events/event-store.test.ts +387 -0
- package/src/events/event-store.ts +588 -0
- package/src/events/example-usage.ts +293 -0
- package/src/events/index.ts +90 -0
- package/src/events/projections.ts +561 -0
- package/src/events/state-reconstructor.ts +349 -0
- package/src/events.ts +367 -0
- package/src/hooks/INTEGRATION.md +658 -0
- package/src/hooks/README.md +532 -0
- package/src/hooks/example-usage.ts +499 -0
- package/src/hooks/executor.ts +379 -0
- package/src/hooks/hooks.test.ts +421 -0
- package/src/hooks/index.ts +131 -0
- package/src/hooks/registry.ts +333 -0
- package/src/hooks/safety/bash-safety.ts +604 -0
- package/src/hooks/safety/file-organization.ts +473 -0
- package/src/hooks/safety/git-commit.ts +623 -0
- package/src/hooks/safety/index.ts +46 -0
- package/src/hooks/session-hooks.ts +559 -0
- package/src/hooks/task-hooks.ts +513 -0
- package/src/hooks/types.ts +357 -0
- package/src/hooks/verify-exports.test.ts +125 -0
- package/src/index.ts +190 -0
- package/src/mcp/connection-pool.ts +438 -0
- package/src/mcp/index.ts +183 -0
- package/src/mcp/server.ts +774 -0
- package/src/mcp/session-manager.ts +428 -0
- package/src/mcp/tool-registry.ts +566 -0
- package/src/mcp/transport/http.ts +557 -0
- package/src/mcp/transport/index.ts +294 -0
- package/src/mcp/transport/stdio.ts +324 -0
- package/src/mcp/transport/websocket.ts +484 -0
- package/src/mcp/types.ts +565 -0
- package/src/plugin-interface.ts +663 -0
- package/src/plugin-loader.ts +638 -0
- package/src/plugin-registry.ts +604 -0
- package/src/plugins/index.ts +34 -0
- package/src/plugins/official/hive-mind-plugin.ts +330 -0
- package/src/plugins/official/index.ts +24 -0
- package/src/plugins/official/maestro-plugin.ts +508 -0
- package/src/plugins/types.ts +108 -0
- package/src/resilience/bulkhead.ts +277 -0
- package/src/resilience/circuit-breaker.ts +326 -0
- package/src/resilience/index.ts +26 -0
- package/src/resilience/rate-limiter.ts +420 -0
- package/src/resilience/retry.ts +224 -0
- package/src/security/index.ts +39 -0
- package/src/security/input-validation.ts +265 -0
- package/src/security/secure-random.ts +159 -0
- package/src/types/agent.types.ts +144 -0
- package/src/types/index.ts +22 -0
- package/src/types/mcp.types.ts +300 -0
- package/src/types/memory.types.ts +263 -0
- package/src/types/swarm.types.ts +255 -0
- package/src/types/task.types.ts +205 -0
- package/src/types.ts +367 -0
- package/src/utils/secure-logger.d.ts +69 -0
- package/src/utils/secure-logger.d.ts.map +1 -0
- package/src/utils/secure-logger.js +208 -0
- package/src/utils/secure-logger.js.map +1 -0
- package/src/utils/secure-logger.ts +257 -0
- package/tsconfig.json +9 -0
- package/tsconfig.tsbuildinfo +1 -0
|
@@ -0,0 +1,236 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 Event Bus
|
|
3
|
+
* Core event pub/sub implementation
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
import type {
|
|
7
|
+
IEvent,
|
|
8
|
+
IEventBus,
|
|
9
|
+
IEventCreate,
|
|
10
|
+
IEventHandler,
|
|
11
|
+
IEventSubscription,
|
|
12
|
+
IEventFilter,
|
|
13
|
+
} from './interfaces/event.interface.js';
|
|
14
|
+
import { randomBytes } from 'crypto';
|
|
15
|
+
|
|
16
|
+
// Secure event ID generation
|
|
17
|
+
function generateSecureEventId(): string {
|
|
18
|
+
const timestamp = Date.now().toString(36);
|
|
19
|
+
const random = randomBytes(12).toString('hex');
|
|
20
|
+
return `evt_${timestamp}_${random}`;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Event subscription implementation
|
|
25
|
+
*/
|
|
26
|
+
class EventSubscription implements IEventSubscription {
|
|
27
|
+
private active = true;
|
|
28
|
+
private paused = false;
|
|
29
|
+
|
|
30
|
+
constructor(
|
|
31
|
+
readonly id: string,
|
|
32
|
+
readonly filter: IEventFilter,
|
|
33
|
+
private removeCallback: () => void,
|
|
34
|
+
) {}
|
|
35
|
+
|
|
36
|
+
unsubscribe(): void {
|
|
37
|
+
this.active = false;
|
|
38
|
+
this.removeCallback();
|
|
39
|
+
}
|
|
40
|
+
|
|
41
|
+
pause(): void {
|
|
42
|
+
this.paused = true;
|
|
43
|
+
}
|
|
44
|
+
|
|
45
|
+
resume(): void {
|
|
46
|
+
this.paused = false;
|
|
47
|
+
}
|
|
48
|
+
|
|
49
|
+
isActive(): boolean {
|
|
50
|
+
return this.active && !this.paused;
|
|
51
|
+
}
|
|
52
|
+
}
|
|
53
|
+
|
|
54
|
+
/**
|
|
55
|
+
* Event bus implementation
|
|
56
|
+
*/
|
|
57
|
+
export class EventBus implements IEventBus {
|
|
58
|
+
private handlers = new Map<string, Set<IEventHandler>>();
|
|
59
|
+
private subscriptions = new Map<string, { filter: IEventFilter; handler: IEventHandler; subscription: EventSubscription }>();
|
|
60
|
+
private subscriptionId = 0;
|
|
61
|
+
|
|
62
|
+
emit<T = unknown>(type: string, payload: T, options?: Partial<IEventCreate<T>>): void {
|
|
63
|
+
const event = this.createEvent(type, payload, options);
|
|
64
|
+
this.dispatchEvent(event);
|
|
65
|
+
}
|
|
66
|
+
|
|
67
|
+
async emitAsync<T = unknown>(type: string, payload: T, options?: Partial<IEventCreate<T>>): Promise<void> {
|
|
68
|
+
const event = this.createEvent(type, payload, options);
|
|
69
|
+
await this.dispatchEventAsync(event);
|
|
70
|
+
}
|
|
71
|
+
|
|
72
|
+
on<T = unknown>(type: string, handler: IEventHandler<T>): IEventSubscription {
|
|
73
|
+
return this.subscribe({ types: [type] }, handler);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
subscribe<T = unknown>(filter: IEventFilter, handler: IEventHandler<T>): IEventSubscription {
|
|
77
|
+
const id = `sub_${++this.subscriptionId}`;
|
|
78
|
+
|
|
79
|
+
// Register for all matching types
|
|
80
|
+
const types = filter.types ?? ['*'];
|
|
81
|
+
for (const type of types) {
|
|
82
|
+
let handlers = this.handlers.get(type);
|
|
83
|
+
if (!handlers) {
|
|
84
|
+
handlers = new Set();
|
|
85
|
+
this.handlers.set(type, handlers);
|
|
86
|
+
}
|
|
87
|
+
handlers.add(handler as IEventHandler);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
const subscription = new EventSubscription(id, filter, () => {
|
|
91
|
+
this.removeSubscription(id);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
this.subscriptions.set(id, { filter, handler: handler as IEventHandler, subscription });
|
|
95
|
+
|
|
96
|
+
return subscription;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
once<T = unknown>(type: string, handler: IEventHandler<T>): IEventSubscription {
|
|
100
|
+
const wrappedHandler: IEventHandler<T> = async (event) => {
|
|
101
|
+
subscription.unsubscribe();
|
|
102
|
+
await handler(event);
|
|
103
|
+
};
|
|
104
|
+
|
|
105
|
+
const subscription = this.on(type, wrappedHandler);
|
|
106
|
+
return subscription;
|
|
107
|
+
}
|
|
108
|
+
|
|
109
|
+
off(type: string, handler: IEventHandler): void {
|
|
110
|
+
const handlers = this.handlers.get(type);
|
|
111
|
+
if (handlers) {
|
|
112
|
+
handlers.delete(handler);
|
|
113
|
+
if (handlers.size === 0) {
|
|
114
|
+
this.handlers.delete(type);
|
|
115
|
+
}
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
removeAllListeners(type?: string): void {
|
|
120
|
+
if (type) {
|
|
121
|
+
this.handlers.delete(type);
|
|
122
|
+
} else {
|
|
123
|
+
this.handlers.clear();
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
listenerCount(type: string): number {
|
|
128
|
+
return this.handlers.get(type)?.size ?? 0;
|
|
129
|
+
}
|
|
130
|
+
|
|
131
|
+
eventNames(): string[] {
|
|
132
|
+
return Array.from(this.handlers.keys());
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
private createEvent<T>(type: string, payload: T, options?: Partial<IEventCreate<T>>): IEvent<T> {
|
|
136
|
+
return {
|
|
137
|
+
id: generateSecureEventId(),
|
|
138
|
+
type,
|
|
139
|
+
timestamp: new Date(),
|
|
140
|
+
source: options?.source ?? 'event-bus',
|
|
141
|
+
payload,
|
|
142
|
+
priority: options?.priority,
|
|
143
|
+
correlationId: options?.correlationId,
|
|
144
|
+
causationId: options?.causationId,
|
|
145
|
+
metadata: options?.metadata,
|
|
146
|
+
};
|
|
147
|
+
}
|
|
148
|
+
|
|
149
|
+
private dispatchEvent<T>(event: IEvent<T>): void {
|
|
150
|
+
// Get handlers for specific type
|
|
151
|
+
const typeHandlers = this.handlers.get(event.type);
|
|
152
|
+
|
|
153
|
+
// Get wildcard handlers
|
|
154
|
+
const wildcardHandlers = this.handlers.get('*');
|
|
155
|
+
|
|
156
|
+
const allHandlers = new Set<IEventHandler>();
|
|
157
|
+
|
|
158
|
+
if (typeHandlers) {
|
|
159
|
+
for (const handler of typeHandlers) {
|
|
160
|
+
allHandlers.add(handler);
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
|
|
164
|
+
if (wildcardHandlers) {
|
|
165
|
+
for (const handler of wildcardHandlers) {
|
|
166
|
+
allHandlers.add(handler);
|
|
167
|
+
}
|
|
168
|
+
}
|
|
169
|
+
|
|
170
|
+
for (const handler of allHandlers) {
|
|
171
|
+
try {
|
|
172
|
+
const result = handler(event);
|
|
173
|
+
if (result instanceof Promise) {
|
|
174
|
+
result.catch((error) => {
|
|
175
|
+
console.error(`Error in async event handler for ${event.type}:`, error);
|
|
176
|
+
});
|
|
177
|
+
}
|
|
178
|
+
} catch (error) {
|
|
179
|
+
console.error(`Error in event handler for ${event.type}:`, error);
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
}
|
|
183
|
+
|
|
184
|
+
private async dispatchEventAsync<T>(event: IEvent<T>): Promise<void> {
|
|
185
|
+
const typeHandlers = this.handlers.get(event.type);
|
|
186
|
+
const wildcardHandlers = this.handlers.get('*');
|
|
187
|
+
|
|
188
|
+
const allHandlers = new Set<IEventHandler>();
|
|
189
|
+
|
|
190
|
+
if (typeHandlers) {
|
|
191
|
+
for (const handler of typeHandlers) {
|
|
192
|
+
allHandlers.add(handler);
|
|
193
|
+
}
|
|
194
|
+
}
|
|
195
|
+
|
|
196
|
+
if (wildcardHandlers) {
|
|
197
|
+
for (const handler of wildcardHandlers) {
|
|
198
|
+
allHandlers.add(handler);
|
|
199
|
+
}
|
|
200
|
+
}
|
|
201
|
+
|
|
202
|
+
const promises = Array.from(allHandlers).map(async (handler) => {
|
|
203
|
+
try {
|
|
204
|
+
await handler(event);
|
|
205
|
+
} catch (error) {
|
|
206
|
+
console.error(`Error in event handler for ${event.type}:`, error);
|
|
207
|
+
}
|
|
208
|
+
});
|
|
209
|
+
|
|
210
|
+
await Promise.allSettled(promises);
|
|
211
|
+
}
|
|
212
|
+
|
|
213
|
+
private removeSubscription(id: string): void {
|
|
214
|
+
const sub = this.subscriptions.get(id);
|
|
215
|
+
if (sub) {
|
|
216
|
+
const types = sub.filter.types ?? ['*'];
|
|
217
|
+
for (const type of types) {
|
|
218
|
+
const handlers = this.handlers.get(type);
|
|
219
|
+
if (handlers) {
|
|
220
|
+
handlers.delete(sub.handler);
|
|
221
|
+
if (handlers.size === 0) {
|
|
222
|
+
this.handlers.delete(type);
|
|
223
|
+
}
|
|
224
|
+
}
|
|
225
|
+
}
|
|
226
|
+
this.subscriptions.delete(id);
|
|
227
|
+
}
|
|
228
|
+
}
|
|
229
|
+
}
|
|
230
|
+
|
|
231
|
+
/**
|
|
232
|
+
* Create a new event bus instance
|
|
233
|
+
*/
|
|
234
|
+
export function createEventBus(): IEventBus {
|
|
235
|
+
return new EventBus();
|
|
236
|
+
}
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 Core Module - Public API
|
|
3
|
+
* Domain-Driven Design with Clean Architecture
|
|
4
|
+
*
|
|
5
|
+
* This module provides the core architecture for claude-flow v3:
|
|
6
|
+
* - Decomposed orchestrator (task, session, health, lifecycle management)
|
|
7
|
+
* - Event-driven architecture with event bus and coordinator
|
|
8
|
+
* - Type-safe configuration with Zod validation
|
|
9
|
+
* - Clean interfaces following DDD principles
|
|
10
|
+
*/
|
|
11
|
+
|
|
12
|
+
// Interfaces (Domain contracts)
|
|
13
|
+
export * from './interfaces/index.js';
|
|
14
|
+
|
|
15
|
+
// Event system
|
|
16
|
+
export { EventBus, createEventBus } from './event-bus.js';
|
|
17
|
+
|
|
18
|
+
// Orchestrator components (decomposed)
|
|
19
|
+
export * from './orchestrator/index.js';
|
|
20
|
+
|
|
21
|
+
// Configuration
|
|
22
|
+
export * from './config/index.js';
|
|
@@ -0,0 +1,251 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 Agent Interfaces
|
|
3
|
+
* Domain-Driven Design - Agent Lifecycle Bounded Context
|
|
4
|
+
*/
|
|
5
|
+
|
|
6
|
+
/**
|
|
7
|
+
* Agent status in the system
|
|
8
|
+
*/
|
|
9
|
+
export type AgentStatus = 'spawning' | 'active' | 'idle' | 'busy' | 'error' | 'terminated';
|
|
10
|
+
|
|
11
|
+
/**
|
|
12
|
+
* Agent type classification
|
|
13
|
+
*/
|
|
14
|
+
export type AgentType =
|
|
15
|
+
| 'coder'
|
|
16
|
+
| 'reviewer'
|
|
17
|
+
| 'tester'
|
|
18
|
+
| 'researcher'
|
|
19
|
+
| 'planner'
|
|
20
|
+
| 'architect'
|
|
21
|
+
| 'coordinator'
|
|
22
|
+
| 'security'
|
|
23
|
+
| 'performance'
|
|
24
|
+
| 'custom';
|
|
25
|
+
|
|
26
|
+
/**
|
|
27
|
+
* Agent capability declaration
|
|
28
|
+
*/
|
|
29
|
+
export interface IAgentCapability {
|
|
30
|
+
name: string;
|
|
31
|
+
level: 'basic' | 'intermediate' | 'advanced' | 'expert';
|
|
32
|
+
description?: string;
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Agent configuration for spawning
|
|
37
|
+
*/
|
|
38
|
+
export interface IAgentConfig {
|
|
39
|
+
readonly id: string;
|
|
40
|
+
readonly name: string;
|
|
41
|
+
readonly type: AgentType | string;
|
|
42
|
+
|
|
43
|
+
capabilities: string[];
|
|
44
|
+
maxConcurrentTasks: number;
|
|
45
|
+
priority: number;
|
|
46
|
+
|
|
47
|
+
timeout?: number;
|
|
48
|
+
retryPolicy?: {
|
|
49
|
+
maxRetries: number;
|
|
50
|
+
backoffMs: number;
|
|
51
|
+
backoffMultiplier: number;
|
|
52
|
+
};
|
|
53
|
+
|
|
54
|
+
resources?: {
|
|
55
|
+
maxMemoryMb?: number;
|
|
56
|
+
maxCpuPercent?: number;
|
|
57
|
+
};
|
|
58
|
+
|
|
59
|
+
metadata?: Record<string, unknown>;
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
/**
|
|
63
|
+
* Core agent entity
|
|
64
|
+
*/
|
|
65
|
+
export interface IAgent {
|
|
66
|
+
readonly id: string;
|
|
67
|
+
readonly name: string;
|
|
68
|
+
readonly type: AgentType | string;
|
|
69
|
+
readonly config: IAgentConfig;
|
|
70
|
+
readonly createdAt: Date;
|
|
71
|
+
|
|
72
|
+
status: AgentStatus;
|
|
73
|
+
currentTaskCount: number;
|
|
74
|
+
lastActivity: Date;
|
|
75
|
+
|
|
76
|
+
sessionId?: string;
|
|
77
|
+
terminalId?: string;
|
|
78
|
+
memoryBankId?: string;
|
|
79
|
+
|
|
80
|
+
metrics?: {
|
|
81
|
+
tasksCompleted: number;
|
|
82
|
+
tasksFailed: number;
|
|
83
|
+
avgTaskDuration: number;
|
|
84
|
+
errorCount: number;
|
|
85
|
+
uptime: number;
|
|
86
|
+
};
|
|
87
|
+
|
|
88
|
+
health?: {
|
|
89
|
+
status: 'healthy' | 'degraded' | 'unhealthy';
|
|
90
|
+
lastCheck: Date;
|
|
91
|
+
issues?: string[];
|
|
92
|
+
};
|
|
93
|
+
}
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Agent session for tracking active work
|
|
97
|
+
*/
|
|
98
|
+
export interface IAgentSession {
|
|
99
|
+
readonly id: string;
|
|
100
|
+
readonly agentId: string;
|
|
101
|
+
readonly startTime: Date;
|
|
102
|
+
|
|
103
|
+
status: 'active' | 'idle' | 'terminated';
|
|
104
|
+
terminalId: string;
|
|
105
|
+
memoryBankId: string;
|
|
106
|
+
|
|
107
|
+
lastActivity: Date;
|
|
108
|
+
endTime?: Date;
|
|
109
|
+
|
|
110
|
+
metadata?: Record<string, unknown>;
|
|
111
|
+
}
|
|
112
|
+
|
|
113
|
+
/**
|
|
114
|
+
* Agent pool for managing multiple agents
|
|
115
|
+
*/
|
|
116
|
+
export interface IAgentPool {
|
|
117
|
+
/**
|
|
118
|
+
* Add an agent to the pool
|
|
119
|
+
*/
|
|
120
|
+
add(agent: IAgent): void;
|
|
121
|
+
|
|
122
|
+
/**
|
|
123
|
+
* Remove an agent from the pool
|
|
124
|
+
*/
|
|
125
|
+
remove(agentId: string): boolean;
|
|
126
|
+
|
|
127
|
+
/**
|
|
128
|
+
* Get an agent by ID
|
|
129
|
+
*/
|
|
130
|
+
get(agentId: string): IAgent | undefined;
|
|
131
|
+
|
|
132
|
+
/**
|
|
133
|
+
* Get all agents in the pool
|
|
134
|
+
*/
|
|
135
|
+
getAll(): IAgent[];
|
|
136
|
+
|
|
137
|
+
/**
|
|
138
|
+
* Get agents by status
|
|
139
|
+
*/
|
|
140
|
+
getByStatus(status: AgentStatus): IAgent[];
|
|
141
|
+
|
|
142
|
+
/**
|
|
143
|
+
* Get agents by type
|
|
144
|
+
*/
|
|
145
|
+
getByType(type: AgentType | string): IAgent[];
|
|
146
|
+
|
|
147
|
+
/**
|
|
148
|
+
* Get available agents (can accept more tasks)
|
|
149
|
+
*/
|
|
150
|
+
getAvailable(): IAgent[];
|
|
151
|
+
|
|
152
|
+
/**
|
|
153
|
+
* Get pool size
|
|
154
|
+
*/
|
|
155
|
+
size(): number;
|
|
156
|
+
|
|
157
|
+
/**
|
|
158
|
+
* Check if pool has capacity
|
|
159
|
+
*/
|
|
160
|
+
hasCapacity(maxSize: number): boolean;
|
|
161
|
+
|
|
162
|
+
/**
|
|
163
|
+
* Clear all agents
|
|
164
|
+
*/
|
|
165
|
+
clear(): void;
|
|
166
|
+
}
|
|
167
|
+
|
|
168
|
+
/**
|
|
169
|
+
* Agent lifecycle manager interface
|
|
170
|
+
*/
|
|
171
|
+
export interface IAgentLifecycleManager {
|
|
172
|
+
/**
|
|
173
|
+
* Spawn a new agent
|
|
174
|
+
*/
|
|
175
|
+
spawn(config: IAgentConfig): Promise<IAgent>;
|
|
176
|
+
|
|
177
|
+
/**
|
|
178
|
+
* Spawn multiple agents in parallel
|
|
179
|
+
*/
|
|
180
|
+
spawnBatch(configs: IAgentConfig[]): Promise<Map<string, IAgent>>;
|
|
181
|
+
|
|
182
|
+
/**
|
|
183
|
+
* Terminate an agent
|
|
184
|
+
*/
|
|
185
|
+
terminate(agentId: string, reason?: string): Promise<void>;
|
|
186
|
+
|
|
187
|
+
/**
|
|
188
|
+
* Terminate all agents
|
|
189
|
+
*/
|
|
190
|
+
terminateAll(reason?: string): Promise<void>;
|
|
191
|
+
|
|
192
|
+
/**
|
|
193
|
+
* Restart an agent
|
|
194
|
+
*/
|
|
195
|
+
restart(agentId: string): Promise<IAgent>;
|
|
196
|
+
|
|
197
|
+
/**
|
|
198
|
+
* Update agent configuration
|
|
199
|
+
*/
|
|
200
|
+
updateConfig(agentId: string, config: Partial<IAgentConfig>): Promise<void>;
|
|
201
|
+
|
|
202
|
+
/**
|
|
203
|
+
* Get agent by ID
|
|
204
|
+
*/
|
|
205
|
+
getAgent(agentId: string): IAgent | undefined;
|
|
206
|
+
|
|
207
|
+
/**
|
|
208
|
+
* Get all agents
|
|
209
|
+
*/
|
|
210
|
+
getAllAgents(): IAgent[];
|
|
211
|
+
|
|
212
|
+
/**
|
|
213
|
+
* Get active agents count
|
|
214
|
+
*/
|
|
215
|
+
getActiveCount(): number;
|
|
216
|
+
|
|
217
|
+
/**
|
|
218
|
+
* Check agent health
|
|
219
|
+
*/
|
|
220
|
+
checkHealth(agentId: string): Promise<IAgent['health']>;
|
|
221
|
+
}
|
|
222
|
+
|
|
223
|
+
/**
|
|
224
|
+
* Agent registry for type definitions
|
|
225
|
+
*/
|
|
226
|
+
export interface IAgentRegistry {
|
|
227
|
+
/**
|
|
228
|
+
* Register an agent type with default config
|
|
229
|
+
*/
|
|
230
|
+
register(type: string, defaultConfig: Partial<IAgentConfig>): void;
|
|
231
|
+
|
|
232
|
+
/**
|
|
233
|
+
* Unregister an agent type
|
|
234
|
+
*/
|
|
235
|
+
unregister(type: string): boolean;
|
|
236
|
+
|
|
237
|
+
/**
|
|
238
|
+
* Get default config for a type
|
|
239
|
+
*/
|
|
240
|
+
getDefaultConfig(type: string): Partial<IAgentConfig> | undefined;
|
|
241
|
+
|
|
242
|
+
/**
|
|
243
|
+
* Get all registered types
|
|
244
|
+
*/
|
|
245
|
+
getRegisteredTypes(): string[];
|
|
246
|
+
|
|
247
|
+
/**
|
|
248
|
+
* Check if a type is registered
|
|
249
|
+
*/
|
|
250
|
+
isRegistered(type: string): boolean;
|
|
251
|
+
}
|