moflo 4.8.19 → 4.8.20
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/.claude/guidance/shipped/moflo.md +45 -0
- package/.claude/helpers/statusline.cjs +1 -1
- package/.claude/workflow-state.json +9 -0
- package/package.json +2 -2
- package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
- package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
- package/src/@claude-flow/cli/package.json +1 -1
- package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
- package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
- package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
- package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
- package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
- package/src/@claude-flow/memory/dist/application/index.js +15 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
- package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
- package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
- package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
- package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
- package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
- package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
- package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
- package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
- package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
- package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
- package/src/@claude-flow/memory/dist/database-provider.js +372 -0
- package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
- package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
- package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
- package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
- package/src/@claude-flow/memory/dist/domain/index.js +12 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
- package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
- package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
- package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
- package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
- package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
- package/src/@claude-flow/memory/dist/index.d.ts +204 -0
- package/src/@claude-flow/memory/dist/index.js +358 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
- package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
- package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
- package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
- package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
- package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
- package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
- package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
- package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
- package/src/@claude-flow/memory/dist/migration.js +513 -0
- package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
- package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
- package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
- package/src/@claude-flow/memory/dist/query-builder.js +438 -0
- package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
- package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
- package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
- package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
- package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
- package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
- package/src/@claude-flow/memory/dist/types.d.ts +484 -0
- package/src/@claude-flow/memory/dist/types.js +58 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
- package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
- package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
- package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
- package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
- package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
- package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
- package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
- package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
- package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
- package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
- package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
- package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
- package/src/@claude-flow/shared/dist/core/index.js +19 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
- package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
- package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
- package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
- package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
- package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
- package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
- package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
- package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
- package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
- package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
- package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
- package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
- package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
- package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
- package/src/@claude-flow/shared/dist/events/index.js +22 -0
- package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
- package/src/@claude-flow/shared/dist/events/projections.js +421 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
- package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
- package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
- package/src/@claude-flow/shared/dist/events.d.ts +80 -0
- package/src/@claude-flow/shared/dist/events.js +249 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
- package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
- package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
- package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
- package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
- package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
- package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
- package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
- package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
- package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
- package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
- package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
- package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
- package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
- package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
- package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
- package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
- package/src/@claude-flow/shared/dist/index.d.ts +20 -0
- package/src/@claude-flow/shared/dist/index.js +50 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
- package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
- package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
- package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
- package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
- package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
- package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
- package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
- package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
- package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
- package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
- package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
- package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
- package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
- package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
- package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
- package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
- package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
- package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
- package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
- package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
- package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
- package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
- package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
- package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
- package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
- package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
- package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
- package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
- package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
- package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
- package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
- package/src/@claude-flow/shared/dist/security/index.js +12 -0
- package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
- package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
- package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
- package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
- package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
- package/src/@claude-flow/shared/dist/services/index.js +7 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
- package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
- package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
- package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
- package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
- package/src/@claude-flow/shared/dist/types/index.js +17 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
- package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
- package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
- package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
- package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
- package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
- package/src/@claude-flow/shared/dist/types.d.ts +197 -0
- package/src/@claude-flow/shared/dist/types.js +21 -0
- package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
- package/src/@claude-flow/shared/dist/utils/secure-logger.js +208 -0
|
@@ -0,0 +1,434 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 Plugin Loader
|
|
3
|
+
* Domain-Driven Design - Plugin-Based Architecture (ADR-004)
|
|
4
|
+
*
|
|
5
|
+
* Handles plugin loading, dependency resolution, and lifecycle management
|
|
6
|
+
*/
|
|
7
|
+
import { PluginError } from './plugin-interface.js';
|
|
8
|
+
/**
|
|
9
|
+
* Default plugin loader configuration
|
|
10
|
+
*/
|
|
11
|
+
const DEFAULT_CONFIG = {
|
|
12
|
+
initializationTimeout: 30000, // 30 seconds
|
|
13
|
+
shutdownTimeout: 10000, // 10 seconds
|
|
14
|
+
parallelInitialization: false, // Sequential by default for safety
|
|
15
|
+
strictDependencies: true,
|
|
16
|
+
enableHealthChecks: false,
|
|
17
|
+
healthCheckInterval: 60000, // 1 minute
|
|
18
|
+
};
|
|
19
|
+
/**
|
|
20
|
+
* Plugin loader for managing plugin lifecycle
|
|
21
|
+
*/
|
|
22
|
+
export class PluginLoader {
|
|
23
|
+
config;
|
|
24
|
+
registry;
|
|
25
|
+
initializationOrder = [];
|
|
26
|
+
healthCheckIntervalId;
|
|
27
|
+
constructor(registry, config) {
|
|
28
|
+
this.registry = registry;
|
|
29
|
+
this.config = { ...DEFAULT_CONFIG, ...config };
|
|
30
|
+
}
|
|
31
|
+
/**
|
|
32
|
+
* Load a single plugin
|
|
33
|
+
*/
|
|
34
|
+
async loadPlugin(plugin, context) {
|
|
35
|
+
// Validate plugin
|
|
36
|
+
this.validatePlugin(plugin);
|
|
37
|
+
// Check for duplicates
|
|
38
|
+
if (this.registry.hasPlugin(plugin.name)) {
|
|
39
|
+
throw new PluginError(`Plugin '${plugin.name}' is already loaded`, plugin.name, 'DUPLICATE_PLUGIN');
|
|
40
|
+
}
|
|
41
|
+
// Register plugin in uninitialized state
|
|
42
|
+
this.registry.registerPlugin(plugin, 'uninitialized', context);
|
|
43
|
+
// Resolve dependencies
|
|
44
|
+
if (this.config.strictDependencies) {
|
|
45
|
+
this.validateDependencies(plugin);
|
|
46
|
+
}
|
|
47
|
+
// Initialize plugin
|
|
48
|
+
await this.initializePlugin(plugin, context);
|
|
49
|
+
// Update initialization order
|
|
50
|
+
this.initializationOrder.push(plugin.name);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Load multiple plugins with dependency resolution
|
|
54
|
+
*/
|
|
55
|
+
async loadPlugins(plugins, context) {
|
|
56
|
+
const results = {
|
|
57
|
+
successful: [],
|
|
58
|
+
failed: [],
|
|
59
|
+
totalDuration: 0,
|
|
60
|
+
};
|
|
61
|
+
const startTime = Date.now();
|
|
62
|
+
try {
|
|
63
|
+
// Validate all plugins first
|
|
64
|
+
for (const plugin of plugins) {
|
|
65
|
+
this.validatePlugin(plugin);
|
|
66
|
+
}
|
|
67
|
+
// Build dependency graph
|
|
68
|
+
const dependencyGraph = this.buildDependencyGraph(plugins);
|
|
69
|
+
// Detect circular dependencies
|
|
70
|
+
this.detectCircularDependencies(dependencyGraph);
|
|
71
|
+
// Sort plugins by dependency order (topological sort)
|
|
72
|
+
const sortedPlugins = this.topologicalSort(dependencyGraph);
|
|
73
|
+
// Initialize plugins in order
|
|
74
|
+
if (this.config.parallelInitialization) {
|
|
75
|
+
await this.initializePluginsParallel(sortedPlugins, context, results);
|
|
76
|
+
}
|
|
77
|
+
else {
|
|
78
|
+
await this.initializePluginsSequential(sortedPlugins, context, results);
|
|
79
|
+
}
|
|
80
|
+
}
|
|
81
|
+
catch (error) {
|
|
82
|
+
// If error during setup, mark all as failed
|
|
83
|
+
for (const plugin of plugins) {
|
|
84
|
+
if (!results.successful.includes(plugin.name) && !results.failed.some((f) => f.name === plugin.name)) {
|
|
85
|
+
results.failed.push({
|
|
86
|
+
name: plugin.name,
|
|
87
|
+
error: error instanceof Error ? error : new Error(String(error)),
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
finally {
|
|
93
|
+
results.totalDuration = Date.now() - startTime;
|
|
94
|
+
}
|
|
95
|
+
// Start health checks if enabled
|
|
96
|
+
if (this.config.enableHealthChecks) {
|
|
97
|
+
this.startHealthChecks();
|
|
98
|
+
}
|
|
99
|
+
return results;
|
|
100
|
+
}
|
|
101
|
+
/**
|
|
102
|
+
* Unload a single plugin
|
|
103
|
+
*/
|
|
104
|
+
async unloadPlugin(pluginName) {
|
|
105
|
+
const pluginInfo = this.registry.getPlugin(pluginName);
|
|
106
|
+
if (!pluginInfo) {
|
|
107
|
+
throw new PluginError(`Plugin '${pluginName}' not found`, pluginName, 'INVALID_PLUGIN');
|
|
108
|
+
}
|
|
109
|
+
// Check for dependents
|
|
110
|
+
const dependents = this.findDependents(pluginName);
|
|
111
|
+
if (dependents.length > 0) {
|
|
112
|
+
throw new PluginError(`Cannot unload plugin '${pluginName}': depended on by ${dependents.join(', ')}`, pluginName, 'DEPENDENCY_NOT_FOUND');
|
|
113
|
+
}
|
|
114
|
+
// Shutdown plugin
|
|
115
|
+
await this.shutdownPlugin(pluginInfo.plugin);
|
|
116
|
+
// Unregister plugin
|
|
117
|
+
this.registry.unregisterPlugin(pluginName);
|
|
118
|
+
// Remove from initialization order
|
|
119
|
+
const index = this.initializationOrder.indexOf(pluginName);
|
|
120
|
+
if (index !== -1) {
|
|
121
|
+
this.initializationOrder.splice(index, 1);
|
|
122
|
+
}
|
|
123
|
+
}
|
|
124
|
+
/**
|
|
125
|
+
* Unload all plugins in reverse initialization order
|
|
126
|
+
*/
|
|
127
|
+
async unloadAll() {
|
|
128
|
+
// Stop health checks
|
|
129
|
+
if (this.healthCheckIntervalId) {
|
|
130
|
+
clearInterval(this.healthCheckIntervalId);
|
|
131
|
+
this.healthCheckIntervalId = undefined;
|
|
132
|
+
}
|
|
133
|
+
// Shutdown in reverse order
|
|
134
|
+
const pluginsToShutdown = [...this.initializationOrder].reverse();
|
|
135
|
+
for (const pluginName of pluginsToShutdown) {
|
|
136
|
+
try {
|
|
137
|
+
await this.unloadPlugin(pluginName);
|
|
138
|
+
}
|
|
139
|
+
catch (error) {
|
|
140
|
+
// Log error but continue shutting down other plugins
|
|
141
|
+
console.error(`Error unloading plugin '${pluginName}':`, error);
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
this.initializationOrder = [];
|
|
145
|
+
}
|
|
146
|
+
/**
|
|
147
|
+
* Reload a plugin
|
|
148
|
+
*/
|
|
149
|
+
async reloadPlugin(pluginName, newPlugin, context) {
|
|
150
|
+
await this.unloadPlugin(pluginName);
|
|
151
|
+
await this.loadPlugin(newPlugin, context);
|
|
152
|
+
}
|
|
153
|
+
/**
|
|
154
|
+
* Get plugin initialization order
|
|
155
|
+
*/
|
|
156
|
+
getInitializationOrder() {
|
|
157
|
+
return [...this.initializationOrder];
|
|
158
|
+
}
|
|
159
|
+
/**
|
|
160
|
+
* Validate plugin interface
|
|
161
|
+
*/
|
|
162
|
+
validatePlugin(plugin) {
|
|
163
|
+
if (!plugin.name) {
|
|
164
|
+
throw new PluginError('Plugin must have a name', '<unknown>', 'INVALID_PLUGIN');
|
|
165
|
+
}
|
|
166
|
+
if (!plugin.version) {
|
|
167
|
+
throw new PluginError(`Plugin '${plugin.name}' must have a version`, plugin.name, 'INVALID_PLUGIN');
|
|
168
|
+
}
|
|
169
|
+
if (typeof plugin.initialize !== 'function') {
|
|
170
|
+
throw new PluginError(`Plugin '${plugin.name}' must implement initialize()`, plugin.name, 'INVALID_PLUGIN');
|
|
171
|
+
}
|
|
172
|
+
if (typeof plugin.shutdown !== 'function') {
|
|
173
|
+
throw new PluginError(`Plugin '${plugin.name}' must implement shutdown()`, plugin.name, 'INVALID_PLUGIN');
|
|
174
|
+
}
|
|
175
|
+
}
|
|
176
|
+
/**
|
|
177
|
+
* Validate plugin dependencies
|
|
178
|
+
*/
|
|
179
|
+
validateDependencies(plugin) {
|
|
180
|
+
if (!plugin.dependencies || plugin.dependencies.length === 0) {
|
|
181
|
+
return;
|
|
182
|
+
}
|
|
183
|
+
for (const dep of plugin.dependencies) {
|
|
184
|
+
if (!this.registry.hasPlugin(dep)) {
|
|
185
|
+
throw new PluginError(`Plugin '${plugin.name}' depends on '${dep}' which is not loaded`, plugin.name, 'DEPENDENCY_NOT_FOUND');
|
|
186
|
+
}
|
|
187
|
+
// Check dependency is initialized
|
|
188
|
+
const depInfo = this.registry.getPlugin(dep);
|
|
189
|
+
if (depInfo && depInfo.state !== 'initialized') {
|
|
190
|
+
throw new PluginError(`Plugin '${plugin.name}' depends on '${dep}' which is not initialized (state: ${depInfo.state})`, plugin.name, 'DEPENDENCY_NOT_FOUND');
|
|
191
|
+
}
|
|
192
|
+
}
|
|
193
|
+
}
|
|
194
|
+
/**
|
|
195
|
+
* Initialize a single plugin
|
|
196
|
+
*/
|
|
197
|
+
async initializePlugin(plugin, context) {
|
|
198
|
+
this.registry.updatePluginState(plugin.name, 'initializing');
|
|
199
|
+
try {
|
|
200
|
+
// Run initialization with timeout
|
|
201
|
+
await this.withTimeout(plugin.initialize(context), this.config.initializationTimeout, `Plugin '${plugin.name}' initialization timed out`);
|
|
202
|
+
this.registry.updatePluginState(plugin.name, 'initialized');
|
|
203
|
+
this.registry.collectPluginMetrics(plugin.name);
|
|
204
|
+
}
|
|
205
|
+
catch (error) {
|
|
206
|
+
this.registry.updatePluginState(plugin.name, 'error', error instanceof Error ? error : new Error(String(error)));
|
|
207
|
+
throw new PluginError(`Failed to initialize plugin '${plugin.name}': ${error}`, plugin.name, 'INITIALIZATION_FAILED', error instanceof Error ? error : undefined);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
/**
|
|
211
|
+
* Shutdown a single plugin
|
|
212
|
+
*/
|
|
213
|
+
async shutdownPlugin(plugin) {
|
|
214
|
+
this.registry.updatePluginState(plugin.name, 'shutting-down');
|
|
215
|
+
try {
|
|
216
|
+
await this.withTimeout(plugin.shutdown(), this.config.shutdownTimeout, `Plugin '${plugin.name}' shutdown timed out`);
|
|
217
|
+
this.registry.updatePluginState(plugin.name, 'shutdown');
|
|
218
|
+
}
|
|
219
|
+
catch (error) {
|
|
220
|
+
this.registry.updatePluginState(plugin.name, 'error', error instanceof Error ? error : new Error(String(error)));
|
|
221
|
+
throw new PluginError(`Failed to shutdown plugin '${plugin.name}': ${error}`, plugin.name, 'SHUTDOWN_FAILED', error instanceof Error ? error : undefined);
|
|
222
|
+
}
|
|
223
|
+
}
|
|
224
|
+
/**
|
|
225
|
+
* Initialize plugins sequentially
|
|
226
|
+
*/
|
|
227
|
+
async initializePluginsSequential(plugins, context, results) {
|
|
228
|
+
for (const plugin of plugins) {
|
|
229
|
+
try {
|
|
230
|
+
// Register and initialize
|
|
231
|
+
this.registry.registerPlugin(plugin, 'uninitialized', context);
|
|
232
|
+
await this.initializePlugin(plugin, context);
|
|
233
|
+
results.successful.push(plugin.name);
|
|
234
|
+
this.initializationOrder.push(plugin.name);
|
|
235
|
+
}
|
|
236
|
+
catch (error) {
|
|
237
|
+
results.failed.push({
|
|
238
|
+
name: plugin.name,
|
|
239
|
+
error: error instanceof Error ? error : new Error(String(error)),
|
|
240
|
+
});
|
|
241
|
+
// Stop on first failure in sequential mode if strict
|
|
242
|
+
if (this.config.strictDependencies) {
|
|
243
|
+
break;
|
|
244
|
+
}
|
|
245
|
+
}
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
/**
|
|
249
|
+
* Initialize plugins in parallel (by dependency level)
|
|
250
|
+
*/
|
|
251
|
+
async initializePluginsParallel(plugins, context, results) {
|
|
252
|
+
// Group plugins by dependency depth
|
|
253
|
+
const dependencyGraph = this.buildDependencyGraph(plugins);
|
|
254
|
+
const levels = this.groupByDepth(dependencyGraph);
|
|
255
|
+
// Initialize each level in parallel
|
|
256
|
+
for (const level of levels) {
|
|
257
|
+
const promises = level.map(async (plugin) => {
|
|
258
|
+
try {
|
|
259
|
+
this.registry.registerPlugin(plugin, 'uninitialized', context);
|
|
260
|
+
await this.initializePlugin(plugin, context);
|
|
261
|
+
results.successful.push(plugin.name);
|
|
262
|
+
this.initializationOrder.push(plugin.name);
|
|
263
|
+
}
|
|
264
|
+
catch (error) {
|
|
265
|
+
results.failed.push({
|
|
266
|
+
name: plugin.name,
|
|
267
|
+
error: error instanceof Error ? error : new Error(String(error)),
|
|
268
|
+
});
|
|
269
|
+
}
|
|
270
|
+
});
|
|
271
|
+
await Promise.all(promises);
|
|
272
|
+
// Stop on failures in level if strict
|
|
273
|
+
if (this.config.strictDependencies && results.failed.length > 0) {
|
|
274
|
+
break;
|
|
275
|
+
}
|
|
276
|
+
}
|
|
277
|
+
}
|
|
278
|
+
/**
|
|
279
|
+
* Build dependency graph
|
|
280
|
+
*/
|
|
281
|
+
buildDependencyGraph(plugins) {
|
|
282
|
+
const graph = new Map();
|
|
283
|
+
// Create nodes
|
|
284
|
+
for (const plugin of plugins) {
|
|
285
|
+
graph.set(plugin.name, {
|
|
286
|
+
plugin,
|
|
287
|
+
dependencies: new Set(plugin.dependencies || []),
|
|
288
|
+
dependents: new Set(),
|
|
289
|
+
depth: 0,
|
|
290
|
+
});
|
|
291
|
+
}
|
|
292
|
+
// Build dependency links
|
|
293
|
+
for (const [name, node] of Array.from(graph.entries())) {
|
|
294
|
+
for (const dep of Array.from(node.dependencies)) {
|
|
295
|
+
const depNode = graph.get(dep);
|
|
296
|
+
if (depNode) {
|
|
297
|
+
depNode.dependents.add(name);
|
|
298
|
+
}
|
|
299
|
+
}
|
|
300
|
+
}
|
|
301
|
+
// Calculate depths
|
|
302
|
+
this.calculateDepths(graph);
|
|
303
|
+
return graph;
|
|
304
|
+
}
|
|
305
|
+
/**
|
|
306
|
+
* Calculate depth of each node (for topological sorting)
|
|
307
|
+
*/
|
|
308
|
+
calculateDepths(graph) {
|
|
309
|
+
const visited = new Set();
|
|
310
|
+
const visit = (name) => {
|
|
311
|
+
if (visited.has(name)) {
|
|
312
|
+
const node = graph.get(name);
|
|
313
|
+
return node ? node.depth : 0;
|
|
314
|
+
}
|
|
315
|
+
visited.add(name);
|
|
316
|
+
const node = graph.get(name);
|
|
317
|
+
if (!node)
|
|
318
|
+
return 0;
|
|
319
|
+
let maxDepth = 0;
|
|
320
|
+
for (const dep of Array.from(node.dependencies)) {
|
|
321
|
+
maxDepth = Math.max(maxDepth, visit(dep) + 1);
|
|
322
|
+
}
|
|
323
|
+
node.depth = maxDepth;
|
|
324
|
+
return maxDepth;
|
|
325
|
+
};
|
|
326
|
+
for (const name of Array.from(graph.keys())) {
|
|
327
|
+
visit(name);
|
|
328
|
+
}
|
|
329
|
+
}
|
|
330
|
+
/**
|
|
331
|
+
* Topological sort (dependency order)
|
|
332
|
+
*/
|
|
333
|
+
topologicalSort(graph) {
|
|
334
|
+
const sorted = [];
|
|
335
|
+
const nodes = Array.from(graph.values());
|
|
336
|
+
// Sort by depth (dependencies first)
|
|
337
|
+
nodes.sort((a, b) => a.depth - b.depth);
|
|
338
|
+
for (const node of nodes) {
|
|
339
|
+
sorted.push(node.plugin);
|
|
340
|
+
}
|
|
341
|
+
return sorted;
|
|
342
|
+
}
|
|
343
|
+
/**
|
|
344
|
+
* Group plugins by dependency depth (for parallel initialization)
|
|
345
|
+
*/
|
|
346
|
+
groupByDepth(graph) {
|
|
347
|
+
const levels = [];
|
|
348
|
+
const maxDepth = Math.max(...Array.from(graph.values()).map((n) => n.depth));
|
|
349
|
+
for (let depth = 0; depth <= maxDepth; depth++) {
|
|
350
|
+
const level = [];
|
|
351
|
+
for (const node of Array.from(graph.values())) {
|
|
352
|
+
if (node.depth === depth) {
|
|
353
|
+
level.push(node.plugin);
|
|
354
|
+
}
|
|
355
|
+
}
|
|
356
|
+
if (level.length > 0) {
|
|
357
|
+
levels.push(level);
|
|
358
|
+
}
|
|
359
|
+
}
|
|
360
|
+
return levels;
|
|
361
|
+
}
|
|
362
|
+
/**
|
|
363
|
+
* Detect circular dependencies
|
|
364
|
+
*/
|
|
365
|
+
detectCircularDependencies(graph) {
|
|
366
|
+
const visited = new Set();
|
|
367
|
+
const stack = new Set();
|
|
368
|
+
const visit = (name, path) => {
|
|
369
|
+
if (stack.has(name)) {
|
|
370
|
+
const cycle = [...path, name];
|
|
371
|
+
throw new PluginError(`Circular dependency detected: ${cycle.join(' -> ')}`, name, 'CIRCULAR_DEPENDENCY');
|
|
372
|
+
}
|
|
373
|
+
if (visited.has(name)) {
|
|
374
|
+
return;
|
|
375
|
+
}
|
|
376
|
+
visited.add(name);
|
|
377
|
+
stack.add(name);
|
|
378
|
+
const node = graph.get(name);
|
|
379
|
+
if (node) {
|
|
380
|
+
for (const dep of Array.from(node.dependencies)) {
|
|
381
|
+
visit(dep, [...path, name]);
|
|
382
|
+
}
|
|
383
|
+
}
|
|
384
|
+
stack.delete(name);
|
|
385
|
+
};
|
|
386
|
+
for (const name of Array.from(graph.keys())) {
|
|
387
|
+
visit(name, []);
|
|
388
|
+
}
|
|
389
|
+
}
|
|
390
|
+
/**
|
|
391
|
+
* Find plugins that depend on a given plugin
|
|
392
|
+
*/
|
|
393
|
+
findDependents(pluginName) {
|
|
394
|
+
const dependents = [];
|
|
395
|
+
for (const [name, info] of Array.from(this.registry.getAllPlugins().entries())) {
|
|
396
|
+
if (info.plugin.dependencies?.includes(pluginName)) {
|
|
397
|
+
dependents.push(name);
|
|
398
|
+
}
|
|
399
|
+
}
|
|
400
|
+
return dependents;
|
|
401
|
+
}
|
|
402
|
+
/**
|
|
403
|
+
* Start periodic health checks
|
|
404
|
+
*/
|
|
405
|
+
startHealthChecks() {
|
|
406
|
+
this.healthCheckIntervalId = setInterval(async () => {
|
|
407
|
+
for (const [name, info] of Array.from(this.registry.getAllPlugins().entries())) {
|
|
408
|
+
if (info.state === 'initialized' && info.plugin.healthCheck) {
|
|
409
|
+
try {
|
|
410
|
+
const healthy = await info.plugin.healthCheck();
|
|
411
|
+
if (!healthy) {
|
|
412
|
+
console.warn(`Plugin '${name}' health check failed`);
|
|
413
|
+
this.registry.updatePluginState(name, 'error', new Error('Health check failed'));
|
|
414
|
+
}
|
|
415
|
+
}
|
|
416
|
+
catch (error) {
|
|
417
|
+
console.error(`Plugin '${name}' health check error:`, error);
|
|
418
|
+
this.registry.updatePluginState(name, 'error', error instanceof Error ? error : new Error(String(error)));
|
|
419
|
+
}
|
|
420
|
+
}
|
|
421
|
+
}
|
|
422
|
+
}, this.config.healthCheckInterval);
|
|
423
|
+
}
|
|
424
|
+
/**
|
|
425
|
+
* Utility: Run promise with timeout
|
|
426
|
+
*/
|
|
427
|
+
async withTimeout(promise, timeoutMs, errorMessage) {
|
|
428
|
+
return Promise.race([
|
|
429
|
+
promise,
|
|
430
|
+
new Promise((_, reject) => setTimeout(() => reject(new Error(errorMessage)), timeoutMs)),
|
|
431
|
+
]);
|
|
432
|
+
}
|
|
433
|
+
}
|
|
434
|
+
//# sourceMappingURL=plugin-loader.js.map
|
|
@@ -0,0 +1,183 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* V3 Plugin Registry
|
|
3
|
+
* Domain-Driven Design - Plugin-Based Architecture (ADR-004)
|
|
4
|
+
*
|
|
5
|
+
* Central registry for tracking plugin state, metadata, and registrations
|
|
6
|
+
*/
|
|
7
|
+
import type { ClaudeFlowPlugin, PluginInfo, PluginLifecycleState, PluginContext, AgentTypeDefinition, TaskTypeDefinition, MCPToolDefinition, CLICommandDefinition, MemoryBackendFactory } from './plugin-interface.js';
|
|
8
|
+
/**
|
|
9
|
+
* Plugin registry for managing plugin lifecycle and registrations
|
|
10
|
+
*/
|
|
11
|
+
export declare class PluginRegistry {
|
|
12
|
+
private plugins;
|
|
13
|
+
private agentTypes;
|
|
14
|
+
private taskTypes;
|
|
15
|
+
private mcpTools;
|
|
16
|
+
private cliCommands;
|
|
17
|
+
private memoryBackends;
|
|
18
|
+
/**
|
|
19
|
+
* Register a plugin in the registry
|
|
20
|
+
*/
|
|
21
|
+
registerPlugin(plugin: ClaudeFlowPlugin, initialState: PluginLifecycleState, context: PluginContext): void;
|
|
22
|
+
/**
|
|
23
|
+
* Unregister a plugin from the registry
|
|
24
|
+
*/
|
|
25
|
+
unregisterPlugin(pluginName: string): boolean;
|
|
26
|
+
/**
|
|
27
|
+
* Get a plugin by name
|
|
28
|
+
*/
|
|
29
|
+
getPlugin(pluginName: string): PluginInfo | undefined;
|
|
30
|
+
/**
|
|
31
|
+
* Get all registered plugins
|
|
32
|
+
*/
|
|
33
|
+
getAllPlugins(): Map<string, PluginInfo>;
|
|
34
|
+
/**
|
|
35
|
+
* Get all plugin names
|
|
36
|
+
*/
|
|
37
|
+
getPluginNames(): string[];
|
|
38
|
+
/**
|
|
39
|
+
* Check if a plugin is registered
|
|
40
|
+
*/
|
|
41
|
+
hasPlugin(pluginName: string): boolean;
|
|
42
|
+
/**
|
|
43
|
+
* Get plugins by state
|
|
44
|
+
*/
|
|
45
|
+
getPluginsByState(state: PluginLifecycleState): PluginInfo[];
|
|
46
|
+
/**
|
|
47
|
+
* Get plugin count
|
|
48
|
+
*/
|
|
49
|
+
getPluginCount(): number;
|
|
50
|
+
/**
|
|
51
|
+
* Update plugin state
|
|
52
|
+
*/
|
|
53
|
+
updatePluginState(pluginName: string, state: PluginLifecycleState, error?: Error): void;
|
|
54
|
+
/**
|
|
55
|
+
* Collect and update plugin metrics
|
|
56
|
+
*/
|
|
57
|
+
collectPluginMetrics(pluginName: string): void;
|
|
58
|
+
/**
|
|
59
|
+
* Get plugin status summary
|
|
60
|
+
*/
|
|
61
|
+
getStatusSummary(): PluginRegistryStatus;
|
|
62
|
+
/**
|
|
63
|
+
* Register agent types from a plugin
|
|
64
|
+
*/
|
|
65
|
+
registerAgentTypes(pluginName: string): void;
|
|
66
|
+
/**
|
|
67
|
+
* Unregister agent types from a plugin
|
|
68
|
+
*/
|
|
69
|
+
unregisterPluginAgentTypes(pluginName: string): void;
|
|
70
|
+
/**
|
|
71
|
+
* Get agent type definition
|
|
72
|
+
*/
|
|
73
|
+
getAgentType(type: string): AgentTypeDefinition | undefined;
|
|
74
|
+
/**
|
|
75
|
+
* Get all agent types
|
|
76
|
+
*/
|
|
77
|
+
getAllAgentTypes(): AgentTypeDefinition[];
|
|
78
|
+
/**
|
|
79
|
+
* Get agent types by plugin
|
|
80
|
+
*/
|
|
81
|
+
getAgentTypesByPlugin(pluginName: string): AgentTypeDefinition[];
|
|
82
|
+
/**
|
|
83
|
+
* Register task types from a plugin
|
|
84
|
+
*/
|
|
85
|
+
registerTaskTypes(pluginName: string): void;
|
|
86
|
+
/**
|
|
87
|
+
* Unregister task types from a plugin
|
|
88
|
+
*/
|
|
89
|
+
unregisterPluginTaskTypes(pluginName: string): void;
|
|
90
|
+
/**
|
|
91
|
+
* Get task type definition
|
|
92
|
+
*/
|
|
93
|
+
getTaskType(type: string): TaskTypeDefinition | undefined;
|
|
94
|
+
/**
|
|
95
|
+
* Get all task types
|
|
96
|
+
*/
|
|
97
|
+
getAllTaskTypes(): TaskTypeDefinition[];
|
|
98
|
+
/**
|
|
99
|
+
* Get task types by plugin
|
|
100
|
+
*/
|
|
101
|
+
getTaskTypesByPlugin(pluginName: string): TaskTypeDefinition[];
|
|
102
|
+
/**
|
|
103
|
+
* Register MCP tools from a plugin
|
|
104
|
+
*/
|
|
105
|
+
registerMCPTools(pluginName: string): void;
|
|
106
|
+
/**
|
|
107
|
+
* Unregister MCP tools from a plugin
|
|
108
|
+
*/
|
|
109
|
+
unregisterPluginMCPTools(pluginName: string): void;
|
|
110
|
+
/**
|
|
111
|
+
* Get MCP tool definition
|
|
112
|
+
*/
|
|
113
|
+
getMCPTool(name: string): MCPToolDefinition | undefined;
|
|
114
|
+
/**
|
|
115
|
+
* Get all MCP tools
|
|
116
|
+
*/
|
|
117
|
+
getAllMCPTools(): MCPToolDefinition[];
|
|
118
|
+
/**
|
|
119
|
+
* Get MCP tools by plugin
|
|
120
|
+
*/
|
|
121
|
+
getMCPToolsByPlugin(pluginName: string): MCPToolDefinition[];
|
|
122
|
+
/**
|
|
123
|
+
* Register CLI commands from a plugin
|
|
124
|
+
*/
|
|
125
|
+
registerCLICommands(pluginName: string): void;
|
|
126
|
+
/**
|
|
127
|
+
* Unregister CLI commands from a plugin
|
|
128
|
+
*/
|
|
129
|
+
unregisterPluginCLICommands(pluginName: string): void;
|
|
130
|
+
/**
|
|
131
|
+
* Get CLI command definition
|
|
132
|
+
*/
|
|
133
|
+
getCLICommand(name: string): CLICommandDefinition | undefined;
|
|
134
|
+
/**
|
|
135
|
+
* Get all CLI commands
|
|
136
|
+
*/
|
|
137
|
+
getAllCLICommands(): CLICommandDefinition[];
|
|
138
|
+
/**
|
|
139
|
+
* Get CLI commands by plugin
|
|
140
|
+
*/
|
|
141
|
+
getCLICommandsByPlugin(pluginName: string): CLICommandDefinition[];
|
|
142
|
+
/**
|
|
143
|
+
* Register memory backends from a plugin
|
|
144
|
+
*/
|
|
145
|
+
registerMemoryBackends(pluginName: string): void;
|
|
146
|
+
/**
|
|
147
|
+
* Unregister memory backends from a plugin
|
|
148
|
+
*/
|
|
149
|
+
unregisterPluginMemoryBackends(pluginName: string): void;
|
|
150
|
+
/**
|
|
151
|
+
* Get memory backend factory
|
|
152
|
+
*/
|
|
153
|
+
getMemoryBackend(name: string): MemoryBackendFactory | undefined;
|
|
154
|
+
/**
|
|
155
|
+
* Get all memory backends
|
|
156
|
+
*/
|
|
157
|
+
getAllMemoryBackends(): MemoryBackendFactory[];
|
|
158
|
+
/**
|
|
159
|
+
* Get memory backends by plugin
|
|
160
|
+
*/
|
|
161
|
+
getMemoryBackendsByPlugin(pluginName: string): MemoryBackendFactory[];
|
|
162
|
+
/**
|
|
163
|
+
* Register all extension points from a plugin
|
|
164
|
+
*/
|
|
165
|
+
registerAllFromPlugin(pluginName: string): void;
|
|
166
|
+
/**
|
|
167
|
+
* Clear all registrations (for testing)
|
|
168
|
+
*/
|
|
169
|
+
clear(): void;
|
|
170
|
+
}
|
|
171
|
+
/**
|
|
172
|
+
* Plugin registry status summary
|
|
173
|
+
*/
|
|
174
|
+
export interface PluginRegistryStatus {
|
|
175
|
+
totalPlugins: number;
|
|
176
|
+
states: Record<PluginLifecycleState, number>;
|
|
177
|
+
agentTypesRegistered: number;
|
|
178
|
+
taskTypesRegistered: number;
|
|
179
|
+
mcpToolsRegistered: number;
|
|
180
|
+
cliCommandsRegistered: number;
|
|
181
|
+
memoryBackendsRegistered: number;
|
|
182
|
+
}
|
|
183
|
+
//# sourceMappingURL=plugin-registry.d.ts.map
|