@frontmcp/sdk 0.2.5 → 0.3.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 (899) hide show
  1. package/README.md +81 -99
  2. package/package.json +24 -2
  3. package/src/adapter/adapter.instance.d.ts +11 -0
  4. package/src/adapter/adapter.instance.js +65 -0
  5. package/src/adapter/adapter.instance.js.map +1 -0
  6. package/src/adapter/adapter.regsitry.d.ts +13 -0
  7. package/src/adapter/adapter.regsitry.js +54 -0
  8. package/src/adapter/adapter.regsitry.js.map +1 -0
  9. package/src/adapter/adapter.utils.d.ts +10 -0
  10. package/src/adapter/adapter.utils.js +83 -0
  11. package/src/adapter/adapter.utils.js.map +1 -0
  12. package/src/app/app.registry.d.ts +12 -0
  13. package/src/app/app.registry.js +64 -0
  14. package/src/app/app.registry.js.map +1 -0
  15. package/src/app/app.utils.d.ts +15 -0
  16. package/src/app/app.utils.js +58 -0
  17. package/src/app/app.utils.js.map +1 -0
  18. package/src/app/instances/app.local.instance.d.ts +25 -0
  19. package/src/app/instances/app.local.instance.js +70 -0
  20. package/src/app/instances/app.local.instance.js.map +1 -0
  21. package/src/app/instances/app.remote.instance.d.ts +13 -0
  22. package/src/app/instances/app.remote.instance.js +36 -0
  23. package/src/app/instances/app.remote.instance.js.map +1 -0
  24. package/src/app/instances/index.d.ts +2 -0
  25. package/src/app/instances/index.js +6 -0
  26. package/src/app/instances/index.js.map +1 -0
  27. package/src/auth/auth.registry.d.ts +13 -0
  28. package/src/auth/auth.registry.js +81 -0
  29. package/src/auth/auth.registry.js.map +1 -0
  30. package/src/auth/auth.utils.d.ts +10 -0
  31. package/src/auth/auth.utils.js +85 -0
  32. package/src/auth/auth.utils.js.map +1 -0
  33. package/src/auth/flows/oauth.authorize.flow.d.ts +231 -0
  34. package/src/auth/flows/oauth.authorize.flow.js +154 -0
  35. package/src/auth/flows/oauth.authorize.flow.js.map +1 -0
  36. package/src/auth/flows/oauth.register.flow.d.ts +202 -0
  37. package/src/auth/flows/oauth.register.flow.js +201 -0
  38. package/src/auth/flows/oauth.register.flow.js.map +1 -0
  39. package/src/auth/flows/oauth.token.flow.d.ts +242 -0
  40. package/src/auth/flows/oauth.token.flow.js +181 -0
  41. package/src/auth/flows/oauth.token.flow.js.map +1 -0
  42. package/src/auth/flows/session.verify.flow.d.ts +404 -0
  43. package/src/auth/flows/session.verify.flow.js +205 -0
  44. package/src/auth/flows/session.verify.flow.js.map +1 -0
  45. package/src/auth/flows/well-known.jwks.flow.d.ts +261 -0
  46. package/src/auth/flows/well-known.jwks.flow.js +82 -0
  47. package/src/auth/flows/well-known.jwks.flow.js.map +1 -0
  48. package/src/auth/flows/well-known.oauth-authorization-server.flow.d.ts +282 -0
  49. package/src/auth/flows/well-known.oauth-authorization-server.flow.js +123 -0
  50. package/src/auth/flows/well-known.oauth-authorization-server.flow.js.map +1 -0
  51. package/src/auth/flows/well-known.prm.flow.d.ts +159 -0
  52. package/src/auth/flows/well-known.prm.flow.js +107 -0
  53. package/src/auth/flows/well-known.prm.flow.js.map +1 -0
  54. package/src/auth/instances/instance.local-primary-auth.d.ts +20 -0
  55. package/src/auth/instances/instance.local-primary-auth.js +78 -0
  56. package/src/auth/instances/instance.local-primary-auth.js.map +1 -0
  57. package/src/auth/instances/instance.remote-primary-auth.d.ts +15 -0
  58. package/src/auth/instances/instance.remote-primary-auth.js +49 -0
  59. package/src/auth/instances/instance.remote-primary-auth.js.map +1 -0
  60. package/src/auth/jwks/index.d.ts +2 -0
  61. package/src/auth/jwks/index.js +6 -0
  62. package/src/auth/jwks/index.js.map +1 -0
  63. package/src/auth/jwks/jwks.service.d.ts +41 -0
  64. package/src/auth/jwks/jwks.service.js +234 -0
  65. package/src/auth/jwks/jwks.service.js.map +1 -0
  66. package/src/auth/jwks/jwks.types.d.ts +25 -0
  67. package/src/auth/jwks/jwks.types.js +3 -0
  68. package/src/auth/jwks/jwks.types.js.map +1 -0
  69. package/src/auth/jwks/jwks.utils.d.ts +4 -0
  70. package/src/auth/jwks/jwks.utils.js +32 -0
  71. package/src/auth/jwks/jwks.utils.js.map +1 -0
  72. package/src/auth/oauth/flows/oauth.authorize.flow.d.ts +31 -0
  73. package/src/auth/oauth/flows/oauth.authorize.flow.js +33 -0
  74. package/src/auth/oauth/flows/oauth.authorize.flow.js.map +1 -0
  75. package/src/auth/oauth/flows/oauth.device-authorization.flow.d.ts +46 -0
  76. package/src/auth/oauth/flows/oauth.device-authorization.flow.js +48 -0
  77. package/src/auth/oauth/flows/oauth.device-authorization.flow.js.map +1 -0
  78. package/src/auth/oauth/flows/oauth.introspect.flow.d.ts +26 -0
  79. package/src/auth/oauth/flows/oauth.introspect.flow.js +28 -0
  80. package/src/auth/oauth/flows/oauth.introspect.flow.js.map +1 -0
  81. package/src/auth/oauth/flows/oauth.par.flow.d.ts +27 -0
  82. package/src/auth/oauth/flows/oauth.par.flow.js +29 -0
  83. package/src/auth/oauth/flows/oauth.par.flow.js.map +1 -0
  84. package/src/auth/oauth/flows/oauth.revoke.flow.d.ts +25 -0
  85. package/src/auth/oauth/flows/oauth.revoke.flow.js +27 -0
  86. package/src/auth/oauth/flows/oauth.revoke.flow.js.map +1 -0
  87. package/src/auth/oauth/flows/oauth.token.flow.d.ts +57 -0
  88. package/src/auth/oauth/flows/oauth.token.flow.js +59 -0
  89. package/src/auth/oauth/flows/oauth.token.flow.js.map +1 -0
  90. package/src/auth/oauth/flows/oauth.userinfo.flow.d.ts +22 -0
  91. package/src/auth/oauth/flows/oauth.userinfo.flow.js +24 -0
  92. package/src/auth/oauth/flows/oauth.userinfo.flow.js.map +1 -0
  93. package/src/auth/oauth/flows/oidc.logout.flow.d.ts +18 -0
  94. package/src/auth/oauth/flows/oidc.logout.flow.js +20 -0
  95. package/src/auth/oauth/flows/oidc.logout.flow.js.map +1 -0
  96. package/src/auth/path.utils.d.ts +20 -0
  97. package/src/auth/path.utils.js +71 -0
  98. package/src/auth/path.utils.js.map +1 -0
  99. package/src/auth/session/index.d.ts +4 -0
  100. package/src/auth/session/index.js +10 -0
  101. package/src/auth/session/index.js.map +1 -0
  102. package/src/auth/session/record/session.base.d.ts +103 -0
  103. package/src/auth/session/record/session.base.js +123 -0
  104. package/src/auth/session/record/session.base.js.map +1 -0
  105. package/src/auth/session/record/session.stateful.d.ts +20 -0
  106. package/src/auth/session/record/session.stateful.js +55 -0
  107. package/src/auth/session/record/session.stateful.js.map +1 -0
  108. package/src/auth/session/record/session.stateless.d.ts +17 -0
  109. package/src/auth/session/record/session.stateless.js +30 -0
  110. package/src/auth/session/record/session.stateless.js.map +1 -0
  111. package/src/auth/session/record/session.transparent.d.ts +17 -0
  112. package/src/auth/session/record/session.transparent.js +22 -0
  113. package/src/auth/session/record/session.transparent.js.map +1 -0
  114. package/src/auth/session/session.crypto.d.ts +7 -0
  115. package/src/auth/session/session.crypto.js +47 -0
  116. package/src/auth/session/session.crypto.js.map +1 -0
  117. package/src/auth/session/session.schema.d.ts +5 -0
  118. package/src/auth/session/session.schema.js +13 -0
  119. package/src/auth/session/session.schema.js.map +1 -0
  120. package/src/auth/session/session.service.d.ts +17 -0
  121. package/src/auth/session/session.service.js +111 -0
  122. package/src/auth/session/session.service.js.map +1 -0
  123. package/src/auth/session/session.transport.d.ts +4 -0
  124. package/src/auth/session/session.transport.js +20 -0
  125. package/src/auth/session/session.transport.js.map +1 -0
  126. package/src/auth/session/session.types.d.ts +65 -0
  127. package/src/auth/session/session.types.js +4 -0
  128. package/src/auth/session/session.types.js.map +1 -0
  129. package/src/auth/session/token.refresh.d.ts +60 -0
  130. package/src/auth/session/token.refresh.js +63 -0
  131. package/src/auth/session/token.refresh.js.map +1 -0
  132. package/src/auth/session/token.store.d.ts +35 -0
  133. package/src/auth/session/token.store.js +53 -0
  134. package/src/auth/session/token.store.js.map +1 -0
  135. package/src/auth/session/token.vault.d.ts +26 -0
  136. package/src/auth/session/token.vault.js +54 -0
  137. package/src/auth/session/token.vault.js.map +1 -0
  138. package/src/auth/session/utils/auth-token.utils.d.ts +11 -0
  139. package/src/auth/session/utils/auth-token.utils.js +57 -0
  140. package/src/auth/session/utils/auth-token.utils.js.map +1 -0
  141. package/src/auth/session/utils/session-id.utils.d.ts +17 -0
  142. package/src/auth/session/utils/session-id.utils.js +129 -0
  143. package/src/auth/session/utils/session-id.utils.js.map +1 -0
  144. package/src/auth/session/utils/tiny-ttl-cache.d.ts +7 -0
  145. package/src/auth/session/utils/tiny-ttl-cache.js +26 -0
  146. package/src/auth/session/utils/tiny-ttl-cache.js.map +1 -0
  147. package/src/common/common.schema.d.ts +29 -0
  148. package/src/common/common.schema.js +35 -0
  149. package/src/common/common.schema.js.map +1 -0
  150. package/src/common/constants.d.ts +2 -0
  151. package/src/common/constants.js +8 -0
  152. package/src/common/constants.js.map +1 -0
  153. package/src/common/decorators/adapter.decorator.js.map +1 -0
  154. package/src/common/decorators/app.decorator.js.map +1 -0
  155. package/src/common/decorators/auth-provider.decorator.js.map +1 -0
  156. package/src/common/decorators/flow.decorator.js.map +1 -0
  157. package/src/common/decorators/front-mcp.decorator.js +40 -0
  158. package/src/common/decorators/front-mcp.decorator.js.map +1 -0
  159. package/src/common/decorators/hook.decorator.js.map +1 -0
  160. package/src/common/decorators/index.js.map +1 -0
  161. package/src/common/decorators/logger.decorator.js.map +1 -0
  162. package/src/common/decorators/plugin.decorator.js.map +1 -0
  163. package/src/common/decorators/prompt.decorator.js.map +1 -0
  164. package/src/common/decorators/provider.decorator.js.map +1 -0
  165. package/src/common/decorators/resource.decorator.js.map +1 -0
  166. package/src/common/decorators/tool.decorator.d.ts +42 -0
  167. package/src/common/decorators/tool.decorator.js +46 -0
  168. package/src/common/decorators/tool.decorator.js.map +1 -0
  169. package/src/common/decorators-old/async-with.decorator.d.ts +10 -0
  170. package/src/common/decorators-old/async-with.decorator.js +24 -0
  171. package/src/common/decorators-old/async-with.decorator.js.map +1 -0
  172. package/src/common/decorators-old/auth-hook.decorator.js.map +1 -0
  173. package/src/common/decorators-old/session-hook.decorator.js.map +1 -0
  174. package/src/common/dynamic/dynamic.adapter.js.map +1 -0
  175. package/src/common/dynamic/dynamic.plugin.js.map +1 -0
  176. package/src/common/dynamic/dynamic.utils.d.ts +3 -0
  177. package/src/common/dynamic/dynamic.utils.js.map +1 -0
  178. package/src/common/dynamic/index.js.map +1 -0
  179. package/src/common/entries/adapter.entry.js.map +1 -0
  180. package/src/common/entries/app.entry.d.ts +13 -0
  181. package/src/common/entries/app.entry.js.map +1 -0
  182. package/src/common/entries/auth-provider.entry.js.map +1 -0
  183. package/src/common/entries/base.entry.js.map +1 -0
  184. package/src/common/entries/flow.entry.js.map +1 -0
  185. package/src/common/entries/hook.entry.js.map +1 -0
  186. package/src/common/entries/index.js.map +1 -0
  187. package/src/common/entries/logger.entry.js.map +1 -0
  188. package/src/common/entries/plugin.entry.js.map +1 -0
  189. package/src/common/entries/prompt.entry.js.map +1 -0
  190. package/src/common/entries/provider.entry.js.map +1 -0
  191. package/src/common/entries/resource.entry.js.map +1 -0
  192. package/src/common/entries/scope.entry.d.ts +19 -0
  193. package/src/common/entries/scope.entry.js +14 -0
  194. package/src/common/entries/scope.entry.js.map +1 -0
  195. package/src/common/entries/tool.entry.js.map +1 -0
  196. package/src/common/index.d.ts +17 -0
  197. package/src/common/index.js +21 -0
  198. package/src/common/index.js.map +1 -0
  199. package/src/common/interfaces/adapter.interface.js.map +1 -0
  200. package/src/common/interfaces/app.interface.js.map +1 -0
  201. package/src/common/interfaces/auth-hook.interface.js.map +1 -0
  202. package/src/common/interfaces/auth-provider.interface.js.map +1 -0
  203. package/src/common/interfaces/base.interface.js.map +1 -0
  204. package/src/common/interfaces/flow.interface.d.ts +41 -0
  205. package/src/common/interfaces/flow.interface.js.map +1 -0
  206. package/src/common/interfaces/front-mcp.interface.js.map +1 -0
  207. package/src/common/interfaces/hook.interface.js.map +1 -0
  208. package/src/common/interfaces/index.js.map +1 -0
  209. package/src/common/interfaces/internal/flow.utils.d.ts +23 -0
  210. package/src/common/interfaces/internal/flow.utils.js.map +1 -0
  211. package/src/common/interfaces/internal/index.js.map +1 -0
  212. package/src/common/interfaces/internal/primary-auth-provider.interface.d.ts +24 -0
  213. package/src/common/interfaces/internal/primary-auth-provider.interface.js.map +1 -0
  214. package/src/common/interfaces/internal/registry.interface.d.ts +95 -0
  215. package/src/common/interfaces/internal/registry.interface.js.map +1 -0
  216. package/src/common/interfaces/logger.interface.js.map +1 -0
  217. package/src/common/interfaces/plugin.interface.js.map +1 -0
  218. package/src/common/interfaces/prompt.interface.js.map +1 -0
  219. package/src/common/interfaces/provider.interface.js.map +1 -0
  220. package/src/common/interfaces/resource.interface.js.map +1 -0
  221. package/src/common/interfaces/scope.interface.js.map +1 -0
  222. package/src/common/interfaces/server.interface.js.map +1 -0
  223. package/src/common/interfaces/session-hook.interface.js.map +1 -0
  224. package/src/common/interfaces/tool-hook.interface.js.map +1 -0
  225. package/src/common/interfaces/tool.interface.js.map +1 -0
  226. package/src/common/metadata/adapter.metadata.js.map +1 -0
  227. package/src/common/metadata/app.metadata.d.ts +872 -0
  228. package/src/common/metadata/app.metadata.js.map +1 -0
  229. package/src/common/metadata/auth-provider.metadata.js.map +1 -0
  230. package/src/common/metadata/flow.metadata.d.ts +77 -0
  231. package/src/common/metadata/flow.metadata.js.map +1 -0
  232. package/src/common/metadata/front-mcp.metadata.d.ts +1144 -0
  233. package/src/common/metadata/front-mcp.metadata.js.map +1 -0
  234. package/src/common/metadata/hook.metadata.js.map +1 -0
  235. package/src/common/metadata/index.js.map +1 -0
  236. package/src/common/metadata/logger.metadata.js.map +1 -0
  237. package/src/common/metadata/plugin.metadata.js.map +1 -0
  238. package/src/common/metadata/prompt.metadata.js.map +1 -0
  239. package/src/common/metadata/provider.metadata.js.map +1 -0
  240. package/src/common/metadata/resource.metadata.js.map +1 -0
  241. package/src/common/metadata/tool.metadata.d.ts +178 -0
  242. package/src/common/metadata/tool.metadata.js.map +1 -0
  243. package/src/common/providers/session.provider.js.map +1 -0
  244. package/src/common/records/adapter.record.js.map +1 -0
  245. package/src/common/records/app.record.js.map +1 -0
  246. package/src/common/records/auth-provider.record.js.map +1 -0
  247. package/src/common/records/flow.record.js.map +1 -0
  248. package/src/common/records/hook.record.js.map +1 -0
  249. package/src/common/records/index.js.map +1 -0
  250. package/src/common/records/logger.record.d.ts +11 -0
  251. package/src/common/records/logger.record.js.map +1 -0
  252. package/src/common/records/plugin.record.js.map +1 -0
  253. package/src/common/records/prompt.record.js.map +1 -0
  254. package/src/common/records/provider.record.js.map +1 -0
  255. package/src/common/records/resource.record.js.map +1 -0
  256. package/src/common/records/scope.record.d.ts +18 -0
  257. package/src/common/records/scope.record.js.map +1 -0
  258. package/src/common/records/tool.record.js.map +1 -0
  259. package/src/common/schemas/annotated-class.schema.js.map +1 -0
  260. package/src/common/schemas/http-input.schema.js.map +1 -0
  261. package/src/common/schemas/http-output.schema.d.ts +2011 -0
  262. package/src/common/schemas/http-output.schema.js.map +1 -0
  263. package/src/common/schemas/index.js.map +1 -0
  264. package/src/common/tokens/adapter.tokens.js.map +1 -0
  265. package/src/common/tokens/app.tokens.js.map +1 -0
  266. package/src/common/tokens/auth-provider.tokens.js.map +1 -0
  267. package/src/common/tokens/base.tokens.js.map +1 -0
  268. package/src/common/tokens/flow-hook.tokens.js.map +1 -0
  269. package/src/common/tokens/flow.tokens.js.map +1 -0
  270. package/src/common/tokens/front-mcp.tokens.js.map +1 -0
  271. package/src/common/tokens/index.js.map +1 -0
  272. package/src/common/tokens/logger.tokens.js.map +1 -0
  273. package/src/common/tokens/plugin.tokens.js.map +1 -0
  274. package/src/common/tokens/prompt.tokens.js.map +1 -0
  275. package/src/common/tokens/provider.tokens.js.map +1 -0
  276. package/src/common/tokens/resource.tokens.js.map +1 -0
  277. package/src/common/tokens/server.tokens.js.map +1 -0
  278. package/src/common/tokens/tool.tokens.js.map +1 -0
  279. package/src/common/types/auth/index.js.map +1 -0
  280. package/src/common/types/auth/jwt.types.js.map +1 -0
  281. package/src/common/types/auth/session.types.d.ts +263 -0
  282. package/src/common/types/auth/session.types.js.map +1 -0
  283. package/src/common/types/common.types.js.map +1 -0
  284. package/src/common/types/index.js.map +1 -0
  285. package/src/common/types/options/auth.options.d.ts +513 -0
  286. package/src/common/types/options/auth.options.js.map +1 -0
  287. package/src/common/types/options/http.options.js.map +1 -0
  288. package/src/common/types/options/index.js.map +1 -0
  289. package/src/common/types/options/logging.options.d.ts +39 -0
  290. package/src/common/types/options/logging.options.js.map +1 -0
  291. package/src/common/types/options/server-info.options.d.ts +48 -0
  292. package/src/common/types/options/server-info.options.js.map +1 -0
  293. package/src/common/types/options/session.options.d.ts +67 -0
  294. package/src/common/types/options/session.options.js.map +1 -0
  295. package/src/common/utils/decide-request-intent.utils.d.ts +79 -0
  296. package/src/common/utils/decide-request-intent.utils.js.map +1 -0
  297. package/src/common/utils/index.js.map +1 -0
  298. package/src/common/utils/path.utils.d.ts +20 -0
  299. package/src/common/utils/path.utils.js.map +1 -0
  300. package/src/exceptions/mcp-exceptions/session-missing.exception.d.ts +3 -0
  301. package/src/exceptions/mcp-exceptions/session-missing.exception.js +11 -0
  302. package/src/exceptions/mcp-exceptions/session-missing.exception.js.map +1 -0
  303. package/src/exceptions/mcp-exceptions/unsupported-client-version.exception.d.ts +5 -0
  304. package/src/exceptions/mcp-exceptions/unsupported-client-version.exception.js +15 -0
  305. package/src/exceptions/mcp-exceptions/unsupported-client-version.exception.js.map +1 -0
  306. package/src/flows/flow.instance.d.ts +16 -0
  307. package/src/flows/flow.instance.js +332 -0
  308. package/src/flows/flow.instance.js.map +1 -0
  309. package/src/flows/flow.registry.d.ts +14 -0
  310. package/src/flows/flow.registry.js +79 -0
  311. package/src/flows/flow.registry.js.map +1 -0
  312. package/src/flows/flow.stages.d.ts +12 -0
  313. package/src/flows/flow.stages.js +110 -0
  314. package/src/flows/flow.stages.js.map +1 -0
  315. package/src/flows/flow.utils.d.ts +8 -0
  316. package/src/flows/flow.utils.js +36 -0
  317. package/src/flows/flow.utils.js.map +1 -0
  318. package/src/front-mcp/front-mcp.d.ts +12 -0
  319. package/src/front-mcp/front-mcp.js +44 -0
  320. package/src/front-mcp/front-mcp.js.map +1 -0
  321. package/src/front-mcp/front-mcp.providers.d.ts +198 -0
  322. package/src/front-mcp/front-mcp.providers.js +30 -0
  323. package/src/front-mcp/front-mcp.providers.js.map +1 -0
  324. package/src/front-mcp/front-mcp.tokens.d.ts +2 -0
  325. package/src/front-mcp/front-mcp.tokens.js +5 -0
  326. package/src/front-mcp/front-mcp.tokens.js.map +1 -0
  327. package/src/front-mcp/index.d.ts +1 -0
  328. package/src/front-mcp/index.js +5 -0
  329. package/src/front-mcp/index.js.map +1 -0
  330. package/src/hooks/hook.instance.d.ts +7 -0
  331. package/src/hooks/hook.instance.js +23 -0
  332. package/src/hooks/hook.instance.js.map +1 -0
  333. package/src/hooks/hook.registry.d.ts +34 -0
  334. package/src/hooks/hook.registry.js +138 -0
  335. package/src/hooks/hook.registry.js.map +1 -0
  336. package/src/hooks/hooks.utils.d.ts +3 -0
  337. package/src/hooks/hooks.utils.js +27 -0
  338. package/src/hooks/hooks.utils.js.map +1 -0
  339. package/src/index.d.ts +21 -18
  340. package/src/index.js +9 -18
  341. package/src/index.js.map +1 -1
  342. package/src/logger/instances/instance.console-logger.d.ts +10 -0
  343. package/src/logger/instances/instance.console-logger.js +75 -0
  344. package/src/logger/instances/instance.console-logger.js.map +1 -0
  345. package/src/logger/instances/instance.logger.d.ts +24 -0
  346. package/src/logger/instances/instance.logger.js +77 -0
  347. package/src/logger/instances/instance.logger.js.map +1 -0
  348. package/src/logger/logger.registry.d.ts +13 -0
  349. package/src/logger/logger.registry.js +91 -0
  350. package/src/logger/logger.registry.js.map +1 -0
  351. package/src/logger/logger.tokens.d.ts +1 -0
  352. package/src/logger/logger.tokens.js +3 -0
  353. package/src/logger/logger.tokens.js.map +1 -0
  354. package/src/logger/logger.types.d.ts +10 -0
  355. package/src/logger/logger.types.js +8 -0
  356. package/src/logger/logger.types.js.map +1 -0
  357. package/src/logger/logger.utils.d.ts +15 -0
  358. package/src/logger/logger.utils.js +42 -0
  359. package/src/logger/logger.utils.js.map +1 -0
  360. package/src/plugin/plugin.registry.d.ts +24 -0
  361. package/src/plugin/plugin.registry.js +137 -0
  362. package/src/plugin/plugin.registry.js.map +1 -0
  363. package/src/plugin/plugin.utils.d.ts +10 -0
  364. package/src/plugin/plugin.utils.js +88 -0
  365. package/src/plugin/plugin.utils.js.map +1 -0
  366. package/src/prompt/prompt.registry.d.ts +16 -0
  367. package/src/prompt/prompt.registry.js +34 -0
  368. package/src/prompt/prompt.registry.js.map +1 -0
  369. package/src/provider/provider.registry.d.ts +75 -0
  370. package/src/provider/provider.registry.js +679 -0
  371. package/src/provider/provider.registry.js.map +1 -0
  372. package/src/provider/provider.types.d.ts +9 -0
  373. package/src/provider/provider.types.js +3 -0
  374. package/src/provider/provider.types.js.map +1 -0
  375. package/src/provider/provider.utils.d.ts +13 -0
  376. package/src/provider/provider.utils.js +103 -0
  377. package/src/provider/provider.utils.js.map +1 -0
  378. package/src/regsitry/index.d.ts +1 -0
  379. package/src/regsitry/index.js +5 -0
  380. package/src/regsitry/index.js.map +1 -0
  381. package/src/regsitry/registry.base.d.ts +25 -0
  382. package/src/regsitry/registry.base.js +32 -0
  383. package/src/regsitry/registry.base.js.map +1 -0
  384. package/src/resource/resource.registry.d.ts +15 -0
  385. package/src/resource/resource.registry.js +31 -0
  386. package/src/resource/resource.registry.js.map +1 -0
  387. package/src/scope/flows/http.request.flow.d.ts +384 -0
  388. package/src/scope/flows/http.request.flow.js +210 -0
  389. package/src/scope/flows/http.request.flow.js.map +1 -0
  390. package/src/scope/index.d.ts +1 -0
  391. package/src/scope/index.js +6 -0
  392. package/src/scope/index.js.map +1 -0
  393. package/src/scope/scope.instance.d.ts +35 -0
  394. package/src/scope/scope.instance.js +126 -0
  395. package/src/scope/scope.instance.js.map +1 -0
  396. package/src/scope/scope.registry.d.ts +10 -0
  397. package/src/scope/scope.registry.js +94 -0
  398. package/src/scope/scope.registry.js.map +1 -0
  399. package/src/scope/scope.utils.d.ts +13 -0
  400. package/src/scope/scope.utils.js +61 -0
  401. package/src/scope/scope.utils.js.map +1 -0
  402. package/src/server/adapters/base.host.adapter.d.ts +7 -0
  403. package/src/server/adapters/base.host.adapter.js +8 -0
  404. package/src/server/adapters/base.host.adapter.js.map +1 -0
  405. package/src/server/adapters/express.host.adapter.d.ts +12 -0
  406. package/src/server/adapters/express.host.adapter.js +50 -0
  407. package/src/server/adapters/express.host.adapter.js.map +1 -0
  408. package/src/server/server.instance.d.ts +12 -0
  409. package/src/server/server.instance.js +47 -0
  410. package/src/server/server.instance.js.map +1 -0
  411. package/src/server/server.types.d.ts +24 -0
  412. package/src/server/server.types.js +3 -0
  413. package/src/server/server.types.js.map +1 -0
  414. package/src/server/server.validation.d.ts +2 -0
  415. package/src/server/server.validation.js +192 -0
  416. package/src/server/server.validation.js.map +1 -0
  417. package/src/store/adapters/store.base.adapter.d.ts +21 -0
  418. package/src/store/adapters/store.base.adapter.js +16 -0
  419. package/src/store/adapters/store.base.adapter.js.map +1 -0
  420. package/src/store/adapters/store.memory.adapter.d.ts +26 -0
  421. package/src/store/adapters/store.memory.adapter.js +87 -0
  422. package/src/store/adapters/store.memory.adapter.js.map +1 -0
  423. package/src/store/adapters/store.redis.adapter.d.ts +33 -0
  424. package/src/store/adapters/store.redis.adapter.js +104 -0
  425. package/src/store/adapters/store.redis.adapter.js.map +1 -0
  426. package/src/store/index.d.ts +8 -0
  427. package/src/store/index.js +12 -0
  428. package/src/store/index.js.map +1 -0
  429. package/src/store/store.helpers.d.ts +9 -0
  430. package/src/store/store.helpers.js +67 -0
  431. package/src/store/store.helpers.js.map +1 -0
  432. package/src/store/store.registry.d.ts +13 -0
  433. package/src/store/store.registry.js +37 -0
  434. package/src/store/store.registry.js.map +1 -0
  435. package/src/store/store.tokens.d.ts +3 -0
  436. package/src/store/store.tokens.js +7 -0
  437. package/src/store/store.tokens.js.map +1 -0
  438. package/src/store/store.types.d.ts +64 -0
  439. package/src/store/store.types.js +11 -0
  440. package/src/store/store.types.js.map +1 -0
  441. package/src/store/store.utils.d.ts +8 -0
  442. package/src/store/store.utils.js +18 -0
  443. package/src/store/store.utils.js.map +1 -0
  444. package/src/tool/flows/call-tool.flow.d.ts +875 -0
  445. package/src/tool/flows/call-tool.flow.js +249 -0
  446. package/src/tool/flows/call-tool.flow.js.map +1 -0
  447. package/src/tool/flows/tools-list.flow.d.ts +771 -0
  448. package/src/tool/flows/tools-list.flow.js +149 -0
  449. package/src/tool/flows/tools-list.flow.js.map +1 -0
  450. package/src/tool/tool.events.d.ts +17 -0
  451. package/src/tool/tool.events.js +16 -0
  452. package/src/tool/tool.events.js.map +1 -0
  453. package/src/tool/tool.instance.d.ts +15 -0
  454. package/src/tool/tool.instance.js +68 -0
  455. package/src/tool/tool.instance.js.map +1 -0
  456. package/src/tool/tool.registry.d.ts +72 -0
  457. package/src/tool/tool.registry.js +339 -0
  458. package/src/tool/tool.registry.js.map +1 -0
  459. package/src/tool/tool.types.d.ts +25 -0
  460. package/src/tool/tool.types.js +10 -0
  461. package/src/tool/tool.types.js.map +1 -0
  462. package/src/tool/tool.utils.d.ts +20 -0
  463. package/src/tool/tool.utils.js +157 -0
  464. package/src/tool/tool.utils.js.map +1 -0
  465. package/src/transport/adapters/transport.local.adapter.d.ts +41 -0
  466. package/src/transport/adapters/transport.local.adapter.js +127 -0
  467. package/src/transport/adapters/transport.local.adapter.js.map +1 -0
  468. package/src/transport/adapters/transport.sse.adapter.d.ts +14 -0
  469. package/src/transport/adapters/transport.sse.adapter.js +64 -0
  470. package/src/transport/adapters/transport.sse.adapter.js.map +1 -0
  471. package/src/transport/adapters/transport.streamable-http.adapter.d.ts +13 -0
  472. package/src/transport/adapters/transport.streamable-http.adapter.js +65 -0
  473. package/src/transport/adapters/transport.streamable-http.adapter.js.map +1 -0
  474. package/src/transport/flows/handle.sse.flow.d.ts +92 -0
  475. package/src/transport/flows/handle.sse.flow.js +129 -0
  476. package/src/transport/flows/handle.sse.flow.js.map +1 -0
  477. package/src/transport/flows/handle.streamable-http.flow.d.ts +93 -0
  478. package/src/transport/flows/handle.streamable-http.flow.js +125 -0
  479. package/src/transport/flows/handle.streamable-http.flow.js.map +1 -0
  480. package/src/transport/legacy/legacy.sse.tranporter.d.ts +75 -0
  481. package/src/transport/legacy/legacy.sse.tranporter.js +170 -0
  482. package/src/transport/legacy/legacy.sse.tranporter.js.map +1 -0
  483. package/src/transport/mcp-handlers/Initialized-notification.hanlder.d.ts +3 -0
  484. package/src/transport/mcp-handlers/Initialized-notification.hanlder.js +14 -0
  485. package/src/transport/mcp-handlers/Initialized-notification.hanlder.js.map +1 -0
  486. package/src/transport/mcp-handlers/call-tool-request.handler.d.ts +3 -0
  487. package/src/transport/mcp-handlers/call-tool-request.handler.js +15 -0
  488. package/src/transport/mcp-handlers/call-tool-request.handler.js.map +1 -0
  489. package/src/transport/mcp-handlers/index.d.ts +521 -0
  490. package/src/transport/mcp-handlers/index.js +20 -0
  491. package/src/transport/mcp-handlers/index.js.map +1 -0
  492. package/src/transport/mcp-handlers/initialize-request.handler.d.ts +3 -0
  493. package/src/transport/mcp-handlers/initialize-request.handler.js +33 -0
  494. package/src/transport/mcp-handlers/initialize-request.handler.js.map +1 -0
  495. package/src/transport/mcp-handlers/list-tools-request.handler.d.ts +285 -0
  496. package/src/transport/mcp-handlers/list-tools-request.handler.js +11 -0
  497. package/src/transport/mcp-handlers/list-tools-request.handler.js.map +1 -0
  498. package/src/transport/mcp-handlers/mcp-handlers.types.d.ts +37 -0
  499. package/src/transport/mcp-handlers/mcp-handlers.types.js +3 -0
  500. package/src/transport/mcp-handlers/mcp-handlers.types.js.map +1 -0
  501. package/src/transport/transport.error.d.ts +4 -0
  502. package/src/transport/transport.error.js +25 -0
  503. package/src/transport/transport.error.js.map +1 -0
  504. package/src/transport/transport.event-store.d.ts +10 -0
  505. package/src/transport/transport.event-store.js +36 -0
  506. package/src/transport/transport.event-store.js.map +1 -0
  507. package/src/transport/transport.local.d.ts +17 -0
  508. package/src/transport/transport.local.js +65 -0
  509. package/src/transport/transport.local.js.map +1 -0
  510. package/src/transport/transport.registry.d.ts +23 -0
  511. package/src/transport/transport.registry.js +138 -0
  512. package/src/transport/transport.registry.js.map +1 -0
  513. package/src/transport/transport.remote.d.ts +15 -0
  514. package/src/transport/transport.remote.js +31 -0
  515. package/src/transport/transport.remote.js.map +1 -0
  516. package/src/transport/transport.types.d.ts +54 -0
  517. package/src/transport/transport.types.js +3 -0
  518. package/src/transport/transport.types.js.map +1 -0
  519. package/src/types/drinen-hooks.types.d.ts +20 -0
  520. package/src/types/drinen-hooks.types.js +3 -0
  521. package/src/types/drinen-hooks.types.js.map +1 -0
  522. package/src/types/invoke.type.d.ts +15 -0
  523. package/src/types/invoke.type.js +34 -0
  524. package/src/types/invoke.type.js.map +1 -0
  525. package/src/types/token.types.d.ts +1 -0
  526. package/src/types/token.types.js +3 -0
  527. package/src/types/token.types.js.map +1 -0
  528. package/src/utils/metadata.utils.d.ts +5 -0
  529. package/src/utils/metadata.utils.js +26 -0
  530. package/src/utils/metadata.utils.js.map +1 -0
  531. package/src/utils/server.utils.d.ts +19 -0
  532. package/src/utils/server.utils.js +59 -0
  533. package/src/utils/server.utils.js.map +1 -0
  534. package/src/utils/string.utils.d.ts +1 -0
  535. package/src/utils/string.utils.js +10 -0
  536. package/src/utils/string.utils.js.map +1 -0
  537. package/src/utils/token.utils.d.ts +11 -0
  538. package/src/utils/token.utils.js +65 -0
  539. package/src/utils/token.utils.js.map +1 -0
  540. package/src/utils/types.utils.d.ts +7 -0
  541. package/src/utils/types.utils.js +3 -0
  542. package/src/utils/types.utils.js.map +1 -0
  543. package/src/constants.d.ts +0 -30
  544. package/src/constants.js +0 -36
  545. package/src/constants.js.map +0 -1
  546. package/src/decorators/adapter.decorator.js.map +0 -1
  547. package/src/decorators/app.decorator.js.map +0 -1
  548. package/src/decorators/auth-provider.decorator.js.map +0 -1
  549. package/src/decorators/flow.decorator.js.map +0 -1
  550. package/src/decorators/front-mcp.decorator.js +0 -40
  551. package/src/decorators/front-mcp.decorator.js.map +0 -1
  552. package/src/decorators/hook.decorator.js.map +0 -1
  553. package/src/decorators/index.js.map +0 -1
  554. package/src/decorators/logger.decorator.js.map +0 -1
  555. package/src/decorators/plugin.decorator.js.map +0 -1
  556. package/src/decorators/prompt.decorator.js.map +0 -1
  557. package/src/decorators/provider.decorator.js.map +0 -1
  558. package/src/decorators/resource.decorator.js.map +0 -1
  559. package/src/decorators/tool.decorator.d.ts +0 -42
  560. package/src/decorators/tool.decorator.js +0 -45
  561. package/src/decorators/tool.decorator.js.map +0 -1
  562. package/src/decorators-old/async-with.decorator.d.ts +0 -9
  563. package/src/decorators-old/async-with.decorator.js +0 -23
  564. package/src/decorators-old/async-with.decorator.js.map +0 -1
  565. package/src/decorators-old/auth-hook.decorator.js.map +0 -1
  566. package/src/decorators-old/session-hook.decorator.js.map +0 -1
  567. package/src/decorators-old/tool-hook.decorator.d.ts +0 -14
  568. package/src/decorators-old/tool-hook.decorator.js +0 -27
  569. package/src/decorators-old/tool-hook.decorator.js.map +0 -1
  570. package/src/dynamic/dynamic.adapter.js.map +0 -1
  571. package/src/dynamic/dynamic.plugin.js.map +0 -1
  572. package/src/dynamic/dynamic.utils.d.ts +0 -3
  573. package/src/dynamic/dynamic.utils.js.map +0 -1
  574. package/src/dynamic/index.js.map +0 -1
  575. package/src/entries/adapter.entry.js.map +0 -1
  576. package/src/entries/app.entry.d.ts +0 -13
  577. package/src/entries/app.entry.js.map +0 -1
  578. package/src/entries/auth-provider.entry.js.map +0 -1
  579. package/src/entries/base.entry.js.map +0 -1
  580. package/src/entries/flow.entry.js.map +0 -1
  581. package/src/entries/hook.entry.js.map +0 -1
  582. package/src/entries/index.js.map +0 -1
  583. package/src/entries/logger.entry.js.map +0 -1
  584. package/src/entries/plugin.entry.js.map +0 -1
  585. package/src/entries/prompt.entry.js.map +0 -1
  586. package/src/entries/provider.entry.js.map +0 -1
  587. package/src/entries/resource.entry.js.map +0 -1
  588. package/src/entries/scope.entry.d.ts +0 -18
  589. package/src/entries/scope.entry.js +0 -8
  590. package/src/entries/scope.entry.js.map +0 -1
  591. package/src/entries/tool.entry.js.map +0 -1
  592. package/src/interfaces/adapter.interface.js.map +0 -1
  593. package/src/interfaces/app.interface.js.map +0 -1
  594. package/src/interfaces/auth-hook.interface.js.map +0 -1
  595. package/src/interfaces/auth-provider.interface.js.map +0 -1
  596. package/src/interfaces/base.interface.js.map +0 -1
  597. package/src/interfaces/flow.interface.d.ts +0 -41
  598. package/src/interfaces/flow.interface.js.map +0 -1
  599. package/src/interfaces/front-mcp.interface.js.map +0 -1
  600. package/src/interfaces/hook.interface.js.map +0 -1
  601. package/src/interfaces/index.js.map +0 -1
  602. package/src/interfaces/internal/flow.utils.d.ts +0 -24
  603. package/src/interfaces/internal/flow.utils.js.map +0 -1
  604. package/src/interfaces/internal/index.js.map +0 -1
  605. package/src/interfaces/internal/primary-auth-provider.interface.d.ts +0 -24
  606. package/src/interfaces/internal/primary-auth-provider.interface.js.map +0 -1
  607. package/src/interfaces/internal/registry.interface.d.ts +0 -97
  608. package/src/interfaces/internal/registry.interface.js.map +0 -1
  609. package/src/interfaces/logger.interface.js.map +0 -1
  610. package/src/interfaces/plugin.interface.js.map +0 -1
  611. package/src/interfaces/prompt.interface.js.map +0 -1
  612. package/src/interfaces/provider.interface.js.map +0 -1
  613. package/src/interfaces/resource.interface.js.map +0 -1
  614. package/src/interfaces/scope.interface.js.map +0 -1
  615. package/src/interfaces/server.interface.js.map +0 -1
  616. package/src/interfaces/session-hook.interface.js.map +0 -1
  617. package/src/interfaces/tool-hook.interface.js.map +0 -1
  618. package/src/interfaces/tool.interface.js.map +0 -1
  619. package/src/metadata/adapter.metadata.js.map +0 -1
  620. package/src/metadata/app.metadata.d.ts +0 -872
  621. package/src/metadata/app.metadata.js.map +0 -1
  622. package/src/metadata/auth-provider.metadata.js.map +0 -1
  623. package/src/metadata/flow.metadata.d.ts +0 -77
  624. package/src/metadata/flow.metadata.js.map +0 -1
  625. package/src/metadata/front-mcp.metadata.d.ts +0 -1144
  626. package/src/metadata/front-mcp.metadata.js.map +0 -1
  627. package/src/metadata/hook.metadata.js.map +0 -1
  628. package/src/metadata/index.js.map +0 -1
  629. package/src/metadata/logger.metadata.js.map +0 -1
  630. package/src/metadata/plugin.metadata.js.map +0 -1
  631. package/src/metadata/prompt.metadata.js.map +0 -1
  632. package/src/metadata/provider.metadata.js.map +0 -1
  633. package/src/metadata/resource.metadata.js.map +0 -1
  634. package/src/metadata/tool.metadata.d.ts +0 -178
  635. package/src/metadata/tool.metadata.js.map +0 -1
  636. package/src/providers/session.provider.js.map +0 -1
  637. package/src/records/adapter.record.js.map +0 -1
  638. package/src/records/app.record.js.map +0 -1
  639. package/src/records/auth-provider.record.js.map +0 -1
  640. package/src/records/flow.record.js.map +0 -1
  641. package/src/records/hook.record.js.map +0 -1
  642. package/src/records/index.js.map +0 -1
  643. package/src/records/logger.record.d.ts +0 -11
  644. package/src/records/logger.record.js.map +0 -1
  645. package/src/records/plugin.record.js.map +0 -1
  646. package/src/records/prompt.record.js.map +0 -1
  647. package/src/records/provider.record.js.map +0 -1
  648. package/src/records/resource.record.js.map +0 -1
  649. package/src/records/scope.record.d.ts +0 -18
  650. package/src/records/scope.record.js.map +0 -1
  651. package/src/records/tool.record.js.map +0 -1
  652. package/src/schemas/annotated-class.schema.js.map +0 -1
  653. package/src/schemas/http-input.schema.js.map +0 -1
  654. package/src/schemas/http-output.schema.d.ts +0 -2011
  655. package/src/schemas/http-output.schema.js.map +0 -1
  656. package/src/schemas/index.js.map +0 -1
  657. package/src/tokens/adapter.tokens.js.map +0 -1
  658. package/src/tokens/app.tokens.js.map +0 -1
  659. package/src/tokens/auth-provider.tokens.js.map +0 -1
  660. package/src/tokens/base.tokens.js.map +0 -1
  661. package/src/tokens/flow-hook.tokens.js.map +0 -1
  662. package/src/tokens/flow.tokens.js.map +0 -1
  663. package/src/tokens/front-mcp.tokens.js.map +0 -1
  664. package/src/tokens/index.js.map +0 -1
  665. package/src/tokens/logger.tokens.js.map +0 -1
  666. package/src/tokens/plugin.tokens.js.map +0 -1
  667. package/src/tokens/prompt.tokens.js.map +0 -1
  668. package/src/tokens/provider.tokens.js.map +0 -1
  669. package/src/tokens/resource.tokens.js.map +0 -1
  670. package/src/tokens/server.tokens.js.map +0 -1
  671. package/src/tokens/tool.tokens.js.map +0 -1
  672. package/src/types/auth/index.js.map +0 -1
  673. package/src/types/auth/jwt.types.js.map +0 -1
  674. package/src/types/auth/session.types.d.ts +0 -263
  675. package/src/types/auth/session.types.js.map +0 -1
  676. package/src/types/common.types.js.map +0 -1
  677. package/src/types/index.js.map +0 -1
  678. package/src/types/options/auth.options.d.ts +0 -513
  679. package/src/types/options/auth.options.js.map +0 -1
  680. package/src/types/options/http.options.js.map +0 -1
  681. package/src/types/options/index.js.map +0 -1
  682. package/src/types/options/logging.options.d.ts +0 -39
  683. package/src/types/options/logging.options.js.map +0 -1
  684. package/src/types/options/server-info.options.d.ts +0 -48
  685. package/src/types/options/server-info.options.js.map +0 -1
  686. package/src/types/options/session.options.d.ts +0 -67
  687. package/src/types/options/session.options.js.map +0 -1
  688. package/src/utils/decide-request-intent.utils.d.ts +0 -79
  689. package/src/utils/decide-request-intent.utils.js.map +0 -1
  690. package/src/utils/index.js.map +0 -1
  691. package/src/utils/path.utils.d.ts +0 -20
  692. package/src/utils/path.utils.js.map +0 -1
  693. /package/src/{decorators → common/decorators}/adapter.decorator.d.ts +0 -0
  694. /package/src/{decorators → common/decorators}/adapter.decorator.js +0 -0
  695. /package/src/{decorators → common/decorators}/app.decorator.d.ts +0 -0
  696. /package/src/{decorators → common/decorators}/app.decorator.js +0 -0
  697. /package/src/{decorators → common/decorators}/auth-provider.decorator.d.ts +0 -0
  698. /package/src/{decorators → common/decorators}/auth-provider.decorator.js +0 -0
  699. /package/src/{decorators → common/decorators}/flow.decorator.d.ts +0 -0
  700. /package/src/{decorators → common/decorators}/flow.decorator.js +0 -0
  701. /package/src/{decorators → common/decorators}/front-mcp.decorator.d.ts +0 -0
  702. /package/src/{decorators → common/decorators}/hook.decorator.d.ts +0 -0
  703. /package/src/{decorators → common/decorators}/hook.decorator.js +0 -0
  704. /package/src/{decorators → common/decorators}/index.d.ts +0 -0
  705. /package/src/{decorators → common/decorators}/index.js +0 -0
  706. /package/src/{decorators → common/decorators}/logger.decorator.d.ts +0 -0
  707. /package/src/{decorators → common/decorators}/logger.decorator.js +0 -0
  708. /package/src/{decorators → common/decorators}/plugin.decorator.d.ts +0 -0
  709. /package/src/{decorators → common/decorators}/plugin.decorator.js +0 -0
  710. /package/src/{decorators → common/decorators}/prompt.decorator.d.ts +0 -0
  711. /package/src/{decorators → common/decorators}/prompt.decorator.js +0 -0
  712. /package/src/{decorators → common/decorators}/provider.decorator.d.ts +0 -0
  713. /package/src/{decorators → common/decorators}/provider.decorator.js +0 -0
  714. /package/src/{decorators → common/decorators}/resource.decorator.d.ts +0 -0
  715. /package/src/{decorators → common/decorators}/resource.decorator.js +0 -0
  716. /package/src/{decorators-old → common/decorators-old}/auth-hook.decorator.d.ts +0 -0
  717. /package/src/{decorators-old → common/decorators-old}/auth-hook.decorator.js +0 -0
  718. /package/src/{decorators-old → common/decorators-old}/session-hook.decorator.d.ts +0 -0
  719. /package/src/{decorators-old → common/decorators-old}/session-hook.decorator.js +0 -0
  720. /package/src/{dynamic → common/dynamic}/dynamic.adapter.d.ts +0 -0
  721. /package/src/{dynamic → common/dynamic}/dynamic.adapter.js +0 -0
  722. /package/src/{dynamic → common/dynamic}/dynamic.plugin.d.ts +0 -0
  723. /package/src/{dynamic → common/dynamic}/dynamic.plugin.js +0 -0
  724. /package/src/{dynamic → common/dynamic}/dynamic.utils.js +0 -0
  725. /package/src/{dynamic → common/dynamic}/index.d.ts +0 -0
  726. /package/src/{dynamic → common/dynamic}/index.js +0 -0
  727. /package/src/{entries → common/entries}/adapter.entry.d.ts +0 -0
  728. /package/src/{entries → common/entries}/adapter.entry.js +0 -0
  729. /package/src/{entries → common/entries}/app.entry.js +0 -0
  730. /package/src/{entries → common/entries}/auth-provider.entry.d.ts +0 -0
  731. /package/src/{entries → common/entries}/auth-provider.entry.js +0 -0
  732. /package/src/{entries → common/entries}/base.entry.d.ts +0 -0
  733. /package/src/{entries → common/entries}/base.entry.js +0 -0
  734. /package/src/{entries → common/entries}/flow.entry.d.ts +0 -0
  735. /package/src/{entries → common/entries}/flow.entry.js +0 -0
  736. /package/src/{entries → common/entries}/hook.entry.d.ts +0 -0
  737. /package/src/{entries → common/entries}/hook.entry.js +0 -0
  738. /package/src/{entries → common/entries}/index.d.ts +0 -0
  739. /package/src/{entries → common/entries}/index.js +0 -0
  740. /package/src/{entries → common/entries}/logger.entry.d.ts +0 -0
  741. /package/src/{entries → common/entries}/logger.entry.js +0 -0
  742. /package/src/{entries → common/entries}/plugin.entry.d.ts +0 -0
  743. /package/src/{entries → common/entries}/plugin.entry.js +0 -0
  744. /package/src/{entries → common/entries}/prompt.entry.d.ts +0 -0
  745. /package/src/{entries → common/entries}/prompt.entry.js +0 -0
  746. /package/src/{entries → common/entries}/provider.entry.d.ts +0 -0
  747. /package/src/{entries → common/entries}/provider.entry.js +0 -0
  748. /package/src/{entries → common/entries}/resource.entry.d.ts +0 -0
  749. /package/src/{entries → common/entries}/resource.entry.js +0 -0
  750. /package/src/{entries → common/entries}/tool.entry.d.ts +0 -0
  751. /package/src/{entries → common/entries}/tool.entry.js +0 -0
  752. /package/src/{interfaces → common/interfaces}/adapter.interface.d.ts +0 -0
  753. /package/src/{interfaces → common/interfaces}/adapter.interface.js +0 -0
  754. /package/src/{interfaces → common/interfaces}/app.interface.d.ts +0 -0
  755. /package/src/{interfaces → common/interfaces}/app.interface.js +0 -0
  756. /package/src/{interfaces → common/interfaces}/auth-hook.interface.d.ts +0 -0
  757. /package/src/{interfaces → common/interfaces}/auth-hook.interface.js +0 -0
  758. /package/src/{interfaces → common/interfaces}/auth-provider.interface.d.ts +0 -0
  759. /package/src/{interfaces → common/interfaces}/auth-provider.interface.js +0 -0
  760. /package/src/{interfaces → common/interfaces}/base.interface.d.ts +0 -0
  761. /package/src/{interfaces → common/interfaces}/base.interface.js +0 -0
  762. /package/src/{interfaces → common/interfaces}/flow.interface.js +0 -0
  763. /package/src/{interfaces → common/interfaces}/front-mcp.interface.d.ts +0 -0
  764. /package/src/{interfaces → common/interfaces}/front-mcp.interface.js +0 -0
  765. /package/src/{interfaces → common/interfaces}/hook.interface.d.ts +0 -0
  766. /package/src/{interfaces → common/interfaces}/hook.interface.js +0 -0
  767. /package/src/{interfaces → common/interfaces}/index.d.ts +0 -0
  768. /package/src/{interfaces → common/interfaces}/index.js +0 -0
  769. /package/src/{interfaces → common/interfaces}/internal/flow.utils.js +0 -0
  770. /package/src/{interfaces → common/interfaces}/internal/index.d.ts +0 -0
  771. /package/src/{interfaces → common/interfaces}/internal/index.js +0 -0
  772. /package/src/{interfaces → common/interfaces}/internal/primary-auth-provider.interface.js +0 -0
  773. /package/src/{interfaces → common/interfaces}/internal/registry.interface.js +0 -0
  774. /package/src/{interfaces → common/interfaces}/logger.interface.d.ts +0 -0
  775. /package/src/{interfaces → common/interfaces}/logger.interface.js +0 -0
  776. /package/src/{interfaces → common/interfaces}/plugin.interface.d.ts +0 -0
  777. /package/src/{interfaces → common/interfaces}/plugin.interface.js +0 -0
  778. /package/src/{interfaces → common/interfaces}/prompt.interface.d.ts +0 -0
  779. /package/src/{interfaces → common/interfaces}/prompt.interface.js +0 -0
  780. /package/src/{interfaces → common/interfaces}/provider.interface.d.ts +0 -0
  781. /package/src/{interfaces → common/interfaces}/provider.interface.js +0 -0
  782. /package/src/{interfaces → common/interfaces}/resource.interface.d.ts +0 -0
  783. /package/src/{interfaces → common/interfaces}/resource.interface.js +0 -0
  784. /package/src/{interfaces → common/interfaces}/scope.interface.d.ts +0 -0
  785. /package/src/{interfaces → common/interfaces}/scope.interface.js +0 -0
  786. /package/src/{interfaces → common/interfaces}/server.interface.d.ts +0 -0
  787. /package/src/{interfaces → common/interfaces}/server.interface.js +0 -0
  788. /package/src/{interfaces → common/interfaces}/session-hook.interface.d.ts +0 -0
  789. /package/src/{interfaces → common/interfaces}/session-hook.interface.js +0 -0
  790. /package/src/{interfaces → common/interfaces}/tool-hook.interface.d.ts +0 -0
  791. /package/src/{interfaces → common/interfaces}/tool-hook.interface.js +0 -0
  792. /package/src/{interfaces → common/interfaces}/tool.interface.d.ts +0 -0
  793. /package/src/{interfaces → common/interfaces}/tool.interface.js +0 -0
  794. /package/src/{metadata → common/metadata}/adapter.metadata.d.ts +0 -0
  795. /package/src/{metadata → common/metadata}/adapter.metadata.js +0 -0
  796. /package/src/{metadata → common/metadata}/app.metadata.js +0 -0
  797. /package/src/{metadata → common/metadata}/auth-provider.metadata.d.ts +0 -0
  798. /package/src/{metadata → common/metadata}/auth-provider.metadata.js +0 -0
  799. /package/src/{metadata → common/metadata}/flow.metadata.js +0 -0
  800. /package/src/{metadata → common/metadata}/front-mcp.metadata.js +0 -0
  801. /package/src/{metadata → common/metadata}/hook.metadata.d.ts +0 -0
  802. /package/src/{metadata → common/metadata}/hook.metadata.js +0 -0
  803. /package/src/{metadata → common/metadata}/index.d.ts +0 -0
  804. /package/src/{metadata → common/metadata}/index.js +0 -0
  805. /package/src/{metadata → common/metadata}/logger.metadata.d.ts +0 -0
  806. /package/src/{metadata → common/metadata}/logger.metadata.js +0 -0
  807. /package/src/{metadata → common/metadata}/plugin.metadata.d.ts +0 -0
  808. /package/src/{metadata → common/metadata}/plugin.metadata.js +0 -0
  809. /package/src/{metadata → common/metadata}/prompt.metadata.d.ts +0 -0
  810. /package/src/{metadata → common/metadata}/prompt.metadata.js +0 -0
  811. /package/src/{metadata → common/metadata}/provider.metadata.d.ts +0 -0
  812. /package/src/{metadata → common/metadata}/provider.metadata.js +0 -0
  813. /package/src/{metadata → common/metadata}/resource.metadata.d.ts +0 -0
  814. /package/src/{metadata → common/metadata}/resource.metadata.js +0 -0
  815. /package/src/{metadata → common/metadata}/tool.metadata.js +0 -0
  816. /package/src/{providers → common/providers}/session.provider.d.ts +0 -0
  817. /package/src/{providers → common/providers}/session.provider.js +0 -0
  818. /package/src/{records → common/records}/adapter.record.d.ts +0 -0
  819. /package/src/{records → common/records}/adapter.record.js +0 -0
  820. /package/src/{records → common/records}/app.record.d.ts +0 -0
  821. /package/src/{records → common/records}/app.record.js +0 -0
  822. /package/src/{records → common/records}/auth-provider.record.d.ts +0 -0
  823. /package/src/{records → common/records}/auth-provider.record.js +0 -0
  824. /package/src/{records → common/records}/flow.record.d.ts +0 -0
  825. /package/src/{records → common/records}/flow.record.js +0 -0
  826. /package/src/{records → common/records}/hook.record.d.ts +0 -0
  827. /package/src/{records → common/records}/hook.record.js +0 -0
  828. /package/src/{records → common/records}/index.d.ts +0 -0
  829. /package/src/{records → common/records}/index.js +0 -0
  830. /package/src/{records → common/records}/logger.record.js +0 -0
  831. /package/src/{records → common/records}/plugin.record.d.ts +0 -0
  832. /package/src/{records → common/records}/plugin.record.js +0 -0
  833. /package/src/{records → common/records}/prompt.record.d.ts +0 -0
  834. /package/src/{records → common/records}/prompt.record.js +0 -0
  835. /package/src/{records → common/records}/provider.record.d.ts +0 -0
  836. /package/src/{records → common/records}/provider.record.js +0 -0
  837. /package/src/{records → common/records}/resource.record.d.ts +0 -0
  838. /package/src/{records → common/records}/resource.record.js +0 -0
  839. /package/src/{records → common/records}/scope.record.js +0 -0
  840. /package/src/{records → common/records}/tool.record.d.ts +0 -0
  841. /package/src/{records → common/records}/tool.record.js +0 -0
  842. /package/src/{schemas → common/schemas}/annotated-class.schema.d.ts +0 -0
  843. /package/src/{schemas → common/schemas}/annotated-class.schema.js +0 -0
  844. /package/src/{schemas → common/schemas}/http-input.schema.d.ts +0 -0
  845. /package/src/{schemas → common/schemas}/http-input.schema.js +0 -0
  846. /package/src/{schemas → common/schemas}/http-output.schema.js +0 -0
  847. /package/src/{schemas → common/schemas}/index.d.ts +0 -0
  848. /package/src/{schemas → common/schemas}/index.js +0 -0
  849. /package/src/{tokens → common/tokens}/adapter.tokens.d.ts +0 -0
  850. /package/src/{tokens → common/tokens}/adapter.tokens.js +0 -0
  851. /package/src/{tokens → common/tokens}/app.tokens.d.ts +0 -0
  852. /package/src/{tokens → common/tokens}/app.tokens.js +0 -0
  853. /package/src/{tokens → common/tokens}/auth-provider.tokens.d.ts +0 -0
  854. /package/src/{tokens → common/tokens}/auth-provider.tokens.js +0 -0
  855. /package/src/{tokens → common/tokens}/base.tokens.d.ts +0 -0
  856. /package/src/{tokens → common/tokens}/base.tokens.js +0 -0
  857. /package/src/{tokens → common/tokens}/flow-hook.tokens.d.ts +0 -0
  858. /package/src/{tokens → common/tokens}/flow-hook.tokens.js +0 -0
  859. /package/src/{tokens → common/tokens}/flow.tokens.d.ts +0 -0
  860. /package/src/{tokens → common/tokens}/flow.tokens.js +0 -0
  861. /package/src/{tokens → common/tokens}/front-mcp.tokens.d.ts +0 -0
  862. /package/src/{tokens → common/tokens}/front-mcp.tokens.js +0 -0
  863. /package/src/{tokens → common/tokens}/index.d.ts +0 -0
  864. /package/src/{tokens → common/tokens}/index.js +0 -0
  865. /package/src/{tokens → common/tokens}/logger.tokens.d.ts +0 -0
  866. /package/src/{tokens → common/tokens}/logger.tokens.js +0 -0
  867. /package/src/{tokens → common/tokens}/plugin.tokens.d.ts +0 -0
  868. /package/src/{tokens → common/tokens}/plugin.tokens.js +0 -0
  869. /package/src/{tokens → common/tokens}/prompt.tokens.d.ts +0 -0
  870. /package/src/{tokens → common/tokens}/prompt.tokens.js +0 -0
  871. /package/src/{tokens → common/tokens}/provider.tokens.d.ts +0 -0
  872. /package/src/{tokens → common/tokens}/provider.tokens.js +0 -0
  873. /package/src/{tokens → common/tokens}/resource.tokens.d.ts +0 -0
  874. /package/src/{tokens → common/tokens}/resource.tokens.js +0 -0
  875. /package/src/{tokens → common/tokens}/server.tokens.d.ts +0 -0
  876. /package/src/{tokens → common/tokens}/server.tokens.js +0 -0
  877. /package/src/{tokens → common/tokens}/tool.tokens.d.ts +0 -0
  878. /package/src/{tokens → common/tokens}/tool.tokens.js +0 -0
  879. /package/src/{types → common/types}/auth/index.d.ts +0 -0
  880. /package/src/{types → common/types}/auth/index.js +0 -0
  881. /package/src/{types → common/types}/auth/jwt.types.d.ts +0 -0
  882. /package/src/{types → common/types}/auth/jwt.types.js +0 -0
  883. /package/src/{types → common/types}/auth/session.types.js +0 -0
  884. /package/src/{types → common/types}/common.types.d.ts +0 -0
  885. /package/src/{types → common/types}/common.types.js +0 -0
  886. /package/src/{types → common/types}/index.d.ts +0 -0
  887. /package/src/{types → common/types}/index.js +0 -0
  888. /package/src/{types → common/types}/options/auth.options.js +0 -0
  889. /package/src/{types → common/types}/options/http.options.d.ts +0 -0
  890. /package/src/{types → common/types}/options/http.options.js +0 -0
  891. /package/src/{types → common/types}/options/index.d.ts +0 -0
  892. /package/src/{types → common/types}/options/index.js +0 -0
  893. /package/src/{types → common/types}/options/logging.options.js +0 -0
  894. /package/src/{types → common/types}/options/server-info.options.js +0 -0
  895. /package/src/{types → common/types}/options/session.options.js +0 -0
  896. /package/src/{utils → common/utils}/decide-request-intent.utils.js +0 -0
  897. /package/src/{utils → common/utils}/index.d.ts +0 -0
  898. /package/src/{utils → common/utils}/index.js +0 -0
  899. /package/src/{utils → common/utils}/path.utils.js +0 -0
