@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
@@ -0,0 +1,200 @@
1
+ import { describe, it, expect, vi, beforeEach, afterEach } from 'vitest';
2
+ import { saveConfig } from '../../../src/config/config-saver.js';
3
+ import * as fs from 'fs';
4
+ import path from 'path';
5
+ // Mock fs module
6
+ vi.mock('fs');
7
+ vi.mock('path');
8
+ vi.mock('@utils/logger.js', () => ({
9
+ logger: {
10
+ debug: vi.fn(),
11
+ error: vi.fn()
12
+ }
13
+ }));
14
+ describe('ConfigSaver', () => {
15
+ const mockFs = vi.mocked(fs);
16
+ const mockPath = vi.mocked(path);
17
+ const testConfigPath = '/test/path/.mcp-hub.json';
18
+ const testDir = '/test/path';
19
+ beforeEach(() => {
20
+ vi.clearAllMocks();
21
+ mockPath.dirname.mockReturnValue(testDir);
22
+ mockFs.existsSync.mockReturnValue(true);
23
+ });
24
+ afterEach(() => {
25
+ vi.resetAllMocks();
26
+ });
27
+ describe('saveConfig', () => {
28
+ it('should save configuration to disk', () => {
29
+ const config = {
30
+ version: '1.1.0',
31
+ system: {
32
+ host: 'localhost',
33
+ port: 7788
34
+ }
35
+ };
36
+ saveConfig(testConfigPath, config);
37
+ expect(mockPath.dirname).toHaveBeenCalledWith(testConfigPath);
38
+ expect(mockFs.existsSync).toHaveBeenCalledWith(testDir);
39
+ expect(mockFs.writeFileSync).toHaveBeenCalledWith(testConfigPath, JSON.stringify(config, null, 2));
40
+ });
41
+ it('should create directory if it does not exist', () => {
42
+ mockFs.existsSync.mockReturnValue(false);
43
+ const config = { version: '1.1.0' };
44
+ saveConfig(testConfigPath, config);
45
+ expect(mockFs.mkdirSync).toHaveBeenCalledWith(testDir, { recursive: true });
46
+ });
47
+ it('should ignore errors during save', () => {
48
+ mockFs.writeFileSync.mockImplementation(() => {
49
+ throw new Error('Write failed');
50
+ });
51
+ const config = { version: '1.1.0' };
52
+ expect(() => saveConfig(testConfigPath, config)).not.toThrow();
53
+ });
54
+ it('should preserve empty string fields', () => {
55
+ const config = {
56
+ version: '1.1.0',
57
+ emptyField: '',
58
+ nonEmptyField: 'value'
59
+ };
60
+ saveConfig(testConfigPath, config);
61
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
62
+ expect(writtenContent).toEqual(config);
63
+ });
64
+ it('should preserve empty array fields', () => {
65
+ const config = {
66
+ version: '1.1.0',
67
+ emptyArray: [],
68
+ nonEmptyArray: [1, 2, 3]
69
+ };
70
+ saveConfig(testConfigPath, config);
71
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
72
+ expect(writtenContent).toEqual(config);
73
+ });
74
+ it('should preserve empty object fields', () => {
75
+ const config = {
76
+ version: '1.1.0',
77
+ emptyObject: {},
78
+ nonEmptyObject: { key: 'value' }
79
+ };
80
+ saveConfig(testConfigPath, config);
81
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
82
+ expect(writtenContent).toEqual(config);
83
+ });
84
+ it('should preserve null and undefined fields', () => {
85
+ const config = {
86
+ version: '1.1.0',
87
+ nullField: null,
88
+ undefinedField: undefined,
89
+ validField: 'value'
90
+ };
91
+ saveConfig(testConfigPath, config);
92
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
93
+ expect(writtenContent).toEqual({
94
+ version: '1.1.0',
95
+ nullField: null,
96
+ validField: 'value'
97
+ });
98
+ });
99
+ it('should preserve nested empty objects and arrays', () => {
100
+ const config = {
101
+ version: '1.1.0',
102
+ system: {
103
+ host: 'localhost',
104
+ port: 7788,
105
+ emptyNested: {},
106
+ emptyString: '',
107
+ emptyArray: []
108
+ },
109
+ security: {
110
+ emptyArray: [],
111
+ maxConnections: 50
112
+ }
113
+ };
114
+ saveConfig(testConfigPath, config);
115
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
116
+ expect(writtenContent).toEqual(config);
117
+ });
118
+ it('should preserve server configuration with empty collections', () => {
119
+ const config = {
120
+ version: '1.1.0',
121
+ servers: {
122
+ 'test-server': {
123
+ template: {
124
+ type: 'stdio',
125
+ timeout: 60000,
126
+ command: 'npx test',
127
+ args: [],
128
+ env: {},
129
+ headers: {},
130
+ aggregatedTools: []
131
+ },
132
+ instances: [
133
+ {
134
+ id: 'instance-1',
135
+ enabled: true,
136
+ args: [],
137
+ env: {},
138
+ headers: {},
139
+ tags: {}
140
+ }
141
+ ]
142
+ }
143
+ }
144
+ };
145
+ saveConfig(testConfigPath, config);
146
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
147
+ expect(writtenContent).toEqual(config);
148
+ });
149
+ it('should handle complex real-world configuration with empty values', () => {
150
+ const realConfig = {
151
+ version: '1.1.0',
152
+ system: {
153
+ host: 'localhost',
154
+ port: 7788,
155
+ language: 'zh',
156
+ theme: 'system',
157
+ logging: {
158
+ level: 'info',
159
+ rotationAge: '7d',
160
+ extraField: '',
161
+ debugOptions: {}
162
+ }
163
+ },
164
+ security: {
165
+ allowedNetworks: ['127.0.0.1'],
166
+ maxConcurrentConnections: 50,
167
+ connectionTimeout: 30000,
168
+ emptyConfig: []
169
+ },
170
+ servers: {
171
+ 'my-server': {
172
+ template: {
173
+ command: 'npx my-server',
174
+ args: [],
175
+ env: {},
176
+ headers: {},
177
+ timeout: 60000,
178
+ aggregatedTools: [],
179
+ type: 'stdio'
180
+ },
181
+ instances: [
182
+ {
183
+ id: 'default',
184
+ enabled: true,
185
+ args: [],
186
+ env: {},
187
+ headers: {},
188
+ tags: {}
189
+ }
190
+ ]
191
+ }
192
+ },
193
+ emptySection: {}
194
+ };
195
+ saveConfig(testConfigPath, realConfig);
196
+ const writtenContent = JSON.parse(mockFs.writeFileSync.mock.calls[0][1]);
197
+ expect(writtenContent).toEqual(realConfig);
198
+ });
199
+ });
200
+ });
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=config.schema.test.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"config.schema.test.d.ts","sourceRoot":"","sources":["../../../../../tests/unit/config/config.schema.test.ts"],"names":[],"mappings":""}
@@ -0,0 +1,347 @@
1
+ import { describe, it, expect } from 'vitest';
2
+ import { TagDefinitionSchema, ServerInstanceSchema, ServerInstanceUpdateSchema, ServerTemplateSchema, ServerConfigSchema, SystemConfigSchema, isLegacyV1Config } from '../../../src/config/config.schema.js';
3
+ describe('Config Schema (v1.1)', () => {
4
+ describe('TagDefinitionSchema', () => {
5
+ it('should validate a valid tag definition', () => {
6
+ const tagDef = {
7
+ key: 'environment',
8
+ description: 'Deployment environment',
9
+ type: 'enum',
10
+ values: ['dev', 'staging', 'prod']
11
+ };
12
+ const result = TagDefinitionSchema.safeParse(tagDef);
13
+ expect(result.success).toBe(true);
14
+ });
15
+ it('should use default values for optional fields', () => {
16
+ const tagDef = {
17
+ key: 'simple-tag'
18
+ };
19
+ const result = TagDefinitionSchema.safeParse(tagDef);
20
+ expect(result.success).toBe(true);
21
+ if (result.success) {
22
+ expect(result.data.type).toBe('string');
23
+ }
24
+ });
25
+ it('should reject invalid tag types', () => {
26
+ const tagDef = {
27
+ key: 'test',
28
+ type: 'invalid-type'
29
+ };
30
+ const result = TagDefinitionSchema.safeParse(tagDef);
31
+ expect(result.success).toBe(false);
32
+ });
33
+ });
34
+ describe('ServerInstanceSchema', () => {
35
+ it('should validate a valid server instance', () => {
36
+ const instance = {
37
+ id: 'instance-1',
38
+ enabled: true,
39
+ args: ['--verbose'],
40
+ env: { NODE_ENV: 'development' },
41
+ headers: {},
42
+ tags: { environment: 'dev', region: 'us-east' }
43
+ };
44
+ const result = ServerInstanceSchema.safeParse(instance);
45
+ expect(result.success).toBe(true);
46
+ });
47
+ it('should use default values for optional fields', () => {
48
+ const instance = {
49
+ id: 'instance-1'
50
+ };
51
+ const result = ServerInstanceSchema.safeParse(instance);
52
+ expect(result.success).toBe(true);
53
+ if (result.success) {
54
+ expect(result.data.enabled).toBe(true);
55
+ expect(result.data.args).toEqual([]);
56
+ expect(result.data.env).toEqual({});
57
+ expect(result.data.headers).toEqual({});
58
+ expect(result.data.tags).toEqual({});
59
+ }
60
+ });
61
+ it('should reject instances without id', () => {
62
+ const instance = {
63
+ enabled: true
64
+ };
65
+ const result = ServerInstanceSchema.safeParse(instance);
66
+ expect(result.success).toBe(false);
67
+ });
68
+ });
69
+ describe('ServerTemplateSchema', () => {
70
+ it('should validate a valid server template', () => {
71
+ const template = {
72
+ command: 'npx my-server',
73
+ args: ['--config', 'default.json'],
74
+ env: { LOG_LEVEL: 'info' },
75
+ headers: {},
76
+ type: 'stdio',
77
+ timeout: 60000,
78
+ aggregatedTools: ['tool1', 'tool2'],
79
+ description: 'My MCP server template'
80
+ };
81
+ const result = ServerTemplateSchema.safeParse(template);
82
+ expect(result.success).toBe(true);
83
+ });
84
+ it('should use default values', () => {
85
+ const template = {};
86
+ const result = ServerTemplateSchema.safeParse(template);
87
+ expect(result.success).toBe(true);
88
+ if (result.success) {
89
+ expect(result.data.type).toBe('stdio');
90
+ expect(result.data.timeout).toBe(60000);
91
+ expect(result.data.args).toEqual([]);
92
+ expect(result.data.env).toEqual({});
93
+ expect(result.data.headers).toEqual({});
94
+ expect(result.data.aggregatedTools).toEqual([]);
95
+ }
96
+ });
97
+ });
98
+ describe('ServerConfigSchema', () => {
99
+ it('should validate a complete server configuration', () => {
100
+ const serverConfig = {
101
+ template: {
102
+ command: 'npx my-server',
103
+ args: [],
104
+ env: {},
105
+ headers: {},
106
+ type: 'stdio',
107
+ timeout: 60000,
108
+ aggregatedTools: []
109
+ },
110
+ instances: [
111
+ {
112
+ id: 'instance-1',
113
+ enabled: true,
114
+ args: [],
115
+ env: {},
116
+ headers: {},
117
+ tags: { environment: 'dev' }
118
+ },
119
+ {
120
+ id: 'instance-2',
121
+ enabled: false,
122
+ args: [],
123
+ env: {},
124
+ headers: {},
125
+ tags: { environment: 'prod' }
126
+ }
127
+ ],
128
+ tagDefinitions: [
129
+ {
130
+ key: 'environment',
131
+ type: 'enum',
132
+ values: ['dev', 'prod']
133
+ }
134
+ ]
135
+ };
136
+ const result = ServerConfigSchema.safeParse(serverConfig);
137
+ expect(result.success).toBe(true);
138
+ });
139
+ it('should validate all instance selection strategies', () => {
140
+ const strategies = [
141
+ 'random',
142
+ 'round-robin',
143
+ 'tag-match-unique'
144
+ ];
145
+ for (const strategy of strategies) {
146
+ const serverConfig = {
147
+ template: {
148
+ command: 'npx my-server',
149
+ instanceSelectionStrategy: strategy
150
+ }
151
+ };
152
+ const result = ServerConfigSchema.safeParse(serverConfig);
153
+ expect(result.success).toBe(true);
154
+ if (result.success) {
155
+ expect(result.data.template.instanceSelectionStrategy).toBe(strategy);
156
+ }
157
+ }
158
+ });
159
+ it('should reject invalid instance selection strategies', () => {
160
+ const serverConfig = {
161
+ template: {
162
+ command: 'npx my-server',
163
+ instanceSelectionStrategy: 'invalid-strategy'
164
+ }
165
+ };
166
+ const result = ServerConfigSchema.safeParse(serverConfig);
167
+ expect(result.success).toBe(false);
168
+ });
169
+ it('should use defaults for empty instances and tagDefinitions', () => {
170
+ const serverConfig = {
171
+ template: {
172
+ command: 'npx my-server'
173
+ }
174
+ };
175
+ const result = ServerConfigSchema.safeParse(serverConfig);
176
+ expect(result.success).toBe(true);
177
+ if (result.success) {
178
+ expect(result.data.instances).toEqual([]);
179
+ expect(result.data.tagDefinitions).toEqual([]);
180
+ expect(result.data.template.instanceSelectionStrategy).toBeUndefined();
181
+ }
182
+ });
183
+ });
184
+ describe('Type Guards', () => {
185
+ describe('isLegacyV1Config', () => {
186
+ it('should recognize v1 config by version', () => {
187
+ const config = {
188
+ version: '1.0.0',
189
+ servers: {}
190
+ };
191
+ expect(isLegacyV1Config(config)).toBe(true);
192
+ });
193
+ it('should not recognize v1.1 config', () => {
194
+ const config = {
195
+ version: '1.1.0',
196
+ servers: {}
197
+ };
198
+ expect(isLegacyV1Config(config)).toBe(false);
199
+ });
200
+ it('should handle null/undefined', () => {
201
+ expect(isLegacyV1Config(null)).toBe(false);
202
+ expect(isLegacyV1Config(undefined)).toBe(false);
203
+ });
204
+ });
205
+ });
206
+ describe('SystemConfigSchema', () => {
207
+ it('should validate a complete system configuration', () => {
208
+ const config = {
209
+ version: '1.1.0',
210
+ system: {
211
+ host: 'localhost',
212
+ port: 7788,
213
+ language: 'zh',
214
+ theme: 'system',
215
+ logging: {
216
+ level: 'info',
217
+ rotationAge: '7d',
218
+ jsonPretty: true,
219
+ mcpCommDebug: false,
220
+ apiDebug: false
221
+ }
222
+ },
223
+ security: {
224
+ allowedNetworks: ['127.0.0.1'],
225
+ maxConcurrentConnections: 50,
226
+ connectionTimeout: 30000,
227
+ idleConnectionTimeout: 300000,
228
+ maxConnections: 50
229
+ },
230
+ servers: {},
231
+ tagDefinitions: []
232
+ };
233
+ const result = SystemConfigSchema.safeParse(config);
234
+ expect(result.success).toBe(true);
235
+ });
236
+ });
237
+ describe('ServerInstanceUpdateSchema (Regression Test)', () => {
238
+ it('should NOT add default values when parsing empty object', () => {
239
+ const updates = {};
240
+ const result = ServerInstanceUpdateSchema.safeParse(updates);
241
+ expect(result.success).toBe(true);
242
+ if (result.success) {
243
+ // Should NOT have default values - only the fields that were provided
244
+ expect(result.data).toEqual({});
245
+ expect(result.data.args).toBeUndefined();
246
+ expect(result.data.env).toBeUndefined();
247
+ expect(result.data.headers).toBeUndefined();
248
+ expect(result.data.tags).toBeUndefined();
249
+ expect(result.data.enabled).toBeUndefined();
250
+ }
251
+ });
252
+ it('should preserve only the provided fields (displayName only)', () => {
253
+ const updates = { displayName: 'My Updated Instance' };
254
+ const result = ServerInstanceUpdateSchema.safeParse(updates);
255
+ expect(result.success).toBe(true);
256
+ if (result.success) {
257
+ expect(result.data.displayName).toBe('My Updated Instance');
258
+ expect(result.data.args).toBeUndefined();
259
+ expect(result.data.env).toBeUndefined();
260
+ expect(result.data.headers).toBeUndefined();
261
+ expect(result.data.tags).toBeUndefined();
262
+ }
263
+ });
264
+ it('should preserve only the provided fields (env only)', () => {
265
+ const updates = { env: { NEW_KEY: 'new-value' } };
266
+ const result = ServerInstanceUpdateSchema.safeParse(updates);
267
+ expect(result.success).toBe(true);
268
+ if (result.success) {
269
+ expect(result.data.env).toEqual({ NEW_KEY: 'new-value' });
270
+ expect(result.data.args).toBeUndefined();
271
+ expect(result.data.headers).toBeUndefined();
272
+ expect(result.data.tags).toBeUndefined();
273
+ expect(result.data.displayName).toBeUndefined();
274
+ }
275
+ });
276
+ it('should preserve only the provided fields (args only)', () => {
277
+ const updates = { args: ['--new-arg'] };
278
+ const result = ServerInstanceUpdateSchema.safeParse(updates);
279
+ expect(result.success).toBe(true);
280
+ if (result.success) {
281
+ expect(result.data.args).toEqual(['--new-arg']);
282
+ expect(result.data.env).toBeUndefined();
283
+ expect(result.data.headers).toBeUndefined();
284
+ expect(result.data.tags).toBeUndefined();
285
+ }
286
+ });
287
+ it('should work correctly with object merge (preventing regression)', () => {
288
+ // Simulate the original instance with existing values
289
+ const originalInstance = {
290
+ id: 'instance-1',
291
+ enabled: true,
292
+ args: ['--existing-arg'],
293
+ env: { EXISTING_KEY: 'existing-value' },
294
+ headers: { 'X-Existing': 'header' },
295
+ tags: { existing: 'tag' }
296
+ };
297
+ // User only wants to update displayName
298
+ const updates = { displayName: 'Updated Name' };
299
+ const parsedUpdates = ServerInstanceUpdateSchema.parse(updates);
300
+ // Merge should NOT overwrite existing env/args/headers/tags
301
+ const mergedInstance = {
302
+ ...originalInstance,
303
+ ...parsedUpdates
304
+ };
305
+ // Verify existing fields are preserved
306
+ expect(mergedInstance.args).toEqual(['--existing-arg']);
307
+ expect(mergedInstance.env).toEqual({ EXISTING_KEY: 'existing-value' });
308
+ expect(mergedInstance.headers).toEqual({ 'X-Existing': 'header' });
309
+ expect(mergedInstance.tags).toEqual({ existing: 'tag' });
310
+ expect(mergedInstance.displayName).toBe('Updated Name');
311
+ });
312
+ it('should work correctly when updating env without affecting args', () => {
313
+ const originalInstance = {
314
+ id: 'instance-1',
315
+ enabled: true,
316
+ args: ['--keep-this'],
317
+ env: { KEEP_THIS: 'value' },
318
+ headers: {},
319
+ tags: {}
320
+ };
321
+ const updates = { env: { NEW_KEY: 'new-value' } };
322
+ const parsedUpdates = ServerInstanceUpdateSchema.parse(updates);
323
+ const mergedInstance = {
324
+ ...originalInstance,
325
+ ...parsedUpdates
326
+ };
327
+ // args should still be preserved
328
+ expect(mergedInstance.args).toEqual(['--keep-this']);
329
+ // env should be updated
330
+ expect(mergedInstance.env).toEqual({ NEW_KEY: 'new-value' });
331
+ });
332
+ it('should NOT fill in defaults when using ServerInstanceSchema.partial() [demonstrating the bug]', () => {
333
+ // This test demonstrates the bug we're fixing
334
+ const updates = { displayName: 'Test' };
335
+ const result = ServerInstanceSchema.partial().safeParse(updates);
336
+ expect(result.success).toBe(true);
337
+ if (result.success) {
338
+ // ServerInstanceSchema.partial() WILL add default values!
339
+ // This is the bug - it adds args: [], env: {}, etc.
340
+ expect(result.data.args).toEqual([]);
341
+ expect(result.data.env).toEqual({});
342
+ expect(result.data.headers).toEqual({});
343
+ expect(result.data.tags).toEqual({});
344
+ }
345
+ });
346
+ });
347
+ });