@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.
Files changed (541) hide show
  1. package/.agentic-flow/intelligence.json +16 -0
  2. package/README.md +323 -0
  3. package/__tests__/coverage/base.css +224 -0
  4. package/__tests__/coverage/block-navigation.js +87 -0
  5. package/__tests__/coverage/coverage-final.json +50 -0
  6. package/__tests__/coverage/favicon.png +0 -0
  7. package/__tests__/coverage/index.html +326 -0
  8. package/__tests__/coverage/lcov-report/base.css +224 -0
  9. package/__tests__/coverage/lcov-report/block-navigation.js +87 -0
  10. package/__tests__/coverage/lcov-report/favicon.png +0 -0
  11. package/__tests__/coverage/lcov-report/index.html +326 -0
  12. package/__tests__/coverage/lcov-report/prettify.css +1 -0
  13. package/__tests__/coverage/lcov-report/prettify.js +2 -0
  14. package/__tests__/coverage/lcov-report/sort-arrow-sprite.png +0 -0
  15. package/__tests__/coverage/lcov-report/sorter.js +210 -0
  16. package/__tests__/coverage/lcov-report/src/core/config/defaults.ts.html +706 -0
  17. package/__tests__/coverage/lcov-report/src/core/config/index.html +161 -0
  18. package/__tests__/coverage/lcov-report/src/core/config/loader.ts.html +898 -0
  19. package/__tests__/coverage/lcov-report/src/core/config/schema.ts.html +649 -0
  20. package/__tests__/coverage/lcov-report/src/core/config/validator.ts.html +712 -0
  21. package/__tests__/coverage/lcov-report/src/core/event-bus.ts.html +793 -0
  22. package/__tests__/coverage/lcov-report/src/core/index.html +116 -0
  23. package/__tests__/coverage/lcov-report/src/core/interfaces/event.interface.ts.html +886 -0
  24. package/__tests__/coverage/lcov-report/src/core/interfaces/index.html +116 -0
  25. package/__tests__/coverage/lcov-report/src/core/orchestrator/event-coordinator.ts.html +451 -0
  26. package/__tests__/coverage/lcov-report/src/core/orchestrator/health-monitor.ts.html +727 -0
  27. package/__tests__/coverage/lcov-report/src/core/orchestrator/index.html +176 -0
  28. package/__tests__/coverage/lcov-report/src/core/orchestrator/lifecycle-manager.ts.html +874 -0
  29. package/__tests__/coverage/lcov-report/src/core/orchestrator/session-manager.ts.html +922 -0
  30. package/__tests__/coverage/lcov-report/src/core/orchestrator/task-manager.ts.html +1036 -0
  31. package/__tests__/coverage/lcov-report/src/events/domain-events.ts.html +1837 -0
  32. package/__tests__/coverage/lcov-report/src/events/event-store.ts.html +1849 -0
  33. package/__tests__/coverage/lcov-report/src/events/example-usage.ts.html +964 -0
  34. package/__tests__/coverage/lcov-report/src/events/index.html +176 -0
  35. package/__tests__/coverage/lcov-report/src/events/projections.ts.html +1768 -0
  36. package/__tests__/coverage/lcov-report/src/events/state-reconstructor.ts.html +1132 -0
  37. package/__tests__/coverage/lcov-report/src/events.ts.html +1186 -0
  38. package/__tests__/coverage/lcov-report/src/hooks/example-usage.ts.html +1582 -0
  39. package/__tests__/coverage/lcov-report/src/hooks/executor.ts.html +1222 -0
  40. package/__tests__/coverage/lcov-report/src/hooks/index.html +191 -0
  41. package/__tests__/coverage/lcov-report/src/hooks/registry.ts.html +1084 -0
  42. package/__tests__/coverage/lcov-report/src/hooks/safety/bash-safety.ts.html +1897 -0
  43. package/__tests__/coverage/lcov-report/src/hooks/safety/file-organization.ts.html +1504 -0
  44. package/__tests__/coverage/lcov-report/src/hooks/safety/git-commit.ts.html +1954 -0
  45. package/__tests__/coverage/lcov-report/src/hooks/safety/index.html +146 -0
  46. package/__tests__/coverage/lcov-report/src/hooks/session-hooks.ts.html +1762 -0
  47. package/__tests__/coverage/lcov-report/src/hooks/task-hooks.ts.html +1624 -0
  48. package/__tests__/coverage/lcov-report/src/hooks/types.ts.html +1156 -0
  49. package/__tests__/coverage/lcov-report/src/index.html +176 -0
  50. package/__tests__/coverage/lcov-report/src/mcp/connection-pool.ts.html +1399 -0
  51. package/__tests__/coverage/lcov-report/src/mcp/index.html +176 -0
  52. package/__tests__/coverage/lcov-report/src/mcp/server.ts.html +2407 -0
  53. package/__tests__/coverage/lcov-report/src/mcp/session-manager.ts.html +1369 -0
  54. package/__tests__/coverage/lcov-report/src/mcp/tool-registry.ts.html +1783 -0
  55. package/__tests__/coverage/lcov-report/src/mcp/transport/http.ts.html +1756 -0
  56. package/__tests__/coverage/lcov-report/src/mcp/transport/index.html +146 -0
  57. package/__tests__/coverage/lcov-report/src/mcp/transport/stdio.ts.html +1057 -0
  58. package/__tests__/coverage/lcov-report/src/mcp/transport/websocket.ts.html +1537 -0
  59. package/__tests__/coverage/lcov-report/src/mcp/types.ts.html +1780 -0
  60. package/__tests__/coverage/lcov-report/src/plugin-interface.ts.html +2074 -0
  61. package/__tests__/coverage/lcov-report/src/plugin-loader.ts.html +1999 -0
  62. package/__tests__/coverage/lcov-report/src/plugin-registry.ts.html +1897 -0
  63. package/__tests__/coverage/lcov-report/src/plugins/official/hive-mind-plugin.ts.html +1075 -0
  64. package/__tests__/coverage/lcov-report/src/plugins/official/index.html +131 -0
  65. package/__tests__/coverage/lcov-report/src/plugins/official/maestro-plugin.ts.html +1609 -0
  66. package/__tests__/coverage/lcov-report/src/resilience/bulkhead.ts.html +916 -0
  67. package/__tests__/coverage/lcov-report/src/resilience/circuit-breaker.ts.html +1063 -0
  68. package/__tests__/coverage/lcov-report/src/resilience/index.html +161 -0
  69. package/__tests__/coverage/lcov-report/src/resilience/rate-limiter.ts.html +1345 -0
  70. package/__tests__/coverage/lcov-report/src/resilience/retry.ts.html +757 -0
  71. package/__tests__/coverage/lcov-report/src/security/index.html +131 -0
  72. package/__tests__/coverage/lcov-report/src/security/input-validation.ts.html +880 -0
  73. package/__tests__/coverage/lcov-report/src/security/secure-random.ts.html +562 -0
  74. package/__tests__/coverage/lcov-report/src/types/index.html +131 -0
  75. package/__tests__/coverage/lcov-report/src/types/swarm.types.ts.html +850 -0
  76. package/__tests__/coverage/lcov-report/src/types/task.types.ts.html +700 -0
  77. package/__tests__/coverage/lcov-report/src/types.ts.html +1186 -0
  78. package/__tests__/coverage/lcov-report/src/utils/index.html +116 -0
  79. package/__tests__/coverage/lcov-report/src/utils/secure-logger.ts.html +856 -0
  80. package/__tests__/coverage/lcov.info +19877 -0
  81. package/__tests__/coverage/prettify.css +1 -0
  82. package/__tests__/coverage/prettify.js +2 -0
  83. package/__tests__/coverage/sort-arrow-sprite.png +0 -0
  84. package/__tests__/coverage/sorter.js +210 -0
  85. package/__tests__/coverage/src/core/config/defaults.ts.html +706 -0
  86. package/__tests__/coverage/src/core/config/index.html +161 -0
  87. package/__tests__/coverage/src/core/config/loader.ts.html +898 -0
  88. package/__tests__/coverage/src/core/config/schema.ts.html +649 -0
  89. package/__tests__/coverage/src/core/config/validator.ts.html +712 -0
  90. package/__tests__/coverage/src/core/event-bus.ts.html +793 -0
  91. package/__tests__/coverage/src/core/index.html +116 -0
  92. package/__tests__/coverage/src/core/interfaces/event.interface.ts.html +886 -0
  93. package/__tests__/coverage/src/core/interfaces/index.html +116 -0
  94. package/__tests__/coverage/src/core/orchestrator/event-coordinator.ts.html +451 -0
  95. package/__tests__/coverage/src/core/orchestrator/health-monitor.ts.html +727 -0
  96. package/__tests__/coverage/src/core/orchestrator/index.html +176 -0
  97. package/__tests__/coverage/src/core/orchestrator/lifecycle-manager.ts.html +874 -0
  98. package/__tests__/coverage/src/core/orchestrator/session-manager.ts.html +922 -0
  99. package/__tests__/coverage/src/core/orchestrator/task-manager.ts.html +1036 -0
  100. package/__tests__/coverage/src/events/domain-events.ts.html +1837 -0
  101. package/__tests__/coverage/src/events/event-store.ts.html +1849 -0
  102. package/__tests__/coverage/src/events/example-usage.ts.html +964 -0
  103. package/__tests__/coverage/src/events/index.html +176 -0
  104. package/__tests__/coverage/src/events/projections.ts.html +1768 -0
  105. package/__tests__/coverage/src/events/state-reconstructor.ts.html +1132 -0
  106. package/__tests__/coverage/src/events.ts.html +1186 -0
  107. package/__tests__/coverage/src/hooks/example-usage.ts.html +1582 -0
  108. package/__tests__/coverage/src/hooks/executor.ts.html +1222 -0
  109. package/__tests__/coverage/src/hooks/index.html +191 -0
  110. package/__tests__/coverage/src/hooks/registry.ts.html +1084 -0
  111. package/__tests__/coverage/src/hooks/safety/bash-safety.ts.html +1897 -0
  112. package/__tests__/coverage/src/hooks/safety/file-organization.ts.html +1504 -0
  113. package/__tests__/coverage/src/hooks/safety/git-commit.ts.html +1954 -0
  114. package/__tests__/coverage/src/hooks/safety/index.html +146 -0
  115. package/__tests__/coverage/src/hooks/session-hooks.ts.html +1762 -0
  116. package/__tests__/coverage/src/hooks/task-hooks.ts.html +1624 -0
  117. package/__tests__/coverage/src/hooks/types.ts.html +1156 -0
  118. package/__tests__/coverage/src/index.html +176 -0
  119. package/__tests__/coverage/src/mcp/connection-pool.ts.html +1399 -0
  120. package/__tests__/coverage/src/mcp/index.html +176 -0
  121. package/__tests__/coverage/src/mcp/server.ts.html +2407 -0
  122. package/__tests__/coverage/src/mcp/session-manager.ts.html +1369 -0
  123. package/__tests__/coverage/src/mcp/tool-registry.ts.html +1783 -0
  124. package/__tests__/coverage/src/mcp/transport/http.ts.html +1756 -0
  125. package/__tests__/coverage/src/mcp/transport/index.html +146 -0
  126. package/__tests__/coverage/src/mcp/transport/stdio.ts.html +1057 -0
  127. package/__tests__/coverage/src/mcp/transport/websocket.ts.html +1537 -0
  128. package/__tests__/coverage/src/mcp/types.ts.html +1780 -0
  129. package/__tests__/coverage/src/plugin-interface.ts.html +2074 -0
  130. package/__tests__/coverage/src/plugin-loader.ts.html +1999 -0
  131. package/__tests__/coverage/src/plugin-registry.ts.html +1897 -0
  132. package/__tests__/coverage/src/plugins/official/hive-mind-plugin.ts.html +1075 -0
  133. package/__tests__/coverage/src/plugins/official/index.html +131 -0
  134. package/__tests__/coverage/src/plugins/official/maestro-plugin.ts.html +1609 -0
  135. package/__tests__/coverage/src/resilience/bulkhead.ts.html +916 -0
  136. package/__tests__/coverage/src/resilience/circuit-breaker.ts.html +1063 -0
  137. package/__tests__/coverage/src/resilience/index.html +161 -0
  138. package/__tests__/coverage/src/resilience/rate-limiter.ts.html +1345 -0
  139. package/__tests__/coverage/src/resilience/retry.ts.html +757 -0
  140. package/__tests__/coverage/src/security/index.html +131 -0
  141. package/__tests__/coverage/src/security/input-validation.ts.html +880 -0
  142. package/__tests__/coverage/src/security/secure-random.ts.html +562 -0
  143. package/__tests__/coverage/src/types/index.html +131 -0
  144. package/__tests__/coverage/src/types/swarm.types.ts.html +850 -0
  145. package/__tests__/coverage/src/types/task.types.ts.html +700 -0
  146. package/__tests__/coverage/src/types.ts.html +1186 -0
  147. package/__tests__/coverage/src/utils/index.html +116 -0
  148. package/__tests__/coverage/src/utils/secure-logger.ts.html +856 -0
  149. package/__tests__/hooks/bash-safety.test.ts +289 -0
  150. package/__tests__/hooks/file-organization.test.ts +335 -0
  151. package/__tests__/hooks/git-commit.test.ts +336 -0
  152. package/__tests__/hooks/index.ts +23 -0
  153. package/__tests__/hooks/session-hooks.test.ts +357 -0
  154. package/__tests__/hooks/task-hooks.test.ts +193 -0
  155. package/dist/core/config/defaults.d.ts +41 -0
  156. package/dist/core/config/defaults.d.ts.map +1 -0
  157. package/dist/core/config/defaults.js +186 -0
  158. package/dist/core/config/defaults.js.map +1 -0
  159. package/dist/core/config/index.d.ts +8 -0
  160. package/dist/core/config/index.d.ts.map +1 -0
  161. package/dist/core/config/index.js +12 -0
  162. package/dist/core/config/index.js.map +1 -0
  163. package/dist/core/config/loader.d.ts +45 -0
  164. package/dist/core/config/loader.d.ts.map +1 -0
  165. package/dist/core/config/loader.js +222 -0
  166. package/dist/core/config/loader.js.map +1 -0
  167. package/dist/core/config/schema.d.ts +1134 -0
  168. package/dist/core/config/schema.d.ts.map +1 -0
  169. package/dist/core/config/schema.js +158 -0
  170. package/dist/core/config/schema.js.map +1 -0
  171. package/dist/core/config/validator.d.ts +92 -0
  172. package/dist/core/config/validator.d.ts.map +1 -0
  173. package/dist/core/config/validator.js +147 -0
  174. package/dist/core/config/validator.js.map +1 -0
  175. package/dist/core/event-bus.d.ts +31 -0
  176. package/dist/core/event-bus.d.ts.map +1 -0
  177. package/dist/core/event-bus.js +197 -0
  178. package/dist/core/event-bus.js.map +1 -0
  179. package/dist/core/index.d.ts +15 -0
  180. package/dist/core/index.d.ts.map +1 -0
  181. package/dist/core/index.js +19 -0
  182. package/dist/core/index.js.map +1 -0
  183. package/dist/core/interfaces/agent.interface.d.ts +200 -0
  184. package/dist/core/interfaces/agent.interface.d.ts.map +1 -0
  185. package/dist/core/interfaces/agent.interface.js +6 -0
  186. package/dist/core/interfaces/agent.interface.js.map +1 -0
  187. package/dist/core/interfaces/coordinator.interface.d.ts +310 -0
  188. package/dist/core/interfaces/coordinator.interface.d.ts.map +1 -0
  189. package/dist/core/interfaces/coordinator.interface.js +7 -0
  190. package/dist/core/interfaces/coordinator.interface.js.map +1 -0
  191. package/dist/core/interfaces/event.interface.d.ts +224 -0
  192. package/dist/core/interfaces/event.interface.d.ts.map +1 -0
  193. package/dist/core/interfaces/event.interface.js +46 -0
  194. package/dist/core/interfaces/event.interface.js.map +1 -0
  195. package/dist/core/interfaces/index.d.ts +10 -0
  196. package/dist/core/interfaces/index.d.ts.map +1 -0
  197. package/dist/core/interfaces/index.js +15 -0
  198. package/dist/core/interfaces/index.js.map +1 -0
  199. package/dist/core/interfaces/memory.interface.d.ts +298 -0
  200. package/dist/core/interfaces/memory.interface.d.ts.map +1 -0
  201. package/dist/core/interfaces/memory.interface.js +7 -0
  202. package/dist/core/interfaces/memory.interface.js.map +1 -0
  203. package/dist/core/interfaces/task.interface.d.ts +185 -0
  204. package/dist/core/interfaces/task.interface.d.ts.map +1 -0
  205. package/dist/core/interfaces/task.interface.js +6 -0
  206. package/dist/core/interfaces/task.interface.js.map +1 -0
  207. package/dist/core/orchestrator/event-coordinator.d.ts +35 -0
  208. package/dist/core/orchestrator/event-coordinator.d.ts.map +1 -0
  209. package/dist/core/orchestrator/event-coordinator.js +101 -0
  210. package/dist/core/orchestrator/event-coordinator.js.map +1 -0
  211. package/dist/core/orchestrator/health-monitor.d.ts +60 -0
  212. package/dist/core/orchestrator/health-monitor.d.ts.map +1 -0
  213. package/dist/core/orchestrator/health-monitor.js +166 -0
  214. package/dist/core/orchestrator/health-monitor.js.map +1 -0
  215. package/dist/core/orchestrator/index.d.ts +46 -0
  216. package/dist/core/orchestrator/index.d.ts.map +1 -0
  217. package/dist/core/orchestrator/index.js +64 -0
  218. package/dist/core/orchestrator/index.js.map +1 -0
  219. package/dist/core/orchestrator/lifecycle-manager.d.ts +56 -0
  220. package/dist/core/orchestrator/lifecycle-manager.d.ts.map +1 -0
  221. package/dist/core/orchestrator/lifecycle-manager.js +195 -0
  222. package/dist/core/orchestrator/lifecycle-manager.js.map +1 -0
  223. package/dist/core/orchestrator/session-manager.d.ts +83 -0
  224. package/dist/core/orchestrator/session-manager.d.ts.map +1 -0
  225. package/dist/core/orchestrator/session-manager.js +193 -0
  226. package/dist/core/orchestrator/session-manager.js.map +1 -0
  227. package/dist/core/orchestrator/task-manager.d.ts +49 -0
  228. package/dist/core/orchestrator/task-manager.d.ts.map +1 -0
  229. package/dist/core/orchestrator/task-manager.js +253 -0
  230. package/dist/core/orchestrator/task-manager.js.map +1 -0
  231. package/dist/events/domain-events.d.ts +282 -0
  232. package/dist/events/domain-events.d.ts.map +1 -0
  233. package/dist/events/domain-events.js +165 -0
  234. package/dist/events/domain-events.js.map +1 -0
  235. package/dist/events/event-store.d.ts +126 -0
  236. package/dist/events/event-store.d.ts.map +1 -0
  237. package/dist/events/event-store.js +416 -0
  238. package/dist/events/event-store.js.map +1 -0
  239. package/dist/events/event-store.test.d.ts +8 -0
  240. package/dist/events/event-store.test.d.ts.map +1 -0
  241. package/dist/events/event-store.test.js +293 -0
  242. package/dist/events/event-store.test.js.map +1 -0
  243. package/dist/events/example-usage.d.ts +10 -0
  244. package/dist/events/example-usage.d.ts.map +1 -0
  245. package/dist/events/example-usage.js +193 -0
  246. package/dist/events/example-usage.js.map +1 -0
  247. package/dist/events/index.d.ts +19 -0
  248. package/dist/events/index.d.ts.map +1 -0
  249. package/dist/events/index.js +20 -0
  250. package/dist/events/index.js.map +1 -0
  251. package/dist/events/projections.d.ts +177 -0
  252. package/dist/events/projections.d.ts.map +1 -0
  253. package/dist/events/projections.js +421 -0
  254. package/dist/events/projections.js.map +1 -0
  255. package/dist/events/state-reconstructor.d.ts +101 -0
  256. package/dist/events/state-reconstructor.d.ts.map +1 -0
  257. package/dist/events/state-reconstructor.js +263 -0
  258. package/dist/events/state-reconstructor.js.map +1 -0
  259. package/dist/events.d.ts +80 -0
  260. package/dist/events.d.ts.map +1 -0
  261. package/dist/events.js +249 -0
  262. package/dist/events.js.map +1 -0
  263. package/dist/hooks/example-usage.d.ts +42 -0
  264. package/dist/hooks/example-usage.d.ts.map +1 -0
  265. package/dist/hooks/example-usage.js +351 -0
  266. package/dist/hooks/example-usage.js.map +1 -0
  267. package/dist/hooks/executor.d.ts +100 -0
  268. package/dist/hooks/executor.d.ts.map +1 -0
  269. package/dist/hooks/executor.js +264 -0
  270. package/dist/hooks/executor.js.map +1 -0
  271. package/dist/hooks/hooks.test.d.ts +9 -0
  272. package/dist/hooks/hooks.test.d.ts.map +1 -0
  273. package/dist/hooks/hooks.test.js +322 -0
  274. package/dist/hooks/hooks.test.js.map +1 -0
  275. package/dist/hooks/index.d.ts +52 -0
  276. package/dist/hooks/index.d.ts.map +1 -0
  277. package/dist/hooks/index.js +51 -0
  278. package/dist/hooks/index.js.map +1 -0
  279. package/dist/hooks/registry.d.ts +133 -0
  280. package/dist/hooks/registry.d.ts.map +1 -0
  281. package/dist/hooks/registry.js +277 -0
  282. package/dist/hooks/registry.js.map +1 -0
  283. package/dist/hooks/safety/bash-safety.d.ts +105 -0
  284. package/dist/hooks/safety/bash-safety.d.ts.map +1 -0
  285. package/dist/hooks/safety/bash-safety.js +481 -0
  286. package/dist/hooks/safety/bash-safety.js.map +1 -0
  287. package/dist/hooks/safety/file-organization.d.ts +144 -0
  288. package/dist/hooks/safety/file-organization.d.ts.map +1 -0
  289. package/dist/hooks/safety/file-organization.js +328 -0
  290. package/dist/hooks/safety/file-organization.js.map +1 -0
  291. package/dist/hooks/safety/git-commit.d.ts +158 -0
  292. package/dist/hooks/safety/git-commit.d.ts.map +1 -0
  293. package/dist/hooks/safety/git-commit.js +450 -0
  294. package/dist/hooks/safety/git-commit.js.map +1 -0
  295. package/dist/hooks/safety/index.d.ts +17 -0
  296. package/dist/hooks/safety/index.d.ts.map +1 -0
  297. package/dist/hooks/safety/index.js +17 -0
  298. package/dist/hooks/safety/index.js.map +1 -0
  299. package/dist/hooks/session-hooks.d.ts +234 -0
  300. package/dist/hooks/session-hooks.d.ts.map +1 -0
  301. package/dist/hooks/session-hooks.js +334 -0
  302. package/dist/hooks/session-hooks.js.map +1 -0
  303. package/dist/hooks/task-hooks.d.ts +163 -0
  304. package/dist/hooks/task-hooks.d.ts.map +1 -0
  305. package/dist/hooks/task-hooks.js +326 -0
  306. package/dist/hooks/task-hooks.js.map +1 -0
  307. package/dist/hooks/types.d.ts +267 -0
  308. package/dist/hooks/types.d.ts.map +1 -0
  309. package/dist/hooks/types.js +62 -0
  310. package/dist/hooks/types.js.map +1 -0
  311. package/dist/hooks/verify-exports.test.d.ts +9 -0
  312. package/dist/hooks/verify-exports.test.d.ts.map +1 -0
  313. package/dist/hooks/verify-exports.test.js +93 -0
  314. package/dist/hooks/verify-exports.test.js.map +1 -0
  315. package/dist/index.d.ts +19 -0
  316. package/dist/index.d.ts.map +1 -0
  317. package/dist/index.js +46 -0
  318. package/dist/index.js.map +1 -0
  319. package/dist/mcp/connection-pool.d.ts +98 -0
  320. package/dist/mcp/connection-pool.d.ts.map +1 -0
  321. package/dist/mcp/connection-pool.js +364 -0
  322. package/dist/mcp/connection-pool.js.map +1 -0
  323. package/dist/mcp/index.d.ts +69 -0
  324. package/dist/mcp/index.d.ts.map +1 -0
  325. package/dist/mcp/index.js +84 -0
  326. package/dist/mcp/index.js.map +1 -0
  327. package/dist/mcp/server.d.ts +166 -0
  328. package/dist/mcp/server.d.ts.map +1 -0
  329. package/dist/mcp/server.js +593 -0
  330. package/dist/mcp/server.js.map +1 -0
  331. package/dist/mcp/session-manager.d.ts +136 -0
  332. package/dist/mcp/session-manager.d.ts.map +1 -0
  333. package/dist/mcp/session-manager.js +335 -0
  334. package/dist/mcp/session-manager.js.map +1 -0
  335. package/dist/mcp/tool-registry.d.ts +178 -0
  336. package/dist/mcp/tool-registry.d.ts.map +1 -0
  337. package/dist/mcp/tool-registry.js +439 -0
  338. package/dist/mcp/tool-registry.js.map +1 -0
  339. package/dist/mcp/transport/http.d.ts +104 -0
  340. package/dist/mcp/transport/http.d.ts.map +1 -0
  341. package/dist/mcp/transport/http.js +476 -0
  342. package/dist/mcp/transport/http.js.map +1 -0
  343. package/dist/mcp/transport/index.d.ts +102 -0
  344. package/dist/mcp/transport/index.d.ts.map +1 -0
  345. package/dist/mcp/transport/index.js +238 -0
  346. package/dist/mcp/transport/index.js.map +1 -0
  347. package/dist/mcp/transport/stdio.d.ts +104 -0
  348. package/dist/mcp/transport/stdio.d.ts.map +1 -0
  349. package/dist/mcp/transport/stdio.js +263 -0
  350. package/dist/mcp/transport/stdio.js.map +1 -0
  351. package/dist/mcp/transport/websocket.d.ts +133 -0
  352. package/dist/mcp/transport/websocket.d.ts.map +1 -0
  353. package/dist/mcp/transport/websocket.js +396 -0
  354. package/dist/mcp/transport/websocket.js.map +1 -0
  355. package/dist/mcp/types.d.ts +438 -0
  356. package/dist/mcp/types.d.ts.map +1 -0
  357. package/dist/mcp/types.js +54 -0
  358. package/dist/mcp/types.js.map +1 -0
  359. package/dist/plugin-interface.d.ts +544 -0
  360. package/dist/plugin-interface.d.ts.map +1 -0
  361. package/dist/plugin-interface.js +23 -0
  362. package/dist/plugin-interface.js.map +1 -0
  363. package/dist/plugin-loader.d.ts +139 -0
  364. package/dist/plugin-loader.d.ts.map +1 -0
  365. package/dist/plugin-loader.js +434 -0
  366. package/dist/plugin-loader.js.map +1 -0
  367. package/dist/plugin-registry.d.ts +183 -0
  368. package/dist/plugin-registry.d.ts.map +1 -0
  369. package/dist/plugin-registry.js +457 -0
  370. package/dist/plugin-registry.js.map +1 -0
  371. package/dist/plugins/index.d.ts +10 -0
  372. package/dist/plugins/index.d.ts.map +1 -0
  373. package/dist/plugins/index.js +10 -0
  374. package/dist/plugins/index.js.map +1 -0
  375. package/dist/plugins/official/hive-mind-plugin.d.ts +106 -0
  376. package/dist/plugins/official/hive-mind-plugin.d.ts.map +1 -0
  377. package/dist/plugins/official/hive-mind-plugin.js +241 -0
  378. package/dist/plugins/official/hive-mind-plugin.js.map +1 -0
  379. package/dist/plugins/official/index.d.ts +10 -0
  380. package/dist/plugins/official/index.d.ts.map +1 -0
  381. package/dist/plugins/official/index.js +10 -0
  382. package/dist/plugins/official/index.js.map +1 -0
  383. package/dist/plugins/official/maestro-plugin.d.ts +121 -0
  384. package/dist/plugins/official/maestro-plugin.d.ts.map +1 -0
  385. package/dist/plugins/official/maestro-plugin.js +355 -0
  386. package/dist/plugins/official/maestro-plugin.js.map +1 -0
  387. package/dist/plugins/types.d.ts +93 -0
  388. package/dist/plugins/types.d.ts.map +1 -0
  389. package/dist/plugins/types.js +9 -0
  390. package/dist/plugins/types.js.map +1 -0
  391. package/dist/resilience/bulkhead.d.ts +105 -0
  392. package/dist/resilience/bulkhead.d.ts.map +1 -0
  393. package/dist/resilience/bulkhead.js +206 -0
  394. package/dist/resilience/bulkhead.js.map +1 -0
  395. package/dist/resilience/circuit-breaker.d.ts +132 -0
  396. package/dist/resilience/circuit-breaker.d.ts.map +1 -0
  397. package/dist/resilience/circuit-breaker.js +233 -0
  398. package/dist/resilience/circuit-breaker.js.map +1 -0
  399. package/dist/resilience/index.d.ts +19 -0
  400. package/dist/resilience/index.d.ts.map +1 -0
  401. package/dist/resilience/index.js +19 -0
  402. package/dist/resilience/index.js.map +1 -0
  403. package/dist/resilience/rate-limiter.d.ts +168 -0
  404. package/dist/resilience/rate-limiter.d.ts.map +1 -0
  405. package/dist/resilience/rate-limiter.js +314 -0
  406. package/dist/resilience/rate-limiter.js.map +1 -0
  407. package/dist/resilience/retry.d.ts +91 -0
  408. package/dist/resilience/retry.d.ts.map +1 -0
  409. package/dist/resilience/retry.js +159 -0
  410. package/dist/resilience/retry.js.map +1 -0
  411. package/dist/security/index.d.ts +10 -0
  412. package/dist/security/index.d.ts.map +1 -0
  413. package/dist/security/index.js +12 -0
  414. package/dist/security/index.js.map +1 -0
  415. package/dist/security/input-validation.d.ts +73 -0
  416. package/dist/security/input-validation.d.ts.map +1 -0
  417. package/dist/security/input-validation.js +201 -0
  418. package/dist/security/input-validation.js.map +1 -0
  419. package/dist/security/secure-random.d.ts +92 -0
  420. package/dist/security/secure-random.d.ts.map +1 -0
  421. package/dist/security/secure-random.js +142 -0
  422. package/dist/security/secure-random.js.map +1 -0
  423. package/dist/types/agent.types.d.ts +137 -0
  424. package/dist/types/agent.types.d.ts.map +1 -0
  425. package/dist/types/agent.types.js +6 -0
  426. package/dist/types/agent.types.js.map +1 -0
  427. package/dist/types/index.d.ts +11 -0
  428. package/dist/types/index.d.ts.map +1 -0
  429. package/dist/types/index.js +17 -0
  430. package/dist/types/index.js.map +1 -0
  431. package/dist/types/mcp.types.d.ts +266 -0
  432. package/dist/types/mcp.types.d.ts.map +1 -0
  433. package/dist/types/mcp.types.js +7 -0
  434. package/dist/types/mcp.types.js.map +1 -0
  435. package/dist/types/memory.types.d.ts +236 -0
  436. package/dist/types/memory.types.d.ts.map +1 -0
  437. package/dist/types/memory.types.js +7 -0
  438. package/dist/types/memory.types.js.map +1 -0
  439. package/dist/types/swarm.types.d.ts +186 -0
  440. package/dist/types/swarm.types.d.ts.map +1 -0
  441. package/dist/types/swarm.types.js +65 -0
  442. package/dist/types/swarm.types.js.map +1 -0
  443. package/dist/types/task.types.d.ts +178 -0
  444. package/dist/types/task.types.d.ts.map +1 -0
  445. package/dist/types/task.types.js +32 -0
  446. package/dist/types/task.types.js.map +1 -0
  447. package/dist/types.d.ts +197 -0
  448. package/dist/types.d.ts.map +1 -0
  449. package/dist/types.js +21 -0
  450. package/dist/types.js.map +1 -0
  451. package/dist/utils/secure-logger.d.ts +69 -0
  452. package/dist/utils/secure-logger.d.ts.map +1 -0
  453. package/dist/utils/secure-logger.js +208 -0
  454. package/dist/utils/secure-logger.js.map +1 -0
  455. package/docs/EVENTS_IMPLEMENTATION_SUMMARY.md +388 -0
  456. package/docs/EVENTS_QUICK_REFERENCE.md +470 -0
  457. package/docs/EVENTS_README.md +352 -0
  458. package/package.json +34 -0
  459. package/src/core/config/defaults.ts +207 -0
  460. package/src/core/config/index.ts +15 -0
  461. package/src/core/config/loader.ts +271 -0
  462. package/src/core/config/schema.ts +188 -0
  463. package/src/core/config/validator.ts +209 -0
  464. package/src/core/event-bus.ts +236 -0
  465. package/src/core/index.ts +22 -0
  466. package/src/core/interfaces/agent.interface.ts +251 -0
  467. package/src/core/interfaces/coordinator.interface.ts +363 -0
  468. package/src/core/interfaces/event.interface.ts +267 -0
  469. package/src/core/interfaces/index.ts +19 -0
  470. package/src/core/interfaces/memory.interface.ts +332 -0
  471. package/src/core/interfaces/task.interface.ts +223 -0
  472. package/src/core/orchestrator/event-coordinator.ts +122 -0
  473. package/src/core/orchestrator/health-monitor.ts +214 -0
  474. package/src/core/orchestrator/index.ts +89 -0
  475. package/src/core/orchestrator/lifecycle-manager.ts +263 -0
  476. package/src/core/orchestrator/session-manager.ts +279 -0
  477. package/src/core/orchestrator/task-manager.ts +317 -0
  478. package/src/events/domain-events.ts +584 -0
  479. package/src/events/event-store.test.ts +387 -0
  480. package/src/events/event-store.ts +588 -0
  481. package/src/events/example-usage.ts +293 -0
  482. package/src/events/index.ts +90 -0
  483. package/src/events/projections.ts +561 -0
  484. package/src/events/state-reconstructor.ts +349 -0
  485. package/src/events.ts +367 -0
  486. package/src/hooks/INTEGRATION.md +658 -0
  487. package/src/hooks/README.md +532 -0
  488. package/src/hooks/example-usage.ts +499 -0
  489. package/src/hooks/executor.ts +379 -0
  490. package/src/hooks/hooks.test.ts +421 -0
  491. package/src/hooks/index.ts +131 -0
  492. package/src/hooks/registry.ts +333 -0
  493. package/src/hooks/safety/bash-safety.ts +604 -0
  494. package/src/hooks/safety/file-organization.ts +473 -0
  495. package/src/hooks/safety/git-commit.ts +623 -0
  496. package/src/hooks/safety/index.ts +46 -0
  497. package/src/hooks/session-hooks.ts +559 -0
  498. package/src/hooks/task-hooks.ts +513 -0
  499. package/src/hooks/types.ts +357 -0
  500. package/src/hooks/verify-exports.test.ts +125 -0
  501. package/src/index.ts +190 -0
  502. package/src/mcp/connection-pool.ts +438 -0
  503. package/src/mcp/index.ts +183 -0
  504. package/src/mcp/server.ts +774 -0
  505. package/src/mcp/session-manager.ts +428 -0
  506. package/src/mcp/tool-registry.ts +566 -0
  507. package/src/mcp/transport/http.ts +557 -0
  508. package/src/mcp/transport/index.ts +294 -0
  509. package/src/mcp/transport/stdio.ts +324 -0
  510. package/src/mcp/transport/websocket.ts +484 -0
  511. package/src/mcp/types.ts +565 -0
  512. package/src/plugin-interface.ts +663 -0
  513. package/src/plugin-loader.ts +638 -0
  514. package/src/plugin-registry.ts +604 -0
  515. package/src/plugins/index.ts +34 -0
  516. package/src/plugins/official/hive-mind-plugin.ts +330 -0
  517. package/src/plugins/official/index.ts +24 -0
  518. package/src/plugins/official/maestro-plugin.ts +508 -0
  519. package/src/plugins/types.ts +108 -0
  520. package/src/resilience/bulkhead.ts +277 -0
  521. package/src/resilience/circuit-breaker.ts +326 -0
  522. package/src/resilience/index.ts +26 -0
  523. package/src/resilience/rate-limiter.ts +420 -0
  524. package/src/resilience/retry.ts +224 -0
  525. package/src/security/index.ts +39 -0
  526. package/src/security/input-validation.ts +265 -0
  527. package/src/security/secure-random.ts +159 -0
  528. package/src/types/agent.types.ts +144 -0
  529. package/src/types/index.ts +22 -0
  530. package/src/types/mcp.types.ts +300 -0
  531. package/src/types/memory.types.ts +263 -0
  532. package/src/types/swarm.types.ts +255 -0
  533. package/src/types/task.types.ts +205 -0
  534. package/src/types.ts +367 -0
  535. package/src/utils/secure-logger.d.ts +69 -0
  536. package/src/utils/secure-logger.d.ts.map +1 -0
  537. package/src/utils/secure-logger.js +208 -0
  538. package/src/utils/secure-logger.js.map +1 -0
  539. package/src/utils/secure-logger.ts +257 -0
  540. package/tsconfig.json +9 -0
  541. package/tsconfig.tsbuildinfo +1 -0
