@loop_ouroboros/mcp-hub-lite 1.0.0

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 (499) hide show
  1. package/CHANGELOG.md +228 -0
  2. package/LICENSE +21 -0
  3. package/README.md +354 -0
  4. package/dist/client/assets/HomeView-f901HeKw.js +1 -0
  5. package/dist/client/assets/ResourceDetailView-BdOaL_-o.css +1 -0
  6. package/dist/client/assets/ResourceDetailView-Bz66ZjfY.js +1 -0
  7. package/dist/client/assets/ResourcesView-CjMklkyv.css +1 -0
  8. package/dist/client/assets/ResourcesView-lI_fItfA.js +1 -0
  9. package/dist/client/assets/ServerDashboard-7_8Og9JJ.css +1 -0
  10. package/dist/client/assets/ServerDashboard-Bgx8WVkx.js +2 -0
  11. package/dist/client/assets/ServerListView-Bws09jNR.css +1 -0
  12. package/dist/client/assets/ServerListView-CP6Ffkfx.js +30 -0
  13. package/dist/client/assets/ServerStatusTags.vue_vue_type_script_setup_true_lang-BHiTFM7-.js +1 -0
  14. package/dist/client/assets/SessionsView-D68qKR4D.js +1 -0
  15. package/dist/client/assets/SettingsView-BPYfO9BE.js +1 -0
  16. package/dist/client/assets/ToolCallDialog-Br8FNebN.js +1 -0
  17. package/dist/client/assets/ToolCallDialog-C7eh7jHE.css +1 -0
  18. package/dist/client/assets/ToolsView-B6hUiR43.js +1 -0
  19. package/dist/client/assets/ToolsView-BLnU8cV6.css +1 -0
  20. package/dist/client/assets/_baseClone-DCmK847M.js +1 -0
  21. package/dist/client/assets/_plugin-vue_export-helper-DlAUqK2U.js +1 -0
  22. package/dist/client/assets/el-form-item-BVMLpmVC.css +1 -0
  23. package/dist/client/assets/el-form-item-DM0q2hmO.js +12 -0
  24. package/dist/client/assets/el-input-BtI9NECe.js +1 -0
  25. package/dist/client/assets/el-input-CmuHb8HS.css +1 -0
  26. package/dist/client/assets/el-loading-CChNmKeI.js +1 -0
  27. package/dist/client/assets/el-loading-bpKhqqQq.css +1 -0
  28. package/dist/client/assets/el-overlay-B2ZKM6Up.css +1 -0
  29. package/dist/client/assets/el-overlay-lZZbPmsX.js +1 -0
  30. package/dist/client/assets/el-select-BXztu2b5.js +1 -0
  31. package/dist/client/assets/el-select-C0U_l4IZ.css +1 -0
  32. package/dist/client/assets/el-tab-pane-CnNoQHsR.css +1 -0
  33. package/dist/client/assets/el-tab-pane-Dy9ruaEX.js +1 -0
  34. package/dist/client/assets/el-table-column-98UyVgBH.js +1 -0
  35. package/dist/client/assets/el-table-column-T_mV9jNw.css +1 -0
  36. package/dist/client/assets/el-tag-B5lLT51E.js +1 -0
  37. package/dist/client/assets/el-tag-DjxZVOpb.css +1 -0
  38. package/dist/client/assets/event-BB_Ol6Sd.js +1 -0
  39. package/dist/client/assets/index-BgKcmWJr.js +1 -0
  40. package/dist/client/assets/index-BsDWtoIl.css +1 -0
  41. package/dist/client/assets/index-BzQXG7no.js +1 -0
  42. package/dist/client/assets/index-CSTs2jYk.js +2 -0
  43. package/dist/client/assets/omit-Bx5HJNV_.js +1 -0
  44. package/dist/client/assets/raf-B9VDMtMF.js +1 -0
  45. package/dist/client/assets/typescript-Bp3YSIOJ.js +1 -0
  46. package/dist/client/assets/vnode-B8aJx8u4.js +1 -0
  47. package/dist/client/assets/vue-vendor-6ny5zj9i.js +3 -0
  48. package/dist/client/index.html +15 -0
  49. package/dist/server/shared/index.d.ts +3 -0
  50. package/dist/server/shared/index.d.ts.map +1 -0
  51. package/dist/server/shared/index.js +2 -0
  52. package/dist/server/shared/models/index.d.ts +4 -0
  53. package/dist/server/shared/models/index.d.ts.map +1 -0
  54. package/dist/server/shared/models/index.js +3 -0
  55. package/dist/server/shared/models/resource.model.d.ts +8 -0
  56. package/dist/server/shared/models/resource.model.d.ts.map +1 -0
  57. package/dist/server/shared/models/resource.model.js +1 -0
  58. package/dist/server/shared/models/server.model.d.ts +57 -0
  59. package/dist/server/shared/models/server.model.d.ts.map +1 -0
  60. package/dist/server/shared/models/server.model.js +1 -0
  61. package/dist/server/shared/models/session.model.d.ts +73 -0
  62. package/dist/server/shared/models/session.model.d.ts.map +1 -0
  63. package/dist/server/shared/models/session.model.js +70 -0
  64. package/dist/server/shared/models/tool.model.d.ts +22 -0
  65. package/dist/server/shared/models/tool.model.d.ts.map +1 -0
  66. package/dist/server/shared/models/tool.model.js +1 -0
  67. package/dist/server/shared/types/client.types.d.ts +35 -0
  68. package/dist/server/shared/types/client.types.d.ts.map +1 -0
  69. package/dist/server/shared/types/client.types.js +5 -0
  70. package/dist/server/shared/types/common.types.d.ts +5 -0
  71. package/dist/server/shared/types/common.types.d.ts.map +1 -0
  72. package/dist/server/shared/types/common.types.js +2 -0
  73. package/dist/server/shared/types/index.d.ts +4 -0
  74. package/dist/server/shared/types/index.d.ts.map +1 -0
  75. package/dist/server/shared/types/index.js +3 -0
  76. package/dist/server/shared/types/session.types.d.ts +15 -0
  77. package/dist/server/shared/types/session.types.d.ts.map +1 -0
  78. package/dist/server/shared/types/session.types.js +5 -0
  79. package/dist/server/shared/types/websocket.types.d.ts +177 -0
  80. package/dist/server/shared/types/websocket.types.d.ts.map +1 -0
  81. package/dist/server/shared/types/websocket.types.js +25 -0
  82. package/dist/server/src/api/mcp/debug-response-wrapper.d.ts +13 -0
  83. package/dist/server/src/api/mcp/debug-response-wrapper.d.ts.map +1 -0
  84. package/dist/server/src/api/mcp/debug-response-wrapper.js +271 -0
  85. package/dist/server/src/api/mcp/gateway.d.ts +14 -0
  86. package/dist/server/src/api/mcp/gateway.d.ts.map +1 -0
  87. package/dist/server/src/api/mcp/gateway.js +116 -0
  88. package/dist/server/src/api/mcp/session-context-extractor.d.ts +47 -0
  89. package/dist/server/src/api/mcp/session-context-extractor.d.ts.map +1 -0
  90. package/dist/server/src/api/mcp/session-context-extractor.js +127 -0
  91. package/dist/server/src/api/mcp/sse-stream-manager.d.ts +13 -0
  92. package/dist/server/src/api/mcp/sse-stream-manager.d.ts.map +1 -0
  93. package/dist/server/src/api/mcp/sse-stream-manager.js +40 -0
  94. package/dist/server/src/api/web/clients.d.ts +30 -0
  95. package/dist/server/src/api/web/clients.d.ts.map +1 -0
  96. package/dist/server/src/api/web/clients.js +41 -0
  97. package/dist/server/src/api/web/config.d.ts +21 -0
  98. package/dist/server/src/api/web/config.d.ts.map +1 -0
  99. package/dist/server/src/api/web/config.js +119 -0
  100. package/dist/server/src/api/web/health.d.ts +21 -0
  101. package/dist/server/src/api/web/health.d.ts.map +1 -0
  102. package/dist/server/src/api/web/health.js +24 -0
  103. package/dist/server/src/api/web/hub-tools.d.ts +30 -0
  104. package/dist/server/src/api/web/hub-tools.d.ts.map +1 -0
  105. package/dist/server/src/api/web/hub-tools.js +202 -0
  106. package/dist/server/src/api/web/logs.d.ts +30 -0
  107. package/dist/server/src/api/web/logs.d.ts.map +1 -0
  108. package/dist/server/src/api/web/logs.js +141 -0
  109. package/dist/server/src/api/web/mcp-status.d.ts +29 -0
  110. package/dist/server/src/api/web/mcp-status.d.ts.map +1 -0
  111. package/dist/server/src/api/web/mcp-status.js +126 -0
  112. package/dist/server/src/api/web/resources.d.ts +28 -0
  113. package/dist/server/src/api/web/resources.d.ts.map +1 -0
  114. package/dist/server/src/api/web/resources.js +93 -0
  115. package/dist/server/src/api/web/search.d.ts +26 -0
  116. package/dist/server/src/api/web/search.d.ts.map +1 -0
  117. package/dist/server/src/api/web/search.js +62 -0
  118. package/dist/server/src/api/web/servers.d.ts +33 -0
  119. package/dist/server/src/api/web/servers.d.ts.map +1 -0
  120. package/dist/server/src/api/web/servers.js +235 -0
  121. package/dist/server/src/api/web/sessions.d.ts +29 -0
  122. package/dist/server/src/api/web/sessions.d.ts.map +1 -0
  123. package/dist/server/src/api/web/sessions.js +104 -0
  124. package/dist/server/src/api/ws/events.d.ts +29 -0
  125. package/dist/server/src/api/ws/events.d.ts.map +1 -0
  126. package/dist/server/src/api/ws/events.js +44 -0
  127. package/dist/server/src/api/ws/ws-handler.d.ts +83 -0
  128. package/dist/server/src/api/ws/ws-handler.d.ts.map +1 -0
  129. package/dist/server/src/api/ws/ws-handler.js +217 -0
  130. package/dist/server/src/app.d.ts +24 -0
  131. package/dist/server/src/app.d.ts.map +1 -0
  132. package/dist/server/src/app.js +108 -0
  133. package/dist/server/src/cli/commands/list.d.ts +71 -0
  134. package/dist/server/src/cli/commands/list.d.ts.map +1 -0
  135. package/dist/server/src/cli/commands/list.js +97 -0
  136. package/dist/server/src/cli/commands/restart.d.ts +42 -0
  137. package/dist/server/src/cli/commands/restart.d.ts.map +1 -0
  138. package/dist/server/src/cli/commands/restart.js +61 -0
  139. package/dist/server/src/cli/commands/start.d.ts +43 -0
  140. package/dist/server/src/cli/commands/start.d.ts.map +1 -0
  141. package/dist/server/src/cli/commands/start.js +160 -0
  142. package/dist/server/src/cli/commands/status.d.ts +39 -0
  143. package/dist/server/src/cli/commands/status.d.ts.map +1 -0
  144. package/dist/server/src/cli/commands/status.js +164 -0
  145. package/dist/server/src/cli/commands/stop.d.ts +34 -0
  146. package/dist/server/src/cli/commands/stop.d.ts.map +1 -0
  147. package/dist/server/src/cli/commands/stop.js +47 -0
  148. package/dist/server/src/cli/commands/ui.d.ts +44 -0
  149. package/dist/server/src/cli/commands/ui.d.ts.map +1 -0
  150. package/dist/server/src/cli/commands/ui.js +95 -0
  151. package/dist/server/src/cli/index.d.ts +62 -0
  152. package/dist/server/src/cli/index.d.ts.map +1 -0
  153. package/dist/server/src/cli/index.js +88 -0
  154. package/dist/server/src/cli/parse-args.d.ts +108 -0
  155. package/dist/server/src/cli/parse-args.d.ts.map +1 -0
  156. package/dist/server/src/cli/parse-args.js +131 -0
  157. package/dist/server/src/cli/server.d.ts +171 -0
  158. package/dist/server/src/cli/server.d.ts.map +1 -0
  159. package/dist/server/src/cli/server.js +246 -0
  160. package/dist/server/src/config/config-change-logger.d.ts +16 -0
  161. package/dist/server/src/config/config-change-logger.d.ts.map +1 -0
  162. package/dist/server/src/config/config-change-logger.js +43 -0
  163. package/dist/server/src/config/config-loader.d.ts +22 -0
  164. package/dist/server/src/config/config-loader.d.ts.map +1 -0
  165. package/dist/server/src/config/config-loader.js +66 -0
  166. package/dist/server/src/config/config-manager.d.ts +158 -0
  167. package/dist/server/src/config/config-manager.d.ts.map +1 -0
  168. package/dist/server/src/config/config-manager.js +246 -0
  169. package/dist/server/src/config/config-saver.d.ts +16 -0
  170. package/dist/server/src/config/config-saver.d.ts.map +1 -0
  171. package/dist/server/src/config/config-saver.js +28 -0
  172. package/dist/server/src/config/config.schema.d.ts +108 -0
  173. package/dist/server/src/config/config.schema.d.ts.map +1 -0
  174. package/dist/server/src/config/config.schema.js +103 -0
  175. package/dist/server/src/config/server-config-manager.d.ts +74 -0
  176. package/dist/server/src/config/server-config-manager.d.ts.map +1 -0
  177. package/dist/server/src/config/server-config-manager.js +157 -0
  178. package/dist/server/src/config/type-converter.d.ts +13 -0
  179. package/dist/server/src/config/type-converter.d.ts.map +1 -0
  180. package/dist/server/src/config/type-converter.js +37 -0
  181. package/dist/server/src/index.d.ts +3 -0
  182. package/dist/server/src/index.d.ts.map +1 -0
  183. package/dist/server/src/index.js +352 -0
  184. package/dist/server/src/models/event.model.d.ts +106 -0
  185. package/dist/server/src/models/event.model.d.ts.map +1 -0
  186. package/dist/server/src/models/event.model.js +5 -0
  187. package/dist/server/src/models/server.model.d.ts +19 -0
  188. package/dist/server/src/models/server.model.d.ts.map +1 -0
  189. package/dist/server/src/models/server.model.js +1 -0
  190. package/dist/server/src/models/system-tools.constants.d.ts +73 -0
  191. package/dist/server/src/models/system-tools.constants.d.ts.map +1 -0
  192. package/dist/server/src/models/system-tools.constants.js +31 -0
  193. package/dist/server/src/models/types.d.ts +84 -0
  194. package/dist/server/src/models/types.d.ts.map +1 -0
  195. package/dist/server/src/models/types.js +67 -0
  196. package/dist/server/src/pid/file.d.ts +26 -0
  197. package/dist/server/src/pid/file.d.ts.map +1 -0
  198. package/dist/server/src/pid/file.js +68 -0
  199. package/dist/server/src/pid/manager.d.ts +98 -0
  200. package/dist/server/src/pid/manager.d.ts.map +1 -0
  201. package/dist/server/src/pid/manager.js +158 -0
  202. package/dist/server/src/pid/types.d.ts +13 -0
  203. package/dist/server/src/pid/types.d.ts.map +1 -0
  204. package/dist/server/src/pid/types.js +4 -0
  205. package/dist/server/src/server/dev-server.d.ts +2 -0
  206. package/dist/server/src/server/dev-server.d.ts.map +1 -0
  207. package/dist/server/src/server/dev-server.js +171 -0
  208. package/dist/server/src/server/runner.d.ts +57 -0
  209. package/dist/server/src/server/runner.d.ts.map +1 -0
  210. package/dist/server/src/server/runner.js +163 -0
  211. package/dist/server/src/services/client-tracker.service.d.ts +132 -0
  212. package/dist/server/src/services/client-tracker.service.d.ts.map +1 -0
  213. package/dist/server/src/services/client-tracker.service.js +203 -0
  214. package/dist/server/src/services/connection/connection-manager.d.ts +478 -0
  215. package/dist/server/src/services/connection/connection-manager.d.ts.map +1 -0
  216. package/dist/server/src/services/connection/connection-manager.js +929 -0
  217. package/dist/server/src/services/connection/index.d.ts +6 -0
  218. package/dist/server/src/services/connection/index.d.ts.map +1 -0
  219. package/dist/server/src/services/connection/index.js +4 -0
  220. package/dist/server/src/services/connection/tool-cache.d.ts +122 -0
  221. package/dist/server/src/services/connection/tool-cache.d.ts.map +1 -0
  222. package/dist/server/src/services/connection/tool-cache.js +202 -0
  223. package/dist/server/src/services/connection/types.d.ts +30 -0
  224. package/dist/server/src/services/connection/types.d.ts.map +1 -0
  225. package/dist/server/src/services/connection/types.js +1 -0
  226. package/dist/server/src/services/event-bus.service.d.ts +169 -0
  227. package/dist/server/src/services/event-bus.service.d.ts.map +1 -0
  228. package/dist/server/src/services/event-bus.service.js +200 -0
  229. package/dist/server/src/services/gateway/gateway.service.d.ts +61 -0
  230. package/dist/server/src/services/gateway/gateway.service.d.ts.map +1 -0
  231. package/dist/server/src/services/gateway/gateway.service.js +107 -0
  232. package/dist/server/src/services/gateway/index.d.ts +8 -0
  233. package/dist/server/src/services/gateway/index.d.ts.map +1 -0
  234. package/dist/server/src/services/gateway/index.js +6 -0
  235. package/dist/server/src/services/gateway/log-formatter.d.ts +26 -0
  236. package/dist/server/src/services/gateway/log-formatter.d.ts.map +1 -0
  237. package/dist/server/src/services/gateway/log-formatter.js +66 -0
  238. package/dist/server/src/services/gateway/request-handlers/call-tool-handler.d.ts +13 -0
  239. package/dist/server/src/services/gateway/request-handlers/call-tool-handler.d.ts.map +1 -0
  240. package/dist/server/src/services/gateway/request-handlers/call-tool-handler.js +131 -0
  241. package/dist/server/src/services/gateway/request-handlers/index.d.ts +9 -0
  242. package/dist/server/src/services/gateway/request-handlers/index.d.ts.map +1 -0
  243. package/dist/server/src/services/gateway/request-handlers/index.js +8 -0
  244. package/dist/server/src/services/gateway/request-handlers/initialize-handler.d.ts +11 -0
  245. package/dist/server/src/services/gateway/request-handlers/initialize-handler.d.ts.map +1 -0
  246. package/dist/server/src/services/gateway/request-handlers/initialize-handler.js +85 -0
  247. package/dist/server/src/services/gateway/request-handlers/resources-handler.d.ts +11 -0
  248. package/dist/server/src/services/gateway/request-handlers/resources-handler.d.ts.map +1 -0
  249. package/dist/server/src/services/gateway/request-handlers/resources-handler.js +56 -0
  250. package/dist/server/src/services/gateway/request-handlers/system-tools-handler.d.ts +11 -0
  251. package/dist/server/src/services/gateway/request-handlers/system-tools-handler.d.ts.map +1 -0
  252. package/dist/server/src/services/gateway/request-handlers/system-tools-handler.js +228 -0
  253. package/dist/server/src/services/gateway/request-handlers/tools-handler.d.ts +11 -0
  254. package/dist/server/src/services/gateway/request-handlers/tools-handler.d.ts.map +1 -0
  255. package/dist/server/src/services/gateway/request-handlers/tools-handler.js +79 -0
  256. package/dist/server/src/services/gateway/tool-list-generator.d.ts +23 -0
  257. package/dist/server/src/services/gateway/tool-list-generator.d.ts.map +1 -0
  258. package/dist/server/src/services/gateway/tool-list-generator.js +115 -0
  259. package/dist/server/src/services/gateway/types.d.ts +27 -0
  260. package/dist/server/src/services/gateway/types.d.ts.map +1 -0
  261. package/dist/server/src/services/gateway/types.js +4 -0
  262. package/dist/server/src/services/gateway.service.d.ts +7 -0
  263. package/dist/server/src/services/gateway.service.d.ts.map +1 -0
  264. package/dist/server/src/services/gateway.service.js +6 -0
  265. package/dist/server/src/services/hub-manager.service.d.ts +299 -0
  266. package/dist/server/src/services/hub-manager.service.d.ts.map +1 -0
  267. package/dist/server/src/services/hub-manager.service.js +413 -0
  268. package/dist/server/src/services/hub-tools/index.d.ts +10 -0
  269. package/dist/server/src/services/hub-tools/index.d.ts.map +1 -0
  270. package/dist/server/src/services/hub-tools/index.js +6 -0
  271. package/dist/server/src/services/hub-tools/resource-generator.d.ts +63 -0
  272. package/dist/server/src/services/hub-tools/resource-generator.d.ts.map +1 -0
  273. package/dist/server/src/services/hub-tools/resource-generator.js +141 -0
  274. package/dist/server/src/services/hub-tools/server-selector.d.ts +63 -0
  275. package/dist/server/src/services/hub-tools/server-selector.d.ts.map +1 -0
  276. package/dist/server/src/services/hub-tools/server-selector.js +108 -0
  277. package/dist/server/src/services/hub-tools/system-tool-definitions.d.ts +47 -0
  278. package/dist/server/src/services/hub-tools/system-tool-definitions.d.ts.map +1 -0
  279. package/dist/server/src/services/hub-tools/system-tool-definitions.js +225 -0
  280. package/dist/server/src/services/hub-tools/tool-search.d.ts +85 -0
  281. package/dist/server/src/services/hub-tools/tool-search.d.ts.map +1 -0
  282. package/dist/server/src/services/hub-tools/tool-search.js +115 -0
  283. package/dist/server/src/services/hub-tools/types.d.ts +42 -0
  284. package/dist/server/src/services/hub-tools/types.d.ts.map +1 -0
  285. package/dist/server/src/services/hub-tools/types.js +1 -0
  286. package/dist/server/src/services/hub-tools.service.d.ts +235 -0
  287. package/dist/server/src/services/hub-tools.service.d.ts.map +1 -0
  288. package/dist/server/src/services/hub-tools.service.js +457 -0
  289. package/dist/server/src/services/log-storage.service.d.ts +177 -0
  290. package/dist/server/src/services/log-storage.service.d.ts.map +1 -0
  291. package/dist/server/src/services/log-storage.service.js +243 -0
  292. package/dist/server/src/services/mcp-connection-manager.d.ts +7 -0
  293. package/dist/server/src/services/mcp-connection-manager.d.ts.map +1 -0
  294. package/dist/server/src/services/mcp-connection-manager.js +6 -0
  295. package/dist/server/src/services/mcp-session-manager.d.ts +6 -0
  296. package/dist/server/src/services/mcp-session-manager.d.ts.map +1 -0
  297. package/dist/server/src/services/mcp-session-manager.js +4 -0
  298. package/dist/server/src/services/search/index.d.ts +5 -0
  299. package/dist/server/src/services/search/index.d.ts.map +1 -0
  300. package/dist/server/src/services/search/index.js +5 -0
  301. package/dist/server/src/services/search/search-cache.d.ts +132 -0
  302. package/dist/server/src/services/search/search-cache.d.ts.map +1 -0
  303. package/dist/server/src/services/search/search-cache.js +151 -0
  304. package/dist/server/src/services/search/search-core.service.d.ts +108 -0
  305. package/dist/server/src/services/search/search-core.service.d.ts.map +1 -0
  306. package/dist/server/src/services/search/search-core.service.js +187 -0
  307. package/dist/server/src/services/search/search-scorer.d.ts +54 -0
  308. package/dist/server/src/services/search/search-scorer.d.ts.map +1 -0
  309. package/dist/server/src/services/search/search-scorer.js +83 -0
  310. package/dist/server/src/services/search/types.d.ts +20 -0
  311. package/dist/server/src/services/search/types.d.ts.map +1 -0
  312. package/dist/server/src/services/search/types.js +1 -0
  313. package/dist/server/src/services/session/index.d.ts +6 -0
  314. package/dist/server/src/services/session/index.d.ts.map +1 -0
  315. package/dist/server/src/services/session/index.js +4 -0
  316. package/dist/server/src/services/session/session-manager.d.ts +352 -0
  317. package/dist/server/src/services/session/session-manager.d.ts.map +1 -0
  318. package/dist/server/src/services/session/session-manager.js +835 -0
  319. package/dist/server/src/services/session/types.d.ts +32 -0
  320. package/dist/server/src/services/session/types.d.ts.map +1 -0
  321. package/dist/server/src/services/session/types.js +1 -0
  322. package/dist/server/src/services/simple-search.service.d.ts +67 -0
  323. package/dist/server/src/services/simple-search.service.d.ts.map +1 -0
  324. package/dist/server/src/services/simple-search.service.js +82 -0
  325. package/dist/server/src/services/system-tool-handler.d.ts +10 -0
  326. package/dist/server/src/services/system-tool-handler.d.ts.map +1 -0
  327. package/dist/server/src/services/system-tool-handler.js +77 -0
  328. package/dist/server/src/utils/error-handler.d.ts +18 -0
  329. package/dist/server/src/utils/error-handler.d.ts.map +1 -0
  330. package/dist/server/src/utils/error-handler.js +59 -0
  331. package/dist/server/src/utils/format-utils.d.ts +23 -0
  332. package/dist/server/src/utils/format-utils.d.ts.map +1 -0
  333. package/dist/server/src/utils/format-utils.js +58 -0
  334. package/dist/server/src/utils/index.d.ts +2 -0
  335. package/dist/server/src/utils/index.d.ts.map +1 -0
  336. package/dist/server/src/utils/index.js +1 -0
  337. package/dist/server/src/utils/json-utils.d.ts +82 -0
  338. package/dist/server/src/utils/json-utils.d.ts.map +1 -0
  339. package/dist/server/src/utils/json-utils.js +204 -0
  340. package/dist/server/src/utils/log-rotator.d.ts +223 -0
  341. package/dist/server/src/utils/log-rotator.d.ts.map +1 -0
  342. package/dist/server/src/utils/log-rotator.js +306 -0
  343. package/dist/server/src/utils/logger/dev-logger.d.ts +39 -0
  344. package/dist/server/src/utils/logger/dev-logger.d.ts.map +1 -0
  345. package/dist/server/src/utils/logger/dev-logger.js +63 -0
  346. package/dist/server/src/utils/logger/index.d.ts +36 -0
  347. package/dist/server/src/utils/logger/index.d.ts.map +1 -0
  348. package/dist/server/src/utils/logger/index.js +46 -0
  349. package/dist/server/src/utils/logger/log-colors.d.ts +27 -0
  350. package/dist/server/src/utils/logger/log-colors.d.ts.map +1 -0
  351. package/dist/server/src/utils/logger/log-colors.js +41 -0
  352. package/dist/server/src/utils/logger/log-context.d.ts +13 -0
  353. package/dist/server/src/utils/logger/log-context.d.ts.map +1 -0
  354. package/dist/server/src/utils/logger/log-context.js +5 -0
  355. package/dist/server/src/utils/logger/log-formatter.d.ts +47 -0
  356. package/dist/server/src/utils/logger/log-formatter.d.ts.map +1 -0
  357. package/dist/server/src/utils/logger/log-formatter.js +150 -0
  358. package/dist/server/src/utils/logger/log-modules.d.ts +141 -0
  359. package/dist/server/src/utils/logger/log-modules.d.ts.map +1 -0
  360. package/dist/server/src/utils/logger/log-modules.js +81 -0
  361. package/dist/server/src/utils/logger/log-output.d.ts +68 -0
  362. package/dist/server/src/utils/logger/log-output.d.ts.map +1 -0
  363. package/dist/server/src/utils/logger/log-output.js +320 -0
  364. package/dist/server/src/utils/logger/logger.d.ts +190 -0
  365. package/dist/server/src/utils/logger/logger.d.ts.map +1 -0
  366. package/dist/server/src/utils/logger/logger.js +350 -0
  367. package/dist/server/src/utils/logger.d.ts +12 -0
  368. package/dist/server/src/utils/logger.d.ts.map +1 -0
  369. package/dist/server/src/utils/logger.js +12 -0
  370. package/dist/server/src/utils/mcp-error-handler.d.ts +162 -0
  371. package/dist/server/src/utils/mcp-error-handler.d.ts.map +1 -0
  372. package/dist/server/src/utils/mcp-error-handler.js +270 -0
  373. package/dist/server/src/utils/port-checker.d.ts +16 -0
  374. package/dist/server/src/utils/port-checker.d.ts.map +1 -0
  375. package/dist/server/src/utils/port-checker.js +242 -0
  376. package/dist/server/src/utils/request-context.d.ts +71 -0
  377. package/dist/server/src/utils/request-context.d.ts.map +1 -0
  378. package/dist/server/src/utils/request-context.js +73 -0
  379. package/dist/server/src/utils/tool-args-parser.d.ts +17 -0
  380. package/dist/server/src/utils/tool-args-parser.d.ts.map +1 -0
  381. package/dist/server/src/utils/tool-args-parser.js +34 -0
  382. package/dist/server/src/utils/transports/sse-transport.d.ts +104 -0
  383. package/dist/server/src/utils/transports/sse-transport.d.ts.map +1 -0
  384. package/dist/server/src/utils/transports/sse-transport.js +189 -0
  385. package/dist/server/src/utils/transports/stdio-transport.d.ts +122 -0
  386. package/dist/server/src/utils/transports/stdio-transport.d.ts.map +1 -0
  387. package/dist/server/src/utils/transports/stdio-transport.js +324 -0
  388. package/dist/server/src/utils/transports/streamable-http-transport.d.ts +146 -0
  389. package/dist/server/src/utils/transports/streamable-http-transport.d.ts.map +1 -0
  390. package/dist/server/src/utils/transports/streamable-http-transport.js +212 -0
  391. package/dist/server/src/utils/transports/transport-factory.d.ts +26 -0
  392. package/dist/server/src/utils/transports/transport-factory.d.ts.map +1 -0
  393. package/dist/server/src/utils/transports/transport-factory.js +104 -0
  394. package/dist/server/src/utils/transports/transport.interface.d.ts +35 -0
  395. package/dist/server/src/utils/transports/transport.interface.d.ts.map +1 -0
  396. package/dist/server/src/utils/transports/transport.interface.js +1 -0
  397. package/dist/server/tests/contract/mcp-protocol/initialize.test.d.ts +2 -0
  398. package/dist/server/tests/contract/mcp-protocol/initialize.test.d.ts.map +1 -0
  399. package/dist/server/tests/contract/mcp-protocol/initialize.test.js +103 -0
  400. package/dist/server/tests/contract/mcp-protocol/tools-call.test.d.ts +2 -0
  401. package/dist/server/tests/contract/mcp-protocol/tools-call.test.d.ts.map +1 -0
  402. package/dist/server/tests/contract/mcp-protocol/tools-call.test.js +181 -0
  403. package/dist/server/tests/contract/mcp-protocol/tools-list.test.d.ts +2 -0
  404. package/dist/server/tests/contract/mcp-protocol/tools-list.test.d.ts.map +1 -0
  405. package/dist/server/tests/contract/mcp-protocol/tools-list.test.js +155 -0
  406. package/dist/server/tests/evaluation/evaluation.test.d.ts +2 -0
  407. package/dist/server/tests/evaluation/evaluation.test.d.ts.map +1 -0
  408. package/dist/server/tests/evaluation/evaluation.test.js +102 -0
  409. package/dist/server/tests/helpers/sdk-test-helpers.d.ts +32 -0
  410. package/dist/server/tests/helpers/sdk-test-helpers.d.ts.map +1 -0
  411. package/dist/server/tests/helpers/sdk-test-helpers.js +82 -0
  412. package/dist/server/tests/integration/api/gateway.test.d.ts +2 -0
  413. package/dist/server/tests/integration/api/gateway.test.d.ts.map +1 -0
  414. package/dist/server/tests/integration/api/gateway.test.js +366 -0
  415. package/dist/server/tests/integration/gateway/fault-tolerance.test.d.ts +2 -0
  416. package/dist/server/tests/integration/gateway/fault-tolerance.test.d.ts.map +1 -0
  417. package/dist/server/tests/integration/gateway/fault-tolerance.test.js +109 -0
  418. package/dist/server/tests/integration/gateway/mcp-connection.test.d.ts +2 -0
  419. package/dist/server/tests/integration/gateway/mcp-connection.test.d.ts.map +1 -0
  420. package/dist/server/tests/integration/gateway/mcp-connection.test.js +149 -0
  421. package/dist/server/tests/server.test.d.ts +2 -0
  422. package/dist/server/tests/server.test.d.ts.map +1 -0
  423. package/dist/server/tests/server.test.js +95 -0
  424. package/dist/server/tests/setup.d.ts +7 -0
  425. package/dist/server/tests/setup.d.ts.map +1 -0
  426. package/dist/server/tests/setup.js +53 -0
  427. package/dist/server/tests/types/logger-test-helpers.d.ts +17 -0
  428. package/dist/server/tests/types/logger-test-helpers.d.ts.map +1 -0
  429. package/dist/server/tests/types/logger-test-helpers.js +4 -0
  430. package/dist/server/tests/types/test-helpers.d.ts +27 -0
  431. package/dist/server/tests/types/test-helpers.d.ts.map +1 -0
  432. package/dist/server/tests/types/test-helpers.js +4 -0
  433. package/dist/server/tests/unit/cli/basic-cli.test.d.ts +2 -0
  434. package/dist/server/tests/unit/cli/basic-cli.test.d.ts.map +1 -0
  435. package/dist/server/tests/unit/cli/basic-cli.test.js +33 -0
  436. package/dist/server/tests/unit/cli/cli.test.d.ts +2 -0
  437. package/dist/server/tests/unit/cli/cli.test.d.ts.map +1 -0
  438. package/dist/server/tests/unit/cli/cli.test.js +17 -0
  439. package/dist/server/tests/unit/cli/commands.test.d.ts +2 -0
  440. package/dist/server/tests/unit/cli/commands.test.d.ts.map +1 -0
  441. package/dist/server/tests/unit/cli/commands.test.js +75 -0
  442. package/dist/server/tests/unit/cli/server.test.d.ts +2 -0
  443. package/dist/server/tests/unit/cli/server.test.d.ts.map +1 -0
  444. package/dist/server/tests/unit/cli/server.test.js +68 -0
  445. package/dist/server/tests/unit/server/runner.test.d.ts +2 -0
  446. package/dist/server/tests/unit/server/runner.test.d.ts.map +1 -0
  447. package/dist/server/tests/unit/server/runner.test.js +488 -0
  448. package/dist/server/tests/unit/server/setup.d.ts +2 -0
  449. package/dist/server/tests/unit/server/setup.d.ts.map +1 -0
  450. package/dist/server/tests/unit/server/setup.js +21 -0
  451. package/dist/server/tests/unit/services/gateway-logging.test.d.ts +2 -0
  452. package/dist/server/tests/unit/services/gateway-logging.test.d.ts.map +1 -0
  453. package/dist/server/tests/unit/services/gateway-logging.test.js +47 -0
  454. package/dist/server/tests/unit/services/hub-manager-service.test.d.ts +2 -0
  455. package/dist/server/tests/unit/services/hub-manager-service.test.d.ts.map +1 -0
  456. package/dist/server/tests/unit/services/hub-manager-service.test.js +140 -0
  457. package/dist/server/tests/unit/services/hub-manager.test.d.ts +2 -0
  458. package/dist/server/tests/unit/services/hub-manager.test.d.ts.map +1 -0
  459. package/dist/server/tests/unit/services/hub-manager.test.js +98 -0
  460. package/dist/server/tests/unit/services/hub-tools.service.test.d.ts +2 -0
  461. package/dist/server/tests/unit/services/hub-tools.service.test.d.ts.map +1 -0
  462. package/dist/server/tests/unit/services/hub-tools.service.test.js +674 -0
  463. package/dist/server/tests/unit/services/search/search-cache.test.d.ts +2 -0
  464. package/dist/server/tests/unit/services/search/search-cache.test.d.ts.map +1 -0
  465. package/dist/server/tests/unit/services/search/search-cache.test.js +58 -0
  466. package/dist/server/tests/unit/services/search/search-core.service.test.d.ts +2 -0
  467. package/dist/server/tests/unit/services/search/search-core.service.test.d.ts.map +1 -0
  468. package/dist/server/tests/unit/services/search/search-core.service.test.js +84 -0
  469. package/dist/server/tests/unit/services/search/search-scorer.test.d.ts +2 -0
  470. package/dist/server/tests/unit/services/search/search-scorer.test.d.ts.map +1 -0
  471. package/dist/server/tests/unit/services/search/search-scorer.test.js +97 -0
  472. package/dist/server/tests/unit/services/session-manager.test.d.ts +2 -0
  473. package/dist/server/tests/unit/services/session-manager.test.d.ts.map +1 -0
  474. package/dist/server/tests/unit/services/session-manager.test.js +481 -0
  475. package/dist/server/tests/unit/utils/config.test.d.ts +2 -0
  476. package/dist/server/tests/unit/utils/config.test.d.ts.map +1 -0
  477. package/dist/server/tests/unit/utils/config.test.js +634 -0
  478. package/dist/server/tests/unit/utils/json-utils.test.d.ts +2 -0
  479. package/dist/server/tests/unit/utils/json-utils.test.d.ts.map +1 -0
  480. package/dist/server/tests/unit/utils/json-utils.test.js +296 -0
  481. package/dist/server/tests/unit/utils/log-rotator.test.d.ts +2 -0
  482. package/dist/server/tests/unit/utils/log-rotator.test.d.ts.map +1 -0
  483. package/dist/server/tests/unit/utils/log-rotator.test.js +296 -0
  484. package/dist/server/tests/unit/utils/logger.test.d.ts +2 -0
  485. package/dist/server/tests/unit/utils/logger.test.d.ts.map +1 -0
  486. package/dist/server/tests/unit/utils/logger.test.js +462 -0
  487. package/dist/server/tests/unit/utils/mcp-error-handler.test.d.ts +2 -0
  488. package/dist/server/tests/unit/utils/mcp-error-handler.test.d.ts.map +1 -0
  489. package/dist/server/tests/unit/utils/mcp-error-handler.test.js +163 -0
  490. package/dist/server/tests/unit/utils/request-context.test.d.ts +2 -0
  491. package/dist/server/tests/unit/utils/request-context.test.d.ts.map +1 -0
  492. package/dist/server/tests/unit/utils/request-context.test.js +82 -0
  493. package/dist/server/vite.config.d.ts +3 -0
  494. package/dist/server/vite.config.d.ts.map +1 -0
  495. package/dist/server/vite.config.js +160 -0
  496. package/dist/server/vitest.config.d.ts +3 -0
  497. package/dist/server/vitest.config.d.ts.map +1 -0
  498. package/dist/server/vitest.config.js +53 -0
  499. package/package.json +113 -0
