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.
Files changed (241) hide show
  1. package/.claude/guidance/shipped/moflo.md +45 -0
  2. package/.claude/helpers/statusline.cjs +1 -1
  3. package/.claude/workflow-state.json +9 -0
  4. package/package.json +2 -2
  5. package/src/@claude-flow/cli/dist/src/init/statusline-generator.js +1 -1
  6. package/src/@claude-flow/cli/dist/src/services/agentic-flow-bridge.js +5 -3
  7. package/src/@claude-flow/cli/package.json +1 -1
  8. package/src/@claude-flow/memory/dist/agent-memory-scope.d.ts +131 -0
  9. package/src/@claude-flow/memory/dist/agent-memory-scope.js +223 -0
  10. package/src/@claude-flow/memory/dist/agent-memory-scope.test.d.ts +8 -0
  11. package/src/@claude-flow/memory/dist/agent-memory-scope.test.js +466 -0
  12. package/src/@claude-flow/memory/dist/agentdb-adapter.d.ts +165 -0
  13. package/src/@claude-flow/memory/dist/agentdb-adapter.js +806 -0
  14. package/src/@claude-flow/memory/dist/agentdb-backend.d.ts +212 -0
  15. package/src/@claude-flow/memory/dist/agentdb-backend.js +842 -0
  16. package/src/@claude-flow/memory/dist/agentdb-backend.test.d.ts +7 -0
  17. package/src/@claude-flow/memory/dist/agentdb-backend.test.js +258 -0
  18. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.d.ts +65 -0
  19. package/src/@claude-flow/memory/dist/application/commands/delete-memory.command.js +129 -0
  20. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.d.ts +48 -0
  21. package/src/@claude-flow/memory/dist/application/commands/store-memory.command.js +72 -0
  22. package/src/@claude-flow/memory/dist/application/index.d.ts +12 -0
  23. package/src/@claude-flow/memory/dist/application/index.js +15 -0
  24. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.d.ts +72 -0
  25. package/src/@claude-flow/memory/dist/application/queries/search-memory.query.js +143 -0
  26. package/src/@claude-flow/memory/dist/application/services/memory-application-service.d.ts +121 -0
  27. package/src/@claude-flow/memory/dist/application/services/memory-application-service.js +190 -0
  28. package/src/@claude-flow/memory/dist/auto-memory-bridge.d.ts +226 -0
  29. package/src/@claude-flow/memory/dist/auto-memory-bridge.js +709 -0
  30. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.d.ts +8 -0
  31. package/src/@claude-flow/memory/dist/auto-memory-bridge.test.js +757 -0
  32. package/src/@claude-flow/memory/dist/benchmark.test.d.ts +2 -0
  33. package/src/@claude-flow/memory/dist/benchmark.test.js +277 -0
  34. package/src/@claude-flow/memory/dist/cache-manager.d.ts +134 -0
  35. package/src/@claude-flow/memory/dist/cache-manager.js +407 -0
  36. package/src/@claude-flow/memory/dist/controller-registry.d.ts +216 -0
  37. package/src/@claude-flow/memory/dist/controller-registry.js +893 -0
  38. package/src/@claude-flow/memory/dist/controller-registry.test.d.ts +14 -0
  39. package/src/@claude-flow/memory/dist/controller-registry.test.js +593 -0
  40. package/src/@claude-flow/memory/dist/database-provider.d.ts +87 -0
  41. package/src/@claude-flow/memory/dist/database-provider.js +372 -0
  42. package/src/@claude-flow/memory/dist/database-provider.test.d.ts +7 -0
  43. package/src/@claude-flow/memory/dist/database-provider.test.js +287 -0
  44. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.d.ts +143 -0
  45. package/src/@claude-flow/memory/dist/domain/entities/memory-entry.js +226 -0
  46. package/src/@claude-flow/memory/dist/domain/index.d.ts +11 -0
  47. package/src/@claude-flow/memory/dist/domain/index.js +12 -0
  48. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.d.ts +102 -0
  49. package/src/@claude-flow/memory/dist/domain/repositories/memory-repository.interface.js +11 -0
  50. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.d.ts +105 -0
  51. package/src/@claude-flow/memory/dist/domain/services/memory-domain-service.js +297 -0
  52. package/src/@claude-flow/memory/dist/hnsw-index.d.ts +111 -0
  53. package/src/@claude-flow/memory/dist/hnsw-index.js +781 -0
  54. package/src/@claude-flow/memory/dist/hnsw-lite.d.ts +23 -0
  55. package/src/@claude-flow/memory/dist/hnsw-lite.js +168 -0
  56. package/src/@claude-flow/memory/dist/index.d.ts +204 -0
  57. package/src/@claude-flow/memory/dist/index.js +358 -0
  58. package/src/@claude-flow/memory/dist/infrastructure/index.d.ts +17 -0
  59. package/src/@claude-flow/memory/dist/infrastructure/index.js +16 -0
  60. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.d.ts +66 -0
  61. package/src/@claude-flow/memory/dist/infrastructure/repositories/hybrid-memory-repository.js +409 -0
  62. package/src/@claude-flow/memory/dist/learning-bridge.d.ts +137 -0
  63. package/src/@claude-flow/memory/dist/learning-bridge.js +335 -0
  64. package/src/@claude-flow/memory/dist/learning-bridge.test.d.ts +8 -0
  65. package/src/@claude-flow/memory/dist/learning-bridge.test.js +578 -0
  66. package/src/@claude-flow/memory/dist/memory-graph.d.ts +100 -0
  67. package/src/@claude-flow/memory/dist/memory-graph.js +333 -0
  68. package/src/@claude-flow/memory/dist/memory-graph.test.d.ts +8 -0
  69. package/src/@claude-flow/memory/dist/memory-graph.test.js +609 -0
  70. package/src/@claude-flow/memory/dist/migration.d.ts +68 -0
  71. package/src/@claude-flow/memory/dist/migration.js +513 -0
  72. package/src/@claude-flow/memory/dist/persistent-sona.d.ts +144 -0
  73. package/src/@claude-flow/memory/dist/persistent-sona.js +332 -0
  74. package/src/@claude-flow/memory/dist/query-builder.d.ts +211 -0
  75. package/src/@claude-flow/memory/dist/query-builder.js +438 -0
  76. package/src/@claude-flow/memory/dist/rvf-backend.d.ts +51 -0
  77. package/src/@claude-flow/memory/dist/rvf-backend.js +481 -0
  78. package/src/@claude-flow/memory/dist/rvf-learning-store.d.ts +139 -0
  79. package/src/@claude-flow/memory/dist/rvf-learning-store.js +295 -0
  80. package/src/@claude-flow/memory/dist/rvf-migration.d.ts +45 -0
  81. package/src/@claude-flow/memory/dist/rvf-migration.js +234 -0
  82. package/src/@claude-flow/memory/dist/sqljs-backend.d.ts +127 -0
  83. package/src/@claude-flow/memory/dist/sqljs-backend.js +600 -0
  84. package/src/@claude-flow/memory/dist/types.d.ts +484 -0
  85. package/src/@claude-flow/memory/dist/types.js +58 -0
  86. package/src/@claude-flow/shared/dist/core/config/defaults.d.ts +41 -0
  87. package/src/@claude-flow/shared/dist/core/config/defaults.js +186 -0
  88. package/src/@claude-flow/shared/dist/core/config/index.d.ts +8 -0
  89. package/src/@claude-flow/shared/dist/core/config/index.js +12 -0
  90. package/src/@claude-flow/shared/dist/core/config/loader.d.ts +45 -0
  91. package/src/@claude-flow/shared/dist/core/config/loader.js +222 -0
  92. package/src/@claude-flow/shared/dist/core/config/schema.d.ts +1134 -0
  93. package/src/@claude-flow/shared/dist/core/config/schema.js +158 -0
  94. package/src/@claude-flow/shared/dist/core/config/validator.d.ts +92 -0
  95. package/src/@claude-flow/shared/dist/core/config/validator.js +147 -0
  96. package/src/@claude-flow/shared/dist/core/event-bus.d.ts +31 -0
  97. package/src/@claude-flow/shared/dist/core/event-bus.js +197 -0
  98. package/src/@claude-flow/shared/dist/core/index.d.ts +15 -0
  99. package/src/@claude-flow/shared/dist/core/index.js +19 -0
  100. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.d.ts +200 -0
  101. package/src/@claude-flow/shared/dist/core/interfaces/agent.interface.js +6 -0
  102. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.d.ts +310 -0
  103. package/src/@claude-flow/shared/dist/core/interfaces/coordinator.interface.js +7 -0
  104. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.d.ts +224 -0
  105. package/src/@claude-flow/shared/dist/core/interfaces/event.interface.js +46 -0
  106. package/src/@claude-flow/shared/dist/core/interfaces/index.d.ts +10 -0
  107. package/src/@claude-flow/shared/dist/core/interfaces/index.js +15 -0
  108. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.d.ts +298 -0
  109. package/src/@claude-flow/shared/dist/core/interfaces/memory.interface.js +7 -0
  110. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.d.ts +185 -0
  111. package/src/@claude-flow/shared/dist/core/interfaces/task.interface.js +6 -0
  112. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.d.ts +35 -0
  113. package/src/@claude-flow/shared/dist/core/orchestrator/event-coordinator.js +101 -0
  114. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.d.ts +60 -0
  115. package/src/@claude-flow/shared/dist/core/orchestrator/health-monitor.js +166 -0
  116. package/src/@claude-flow/shared/dist/core/orchestrator/index.d.ts +46 -0
  117. package/src/@claude-flow/shared/dist/core/orchestrator/index.js +64 -0
  118. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
  119. package/src/@claude-flow/shared/dist/core/orchestrator/lifecycle-manager.js +195 -0
  120. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.d.ts +83 -0
  121. package/src/@claude-flow/shared/dist/core/orchestrator/session-manager.js +193 -0
  122. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.d.ts +49 -0
  123. package/src/@claude-flow/shared/dist/core/orchestrator/task-manager.js +253 -0
  124. package/src/@claude-flow/shared/dist/events/domain-events.d.ts +282 -0
  125. package/src/@claude-flow/shared/dist/events/domain-events.js +165 -0
  126. package/src/@claude-flow/shared/dist/events/event-store.d.ts +126 -0
  127. package/src/@claude-flow/shared/dist/events/event-store.js +432 -0
  128. package/src/@claude-flow/shared/dist/events/event-store.test.d.ts +8 -0
  129. package/src/@claude-flow/shared/dist/events/event-store.test.js +297 -0
  130. package/src/@claude-flow/shared/dist/events/example-usage.d.ts +10 -0
  131. package/src/@claude-flow/shared/dist/events/example-usage.js +193 -0
  132. package/src/@claude-flow/shared/dist/events/index.d.ts +21 -0
  133. package/src/@claude-flow/shared/dist/events/index.js +22 -0
  134. package/src/@claude-flow/shared/dist/events/projections.d.ts +177 -0
  135. package/src/@claude-flow/shared/dist/events/projections.js +421 -0
  136. package/src/@claude-flow/shared/dist/events/rvf-event-log.d.ts +82 -0
  137. package/src/@claude-flow/shared/dist/events/rvf-event-log.js +340 -0
  138. package/src/@claude-flow/shared/dist/events/state-reconstructor.d.ts +101 -0
  139. package/src/@claude-flow/shared/dist/events/state-reconstructor.js +263 -0
  140. package/src/@claude-flow/shared/dist/events.d.ts +80 -0
  141. package/src/@claude-flow/shared/dist/events.js +249 -0
  142. package/src/@claude-flow/shared/dist/hooks/example-usage.d.ts +42 -0
  143. package/src/@claude-flow/shared/dist/hooks/example-usage.js +351 -0
  144. package/src/@claude-flow/shared/dist/hooks/executor.d.ts +100 -0
  145. package/src/@claude-flow/shared/dist/hooks/executor.js +267 -0
  146. package/src/@claude-flow/shared/dist/hooks/hooks.test.d.ts +9 -0
  147. package/src/@claude-flow/shared/dist/hooks/hooks.test.js +322 -0
  148. package/src/@claude-flow/shared/dist/hooks/index.d.ts +52 -0
  149. package/src/@claude-flow/shared/dist/hooks/index.js +51 -0
  150. package/src/@claude-flow/shared/dist/hooks/registry.d.ts +133 -0
  151. package/src/@claude-flow/shared/dist/hooks/registry.js +277 -0
  152. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.d.ts +105 -0
  153. package/src/@claude-flow/shared/dist/hooks/safety/bash-safety.js +481 -0
  154. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.d.ts +144 -0
  155. package/src/@claude-flow/shared/dist/hooks/safety/file-organization.js +328 -0
  156. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.d.ts +158 -0
  157. package/src/@claude-flow/shared/dist/hooks/safety/git-commit.js +450 -0
  158. package/src/@claude-flow/shared/dist/hooks/safety/index.d.ts +17 -0
  159. package/src/@claude-flow/shared/dist/hooks/safety/index.js +17 -0
  160. package/src/@claude-flow/shared/dist/hooks/session-hooks.d.ts +234 -0
  161. package/src/@claude-flow/shared/dist/hooks/session-hooks.js +334 -0
  162. package/src/@claude-flow/shared/dist/hooks/task-hooks.d.ts +163 -0
  163. package/src/@claude-flow/shared/dist/hooks/task-hooks.js +326 -0
  164. package/src/@claude-flow/shared/dist/hooks/types.d.ts +267 -0
  165. package/src/@claude-flow/shared/dist/hooks/types.js +62 -0
  166. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.d.ts +9 -0
  167. package/src/@claude-flow/shared/dist/hooks/verify-exports.test.js +93 -0
  168. package/src/@claude-flow/shared/dist/index.d.ts +20 -0
  169. package/src/@claude-flow/shared/dist/index.js +50 -0
  170. package/src/@claude-flow/shared/dist/mcp/connection-pool.d.ts +98 -0
  171. package/src/@claude-flow/shared/dist/mcp/connection-pool.js +364 -0
  172. package/src/@claude-flow/shared/dist/mcp/index.d.ts +69 -0
  173. package/src/@claude-flow/shared/dist/mcp/index.js +84 -0
  174. package/src/@claude-flow/shared/dist/mcp/server.d.ts +166 -0
  175. package/src/@claude-flow/shared/dist/mcp/server.js +593 -0
  176. package/src/@claude-flow/shared/dist/mcp/session-manager.d.ts +136 -0
  177. package/src/@claude-flow/shared/dist/mcp/session-manager.js +335 -0
  178. package/src/@claude-flow/shared/dist/mcp/tool-registry.d.ts +178 -0
  179. package/src/@claude-flow/shared/dist/mcp/tool-registry.js +439 -0
  180. package/src/@claude-flow/shared/dist/mcp/transport/http.d.ts +104 -0
  181. package/src/@claude-flow/shared/dist/mcp/transport/http.js +476 -0
  182. package/src/@claude-flow/shared/dist/mcp/transport/index.d.ts +102 -0
  183. package/src/@claude-flow/shared/dist/mcp/transport/index.js +238 -0
  184. package/src/@claude-flow/shared/dist/mcp/transport/stdio.d.ts +104 -0
  185. package/src/@claude-flow/shared/dist/mcp/transport/stdio.js +263 -0
  186. package/src/@claude-flow/shared/dist/mcp/transport/websocket.d.ts +133 -0
  187. package/src/@claude-flow/shared/dist/mcp/transport/websocket.js +396 -0
  188. package/src/@claude-flow/shared/dist/mcp/types.d.ts +438 -0
  189. package/src/@claude-flow/shared/dist/mcp/types.js +54 -0
  190. package/src/@claude-flow/shared/dist/plugin-interface.d.ts +544 -0
  191. package/src/@claude-flow/shared/dist/plugin-interface.js +23 -0
  192. package/src/@claude-flow/shared/dist/plugin-loader.d.ts +139 -0
  193. package/src/@claude-flow/shared/dist/plugin-loader.js +434 -0
  194. package/src/@claude-flow/shared/dist/plugin-registry.d.ts +183 -0
  195. package/src/@claude-flow/shared/dist/plugin-registry.js +457 -0
  196. package/src/@claude-flow/shared/dist/plugins/index.d.ts +10 -0
  197. package/src/@claude-flow/shared/dist/plugins/index.js +10 -0
  198. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
  199. package/src/@claude-flow/shared/dist/plugins/official/hive-mind-plugin.js +241 -0
  200. package/src/@claude-flow/shared/dist/plugins/official/index.d.ts +10 -0
  201. package/src/@claude-flow/shared/dist/plugins/official/index.js +10 -0
  202. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.d.ts +121 -0
  203. package/src/@claude-flow/shared/dist/plugins/official/maestro-plugin.js +355 -0
  204. package/src/@claude-flow/shared/dist/plugins/types.d.ts +93 -0
  205. package/src/@claude-flow/shared/dist/plugins/types.js +9 -0
  206. package/src/@claude-flow/shared/dist/resilience/bulkhead.d.ts +105 -0
  207. package/src/@claude-flow/shared/dist/resilience/bulkhead.js +206 -0
  208. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.d.ts +132 -0
  209. package/src/@claude-flow/shared/dist/resilience/circuit-breaker.js +233 -0
  210. package/src/@claude-flow/shared/dist/resilience/index.d.ts +19 -0
  211. package/src/@claude-flow/shared/dist/resilience/index.js +19 -0
  212. package/src/@claude-flow/shared/dist/resilience/rate-limiter.d.ts +168 -0
  213. package/src/@claude-flow/shared/dist/resilience/rate-limiter.js +314 -0
  214. package/src/@claude-flow/shared/dist/resilience/retry.d.ts +91 -0
  215. package/src/@claude-flow/shared/dist/resilience/retry.js +159 -0
  216. package/src/@claude-flow/shared/dist/security/index.d.ts +10 -0
  217. package/src/@claude-flow/shared/dist/security/index.js +12 -0
  218. package/src/@claude-flow/shared/dist/security/input-validation.d.ts +73 -0
  219. package/src/@claude-flow/shared/dist/security/input-validation.js +201 -0
  220. package/src/@claude-flow/shared/dist/security/secure-random.d.ts +92 -0
  221. package/src/@claude-flow/shared/dist/security/secure-random.js +142 -0
  222. package/src/@claude-flow/shared/dist/services/index.d.ts +7 -0
  223. package/src/@claude-flow/shared/dist/services/index.js +7 -0
  224. package/src/@claude-flow/shared/dist/services/v3-progress.service.d.ts +124 -0
  225. package/src/@claude-flow/shared/dist/services/v3-progress.service.js +402 -0
  226. package/src/@claude-flow/shared/dist/types/agent.types.d.ts +137 -0
  227. package/src/@claude-flow/shared/dist/types/agent.types.js +6 -0
  228. package/src/@claude-flow/shared/dist/types/index.d.ts +11 -0
  229. package/src/@claude-flow/shared/dist/types/index.js +17 -0
  230. package/src/@claude-flow/shared/dist/types/mcp.types.d.ts +266 -0
  231. package/src/@claude-flow/shared/dist/types/mcp.types.js +7 -0
  232. package/src/@claude-flow/shared/dist/types/memory.types.d.ts +236 -0
  233. package/src/@claude-flow/shared/dist/types/memory.types.js +7 -0
  234. package/src/@claude-flow/shared/dist/types/swarm.types.d.ts +186 -0
  235. package/src/@claude-flow/shared/dist/types/swarm.types.js +65 -0
  236. package/src/@claude-flow/shared/dist/types/task.types.d.ts +178 -0
  237. package/src/@claude-flow/shared/dist/types/task.types.js +32 -0
  238. package/src/@claude-flow/shared/dist/types.d.ts +197 -0
  239. package/src/@claude-flow/shared/dist/types.js +21 -0
  240. package/src/@claude-flow/shared/dist/utils/secure-logger.d.ts +69 -0
  241. 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