@@ -0,0 +1,566 @@
1
+ /**
2
+ * V3 MCP Tool Registry
3
+ *
4
+ * High-performance tool management with:
5
+ * - Fast O(1) lookup using Map
6
+ * - Category-based organization
7
+ * - Tool validation on registration
8
+ * - Dynamic registration/unregistration
9
+ * - Caching for frequently used tools
10
+ *
11
+ * Performance Targets:
12
+ * - Tool registration: <10ms
13
+ * - Tool lookup: <1ms
14
+ * - Tool validation: <5ms
15
+ */
16
+
17
+ import { EventEmitter } from 'events';
18
+ import {
19
+ MCPTool,
20
+ JSONSchema,
21
+ ToolHandler,
22
+ ToolContext,
23
+ ToolCallResult,
24
+ ToolRegistrationOptions,
25
+ ILogger,
26
+ } from './types.js';
27
+
28
+ /**
29
+ * Tool metadata for enhanced lookup
30
+ */
31
+ interface ToolMetadata {
32
+ tool: MCPTool;
33
+ registeredAt: Date;
34
+ callCount: number;
35
+ lastCalled?: Date;
36
+ avgExecutionTime: number;
37
+ errorCount: number;
38
+ }
39
+
40
+ /**
41
+ * Tool search options
42
+ */
43
+ interface ToolSearchOptions {
44
+ category?: string;
45
+ tags?: string[];
46
+ deprecated?: boolean;
47
+ cacheable?: boolean;
48
+ }
49
+
50
+ /**
51
+ * Tool Registry
52
+ *
53
+ * Manages registration, lookup, and execution of MCP tools
54
+ */
55
+ export class ToolRegistry extends EventEmitter {
56
+ private readonly tools: Map<string, ToolMetadata> = new Map();
57
+ private readonly categoryIndex: Map<string, Set<string>> = new Map();
58
+ private readonly tagIndex: Map<string, Set<string>> = new Map();
59
+ private defaultContext?: ToolContext;
60
+
61
+ // Performance tracking
62
+ private totalRegistrations = 0;
63
+ private totalLookups = 0;
64
+ private totalExecutions = 0;
65
+
66
+ constructor(private readonly logger: ILogger) {
67
+ super();
68
+ }
69
+
70
+ /**
71
+ * Register a tool
72
+ */
73
+ register(tool: MCPTool, options: ToolRegistrationOptions = {}): boolean {
74
+ const startTime = performance.now();
75
+
76
+ // Check for existing tool
77
+ if (this.tools.has(tool.name) && !options.override) {
78
+ this.logger.warn('Tool already registered', { name: tool.name });
79
+ return false;
80
+ }
81
+
82
+ // Validate tool if requested
83
+ if (options.validate !== false) {
84
+ const validation = this.validateTool(tool);
85
+ if (!validation.valid) {
86
+ this.logger.error('Tool validation failed', {
87
+ name: tool.name,
88
+ errors: validation.errors,
89
+ });
90
+ return false;
91
+ }
92
+ }
93
+
94
+ // Create metadata
95
+ const metadata: ToolMetadata = {
96
+ tool,
97
+ registeredAt: new Date(),
98
+ callCount: 0,
99
+ avgExecutionTime: 0,
100
+ errorCount: 0,
101
+ };
102
+
103
+ // Register tool
104
+ this.tools.set(tool.name, metadata);
105
+ this.totalRegistrations++;
106
+
107
+ // Update category index
108
+ if (tool.category) {
109
+ if (!this.categoryIndex.has(tool.category)) {
110
+ this.categoryIndex.set(tool.category, new Set());
111
+ }
112
+ this.categoryIndex.get(tool.category)!.add(tool.name);
113
+ }
114
+
115
+ // Update tag index
116
+ if (tool.tags) {
117
+ for (const tag of tool.tags) {
118
+ if (!this.tagIndex.has(tag)) {
119
+ this.tagIndex.set(tag, new Set());
120
+ }
121
+ this.tagIndex.get(tag)!.add(tool.name);
122
+ }
123
+ }
124
+
125
+ const duration = performance.now() - startTime;
126
+ this.logger.debug('Tool registered', {
127
+ name: tool.name,
128
+ category: tool.category,
129
+ duration: `${duration.toFixed(2)}ms`,
130
+ });
131
+
132
+ this.emit('tool:registered', tool.name);
133
+ return true;
134
+ }
135
+
136
+ /**
137
+ * Register multiple tools at once
138
+ */
139
+ registerBatch(tools: MCPTool[], options: ToolRegistrationOptions = {}): {
140
+ registered: number;
141
+ failed: string[];
142
+ } {
143
+ const startTime = performance.now();
144
+ const failed: string[] = [];
145
+ let registered = 0;
146
+
147
+ for (const tool of tools) {
148
+ if (this.register(tool, options)) {
149
+ registered++;
150
+ } else {
151
+ failed.push(tool.name);
152
+ }
153
+ }
154
+
155
+ const duration = performance.now() - startTime;
156
+ this.logger.info('Batch registration complete', {
157
+ total: tools.length,
158
+ registered,
159
+ failed: failed.length,
160
+ duration: `${duration.toFixed(2)}ms`,
161
+ });
162
+
163
+ return { registered, failed };
164
+ }
165
+
166
+ /**
167
+ * Unregister a tool
168
+ */
169
+ unregister(name: string): boolean {
170
+ const metadata = this.tools.get(name);
171
+ if (!metadata) {
172
+ return false;
173
+ }
174
+
175
+ // Remove from category index
176
+ if (metadata.tool.category) {
177
+ const categoryTools = this.categoryIndex.get(metadata.tool.category);
178
+ categoryTools?.delete(name);
179
+ if (categoryTools?.size === 0) {
180
+ this.categoryIndex.delete(metadata.tool.category);
181
+ }
182
+ }
183
+
184
+ // Remove from tag index
185
+ if (metadata.tool.tags) {
186
+ for (const tag of metadata.tool.tags) {
187
+ const tagTools = this.tagIndex.get(tag);
188
+ tagTools?.delete(name);
189
+ if (tagTools?.size === 0) {
190
+ this.tagIndex.delete(tag);
191
+ }
192
+ }
193
+ }
194
+
195
+ this.tools.delete(name);
196
+ this.logger.debug('Tool unregistered', { name });
197
+ this.emit('tool:unregistered', name);
198
+
199
+ return true;
200
+ }
201
+
202
+ /**
203
+ * Get a tool by name
204
+ */
205
+ getTool(name: string): MCPTool | undefined {
206
+ this.totalLookups++;
207
+ return this.tools.get(name)?.tool;
208
+ }
209
+
210
+ /**
211
+ * Check if a tool exists
212
+ */
213
+ hasTool(name: string): boolean {
214
+ return this.tools.has(name);
215
+ }
216
+
217
+ /**
218
+ * Get tool count
219
+ */
220
+ getToolCount(): number {
221
+ return this.tools.size;
222
+ }
223
+
224
+ /**
225
+ * Get all tool names
226
+ */
227
+ getToolNames(): string[] {
228
+ return Array.from(this.tools.keys());
229
+ }
230
+
231
+ /**
232
+ * List all tools with metadata
233
+ */
234
+ listTools(): Array<{
235
+ name: string;
236
+ description: string;
237
+ category?: string;
238
+ tags?: string[];
239
+ deprecated?: boolean;
240
+ }> {
241
+ return Array.from(this.tools.values()).map(({ tool }) => ({
242
+ name: tool.name,
243
+ description: tool.description,
244
+ category: tool.category,
245
+ tags: tool.tags,
246
+ deprecated: tool.deprecated,
247
+ }));
248
+ }
249
+
250
+ /**
251
+ * Search tools by criteria
252
+ */
253
+ search(options: ToolSearchOptions): MCPTool[] {
254
+ let results: Set<string> | undefined;
255
+
256
+ // Filter by category
257
+ if (options.category) {
258
+ const categoryTools = this.categoryIndex.get(options.category);
259
+ if (!categoryTools) return [];
260
+ results = new Set(categoryTools);
261
+ }
262
+
263
+ // Filter by tags (intersection)
264
+ if (options.tags && options.tags.length > 0) {
265
+ for (const tag of options.tags) {
266
+ const tagTools = this.tagIndex.get(tag);
267
+ if (!tagTools) return [];
268
+
269
+ if (results) {
270
+ results = new Set([...results].filter((name) => tagTools.has(name)));
271
+ } else {
272
+ results = new Set(tagTools);
273
+ }
274
+ }
275
+ }
276
+
277
+ // Get all tools if no filters applied
278
+ if (!results) {
279
+ results = new Set(this.tools.keys());
280
+ }
281
+
282
+ // Convert to tools and apply additional filters
283
+ const tools: MCPTool[] = [];
284
+ for (const name of results) {
285
+ const metadata = this.tools.get(name);
286
+ if (!metadata) continue;
287
+
288
+ const tool = metadata.tool;
289
+
290
+ // Filter by deprecated status
291
+ if (options.deprecated !== undefined && tool.deprecated !== options.deprecated) {
292
+ continue;
293
+ }
294
+
295
+ // Filter by cacheable status
296
+ if (options.cacheable !== undefined && tool.cacheable !== options.cacheable) {
297
+ continue;
298
+ }
299
+
300
+ tools.push(tool);
301
+ }
302
+
303
+ return tools;
304
+ }
305
+
306
+ /**
307
+ * Get tools by category
308
+ */
309
+ getByCategory(category: string): MCPTool[] {
310
+ const toolNames = this.categoryIndex.get(category);
311
+ if (!toolNames) return [];
312
+
313
+ return Array.from(toolNames)
314
+ .map((name) => this.tools.get(name)?.tool)
315
+ .filter((tool): tool is MCPTool => tool !== undefined);
316
+ }
317
+
318
+ /**
319
+ * Get tools by tag
320
+ */
321
+ getByTag(tag: string): MCPTool[] {
322
+ const toolNames = this.tagIndex.get(tag);
323
+ if (!toolNames) return [];
324
+
325
+ return Array.from(toolNames)
326
+ .map((name) => this.tools.get(name)?.tool)
327
+ .filter((tool): tool is MCPTool => tool !== undefined);
328
+ }
329
+
330
+ /**
331
+ * Get all categories
332
+ */
333
+ getCategories(): string[] {
334
+ return Array.from(this.categoryIndex.keys());
335
+ }
336
+
337
+ /**
338
+ * Get all tags
339
+ */
340
+ getTags(): string[] {
341
+ return Array.from(this.tagIndex.keys());
342
+ }
343
+
344
+ /**
345
+ * Execute a tool
346
+ */
347
+ async execute(
348
+ name: string,
349
+ input: Record<string, unknown>,
350
+ context?: ToolContext
351
+ ): Promise<ToolCallResult> {
352
+ const startTime = performance.now();
353
+ const metadata = this.tools.get(name);
354
+
355
+ if (!metadata) {
356
+ return {
357
+ content: [{ type: 'text', text: `Tool not found: ${name}` }],
358
+ isError: true,
359
+ };
360
+ }
361
+
362
+ // Build execution context with required sessionId
363
+ const execContext: ToolContext = {
364
+ sessionId: context?.sessionId || this.defaultContext?.sessionId || 'default-session',
365
+ ...this.defaultContext,
366
+ ...context,
367
+ };
368
+ this.totalExecutions++;
369
+ metadata.callCount++;
370
+ metadata.lastCalled = new Date();
371
+
372
+ try {
373
+ this.emit('tool:called', { name, input });
374
+
375
+ const result = await metadata.tool.handler(input, execContext);
376
+
377
+ const duration = performance.now() - startTime;
378
+ this.updateAverageExecutionTime(metadata, duration);
379
+
380
+ this.logger.debug('Tool executed', {
381
+ name,
382
+ duration: `${duration.toFixed(2)}ms`,
383
+ success: true,
384
+ });
385
+
386
+ this.emit('tool:completed', { name, duration, success: true });
387
+
388
+ // Format result
389
+ return {
390
+ content: [{
391
+ type: 'text',
392
+ text: typeof result === 'string' ? result : JSON.stringify(result, null, 2),
393
+ }],
394
+ isError: false,
395
+ };
396
+ } catch (error) {
397
+ const duration = performance.now() - startTime;
398
+ metadata.errorCount++;
399
+
400
+ this.logger.error('Tool execution failed', { name, error });
401
+ this.emit('tool:error', { name, error, duration });
402
+
403
+ return {
404
+ content: [{
405
+ type: 'text',
406
+ text: `Error: ${error instanceof Error ? error.message : String(error)}`,
407
+ }],
408
+ isError: true,
409
+ };
410
+ }
411
+ }
412
+
413
+ /**
414
+ * Set default execution context
415
+ */
416
+ setDefaultContext(context: ToolContext): void {
417
+ this.defaultContext = context;
418
+ }
419
+
420
+ /**
421
+ * Get tool metadata
422
+ */
423
+ getMetadata(name: string): ToolMetadata | undefined {
424
+ return this.tools.get(name);
425
+ }
426
+
427
+ /**
428
+ * Get registry statistics
429
+ */
430
+ getStats(): {
431
+ totalTools: number;
432
+ totalCategories: number;
433
+ totalTags: number;
434
+ totalRegistrations: number;
435
+ totalLookups: number;
436
+ totalExecutions: number;
437
+ topTools: Array<{ name: string; calls: number }>;
438
+ } {
439
+ // Get top 10 most used tools
440
+ const topTools = Array.from(this.tools.entries())
441
+ .map(([name, metadata]) => ({ name, calls: metadata.callCount }))
442
+ .sort((a, b) => b.calls - a.calls)
443
+ .slice(0, 10);
444
+
445
+ return {
446
+ totalTools: this.tools.size,
447
+ totalCategories: this.categoryIndex.size,
448
+ totalTags: this.tagIndex.size,
449
+ totalRegistrations: this.totalRegistrations,
450
+ totalLookups: this.totalLookups,
451
+ totalExecutions: this.totalExecutions,
452
+ topTools,
453
+ };
454
+ }
455
+
456
+ /**
457
+ * Validate a tool definition
458
+ */
459
+ validateTool(tool: MCPTool): { valid: boolean; errors: string[] } {
460
+ const errors: string[] = [];
461
+
462
+ if (!tool.name || typeof tool.name !== 'string') {
463
+ errors.push('Tool name is required and must be a string');
464
+ } else if (!/^[a-zA-Z][a-zA-Z0-9_/:-]*$/.test(tool.name)) {
465
+ errors.push('Tool name must start with a letter and contain only alphanumeric characters, underscores, slashes, colons, and hyphens');
466
+ }
467
+
468
+ if (!tool.description || typeof tool.description !== 'string') {
469
+ errors.push('Tool description is required and must be a string');
470
+ }
471
+
472
+ if (!tool.inputSchema || typeof tool.inputSchema !== 'object') {
473
+ errors.push('Tool inputSchema is required and must be an object');
474
+ } else {
475
+ const schemaErrors = this.validateSchema(tool.inputSchema);
476
+ errors.push(...schemaErrors);
477
+ }
478
+
479
+ if (typeof tool.handler !== 'function') {
480
+ errors.push('Tool handler is required and must be a function');
481
+ }
482
+
483
+ return {
484
+ valid: errors.length === 0,
485
+ errors,
486
+ };
487
+ }
488
+
489
+ /**
490
+ * Validate JSON Schema
491
+ */
492
+ private validateSchema(schema: JSONSchema, path = ''): string[] {
493
+ const errors: string[] = [];
494
+
495
+ if (!schema.type) {
496
+ errors.push(`${path || 'schema'}: type is required`);
497
+ }
498
+
499
+ if (schema.type === 'object' && schema.properties) {
500
+ for (const [key, propSchema] of Object.entries(schema.properties)) {
501
+ const propPath = path ? `${path}.${key}` : key;
502
+ errors.push(...this.validateSchema(propSchema, propPath));
503
+ }
504
+ }
505
+
506
+ if (schema.type === 'array' && schema.items) {
507
+ errors.push(...this.validateSchema(schema.items, `${path}[]`));
508
+ }
509
+
510
+ return errors;
511
+ }
512
+
513
+ /**
514
+ * Update average execution time
515
+ */
516
+ private updateAverageExecutionTime(metadata: ToolMetadata, duration: number): void {
517
+ const n = metadata.callCount;
518
+ metadata.avgExecutionTime =
519
+ ((metadata.avgExecutionTime * (n - 1)) + duration) / n;
520
+ }
521
+
522
+ /**
523
+ * Clear all tools
524
+ */
525
+ clear(): void {
526
+ this.tools.clear();
527
+ this.categoryIndex.clear();
528
+ this.tagIndex.clear();
529
+ this.logger.info('Tool registry cleared');
530
+ this.emit('registry:cleared');
531
+ }
532
+ }
533
+
534
+ /**
535
+ * Create a tool registry
536
+ */
537
+ export function createToolRegistry(logger: ILogger): ToolRegistry {
538
+ return new ToolRegistry(logger);
539
+ }
540
+
541
+ /**
542
+ * Helper to create a tool definition
543
+ */
544
+ export function defineTool<TInput = Record<string, unknown>, TOutput = unknown>(
545
+ name: string,
546
+ description: string,
547
+ inputSchema: JSONSchema,
548
+ handler: ToolHandler<TInput, TOutput>,
549
+ options?: {
550
+ category?: string;
551
+ tags?: string[];
552
+ version?: string;
553
+ deprecated?: boolean;
554
+ cacheable?: boolean;
555
+ cacheTTL?: number;
556
+ timeout?: number;
557
+ }
558
+ ): MCPTool<TInput, TOutput> {
559
+ return {
560
+ name,
561
+ description,
562
+ inputSchema,
563
+ handler,
564
+ ...options,
565
+ };
566
+ }