@loop_ouroboros/mcp-hub-lite 1.0.2 → 1.1.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 (322) hide show
  1. package/CHANGELOG.md +32 -0
  2. package/dist/client/assets/{HomeView-7rMg9C6t.js → HomeView-BBwvy1oj.js} +1 -1
  3. package/dist/client/assets/ResourceDetailView-CZ2aB73w.js +1 -0
  4. package/dist/client/assets/ResourceDetailView-DUJZbegl.css +1 -0
  5. package/dist/client/assets/ResourcesView-CN1NlhWs.js +1 -0
  6. package/dist/client/assets/ResourcesView-Cc8RHtia.css +1 -0
  7. package/dist/client/assets/ServerDashboard-BfLeFDGw.css +1 -0
  8. package/dist/client/assets/ServerDashboard-k652Vw4Z.js +1 -0
  9. package/dist/client/assets/ServerDetail-BLQ-a4cO.js +2 -0
  10. package/dist/client/assets/ServerDetail-CtnNKJGx.css +1 -0
  11. package/dist/client/assets/{ServerListView-Bws09jNR.css → ServerListView-B-bPljsO.css} +1 -1
  12. package/dist/client/assets/ServerListView-BHrsFD5i.js +36 -0
  13. package/dist/client/assets/ServerStatusTags.vue_vue_type_script_setup_true_lang-BHhwEuGe.js +1 -0
  14. package/dist/client/assets/SettingsView-CUOFNXrz.js +1 -0
  15. package/dist/client/assets/SettingsView-GkBOKL0V.css +1 -0
  16. package/dist/client/assets/ToolCallDialog-BfPjLxfV.js +1 -0
  17. package/dist/client/assets/ToolsView-BxgXvPC3.css +1 -0
  18. package/dist/client/assets/ToolsView-CyuhYAE2.js +1 -0
  19. package/dist/client/assets/{_baseClone-5q1b0P3O.js → _baseClone-DO5qfalW.js} +1 -1
  20. package/dist/client/assets/el-form-item-B4LbJ6OO.css +1 -0
  21. package/dist/client/assets/el-form-item-CcGsD2K_.js +12 -0
  22. package/dist/client/assets/el-input-BH4BZKnG.css +1 -0
  23. package/dist/client/assets/el-input-tYgeiaCT.js +1 -0
  24. package/dist/client/assets/{el-loading-H85n3BUC.js → el-loading-Dwl9E_Vr.js} +1 -1
  25. package/dist/client/assets/{el-select-C0U_l4IZ.css → el-overlay-CBvdpA69.css} +1 -1
  26. package/dist/client/assets/el-overlay-kqX_BABo.js +1 -0
  27. package/dist/client/assets/{ResourceDetailView-BdOaL_-o.css → el-radio-group-B0bauIRR.css} +1 -1
  28. package/dist/client/assets/el-radio-group-D8aWBVOT.js +1 -0
  29. package/dist/client/assets/el-skeleton-item-BLY1jEuR.css +1 -0
  30. package/dist/client/assets/el-skeleton-item-BRwIFspE.js +1 -0
  31. package/dist/client/assets/el-switch-BBrS-_6y.css +1 -0
  32. package/dist/client/assets/el-switch-BF8c-xeU.js +1 -0
  33. package/dist/client/assets/el-tab-pane-C4Ep94cd.js +1 -0
  34. package/dist/client/assets/el-table-column-BdvRS9Y2.css +1 -0
  35. package/dist/client/assets/el-table-column-Cog6uCh-.js +1 -0
  36. package/dist/client/assets/index-ByNBhPAR.js +1 -0
  37. package/dist/client/assets/index-CTB6oe-9.js +2 -0
  38. package/dist/client/assets/{index-BsDWtoIl.css → index-DpH6ZSbs.css} +1 -1
  39. package/dist/client/assets/omit-CUnDT6sS.js +1 -0
  40. package/dist/client/assets/{raf-DY5mgbuB.js → raf-CmzeRPMd.js} +1 -1
  41. package/dist/client/assets/{vue-vendor-6ny5zj9i.js → vue-vendor-CbgVSHIh.js} +3 -3
  42. package/dist/client/index.html +3 -3
  43. package/dist/server/shared/models/resource.model.d.ts +2 -1
  44. package/dist/server/shared/models/resource.model.d.ts.map +1 -1
  45. package/dist/server/shared/models/server.model.d.ts +362 -5
  46. package/dist/server/shared/models/server.model.d.ts.map +1 -1
  47. package/dist/server/shared/models/server.model.js +220 -1
  48. package/dist/server/shared/models/session.model.d.ts +1 -57
  49. package/dist/server/shared/models/session.model.d.ts.map +1 -1
  50. package/dist/server/shared/models/session.model.js +1 -55
  51. package/dist/server/shared/models/tool.model.d.ts +4 -2
  52. package/dist/server/shared/models/tool.model.d.ts.map +1 -1
  53. package/dist/server/shared/types/session-context.types.d.ts +0 -2
  54. package/dist/server/shared/types/session-context.types.d.ts.map +1 -1
  55. package/dist/server/shared/types/websocket.types.d.ts +17 -10
  56. package/dist/server/shared/types/websocket.types.d.ts.map +1 -1
  57. package/dist/server/src/api/mcp/debug-response-wrapper.js +2 -2
  58. package/dist/server/src/api/mcp/gateway.d.ts +1 -3
  59. package/dist/server/src/api/mcp/gateway.d.ts.map +1 -1
  60. package/dist/server/src/api/mcp/gateway.js +32 -49
  61. package/dist/server/src/api/web/hub-tools.d.ts +2 -2
  62. package/dist/server/src/api/web/hub-tools.d.ts.map +1 -1
  63. package/dist/server/src/api/web/hub-tools.js +3 -54
  64. package/dist/server/src/api/web/mcp-status.d.ts +1 -1
  65. package/dist/server/src/api/web/mcp-status.d.ts.map +1 -1
  66. package/dist/server/src/api/web/mcp-status.js +71 -30
  67. package/dist/server/src/api/web/resources.d.ts.map +1 -1
  68. package/dist/server/src/api/web/resources.js +28 -22
  69. package/dist/server/src/api/web/search.d.ts +2 -16
  70. package/dist/server/src/api/web/search.d.ts.map +1 -1
  71. package/dist/server/src/api/web/search.js +24 -45
  72. package/dist/server/src/api/web/servers.d.ts +3 -3
  73. package/dist/server/src/api/web/servers.d.ts.map +1 -1
  74. package/dist/server/src/api/web/servers.js +70 -25
  75. package/dist/server/src/api/ws/ws-handler.d.ts.map +1 -1
  76. package/dist/server/src/api/ws/ws-handler.js +4 -2
  77. package/dist/server/src/app.d.ts.map +1 -1
  78. package/dist/server/src/app.js +0 -2
  79. package/dist/server/src/cli/commands/list.js +2 -2
  80. package/dist/server/src/cli/commands/server.d.ts +57 -0
  81. package/dist/server/src/cli/commands/server.d.ts.map +1 -0
  82. package/dist/server/src/cli/commands/server.js +169 -0
  83. package/dist/server/src/cli/commands/status.d.ts.map +1 -1
  84. package/dist/server/src/cli/commands/status.js +41 -30
  85. package/dist/server/src/cli/index.d.ts.map +1 -1
  86. package/dist/server/src/cli/index.js +2 -1
  87. package/dist/server/src/cli/server.d.ts +11 -2
  88. package/dist/server/src/cli/server.d.ts.map +1 -1
  89. package/dist/server/src/config/config-change-logger.d.ts +22 -0
  90. package/dist/server/src/config/config-change-logger.d.ts.map +1 -1
  91. package/dist/server/src/config/config-change-logger.js +135 -11
  92. package/dist/server/src/config/config-loader.d.ts +6 -5
  93. package/dist/server/src/config/config-loader.d.ts.map +1 -1
  94. package/dist/server/src/config/config-loader.js +54 -16
  95. package/dist/server/src/config/config-manager.d.ts +51 -43
  96. package/dist/server/src/config/config-manager.d.ts.map +1 -1
  97. package/dist/server/src/config/config-manager.js +84 -66
  98. package/dist/server/src/config/config-migrator.d.ts +82 -0
  99. package/dist/server/src/config/config-migrator.d.ts.map +1 -0
  100. package/dist/server/src/config/config-migrator.js +348 -0
  101. package/dist/server/src/config/config-saver.d.ts +2 -0
  102. package/dist/server/src/config/config-saver.d.ts.map +1 -1
  103. package/dist/server/src/config/config-saver.js +8 -2
  104. package/dist/server/src/config/config.schema.d.ts +10 -104
  105. package/dist/server/src/config/config.schema.d.ts.map +1 -1
  106. package/dist/server/src/config/config.schema.js +15 -99
  107. package/dist/server/src/config/path-validator.d.ts +27 -0
  108. package/dist/server/src/config/path-validator.d.ts.map +1 -0
  109. package/dist/server/src/config/path-validator.js +53 -0
  110. package/dist/server/src/config/server-config-manager.d.ts +37 -31
  111. package/dist/server/src/config/server-config-manager.d.ts.map +1 -1
  112. package/dist/server/src/config/server-config-manager.js +222 -66
  113. package/dist/server/src/config/type-converter.d.ts.map +1 -1
  114. package/dist/server/src/config/type-converter.js +3 -2
  115. package/dist/server/src/models/event.model.d.ts +17 -10
  116. package/dist/server/src/models/event.model.d.ts.map +1 -1
  117. package/dist/server/src/models/server.model.d.ts +17 -3
  118. package/dist/server/src/models/server.model.d.ts.map +1 -1
  119. package/dist/server/src/models/server.model.js +2 -1
  120. package/dist/server/src/models/system-tools.constants.d.ts +10 -27
  121. package/dist/server/src/models/system-tools.constants.d.ts.map +1 -1
  122. package/dist/server/src/models/system-tools.constants.js +4 -8
  123. package/dist/server/src/pid/manager.d.ts.map +1 -1
  124. package/dist/server/src/pid/manager.js +2 -1
  125. package/dist/server/src/server/dev-server.js +34 -20
  126. package/dist/server/src/server/runner.d.ts.map +1 -1
  127. package/dist/server/src/server/runner.js +41 -26
  128. package/dist/server/src/services/connection/connection-manager.d.ts +85 -103
  129. package/dist/server/src/services/connection/connection-manager.d.ts.map +1 -1
  130. package/dist/server/src/services/connection/connection-manager.js +286 -241
  131. package/dist/server/src/services/connection/tool-cache.d.ts +27 -25
  132. package/dist/server/src/services/connection/tool-cache.d.ts.map +1 -1
  133. package/dist/server/src/services/connection/tool-cache.js +50 -55
  134. package/dist/server/src/services/gateway/gateway.service.d.ts +2 -0
  135. package/dist/server/src/services/gateway/gateway.service.d.ts.map +1 -1
  136. package/dist/server/src/services/gateway/gateway.service.js +53 -23
  137. package/dist/server/src/services/gateway/global-transport.d.ts +19 -0
  138. package/dist/server/src/services/gateway/global-transport.d.ts.map +1 -0
  139. package/dist/server/src/services/gateway/global-transport.js +66 -0
  140. package/dist/server/src/services/gateway/request-handlers/call-tool-handler.d.ts.map +1 -1
  141. package/dist/server/src/services/gateway/request-handlers/call-tool-handler.js +67 -65
  142. package/dist/server/src/services/gateway/request-handlers/index.d.ts +1 -1
  143. package/dist/server/src/services/gateway/request-handlers/index.d.ts.map +1 -1
  144. package/dist/server/src/services/gateway/request-handlers/index.js +1 -1
  145. package/dist/server/src/services/gateway/request-handlers/initialize-handler.d.ts +1 -4
  146. package/dist/server/src/services/gateway/request-handlers/initialize-handler.d.ts.map +1 -1
  147. package/dist/server/src/services/gateway/request-handlers/initialize-handler.js +20 -80
  148. package/dist/server/src/services/gateway/request-handlers/initialize.constants.d.ts +35 -0
  149. package/dist/server/src/services/gateway/request-handlers/initialize.constants.d.ts.map +1 -0
  150. package/dist/server/src/services/gateway/request-handlers/initialize.constants.js +44 -0
  151. package/dist/server/src/services/gateway/request-handlers/resources-handler.d.ts.map +1 -1
  152. package/dist/server/src/services/gateway/request-handlers/resources-handler.js +5 -4
  153. package/dist/server/src/services/gateway/request-handlers/system-tools-handler.d.ts.map +1 -1
  154. package/dist/server/src/services/gateway/request-handlers/system-tools-handler.js +32 -77
  155. package/dist/server/src/services/gateway/tool-list-generator.d.ts.map +1 -1
  156. package/dist/server/src/services/gateway/tool-list-generator.js +37 -16
  157. package/dist/server/src/services/gateway/types.d.ts +2 -1
  158. package/dist/server/src/services/gateway/types.d.ts.map +1 -1
  159. package/dist/server/src/services/hub-manager.service.d.ts +32 -238
  160. package/dist/server/src/services/hub-manager.service.d.ts.map +1 -1
  161. package/dist/server/src/services/hub-manager.service.js +89 -267
  162. package/dist/server/src/services/hub-tools/index.d.ts +1 -3
  163. package/dist/server/src/services/hub-tools/index.d.ts.map +1 -1
  164. package/dist/server/src/services/hub-tools/index.js +1 -2
  165. package/dist/server/src/services/hub-tools/instance-matcher.d.ts +62 -0
  166. package/dist/server/src/services/hub-tools/instance-matcher.d.ts.map +1 -0
  167. package/dist/server/src/services/hub-tools/instance-matcher.js +132 -0
  168. package/dist/server/src/services/hub-tools/instance-selector.d.ts +29 -0
  169. package/dist/server/src/services/hub-tools/instance-selector.d.ts.map +1 -0
  170. package/dist/server/src/services/hub-tools/instance-selector.js +103 -0
  171. package/dist/server/src/services/hub-tools/resource-generator.d.ts +24 -1
  172. package/dist/server/src/services/hub-tools/resource-generator.d.ts.map +1 -1
  173. package/dist/server/src/services/hub-tools/resource-generator.js +259 -39
  174. package/dist/server/src/services/hub-tools/server-selector.d.ts +26 -13
  175. package/dist/server/src/services/hub-tools/server-selector.d.ts.map +1 -1
  176. package/dist/server/src/services/hub-tools/server-selector.js +44 -37
  177. package/dist/server/src/services/hub-tools/system-tool-definitions.d.ts +1 -4
  178. package/dist/server/src/services/hub-tools/system-tool-definitions.d.ts.map +1 -1
  179. package/dist/server/src/services/hub-tools/system-tool-definitions.js +17 -80
  180. package/dist/server/src/services/hub-tools/tool-search.d.ts +7 -7
  181. package/dist/server/src/services/hub-tools/tool-search.d.ts.map +1 -1
  182. package/dist/server/src/services/hub-tools/tool-search.js +10 -4
  183. package/dist/server/src/services/hub-tools/types.d.ts +2 -2
  184. package/dist/server/src/services/hub-tools/types.d.ts.map +1 -1
  185. package/dist/server/src/services/hub-tools.service.d.ts +43 -72
  186. package/dist/server/src/services/hub-tools.service.d.ts.map +1 -1
  187. package/dist/server/src/services/hub-tools.service.js +185 -110
  188. package/dist/server/src/services/system-tool-handler.d.ts.map +1 -1
  189. package/dist/server/src/services/system-tool-handler.js +7 -17
  190. package/dist/server/src/utils/composite-key.d.ts +29 -0
  191. package/dist/server/src/utils/composite-key.d.ts.map +1 -0
  192. package/dist/server/src/utils/composite-key.js +39 -0
  193. package/dist/server/src/utils/error-handler.d.ts.map +1 -1
  194. package/dist/server/src/utils/error-handler.js +3 -2
  195. package/dist/server/src/utils/index.d.ts +2 -0
  196. package/dist/server/src/utils/index.d.ts.map +1 -1
  197. package/dist/server/src/utils/index.js +2 -0
  198. package/dist/server/src/utils/instance-id.d.ts +22 -0
  199. package/dist/server/src/utils/instance-id.d.ts.map +1 -0
  200. package/dist/server/src/utils/instance-id.js +59 -0
  201. package/dist/server/src/utils/json-utils.d.ts +4 -4
  202. package/dist/server/src/utils/json-utils.d.ts.map +1 -1
  203. package/dist/server/src/utils/json-utils.js +4 -4
  204. package/dist/server/src/utils/logger/dev-logger.d.ts +2 -1
  205. package/dist/server/src/utils/logger/dev-logger.d.ts.map +1 -1
  206. package/dist/server/src/utils/logger/log-formatter.d.ts.map +1 -1
  207. package/dist/server/src/utils/logger/log-formatter.js +82 -5
  208. package/dist/server/src/utils/logger/log-modules.d.ts +15 -9
  209. package/dist/server/src/utils/logger/log-modules.d.ts.map +1 -1
  210. package/dist/server/src/utils/logger/log-modules.js +8 -6
  211. package/dist/server/src/utils/parameter-validator.d.ts +10 -0
  212. package/dist/server/src/utils/parameter-validator.d.ts.map +1 -0
  213. package/dist/server/src/utils/parameter-validator.js +53 -0
  214. package/dist/server/src/utils/process-tree.d.ts +49 -0
  215. package/dist/server/src/utils/process-tree.d.ts.map +1 -0
  216. package/dist/server/src/utils/process-tree.js +285 -0
  217. package/dist/server/src/utils/sort-utils.d.ts +40 -0
  218. package/dist/server/src/utils/sort-utils.d.ts.map +1 -0
  219. package/dist/server/src/utils/sort-utils.js +131 -0
  220. package/dist/server/src/utils/transports/sse-transport.d.ts +16 -1
  221. package/dist/server/src/utils/transports/sse-transport.d.ts.map +1 -1
  222. package/dist/server/src/utils/transports/sse-transport.js +55 -9
  223. package/dist/server/src/utils/transports/stdio-transport.d.ts +24 -53
  224. package/dist/server/src/utils/transports/stdio-transport.d.ts.map +1 -1
  225. package/dist/server/src/utils/transports/stdio-transport.js +66 -247
  226. package/dist/server/src/utils/transports/streamable-http-transport.d.ts +24 -1
  227. package/dist/server/src/utils/transports/streamable-http-transport.d.ts.map +1 -1
  228. package/dist/server/src/utils/transports/streamable-http-transport.js +68 -8
  229. package/dist/server/src/utils/transports/transport-factory.d.ts +9 -4
  230. package/dist/server/src/utils/transports/transport-factory.d.ts.map +1 -1
  231. package/dist/server/src/utils/transports/transport-factory.js +31 -11
  232. package/dist/server/src/utils/transports/transport.interface.d.ts +6 -0
  233. package/dist/server/src/utils/transports/transport.interface.d.ts.map +1 -1
  234. package/dist/server/src/utils/version.d.ts +11 -0
  235. package/dist/server/src/utils/version.d.ts.map +1 -0
  236. package/dist/server/src/utils/version.js +57 -0
  237. package/dist/server/tests/contract/mcp-protocol/initialize.test.js +24 -24
  238. package/dist/server/tests/contract/mcp-protocol/tools-call.test.js +49 -45
  239. package/dist/server/tests/contract/mcp-protocol/tools-list.test.js +35 -36
  240. package/dist/server/tests/integration/gateway/fault-tolerance.test.js +65 -25
  241. package/dist/server/tests/integration/gateway/mcp-connection.test.js +53 -61
  242. package/dist/server/tests/server.test.js +27 -16
  243. package/dist/server/tests/temp/temp-run-docling.d.ts +2 -0
  244. package/dist/server/tests/temp/temp-run-docling.d.ts.map +1 -0
  245. package/dist/server/tests/temp/temp-run-docling.js +53 -0
  246. package/dist/server/tests/types/test-helpers.d.ts +1 -2
  247. package/dist/server/tests/types/test-helpers.d.ts.map +1 -1
  248. package/dist/server/tests/unit/config/config-loader-automatic-migration.test.d.ts +2 -0
  249. package/dist/server/tests/unit/config/config-loader-automatic-migration.test.d.ts.map +1 -0
  250. package/dist/server/tests/unit/config/config-loader-automatic-migration.test.js +199 -0
  251. package/dist/server/tests/unit/config/config-migrator.test.d.ts +2 -0
  252. package/dist/server/tests/unit/config/config-migrator.test.d.ts.map +1 -0
  253. package/dist/server/tests/unit/config/config-migrator.test.js +316 -0
  254. package/dist/server/tests/unit/config/config-saver.test.d.ts +2 -0
  255. package/dist/server/tests/unit/config/config-saver.test.d.ts.map +1 -0
  256. package/dist/server/tests/unit/config/config-saver.test.js +200 -0
  257. package/dist/server/tests/unit/config/config.schema.test.d.ts +2 -0
  258. package/dist/server/tests/unit/config/config.schema.test.d.ts.map +1 -0
  259. package/dist/server/tests/unit/config/config.schema.test.js +347 -0
  260. package/dist/server/tests/unit/server/runner.test.js +86 -62
  261. package/dist/server/tests/unit/services/connection/connection-manager.test.d.ts +2 -0
  262. package/dist/server/tests/unit/services/connection/connection-manager.test.d.ts.map +1 -0
  263. package/dist/server/tests/unit/services/connection/connection-manager.test.js +112 -0
  264. package/dist/server/tests/unit/services/hub-manager-service.test.js +112 -46
  265. package/dist/server/tests/unit/services/hub-manager.test.js +25 -15
  266. package/dist/server/tests/unit/services/hub-tools/instance-selector.test.d.ts +2 -0
  267. package/dist/server/tests/unit/services/hub-tools/instance-selector.test.d.ts.map +1 -0
  268. package/dist/server/tests/unit/services/hub-tools/instance-selector.test.js +195 -0
  269. package/dist/server/tests/unit/services/hub-tools/server-selector.test.d.ts +2 -0
  270. package/dist/server/tests/unit/services/hub-tools/server-selector.test.d.ts.map +1 -0
  271. package/dist/server/tests/unit/services/hub-tools/server-selector.test.js +190 -0
  272. package/dist/server/tests/unit/services/hub-tools.service.test.js +560 -320
  273. package/dist/server/tests/unit/services/instance-matcher.test.d.ts +2 -0
  274. package/dist/server/tests/unit/services/instance-matcher.test.d.ts.map +1 -0
  275. package/dist/server/tests/unit/services/instance-matcher.test.js +256 -0
  276. package/dist/server/tests/unit/services/session-manager.test.js +26 -436
  277. package/dist/server/tests/unit/utils/config.test.js +88 -186
  278. package/dist/server/tests/unit/utils/json-utils.test.js +18 -18
  279. package/dist/server/tests/unit/utils/logger-formatter.test.d.ts +2 -0
  280. package/dist/server/tests/unit/utils/logger-formatter.test.d.ts.map +1 -0
  281. package/dist/server/tests/unit/utils/logger-formatter.test.js +66 -0
  282. package/dist/server/tests/unit/utils/parameter-validator.test.d.ts +2 -0
  283. package/dist/server/tests/unit/utils/parameter-validator.test.d.ts.map +1 -0
  284. package/dist/server/tests/unit/utils/parameter-validator.test.js +63 -0
  285. package/dist/server/tests/unit/utils/process-tree.test.d.ts +2 -0
  286. package/dist/server/tests/unit/utils/process-tree.test.d.ts.map +1 -0
  287. package/dist/server/tests/unit/utils/process-tree.test.js +129 -0
  288. package/dist/server/tests/unit/utils/sort-utils.test.d.ts +2 -0
  289. package/dist/server/tests/unit/utils/sort-utils.test.d.ts.map +1 -0
  290. package/dist/server/tests/unit/utils/sort-utils.test.js +220 -0
  291. package/dist/server/tests/unit/utils/transport-factory.test.d.ts +2 -0
  292. package/dist/server/tests/unit/utils/transport-factory.test.d.ts.map +1 -0
  293. package/dist/server/tests/unit/utils/transport-factory.test.js +55 -0
  294. package/package.json +3 -1
  295. package/dist/client/assets/ResourceDetailView-Bf-1ffbk.js +0 -1
  296. package/dist/client/assets/ResourcesView-CjMklkyv.css +0 -1
  297. package/dist/client/assets/ResourcesView-g5x4xCPh.js +0 -1
  298. package/dist/client/assets/ServerDashboard-Chpne8Q0.css +0 -1
  299. package/dist/client/assets/ServerDashboard-G8Wmp4hF.js +0 -2
  300. package/dist/client/assets/ServerListView-dV2XrPjo.js +0 -32
  301. package/dist/client/assets/ServerStatusTags.vue_vue_type_script_setup_true_lang-BHiTFM7-.js +0 -1
  302. package/dist/client/assets/SessionsView-Ckd38lj1.js +0 -1
  303. package/dist/client/assets/SettingsView-BJUdepEQ.js +0 -1
  304. package/dist/client/assets/ToolCallDialog-C_bTCpHC.js +0 -1
  305. package/dist/client/assets/ToolsView-0c2eputu.js +0 -1
  306. package/dist/client/assets/ToolsView-E3Ps9c7i.css +0 -1
  307. package/dist/client/assets/el-form-item-BVMLpmVC.css +0 -1
  308. package/dist/client/assets/el-form-item-ClFnj49k.js +0 -12
  309. package/dist/client/assets/el-input-CDnuSKVZ.js +0 -1
  310. package/dist/client/assets/el-input-CmuHb8HS.css +0 -1
  311. package/dist/client/assets/el-overlay-B2ZKM6Up.css +0 -1
  312. package/dist/client/assets/el-overlay-CzMkXyYy.js +0 -1
  313. package/dist/client/assets/el-select-DvjGddk_.js +0 -1
  314. package/dist/client/assets/el-tab-pane-C_DQMcwe.js +0 -1
  315. package/dist/client/assets/el-table-column-CASRIbZM.js +0 -1
  316. package/dist/client/assets/el-table-column-T_mV9jNw.css +0 -1
  317. package/dist/client/assets/el-tag-DjxZVOpb.css +0 -1
  318. package/dist/client/assets/el-tag-npbwux4f.js +0 -1
  319. package/dist/client/assets/index-CCnAxNF8.js +0 -2
  320. package/dist/client/assets/index-d1DZeSfz.js +0 -1
  321. package/dist/client/assets/omit-DPsOVNIJ.js +0 -1
  322. package/dist/client/assets/vnode-CHomNjgN.js +0 -1