@@ -0,0 +1,123 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.wellKnownAsStateSchema = exports.outputSchema = void 0;
4
+ const tslib_1 = require("tslib");
5
+ // auth/flows/well-known.oauth-authorization-server.flow.ts
6
+ require("reflect-metadata");
7
+ const zod_1 = require("zod");
8
+ const common_1 = require("../../common");
9
+ const path_utils_1 = require("../path.utils");
10
+ const inputSchema = common_1.httpInputSchema;
11
+ // ===== Result =====
12
+ const AuthServerMetadataSchema = zod_1.z.object({
13
+ kind: zod_1.z.literal('json'),
14
+ status: zod_1.z.literal(200),
15
+ contentType: zod_1.z.literal('application/json; charset=utf-8'),
16
+ body: zod_1.z
17
+ .object({
18
+ issuer: zod_1.z.string().min(1),
19
+ authorization_endpoint: zod_1.z.string().min(1),
20
+ token_endpoint: zod_1.z.string().min(1),
21
+ userinfo_endpoint: zod_1.z.string().min(1).optional(),
22
+ jwks_uri: zod_1.z.string().min(1),
23
+ registration_endpoint: zod_1.z.string().min(1).optional(),
24
+ token_endpoint_auth_methods_supported: zod_1.z
25
+ .array(zod_1.z.enum(['client_secret_basic', 'client_secret_post', 'private_key_jwt']))
26
+ .optional(),
27
+ response_types_supported: zod_1.z.array(zod_1.z.enum(['code'])).default(['code']),
28
+ grant_types_supported: zod_1.z
29
+ .array(zod_1.z.enum(['authorization_code', 'refresh_token']))
30
+ .default(['authorization_code', 'refresh_token']),
31
+ scopes_supported: zod_1.z.array(zod_1.z.string()).default(['openid', 'profile', 'email']),
32
+ code_challenge_methods_supported: zod_1.z.array(zod_1.z.enum(['S256'])).default(['S256']),
33
+ })
34
+ .passthrough(),
35
+ });
36
+ exports.outputSchema = zod_1.z.union([AuthServerMetadataSchema, common_1.HttpRedirectSchema, common_1.HttpTextSchema]);
37
+ exports.wellKnownAsStateSchema = zod_1.z.object({
38
+ baseUrl: zod_1.z.string().min(1), // baseUrl + entryPrefix (unsuffixed)
39
+ scopesSupported: zod_1.z.array(zod_1.z.string()).default(['openid', 'profile', 'email']),
40
+ tokenEndpointAuthMethods: zod_1.z
41
+ .array(zod_1.z.enum(['client_secret_basic', 'client_secret_post', 'private_key_jwt']))
42
+ .default(['client_secret_basic', 'client_secret_post']),
43
+ dcrEnabled: zod_1.z.boolean().default(true),
44
+ isOrchestrated: zod_1.z.boolean(),
45
+ });
46
+ const wellKnownAsPlan = {
47
+ pre: ['parseInput'],
48
+ execute: ['collectData'],
49
+ };
50
+ const name = 'well-known.oauth-authorization-server';
51
+ const Stage = (0, common_1.StageHookOf)(name);
52
+ let WellKnownAsFlow = class WellKnownAsFlow extends common_1.FlowBase {
53
+ static canActivate(request, scope) {
54
+ return (0, path_utils_1.makeWellKnownPaths)('oauth-authorization-server', scope.entryPath, scope.routeBase).has(request.path);
55
+ }
56
+ async parseInput() {
57
+ const { request } = this.rawInput;
58
+ if (!request)
59
+ throw new Error('Request is undefined');
60
+ const baseUrl = (0, path_utils_1.getRequestBaseUrl)(request, this.scope.entryPath);
61
+ this.state.set(exports.wellKnownAsStateSchema.parse({
62
+ baseUrl,
63
+ scopesSupported: [],
64
+ tokenEndpointAuthMethods: [],
65
+ dcrEnabled: false, //scope.oauth.dcrEnabled,
66
+ isOrchestrated: !this.scope.metadata.auth, // scope.orchestrated,
67
+ }));
68
+ }
69
+ async collectData() {
70
+ const { baseUrl, scopesSupported, tokenEndpointAuthMethods, dcrEnabled, isOrchestrated } = this.state.required;
71
+ // Orchestrated => gateway is the AS
72
+ if (isOrchestrated) {
73
+ const baseIssuer = `${baseUrl}`;
74
+ this.respond({
75
+ kind: 'json',
76
+ contentType: 'application/json; charset=utf-8',
77
+ status: 200,
78
+ body: {
79
+ issuer: baseIssuer,
80
+ authorization_endpoint: `${baseIssuer}/oauth/authorize`,
81
+ token_endpoint: `${baseIssuer}/oauth/token`,
82
+ userinfo_endpoint: `${baseIssuer}/oauth/userinfo`,
83
+ jwks_uri: `${baseIssuer}/.well-known/jwks.json`,
84
+ registration_endpoint: `${baseIssuer}/oauth/register`,
85
+ token_endpoint_auth_methods_supported: tokenEndpointAuthMethods,
86
+ response_types_supported: ['code'],
87
+ grant_types_supported: ['authorization_code', 'refresh_token'],
88
+ scopes_supported: scopesSupported,
89
+ code_challenge_methods_supported: ['S256'],
90
+ },
91
+ });
92
+ return;
93
+ }
94
+ const primary = this.scope.auth;
95
+ this.respond(common_1.httpRespond.redirect(`${primary.issuer}/.well-known/oauth-authorization-server`));
96
+ }
97
+ };
98
+ tslib_1.__decorate([
99
+ Stage('parseInput'),
100
+ tslib_1.__metadata("design:type", Function),
101
+ tslib_1.__metadata("design:paramtypes", []),
102
+ tslib_1.__metadata("design:returntype", Promise)
103
+ ], WellKnownAsFlow.prototype, "parseInput", null);
104
+ tslib_1.__decorate([
105
+ Stage('collectData'),
106
+ tslib_1.__metadata("design:type", Function),
107
+ tslib_1.__metadata("design:paramtypes", []),
108
+ tslib_1.__metadata("design:returntype", Promise)
109
+ ], WellKnownAsFlow.prototype, "collectData", null);
110
+ WellKnownAsFlow = tslib_1.__decorate([
111
+ (0, common_1.Flow)({
112
+ name,
113
+ plan: wellKnownAsPlan,
114
+ inputSchema,
115
+ outputSchema: exports.outputSchema,
116
+ access: 'public',
117
+ middleware: {
118
+ method: 'GET',
119
+ },
120
+ })
121
+ ], WellKnownAsFlow);
122
+ exports.default = WellKnownAsFlow;
123
+ //# sourceMappingURL=well-known.oauth-authorization-server.flow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"well-known.oauth-authorization-server.flow.js","sourceRoot":"","sources":["../../../../src/auth/flows/well-known.oauth-authorization-server.flow.ts"],"names":[],"mappings":"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","sourcesContent":["// auth/flows/well-known.oauth-authorization-server.flow.ts\nimport 'reflect-metadata';\nimport {z} from 'zod';\nimport {\n HttpRedirectSchema,\n httpRespond,\n HttpTextSchema,\n Flow,\n FlowBase,\n FlowRunOptions,\n ScopeEntry,\n ServerRequest,\n StageHookOf, httpInputSchema, FlowPlan,\n} from '../../common';\nimport {getRequestBaseUrl, makeWellKnownPaths} from '../path.utils';\n\n\nconst inputSchema = httpInputSchema;\n\n\n// ===== Result =====\nconst AuthServerMetadataSchema = z.object({\n kind: z.literal('json'),\n status: z.literal(200),\n contentType: z.literal('application/json; charset=utf-8'),\n body: z\n .object({\n issuer: z.string().min(1),\n authorization_endpoint: z.string().min(1),\n token_endpoint: z.string().min(1),\n userinfo_endpoint: z.string().min(1).optional(),\n jwks_uri: z.string().min(1),\n registration_endpoint: z.string().min(1).optional(),\n token_endpoint_auth_methods_supported: z\n .array(z.enum(['client_secret_basic', 'client_secret_post', 'private_key_jwt']))\n .optional(),\n response_types_supported: z.array(z.enum(['code'])).default(['code']),\n grant_types_supported: z\n .array(z.enum(['authorization_code', 'refresh_token']))\n .default(['authorization_code', 'refresh_token']),\n scopes_supported: z.array(z.string()).default(['openid', 'profile', 'email']),\n code_challenge_methods_supported: z.array(z.enum(['S256'])).default(['S256']),\n })\n .passthrough(),\n});\n\nexport const outputSchema = z.union([AuthServerMetadataSchema, HttpRedirectSchema, HttpTextSchema]);\n\nexport const wellKnownAsStateSchema = z.object({\n baseUrl: z.string().min(1), // baseUrl + entryPrefix (unsuffixed)\n scopesSupported: z.array(z.string()).default(['openid', 'profile', 'email']),\n tokenEndpointAuthMethods: z\n .array(z.enum(['client_secret_basic', 'client_secret_post', 'private_key_jwt']))\n .default(['client_secret_basic', 'client_secret_post']),\n dcrEnabled: z.boolean().default(true),\n isOrchestrated: z.boolean(),\n});\n\n\nconst wellKnownAsPlan = {\n pre: ['parseInput'],\n execute: ['collectData'],\n} as const satisfies FlowPlan<string>;\n\ntype WellKnownAsPlan = typeof wellKnownAsPlan;\ntype WellKnownAsFlowOptions = FlowRunOptions<\n WellKnownAsFlow,\n WellKnownAsPlan,\n typeof inputSchema,\n typeof outputSchema,\n typeof wellKnownAsStateSchema\n>\n\ndeclare global {\n interface ExtendFlows {\n 'well-known.oauth-authorization-server': WellKnownAsFlowOptions;\n }\n}\n\nconst name = 'well-known.oauth-authorization-server' as const;\nconst Stage = StageHookOf(name);\n\n\n@Flow({\n name,\n plan: wellKnownAsPlan,\n inputSchema,\n outputSchema,\n access: 'public',\n middleware: {\n method: 'GET',\n },\n})\nexport default class WellKnownAsFlow extends FlowBase<typeof name> {\n static canActivate(request: ServerRequest, scope: ScopeEntry) {\n return makeWellKnownPaths('oauth-authorization-server', scope.entryPath, scope.routeBase).has(request.path);\n }\n\n @Stage('parseInput')\n async parseInput() {\n const {request} = this.rawInput;\n if (!request) throw new Error('Request is undefined');\n\n const baseUrl = getRequestBaseUrl(request, this.scope.entryPath);\n this.state.set(wellKnownAsStateSchema.parse({\n baseUrl,\n scopesSupported: [],\n tokenEndpointAuthMethods: [],\n dcrEnabled: false, //scope.oauth.dcrEnabled,\n isOrchestrated: !this.scope.metadata.auth, // scope.orchestrated,\n }));\n }\n\n @Stage('collectData')\n async collectData() {\n const {baseUrl, scopesSupported, tokenEndpointAuthMethods, dcrEnabled, isOrchestrated} = this.state.required;\n // Orchestrated => gateway is the AS\n if (isOrchestrated) {\n const baseIssuer = `${baseUrl}`;\n this.respond({\n kind: 'json',\n contentType: 'application/json; charset=utf-8',\n status: 200,\n body: {\n issuer: baseIssuer,\n authorization_endpoint: `${baseIssuer}/oauth/authorize`,\n token_endpoint: `${baseIssuer}/oauth/token`,\n userinfo_endpoint: `${baseIssuer}/oauth/userinfo`,\n jwks_uri: `${baseIssuer}/.well-known/jwks.json`,\n registration_endpoint: `${baseIssuer}/oauth/register`,\n token_endpoint_auth_methods_supported: tokenEndpointAuthMethods,\n response_types_supported: ['code'],\n grant_types_supported: ['authorization_code', 'refresh_token'],\n scopes_supported: scopesSupported,\n code_challenge_methods_supported: ['S256'],\n },\n });\n return;\n }\n const primary = this.scope.auth;\n this.respond(httpRespond.redirect(`${primary.issuer}/.well-known/oauth-authorization-server`));\n }\n}\n"]}
@@ -0,0 +1,159 @@
1
+ import 'reflect-metadata';
2
+ import { z } from 'zod';
3
+ import { FlowBase, FlowRunOptions, ScopeEntry, ServerRequest } from '../../common';
4
+ declare const inputSchema: z.ZodObject<{
5
+ request: z.ZodObject<{}, "passthrough", z.ZodTypeAny, z.objectOutputType<{}, z.ZodTypeAny, "passthrough">, z.objectInputType<{}, z.ZodTypeAny, "passthrough">>;
6
+ response: z.ZodObject<{}, "passthrough", z.ZodTypeAny, z.objectOutputType<{}, z.ZodTypeAny, "passthrough">, z.objectInputType<{}, z.ZodTypeAny, "passthrough">>;
7
+ next: z.ZodOptional<z.ZodFunction<z.ZodTuple<[], z.ZodUnknown>, z.ZodUnknown>>;
8
+ }, "strip", z.ZodTypeAny, {
9
+ request: {} & {
10
+ [k: string]: unknown;
11
+ };
12
+ response: {} & {
13
+ [k: string]: unknown;
14
+ };
15
+ next?: ((...args: unknown[]) => unknown) | undefined;
16
+ }, {
17
+ request: {} & {
18
+ [k: string]: unknown;
19
+ };
20
+ response: {} & {
21
+ [k: string]: unknown;
22
+ };
23
+ next?: ((...args: unknown[]) => unknown) | undefined;
24
+ }>;
25
+ declare const stateSchema: z.ZodObject<{
26
+ resource: z.ZodString;
27
+ baseUrl: z.ZodString;
28
+ scopesSupported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
29
+ isOrchestrated: z.ZodBoolean;
30
+ }, "strip", z.ZodTypeAny, {
31
+ resource: string;
32
+ baseUrl: string;
33
+ scopesSupported: string[];
34
+ isOrchestrated: boolean;
35
+ }, {
36
+ resource: string;
37
+ baseUrl: string;
38
+ isOrchestrated: boolean;
39
+ scopesSupported?: string[] | undefined;
40
+ }>;
41
+ declare const outputSchema: z.ZodObject<{
42
+ kind: z.ZodLiteral<"json">;
43
+ status: z.ZodEffects<z.ZodNumber, number, number>;
44
+ contentType: z.ZodDefault<z.ZodString>;
45
+ headers: z.ZodOptional<z.ZodDefault<z.ZodRecord<z.ZodString, z.ZodUnion<[z.ZodString, z.ZodUnion<[z.ZodString, z.ZodArray<z.ZodString, "many">]>]>>>>;
46
+ cookies: z.ZodOptional<z.ZodDefault<z.ZodArray<z.ZodObject<{
47
+ name: z.ZodString;
48
+ value: z.ZodString;
49
+ path: z.ZodDefault<z.ZodString>;
50
+ domain: z.ZodOptional<z.ZodString>;
51
+ httpOnly: z.ZodDefault<z.ZodBoolean>;
52
+ secure: z.ZodOptional<z.ZodBoolean>;
53
+ sameSite: z.ZodOptional<z.ZodEnum<["lax", "strict", "none"]>>;
54
+ maxAge: z.ZodOptional<z.ZodNumber>;
55
+ expires: z.ZodOptional<z.ZodDate>;
56
+ }, "strip", z.ZodTypeAny, {
57
+ value: string;
58
+ path: string;
59
+ name: string;
60
+ httpOnly: boolean;
61
+ domain?: string | undefined;
62
+ secure?: boolean | undefined;
63
+ sameSite?: "lax" | "strict" | "none" | undefined;
64
+ maxAge?: number | undefined;
65
+ expires?: Date | undefined;
66
+ }, {
67
+ value: string;
68
+ name: string;
69
+ path?: string | undefined;
70
+ domain?: string | undefined;
71
+ httpOnly?: boolean | undefined;
72
+ secure?: boolean | undefined;
73
+ sameSite?: "lax" | "strict" | "none" | undefined;
74
+ maxAge?: number | undefined;
75
+ expires?: Date | undefined;
76
+ }>, "many">>>;
77
+ } & {
78
+ body: z.ZodObject<{
79
+ resource: z.ZodString;
80
+ authorization_servers: z.ZodArray<z.ZodString, "many">;
81
+ scopes_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
82
+ bearer_methods_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
83
+ }, "passthrough", z.ZodTypeAny, z.objectOutputType<{
84
+ resource: z.ZodString;
85
+ authorization_servers: z.ZodArray<z.ZodString, "many">;
86
+ scopes_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
87
+ bearer_methods_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
88
+ }, z.ZodTypeAny, "passthrough">, z.objectInputType<{
89
+ resource: z.ZodString;
90
+ authorization_servers: z.ZodArray<z.ZodString, "many">;
91
+ scopes_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
92
+ bearer_methods_supported: z.ZodDefault<z.ZodArray<z.ZodString, "many">>;
93
+ }, z.ZodTypeAny, "passthrough">>;
94
+ }, "strip", z.ZodTypeAny, {
95
+ status: number;
96
+ kind: "json";
97
+ body: {
98
+ resource: string;
99
+ authorization_servers: string[];
100
+ scopes_supported: string[];
101
+ bearer_methods_supported: string[];
102
+ } & {
103
+ [k: string]: unknown;
104
+ };
105
+ contentType: string;
106
+ headers?: Record<string, string | string[]> | undefined;
107
+ cookies?: {
108
+ value: string;
109
+ path: string;
110
+ name: string;
111
+ httpOnly: boolean;
112
+ domain?: string | undefined;
113
+ secure?: boolean | undefined;
114
+ sameSite?: "lax" | "strict" | "none" | undefined;
115
+ maxAge?: number | undefined;
116
+ expires?: Date | undefined;
117
+ }[] | undefined;
118
+ }, {
119
+ status: number;
120
+ kind: "json";
121
+ body: {
122
+ resource: string;
123
+ authorization_servers: string[];
124
+ scopes_supported?: string[] | undefined;
125
+ bearer_methods_supported?: string[] | undefined;
126
+ } & {
127
+ [k: string]: unknown;
128
+ };
129
+ headers?: Record<string, string | string[]> | undefined;
130
+ cookies?: {
131
+ value: string;
132
+ name: string;
133
+ path?: string | undefined;
134
+ domain?: string | undefined;
135
+ httpOnly?: boolean | undefined;
136
+ secure?: boolean | undefined;
137
+ sameSite?: "lax" | "strict" | "none" | undefined;
138
+ maxAge?: number | undefined;
139
+ expires?: Date | undefined;
140
+ }[] | undefined;
141
+ contentType?: string | undefined;
142
+ }>;
143
+ declare const plan: {
144
+ readonly pre: ["parseInput"];
145
+ readonly execute: ["collectData"];
146
+ readonly post: ["validateOutput"];
147
+ };
148
+ declare global {
149
+ interface ExtendFlows {
150
+ 'well-known.oauth-protected-resource': FlowRunOptions<WellKnownPrmFlow, typeof plan, typeof inputSchema, typeof outputSchema, typeof stateSchema>;
151
+ }
152
+ }
153
+ declare const name: "well-known.oauth-protected-resource";
154
+ export default class WellKnownPrmFlow extends FlowBase<typeof name> {
155
+ static canActivate(request: ServerRequest, scope: ScopeEntry): boolean;
156
+ parseInput(): Promise<void>;
157
+ collectData(): Promise<void>;
158
+ }
159
+ export {};
@@ -0,0 +1,107 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ // auth/flows/well-known.prm.flow.ts
5
+ require("reflect-metadata");
6
+ const zod_1 = require("zod");
7
+ const common_1 = require("../../common");
8
+ const path_utils_1 = require("../path.utils");
9
+ const inputSchema = common_1.httpInputSchema;
10
+ const stateSchema = zod_1.z.object({
11
+ resource: zod_1.z.string().min(1),
12
+ baseUrl: zod_1.z.string().min(1),
13
+ scopesSupported: zod_1.z.array(zod_1.z.string()).default(['openid', 'profile', 'email']),
14
+ isOrchestrated: zod_1.z.boolean(),
15
+ });
16
+ const outputSchema = common_1.HttpJsonSchema.extend({
17
+ body: zod_1.z
18
+ .object({
19
+ resource: zod_1.z.string().min(1),
20
+ authorization_servers: zod_1.z.array(zod_1.z.string().min(1)).min(1),
21
+ scopes_supported: zod_1.z.array(zod_1.z.string()).default(['openid', 'profile', 'email']),
22
+ bearer_methods_supported: zod_1.z.array(zod_1.z.string()).default(['header']),
23
+ })
24
+ .passthrough(),
25
+ });
26
+ const plan = {
27
+ pre: ['parseInput'],
28
+ execute: ['collectData'],
29
+ post: ['validateOutput'],
30
+ };
31
+ const name = 'well-known.oauth-protected-resource';
32
+ const Stage = (0, common_1.StageHookOf)(name);
33
+ let WellKnownPrmFlow = class WellKnownPrmFlow extends common_1.FlowBase {
34
+ static canActivate(request, scope) {
35
+ return (0, path_utils_1.makeWellKnownPaths)('oauth-protected-resource', scope.entryPath, scope.routeBase).has(request.path);
36
+ }
37
+ async parseInput() {
38
+ const { request } = this.rawInput;
39
+ const scope = this.scope;
40
+ if (!request)
41
+ throw new Error('Request is undefined');
42
+ const resource = (0, path_utils_1.computeResource)(request, scope.entryPath, scope.routeBase);
43
+ const baseUrl = (0, path_utils_1.getRequestBaseUrl)(request, scope.entryPath);
44
+ this.state.set(stateSchema.parse({
45
+ resource,
46
+ baseUrl,
47
+ scopesSupported: ['openid', 'profile', 'email'],
48
+ isOrchestrated: false, //scope.orchestrated,// TODO: fix
49
+ }));
50
+ }
51
+ async collectData() {
52
+ const { resource, baseUrl, scopesSupported, isOrchestrated } = this.state.required;
53
+ if (isOrchestrated) {
54
+ this.respond({
55
+ kind: 'json',
56
+ contentType: 'application/json; charset=utf-8',
57
+ status: 200,
58
+ body: {
59
+ resource,
60
+ authorization_servers: [baseUrl],
61
+ scopes_supported: scopesSupported,
62
+ bearer_methods_supported: ['header'],
63
+ },
64
+ });
65
+ return;
66
+ }
67
+ const issuer = this.scope.auth.issuer;
68
+ // Transparent scope
69
+ this.respond({
70
+ kind: 'json',
71
+ status: 200,
72
+ contentType: 'application/json; charset=utf-8',
73
+ body: {
74
+ resource,
75
+ authorization_servers: [issuer],
76
+ scopes_supported: scopesSupported,
77
+ bearer_methods_supported: ['header'],
78
+ },
79
+ });
80
+ }
81
+ };
82
+ tslib_1.__decorate([
83
+ Stage('parseInput'),
84
+ tslib_1.__metadata("design:type", Function),
85
+ tslib_1.__metadata("design:paramtypes", []),
86
+ tslib_1.__metadata("design:returntype", Promise)
87
+ ], WellKnownPrmFlow.prototype, "parseInput", null);
88
+ tslib_1.__decorate([
89
+ Stage('collectData'),
90
+ tslib_1.__metadata("design:type", Function),
91
+ tslib_1.__metadata("design:paramtypes", []),
92
+ tslib_1.__metadata("design:returntype", Promise)
93
+ ], WellKnownPrmFlow.prototype, "collectData", null);
94
+ WellKnownPrmFlow = tslib_1.__decorate([
95
+ (0, common_1.Flow)({
96
+ name,
97
+ plan,
98
+ inputSchema,
99
+ outputSchema,
100
+ access: 'public',
101
+ middleware: {
102
+ method: 'GET',
103
+ },
104
+ })
105
+ ], WellKnownPrmFlow);
106
+ exports.default = WellKnownPrmFlow;
107
+ //# sourceMappingURL=well-known.prm.flow.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"well-known.prm.flow.js","sourceRoot":"","sources":["../../../../src/auth/flows/well-known.prm.flow.ts"],"names":[],"mappings":"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","sourcesContent":["// auth/flows/well-known.prm.flow.ts\nimport 'reflect-metadata';\nimport {z} from 'zod';\nimport {\n Flow,\n FlowBase, FlowPlan,\n FlowRunOptions,\n httpInputSchema,\n HttpJsonSchema,\n ScopeEntry,\n ServerRequest,\n StageHookOf,\n} from '../../common';\nimport {computeResource, getRequestBaseUrl, makeWellKnownPaths} from '../path.utils';\n\nconst inputSchema = httpInputSchema;\n\nconst stateSchema = z.object({\n resource: z.string().min(1),\n baseUrl: z.string().min(1),\n scopesSupported: z.array(z.string()).default(['openid', 'profile', 'email']),\n isOrchestrated: z.boolean(),\n});\n\nconst outputSchema = HttpJsonSchema.extend({\n body: z\n .object({\n resource: z.string().min(1),\n authorization_servers: z.array(z.string().min(1)).min(1),\n scopes_supported: z.array(z.string()).default(['openid', 'profile', 'email']),\n bearer_methods_supported: z.array(z.string()).default(['header']),\n })\n .passthrough(),\n});\n\nconst plan = {\n pre: ['parseInput'],\n execute: ['collectData'],\n post: ['validateOutput'],\n} as const satisfies FlowPlan<string>;\n\ndeclare global {\n interface ExtendFlows {\n 'well-known.oauth-protected-resource': FlowRunOptions<\n WellKnownPrmFlow,\n typeof plan,\n typeof inputSchema,\n typeof outputSchema,\n typeof stateSchema\n >;\n }\n}\n\nconst name = 'well-known.oauth-protected-resource' as const;\nconst Stage = StageHookOf(name);\n\n@Flow({\n name,\n plan,\n inputSchema,\n outputSchema,\n access: 'public',\n middleware: {\n method: 'GET',\n },\n})\nexport default class WellKnownPrmFlow extends FlowBase<typeof name> {\n static canActivate(request: ServerRequest, scope: ScopeEntry) {\n return makeWellKnownPaths('oauth-protected-resource', scope.entryPath, scope.routeBase).has(request.path);\n }\n\n @Stage('parseInput')\n async parseInput() {\n const {request} = this.rawInput;\n const scope = this.scope;\n if (!request) throw new Error('Request is undefined');\n\n const resource = computeResource(request, scope.entryPath, scope.routeBase);\n const baseUrl = getRequestBaseUrl(request, scope.entryPath);\n this.state.set(stateSchema.parse({\n resource,\n baseUrl,\n scopesSupported: ['openid', 'profile', 'email'],\n isOrchestrated: false,//scope.orchestrated,// TODO: fix\n }));\n }\n\n @Stage('collectData') async collectData() {\n const {resource, baseUrl, scopesSupported, isOrchestrated} = this.state.required;\n\n if (isOrchestrated) {\n this.respond({\n kind: 'json',\n contentType: 'application/json; charset=utf-8',\n status: 200,\n body: {\n resource,\n authorization_servers: [baseUrl],\n scopes_supported: scopesSupported,\n bearer_methods_supported: ['header'],\n },\n });\n return;\n }\n const issuer = this.scope.auth.issuer;\n // Transparent scope\n this.respond({\n kind: 'json',\n status: 200,\n contentType: 'application/json; charset=utf-8',\n body: {\n resource,\n authorization_servers: [issuer],\n scopes_supported: scopesSupported,\n bearer_methods_supported: ['header'],\n },\n });\n }\n}\n"]}
@@ -0,0 +1,20 @@
1
+ import { URL } from 'url';
2
+ import { FrontMcpAuth, FrontMcpLogger, LocalAuthOptions, ScopeEntry, ServerRequest } from '../../common';
3
+ import ProviderRegistry from '../../provider/provider.registry';
4
+ export declare class LocalPrimaryAuth extends FrontMcpAuth {
5
+ private scope;
6
+ private providers;
7
+ readonly host: string;
8
+ readonly port: number;
9
+ readonly issuer: string;
10
+ readonly keys: any[];
11
+ readonly secret: Uint8Array;
12
+ readonly logger: FrontMcpLogger;
13
+ private jwks;
14
+ constructor(scope: ScopeEntry, providers: ProviderRegistry, metadata: LocalAuthOptions);
15
+ signAnonymousJwt(): Promise<string>;
16
+ protected initialize(): Promise<void>;
17
+ fetch(input: RequestInfo | URL, init?: RequestInit): Promise<Response>;
18
+ validate(request: ServerRequest): Promise<void>;
19
+ private registerAuthFlows;
20
+ }
@@ -0,0 +1,78 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.LocalPrimaryAuth = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const jose_1 = require("jose");
6
+ const crypto_1 = require("crypto");
7
+ const common_1 = require("../../common");
8
+ const well_known_prm_flow_1 = tslib_1.__importDefault(require("../flows/well-known.prm.flow"));
9
+ const well_known_oauth_authorization_server_flow_1 = tslib_1.__importDefault(require("../flows/well-known.oauth-authorization-server.flow"));
10
+ const well_known_jwks_flow_1 = tslib_1.__importDefault(require("../flows/well-known.jwks.flow"));
11
+ const session_verify_flow_1 = tslib_1.__importDefault(require("../flows/session.verify.flow"));
12
+ const oauth_authorize_flow_1 = tslib_1.__importDefault(require("../flows/oauth.authorize.flow"));
13
+ const oauth_register_flow_1 = tslib_1.__importDefault(require("../flows/oauth.register.flow"));
14
+ const oauth_token_flow_1 = tslib_1.__importDefault(require("../flows/oauth.token.flow"));
15
+ const jwks_1 = require("../jwks");
16
+ const DEFAULT_NO_AUTH_SECRET = (0, crypto_1.randomBytes)(32);
17
+ class LocalPrimaryAuth extends common_1.FrontMcpAuth {
18
+ scope;
19
+ providers;
20
+ host;
21
+ port;
22
+ issuer;
23
+ keys = [];
24
+ secret;
25
+ logger;
26
+ jwks = new jwks_1.JwksService();
27
+ constructor(scope, providers, metadata) {
28
+ super(metadata);
29
+ this.scope = scope;
30
+ this.providers = providers;
31
+ this.logger = this.providers.getActiveScope().logger.child('LocalPrimaryAuth');
32
+ this.port = this.providers.getActiveScope().metadata.http?.port ?? 3001;
33
+ this.host = 'localhost';
34
+ this.issuer = `http://${this.host}:${this.port}${scope.fullPath}`;
35
+ if (process.env["JWT_SECRET"]) {
36
+ this.secret = new TextEncoder().encode(process.env["JWT_SECRET"]);
37
+ }
38
+ else {
39
+ this.logger.warn('JWT_SECRET is not set, using default secret');
40
+ this.secret = DEFAULT_NO_AUTH_SECRET;
41
+ }
42
+ this.ready = this.initialize();
43
+ }
44
+ async signAnonymousJwt() {
45
+ const sub = (0, crypto_1.randomUUID)();
46
+ return new jose_1.SignJWT({ sub, role: 'user', anonymous: true })
47
+ .setProtectedHeader({ alg: 'HS256', typ: 'JWT' })
48
+ .setIssuedAt()
49
+ .setIssuer(this.issuer)
50
+ .setExpirationTime('1d')
51
+ .sign(this.secret);
52
+ }
53
+ async initialize() {
54
+ // TODO: create separated jwk service for local/remote auth options
55
+ this.providers.injectProvider({
56
+ value: this.jwks,
57
+ metadata: {
58
+ scope: common_1.ProviderScope.GLOBAL,
59
+ name: 'auth:jwk-service',
60
+ },
61
+ provide: jwks_1.JwksService,
62
+ });
63
+ await this.registerAuthFlows();
64
+ return Promise.resolve();
65
+ }
66
+ fetch(input, init) {
67
+ return fetch(input, init);
68
+ }
69
+ validate(request) {
70
+ return Promise.resolve();
71
+ }
72
+ async registerAuthFlows() {
73
+ const scope = this.providers.getActiveScope();
74
+ await scope.registryFlows(well_known_prm_flow_1.default, /** /.well-known/oauth-protected-resource */ well_known_oauth_authorization_server_flow_1.default, /** /.well-known/oauth-authorization-server */ well_known_jwks_flow_1.default, /** /.well-known/jwks.json */ session_verify_flow_1.default, /** Session verification flow */ oauth_authorize_flow_1.default, oauth_token_flow_1.default, oauth_register_flow_1.default);
75
+ }
76
+ }
77
+ exports.LocalPrimaryAuth = LocalPrimaryAuth;
78
+ //# sourceMappingURL=instance.local-primary-auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance.local-primary-auth.js","sourceRoot":"","sources":["../../../../src/auth/instances/instance.local-primary-auth.ts"],"names":[],"mappings":"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","sourcesContent":["import {SignJWT} from \"jose\";\nimport {URL} from 'url';\nimport {randomBytes, randomUUID} from \"crypto\";\nimport {FrontMcpAuth, FrontMcpLogger, LocalAuthOptions, ProviderScope, ScopeEntry, ServerRequest} from '../../common';\nimport ProviderRegistry from '../../provider/provider.registry';\nimport WellKnownPrmFlow from '../flows/well-known.prm.flow';\nimport WellKnownAsFlow from '../flows/well-known.oauth-authorization-server.flow';\nimport WellKnownJwksFlow from '../flows/well-known.jwks.flow';\nimport SessionVerifyFlow from '../flows/session.verify.flow';\nimport OauthAuthorizeFlow from \"../flows/oauth.authorize.flow\";\nimport OauthRegisterFlow from \"../flows/oauth.register.flow\";\nimport OauthTokenFlow from \"../flows/oauth.token.flow\";\nimport {JwksService} from \"../jwks\";\n\n\nconst DEFAULT_NO_AUTH_SECRET = randomBytes(32)\n\nexport class LocalPrimaryAuth extends FrontMcpAuth {\n readonly host: string;\n readonly port: number;\n readonly issuer: string;\n readonly keys: any[] = [];\n readonly secret: Uint8Array;\n readonly logger: FrontMcpLogger;\n private jwks = new JwksService();\n\n constructor(private scope:ScopeEntry,private providers: ProviderRegistry, metadata: LocalAuthOptions) {\n super(metadata);\n this.logger = this.providers.getActiveScope().logger.child('LocalPrimaryAuth');\n this.port = this.providers.getActiveScope().metadata.http?.port ?? 3001;\n this.host = 'localhost';\n this.issuer = `http://${this.host}:${this.port}${scope.fullPath}`\n\n if (process.env[\"JWT_SECRET\"]) {\n this.secret = new TextEncoder().encode(process.env[\"JWT_SECRET\"])\n } else {\n this.logger.warn('JWT_SECRET is not set, using default secret')\n this.secret = DEFAULT_NO_AUTH_SECRET;\n }\n this.ready = this.initialize();\n }\n\n\n async signAnonymousJwt() {\n const sub = randomUUID()\n return new SignJWT({sub, role: 'user', anonymous: true})\n .setProtectedHeader({alg: 'HS256', typ: 'JWT'})\n .setIssuedAt()\n .setIssuer(this.issuer)\n .setExpirationTime('1d')\n .sign(this.secret)\n }\n\n protected async initialize(): Promise<void> {\n // TODO: create separated jwk service for local/remote auth options\n this.providers.injectProvider({\n value: this.jwks,\n metadata: {\n scope: ProviderScope.GLOBAL,\n name: 'auth:jwk-service',\n },\n provide: JwksService,\n });\n\n await this.registerAuthFlows();\n\n\n return Promise.resolve();\n }\n\n override fetch(input: RequestInfo | URL, init?: RequestInit): Promise<Response> {\n return fetch(input, init);\n }\n\n override validate(request: ServerRequest): Promise<void> {\n return Promise.resolve();\n }\n\n\n private async registerAuthFlows() {\n const scope = this.providers.getActiveScope();\n await scope.registryFlows(\n WellKnownPrmFlow, /** /.well-known/oauth-protected-resource */\n WellKnownAsFlow, /** /.well-known/oauth-authorization-server */\n WellKnownJwksFlow, /** /.well-known/jwks.json */\n SessionVerifyFlow, /** Session verification flow */\n\n OauthAuthorizeFlow,\n OauthTokenFlow,\n OauthRegisterFlow\n );\n }\n}"]}
@@ -0,0 +1,15 @@
1
+ import { FrontMcpAuth, RemoteAuthOptions, ScopeEntry, ServerRequest } from '../../common';
2
+ import { URL } from 'url';
3
+ import ProviderRegistry from '../../provider/provider.registry';
4
+ export declare class RemotePrimaryAuth extends FrontMcpAuth<RemoteAuthOptions> {
5
+ private readonly scope;
6
+ private readonly providers;
7
+ ready: Promise<void>;
8
+ private jwks;
9
+ constructor(scope: ScopeEntry, providers: ProviderRegistry, options: RemoteAuthOptions);
10
+ fetch(input: RequestInfo | URL, init?: RequestInit): Promise<Response>;
11
+ validate(request: ServerRequest): Promise<void>;
12
+ get issuer(): string;
13
+ protected initialize(): Promise<void>;
14
+ private registerAuthFlows;
15
+ }
@@ -0,0 +1,49 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.RemotePrimaryAuth = void 0;
4
+ const tslib_1 = require("tslib");
5
+ const common_1 = require("../../common");
6
+ const jwks_1 = require("../jwks");
7
+ const well_known_prm_flow_1 = tslib_1.__importDefault(require("../flows/well-known.prm.flow"));
8
+ const well_known_oauth_authorization_server_flow_1 = tslib_1.__importDefault(require("../flows/well-known.oauth-authorization-server.flow"));
9
+ const well_known_jwks_flow_1 = tslib_1.__importDefault(require("../flows/well-known.jwks.flow"));
10
+ const session_verify_flow_1 = tslib_1.__importDefault(require("../flows/session.verify.flow"));
11
+ class RemotePrimaryAuth extends common_1.FrontMcpAuth {
12
+ scope;
13
+ providers;
14
+ ready;
15
+ jwks = new jwks_1.JwksService();
16
+ constructor(scope, providers, options) {
17
+ super(options);
18
+ this.scope = scope;
19
+ this.providers = providers;
20
+ this.ready = this.initialize();
21
+ }
22
+ fetch(input, init) {
23
+ return fetch(input, init);
24
+ }
25
+ validate(request) {
26
+ return Promise.resolve();
27
+ }
28
+ get issuer() {
29
+ return this.options.baseUrl;
30
+ }
31
+ async initialize() {
32
+ const scope = this.providers.getActiveScope();
33
+ this.providers.injectProvider({
34
+ value: this.jwks,
35
+ metadata: {
36
+ scope: common_1.ProviderScope.GLOBAL,
37
+ name: 'auth:jwk-service',
38
+ },
39
+ provide: jwks_1.JwksService,
40
+ });
41
+ await this.registerAuthFlows(scope);
42
+ return Promise.resolve();
43
+ }
44
+ async registerAuthFlows(scope) {
45
+ await scope.registryFlows(well_known_prm_flow_1.default, /** /.well-known/oauth-protected-resource */ well_known_oauth_authorization_server_flow_1.default, /** /.well-known/oauth-authorization-server */ well_known_jwks_flow_1.default, /** /.well-known/jwks.json */ session_verify_flow_1.default);
46
+ }
47
+ }
48
+ exports.RemotePrimaryAuth = RemotePrimaryAuth;
49
+ //# sourceMappingURL=instance.remote-primary-auth.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instance.remote-primary-auth.js","sourceRoot":"","sources":["../../../../src/auth/instances/instance.remote-primary-auth.ts"],"names":[],"mappings":";;;;AAAA,yCAAuG;AAGvG,kCAAoC;AACpC,+FAA4D;AAC5D,6IAAkF;AAClF,iGAA8D;AAC9D,+FAA6D;AAI7D,MAAa,iBAAkB,SAAQ,qBAA+B;IAIvC;IAAoC;IAHxD,KAAK,CAAgB;IACtB,IAAI,GAAG,IAAI,kBAAW,EAAE,CAAC;IAEjC,YAA6B,KAAiB,EAAmB,SAA2B,EAAE,OAA0B;QACtH,KAAK,CAAC,OAAO,CAAC,CAAC;QADY,UAAK,GAAL,KAAK,CAAY;QAAmB,cAAS,GAAT,SAAS,CAAkB;QAE1F,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAEQ,KAAK,CAAC,KAAwB,EAAE,IAAkB;QACzD,OAAO,KAAK,CAAC,KAAK,EAAE,IAAI,CAAC,CAAC;IAC5B,CAAC;IAEQ,QAAQ,CAAC,OAAsB;QACtC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAGD,IAAI,MAAM;QACR,OAAO,IAAI,CAAC,OAAO,CAAC,OAAO,CAAC;IAC9B,CAAC;IAES,KAAK,CAAC,UAAU;QACxB,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,cAAc,EAAE,CAAC;QAE9C,IAAI,CAAC,SAAS,CAAC,cAAc,CAAC;YAC5B,KAAK,EAAE,IAAI,CAAC,IAAI;YAChB,QAAQ,EAAE;gBACR,KAAK,EAAE,sBAAa,CAAC,MAAM;gBAC3B,IAAI,EAAE,kBAAkB;aACzB;YACD,OAAO,EAAE,kBAAW;SACrB,CAAC,CAAC;QAEH,MAAM,IAAI,CAAC,iBAAiB,CAAC,KAAK,CAAC,CAAC;QACpC,OAAO,OAAO,CAAC,OAAO,EAAE,CAAC;IAC3B,CAAC;IAGO,KAAK,CAAC,iBAAiB,CAAC,KAAY;QAC1C,MAAM,KAAK,CAAC,aAAa,CACvB,6BAAgB,EAAE,4CAA4C,CAC9D,oDAAe,EAAE,8CAA8C,CAC/D,8BAAiB,EAAE,6BAA6B,CAChD,6BAAiB,CAClB,CAAC;IACJ,CAAC;CACF;AA/CD,8CA+CC","sourcesContent":["import {FrontMcpAuth, ProviderScope, RemoteAuthOptions, ScopeEntry, ServerRequest} from '../../common';\nimport {URL} from 'url';\nimport ProviderRegistry from '../../provider/provider.registry';\nimport {JwksService} from '../jwks';\nimport WellKnownPrmFlow from '../flows/well-known.prm.flow';\nimport WellKnownAsFlow from '../flows/well-known.oauth-authorization-server.flow';\nimport WellKnownJwksFlow from '../flows/well-known.jwks.flow';\nimport SessionVerifyFlow from '../flows/session.verify.flow';\nimport {Scope} from '../../scope';\n\n\nexport class RemotePrimaryAuth extends FrontMcpAuth<RemoteAuthOptions> {\n override ready: Promise<void>;\n private jwks = new JwksService();\n\n constructor(private readonly scope: ScopeEntry, private readonly providers: ProviderRegistry, options: RemoteAuthOptions) {\n super(options);\n this.ready = this.initialize();\n }\n\n override fetch(input: RequestInfo | URL, init?: RequestInit): Promise<Response> {\n return fetch(input, init);\n }\n\n override validate(request: ServerRequest): Promise<void> {\n return Promise.resolve();\n }\n\n\n get issuer(): string {\n return this.options.baseUrl;\n }\n\n protected async initialize() {\n const scope = this.providers.getActiveScope();\n\n this.providers.injectProvider({\n value: this.jwks,\n metadata: {\n scope: ProviderScope.GLOBAL,\n name: 'auth:jwk-service',\n },\n provide: JwksService,\n });\n\n await this.registerAuthFlows(scope);\n return Promise.resolve();\n }\n\n\n private async registerAuthFlows(scope: Scope) {\n await scope.registryFlows(\n WellKnownPrmFlow, /** /.well-known/oauth-protected-resource */\n WellKnownAsFlow, /** /.well-known/oauth-authorization-server */\n WellKnownJwksFlow, /** /.well-known/jwks.json */\n SessionVerifyFlow, /** Session verification flow */\n );\n }\n}"]}
@@ -0,0 +1,2 @@
1
+ export * from './jwks.service';
2
+ export * from './jwks.types';
@@ -0,0 +1,6 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ const tslib_1 = require("tslib");
4
+ tslib_1.__exportStar(require("./jwks.service"), exports);
5
+ tslib_1.__exportStar(require("./jwks.types"), exports);
6
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/auth/jwks/index.ts"],"names":[],"mappings":";;;AAAA,yDAA+B;AAC/B,uDAA6B","sourcesContent":["export * from './jwks.service';\nexport * from './jwks.types';\n"]}