@@ -0,0 +1,102 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import fs from 'fs';
3
+ import path from 'path';
4
+ /**
5
+ * MCP Evaluation Tests - Verify the integrity and format correctness of evaluation test files
6
+ *
7
+ * These tests ensure that evaluation test files comply with the requirements of the MCP evaluation guidelines
8
+ */
9
+ describe('MCP Evaluation Tests', () => {
10
+ const evaluationFile = path.resolve(__dirname, 'evaluation.xml');
11
+ it('should have evaluation.xml file', () => {
12
+ expect(fs.existsSync(evaluationFile)).toBe(true);
13
+ });
14
+ it('should have valid XML format', () => {
15
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
16
+ expect(content).toContain('<evaluation>');
17
+ expect(content).toContain('</evaluation>');
18
+ });
19
+ it('should have exactly 10 QA pairs', () => {
20
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
21
+ const qaPairCount = (content.match(/<qa_pair>/g) || []).length;
22
+ expect(qaPairCount).toBe(10);
23
+ });
24
+ it('should have valid question and answer fields', () => {
25
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
26
+ const qaPairs = content.match(/<qa_pair>([\s\S]*?)<\/qa_pair>/g) || [];
27
+ qaPairs.forEach((qaPair) => {
28
+ expect(qaPair).toContain('<question>');
29
+ expect(qaPair).toContain('</question>');
30
+ expect(qaPair).toContain('<answer>');
31
+ expect(qaPair).toContain('</answer>');
32
+ // Check that question and answer content are not empty
33
+ const question = qaPair.match(/<question>([\s\S]*?)<\/question>/)?.[1].trim();
34
+ const answer = qaPair.match(/<answer>([\s\S]*?)<\/answer>/)?.[1].trim();
35
+ expect(question).toBeTruthy();
36
+ expect(answer).toBeTruthy();
37
+ if (question && answer) {
38
+ // Check that question length is reasonable
39
+ expect(question.length).toBeGreaterThan(10);
40
+ expect(question.length).toBeLessThan(500);
41
+ // Check that answer length is reasonable
42
+ expect(answer.length).toBeGreaterThan(10);
43
+ expect(answer.length).toBeLessThan(500);
44
+ }
45
+ });
46
+ });
47
+ it('should have independent and complex questions', () => {
48
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
49
+ const questions = (content.match(/<question>([\s\S]*?)<\/question>/g) || []).map((match) => match.replace(/<\/?question>/g, '').trim());
50
+ // Check if questions contain keywords that require multiple tool calls
51
+ const complexQuestionIndicators = [
52
+ 'List',
53
+ 'Count',
54
+ 'Find',
55
+ 'Get',
56
+ 'Distributed',
57
+ 'Calculate',
58
+ 'Group',
59
+ 'Total number',
60
+ 'Average',
61
+ 'Filter'
62
+ ];
63
+ questions.forEach((question, index) => {
64
+ const hasComplexIndicator = complexQuestionIndicators.some((indicator) => question.includes(indicator));
65
+ expect(hasComplexIndicator, `Question ${index + 1} does not appear to be complex enough: "${question}"`).toBe(true);
66
+ });
67
+ });
68
+ it('should have read-only operations', () => {
69
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
70
+ const answers = (content.match(/<answer>([\s\S]*?)<\/answer>/g) || []).map((match) => match.replace(/<\/?answer>/g, '').trim());
71
+ // Check if answers contain keywords for destructive operations
72
+ const destructiveIndicators = [
73
+ 'Create',
74
+ 'Delete',
75
+ 'Update',
76
+ 'Modify',
77
+ 'Add',
78
+ 'Remove',
79
+ 'Execute',
80
+ 'Run'
81
+ ];
82
+ answers.forEach((answer, index) => {
83
+ const hasDestructiveIndicator = destructiveIndicators.some((indicator) => answer.includes(indicator));
84
+ expect(hasDestructiveIndicator, `Answer ${index + 1} may contain destructive operations: "${answer}"`).toBe(false);
85
+ });
86
+ });
87
+ it('should reference valid tools', () => {
88
+ const validTools = [
89
+ 'list-servers',
90
+ 'find-servers',
91
+ 'list-all-tools-in-server',
92
+ 'find-tools-in-server',
93
+ 'get-tool',
94
+ 'call-tool',
95
+ 'find-tools'
96
+ ];
97
+ const content = fs.readFileSync(evaluationFile, 'utf-8');
98
+ validTools.forEach((tool) => {
99
+ expect(content).toContain(tool);
100
+ });
101
+ });
102
+ });
@@ -0,0 +1,32 @@
1
+ /**
2
+ * Create a mock MCP server for testing
3
+ */
4
+ export declare class MockMcpServer {
5
+ private config;
6
+ private server;
7
+ constructor(config: {
8
+ name: string;
9
+ version: string;
10
+ tools?: Array<{
11
+ name: string;
12
+ description?: string;
13
+ inputSchema?: unknown;
14
+ handler: (args: unknown) => Promise<unknown>;
15
+ }>;
16
+ });
17
+ private setupHandlers;
18
+ getConnectConfig(): {
19
+ command: string;
20
+ args: string[];
21
+ type: "stdio";
22
+ };
23
+ private getServerScript;
24
+ }
25
+ /**
26
+ * In-memory test server using memory transport
27
+ * More efficient, no need to spawn child processes
28
+ */
29
+ export declare class InMemoryMcpServer {
30
+ constructor();
31
+ }
32
+ //# sourceMappingURL=sdk-test-helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sdk-test-helpers.d.ts","sourceRoot":"","sources":["../../../../tests/helpers/sdk-test-helpers.ts"],"names":[],"mappings":"AAGA;;GAEG;AACH,qBAAa,aAAa;IAItB,OAAO,CAAC,MAAM;IAHhB,OAAO,CAAC,MAAM,CAAY;gBAGhB,MAAM,EAAE;QACd,IAAI,EAAE,MAAM,CAAC;QACb,OAAO,EAAE,MAAM,CAAC;QAChB,KAAK,CAAC,EAAE,KAAK,CAAC;YACZ,IAAI,EAAE,MAAM,CAAC;YACb,WAAW,CAAC,EAAE,MAAM,CAAC;YACrB,WAAW,CAAC,EAAE,OAAO,CAAC;YACtB,OAAO,EAAE,CAAC,IAAI,EAAE,OAAO,KAAK,OAAO,CAAC,OAAO,CAAC,CAAC;SAC9C,CAAC,CAAC;KACJ;IAUH,OAAO,CAAC,aAAa;IAgDrB,gBAAgB;;;;;IAShB,OAAO,CAAC,eAAe;CAOxB;AAED;;;GAGG;AACH,qBAAa,iBAAiB;;CAI7B"}
@@ -0,0 +1,82 @@
1
+ import { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';
2
+ /**
3
+ * Create a mock MCP server for testing
4
+ */
5
+ export class MockMcpServer {
6
+ config;
7
+ server;
8
+ constructor(config) {
9
+ this.config = config;
10
+ this.server = new McpServer({ name: config.name, version: config.version }, { capabilities: { tools: {} } });
11
+ this.setupHandlers();
12
+ }
13
+ setupHandlers() {
14
+ // Register handler for each tool
15
+ if (this.config.tools) {
16
+ for (const tool of this.config.tools) {
17
+ const schema = {
18
+ method: 'tools/call',
19
+ params: {
20
+ name: tool.name,
21
+ arguments: tool.inputSchema || {}
22
+ },
23
+ id: '1',
24
+ jsonrpc: '2.0'
25
+ };
26
+ // @ts-expect-error - Test helper schema doesn't need full type safety
27
+ this.server.server.setRequestHandler(schema, async (request) => {
28
+ // Safely extract arguments from request params
29
+ let args = undefined;
30
+ if (request.params &&
31
+ typeof request.params === 'object' &&
32
+ 'arguments' in request.params) {
33
+ args = request.params.arguments;
34
+ }
35
+ const result = await tool.handler(args);
36
+ // For test purposes, wrap the result in a valid CallToolResult structure
37
+ if (typeof result === 'object' && result !== null) {
38
+ return {
39
+ content: [],
40
+ ...result
41
+ };
42
+ }
43
+ else {
44
+ return {
45
+ content: [
46
+ {
47
+ type: 'text',
48
+ text: String(result)
49
+ }
50
+ ]
51
+ };
52
+ }
53
+ });
54
+ }
55
+ }
56
+ }
57
+ // Get connection configuration
58
+ getConnectConfig() {
59
+ return {
60
+ command: 'node',
61
+ args: ['-e', this.getServerScript()],
62
+ type: 'stdio'
63
+ };
64
+ }
65
+ // Generate executable server script
66
+ getServerScript() {
67
+ // Return an inline MCP server script
68
+ // Using SDK's StdioServerTransport
69
+ return `
70
+ // Inline server code...
71
+ `;
72
+ }
73
+ }
74
+ /**
75
+ * In-memory test server using memory transport
76
+ * More efficient, no need to spawn child processes
77
+ */
78
+ export class InMemoryMcpServer {
79
+ constructor() {
80
+ // Memory transport not implemented yet
81
+ }
82
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=gateway.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"gateway.test.d.ts","sourceRoot":"","sources":["../../../../../tests/integration/api/gateway.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,366 @@
1
+ import { describe, it, expect, vi, beforeEach } from 'vitest';
2
+ // Define mocks first
3
+ const mocks = vi.hoisted(() => {
4
+ const mockToolCache = new Map();
5
+ return {
6
+ setRequestHandler: vi.fn(),
7
+ setNotificationHandler: vi.fn(),
8
+ request: vi.fn(),
9
+ connect: vi.fn(),
10
+ getAllTools: vi.fn(),
11
+ callTool: vi.fn(),
12
+ getServerById: vi.fn(),
13
+ listAllToolsInServer: vi.fn(),
14
+ findToolsInServer: vi.fn(),
15
+ getTool: vi.fn(),
16
+ callToolDirect: vi.fn(),
17
+ listAllTools: vi.fn(),
18
+ findTools: vi.fn(),
19
+ listServers: vi.fn(),
20
+ findServers: vi.fn(),
21
+ getSystemTools: vi.fn().mockReturnValue([]),
22
+ updateClientRoots: vi.fn(),
23
+ getClientContext: vi.fn().mockReturnValue({ sessionId: 'test-session' }),
24
+ mockToolCache
25
+ };
26
+ });
27
+ // Mock dependencies
28
+ vi.mock('@services/client-tracker.service.js', () => ({
29
+ clientTrackerService: {
30
+ updateClientRoots: mocks.updateClientRoots,
31
+ getClients: vi.fn().mockReturnValue([])
32
+ }
33
+ }));
34
+ vi.mock('@utils/request-context.js', () => ({
35
+ getClientContext: mocks.getClientContext,
36
+ getClientCwd: vi.fn()
37
+ }));
38
+ vi.mock('@utils/logger.js', () => ({
39
+ logger: {
40
+ info: vi.fn(),
41
+ warn: vi.fn(),
42
+ error: vi.fn(),
43
+ debug: vi.fn()
44
+ },
45
+ LOG_MODULES: {
46
+ SYSTEM_TOOL: { module: 'SystemTool' },
47
+ GATEWAY: { module: 'Gateway' }
48
+ }
49
+ }));
50
+ vi.mock('@services/mcp-connection-manager.js', () => ({
51
+ mcpConnectionManager: {
52
+ getAllTools: mocks.getAllTools,
53
+ callTool: mocks.callTool,
54
+ toolCache: mocks.mockToolCache,
55
+ // Add method to access the mock toolCache
56
+ getToolCache: () => mocks.mockToolCache
57
+ }
58
+ }));
59
+ vi.mock('@services/hub-manager.service.js', () => ({
60
+ hubManager: {
61
+ getServerById: mocks.getServerById,
62
+ getAllServers: vi.fn().mockReturnValue([{ id: 'server1', name: 'Test Server' }])
63
+ }
64
+ }));
65
+ vi.mock('@services/hub-tools.service.js', () => ({
66
+ hubToolsService: {
67
+ listAllToolsInServer: mocks.listAllToolsInServer,
68
+ findToolsInServer: mocks.findToolsInServer,
69
+ getTool: mocks.getTool,
70
+ callTool: mocks.callToolDirect,
71
+ listAllTools: mocks.listAllTools,
72
+ findTools: mocks.findTools,
73
+ listServers: mocks.listServers,
74
+ findServers: mocks.findServers,
75
+ getSystemTools: mocks.getSystemTools
76
+ }
77
+ }));
78
+ vi.mock('@modelcontextprotocol/sdk/server/mcp.js', () => {
79
+ return {
80
+ McpServer: class {
81
+ server = {
82
+ setRequestHandler: mocks.setRequestHandler,
83
+ setNotificationHandler: mocks.setNotificationHandler,
84
+ request: mocks.request
85
+ };
86
+ connect = mocks.connect;
87
+ }
88
+ };
89
+ });
90
+ vi.mock('@modelcontextprotocol/sdk/server/stdio.js', () => {
91
+ return {
92
+ StdioServerTransport: class {
93
+ }
94
+ };
95
+ });
96
+ // Import after mocks
97
+ import { GatewayService } from '../../../src/services/gateway.service.js';
98
+ describe('GatewayService', () => {
99
+ beforeEach(() => {
100
+ vi.clearAllMocks();
101
+ new GatewayService();
102
+ });
103
+ it('should register handlers on initialization', () => {
104
+ // Check call arguments by type (zod schema)
105
+ const calls = mocks.setRequestHandler.mock.calls;
106
+ // We now register multiple handlers: initialize, ping, search, list servers, find servers, etc.
107
+ expect(calls.length).toBeGreaterThanOrEqual(10);
108
+ });
109
+ it('should list tools with prefixed names', async () => {
110
+ // Setup mock data
111
+ const mockTools = [
112
+ { name: 'testTool', description: 'desc', inputSchema: {}, serverId: 'server1' }
113
+ ];
114
+ vi.mocked(mocks.getAllTools).mockReturnValue(mockTools);
115
+ vi.mocked(mocks.getServerById).mockReturnValue({
116
+ name: 'Test Server',
117
+ id: 'server1',
118
+ config: { allowedTools: ['testTool'] },
119
+ instance: { id: 'server1', timestamp: Date.now(), hash: 'abc123' }
120
+ });
121
+ // Populate toolCache for the test
122
+ mocks.mockToolCache.set('server1', mockTools);
123
+ // Find the registered handler for ListTools
124
+ // We can identify ListTools handler by checking if the schema has 'method' literal 'tools/list'
125
+ // Since ListToolsRequestSchema is from @modelcontextprotocol/sdk, we can stringify schemas for comparison
126
+ let listToolsHandler;
127
+ for (const call of mocks.setRequestHandler.mock.calls) {
128
+ const schema = call[0];
129
+ const handler = call[1];
130
+ // Convert schema to string for identification
131
+ const schemaStr = JSON.stringify(schema);
132
+ // Look for schema that has the method: 'tools/list' which is characteristic of ListTools
133
+ if (schemaStr.includes('"tools/list"')) {
134
+ listToolsHandler = handler;
135
+ break;
136
+ }
137
+ }
138
+ expect(listToolsHandler).toBeDefined();
139
+ const result = await listToolsHandler({
140
+ params: {},
141
+ id: 'test-id',
142
+ jsonrpc: '2.0',
143
+ method: 'tools/list'
144
+ });
145
+ // We expect 1 tool: 1 from mockTools
146
+ // The name should be 'testTool' because it's unique
147
+ expect(result.tools).toHaveLength(1);
148
+ const testTool = result.tools.find((t) => t.name === 'testTool');
149
+ expect(testTool).toBeDefined();
150
+ expect(testTool.description).toContain('[From Test Server]');
151
+ });
152
+ it('should route callTool to correct server', async () => {
153
+ // Setup mock data for mapping (simulate listTools call first)
154
+ const mockTools = [
155
+ { name: 'testTool', description: 'desc', inputSchema: {}, serverId: 'server1' }
156
+ ];
157
+ vi.mocked(mocks.getAllTools).mockReturnValue(mockTools);
158
+ vi.mocked(mocks.getServerById).mockReturnValue({
159
+ name: 'Test Server',
160
+ id: 'server1',
161
+ config: { allowedTools: ['testTool'] },
162
+ instance: { id: 'server1', timestamp: Date.now(), hash: 'abc123' }
163
+ });
164
+ // Find list tools handler to populate tool map
165
+ let listToolsHandler;
166
+ for (const call of mocks.setRequestHandler.mock.calls) {
167
+ const schemaStr = JSON.stringify(call[0]);
168
+ if (schemaStr.includes('"tools/list"')) {
169
+ listToolsHandler = call[1];
170
+ break;
171
+ }
172
+ }
173
+ expect(listToolsHandler).toBeDefined();
174
+ await listToolsHandler({
175
+ params: {},
176
+ id: 'test-id',
177
+ jsonrpc: '2.0',
178
+ method: 'tools/list'
179
+ }); // This populates the internal map
180
+ // Find call tool handler by checking if schema has 'method' literal 'tools/call'
181
+ let callToolHandler;
182
+ for (const call of mocks.setRequestHandler.mock.calls) {
183
+ const schemaStr = JSON.stringify(call[0]);
184
+ if (schemaStr.includes('"tools/call"')) {
185
+ callToolHandler = call[1];
186
+ break;
187
+ }
188
+ }
189
+ expect(callToolHandler).toBeDefined();
190
+ vi.mocked(mocks.callTool).mockResolvedValue({ content: [] });
191
+ // Use the correct tool name (testTool)
192
+ await callToolHandler({
193
+ params: {
194
+ name: 'testTool',
195
+ arguments: { arg: 1 }
196
+ },
197
+ id: 'test-id',
198
+ jsonrpc: '2.0',
199
+ method: 'tools/call'
200
+ });
201
+ expect(mocks.callTool).toHaveBeenCalledWith('server1', 'testTool', { arg: 1 });
202
+ });
203
+ it('should list system tools', async () => {
204
+ // Setup mock data
205
+ const mockTools = [];
206
+ vi.mocked(mocks.getAllTools).mockReturnValue(mockTools);
207
+ vi.mocked(mocks.getSystemTools).mockReturnValue([
208
+ { name: 'list_servers', description: 'List all servers', inputSchema: {} },
209
+ { name: 'find_servers', description: 'Find servers matching a pattern', inputSchema: {} },
210
+ {
211
+ name: 'list_all_tools_in_server',
212
+ description: 'List all tools from a specific server',
213
+ inputSchema: {}
214
+ },
215
+ {
216
+ name: 'find_tools_in_server',
217
+ description: 'Find tools matching a pattern in a specific server',
218
+ inputSchema: {}
219
+ },
220
+ {
221
+ name: 'get_tool',
222
+ description: 'Get complete schema for a specific tool from a specific server',
223
+ inputSchema: {}
224
+ },
225
+ {
226
+ name: 'call_tool',
227
+ description: 'Call a specific tool from a specific server',
228
+ inputSchema: {}
229
+ },
230
+ {
231
+ name: 'find_tools',
232
+ description: 'Find tools matching a pattern across all connected servers',
233
+ inputSchema: {}
234
+ },
235
+ {
236
+ name: 'list_resources',
237
+ description: 'List all Hub resources (servers, tools, and resources metadata)',
238
+ inputSchema: {}
239
+ },
240
+ {
241
+ name: 'read_resource',
242
+ description: 'Read content from a specific Hub resource URI',
243
+ inputSchema: {}
244
+ }
245
+ ]);
246
+ // Clear toolCache to ensure only system tools are returned
247
+ mocks.mockToolCache.clear();
248
+ // Find list tools handler
249
+ let listToolsHandler;
250
+ for (const call of mocks.setRequestHandler.mock.calls) {
251
+ const schemaStr = JSON.stringify(call[0]);
252
+ if (schemaStr.includes('"tools/list"')) {
253
+ listToolsHandler = call[1];
254
+ break;
255
+ }
256
+ }
257
+ expect(listToolsHandler).toBeDefined();
258
+ const result = await listToolsHandler({
259
+ params: {},
260
+ id: 'test-id',
261
+ jsonrpc: '2.0',
262
+ method: 'tools/list'
263
+ });
264
+ // Expect 9 system tools
265
+ expect(result.tools).toHaveLength(9);
266
+ expect(result.tools.some((t) => t.name === 'list_servers')).toBe(true);
267
+ });
268
+ // it('should fetch roots on initialized notification', async () => {
269
+ // // Find initialized notification handler
270
+ // let initializedHandler: Function | undefined;
271
+ // for (const call of mocks.setNotificationHandler.mock.calls) {
272
+ // const schemaStr = JSON.stringify(call[0]);
273
+ // if (schemaStr.includes('"notifications/initialized"')) {
274
+ // initializedHandler = call[1];
275
+ // break;
276
+ // }
277
+ // }
278
+ // expect(initializedHandler).toBeDefined();
279
+ //
280
+ // // Mock server.request returning roots
281
+ // vi.mocked(mocks.request).mockResolvedValue({ roots: [{ uri: 'file:///test/path' }] });
282
+ //
283
+ // // Call the handler
284
+ // await initializedHandler!();
285
+ //
286
+ // // Verify request was made
287
+ // expect(mocks.request).toHaveBeenCalledWith(
288
+ // expect.objectContaining({ method: 'roots/list' }),
289
+ // expect.anything()
290
+ // );
291
+ //
292
+ // // Verify client tracker was updated
293
+ // expect(mocks.updateClientRoots).toHaveBeenCalledWith('test-session', [{ uri: 'file:///test/path' }]);
294
+ // });
295
+ it('should call system tools', async () => {
296
+ // Find call tool handler
297
+ let callToolHandler;
298
+ for (const call of mocks.setRequestHandler.mock.calls) {
299
+ const schemaStr = JSON.stringify(call[0]);
300
+ if (schemaStr.includes('"tools/call"')) {
301
+ callToolHandler = call[1];
302
+ break;
303
+ }
304
+ }
305
+ expect(callToolHandler).toBeDefined();
306
+ vi.mocked(mocks.listServers).mockResolvedValue(['server1']);
307
+ const result = await callToolHandler({
308
+ params: {
309
+ name: 'list_servers',
310
+ arguments: {}
311
+ },
312
+ id: 'test-id',
313
+ jsonrpc: '2.0',
314
+ method: 'tools/call'
315
+ });
316
+ expect(mocks.listServers).toHaveBeenCalled();
317
+ expect(result.content[0].text).toContain('server1');
318
+ });
319
+ it('should call call_tool system tool with undefined serverName', async () => {
320
+ // Find call tool handler
321
+ let callToolHandler;
322
+ for (const call of mocks.setRequestHandler.mock.calls) {
323
+ const schemaStr = JSON.stringify(call[0]);
324
+ if (schemaStr.includes('"tools/call"')) {
325
+ callToolHandler = call[1];
326
+ break;
327
+ }
328
+ }
329
+ expect(callToolHandler).toBeDefined();
330
+ // Mock the actual listServers implementation to return expected result
331
+ // Note: listServers returns server names, not server IDs
332
+ vi.mocked(mocks.listServers).mockImplementation(async () => ['Test Server']);
333
+ // Mock callToolDirect to return the expected result format
334
+ vi.mocked(mocks.callToolDirect).mockImplementation(async (args) => {
335
+ if (args.toolName === 'list_servers') {
336
+ return {
337
+ content: [
338
+ {
339
+ type: 'text',
340
+ text: JSON.stringify(['Test Server'], null, 2)
341
+ }
342
+ ]
343
+ };
344
+ }
345
+ return { content: [] };
346
+ });
347
+ const result = await callToolHandler({
348
+ params: {
349
+ name: 'call_tool',
350
+ arguments: {
351
+ serverName: undefined,
352
+ toolName: 'list_servers',
353
+ toolArgs: {}
354
+ }
355
+ },
356
+ id: 'test-id',
357
+ jsonrpc: '2.0',
358
+ method: 'tools/call'
359
+ });
360
+ // Verify the result contains the expected content
361
+ expect(result).toBeDefined();
362
+ expect(result.content).toBeDefined();
363
+ expect(result.content[0]).toBeDefined();
364
+ expect(result.content[0].text).toContain('Test Server');
365
+ });
366
+ });
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=fault-tolerance.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"fault-tolerance.test.d.ts","sourceRoot":"","sources":["../../../../../tests/integration/gateway/fault-tolerance.test.ts"],"names":[],"mappings":""}