@@ -2,6 +2,11 @@ import { describe, it, expect, beforeEach, vi } from 'vitest';
2
2
  import { HubManagerService } from '../../../src/services/hub-manager.service.js';
3
3
  import { mcpConnectionManager } from '../../../src/services/mcp-connection-manager.js';
4
4
  import { configManager } from '../../../src/config/config-manager.js';
5
+ // Mock resolveInstanceConfig to return a valid resolved config
6
+ vi.mock('@config/config-migrator.js', () => ({
7
+ resolveInstanceConfig: vi.fn(),
8
+ getEnabledInstances: vi.fn()
9
+ }));
5
10
  // Mock dependencies
6
11
  vi.mock('@config/config-manager.js', () => ({
7
12
  ConfigManager: vi.fn(),
@@ -13,7 +18,7 @@ vi.mock('@config/config-manager.js', () => ({
13
18
  updateServer: vi.fn(),
14
19
  removeServer: vi.fn(),
15
20
  addServerInstance: vi.fn(),
16
- getServerInstanceByName: vi.fn(),
21
+ getServerInstancesByName: vi.fn(),
17
22
  updateServerInstance: vi.fn(),
18
23
  removeServerInstance: vi.fn()
19
24
  }
@@ -32,6 +37,12 @@ vi.mock('@utils/logger.js', () => ({
32
37
  },
33
38
  LOG_MODULES: {}
34
39
  }));
40
+ vi.mock('@services/event-bus.service.js', () => ({
41
+ eventBus: {
42
+ publish: vi.fn()
43
+ },
44
+ EventTypes: {}
45
+ }));
35
46
  describe('HubManagerService', () => {
36
47
  let service;
37
48
  beforeEach(() => {
@@ -39,86 +50,138 @@ describe('HubManagerService', () => {
39
50
  service = new HubManagerService(configManager);
40
51
  });
41
52
  it('should auto-connect when adding an enabled server instance', async () => {
53
+ // Import the mocked module
54
+ const { resolveInstanceConfig } = await import('../../../src/config/config-migrator.js');
42
55
  const serverName = 'Test Server';
43
56
  const serverBaseConfig = {
44
- type: 'stdio',
45
- command: 'node',
46
- args: [],
47
- enabled: true,
48
- allowedTools: [],
49
- timeout: 30000
57
+ template: {
58
+ type: 'stdio',
59
+ command: 'node',
60
+ args: [],
61
+ env: {},
62
+ headers: {},
63
+ aggregatedTools: [],
64
+ timeout: 30000
65
+ },
66
+ instances: [],
67
+ tagDefinitions: []
50
68
  };
51
69
  const serverInstanceConfig = {
52
70
  id: 'test-server',
53
- timestamp: Date.now(),
54
- hash: 'test-hash'
71
+ enabled: true,
72
+ args: [],
73
+ env: {},
74
+ headers: {},
75
+ tags: {}
55
76
  };
56
77
  vi.mocked(configManager.addServer).mockResolvedValue(serverBaseConfig);
57
78
  vi.mocked(configManager.addServerInstance).mockResolvedValue(serverInstanceConfig);
58
79
  vi.mocked(configManager.getServerByName).mockReturnValue(serverBaseConfig);
59
- await service.addServer(serverName, serverBaseConfig);
80
+ // Mock resolveInstanceConfig to return enabled = true
81
+ vi.mocked(resolveInstanceConfig).mockReturnValue({
82
+ command: 'node',
83
+ args: [],
84
+ type: 'stdio',
85
+ timeout: 30000,
86
+ aggregatedTools: [],
87
+ tags: {},
88
+ enabled: true
89
+ });
90
+ await service.addServer(serverName, serverBaseConfig.template);
60
91
  await service.addServerInstance(serverName, serverInstanceConfig);
61
- expect(configManager.addServer).toHaveBeenCalledWith(serverName, serverBaseConfig);
62
- expect(configManager.addServerInstance).toHaveBeenCalledWith(serverName, serverInstanceConfig);
92
+ expect(configManager.addServer).toHaveBeenCalled();
93
+ expect(configManager.addServerInstance).toHaveBeenCalled();
63
94
  expect(mcpConnectionManager.connect).toHaveBeenCalled();
64
95
  });
65
96
  it('should NOT auto-connect when adding a disabled server instance', async () => {
97
+ // Import the mocked module
98
+ const { resolveInstanceConfig } = await import('../../../src/config/config-migrator.js');
66
99
  const serverName = 'Disabled Server';
67
100
  const serverBaseConfig = {
68
- type: 'stdio',
69
- command: 'node',
70
- args: [],
71
- enabled: false,
72
- allowedTools: [],
73
- timeout: 30000
101
+ template: {
102
+ type: 'stdio',
103
+ command: 'node',
104
+ args: [],
105
+ env: {},
106
+ headers: {},
107
+ aggregatedTools: [],
108
+ timeout: 30000
109
+ },
110
+ instances: [],
111
+ tagDefinitions: []
74
112
  };
75
113
  const serverInstanceConfig = {
76
114
  id: 'test-server-disabled',
77
- name: serverName,
78
- timestamp: Date.now(),
79
- hash: 'test-hash'
115
+ enabled: false,
116
+ args: [],
117
+ env: {},
118
+ headers: {},
119
+ tags: {}
80
120
  };
81
121
  vi.mocked(configManager.addServer).mockResolvedValue(serverBaseConfig);
82
122
  vi.mocked(configManager.addServerInstance).mockResolvedValue(serverInstanceConfig);
83
123
  vi.mocked(configManager.getServerByName).mockReturnValue(serverBaseConfig);
84
- await service.addServer(serverName, serverBaseConfig);
124
+ // Mock resolveInstanceConfig to return enabled = false
125
+ vi.mocked(resolveInstanceConfig).mockReturnValue({
126
+ command: 'node',
127
+ args: [],
128
+ type: 'stdio',
129
+ timeout: 30000,
130
+ aggregatedTools: [],
131
+ tags: {},
132
+ enabled: false
133
+ });
134
+ await service.addServer(serverName, serverBaseConfig.template);
85
135
  await service.addServerInstance(serverName, serverInstanceConfig);
86
- expect(configManager.addServer).toHaveBeenCalledWith(serverName, serverBaseConfig);
87
- expect(configManager.addServerInstance).toHaveBeenCalledWith(serverName, serverInstanceConfig);
136
+ expect(configManager.addServer).toHaveBeenCalled();
137
+ expect(configManager.addServerInstance).toHaveBeenCalled();
88
138
  expect(mcpConnectionManager.connect).not.toHaveBeenCalled();
89
139
  });
90
140
  it('should call disconnect when removing a server', async () => {
91
141
  const serverName = 'Test Server';
92
142
  const serverConfig = {
93
- type: 'stdio',
94
- command: 'node',
95
- args: [],
96
- enabled: true,
97
- allowedTools: [],
98
- timeout: 30000
143
+ template: {
144
+ type: 'stdio',
145
+ command: 'node',
146
+ args: [],
147
+ env: {},
148
+ headers: {},
149
+ aggregatedTools: [],
150
+ timeout: 30000
151
+ },
152
+ instances: [],
153
+ tagDefinitions: []
99
154
  };
100
155
  vi.mocked(configManager.getServerByName).mockReturnValue(serverConfig);
101
- vi.mocked(configManager.removeServer).mockResolvedValue();
102
- vi.mocked(configManager.getServerInstanceByName).mockReturnValue([
156
+ vi.mocked(configManager.removeServer).mockResolvedValue(true);
157
+ vi.mocked(configManager.getServerInstancesByName).mockReturnValue([
103
158
  {
104
159
  id: 'test-server-instance',
105
- timestamp: Date.now(),
106
- hash: 'test-hash'
160
+ enabled: true,
161
+ args: [],
162
+ env: {},
163
+ headers: {},
164
+ tags: {}
107
165
  }
108
166
  ]);
109
167
  await service.removeServer(serverName);
110
168
  expect(configManager.removeServer).toHaveBeenCalledWith(serverName);
111
- expect(mcpConnectionManager.disconnect).toHaveBeenCalledWith('test-server-instance');
169
+ expect(mcpConnectionManager.disconnect).toHaveBeenCalledWith(serverName, 0);
112
170
  });
113
171
  it('should get server by name', async () => {
114
172
  const serverName = 'Test Server';
115
173
  const serverBaseConfig = {
116
- type: 'stdio',
117
- command: 'test',
118
- args: [],
119
- enabled: true,
120
- allowedTools: [],
121
- timeout: 30000
174
+ template: {
175
+ type: 'stdio',
176
+ command: 'test',
177
+ args: [],
178
+ env: {},
179
+ headers: {},
180
+ aggregatedTools: [],
181
+ timeout: 30000
182
+ },
183
+ instances: [],
184
+ tagDefinitions: []
122
185
  };
123
186
  vi.mocked(configManager.getServerByName).mockReturnValue(serverBaseConfig);
124
187
  const server = service.getServerByName(serverName);
@@ -129,12 +192,15 @@ describe('HubManagerService', () => {
129
192
  const serverName = 'Test Server';
130
193
  const serverInstanceConfig = {
131
194
  id: 'test-instance',
132
- timestamp: Date.now(),
133
- hash: 'test-hash'
195
+ enabled: true,
196
+ args: [],
197
+ env: {},
198
+ headers: {},
199
+ tags: {}
134
200
  };
135
- vi.mocked(configManager.getServerInstanceByName).mockReturnValue([serverInstanceConfig]);
136
- const instances = service.getServerInstanceByName(serverName);
201
+ vi.mocked(configManager.getServerInstancesByName).mockReturnValue([serverInstanceConfig]);
202
+ const instances = service.getServerInstancesByName(serverName);
137
203
  expect(instances).toEqual([serverInstanceConfig]);
138
- expect(configManager.getServerInstanceByName).toHaveBeenCalledWith(serverName);
204
+ expect(configManager.getServerInstancesByName).toHaveBeenCalledWith(serverName);
139
205
  });
140
206
  });
@@ -9,7 +9,7 @@ vi.mock('@services/hub-manager.service.js', () => ({
9
9
  getServerById: vi.fn(),
10
10
  getServerByName: vi.fn(),
11
11
  getServerInstances: vi.fn(),
12
- getServerInstanceByName: vi.fn(),
12
+ getServerInstancesByName: vi.fn(),
13
13
  addServer: vi.fn(),
14
14
  addServerInstance: vi.fn(),
15
15
  updateServer: vi.fn(),
@@ -35,12 +35,18 @@ describe('Server API Routes', () => {
35
35
  id: '1',
36
36
  name: 'test',
37
37
  config: {
38
- type: 'stdio',
39
- command: 'test',
40
- args: [],
41
- enabled: true,
42
- allowedTools: [],
43
- timeout: 30000
38
+ template: {
39
+ type: 'stdio',
40
+ command: 'test',
41
+ args: [],
42
+ env: {},
43
+ headers: {},
44
+ aggregatedTools: [],
45
+ timeout: 30000,
46
+ tags: {}
47
+ },
48
+ instances: [],
49
+ tagDefinitions: []
44
50
  }
45
51
  }
46
52
  ];
@@ -59,17 +65,21 @@ describe('Server API Routes', () => {
59
65
  command: 'node',
60
66
  args: [],
61
67
  env: {},
62
- enabled: true
68
+ headers: {}
63
69
  }
64
70
  };
65
71
  const createdServer = {
66
- type: 'stdio',
67
- command: 'node',
68
- args: [],
69
- env: {},
70
- enabled: true,
71
- allowedTools: [],
72
- timeout: 30000
72
+ template: {
73
+ type: 'stdio',
74
+ command: 'node',
75
+ args: [],
76
+ env: {},
77
+ headers: {},
78
+ aggregatedTools: [],
79
+ timeout: 30000
80
+ },
81
+ instances: [],
82
+ tagDefinitions: []
73
83
  };
74
84
  vi.mocked(hubManager.addServer).mockReturnValue(Promise.resolve(createdServer));
75
85
  const response = await app.inject({
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=instance-selector.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance-selector.test.d.ts","sourceRoot":"","sources":["../../../../../../tests/unit/services/hub-tools/instance-selector.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,195 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { InstanceSelector } from '../../../../src/services/hub-tools/instance-selector.js';
3
+ describe('InstanceSelector', () => {
4
+ const baseTemplate = {
5
+ type: 'stdio',
6
+ command: 'test-command',
7
+ args: [],
8
+ env: {},
9
+ headers: {},
10
+ timeout: 60000,
11
+ aggregatedTools: []
12
+ };
13
+ const baseInstance = {
14
+ enabled: true,
15
+ args: [],
16
+ env: {},
17
+ headers: {},
18
+ tags: {}
19
+ };
20
+ describe('random strategy', () => {
21
+ it('should select random instance from enabled instances', () => {
22
+ const config = {
23
+ template: {
24
+ ...baseTemplate,
25
+ instanceSelectionStrategy: 'random'
26
+ },
27
+ instances: [
28
+ { ...baseInstance, id: '1', index: 0, enabled: true },
29
+ { ...baseInstance, id: '2', index: 1, enabled: true },
30
+ { ...baseInstance, id: '3', index: 2, enabled: false }
31
+ ],
32
+ tagDefinitions: []
33
+ };
34
+ const selected = InstanceSelector.selectInstance('test-server', config);
35
+ expect(selected).toBeDefined();
36
+ expect(['1', '2']).toContain(selected.id);
37
+ });
38
+ it('should return undefined when no enabled instances', () => {
39
+ const config = {
40
+ template: {
41
+ ...baseTemplate,
42
+ instanceSelectionStrategy: 'random'
43
+ },
44
+ instances: [
45
+ { ...baseInstance, id: '1', index: 0, enabled: false },
46
+ { ...baseInstance, id: '2', index: 1, enabled: false }
47
+ ],
48
+ tagDefinitions: []
49
+ };
50
+ const selected = InstanceSelector.selectInstance('test-server', config);
51
+ expect(selected).toBeUndefined();
52
+ });
53
+ });
54
+ describe('round-robin strategy', () => {
55
+ it('should cycle through enabled instances', () => {
56
+ const config = {
57
+ template: {
58
+ ...baseTemplate,
59
+ instanceSelectionStrategy: 'round-robin'
60
+ },
61
+ instances: [
62
+ { ...baseInstance, id: '1', index: 0, enabled: true },
63
+ { ...baseInstance, id: '2', index: 1, enabled: true },
64
+ { ...baseInstance, id: '3', index: 2, enabled: true }
65
+ ],
66
+ tagDefinitions: []
67
+ };
68
+ const selected1 = InstanceSelector.selectInstance('test-server-rr', config);
69
+ const selected2 = InstanceSelector.selectInstance('test-server-rr', config);
70
+ const selected3 = InstanceSelector.selectInstance('test-server-rr', config);
71
+ const selected4 = InstanceSelector.selectInstance('test-server-rr', config);
72
+ expect(selected1.id).toBe('1');
73
+ expect(selected2.id).toBe('2');
74
+ expect(selected3.id).toBe('3');
75
+ expect(selected4.id).toBe('1');
76
+ });
77
+ });
78
+ describe('tag-match-unique strategy', () => {
79
+ it('should select instance that uniquely matches tags', () => {
80
+ const config = {
81
+ template: {
82
+ ...baseTemplate,
83
+ instanceSelectionStrategy: 'tag-match-unique'
84
+ },
85
+ instances: [
86
+ { ...baseInstance, id: '1', index: 0, tags: { env: 'dev', region: 'us' } },
87
+ { ...baseInstance, id: '2', index: 1, tags: { env: 'prod', region: 'us' } },
88
+ { ...baseInstance, id: '3', index: 2, tags: { env: 'prod', region: 'eu' } }
89
+ ],
90
+ tagDefinitions: []
91
+ };
92
+ const selected = InstanceSelector.selectInstance('test-server', config, {
93
+ tags: { env: 'prod', region: 'us' }
94
+ });
95
+ expect(selected).toBeDefined();
96
+ expect(selected.id).toBe('2');
97
+ });
98
+ it('should throw error when no instance matches tags', () => {
99
+ const config = {
100
+ template: {
101
+ ...baseTemplate,
102
+ instanceSelectionStrategy: 'tag-match-unique'
103
+ },
104
+ instances: [
105
+ { ...baseInstance, id: '1', index: 0, tags: { env: 'dev' } },
106
+ { ...baseInstance, id: '2', index: 1, tags: { env: 'prod' } }
107
+ ],
108
+ tagDefinitions: []
109
+ };
110
+ expect(() => {
111
+ InstanceSelector.selectInstance('test-server', config, {
112
+ tags: { env: 'staging' }
113
+ });
114
+ }).toThrow('No instance found matching tags');
115
+ });
116
+ it('should throw error when multiple instances match tags', () => {
117
+ const config = {
118
+ template: {
119
+ ...baseTemplate,
120
+ instanceSelectionStrategy: 'tag-match-unique'
121
+ },
122
+ instances: [
123
+ { ...baseInstance, id: '1', index: 0, tags: { env: 'prod' } },
124
+ { ...baseInstance, id: '2', index: 1, tags: { env: 'prod' } }
125
+ ],
126
+ tagDefinitions: []
127
+ };
128
+ expect(() => {
129
+ InstanceSelector.selectInstance('test-server', config, {
130
+ tags: { env: 'prod' }
131
+ });
132
+ }).toThrow('Multiple instances match tags');
133
+ });
134
+ it('should return the single instance when no tags provided and only one instance exists', () => {
135
+ const config = {
136
+ template: {
137
+ ...baseTemplate,
138
+ instanceSelectionStrategy: 'tag-match-unique'
139
+ },
140
+ instances: [{ ...baseInstance, id: '1', index: 0 }],
141
+ tagDefinitions: []
142
+ };
143
+ const selected = InstanceSelector.selectInstance('test-server', config);
144
+ expect(selected).toBeDefined();
145
+ expect(selected.id).toBe('1');
146
+ });
147
+ it('should throw error when no tags provided with multiple instances', () => {
148
+ const config = {
149
+ template: {
150
+ ...baseTemplate,
151
+ instanceSelectionStrategy: 'tag-match-unique'
152
+ },
153
+ instances: [
154
+ { ...baseInstance, id: '1', index: 0 },
155
+ { ...baseInstance, id: '2', index: 1 }
156
+ ],
157
+ tagDefinitions: []
158
+ };
159
+ expect(() => {
160
+ InstanceSelector.selectInstance('test-server', config);
161
+ }).toThrow('No tags provided for tag-match-unique strategy with 2 instances. Available: [0:{}, 1:{}]. Pass matching tags to select.');
162
+ });
163
+ });
164
+ describe('single instance', () => {
165
+ it('should return the single instance regardless of strategy', () => {
166
+ const config = {
167
+ template: {
168
+ ...baseTemplate,
169
+ instanceSelectionStrategy: 'round-robin'
170
+ },
171
+ instances: [{ ...baseInstance, id: '1', index: 0 }],
172
+ tagDefinitions: []
173
+ };
174
+ const selected = InstanceSelector.selectInstance('test-server', config);
175
+ expect(selected).toBeDefined();
176
+ expect(selected.id).toBe('1');
177
+ });
178
+ });
179
+ describe('default strategy', () => {
180
+ it('should use random strategy when no strategy specified', () => {
181
+ const config = {
182
+ template: baseTemplate,
183
+ instances: [
184
+ { ...baseInstance, id: '1', index: 0 },
185
+ { ...baseInstance, id: '2', index: 1 }
186
+ ],
187
+ tagDefinitions: []
188
+ // No instanceSelectionStrategy field
189
+ };
190
+ const selected = InstanceSelector.selectInstance('test-server', config);
191
+ expect(selected).toBeDefined();
192
+ expect(['1', '2']).toContain(selected.id);
193
+ });
194
+ });
195
+ });
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=server-selector.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"server-selector.test.d.ts","sourceRoot":"","sources":["../../../../../../tests/unit/services/hub-tools/server-selector.test.ts"],"names":[],"mappings":""}