@frontmcp/sdk 0.4.1 → 0.5.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 (558) hide show
  1. package/README.md +30 -18
  2. package/package.json +20 -5
  3. package/src/app/app.registry.d.ts +3 -2
  4. package/src/app/app.registry.js +3 -1
  5. package/src/app/app.registry.js.map +1 -1
  6. package/src/app/instances/app.local.instance.js +2 -2
  7. package/src/app/instances/app.local.instance.js.map +1 -1
  8. package/src/auth/auth.registry.d.ts +34 -2
  9. package/src/auth/auth.registry.js +162 -24
  10. package/src/auth/auth.registry.js.map +1 -1
  11. package/src/auth/auth.utils.js +8 -9
  12. package/src/auth/auth.utils.js.map +1 -1
  13. package/src/auth/authorization/authorization.class.d.ts +125 -0
  14. package/src/auth/authorization/authorization.class.js +224 -0
  15. package/src/auth/authorization/authorization.class.js.map +1 -0
  16. package/src/auth/authorization/authorization.types.d.ts +300 -0
  17. package/src/auth/authorization/authorization.types.js +79 -0
  18. package/src/auth/authorization/authorization.types.js.map +1 -0
  19. package/src/auth/authorization/index.d.ts +5 -0
  20. package/src/auth/authorization/index.js +19 -0
  21. package/src/auth/authorization/index.js.map +1 -0
  22. package/src/auth/authorization/orchestrated.authorization.d.ts +242 -0
  23. package/src/auth/authorization/orchestrated.authorization.js +306 -0
  24. package/src/auth/authorization/orchestrated.authorization.js.map +1 -0
  25. package/src/auth/authorization/public.authorization.d.ts +91 -0
  26. package/src/auth/authorization/public.authorization.js +132 -0
  27. package/src/auth/authorization/public.authorization.js.map +1 -0
  28. package/src/auth/authorization/transparent.authorization.d.ts +130 -0
  29. package/src/auth/authorization/transparent.authorization.js +147 -0
  30. package/src/auth/authorization/transparent.authorization.js.map +1 -0
  31. package/src/auth/consent/consent.types.d.ts +111 -0
  32. package/src/auth/consent/consent.types.js +119 -0
  33. package/src/auth/consent/consent.types.js.map +1 -0
  34. package/src/auth/consent/index.d.ts +1 -0
  35. package/src/auth/consent/index.js +13 -0
  36. package/src/auth/consent/index.js.map +1 -0
  37. package/src/auth/detection/auth-provider-detection.d.ts +84 -0
  38. package/src/auth/detection/auth-provider-detection.js +230 -0
  39. package/src/auth/detection/auth-provider-detection.js.map +1 -0
  40. package/src/auth/detection/index.d.ts +1 -0
  41. package/src/auth/detection/index.js +15 -0
  42. package/src/auth/detection/index.js.map +1 -0
  43. package/src/auth/flows/auth.verify.flow.d.ts +110 -0
  44. package/src/auth/flows/auth.verify.flow.js +379 -0
  45. package/src/auth/flows/auth.verify.flow.js.map +1 -0
  46. package/src/auth/flows/oauth.authorize.flow.d.ts +118 -164
  47. package/src/auth/flows/oauth.authorize.flow.js +701 -33
  48. package/src/auth/flows/oauth.authorize.flow.js.map +1 -1
  49. package/src/auth/flows/oauth.callback.flow.d.ts +117 -0
  50. package/src/auth/flows/oauth.callback.flow.js +357 -0
  51. package/src/auth/flows/oauth.callback.flow.js.map +1 -0
  52. package/src/auth/flows/oauth.register.flow.d.ts +32 -125
  53. package/src/auth/flows/oauth.token.flow.d.ts +52 -154
  54. package/src/auth/flows/oauth.token.flow.js +193 -55
  55. package/src/auth/flows/oauth.token.flow.js.map +1 -1
  56. package/src/auth/flows/session.verify.flow.d.ts +66 -321
  57. package/src/auth/flows/session.verify.flow.js +107 -18
  58. package/src/auth/flows/session.verify.flow.js.map +1 -1
  59. package/src/auth/flows/well-known.jwks.flow.d.ts +34 -205
  60. package/src/auth/flows/well-known.jwks.flow.js +15 -8
  61. package/src/auth/flows/well-known.jwks.flow.js.map +1 -1
  62. package/src/auth/flows/well-known.oauth-authorization-server.flow.d.ts +48 -223
  63. package/src/auth/flows/well-known.oauth-authorization-server.flow.js +2 -3
  64. package/src/auth/flows/well-known.oauth-authorization-server.flow.js.map +1 -1
  65. package/src/auth/flows/well-known.prm.flow.d.ts +19 -120
  66. package/src/auth/flows/well-known.prm.flow.js +3 -4
  67. package/src/auth/flows/well-known.prm.flow.js.map +1 -1
  68. package/src/auth/instances/instance.local-primary-auth.d.ts +91 -4
  69. package/src/auth/instances/instance.local-primary-auth.js +236 -6
  70. package/src/auth/instances/instance.local-primary-auth.js.map +1 -1
  71. package/src/auth/instances/instance.remote-primary-auth.d.ts +4 -3
  72. package/src/auth/instances/instance.remote-primary-auth.js +2 -2
  73. package/src/auth/instances/instance.remote-primary-auth.js.map +1 -1
  74. package/src/auth/session/authorization-vault.d.ts +611 -0
  75. package/src/auth/session/authorization-vault.js +817 -0
  76. package/src/auth/session/authorization-vault.js.map +1 -0
  77. package/src/auth/session/authorization.store.d.ts +301 -0
  78. package/src/auth/session/authorization.store.js +323 -0
  79. package/src/auth/session/authorization.store.js.map +1 -0
  80. package/src/auth/session/encrypted-authorization-vault.d.ts +181 -0
  81. package/src/auth/session/encrypted-authorization-vault.js +493 -0
  82. package/src/auth/session/encrypted-authorization-vault.js.map +1 -0
  83. package/src/auth/session/index.d.ts +4 -4
  84. package/src/auth/session/index.js +11 -7
  85. package/src/auth/session/index.js.map +1 -1
  86. package/src/auth/session/session.schema.d.ts +1 -1
  87. package/src/auth/session/session.service.d.ts +1 -1
  88. package/src/auth/session/transport-session.manager.d.ts +101 -0
  89. package/src/auth/session/transport-session.manager.js +300 -0
  90. package/src/auth/session/transport-session.manager.js.map +1 -0
  91. package/src/auth/session/transport-session.types.d.ts +457 -0
  92. package/src/auth/session/transport-session.types.js +110 -0
  93. package/src/auth/session/transport-session.types.js.map +1 -0
  94. package/src/auth/session/utils/session-id.utils.d.ts +14 -2
  95. package/src/auth/session/utils/session-id.utils.js +68 -19
  96. package/src/auth/session/utils/session-id.utils.js.map +1 -1
  97. package/src/auth/session/vault-encryption.d.ts +189 -0
  98. package/src/auth/session/vault-encryption.js +263 -0
  99. package/src/auth/session/vault-encryption.js.map +1 -0
  100. package/src/auth/ui/base-layout.d.ts +188 -0
  101. package/src/auth/ui/base-layout.js +292 -0
  102. package/src/auth/ui/base-layout.js.map +1 -0
  103. package/src/auth/ui/htmx-templates.d.ts +135 -0
  104. package/src/auth/ui/htmx-templates.js +433 -0
  105. package/src/auth/ui/htmx-templates.js.map +1 -0
  106. package/src/auth/ui/index.d.ts +11 -0
  107. package/src/auth/ui/index.js +35 -0
  108. package/src/auth/ui/index.js.map +1 -0
  109. package/src/auth/utils/audience.validator.d.ts +129 -0
  110. package/src/auth/utils/audience.validator.js +196 -0
  111. package/src/auth/utils/audience.validator.js.map +1 -0
  112. package/src/auth/utils/index.d.ts +2 -0
  113. package/src/auth/utils/index.js +7 -0
  114. package/src/auth/utils/index.js.map +1 -0
  115. package/src/auth/utils/www-authenticate.utils.d.ts +97 -0
  116. package/src/auth/utils/www-authenticate.utils.js +183 -0
  117. package/src/auth/utils/www-authenticate.utils.js.map +1 -0
  118. package/src/common/common.schema.d.ts +2 -16
  119. package/src/common/constants.d.ts +3 -0
  120. package/src/common/constants.js +6 -1
  121. package/src/common/constants.js.map +1 -1
  122. package/src/common/decorators/decorator-utils.d.ts +131 -0
  123. package/src/common/decorators/decorator-utils.js +195 -0
  124. package/src/common/decorators/decorator-utils.js.map +1 -0
  125. package/src/common/decorators/front-mcp.decorator.js +3 -2
  126. package/src/common/decorators/front-mcp.decorator.js.map +1 -1
  127. package/src/common/decorators/hook.decorator.d.ts +58 -2
  128. package/src/common/decorators/hook.decorator.js +127 -17
  129. package/src/common/decorators/hook.decorator.js.map +1 -1
  130. package/src/common/decorators/plugin.decorator.d.ts +1 -1
  131. package/src/common/decorators/plugin.decorator.js +11 -10
  132. package/src/common/decorators/plugin.decorator.js.map +1 -1
  133. package/src/common/decorators/resource.decorator.d.ts +32 -3
  134. package/src/common/decorators/resource.decorator.js +46 -4
  135. package/src/common/decorators/resource.decorator.js.map +1 -1
  136. package/src/common/decorators/tool.decorator.d.ts +54 -5
  137. package/src/common/decorators/tool.decorator.js.map +1 -1
  138. package/src/common/dynamic/dynamic.plugin.d.ts +22 -11
  139. package/src/common/dynamic/dynamic.plugin.js +7 -1
  140. package/src/common/dynamic/dynamic.plugin.js.map +1 -1
  141. package/src/common/entries/prompt.entry.d.ts +46 -2
  142. package/src/common/entries/prompt.entry.js +10 -0
  143. package/src/common/entries/prompt.entry.js.map +1 -1
  144. package/src/common/entries/resource.entry.d.ts +69 -6
  145. package/src/common/entries/resource.entry.js +27 -3
  146. package/src/common/entries/resource.entry.js.map +1 -1
  147. package/src/common/entries/scope.entry.d.ts +5 -1
  148. package/src/common/entries/scope.entry.js +3 -3
  149. package/src/common/entries/scope.entry.js.map +1 -1
  150. package/src/common/flow/flow.utils.d.ts +56 -0
  151. package/src/common/flow/flow.utils.js +96 -0
  152. package/src/common/flow/flow.utils.js.map +1 -0
  153. package/src/common/index.d.ts +2 -2
  154. package/src/common/index.js +2 -2
  155. package/src/common/index.js.map +1 -1
  156. package/src/common/interfaces/execution-context.interface.d.ts +59 -0
  157. package/src/common/interfaces/execution-context.interface.js +81 -0
  158. package/src/common/interfaces/execution-context.interface.js.map +1 -0
  159. package/src/common/interfaces/flow.interface.d.ts +1 -1
  160. package/src/common/interfaces/flow.interface.js.map +1 -1
  161. package/src/common/interfaces/index.d.ts +1 -0
  162. package/src/common/interfaces/index.js +1 -0
  163. package/src/common/interfaces/index.js.map +1 -1
  164. package/src/common/interfaces/internal/primary-auth-provider.interface.d.ts +17 -2
  165. package/src/common/interfaces/internal/primary-auth-provider.interface.js +52 -4
  166. package/src/common/interfaces/internal/primary-auth-provider.interface.js.map +1 -1
  167. package/src/common/interfaces/internal/registry.interface.d.ts +16 -2
  168. package/src/common/interfaces/internal/registry.interface.js.map +1 -1
  169. package/src/common/interfaces/plugin.interface.js.map +1 -1
  170. package/src/common/interfaces/prompt.interface.d.ts +53 -4
  171. package/src/common/interfaces/prompt.interface.js +78 -0
  172. package/src/common/interfaces/prompt.interface.js.map +1 -1
  173. package/src/common/interfaces/resource.interface.d.ts +47 -17
  174. package/src/common/interfaces/resource.interface.js +53 -0
  175. package/src/common/interfaces/resource.interface.js.map +1 -1
  176. package/src/common/interfaces/tool.interface.d.ts +39 -22
  177. package/src/common/interfaces/tool.interface.js +61 -34
  178. package/src/common/interfaces/tool.interface.js.map +1 -1
  179. package/src/common/metadata/adapter.metadata.d.ts +1 -9
  180. package/src/common/metadata/app.metadata.d.ts +425 -730
  181. package/src/common/metadata/auth-provider.metadata.d.ts +2 -12
  182. package/src/common/metadata/flow.metadata.d.ts +10 -25
  183. package/src/common/metadata/front-mcp.metadata.d.ts +602 -1023
  184. package/src/common/metadata/front-mcp.metadata.js +6 -4
  185. package/src/common/metadata/front-mcp.metadata.js.map +1 -1
  186. package/src/common/metadata/hook.metadata.d.ts +1 -1
  187. package/src/common/metadata/hook.metadata.js.map +1 -1
  188. package/src/common/metadata/index.d.ts +1 -0
  189. package/src/common/metadata/index.js +1 -0
  190. package/src/common/metadata/index.js.map +1 -1
  191. package/src/common/metadata/logger.metadata.d.ts +1 -9
  192. package/src/common/metadata/plugin.metadata.d.ts +8 -30
  193. package/src/common/metadata/prompt.metadata.d.ts +4 -161
  194. package/src/common/metadata/provider.metadata.d.ts +2 -12
  195. package/src/common/metadata/resource.metadata.d.ts +6 -98
  196. package/src/common/metadata/resource.metadata.js +15 -6
  197. package/src/common/metadata/resource.metadata.js.map +1 -1
  198. package/src/common/metadata/tool-ui.metadata.d.ts +10 -0
  199. package/src/common/metadata/tool-ui.metadata.js +12 -0
  200. package/src/common/metadata/tool-ui.metadata.js.map +1 -0
  201. package/src/common/metadata/tool.metadata.d.ts +78 -199
  202. package/src/common/metadata/tool.metadata.js +11 -14
  203. package/src/common/metadata/tool.metadata.js.map +1 -1
  204. package/src/common/providers/base-config.provider.d.ts +84 -0
  205. package/src/common/providers/base-config.provider.js +128 -0
  206. package/src/common/providers/base-config.provider.js.map +1 -0
  207. package/src/common/records/plugin.record.d.ts +5 -6
  208. package/src/common/records/plugin.record.js.map +1 -1
  209. package/src/common/records/prompt.record.js.map +1 -1
  210. package/src/common/records/resource.record.d.ts +17 -1
  211. package/src/common/records/resource.record.js +12 -6
  212. package/src/common/records/resource.record.js.map +1 -1
  213. package/src/common/records/tool.record.js.map +1 -1
  214. package/src/common/schemas/annotated-class.schema.d.ts +9 -9
  215. package/src/common/schemas/annotated-class.schema.js +92 -27
  216. package/src/common/schemas/annotated-class.schema.js.map +1 -1
  217. package/src/common/schemas/http-input.schema.d.ts +6 -30
  218. package/src/common/schemas/http-output.schema.d.ts +326 -1630
  219. package/src/common/schemas/http-output.schema.js +39 -1
  220. package/src/common/schemas/http-output.schema.js.map +1 -1
  221. package/src/common/tokens/front-mcp.tokens.js +4 -1
  222. package/src/common/tokens/front-mcp.tokens.js.map +1 -1
  223. package/src/common/tokens/resource.tokens.d.ts +2 -0
  224. package/src/common/tokens/resource.tokens.js +4 -1
  225. package/src/common/tokens/resource.tokens.js.map +1 -1
  226. package/src/common/tokens/tool.tokens.d.ts +2 -0
  227. package/src/common/tokens/tool.tokens.js +2 -0
  228. package/src/common/tokens/tool.tokens.js.map +1 -1
  229. package/src/common/types/auth/jwt.types.d.ts +5 -31
  230. package/src/common/types/auth/session.types.d.ts +97 -192
  231. package/src/common/types/auth/session.types.js +24 -11
  232. package/src/common/types/auth/session.types.js.map +1 -1
  233. package/src/common/types/options/auth.options.d.ts +1013 -490
  234. package/src/common/types/options/auth.options.js +554 -36
  235. package/src/common/types/options/auth.options.js.map +1 -1
  236. package/src/common/types/options/http.options.d.ts +1 -9
  237. package/src/common/types/options/logging.options.d.ts +7 -13
  238. package/src/common/types/options/logging.options.js +4 -0
  239. package/src/common/types/options/logging.options.js.map +1 -1
  240. package/src/common/types/options/server-info.options.d.ts +3 -31
  241. package/src/common/types/options/session.options.d.ts +90 -10
  242. package/src/common/types/options/session.options.js +26 -3
  243. package/src/common/types/options/session.options.js.map +1 -1
  244. package/src/common/utils/decide-request-intent.utils.d.ts +8 -46
  245. package/src/common/utils/decide-request-intent.utils.js +88 -23
  246. package/src/common/utils/decide-request-intent.utils.js.map +1 -1
  247. package/src/completion/flows/complete.flow.d.ts +74 -0
  248. package/src/completion/flows/complete.flow.js +199 -0
  249. package/src/completion/flows/complete.flow.js.map +1 -0
  250. package/src/errors/authorization-required.error.d.ts +189 -0
  251. package/src/errors/authorization-required.error.js +274 -0
  252. package/src/errors/authorization-required.error.js.map +1 -0
  253. package/src/errors/index.d.ts +2 -1
  254. package/src/errors/index.js +17 -1
  255. package/src/errors/index.js.map +1 -1
  256. package/src/errors/mcp.error.d.ts +101 -1
  257. package/src/errors/mcp.error.js +147 -2
  258. package/src/errors/mcp.error.js.map +1 -1
  259. package/src/flows/flow.instance.js +4 -3
  260. package/src/flows/flow.instance.js.map +1 -1
  261. package/src/flows/flow.registry.js.map +1 -1
  262. package/src/flows/flow.stages.js +14 -11
  263. package/src/flows/flow.stages.js.map +1 -1
  264. package/src/front-mcp/front-mcp.providers.d.ts +464 -102
  265. package/src/front-mcp/front-mcp.providers.js +3 -5
  266. package/src/front-mcp/front-mcp.providers.js.map +1 -1
  267. package/src/hooks/hook.instance.d.ts +1 -1
  268. package/src/hooks/hook.instance.js +5 -2
  269. package/src/hooks/hook.instance.js.map +1 -1
  270. package/src/hooks/hook.registry.js +7 -5
  271. package/src/hooks/hook.registry.js.map +1 -1
  272. package/src/index.d.ts +28 -9
  273. package/src/index.js +5 -1
  274. package/src/index.js.map +1 -1
  275. package/src/logger/instances/instance.logger.js +3 -2
  276. package/src/logger/instances/instance.logger.js.map +1 -1
  277. package/src/logger/logger.registry.js +7 -2
  278. package/src/logger/logger.registry.js.map +1 -1
  279. package/src/logging/flows/set-level.flow.d.ts +62 -0
  280. package/src/logging/flows/set-level.flow.js +108 -0
  281. package/src/logging/flows/set-level.flow.js.map +1 -0
  282. package/src/mcp-apps/csp.d.ts +111 -0
  283. package/src/mcp-apps/csp.js +267 -0
  284. package/src/mcp-apps/csp.js.map +1 -0
  285. package/src/mcp-apps/index.d.ts +23 -0
  286. package/src/mcp-apps/index.js +91 -0
  287. package/src/mcp-apps/index.js.map +1 -0
  288. package/src/mcp-apps/schemas.d.ts +403 -0
  289. package/src/mcp-apps/schemas.js +345 -0
  290. package/src/mcp-apps/schemas.js.map +1 -0
  291. package/src/mcp-apps/template.d.ts +94 -0
  292. package/src/mcp-apps/template.js +419 -0
  293. package/src/mcp-apps/template.js.map +1 -0
  294. package/src/mcp-apps/types.d.ts +323 -0
  295. package/src/mcp-apps/types.js +59 -0
  296. package/src/mcp-apps/types.js.map +1 -0
  297. package/src/notification/index.d.ts +1 -0
  298. package/src/notification/index.js +13 -0
  299. package/src/notification/index.js.map +1 -0
  300. package/src/notification/notification.service.d.ts +378 -0
  301. package/src/notification/notification.service.js +727 -0
  302. package/src/notification/notification.service.js.map +1 -0
  303. package/src/plugin/plugin.registry.js +12 -9
  304. package/src/plugin/plugin.registry.js.map +1 -1
  305. package/src/prompt/flows/get-prompt.flow.d.ts +153 -0
  306. package/src/prompt/flows/get-prompt.flow.js +214 -0
  307. package/src/prompt/flows/get-prompt.flow.js.map +1 -0
  308. package/src/prompt/flows/prompts-list.flow.d.ts +67 -0
  309. package/src/prompt/flows/prompts-list.flow.js +176 -0
  310. package/src/prompt/flows/prompts-list.flow.js.map +1 -0
  311. package/src/prompt/index.d.ts +7 -0
  312. package/src/prompt/index.js +17 -0
  313. package/src/prompt/index.js.map +1 -0
  314. package/src/prompt/prompt.events.d.ts +17 -0
  315. package/src/prompt/prompt.events.js +25 -0
  316. package/src/prompt/prompt.events.js.map +1 -0
  317. package/src/prompt/prompt.instance.d.ts +30 -0
  318. package/src/prompt/prompt.instance.js +120 -0
  319. package/src/prompt/prompt.instance.js.map +1 -0
  320. package/src/prompt/prompt.registry.d.ts +79 -12
  321. package/src/prompt/prompt.registry.js +360 -15
  322. package/src/prompt/prompt.registry.js.map +1 -1
  323. package/src/prompt/prompt.types.d.ts +26 -0
  324. package/src/prompt/prompt.types.js +11 -0
  325. package/src/prompt/prompt.types.js.map +1 -0
  326. package/src/prompt/prompt.utils.d.ts +26 -0
  327. package/src/prompt/prompt.utils.js +136 -0
  328. package/src/prompt/prompt.utils.js.map +1 -0
  329. package/src/provider/provider.registry.d.ts +12 -5
  330. package/src/provider/provider.registry.js +30 -138
  331. package/src/provider/provider.registry.js.map +1 -1
  332. package/src/regsitry/registry.base.d.ts +1 -1
  333. package/src/regsitry/registry.base.js.map +1 -1
  334. package/src/resource/flows/read-resource.flow.d.ts +91 -0
  335. package/src/resource/flows/read-resource.flow.js +270 -0
  336. package/src/resource/flows/read-resource.flow.js.map +1 -0
  337. package/src/resource/flows/resource-templates-list.flow.d.ts +64 -0
  338. package/src/resource/flows/resource-templates-list.flow.js +191 -0
  339. package/src/resource/flows/resource-templates-list.flow.js.map +1 -0
  340. package/src/resource/flows/resources-list.flow.d.ts +64 -0
  341. package/src/resource/flows/resources-list.flow.js +196 -0
  342. package/src/resource/flows/resources-list.flow.js.map +1 -0
  343. package/src/resource/flows/subscribe-resource.flow.d.ts +45 -0
  344. package/src/resource/flows/subscribe-resource.flow.js +123 -0
  345. package/src/resource/flows/subscribe-resource.flow.js.map +1 -0
  346. package/src/resource/flows/unsubscribe-resource.flow.d.ts +44 -0
  347. package/src/resource/flows/unsubscribe-resource.flow.js +107 -0
  348. package/src/resource/flows/unsubscribe-resource.flow.js.map +1 -0
  349. package/src/resource/index.d.ts +8 -0
  350. package/src/resource/index.js +20 -0
  351. package/src/resource/index.js.map +1 -0
  352. package/src/resource/resource.events.d.ts +24 -0
  353. package/src/resource/resource.events.js +17 -0
  354. package/src/resource/resource.events.js.map +1 -0
  355. package/src/resource/resource.instance.d.ts +35 -0
  356. package/src/resource/resource.instance.js +163 -0
  357. package/src/resource/resource.instance.js.map +1 -0
  358. package/src/resource/resource.registry.d.ts +106 -12
  359. package/src/resource/resource.registry.js +449 -13
  360. package/src/resource/resource.registry.js.map +1 -1
  361. package/src/resource/resource.types.d.ts +35 -0
  362. package/src/resource/resource.types.js +11 -0
  363. package/src/resource/resource.types.js.map +1 -0
  364. package/src/resource/resource.utils.d.ts +30 -0
  365. package/src/resource/resource.utils.js +151 -0
  366. package/src/resource/resource.utils.js.map +1 -0
  367. package/src/scope/flows/http.request.flow.d.ts +48 -330
  368. package/src/scope/flows/http.request.flow.js +306 -78
  369. package/src/scope/flows/http.request.flow.js.map +1 -1
  370. package/src/scope/scope.instance.d.ts +12 -0
  371. package/src/scope/scope.instance.js +145 -15
  372. package/src/scope/scope.instance.js.map +1 -1
  373. package/src/tool/flows/call-tool.flow.d.ts +64 -1110
  374. package/src/tool/flows/call-tool.flow.js +303 -15
  375. package/src/tool/flows/call-tool.flow.js.map +1 -1
  376. package/src/tool/flows/tools-list.flow.d.ts +32 -473
  377. package/src/tool/flows/tools-list.flow.js +121 -40
  378. package/src/tool/flows/tools-list.flow.js.map +1 -1
  379. package/src/tool/tool.events.d.ts +8 -1
  380. package/src/tool/tool.events.js.map +1 -1
  381. package/src/tool/tool.instance.d.ts +3 -1
  382. package/src/tool/tool.instance.js +17 -3
  383. package/src/tool/tool.instance.js.map +1 -1
  384. package/src/tool/tool.registry.d.ts +7 -1
  385. package/src/tool/tool.registry.js +26 -10
  386. package/src/tool/tool.registry.js.map +1 -1
  387. package/src/tool/tool.types.d.ts +4 -4
  388. package/src/tool/tool.types.js.map +1 -1
  389. package/src/tool/tool.utils.d.ts +3 -12
  390. package/src/tool/tool.utils.js +39 -193
  391. package/src/tool/tool.utils.js.map +1 -1
  392. package/src/tool/ui/index.d.ts +22 -0
  393. package/src/tool/ui/index.js +63 -0
  394. package/src/tool/ui/index.js.map +1 -0
  395. package/src/tool/ui/platform-adapters.d.ts +10 -0
  396. package/src/tool/ui/platform-adapters.js +18 -0
  397. package/src/tool/ui/platform-adapters.js.map +1 -0
  398. package/src/tool/ui/template-helpers.d.ts +46 -0
  399. package/src/tool/ui/template-helpers.js +112 -0
  400. package/src/tool/ui/template-helpers.js.map +1 -0
  401. package/src/tool/ui/ui-resource-template.d.ts +34 -0
  402. package/src/tool/ui/ui-resource-template.js +64 -0
  403. package/src/tool/ui/ui-resource-template.js.map +1 -0
  404. package/src/tool/ui/ui-resource.handler.d.ts +74 -0
  405. package/src/tool/ui/ui-resource.handler.js +129 -0
  406. package/src/tool/ui/ui-resource.handler.js.map +1 -0
  407. package/src/transport/adapters/transport.local.adapter.d.ts +2 -2
  408. package/src/transport/adapters/transport.local.adapter.js +28 -7
  409. package/src/transport/adapters/transport.local.adapter.js.map +1 -1
  410. package/src/transport/adapters/transport.sse.adapter.d.ts +2 -2
  411. package/src/transport/adapters/transport.sse.adapter.js +4 -3
  412. package/src/transport/adapters/transport.sse.adapter.js.map +1 -1
  413. package/src/transport/adapters/transport.streamable-http.adapter.d.ts +10 -3
  414. package/src/transport/adapters/transport.streamable-http.adapter.js +54 -8
  415. package/src/transport/adapters/transport.streamable-http.adapter.js.map +1 -1
  416. package/src/transport/flows/handle.sse.flow.d.ts +29 -63
  417. package/src/transport/flows/handle.sse.flow.js +78 -10
  418. package/src/transport/flows/handle.sse.flow.js.map +1 -1
  419. package/src/transport/flows/handle.stateless-http.flow.d.ts +29 -0
  420. package/src/transport/flows/handle.stateless-http.flow.js +102 -0
  421. package/src/transport/flows/handle.stateless-http.flow.js.map +1 -0
  422. package/src/transport/flows/handle.streamable-http.flow.d.ts +32 -64
  423. package/src/transport/flows/handle.streamable-http.flow.js +158 -26
  424. package/src/transport/flows/handle.streamable-http.flow.js.map +1 -1
  425. package/src/transport/legacy/legacy.sse.tranporter.d.ts +9 -0
  426. package/src/transport/legacy/legacy.sse.tranporter.js +17 -2
  427. package/src/transport/legacy/legacy.sse.tranporter.js.map +1 -1
  428. package/src/transport/mcp-handlers/call-tool-request.handler.js +27 -1
  429. package/src/transport/mcp-handlers/call-tool-request.handler.js.map +1 -1
  430. package/src/transport/mcp-handlers/complete-request.handler.d.ts +69 -0
  431. package/src/transport/mcp-handlers/complete-request.handler.js +11 -0
  432. package/src/transport/mcp-handlers/complete-request.handler.js.map +1 -0
  433. package/src/transport/mcp-handlers/get-prompt-request.handler.d.ts +87 -0
  434. package/src/transport/mcp-handlers/get-prompt-request.handler.js +11 -0
  435. package/src/transport/mcp-handlers/get-prompt-request.handler.js.map +1 -0
  436. package/src/transport/mcp-handlers/index.d.ts +517 -208
  437. package/src/transport/mcp-handlers/index.js +39 -2
  438. package/src/transport/mcp-handlers/index.js.map +1 -1
  439. package/src/transport/mcp-handlers/initialize-request.handler.d.ts +1 -1
  440. package/src/transport/mcp-handlers/initialize-request.handler.js +73 -7
  441. package/src/transport/mcp-handlers/initialize-request.handler.js.map +1 -1
  442. package/src/transport/mcp-handlers/list-prompts-request.handler.d.ts +54 -0
  443. package/src/transport/mcp-handlers/list-prompts-request.handler.js +11 -0
  444. package/src/transport/mcp-handlers/list-prompts-request.handler.js.map +1 -0
  445. package/src/transport/mcp-handlers/list-resource-templates-request.handler.d.ts +51 -0
  446. package/src/transport/mcp-handlers/list-resource-templates-request.handler.js +12 -0
  447. package/src/transport/mcp-handlers/list-resource-templates-request.handler.js.map +1 -0
  448. package/src/transport/mcp-handlers/list-resources-request.handler.d.ts +51 -0
  449. package/src/transport/mcp-handlers/list-resources-request.handler.js +12 -0
  450. package/src/transport/mcp-handlers/list-resources-request.handler.js.map +1 -0
  451. package/src/transport/mcp-handlers/list-tools-request.handler.d.ts +19 -146
  452. package/src/transport/mcp-handlers/logging-set-level-request.handler.d.ts +46 -0
  453. package/src/transport/mcp-handlers/logging-set-level-request.handler.js +34 -0
  454. package/src/transport/mcp-handlers/logging-set-level-request.handler.js.map +1 -0
  455. package/src/transport/mcp-handlers/mcp-handlers.types.d.ts +3 -7
  456. package/src/transport/mcp-handlers/mcp-handlers.types.js.map +1 -1
  457. package/src/transport/mcp-handlers/read-resource-request.handler.d.ts +46 -0
  458. package/src/transport/mcp-handlers/read-resource-request.handler.js +12 -0
  459. package/src/transport/mcp-handlers/read-resource-request.handler.js.map +1 -0
  460. package/src/transport/mcp-handlers/roots-list-changed-notification.handler.d.ts +11 -0
  461. package/src/transport/mcp-handlers/roots-list-changed-notification.handler.js +26 -0
  462. package/src/transport/mcp-handlers/roots-list-changed-notification.handler.js.map +1 -0
  463. package/src/transport/mcp-handlers/subscribe-request.handler.d.ts +37 -0
  464. package/src/transport/mcp-handlers/subscribe-request.handler.js +34 -0
  465. package/src/transport/mcp-handlers/subscribe-request.handler.js.map +1 -0
  466. package/src/transport/mcp-handlers/unsubscribe-request.handler.d.ts +37 -0
  467. package/src/transport/mcp-handlers/unsubscribe-request.handler.js +34 -0
  468. package/src/transport/mcp-handlers/unsubscribe-request.handler.js.map +1 -0
  469. package/src/transport/transport.local.js +7 -2
  470. package/src/transport/transport.local.js.map +1 -1
  471. package/src/transport/transport.registry.d.ts +30 -0
  472. package/src/transport/transport.registry.js +84 -1
  473. package/src/transport/transport.registry.js.map +1 -1
  474. package/src/transport/transport.types.d.ts +3 -3
  475. package/src/transport/transport.types.js.map +1 -1
  476. package/src/utils/content.utils.d.ts +48 -0
  477. package/src/utils/content.utils.js +194 -0
  478. package/src/utils/content.utils.js.map +1 -0
  479. package/src/utils/index.d.ts +8 -0
  480. package/src/utils/index.js +55 -0
  481. package/src/utils/index.js.map +1 -0
  482. package/src/utils/lineage.utils.d.ts +40 -0
  483. package/src/utils/lineage.utils.js +82 -0
  484. package/src/utils/lineage.utils.js.map +1 -0
  485. package/src/utils/naming.utils.d.ts +46 -0
  486. package/src/utils/naming.utils.js +136 -0
  487. package/src/utils/naming.utils.js.map +1 -0
  488. package/src/utils/types.utils.d.ts +2 -2
  489. package/src/utils/types.utils.js.map +1 -1
  490. package/src/utils/uri-template.utils.d.ts +57 -0
  491. package/src/utils/uri-template.utils.js +113 -0
  492. package/src/utils/uri-template.utils.js.map +1 -0
  493. package/src/utils/uri-validation.utils.d.ts +40 -0
  494. package/src/utils/uri-validation.utils.js +76 -0
  495. package/src/utils/uri-validation.utils.js.map +1 -0
  496. package/src/__test-utils__/fixtures/hook.fixtures.d.ts +0 -46
  497. package/src/__test-utils__/fixtures/hook.fixtures.js +0 -114
  498. package/src/__test-utils__/fixtures/hook.fixtures.js.map +0 -1
  499. package/src/__test-utils__/fixtures/index.d.ts +0 -7
  500. package/src/__test-utils__/fixtures/index.js +0 -11
  501. package/src/__test-utils__/fixtures/index.js.map +0 -1
  502. package/src/__test-utils__/fixtures/plugin.fixtures.d.ts +0 -46
  503. package/src/__test-utils__/fixtures/plugin.fixtures.js +0 -127
  504. package/src/__test-utils__/fixtures/plugin.fixtures.js.map +0 -1
  505. package/src/__test-utils__/fixtures/provider.fixtures.d.ts +0 -69
  506. package/src/__test-utils__/fixtures/provider.fixtures.js +0 -131
  507. package/src/__test-utils__/fixtures/provider.fixtures.js.map +0 -1
  508. package/src/__test-utils__/fixtures/scope.fixtures.d.ts +0 -14
  509. package/src/__test-utils__/fixtures/scope.fixtures.js +0 -59
  510. package/src/__test-utils__/fixtures/scope.fixtures.js.map +0 -1
  511. package/src/__test-utils__/fixtures/tool.fixtures.d.ts +0 -36
  512. package/src/__test-utils__/fixtures/tool.fixtures.js +0 -91
  513. package/src/__test-utils__/fixtures/tool.fixtures.js.map +0 -1
  514. package/src/__test-utils__/helpers/assertion.helpers.d.ts +0 -45
  515. package/src/__test-utils__/helpers/assertion.helpers.js +0 -153
  516. package/src/__test-utils__/helpers/assertion.helpers.js.map +0 -1
  517. package/src/__test-utils__/helpers/async.helpers.d.ts +0 -48
  518. package/src/__test-utils__/helpers/async.helpers.js +0 -112
  519. package/src/__test-utils__/helpers/async.helpers.js.map +0 -1
  520. package/src/__test-utils__/helpers/index.d.ts +0 -6
  521. package/src/__test-utils__/helpers/index.js +0 -10
  522. package/src/__test-utils__/helpers/index.js.map +0 -1
  523. package/src/__test-utils__/helpers/setup.helpers.d.ts +0 -54
  524. package/src/__test-utils__/helpers/setup.helpers.js +0 -106
  525. package/src/__test-utils__/helpers/setup.helpers.js.map +0 -1
  526. package/src/__test-utils__/index.d.ts +0 -9
  527. package/src/__test-utils__/index.js +0 -14
  528. package/src/__test-utils__/index.js.map +0 -1
  529. package/src/__test-utils__/mocks/flow-instance.mock.d.ts +0 -50
  530. package/src/__test-utils__/mocks/flow-instance.mock.js +0 -72
  531. package/src/__test-utils__/mocks/flow-instance.mock.js.map +0 -1
  532. package/src/__test-utils__/mocks/hook-registry.mock.d.ts +0 -25
  533. package/src/__test-utils__/mocks/hook-registry.mock.js +0 -65
  534. package/src/__test-utils__/mocks/hook-registry.mock.js.map +0 -1
  535. package/src/__test-utils__/mocks/index.d.ts +0 -8
  536. package/src/__test-utils__/mocks/index.js +0 -12
  537. package/src/__test-utils__/mocks/index.js.map +0 -1
  538. package/src/__test-utils__/mocks/plugin-registry.mock.d.ts +0 -43
  539. package/src/__test-utils__/mocks/plugin-registry.mock.js +0 -70
  540. package/src/__test-utils__/mocks/plugin-registry.mock.js.map +0 -1
  541. package/src/__test-utils__/mocks/provider-registry.mock.d.ts +0 -39
  542. package/src/__test-utils__/mocks/provider-registry.mock.js +0 -72
  543. package/src/__test-utils__/mocks/provider-registry.mock.js.map +0 -1
  544. package/src/__test-utils__/mocks/tool-registry.mock.d.ts +0 -43
  545. package/src/__test-utils__/mocks/tool-registry.mock.js +0 -79
  546. package/src/__test-utils__/mocks/tool-registry.mock.js.map +0 -1
  547. package/src/auth/path.utils.d.ts +0 -20
  548. package/src/auth/path.utils.js +0 -71
  549. package/src/auth/path.utils.js.map +0 -1
  550. package/src/common/decorators-old/async-with.decorator.d.ts +0 -10
  551. package/src/common/decorators-old/async-with.decorator.js +0 -24
  552. package/src/common/decorators-old/async-with.decorator.js.map +0 -1
  553. package/src/common/decorators-old/auth-hook.decorator.d.ts +0 -14
  554. package/src/common/decorators-old/auth-hook.decorator.js +0 -27
  555. package/src/common/decorators-old/auth-hook.decorator.js.map +0 -1
  556. package/src/common/decorators-old/session-hook.decorator.d.ts +0 -14
  557. package/src/common/decorators-old/session-hook.decorator.js +0 -27
  558. package/src/common/decorators-old/session-hook.decorator.js.map +0 -1
@@ -1,72 +0,0 @@
1
- "use strict";
2
- /// <reference types="jest" />
3
- /**
4
- * Mock factory for FlowInstance
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.createMockFlowInstance = createMockFlowInstance;
8
- exports.createMockFlowContext = createMockFlowContext;
9
- exports.createMockStageHandler = createMockStageHandler;
10
- /**
11
- * Creates a mock FlowInstance for testing
12
- */
13
- function createMockFlowInstance(overrides = {}) {
14
- const stages = new Map();
15
- return {
16
- stages,
17
- name: 'TestFlow',
18
- metadata: {
19
- name: 'TestFlow',
20
- stages: ['pre', 'execute', 'post', 'finalize'],
21
- },
22
- execute: jest.fn(async (context) => {
23
- return { success: true, result: 'mock result' };
24
- }),
25
- addStage: jest.fn((stageName, handler) => {
26
- stages.set(stageName, handler);
27
- }),
28
- getStage: jest.fn((stageName) => {
29
- return stages.get(stageName);
30
- }),
31
- hasStage: jest.fn((stageName) => {
32
- return stages.has(stageName);
33
- }),
34
- run: jest.fn(async (context) => {
35
- // Mock run implementation
36
- return context;
37
- }),
38
- ...overrides,
39
- };
40
- }
41
- /**
42
- * Creates a mock flow context
43
- */
44
- function createMockFlowContext(overrides = {}) {
45
- return {
46
- flowName: 'TestFlow',
47
- stage: 'execute',
48
- data: {},
49
- result: undefined,
50
- error: undefined,
51
- respond: jest.fn((result) => {
52
- return { responded: true, result };
53
- }),
54
- fail: jest.fn((error) => {
55
- return { failed: true, error };
56
- }),
57
- abort: jest.fn(() => {
58
- return { aborted: true };
59
- }),
60
- next: jest.fn(async () => {
61
- return { continued: true };
62
- }),
63
- ...overrides,
64
- };
65
- }
66
- /**
67
- * Creates a mock stage handler
68
- */
69
- function createMockStageHandler(implementation) {
70
- return jest.fn(implementation || (async (ctx) => ctx));
71
- }
72
- //# sourceMappingURL=flow-instance.mock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"flow-instance.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/flow-instance.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAKH,wDAkCC;AAKD,sDA0BC;AAKD,wDAEC;AA3ED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,MAAM,GAAG,IAAI,GAAG,EAAe,CAAC;IAEtC,OAAO;QACL,MAAM;QACN,IAAI,EAAE,UAAU;QAChB,QAAQ,EAAE;YACR,IAAI,EAAE,UAAU;YAChB,MAAM,EAAE,CAAC,KAAK,EAAE,SAAS,EAAE,MAAM,EAAE,UAAU,CAAC;SAC/C;QAED,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;YACtC,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,MAAM,EAAE,aAAa,EAAE,CAAC;QAClD,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,OAAY,EAAE,EAAE;YACpD,MAAM,CAAC,GAAG,CAAC,SAAS,EAAE,OAAO,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,EAAE;YACtC,OAAO,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAiB,EAAE,EAAE;YACtC,OAAO,MAAM,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,OAAY,EAAE,EAAE;YAClC,0BAA0B;YAC1B,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,qBAAqB,CAAC,YAA0B,EAAE;IAChE,OAAO;QACL,QAAQ,EAAE,UAAU;QACpB,KAAK,EAAE,SAAS;QAChB,IAAI,EAAE,EAAE;QACR,MAAM,EAAE,SAAS;QACjB,KAAK,EAAE,SAAS;QAEhB,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,MAAW,EAAE,EAAE;YAC/B,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;QACrC,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAU,EAAE,EAAE;YAC3B,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,KAAK,EAAE,CAAC;QACjC,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC;QAC3B,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE;YACvB,OAAO,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC;QAC7B,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,cAA2C;IAChF,OAAO,IAAI,CAAC,EAAE,CAAC,cAAc,IAAI,CAAC,KAAK,EAAE,GAAQ,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;AAC9D,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for FlowInstance\n */\n\n/**\n * Creates a mock FlowInstance for testing\n */\nexport function createMockFlowInstance(overrides: Partial<any> = {}) {\n const stages = new Map<string, any>();\n\n return {\n stages,\n name: 'TestFlow',\n metadata: {\n name: 'TestFlow',\n stages: ['pre', 'execute', 'post', 'finalize'],\n },\n\n execute: jest.fn(async (context: any) => {\n return { success: true, result: 'mock result' };\n }),\n\n addStage: jest.fn((stageName: string, handler: any) => {\n stages.set(stageName, handler);\n }),\n\n getStage: jest.fn((stageName: string) => {\n return stages.get(stageName);\n }),\n\n hasStage: jest.fn((stageName: string) => {\n return stages.has(stageName);\n }),\n\n run: jest.fn(async (context: any) => {\n // Mock run implementation\n return context;\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock flow context\n */\nexport function createMockFlowContext(overrides: Partial<any> = {}) {\n return {\n flowName: 'TestFlow',\n stage: 'execute',\n data: {},\n result: undefined,\n error: undefined,\n\n respond: jest.fn((result: any) => {\n return { responded: true, result };\n }),\n\n fail: jest.fn((error: any) => {\n return { failed: true, error };\n }),\n\n abort: jest.fn(() => {\n return { aborted: true };\n }),\n\n next: jest.fn(async () => {\n return { continued: true };\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock stage handler\n */\nexport function createMockStageHandler(implementation?: (ctx: any) => Promise<any>) {\n return jest.fn(implementation || (async (ctx: any) => ctx));\n}\n"]}
@@ -1,25 +0,0 @@
1
- /**
2
- * Mock factory for HookRegistry
3
- */
4
- import { HookMetadata } from '../../common/metadata';
5
- /**
6
- * Creates a mock HookRegistry for testing
7
- */
8
- export declare function createMockHookRegistry(overrides?: Partial<any>): {
9
- hooks: HookMetadata<keyof ExtendFlows, string, any>[];
10
- register: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>, [hookMetadata: HookMetadata<keyof ExtendFlows, string, any>], any>;
11
- getHooks: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [], any>;
12
- getHooksForFlow: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string], any>;
13
- getHooksForStage: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string, stage: string], any>;
14
- getHooksByPriority: jest.Mock<HookMetadata<keyof ExtendFlows, string, any>[], [flowName: string, stage: string], any>;
15
- clear: jest.Mock<void, [], any>;
16
- executeHooks: jest.Mock<Promise<any>, [flowName: string, stage: string, context: any], any>;
17
- };
18
- /**
19
- * Creates a mock hook entry
20
- */
21
- export declare function createMockHookEntry(flowName: string, stage: string, priority?: number): HookMetadata;
22
- /**
23
- * Adds a hook to a mock registry
24
- */
25
- export declare function addHookToMock(registry: ReturnType<typeof createMockHookRegistry>, hookMetadata: HookMetadata): void;
@@ -1,65 +0,0 @@
1
- "use strict";
2
- /// <reference types="jest" />
3
- /**
4
- * Mock factory for HookRegistry
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.createMockHookRegistry = createMockHookRegistry;
8
- exports.createMockHookEntry = createMockHookEntry;
9
- exports.addHookToMock = addHookToMock;
10
- /**
11
- * Creates a mock HookRegistry for testing
12
- */
13
- function createMockHookRegistry(overrides = {}) {
14
- const hooks = [];
15
- return {
16
- hooks,
17
- register: jest.fn((hookMetadata) => {
18
- hooks.push(hookMetadata);
19
- return hookMetadata;
20
- }),
21
- getHooks: jest.fn(() => hooks),
22
- getHooksForFlow: jest.fn((flowName) => {
23
- return hooks.filter((h) => h.flow === flowName);
24
- }),
25
- getHooksForStage: jest.fn((flowName, stage) => {
26
- return hooks.filter((h) => h.flow === flowName && h.stage === stage);
27
- }),
28
- getHooksByPriority: jest.fn((flowName, stage) => {
29
- return hooks
30
- .filter((h) => h.flow === flowName && h.stage === stage)
31
- .sort((a, b) => (a.priority || 0) - (b.priority || 0));
32
- }),
33
- clear: jest.fn(() => {
34
- hooks.length = 0;
35
- }),
36
- executeHooks: jest.fn(async (flowName, stage, context) => {
37
- const stageHooks = hooks.filter((h) => h.flow === flowName && h.stage === stage);
38
- for (const hook of stageHooks) {
39
- // Mock hook execution
40
- }
41
- return context;
42
- }),
43
- ...overrides,
44
- };
45
- }
46
- /**
47
- * Creates a mock hook entry
48
- */
49
- function createMockHookEntry(flowName, stage, priority = 0) {
50
- return {
51
- type: 'stage',
52
- flow: flowName,
53
- stage,
54
- target: Symbol('MOCK_HOOK'),
55
- method: 'onStage',
56
- priority,
57
- };
58
- }
59
- /**
60
- * Adds a hook to a mock registry
61
- */
62
- function addHookToMock(registry, hookMetadata) {
63
- registry.hooks.push(hookMetadata);
64
- }
65
- //# sourceMappingURL=hook-registry.mock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"hook-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/hook-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,wDAyCC;AAKD,kDAaC;AAKD,sCAKC;AAxED;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,KAAK,GAAmB,EAAE,CAAC;IAEjC,OAAO;QACL,KAAK;QAEL,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,YAA0B,EAAE,EAAE;YAC/C,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YACzB,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,KAAK,CAAC;QAE9B,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,EAAE;YAC5C,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC;QAClD,CAAC,CAAC;QAEF,gBAAgB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,KAAa,EAAE,EAAE;YAC5D,OAAO,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;QACvE,CAAC,CAAC;QAEF,kBAAkB,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,QAAgB,EAAE,KAAa,EAAE,EAAE;YAC9D,OAAO,KAAK;iBACT,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC;iBACvD,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,IAAI,CAAC,CAAC,CAAC,CAAC;QAC3D,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;QACnB,CAAC,CAAC;QAEF,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,QAAgB,EAAE,KAAa,EAAE,OAAY,EAAE,EAAE;YAC5E,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,IAAI,KAAK,QAAQ,IAAI,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;YACjF,KAAK,MAAM,IAAI,IAAI,UAAU,EAAE,CAAC;gBAC9B,sBAAsB;YACxB,CAAC;YACD,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,QAAgB,EAChB,KAAa,EACb,WAAmB,CAAC;IAEpB,OAAO;QACL,IAAI,EAAE,OAAO;QACb,IAAI,EAAE,QAAe;QACrB,KAAK;QACL,MAAM,EAAE,MAAM,CAAC,WAAW,CAAC;QAC3B,MAAM,EAAE,SAAS;QACjB,QAAQ;KACT,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAC3B,QAAmD,EACnD,YAA0B;IAE1B,QAAQ,CAAC,KAAK,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;AACpC,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for HookRegistry\n */\n\nimport { HookMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock HookRegistry for testing\n */\nexport function createMockHookRegistry(overrides: Partial<any> = {}) {\n const hooks: HookMetadata[] = [];\n\n return {\n hooks,\n\n register: jest.fn((hookMetadata: HookMetadata) => {\n hooks.push(hookMetadata);\n return hookMetadata;\n }),\n\n getHooks: jest.fn(() => hooks),\n\n getHooksForFlow: jest.fn((flowName: string) => {\n return hooks.filter((h) => h.flow === flowName);\n }),\n\n getHooksForStage: jest.fn((flowName: string, stage: string) => {\n return hooks.filter((h) => h.flow === flowName && h.stage === stage);\n }),\n\n getHooksByPriority: jest.fn((flowName: string, stage: string) => {\n return hooks\n .filter((h) => h.flow === flowName && h.stage === stage)\n .sort((a, b) => (a.priority || 0) - (b.priority || 0));\n }),\n\n clear: jest.fn(() => {\n hooks.length = 0;\n }),\n\n executeHooks: jest.fn(async (flowName: string, stage: string, context: any) => {\n const stageHooks = hooks.filter((h) => h.flow === flowName && h.stage === stage);\n for (const hook of stageHooks) {\n // Mock hook execution\n }\n return context;\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock hook entry\n */\nexport function createMockHookEntry(\n flowName: string,\n stage: string,\n priority: number = 0\n): HookMetadata {\n return {\n type: 'stage',\n flow: flowName as any,\n stage,\n target: Symbol('MOCK_HOOK'),\n method: 'onStage',\n priority,\n };\n}\n\n/**\n * Adds a hook to a mock registry\n */\nexport function addHookToMock(\n registry: ReturnType<typeof createMockHookRegistry>,\n hookMetadata: HookMetadata\n) {\n registry.hooks.push(hookMetadata);\n}\n"]}
@@ -1,8 +0,0 @@
1
- /**
2
- * Mock factories for SDK registries and components
3
- */
4
- export * from './provider-registry.mock';
5
- export * from './flow-instance.mock';
6
- export * from './hook-registry.mock';
7
- export * from './tool-registry.mock';
8
- export * from './plugin-registry.mock';
@@ -1,12 +0,0 @@
1
- "use strict";
2
- /**
3
- * Mock factories for SDK registries and components
4
- */
5
- Object.defineProperty(exports, "__esModule", { value: true });
6
- const tslib_1 = require("tslib");
7
- tslib_1.__exportStar(require("./provider-registry.mock"), exports);
8
- tslib_1.__exportStar(require("./flow-instance.mock"), exports);
9
- tslib_1.__exportStar(require("./hook-registry.mock"), exports);
10
- tslib_1.__exportStar(require("./tool-registry.mock"), exports);
11
- tslib_1.__exportStar(require("./plugin-registry.mock"), exports);
12
- //# sourceMappingURL=index.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/index.ts"],"names":[],"mappings":";AAAA;;GAEG;;;AAEH,mEAAyC;AACzC,+DAAqC;AACrC,+DAAqC;AACrC,+DAAqC;AACrC,iEAAuC","sourcesContent":["/**\n * Mock factories for SDK registries and components\n */\n\nexport * from './provider-registry.mock';\nexport * from './flow-instance.mock';\nexport * from './hook-registry.mock';\nexport * from './tool-registry.mock';\nexport * from './plugin-registry.mock';\n"]}
@@ -1,43 +0,0 @@
1
- /**
2
- * Mock factory for PluginRegistry
3
- */
4
- import { PluginMetadata } from '../../common/metadata';
5
- /**
6
- * Creates a mock PluginRegistry for testing
7
- */
8
- export declare function createMockPluginRegistry(overrides?: Partial<any>): {
9
- plugins: Map<string, any>;
10
- register: jest.Mock<any, [pluginName: string, plugin: any], any>;
11
- get: jest.Mock<any, [pluginName: string], any>;
12
- has: jest.Mock<boolean, [pluginName: string], any>;
13
- getAll: jest.Mock<any[], [], any>;
14
- getNames: jest.Mock<string[], [], any>;
15
- clear: jest.Mock<void, [], any>;
16
- getProviderRegistry: jest.Mock<null, [], any>;
17
- getToolRegistry: jest.Mock<null, [], any>;
18
- getHookRegistry: jest.Mock<null, [], any>;
19
- };
20
- /**
21
- * Creates a mock plugin entry
22
- */
23
- export declare function createMockPluginEntry(name: string, metadata?: Partial<PluginMetadata>): {
24
- name: string;
25
- metadata: {
26
- id?: string;
27
- name: string;
28
- description: string;
29
- providers?: import("@frontmcp/sdk").ProviderType[];
30
- exports?: import("@frontmcp/sdk").ProviderType[];
31
- plugins?: import("@frontmcp/sdk").PluginType[];
32
- adapters?: import("@frontmcp/sdk").AdapterType[];
33
- tools?: import("@frontmcp/sdk").ToolType[];
34
- resources?: import("@frontmcp/sdk").ResourceType[];
35
- prompts?: import("@frontmcp/sdk").PromptType[];
36
- };
37
- onInit: jest.Mock<Promise<void>, [], any>;
38
- onDestroy: jest.Mock<Promise<void>, [], any>;
39
- };
40
- /**
41
- * Adds a plugin to a mock registry
42
- */
43
- export declare function addPluginToMock(registry: ReturnType<typeof createMockPluginRegistry>, name: string, pluginEntry: any): void;
@@ -1,70 +0,0 @@
1
- "use strict";
2
- /// <reference types="jest" />
3
- /**
4
- * Mock factory for PluginRegistry
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.createMockPluginRegistry = createMockPluginRegistry;
8
- exports.createMockPluginEntry = createMockPluginEntry;
9
- exports.addPluginToMock = addPluginToMock;
10
- /**
11
- * Creates a mock PluginRegistry for testing
12
- */
13
- function createMockPluginRegistry(overrides = {}) {
14
- const plugins = new Map();
15
- return {
16
- plugins,
17
- register: jest.fn((pluginName, plugin) => {
18
- plugins.set(pluginName, plugin);
19
- return plugin;
20
- }),
21
- get: jest.fn((pluginName) => {
22
- return plugins.get(pluginName);
23
- }),
24
- has: jest.fn((pluginName) => {
25
- return plugins.has(pluginName);
26
- }),
27
- getAll: jest.fn(() => {
28
- return Array.from(plugins.values());
29
- }),
30
- getNames: jest.fn(() => {
31
- return Array.from(plugins.keys());
32
- }),
33
- clear: jest.fn(() => {
34
- plugins.clear();
35
- }),
36
- // Nested registries access
37
- getProviderRegistry: jest.fn(() => null),
38
- getToolRegistry: jest.fn(() => null),
39
- getHookRegistry: jest.fn(() => null),
40
- ...overrides,
41
- };
42
- }
43
- /**
44
- * Creates a mock plugin entry
45
- */
46
- function createMockPluginEntry(name, metadata) {
47
- return {
48
- name,
49
- metadata: {
50
- name,
51
- description: `Mock plugin: ${name}`,
52
- ...metadata,
53
- },
54
- onInit: jest.fn(async () => { }),
55
- onDestroy: jest.fn(async () => { }),
56
- };
57
- }
58
- /**
59
- * Adds a plugin to a mock registry
60
- */
61
- function addPluginToMock(registry, name, pluginEntry) {
62
- registry.plugins.set(name, pluginEntry);
63
- registry.has.mockImplementation((n) => n === name || registry.plugins.has(n));
64
- registry.get.mockImplementation((n) => {
65
- if (n === name)
66
- return pluginEntry;
67
- return registry.plugins.get(n);
68
- });
69
- }
70
- //# sourceMappingURL=plugin-registry.mock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"plugin-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/plugin-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,4DAsCC;AAKD,sDAWC;AAKD,0CAOC;AArED;;GAEG;AACH,SAAgB,wBAAwB,CAAC,YAA0B,EAAE;IACnE,MAAM,OAAO,GAAG,IAAI,GAAG,EAAe,CAAC;IAEvC,OAAO;QACL,OAAO;QAEP,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,MAAW,EAAE,EAAE;YACpD,OAAO,CAAC,GAAG,CAAC,UAAU,EAAE,MAAM,CAAC,CAAC;YAChC,OAAO,MAAM,CAAC;QAChB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,EAAE;YAClC,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,UAAkB,EAAE,EAAE;YAClC,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACjC,CAAC,CAAC;QAEF,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACnB,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC,CAAC;QACtC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACrB,OAAO,KAAK,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,OAAO,CAAC,KAAK,EAAE,CAAC;QAClB,CAAC,CAAC;QAEF,2BAA2B;QAC3B,mBAAmB,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QACxC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QACpC,eAAe,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC;QAEpC,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,qBAAqB,CAAC,IAAY,EAAE,QAAkC;IACpF,OAAO;QACL,IAAI;QACJ,QAAQ,EAAE;YACR,IAAI;YACJ,WAAW,EAAE,gBAAgB,IAAI,EAAE;YACnC,GAAG,QAAQ;SACZ;QACD,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,GAAE,CAAC,CAAC;QAC/B,SAAS,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,IAAI,EAAE,GAAE,CAAC,CAAC;KACnC,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,eAAe,CAAC,QAAqD,EAAE,IAAY,EAAE,WAAgB;IACnH,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,WAAW,CAAC,CAAC;IACxC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACtF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE;QAC5C,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,WAAW,CAAC;QACnC,OAAO,QAAQ,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACjC,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for PluginRegistry\n */\n\nimport { PluginMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock PluginRegistry for testing\n */\nexport function createMockPluginRegistry(overrides: Partial<any> = {}) {\n const plugins = new Map<string, any>();\n\n return {\n plugins,\n\n register: jest.fn((pluginName: string, plugin: any) => {\n plugins.set(pluginName, plugin);\n return plugin;\n }),\n\n get: jest.fn((pluginName: string) => {\n return plugins.get(pluginName);\n }),\n\n has: jest.fn((pluginName: string) => {\n return plugins.has(pluginName);\n }),\n\n getAll: jest.fn(() => {\n return Array.from(plugins.values());\n }),\n\n getNames: jest.fn(() => {\n return Array.from(plugins.keys());\n }),\n\n clear: jest.fn(() => {\n plugins.clear();\n }),\n\n // Nested registries access\n getProviderRegistry: jest.fn(() => null),\n getToolRegistry: jest.fn(() => null),\n getHookRegistry: jest.fn(() => null),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock plugin entry\n */\nexport function createMockPluginEntry(name: string, metadata?: Partial<PluginMetadata>) {\n return {\n name,\n metadata: {\n name,\n description: `Mock plugin: ${name}`,\n ...metadata,\n },\n onInit: jest.fn(async () => {}),\n onDestroy: jest.fn(async () => {}),\n };\n}\n\n/**\n * Adds a plugin to a mock registry\n */\nexport function addPluginToMock(registry: ReturnType<typeof createMockPluginRegistry>, name: string, pluginEntry: any) {\n registry.plugins.set(name, pluginEntry);\n registry.has.mockImplementation((n: string) => n === name || registry.plugins.has(n));\n registry.get.mockImplementation((n: string) => {\n if (n === name) return pluginEntry;\n return registry.plugins.get(n);\n });\n}\n"]}
@@ -1,39 +0,0 @@
1
- /**
2
- * Mock factory for ProviderRegistry
3
- */
4
- import { Token } from '../../common/interfaces';
5
- import { ProviderScope } from '../../common/metadata';
6
- /**
7
- * Creates a mock ProviderRegistry for testing
8
- */
9
- export declare function createMockProviderRegistry(overrides?: Partial<any>): {
10
- instances: Map<import("../../common/interfaces").Reference<any>, any>;
11
- defs: Map<import("../../common/interfaces").Reference<any>, any>;
12
- ready: Promise<void>;
13
- getProviders: jest.Mock<never[], [], any>;
14
- get: jest.Mock<any, [token: import("../../common/interfaces").Reference<any>], any>;
15
- has: jest.Mock<boolean, [token: import("../../common/interfaces").Reference<any>], any>;
16
- set: jest.Mock<void, [token: import("../../common/interfaces").Reference<any>, value: any], any>;
17
- resolve: jest.Mock<Promise<any>, [token: import("../../common/interfaces").Reference<any>], any>;
18
- createViews: jest.Mock<{
19
- global: Map<import("../../common/interfaces").Reference<any>, any>;
20
- session: Map<any, any>;
21
- request: Map<any, any>;
22
- }, [sessionId?: string | undefined], any>;
23
- };
24
- /**
25
- * Creates a mock provider entry
26
- */
27
- export declare function createMockProviderEntry(token: Token, value: any, scope?: ProviderScope): {
28
- token: import("../../common/interfaces").Reference<any>;
29
- value: any;
30
- scope: ProviderScope;
31
- metadata: {
32
- name: string;
33
- scope: ProviderScope;
34
- };
35
- };
36
- /**
37
- * Adds a provider to a mock registry
38
- */
39
- export declare function addProviderToMock(registry: ReturnType<typeof createMockProviderRegistry>, token: Token, value: any): void;
@@ -1,72 +0,0 @@
1
- "use strict";
2
- /// <reference types="jest" />
3
- /**
4
- * Mock factory for ProviderRegistry
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.createMockProviderRegistry = createMockProviderRegistry;
8
- exports.createMockProviderEntry = createMockProviderEntry;
9
- exports.addProviderToMock = addProviderToMock;
10
- const metadata_1 = require("../../common/metadata");
11
- /**
12
- * Creates a mock ProviderRegistry for testing
13
- */
14
- function createMockProviderRegistry(overrides = {}) {
15
- const instances = new Map();
16
- const defs = new Map();
17
- return {
18
- instances,
19
- defs,
20
- ready: Promise.resolve(),
21
- getProviders: jest.fn(() => []),
22
- get: jest.fn((token) => {
23
- if (instances.has(token)) {
24
- return instances.get(token);
25
- }
26
- throw new Error(`Token not found: ${String(token)}`);
27
- }),
28
- has: jest.fn((token) => instances.has(token)),
29
- set: jest.fn((token, value) => {
30
- instances.set(token, value);
31
- }),
32
- resolve: jest.fn(async (token) => {
33
- if (instances.has(token)) {
34
- return instances.get(token);
35
- }
36
- throw new Error(`Cannot resolve token: ${String(token)}`);
37
- }),
38
- createViews: jest.fn((sessionId) => ({
39
- global: new Map(instances),
40
- session: new Map(),
41
- request: new Map(),
42
- })),
43
- ...overrides,
44
- };
45
- }
46
- /**
47
- * Creates a mock provider entry
48
- */
49
- function createMockProviderEntry(token, value, scope = metadata_1.ProviderScope.GLOBAL) {
50
- return {
51
- token,
52
- value,
53
- scope,
54
- metadata: {
55
- name: String(token),
56
- scope,
57
- },
58
- };
59
- }
60
- /**
61
- * Adds a provider to a mock registry
62
- */
63
- function addProviderToMock(registry, token, value) {
64
- registry.instances.set(token, value);
65
- registry.has.mockImplementation((t) => t === token || registry.instances.has(t));
66
- registry.get.mockImplementation((t) => {
67
- if (t === token)
68
- return value;
69
- return registry.instances.get(t);
70
- });
71
- }
72
- //# sourceMappingURL=provider-registry.mock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"provider-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/provider-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAQH,gEAuCC;AAKD,0DAUC;AAKD,8CAOC;AAvED,oDAAsD;AAEtD;;GAEG;AACH,SAAgB,0BAA0B,CAAC,YAA0B,EAAE;IACrE,MAAM,SAAS,GAAG,IAAI,GAAG,EAAc,CAAC;IACxC,MAAM,IAAI,GAAG,IAAI,GAAG,EAAc,CAAC;IAEnC,OAAO;QACL,SAAS;QACT,IAAI;QACJ,KAAK,EAAE,OAAO,CAAC,OAAO,EAAE;QAExB,YAAY,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE,CAAC,EAAE,CAAC;QAE/B,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,EAAE;YAC5B,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,oBAAoB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACvD,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,EAAE,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEpD,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,KAAY,EAAE,KAAU,EAAE,EAAE;YACxC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;QAC9B,CAAC,CAAC;QAEF,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,KAAY,EAAE,EAAE;YACtC,IAAI,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC;gBACzB,OAAO,SAAS,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC9B,CAAC;YACD,MAAM,IAAI,KAAK,CAAC,yBAAyB,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QAC5D,CAAC,CAAC;QAEF,WAAW,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,SAAkB,EAAE,EAAE,CAAC,CAAC;YAC5C,MAAM,EAAE,IAAI,GAAG,CAAC,SAAS,CAAC;YAC1B,OAAO,EAAE,IAAI,GAAG,EAAE;YAClB,OAAO,EAAE,IAAI,GAAG,EAAE;SACnB,CAAC,CAAC;QAEH,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,uBAAuB,CAAC,KAAY,EAAE,KAAU,EAAE,QAAuB,wBAAa,CAAC,MAAM;IAC3G,OAAO;QACL,KAAK;QACL,KAAK;QACL,KAAK;QACL,QAAQ,EAAE;YACR,IAAI,EAAE,MAAM,CAAC,KAAK,CAAC;YACnB,KAAK;SACN;KACF,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,iBAAiB,CAAC,QAAuD,EAAE,KAAY,EAAE,KAAU;IACjH,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,KAAK,EAAE,KAAK,CAAC,CAAC;IACrC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAQ,EAAE,EAAE,CAAC,CAAC,KAAK,KAAK,IAAI,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACxF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAQ,EAAE,EAAE;QAC3C,IAAI,CAAC,KAAK,KAAK;YAAE,OAAO,KAAK,CAAC;QAC9B,OAAO,QAAQ,CAAC,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IACnC,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for ProviderRegistry\n */\n\nimport { Token } from '../../common/interfaces';\nimport { ProviderScope } from '../../common/metadata';\n\n/**\n * Creates a mock ProviderRegistry for testing\n */\nexport function createMockProviderRegistry(overrides: Partial<any> = {}) {\n const instances = new Map<Token, any>();\n const defs = new Map<Token, any>();\n\n return {\n instances,\n defs,\n ready: Promise.resolve(),\n\n getProviders: jest.fn(() => []),\n\n get: jest.fn((token: Token) => {\n if (instances.has(token)) {\n return instances.get(token);\n }\n throw new Error(`Token not found: ${String(token)}`);\n }),\n\n has: jest.fn((token: Token) => instances.has(token)),\n\n set: jest.fn((token: Token, value: any) => {\n instances.set(token, value);\n }),\n\n resolve: jest.fn(async (token: Token) => {\n if (instances.has(token)) {\n return instances.get(token);\n }\n throw new Error(`Cannot resolve token: ${String(token)}`);\n }),\n\n createViews: jest.fn((sessionId?: string) => ({\n global: new Map(instances),\n session: new Map(),\n request: new Map(),\n })),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock provider entry\n */\nexport function createMockProviderEntry(token: Token, value: any, scope: ProviderScope = ProviderScope.GLOBAL) {\n return {\n token,\n value,\n scope,\n metadata: {\n name: String(token),\n scope,\n },\n };\n}\n\n/**\n * Adds a provider to a mock registry\n */\nexport function addProviderToMock(registry: ReturnType<typeof createMockProviderRegistry>, token: Token, value: any) {\n registry.instances.set(token, value);\n registry.has.mockImplementation((t: Token) => t === token || registry.instances.has(t));\n registry.get.mockImplementation((t: Token) => {\n if (t === token) return value;\n return registry.instances.get(t);\n });\n}\n"]}
@@ -1,43 +0,0 @@
1
- /**
2
- * Mock factory for ToolRegistry
3
- */
4
- import { ToolMetadata } from '../../common/metadata';
5
- /**
6
- * Creates a mock ToolRegistry for testing
7
- */
8
- export declare function createMockToolRegistry(overrides?: Partial<any>): {
9
- tools: Map<string, any>;
10
- register: jest.Mock<any, [name: string, toolInstance: any], any>;
11
- get: jest.Mock<any, [name: string], any>;
12
- has: jest.Mock<boolean, [name: string], any>;
13
- getAll: jest.Mock<any[], [], any>;
14
- getNames: jest.Mock<string[], [], any>;
15
- list: jest.Mock<{
16
- name: string;
17
- metadata: any;
18
- }[], [], any>;
19
- clear: jest.Mock<void, [], any>;
20
- call: jest.Mock<Promise<any>, [name: string, input: any], any>;
21
- };
22
- /**
23
- * Creates a mock tool entry
24
- */
25
- export declare function createMockToolEntry(name: string, metadata?: Partial<ToolMetadata>, execute?: (input: any) => Promise<any>): {
26
- name: string;
27
- metadata: {
28
- id?: string;
29
- name: string;
30
- description: string;
31
- inputSchema: import("zod").ZodRawShape;
32
- rawInputSchema?: import("json-schema").JSONSchema7;
33
- outputSchema?: import("../../common/metadata").ToolOutputType;
34
- tags?: string[];
35
- annotations?: import("../../common/metadata").ToolAnnotations;
36
- hideFromDiscovery?: boolean;
37
- };
38
- execute: jest.Mock<Promise<any>, [input: any], any>;
39
- };
40
- /**
41
- * Adds a tool to a mock registry
42
- */
43
- export declare function addToolToMock(registry: ReturnType<typeof createMockToolRegistry>, name: string, toolEntry: any): void;
@@ -1,79 +0,0 @@
1
- "use strict";
2
- /// <reference types="jest" />
3
- /**
4
- * Mock factory for ToolRegistry
5
- */
6
- Object.defineProperty(exports, "__esModule", { value: true });
7
- exports.createMockToolRegistry = createMockToolRegistry;
8
- exports.createMockToolEntry = createMockToolEntry;
9
- exports.addToolToMock = addToolToMock;
10
- /**
11
- * Creates a mock ToolRegistry for testing
12
- */
13
- function createMockToolRegistry(overrides = {}) {
14
- const tools = new Map();
15
- return {
16
- tools,
17
- register: jest.fn((name, toolInstance) => {
18
- tools.set(name, toolInstance);
19
- return toolInstance;
20
- }),
21
- get: jest.fn((name) => {
22
- return tools.get(name);
23
- }),
24
- has: jest.fn((name) => {
25
- return tools.has(name);
26
- }),
27
- getAll: jest.fn(() => {
28
- return Array.from(tools.values());
29
- }),
30
- getNames: jest.fn(() => {
31
- return Array.from(tools.keys());
32
- }),
33
- list: jest.fn(() => {
34
- return Array.from(tools.entries()).map(([name, tool]) => ({
35
- name,
36
- metadata: tool.metadata,
37
- }));
38
- }),
39
- clear: jest.fn(() => {
40
- tools.clear();
41
- }),
42
- call: jest.fn(async (name, input) => {
43
- const tool = tools.get(name);
44
- if (!tool) {
45
- throw new Error(`Tool not found: ${name}`);
46
- }
47
- return tool.execute ? await tool.execute(input) : 'mock result';
48
- }),
49
- ...overrides,
50
- };
51
- }
52
- /**
53
- * Creates a mock tool entry
54
- */
55
- function createMockToolEntry(name, metadata, execute) {
56
- return {
57
- name,
58
- metadata: {
59
- name,
60
- description: `Mock tool: ${name}`,
61
- inputSchema: {},
62
- ...metadata,
63
- },
64
- execute: jest.fn(execute || (async (input) => `Result from ${name}`)),
65
- };
66
- }
67
- /**
68
- * Adds a tool to a mock registry
69
- */
70
- function addToolToMock(registry, name, toolEntry) {
71
- registry.tools.set(name, toolEntry);
72
- registry.has.mockImplementation((n) => n === name || registry.tools.has(n));
73
- registry.get.mockImplementation((n) => {
74
- if (n === name)
75
- return toolEntry;
76
- return registry.tools.get(n);
77
- });
78
- }
79
- //# sourceMappingURL=tool-registry.mock.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"tool-registry.mock.js","sourceRoot":"","sources":["../../../../src/__test-utils__/mocks/tool-registry.mock.ts"],"names":[],"mappings":";AAAA,8BAA8B;AAC9B;;GAEG;;AAOH,wDAgDC;AAKD,kDAeC;AAKD,sCAOC;AAnFD;;GAEG;AACH,SAAgB,sBAAsB,CAAC,YAA0B,EAAE;IACjE,MAAM,KAAK,GAAG,IAAI,GAAG,EAAe,CAAC;IAErC,OAAO;QACL,KAAK;QAEL,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,YAAiB,EAAE,EAAE;YACpD,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,YAAY,CAAC,CAAC;YAC9B,OAAO,YAAY,CAAC;QACtB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE;YAC5B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC;QAEF,GAAG,EAAE,IAAI,CAAC,EAAE,CAAC,CAAC,IAAY,EAAE,EAAE;YAC5B,OAAO,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QACzB,CAAC,CAAC;QAEF,MAAM,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACnB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,EAAE,CAAC,CAAC;QACpC,CAAC,CAAC;QAEF,QAAQ,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACrB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAClC,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YACjB,OAAO,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,OAAO,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,EAAE,CAAC,CAAC;gBACxD,IAAI;gBACJ,QAAQ,EAAE,IAAI,CAAC,QAAQ;aACxB,CAAC,CAAC,CAAC;QACN,CAAC,CAAC;QAEF,KAAK,EAAE,IAAI,CAAC,EAAE,CAAC,GAAG,EAAE;YAClB,KAAK,CAAC,KAAK,EAAE,CAAC;QAChB,CAAC,CAAC;QAEF,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,KAAK,EAAE,IAAY,EAAE,KAAU,EAAE,EAAE;YAC/C,MAAM,IAAI,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAC7B,IAAI,CAAC,IAAI,EAAE,CAAC;gBACV,MAAM,IAAI,KAAK,CAAC,mBAAmB,IAAI,EAAE,CAAC,CAAC;YAC7C,CAAC;YACD,OAAO,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,aAAa,CAAC;QAClE,CAAC,CAAC;QAEF,GAAG,SAAS;KACb,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,mBAAmB,CACjC,IAAY,EACZ,QAAgC,EAChC,OAAsC;IAEtC,OAAO;QACL,IAAI;QACJ,QAAQ,EAAE;YACR,IAAI;YACJ,WAAW,EAAE,cAAc,IAAI,EAAE;YACjC,WAAW,EAAE,EAAE;YACf,GAAG,QAAQ;SACZ;QACD,OAAO,EAAE,IAAI,CAAC,EAAE,CAAC,OAAO,IAAI,CAAC,KAAK,EAAE,KAAU,EAAE,EAAE,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC;KAC3E,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAgB,aAAa,CAAC,QAAmD,EAAE,IAAY,EAAE,SAAc;IAC7G,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IACpC,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE,CAAC,CAAC,KAAK,IAAI,IAAI,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC;IACpF,QAAQ,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC,CAAS,EAAE,EAAE;QAC5C,IAAI,CAAC,KAAK,IAAI;YAAE,OAAO,SAAS,CAAC;QACjC,OAAO,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;IAC/B,CAAC,CAAC,CAAC;AACL,CAAC","sourcesContent":["/// <reference types=\"jest\" />\n/**\n * Mock factory for ToolRegistry\n */\n\nimport { ToolMetadata } from '../../common/metadata';\n\n/**\n * Creates a mock ToolRegistry for testing\n */\nexport function createMockToolRegistry(overrides: Partial<any> = {}) {\n const tools = new Map<string, any>();\n\n return {\n tools,\n\n register: jest.fn((name: string, toolInstance: any) => {\n tools.set(name, toolInstance);\n return toolInstance;\n }),\n\n get: jest.fn((name: string) => {\n return tools.get(name);\n }),\n\n has: jest.fn((name: string) => {\n return tools.has(name);\n }),\n\n getAll: jest.fn(() => {\n return Array.from(tools.values());\n }),\n\n getNames: jest.fn(() => {\n return Array.from(tools.keys());\n }),\n\n list: jest.fn(() => {\n return Array.from(tools.entries()).map(([name, tool]) => ({\n name,\n metadata: tool.metadata,\n }));\n }),\n\n clear: jest.fn(() => {\n tools.clear();\n }),\n\n call: jest.fn(async (name: string, input: any) => {\n const tool = tools.get(name);\n if (!tool) {\n throw new Error(`Tool not found: ${name}`);\n }\n return tool.execute ? await tool.execute(input) : 'mock result';\n }),\n\n ...overrides,\n };\n}\n\n/**\n * Creates a mock tool entry\n */\nexport function createMockToolEntry(\n name: string,\n metadata?: Partial<ToolMetadata>,\n execute?: (input: any) => Promise<any>,\n) {\n return {\n name,\n metadata: {\n name,\n description: `Mock tool: ${name}`,\n inputSchema: {},\n ...metadata,\n },\n execute: jest.fn(execute || (async (input: any) => `Result from ${name}`)),\n };\n}\n\n/**\n * Adds a tool to a mock registry\n */\nexport function addToolToMock(registry: ReturnType<typeof createMockToolRegistry>, name: string, toolEntry: any) {\n registry.tools.set(name, toolEntry);\n registry.has.mockImplementation((n: string) => n === name || registry.tools.has(n));\n registry.get.mockImplementation((n: string) => {\n if (n === name) return toolEntry;\n return registry.tools.get(n);\n });\n}\n"]}
@@ -1,20 +0,0 @@
1
- import { ServerRequest } from '../common';
2
- export declare function trimSlashes(s: string): string;
3
- /** Normalize entryPath (gateway prefix) to "" or "/mcp" */
4
- export declare function normalizeEntryPrefix(entryPath?: string): string;
5
- /** Normalize a scope base (per-app or per-auth) to "" or "/app1" */
6
- export declare function normalizeScopeBase(scopeBase?: string): string;
7
- /** Join URL path segments with a single slash and no trailing slash */
8
- export declare function joinPath(...parts: string[]): string;
9
- export declare function getRequestBaseUrl(req: ServerRequest, entryPath?: string): string;
10
- export declare function computeIssuer(req: ServerRequest, entryPath: string, scopeBase: string): string;
11
- export declare function computeResource(req: ServerRequest, entryPath: string, scopeBase: string): string;
12
- /** Derive a safe provider id from a URL when no id is provided. */
13
- export declare function urlToSafeId(url: string): string | undefined;
14
- /**
15
- * Build all path variants for a given well-known name:
16
- * - reversed under root: /.well-known/<name><entryPrefix><scopeBase>
17
- * - in prefix root: <entryPrefix>/.well-known/<name><scopeBase>
18
- * - in prefix + scope: <entryPrefix><scopeBase>/.well-known/<name>
19
- */
20
- export declare function makeWellKnownPaths(name: string, entryPrefix: string, scopeBase?: string): Set<string>;