@mcp-z/client 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (211) hide show
  1. package/AGENTS.md +159 -0
  2. package/LICENSE +21 -0
  3. package/README.md +90 -0
  4. package/dist/cjs/auth/capability-discovery.d.cts +25 -0
  5. package/dist/cjs/auth/capability-discovery.d.ts +25 -0
  6. package/dist/cjs/auth/capability-discovery.js +280 -0
  7. package/dist/cjs/auth/capability-discovery.js.map +1 -0
  8. package/dist/cjs/auth/index.d.cts +9 -0
  9. package/dist/cjs/auth/index.d.ts +9 -0
  10. package/dist/cjs/auth/index.js +28 -0
  11. package/dist/cjs/auth/index.js.map +1 -0
  12. package/dist/cjs/auth/interactive-oauth-flow.d.cts +58 -0
  13. package/dist/cjs/auth/interactive-oauth-flow.d.ts +58 -0
  14. package/dist/cjs/auth/interactive-oauth-flow.js +537 -0
  15. package/dist/cjs/auth/interactive-oauth-flow.js.map +1 -0
  16. package/dist/cjs/auth/oauth-callback-listener.d.cts +56 -0
  17. package/dist/cjs/auth/oauth-callback-listener.d.ts +56 -0
  18. package/dist/cjs/auth/oauth-callback-listener.js +333 -0
  19. package/dist/cjs/auth/oauth-callback-listener.js.map +1 -0
  20. package/dist/cjs/auth/pkce.d.cts +17 -0
  21. package/dist/cjs/auth/pkce.d.ts +17 -0
  22. package/dist/cjs/auth/pkce.js +192 -0
  23. package/dist/cjs/auth/pkce.js.map +1 -0
  24. package/dist/cjs/auth/rfc9728-discovery.d.cts +34 -0
  25. package/dist/cjs/auth/rfc9728-discovery.d.ts +34 -0
  26. package/dist/cjs/auth/rfc9728-discovery.js +436 -0
  27. package/dist/cjs/auth/rfc9728-discovery.js.map +1 -0
  28. package/dist/cjs/auth/types.d.cts +137 -0
  29. package/dist/cjs/auth/types.d.ts +137 -0
  30. package/dist/cjs/auth/types.js +9 -0
  31. package/dist/cjs/auth/types.js.map +1 -0
  32. package/dist/cjs/client-helpers.d.cts +55 -0
  33. package/dist/cjs/client-helpers.d.ts +55 -0
  34. package/dist/cjs/client-helpers.js +128 -0
  35. package/dist/cjs/client-helpers.js.map +1 -0
  36. package/dist/cjs/config/server-loader.d.cts +27 -0
  37. package/dist/cjs/config/server-loader.d.ts +27 -0
  38. package/dist/cjs/config/server-loader.js +111 -0
  39. package/dist/cjs/config/server-loader.js.map +1 -0
  40. package/dist/cjs/config/validate-config.d.cts +15 -0
  41. package/dist/cjs/config/validate-config.d.ts +15 -0
  42. package/dist/cjs/config/validate-config.js +128 -0
  43. package/dist/cjs/config/validate-config.js.map +1 -0
  44. package/dist/cjs/connection/connect-client.d.cts +59 -0
  45. package/dist/cjs/connection/connect-client.d.ts +59 -0
  46. package/dist/cjs/connection/connect-client.js +536 -0
  47. package/dist/cjs/connection/connect-client.js.map +1 -0
  48. package/dist/cjs/connection/existing-process-transport.d.cts +40 -0
  49. package/dist/cjs/connection/existing-process-transport.d.ts +40 -0
  50. package/dist/cjs/connection/existing-process-transport.js +274 -0
  51. package/dist/cjs/connection/existing-process-transport.js.map +1 -0
  52. package/dist/cjs/connection/types.d.cts +61 -0
  53. package/dist/cjs/connection/types.d.ts +61 -0
  54. package/dist/cjs/connection/types.js +53 -0
  55. package/dist/cjs/connection/types.js.map +1 -0
  56. package/dist/cjs/connection/wait-for-http-ready.d.cts +15 -0
  57. package/dist/cjs/connection/wait-for-http-ready.d.ts +15 -0
  58. package/dist/cjs/connection/wait-for-http-ready.js +232 -0
  59. package/dist/cjs/connection/wait-for-http-ready.js.map +1 -0
  60. package/dist/cjs/dcr/dcr-authenticator.d.cts +73 -0
  61. package/dist/cjs/dcr/dcr-authenticator.d.ts +73 -0
  62. package/dist/cjs/dcr/dcr-authenticator.js +655 -0
  63. package/dist/cjs/dcr/dcr-authenticator.js.map +1 -0
  64. package/dist/cjs/dcr/dynamic-client-registrar.d.cts +28 -0
  65. package/dist/cjs/dcr/dynamic-client-registrar.d.ts +28 -0
  66. package/dist/cjs/dcr/dynamic-client-registrar.js +245 -0
  67. package/dist/cjs/dcr/dynamic-client-registrar.js.map +1 -0
  68. package/dist/cjs/dcr/index.d.cts +8 -0
  69. package/dist/cjs/dcr/index.d.ts +8 -0
  70. package/dist/cjs/dcr/index.js +24 -0
  71. package/dist/cjs/dcr/index.js.map +1 -0
  72. package/dist/cjs/index.d.cts +21 -0
  73. package/dist/cjs/index.d.ts +21 -0
  74. package/dist/cjs/index.js +94 -0
  75. package/dist/cjs/index.js.map +1 -0
  76. package/dist/cjs/monkey-patches.d.cts +6 -0
  77. package/dist/cjs/monkey-patches.d.ts +6 -0
  78. package/dist/cjs/monkey-patches.js +236 -0
  79. package/dist/cjs/monkey-patches.js.map +1 -0
  80. package/dist/cjs/package.json +1 -0
  81. package/dist/cjs/response-wrappers.d.cts +41 -0
  82. package/dist/cjs/response-wrappers.d.ts +41 -0
  83. package/dist/cjs/response-wrappers.js +443 -0
  84. package/dist/cjs/response-wrappers.js.map +1 -0
  85. package/dist/cjs/search/index.d.cts +6 -0
  86. package/dist/cjs/search/index.d.ts +6 -0
  87. package/dist/cjs/search/index.js +25 -0
  88. package/dist/cjs/search/index.js.map +1 -0
  89. package/dist/cjs/search/search.d.cts +22 -0
  90. package/dist/cjs/search/search.d.ts +22 -0
  91. package/dist/cjs/search/search.js +630 -0
  92. package/dist/cjs/search/search.js.map +1 -0
  93. package/dist/cjs/search/types.d.cts +122 -0
  94. package/dist/cjs/search/types.d.ts +122 -0
  95. package/dist/cjs/search/types.js +10 -0
  96. package/dist/cjs/search/types.js.map +1 -0
  97. package/dist/cjs/spawn/spawn-server.d.cts +83 -0
  98. package/dist/cjs/spawn/spawn-server.d.ts +83 -0
  99. package/dist/cjs/spawn/spawn-server.js +410 -0
  100. package/dist/cjs/spawn/spawn-server.js.map +1 -0
  101. package/dist/cjs/spawn/spawn-servers.d.cts +151 -0
  102. package/dist/cjs/spawn/spawn-servers.d.ts +151 -0
  103. package/dist/cjs/spawn/spawn-servers.js +911 -0
  104. package/dist/cjs/spawn/spawn-servers.js.map +1 -0
  105. package/dist/cjs/types.d.cts +11 -0
  106. package/dist/cjs/types.d.ts +11 -0
  107. package/dist/cjs/types.js +10 -0
  108. package/dist/cjs/types.js.map +1 -0
  109. package/dist/cjs/utils/logger.d.cts +24 -0
  110. package/dist/cjs/utils/logger.d.ts +24 -0
  111. package/dist/cjs/utils/logger.js +80 -0
  112. package/dist/cjs/utils/logger.js.map +1 -0
  113. package/dist/cjs/utils/path-utils.d.cts +45 -0
  114. package/dist/cjs/utils/path-utils.d.ts +45 -0
  115. package/dist/cjs/utils/path-utils.js +158 -0
  116. package/dist/cjs/utils/path-utils.js.map +1 -0
  117. package/dist/cjs/utils/sanitizer.d.cts +30 -0
  118. package/dist/cjs/utils/sanitizer.d.ts +30 -0
  119. package/dist/cjs/utils/sanitizer.js +124 -0
  120. package/dist/cjs/utils/sanitizer.js.map +1 -0
  121. package/dist/esm/auth/capability-discovery.d.ts +25 -0
  122. package/dist/esm/auth/capability-discovery.js +110 -0
  123. package/dist/esm/auth/capability-discovery.js.map +1 -0
  124. package/dist/esm/auth/index.d.ts +9 -0
  125. package/dist/esm/auth/index.js +6 -0
  126. package/dist/esm/auth/index.js.map +1 -0
  127. package/dist/esm/auth/interactive-oauth-flow.d.ts +58 -0
  128. package/dist/esm/auth/interactive-oauth-flow.js +217 -0
  129. package/dist/esm/auth/interactive-oauth-flow.js.map +1 -0
  130. package/dist/esm/auth/oauth-callback-listener.d.ts +56 -0
  131. package/dist/esm/auth/oauth-callback-listener.js +166 -0
  132. package/dist/esm/auth/oauth-callback-listener.js.map +1 -0
  133. package/dist/esm/auth/pkce.d.ts +17 -0
  134. package/dist/esm/auth/pkce.js +41 -0
  135. package/dist/esm/auth/pkce.js.map +1 -0
  136. package/dist/esm/auth/rfc9728-discovery.d.ts +34 -0
  137. package/dist/esm/auth/rfc9728-discovery.js +157 -0
  138. package/dist/esm/auth/rfc9728-discovery.js.map +1 -0
  139. package/dist/esm/auth/types.d.ts +137 -0
  140. package/dist/esm/auth/types.js +7 -0
  141. package/dist/esm/auth/types.js.map +1 -0
  142. package/dist/esm/client-helpers.d.ts +55 -0
  143. package/dist/esm/client-helpers.js +81 -0
  144. package/dist/esm/client-helpers.js.map +1 -0
  145. package/dist/esm/config/server-loader.d.ts +27 -0
  146. package/dist/esm/config/server-loader.js +49 -0
  147. package/dist/esm/config/server-loader.js.map +1 -0
  148. package/dist/esm/config/validate-config.d.ts +15 -0
  149. package/dist/esm/config/validate-config.js +76 -0
  150. package/dist/esm/config/validate-config.js.map +1 -0
  151. package/dist/esm/connection/connect-client.d.ts +59 -0
  152. package/dist/esm/connection/connect-client.js +272 -0
  153. package/dist/esm/connection/connect-client.js.map +1 -0
  154. package/dist/esm/connection/existing-process-transport.d.ts +40 -0
  155. package/dist/esm/connection/existing-process-transport.js +103 -0
  156. package/dist/esm/connection/existing-process-transport.js.map +1 -0
  157. package/dist/esm/connection/types.d.ts +61 -0
  158. package/dist/esm/connection/types.js +34 -0
  159. package/dist/esm/connection/types.js.map +1 -0
  160. package/dist/esm/connection/wait-for-http-ready.d.ts +15 -0
  161. package/dist/esm/connection/wait-for-http-ready.js +43 -0
  162. package/dist/esm/connection/wait-for-http-ready.js.map +1 -0
  163. package/dist/esm/dcr/dcr-authenticator.d.ts +73 -0
  164. package/dist/esm/dcr/dcr-authenticator.js +235 -0
  165. package/dist/esm/dcr/dcr-authenticator.js.map +1 -0
  166. package/dist/esm/dcr/dynamic-client-registrar.d.ts +28 -0
  167. package/dist/esm/dcr/dynamic-client-registrar.js +66 -0
  168. package/dist/esm/dcr/dynamic-client-registrar.js.map +1 -0
  169. package/dist/esm/dcr/index.d.ts +8 -0
  170. package/dist/esm/dcr/index.js +5 -0
  171. package/dist/esm/dcr/index.js.map +1 -0
  172. package/dist/esm/index.d.ts +21 -0
  173. package/dist/esm/index.js +22 -0
  174. package/dist/esm/index.js.map +1 -0
  175. package/dist/esm/monkey-patches.d.ts +6 -0
  176. package/dist/esm/monkey-patches.js +32 -0
  177. package/dist/esm/monkey-patches.js.map +1 -0
  178. package/dist/esm/package.json +1 -0
  179. package/dist/esm/response-wrappers.d.ts +41 -0
  180. package/dist/esm/response-wrappers.js +201 -0
  181. package/dist/esm/response-wrappers.js.map +1 -0
  182. package/dist/esm/search/index.d.ts +6 -0
  183. package/dist/esm/search/index.js +3 -0
  184. package/dist/esm/search/index.js.map +1 -0
  185. package/dist/esm/search/search.d.ts +22 -0
  186. package/dist/esm/search/search.js +236 -0
  187. package/dist/esm/search/search.js.map +1 -0
  188. package/dist/esm/search/types.d.ts +122 -0
  189. package/dist/esm/search/types.js +8 -0
  190. package/dist/esm/search/types.js.map +1 -0
  191. package/dist/esm/spawn/spawn-server.d.ts +83 -0
  192. package/dist/esm/spawn/spawn-server.js +145 -0
  193. package/dist/esm/spawn/spawn-server.js.map +1 -0
  194. package/dist/esm/spawn/spawn-servers.d.ts +151 -0
  195. package/dist/esm/spawn/spawn-servers.js +406 -0
  196. package/dist/esm/spawn/spawn-servers.js.map +1 -0
  197. package/dist/esm/types.d.ts +11 -0
  198. package/dist/esm/types.js +9 -0
  199. package/dist/esm/types.js.map +1 -0
  200. package/dist/esm/utils/logger.d.ts +24 -0
  201. package/dist/esm/utils/logger.js +59 -0
  202. package/dist/esm/utils/logger.js.map +1 -0
  203. package/dist/esm/utils/path-utils.d.ts +45 -0
  204. package/dist/esm/utils/path-utils.js +89 -0
  205. package/dist/esm/utils/path-utils.js.map +1 -0
  206. package/dist/esm/utils/sanitizer.d.ts +30 -0
  207. package/dist/esm/utils/sanitizer.js +43 -0
  208. package/dist/esm/utils/sanitizer.js.map +1 -0
  209. package/package.json +92 -0
  210. package/schemas/servers.d.ts +90 -0
  211. package/schemas/servers.schema.json +104 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/libs/client/src/dcr/dcr-authenticator.ts"],"sourcesContent":["/**\n * DCR Authenticator\n * Consolidates DCR and OAuth flow logic for MCP HTTP servers\n */\n\nimport path from 'node:path';\nimport * as fs from 'fs';\nimport Keyv from 'keyv';\nimport { KeyvFile } from 'keyv-file';\nimport { InteractiveOAuthFlow } from '../auth/interactive-oauth-flow.ts';\nimport type { AuthCapabilities, TokenSet } from '../auth/types.ts';\nimport { logger as defaultLogger, type Logger } from '../utils/logger.ts';\nimport { DynamicClientRegistrar } from './dynamic-client-registrar.ts';\n\n/**\n * DcrAuthenticator configuration options\n */\nexport interface DcrAuthenticatorOptions {\n /** Custom Keyv store (for testing) - if not provided, uses default ~/.mcpeasy/tokens.json */\n tokenStore?: Keyv;\n /** Headless mode (don't open browser) */\n headless?: boolean;\n /** Required redirect URI for OAuth callback */\n redirectUri: string;\n /** Optional logger for debug output (defaults to singleton logger) */\n logger?: Logger;\n}\n\n/**\n * Buffer time before token expiry to trigger proactive refresh (5 minutes)\n */\nconst REFRESH_BUFFER_MS = 5 * 60 * 1000;\n\n/**\n * DcrAuthenticator manages authentication for MCP HTTP servers\n * Handles DCR registration, OAuth flows, and token management\n */\nexport class DcrAuthenticator {\n private tokenStore: Keyv;\n private dcrClient: DynamicClientRegistrar;\n private oauthFlow: InteractiveOAuthFlow;\n private headless: boolean;\n private redirectUri: string;\n private logger: Logger;\n\n constructor(options: DcrAuthenticatorOptions) {\n if (options.tokenStore) {\n this.tokenStore = options.tokenStore;\n } else {\n // Default CLI store in .mcp-z directory (per-project)\n const storePath = path.join(process.cwd(), '.mcp-z', 'tokens.json');\n\n // Ensure directory exists before creating store\n fs.mkdirSync(path.dirname(storePath), { recursive: true });\n\n this.tokenStore = new Keyv({\n store: new KeyvFile({ filename: storePath }),\n });\n }\n this.dcrClient = new DynamicClientRegistrar();\n this.oauthFlow = new InteractiveOAuthFlow();\n this.headless = options.headless || false;\n this.redirectUri = options.redirectUri;\n this.logger = options.logger ?? defaultLogger;\n }\n\n /**\n * Detect if server is self-hosted DCR (vs external OAuth provider)\n * Self-hosted servers have their own OAuth endpoints and manage token storage\n */\n private async detectSelfHostedMode(baseUrl: string): Promise<boolean> {\n try {\n // Self-hosted DCR servers typically run their own OAuth server\n // Check if this is a self-hosted instance by testing OAuth metadata\n // For now, assume self-hosted if baseUrl matches common localhost patterns\n // TODO: Implement proper self-hosted detection logic\n return baseUrl.includes('localhost') || baseUrl.includes('127.0.0.1');\n } catch (_error) {\n return false; // Assume external mode if detection fails\n }\n }\n\n /**\n * Ensure server is authenticated, performing DCR and OAuth if needed\n * Proactively refreshes tokens if they're within 5 minutes of expiry\n *\n * @param baseUrl - Base URL of the server (e.g., https://example.com)\n * @param capabilities - Auth capabilities from .well-known endpoint\n * @returns Valid token set ready to use\n *\n * @throws Error if authentication fails\n *\n * @example\n * const authenticator = new DcrAuthenticator({ redirectUri: 'http://localhost:3000/callback' });\n * const tokens = await authenticator.ensureAuthenticated(\n * 'https://example.com',\n * capabilities\n * );\n */\n async ensureAuthenticated(baseUrl: string, capabilities: AuthCapabilities): Promise<TokenSet> {\n // Auto-detect server mode\n const isSelfHosted = await this.detectSelfHostedMode(baseUrl);\n\n if (isSelfHosted) {\n return this.ensureAuthenticatedSelfHosted(baseUrl, capabilities);\n }\n return this.ensureAuthenticatedExternal(baseUrl, capabilities);\n }\n\n /**\n * Handle authentication for self-hosted DCR servers\n * Self-hosted servers manage their own token storage via /oauth/verify\n */\n private async ensureAuthenticatedSelfHosted(baseUrl: string, capabilities: AuthCapabilities): Promise<TokenSet> {\n const dcrTokenKey = `dcr-tokens:${baseUrl}`;\n\n // 1. Check for existing DCR tokens (different from external tokens)\n let tokens = (await this.tokenStore.get(dcrTokenKey)) as TokenSet | undefined;\n\n if (tokens) {\n // 2. Verify token is still valid by calling /oauth/verify\n try {\n const verifyUrl = `${baseUrl}/oauth/verify`;\n const verifyResponse = await fetch(verifyUrl, {\n headers: { Authorization: `Bearer ${tokens.accessToken}`, Connection: 'close' },\n });\n\n if (verifyResponse.ok) {\n const verifyData = (await verifyResponse.json()) as { token?: string };\n if (verifyData.token === tokens.accessToken) {\n // Token is still valid with the self-hosted server\n return tokens;\n }\n }\n } catch (_error) {\n // Token verification failed - need to re-authenticate\n }\n\n // Token is expired or invalid\n await this.tokenStore.delete(dcrTokenKey);\n tokens = undefined;\n }\n\n // 3. No valid tokens - perform full DCR + OAuth flow\n if (!capabilities.registrationEndpoint || !capabilities.authorizationEndpoint || !capabilities.tokenEndpoint) {\n throw new Error('Server does not provide required OAuth endpoints');\n }\n\n this.logger.debug('🔐 No valid tokens found, starting self-hosted DCR authentication...');\n\n // Extract port from pre-resolved redirectUri\n const port = parseInt(new URL(this.redirectUri).port, 10) || (this.redirectUri.startsWith('https:') ? 443 : 80);\n\n // Register OAuth client via DCR\n this.logger.debug('📝 Registering OAuth client with self-hosted server...');\n const client = await this.dcrClient.registerClient(capabilities.registrationEndpoint, {\n redirectUri: this.redirectUri,\n });\n\n // Perform OAuth authorization flow with PKCE (RFC 7636)\n const flowOptions: { port: number; headless: boolean; scopes?: string[]; redirectUri: string; pkce: boolean; logger: Logger } = {\n port,\n headless: this.headless,\n redirectUri: this.redirectUri,\n pkce: true,\n logger: this.logger,\n };\n if (capabilities.scopes) {\n flowOptions.scopes = capabilities.scopes;\n }\n\n tokens = await this.oauthFlow.performAuthFlow(capabilities.authorizationEndpoint, capabilities.tokenEndpoint, client.clientId, client.clientSecret, flowOptions);\n\n // For self-hosted mode, verify the token works with /oauth/verify immediately\n try {\n const verifyUrl = `${baseUrl}/oauth/verify`;\n const verifyResponse = await fetch(verifyUrl, {\n headers: { Authorization: `Bearer ${tokens.accessToken}`, Connection: 'close' },\n });\n\n if (!verifyResponse.ok) {\n throw new Error(`DCR token verification failed after authentication: ${verifyResponse.status}`);\n }\n\n const verifyData = (await verifyResponse.json()) as { token?: string };\n if (verifyData.token !== tokens.accessToken) {\n throw new Error('DCR server returned different token in verification');\n }\n\n this.logger.debug('✅ DCR token verified with self-hosted server');\n } catch (error) {\n this.logger.error('❌ DCR token verification failed:', error instanceof Error ? error.message : String(error));\n throw new Error('Self-hosted DCR authentication completed but token verification failed');\n }\n\n // Save tokens for future use\n await this.tokenStore.set(dcrTokenKey, tokens);\n this.logger.debug('✅ Self-hosted DCR authentication successful, tokens saved');\n\n return tokens;\n }\n\n /**\n * Handle authentication for external OAuth providers (original implementation)\n */\n private async ensureAuthenticatedExternal(baseUrl: string, capabilities: AuthCapabilities): Promise<TokenSet> {\n const tokenKey = `tokens:${baseUrl}`;\n\n // 1. Check for existing tokens\n let tokens = (await this.tokenStore.get(tokenKey)) as TokenSet | undefined;\n\n if (tokens) {\n // 2. Proactive refresh if token expires within 5 minutes\n if (tokens.expiresAt < Date.now() + REFRESH_BUFFER_MS) {\n this.logger.debug('🔄 Refreshing access token...');\n\n try {\n tokens = await this.refreshTokens(tokens, capabilities.tokenEndpoint);\n await this.tokenStore.set(tokenKey, tokens);\n this.logger.debug('✅ Token refreshed successfully');\n } catch (_error) {\n // Refresh failed - clear tokens and re-authenticate\n this.logger.warn('⚠️ Token refresh failed, re-authenticating...');\n await this.tokenStore.delete(tokenKey);\n tokens = undefined;\n }\n }\n\n if (tokens) {\n return tokens;\n }\n }\n\n // 3. No valid tokens - perform DCR + OAuth flow\n if (!capabilities.registrationEndpoint || !capabilities.authorizationEndpoint || !capabilities.tokenEndpoint) {\n throw new Error('Server does not provide required OAuth endpoints');\n }\n\n this.logger.debug('🔐 No valid tokens found, starting external OAuth authentication...');\n\n // Extract port from pre-resolved redirectUri\n const port = parseInt(new URL(this.redirectUri).port, 10) || (this.redirectUri.startsWith('https:') ? 443 : 80);\n\n // Register OAuth client via DCR\n this.logger.debug('📝 Registering OAuth client...');\n const client = await this.dcrClient.registerClient(capabilities.registrationEndpoint, {\n redirectUri: this.redirectUri,\n });\n\n // Perform OAuth authorization flow with PKCE (RFC 7636)\n const flowOptions: { port: number; headless: boolean; scopes?: string[]; redirectUri: string; pkce: boolean; logger: Logger } = {\n port,\n headless: this.headless,\n redirectUri: this.redirectUri,\n pkce: true,\n logger: this.logger,\n };\n if (capabilities.scopes) {\n flowOptions.scopes = capabilities.scopes;\n }\n\n tokens = await this.oauthFlow.performAuthFlow(capabilities.authorizationEndpoint, capabilities.tokenEndpoint, client.clientId, client.clientSecret, flowOptions);\n\n // Save tokens for future use\n await this.tokenStore.set(tokenKey, tokens);\n this.logger.debug('✅ Authentication successful, tokens saved');\n\n return tokens;\n }\n\n /**\n * Refresh access token using refresh token\n */\n private async refreshTokens(tokens: TokenSet, tokenEndpoint?: string): Promise<TokenSet> {\n if (!tokenEndpoint) {\n throw new Error('Token endpoint not available for refresh');\n }\n\n if (!tokens.refreshToken) {\n throw new Error('No refresh token available');\n }\n\n if (!tokens.clientId || !tokens.clientSecret) {\n throw new Error('Client credentials not available for refresh');\n }\n\n return await this.oauthFlow.refreshTokens(tokenEndpoint, tokens.refreshToken, tokens.clientId, tokens.clientSecret);\n }\n\n /**\n * Delete stored tokens for a server\n */\n async deleteTokens(baseUrl: string): Promise<void> {\n const tokenKey = `tokens:${baseUrl}`;\n await this.tokenStore.delete(tokenKey);\n this.logger.debug(`🗑️ Deleted tokens for ${baseUrl}`);\n }\n}\n"],"names":["DcrAuthenticator","REFRESH_BUFFER_MS","options","tokenStore","storePath","path","join","process","cwd","fs","mkdirSync","dirname","recursive","Keyv","store","KeyvFile","filename","dcrClient","DynamicClientRegistrar","oauthFlow","InteractiveOAuthFlow","headless","redirectUri","logger","defaultLogger","detectSelfHostedMode","baseUrl","includes","_error","ensureAuthenticated","capabilities","isSelfHosted","ensureAuthenticatedSelfHosted","ensureAuthenticatedExternal","dcrTokenKey","tokens","verifyUrl","verifyResponse","verifyData","port","client","flowOptions","error","get","fetch","headers","Authorization","accessToken","Connection","ok","json","token","delete","undefined","registrationEndpoint","authorizationEndpoint","tokenEndpoint","Error","debug","parseInt","URL","startsWith","registerClient","pkce","scopes","performAuthFlow","clientId","clientSecret","status","message","String","set","tokenKey","expiresAt","Date","now","refreshTokens","warn","refreshToken","deleteTokens"],"mappings":"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"}
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Dynamic Client Registration (DCR) Client
3
+ * Implements RFC 7591 for OAuth client registration
4
+ */
5
+ import type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.js';
6
+ /**
7
+ * DynamicClientRegistrar handles Dynamic Client Registration with OAuth servers
8
+ */
9
+ export declare class DynamicClientRegistrar {
10
+ /**
11
+ * Register a new OAuth client with the authorization server
12
+ *
13
+ * @param registrationEndpoint - DCR registration endpoint URL
14
+ * @param options - Registration options (client name, redirect URI)
15
+ * @returns Client credentials (client ID and secret)
16
+ *
17
+ * @throws Error if registration fails or server returns error
18
+ *
19
+ * @example
20
+ * const registrar = new DynamicClientRegistrar();
21
+ * const creds = await registrar.registerClient(
22
+ * 'https://example.com/oauth/register',
23
+ * { clientName: '@mcp-z/client', redirectUri: 'http://localhost:3000/callback' }
24
+ * );
25
+ * console.log('Client ID:', creds.clientId);
26
+ */
27
+ registerClient(registrationEndpoint: string, options?: DcrRegistrationOptions): Promise<ClientCredentials>;
28
+ }
@@ -0,0 +1,28 @@
1
+ /**
2
+ * Dynamic Client Registration (DCR) Client
3
+ * Implements RFC 7591 for OAuth client registration
4
+ */
5
+ import type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.js';
6
+ /**
7
+ * DynamicClientRegistrar handles Dynamic Client Registration with OAuth servers
8
+ */
9
+ export declare class DynamicClientRegistrar {
10
+ /**
11
+ * Register a new OAuth client with the authorization server
12
+ *
13
+ * @param registrationEndpoint - DCR registration endpoint URL
14
+ * @param options - Registration options (client name, redirect URI)
15
+ * @returns Client credentials (client ID and secret)
16
+ *
17
+ * @throws Error if registration fails or server returns error
18
+ *
19
+ * @example
20
+ * const registrar = new DynamicClientRegistrar();
21
+ * const creds = await registrar.registerClient(
22
+ * 'https://example.com/oauth/register',
23
+ * { clientName: '@mcp-z/client', redirectUri: 'http://localhost:3000/callback' }
24
+ * );
25
+ * console.log('Client ID:', creds.clientId);
26
+ */
27
+ registerClient(registrationEndpoint: string, options?: DcrRegistrationOptions): Promise<ClientCredentials>;
28
+ }
@@ -0,0 +1,245 @@
1
+ /**
2
+ * Dynamic Client Registration (DCR) Client
3
+ * Implements RFC 7591 for OAuth client registration
4
+ */ "use strict";
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ Object.defineProperty(exports, "DynamicClientRegistrar", {
9
+ enumerable: true,
10
+ get: function() {
11
+ return DynamicClientRegistrar;
12
+ }
13
+ });
14
+ function asyncGeneratorStep(gen, resolve, reject, _next, _throw, key, arg) {
15
+ try {
16
+ var info = gen[key](arg);
17
+ var value = info.value;
18
+ } catch (error) {
19
+ reject(error);
20
+ return;
21
+ }
22
+ if (info.done) {
23
+ resolve(value);
24
+ } else {
25
+ Promise.resolve(value).then(_next, _throw);
26
+ }
27
+ }
28
+ function _async_to_generator(fn) {
29
+ return function() {
30
+ var self = this, args = arguments;
31
+ return new Promise(function(resolve, reject) {
32
+ var gen = fn.apply(self, args);
33
+ function _next(value) {
34
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "next", value);
35
+ }
36
+ function _throw(err) {
37
+ asyncGeneratorStep(gen, resolve, reject, _next, _throw, "throw", err);
38
+ }
39
+ _next(undefined);
40
+ });
41
+ };
42
+ }
43
+ function _class_call_check(instance, Constructor) {
44
+ if (!(instance instanceof Constructor)) {
45
+ throw new TypeError("Cannot call a class as a function");
46
+ }
47
+ }
48
+ function _ts_generator(thisArg, body) {
49
+ var f, y, t, _ = {
50
+ label: 0,
51
+ sent: function() {
52
+ if (t[0] & 1) throw t[1];
53
+ return t[1];
54
+ },
55
+ trys: [],
56
+ ops: []
57
+ }, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype), d = Object.defineProperty;
58
+ return d(g, "next", {
59
+ value: verb(0)
60
+ }), d(g, "throw", {
61
+ value: verb(1)
62
+ }), d(g, "return", {
63
+ value: verb(2)
64
+ }), typeof Symbol === "function" && d(g, Symbol.iterator, {
65
+ value: function() {
66
+ return this;
67
+ }
68
+ }), g;
69
+ function verb(n) {
70
+ return function(v) {
71
+ return step([
72
+ n,
73
+ v
74
+ ]);
75
+ };
76
+ }
77
+ function step(op) {
78
+ if (f) throw new TypeError("Generator is already executing.");
79
+ while(g && (g = 0, op[0] && (_ = 0)), _)try {
80
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
81
+ if (y = 0, t) op = [
82
+ op[0] & 2,
83
+ t.value
84
+ ];
85
+ switch(op[0]){
86
+ case 0:
87
+ case 1:
88
+ t = op;
89
+ break;
90
+ case 4:
91
+ _.label++;
92
+ return {
93
+ value: op[1],
94
+ done: false
95
+ };
96
+ case 5:
97
+ _.label++;
98
+ y = op[1];
99
+ op = [
100
+ 0
101
+ ];
102
+ continue;
103
+ case 7:
104
+ op = _.ops.pop();
105
+ _.trys.pop();
106
+ continue;
107
+ default:
108
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
109
+ _ = 0;
110
+ continue;
111
+ }
112
+ if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
113
+ _.label = op[1];
114
+ break;
115
+ }
116
+ if (op[0] === 6 && _.label < t[1]) {
117
+ _.label = t[1];
118
+ t = op;
119
+ break;
120
+ }
121
+ if (t && _.label < t[2]) {
122
+ _.label = t[2];
123
+ _.ops.push(op);
124
+ break;
125
+ }
126
+ if (t[2]) _.ops.pop();
127
+ _.trys.pop();
128
+ continue;
129
+ }
130
+ op = body.call(thisArg, _);
131
+ } catch (e) {
132
+ op = [
133
+ 6,
134
+ e
135
+ ];
136
+ y = 0;
137
+ } finally{
138
+ f = t = 0;
139
+ }
140
+ if (op[0] & 5) throw op[1];
141
+ return {
142
+ value: op[0] ? op[1] : void 0,
143
+ done: true
144
+ };
145
+ }
146
+ }
147
+ var DynamicClientRegistrar = /*#__PURE__*/ function() {
148
+ "use strict";
149
+ function DynamicClientRegistrar() {
150
+ _class_call_check(this, DynamicClientRegistrar);
151
+ }
152
+ var _proto = DynamicClientRegistrar.prototype;
153
+ /**
154
+ * Register a new OAuth client with the authorization server
155
+ *
156
+ * @param registrationEndpoint - DCR registration endpoint URL
157
+ * @param options - Registration options (client name, redirect URI)
158
+ * @returns Client credentials (client ID and secret)
159
+ *
160
+ * @throws Error if registration fails or server returns error
161
+ *
162
+ * @example
163
+ * const registrar = new DynamicClientRegistrar();
164
+ * const creds = await registrar.registerClient(
165
+ * 'https://example.com/oauth/register',
166
+ * { clientName: '@mcp-z/client', redirectUri: 'http://localhost:3000/callback' }
167
+ * );
168
+ * console.log('Client ID:', creds.clientId);
169
+ */ _proto.registerClient = function registerClient(_0) {
170
+ return _async_to_generator(function(registrationEndpoint) {
171
+ var options, requestBody, response, errorText, data, credentials;
172
+ var _arguments = arguments;
173
+ return _ts_generator(this, function(_state) {
174
+ switch(_state.label){
175
+ case 0:
176
+ options = _arguments.length > 1 && _arguments[1] !== void 0 ? _arguments[1] : {};
177
+ requestBody = {
178
+ client_name: options.clientName || '@mcp-z/client',
179
+ redirect_uris: options.redirectUri ? [
180
+ options.redirectUri
181
+ ] : [
182
+ 'http://localhost:3000/callback'
183
+ ],
184
+ grant_types: [
185
+ 'authorization_code',
186
+ 'refresh_token'
187
+ ],
188
+ response_types: [
189
+ 'code'
190
+ ],
191
+ token_endpoint_auth_method: 'client_secret_basic'
192
+ };
193
+ return [
194
+ 4,
195
+ fetch(registrationEndpoint, {
196
+ method: 'POST',
197
+ headers: {
198
+ 'Content-Type': 'application/json',
199
+ Accept: 'application/json',
200
+ Connection: 'close'
201
+ },
202
+ body: JSON.stringify(requestBody)
203
+ })
204
+ ];
205
+ case 1:
206
+ response = _state.sent();
207
+ if (!!response.ok) return [
208
+ 3,
209
+ 3
210
+ ];
211
+ return [
212
+ 4,
213
+ response.text()
214
+ ];
215
+ case 2:
216
+ errorText = _state.sent();
217
+ throw new Error("DCR registration failed (".concat(response.status, "): ").concat(errorText));
218
+ case 3:
219
+ return [
220
+ 4,
221
+ response.json()
222
+ ];
223
+ case 4:
224
+ data = _state.sent();
225
+ if (!data.client_id) {
226
+ throw new Error('DCR registration response missing client_id');
227
+ }
228
+ credentials = {
229
+ clientId: data.client_id,
230
+ clientSecret: data.client_secret || ''
231
+ };
232
+ if (data.client_id_issued_at) {
233
+ credentials.issuedAt = data.client_id_issued_at;
234
+ }
235
+ return [
236
+ 2,
237
+ credentials
238
+ ];
239
+ }
240
+ });
241
+ }).apply(this, arguments);
242
+ };
243
+ return DynamicClientRegistrar;
244
+ }();
245
+ /* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/libs/client/src/dcr/dynamic-client-registrar.ts"],"sourcesContent":["/**\n * Dynamic Client Registration (DCR) Client\n * Implements RFC 7591 for OAuth client registration\n */\n\nimport type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.ts';\n\n/**\n * DCR Registration Request (RFC 7591)\n */\ninterface DcrRegistrationRequest {\n client_name?: string;\n redirect_uris?: string[];\n grant_types?: string[];\n response_types?: string[];\n token_endpoint_auth_method?: string;\n}\n\n/**\n * DCR Registration Response (RFC 7591)\n */\ninterface DcrRegistrationResponse {\n client_id: string;\n client_secret?: string;\n client_id_issued_at?: number;\n client_secret_expires_at?: number;\n}\n\n/**\n * DynamicClientRegistrar handles Dynamic Client Registration with OAuth servers\n */\nexport class DynamicClientRegistrar {\n /**\n * Register a new OAuth client with the authorization server\n *\n * @param registrationEndpoint - DCR registration endpoint URL\n * @param options - Registration options (client name, redirect URI)\n * @returns Client credentials (client ID and secret)\n *\n * @throws Error if registration fails or server returns error\n *\n * @example\n * const registrar = new DynamicClientRegistrar();\n * const creds = await registrar.registerClient(\n * 'https://example.com/oauth/register',\n * { clientName: '@mcp-z/client', redirectUri: 'http://localhost:3000/callback' }\n * );\n * console.log('Client ID:', creds.clientId);\n */\n async registerClient(registrationEndpoint: string, options: DcrRegistrationOptions = {}): Promise<ClientCredentials> {\n const requestBody: DcrRegistrationRequest = {\n client_name: options.clientName || '@mcp-z/client',\n redirect_uris: options.redirectUri ? [options.redirectUri] : ['http://localhost:3000/callback'],\n grant_types: ['authorization_code', 'refresh_token'],\n response_types: ['code'],\n token_endpoint_auth_method: 'client_secret_basic',\n };\n\n const response = await fetch(registrationEndpoint, {\n method: 'POST',\n headers: {\n 'Content-Type': 'application/json',\n Accept: 'application/json',\n Connection: 'close',\n },\n body: JSON.stringify(requestBody),\n });\n\n if (!response.ok) {\n const errorText = await response.text();\n throw new Error(`DCR registration failed (${response.status}): ${errorText}`);\n }\n\n const data = (await response.json()) as DcrRegistrationResponse;\n\n if (!data.client_id) {\n throw new Error('DCR registration response missing client_id');\n }\n\n const credentials: ClientCredentials = {\n clientId: data.client_id,\n clientSecret: data.client_secret || '',\n };\n\n if (data.client_id_issued_at) {\n credentials.issuedAt = data.client_id_issued_at;\n }\n\n return credentials;\n }\n}\n"],"names":["DynamicClientRegistrar","registerClient","registrationEndpoint","options","requestBody","response","errorText","data","credentials","client_name","clientName","redirect_uris","redirectUri","grant_types","response_types","token_endpoint_auth_method","fetch","method","headers","Accept","Connection","body","JSON","stringify","ok","text","Error","status","json","client_id","clientId","clientSecret","client_secret","client_id_issued_at","issuedAt"],"mappings":"AAAA;;;CAGC;;;;+BA4BYA;;;eAAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAN,IAAA,AAAMA,uCAAN;;aAAMA;gCAAAA;;iBAAAA;IACX;;;;;;;;;;;;;;;;GAgBC,GACD,OAAMC,cAwCL,GAxCD,SAAMA;4CAAeC,oBAA4B;gBAAEC,SAC3CC,aAQAC,UAWEC,WAIFC,MAMAC;;;;;wBA9B2CL,UAAAA,oEAAkC,CAAC;wBAC9EC,cAAsC;4BAC1CK,aAAaN,QAAQO,UAAU,IAAI;4BACnCC,eAAeR,QAAQS,WAAW;gCAAIT,QAAQS,WAAW;;gCAAK;;4BAC9DC,WAAW;gCAAG;gCAAsB;;4BACpCC,cAAc;gCAAG;;4BACjBC,4BAA4B;wBAC9B;wBAEiB;;4BAAMC,MAAMd,sBAAsB;gCACjDe,QAAQ;gCACRC,SAAS;oCACP,gBAAgB;oCAChBC,QAAQ;oCACRC,YAAY;gCACd;gCACAC,MAAMC,KAAKC,SAAS,CAACnB;4BACvB;;;wBARMC,WAAW;6BAUb,CAACA,SAASmB,EAAE,EAAZ;;;;wBACgB;;4BAAMnB,SAASoB,IAAI;;;wBAA/BnB,YAAY;wBAClB,MAAM,IAAIoB,MAAM,AAAC,4BAAgDpB,OAArBD,SAASsB,MAAM,EAAC,OAAe,OAAVrB;;wBAGrD;;4BAAMD,SAASuB,IAAI;;;wBAA3BrB,OAAQ;wBAEd,IAAI,CAACA,KAAKsB,SAAS,EAAE;4BACnB,MAAM,IAAIH,MAAM;wBAClB;wBAEMlB,cAAiC;4BACrCsB,UAAUvB,KAAKsB,SAAS;4BACxBE,cAAcxB,KAAKyB,aAAa,IAAI;wBACtC;wBAEA,IAAIzB,KAAK0B,mBAAmB,EAAE;4BAC5BzB,YAAY0B,QAAQ,GAAG3B,KAAK0B,mBAAmB;wBACjD;wBAEA;;4BAAOzB;;;;QACT;;WA1DWR"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * DCR (Dynamic Client Registration) Module
3
+ * Exports public API for DCR authentication
4
+ */
5
+ export type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.js';
6
+ export type { DcrAuthenticatorOptions } from './dcr-authenticator.js';
7
+ export { DcrAuthenticator } from './dcr-authenticator.js';
8
+ export { DynamicClientRegistrar } from './dynamic-client-registrar.js';
@@ -0,0 +1,8 @@
1
+ /**
2
+ * DCR (Dynamic Client Registration) Module
3
+ * Exports public API for DCR authentication
4
+ */
5
+ export type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.js';
6
+ export type { DcrAuthenticatorOptions } from './dcr-authenticator.js';
7
+ export { DcrAuthenticator } from './dcr-authenticator.js';
8
+ export { DynamicClientRegistrar } from './dynamic-client-registrar.js';
@@ -0,0 +1,24 @@
1
+ /**
2
+ * DCR (Dynamic Client Registration) Module
3
+ * Exports public API for DCR authentication
4
+ */ "use strict";
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ function _export(target, all) {
9
+ for(var name in all)Object.defineProperty(target, name, {
10
+ enumerable: true,
11
+ get: Object.getOwnPropertyDescriptor(all, name).get
12
+ });
13
+ }
14
+ _export(exports, {
15
+ get DcrAuthenticator () {
16
+ return _dcrauthenticatorts.DcrAuthenticator;
17
+ },
18
+ get DynamicClientRegistrar () {
19
+ return _dynamicclientregistrarts.DynamicClientRegistrar;
20
+ }
21
+ });
22
+ var _dcrauthenticatorts = require("./dcr-authenticator.js");
23
+ var _dynamicclientregistrarts = require("./dynamic-client-registrar.js");
24
+ /* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/libs/client/src/dcr/index.ts"],"sourcesContent":["/**\n * DCR (Dynamic Client Registration) Module\n * Exports public API for DCR authentication\n */\n\nexport type { ClientCredentials, DcrRegistrationOptions } from '../auth/types.ts';\nexport type { DcrAuthenticatorOptions } from './dcr-authenticator.ts';\nexport { DcrAuthenticator } from './dcr-authenticator.ts';\nexport { DynamicClientRegistrar } from './dynamic-client-registrar.ts';\n"],"names":["DcrAuthenticator","DynamicClientRegistrar"],"mappings":"AAAA;;;CAGC;;;;;;;;;;;QAIQA;eAAAA,oCAAgB;;QAChBC;eAAAA,gDAAsB;;;kCADE;wCACM"}
@@ -0,0 +1,21 @@
1
+ /**
2
+ * @mcp-z/client - MCP Client Library
3
+ */
4
+ export type { McpServerEntry, StartConfig } from '../schemas/servers.d.js';
5
+ export { probeAuthCapabilities } from './auth/capability-discovery.js';
6
+ export type { AuthCapabilities, CallbackResult, OAuthCallbackListenerOptions, OAuthFlowOptions, TokenSet } from './auth/index.js';
7
+ export { InteractiveOAuthFlow } from './auth/interactive-oauth-flow.js';
8
+ export { OAuthCallbackListener } from './auth/oauth-callback-listener.js';
9
+ export { decorateClient, type ManagedClient, type PromptArguments, type WrappedCallToolReturn, type WrappedGetPromptReturn, type WrappedReadResourceReturn } from './client-helpers.js';
10
+ export { type ValidationResult, validateServers } from './config/validate-config.js';
11
+ export type { JsonValue, PromptArgument, ToolArguments } from './connection/types.js';
12
+ export { DcrAuthenticator } from './dcr/dcr-authenticator.js';
13
+ export { DynamicClientRegistrar } from './dcr/dynamic-client-registrar.js';
14
+ export type { ClientCredentials, DcrAuthenticatorOptions, DcrRegistrationOptions } from './dcr/index.js';
15
+ export { type JsonValidator, type NativeCallToolResponse, type NativeGetPromptResponse, type NativeReadResourceResponse, PromptResponseError, PromptResponseWrapper, ResourceResponseError, ResourceResponseWrapper, ToolResponseError, ToolResponseWrapper, } from './response-wrappers.js';
16
+ export type { CapabilityClient, CapabilityIndex, CapabilityType, IndexedCapability, IndexedPrompt, IndexedResource, IndexedTool, SearchField, SearchOptions, SearchResponse, SearchResult } from './search/index.js';
17
+ export { buildCapabilityIndex, search, searchCapabilities } from './search/index.js';
18
+ export { type CloseResult, type CreateServerRegistryOptions, createServerRegistry, type Dialect, type ServerRegistry, type ServersConfig } from './spawn/spawn-servers.js';
19
+ export type { TransportType } from './types.js';
20
+ export { getLogLevel, type Logger, type LogLevel, logger, setLogLevel } from './utils/logger.js';
21
+ export { resolveArgsPaths, resolvePath } from './utils/path-utils.js';
@@ -0,0 +1,21 @@
1
+ /**
2
+ * @mcp-z/client - MCP Client Library
3
+ */
4
+ export type { McpServerEntry, StartConfig } from '../schemas/servers.d.js';
5
+ export { probeAuthCapabilities } from './auth/capability-discovery.js';
6
+ export type { AuthCapabilities, CallbackResult, OAuthCallbackListenerOptions, OAuthFlowOptions, TokenSet } from './auth/index.js';
7
+ export { InteractiveOAuthFlow } from './auth/interactive-oauth-flow.js';
8
+ export { OAuthCallbackListener } from './auth/oauth-callback-listener.js';
9
+ export { decorateClient, type ManagedClient, type PromptArguments, type WrappedCallToolReturn, type WrappedGetPromptReturn, type WrappedReadResourceReturn } from './client-helpers.js';
10
+ export { type ValidationResult, validateServers } from './config/validate-config.js';
11
+ export type { JsonValue, PromptArgument, ToolArguments } from './connection/types.js';
12
+ export { DcrAuthenticator } from './dcr/dcr-authenticator.js';
13
+ export { DynamicClientRegistrar } from './dcr/dynamic-client-registrar.js';
14
+ export type { ClientCredentials, DcrAuthenticatorOptions, DcrRegistrationOptions } from './dcr/index.js';
15
+ export { type JsonValidator, type NativeCallToolResponse, type NativeGetPromptResponse, type NativeReadResourceResponse, PromptResponseError, PromptResponseWrapper, ResourceResponseError, ResourceResponseWrapper, ToolResponseError, ToolResponseWrapper, } from './response-wrappers.js';
16
+ export type { CapabilityClient, CapabilityIndex, CapabilityType, IndexedCapability, IndexedPrompt, IndexedResource, IndexedTool, SearchField, SearchOptions, SearchResponse, SearchResult } from './search/index.js';
17
+ export { buildCapabilityIndex, search, searchCapabilities } from './search/index.js';
18
+ export { type CloseResult, type CreateServerRegistryOptions, createServerRegistry, type Dialect, type ServerRegistry, type ServersConfig } from './spawn/spawn-servers.js';
19
+ export type { TransportType } from './types.js';
20
+ export { getLogLevel, type Logger, type LogLevel, logger, setLogLevel } from './utils/logger.js';
21
+ export { resolveArgsPaths, resolvePath } from './utils/path-utils.js';
@@ -0,0 +1,94 @@
1
+ /**
2
+ * @mcp-z/client - MCP Client Library
3
+ */ // Config types (from schema)
4
+ "use strict";
5
+ Object.defineProperty(exports, "__esModule", {
6
+ value: true
7
+ });
8
+ function _export(target, all) {
9
+ for(var name in all)Object.defineProperty(target, name, {
10
+ enumerable: true,
11
+ get: Object.getOwnPropertyDescriptor(all, name).get
12
+ });
13
+ }
14
+ _export(exports, {
15
+ get DcrAuthenticator () {
16
+ return _dcrauthenticatorts.DcrAuthenticator;
17
+ },
18
+ get DynamicClientRegistrar () {
19
+ return _dynamicclientregistrarts.DynamicClientRegistrar;
20
+ },
21
+ get InteractiveOAuthFlow () {
22
+ return _interactiveoauthflowts.InteractiveOAuthFlow;
23
+ },
24
+ get OAuthCallbackListener () {
25
+ return _oauthcallbacklistenerts.OAuthCallbackListener;
26
+ },
27
+ get PromptResponseError () {
28
+ return _responsewrappersts.PromptResponseError;
29
+ },
30
+ get PromptResponseWrapper () {
31
+ return _responsewrappersts.PromptResponseWrapper;
32
+ },
33
+ get ResourceResponseError () {
34
+ return _responsewrappersts.ResourceResponseError;
35
+ },
36
+ get ResourceResponseWrapper () {
37
+ return _responsewrappersts.ResourceResponseWrapper;
38
+ },
39
+ get ToolResponseError () {
40
+ return _responsewrappersts.ToolResponseError;
41
+ },
42
+ get ToolResponseWrapper () {
43
+ return _responsewrappersts.ToolResponseWrapper;
44
+ },
45
+ get buildCapabilityIndex () {
46
+ return _indexts.buildCapabilityIndex;
47
+ },
48
+ get createServerRegistry () {
49
+ return _spawnserversts.createServerRegistry;
50
+ },
51
+ get decorateClient () {
52
+ return _clienthelpersts.decorateClient;
53
+ },
54
+ get getLogLevel () {
55
+ return _loggerts.getLogLevel;
56
+ },
57
+ get logger () {
58
+ return _loggerts.logger;
59
+ },
60
+ get probeAuthCapabilities () {
61
+ return _capabilitydiscoveryts.probeAuthCapabilities;
62
+ },
63
+ get resolveArgsPaths () {
64
+ return _pathutilsts.resolveArgsPaths;
65
+ },
66
+ get resolvePath () {
67
+ return _pathutilsts.resolvePath;
68
+ },
69
+ get search () {
70
+ return _indexts.search;
71
+ },
72
+ get searchCapabilities () {
73
+ return _indexts.searchCapabilities;
74
+ },
75
+ get setLogLevel () {
76
+ return _loggerts.setLogLevel;
77
+ },
78
+ get validateServers () {
79
+ return _validateconfigts.validateServers;
80
+ }
81
+ });
82
+ var _capabilitydiscoveryts = require("./auth/capability-discovery.js");
83
+ var _interactiveoauthflowts = require("./auth/interactive-oauth-flow.js");
84
+ var _oauthcallbacklistenerts = require("./auth/oauth-callback-listener.js");
85
+ var _clienthelpersts = require("./client-helpers.js");
86
+ var _validateconfigts = require("./config/validate-config.js");
87
+ var _dcrauthenticatorts = require("./dcr/dcr-authenticator.js");
88
+ var _dynamicclientregistrarts = require("./dcr/dynamic-client-registrar.js");
89
+ var _responsewrappersts = require("./response-wrappers.js");
90
+ var _indexts = require("./search/index.js");
91
+ var _spawnserversts = require("./spawn/spawn-servers.js");
92
+ var _loggerts = require("./utils/logger.js");
93
+ var _pathutilsts = require("./utils/path-utils.js");
94
+ /* CJS INTEROP */ if (exports.__esModule && exports.default) { try { Object.defineProperty(exports.default, '__esModule', { value: true }); for (var key in exports) { exports.default[key] = exports[key]; } } catch (_) {}; module.exports = exports.default; }
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/libs/client/src/index.ts"],"sourcesContent":["/**\n * @mcp-z/client - MCP Client Library\n */\n\n// Config types (from schema)\nexport type { McpServerEntry, StartConfig } from '../schemas/servers.d.ts';\n// Auth - OAuth utilities\nexport { probeAuthCapabilities } from './auth/capability-discovery.ts';\nexport type { AuthCapabilities, CallbackResult, OAuthCallbackListenerOptions, OAuthFlowOptions, TokenSet } from './auth/index.ts';\nexport { InteractiveOAuthFlow } from './auth/interactive-oauth-flow.ts';\nexport { OAuthCallbackListener } from './auth/oauth-callback-listener.ts';\n// Client helpers and lightweight overloads\nexport { decorateClient, type ManagedClient, type PromptArguments, type WrappedCallToolReturn, type WrappedGetPromptReturn, type WrappedReadResourceReturn } from './client-helpers.ts';\n// Config - Configuration validation\nexport { type ValidationResult, validateServers } from './config/validate-config.ts';\n// Connection - MCP client connection utilities (internal helpers exposed for advanced use)\nexport type { JsonValue, PromptArgument, ToolArguments } from './connection/types.ts';\n// DCR - Dynamic Client Registration utilities\nexport { DcrAuthenticator } from './dcr/dcr-authenticator.ts';\nexport { DynamicClientRegistrar } from './dcr/dynamic-client-registrar.ts';\nexport type { ClientCredentials, DcrAuthenticatorOptions, DcrRegistrationOptions } from './dcr/index.ts';\nexport {\n type JsonValidator,\n type NativeCallToolResponse,\n type NativeGetPromptResponse,\n type NativeReadResourceResponse,\n PromptResponseError,\n PromptResponseWrapper,\n ResourceResponseError,\n ResourceResponseWrapper,\n ToolResponseError,\n ToolResponseWrapper,\n} from './response-wrappers.ts';\nexport type { CapabilityClient, CapabilityIndex, CapabilityType, IndexedCapability, IndexedPrompt, IndexedResource, IndexedTool, SearchField, SearchOptions, SearchResponse, SearchResult } from './search/index.ts';\n// Search - Capability discovery\nexport { buildCapabilityIndex, search, searchCapabilities } from './search/index.ts';\n// Spawn - Server registry (v3 API)\nexport { type CloseResult, type CreateServerRegistryOptions, createServerRegistry, type Dialect, type ServerRegistry, type ServersConfig } from './spawn/spawn-servers.ts';\nexport type { TransportType } from './types.ts';\n// Utils - Shared utilities\nexport { getLogLevel, type Logger, type LogLevel, logger, setLogLevel } from './utils/logger.ts';\nexport { resolveArgsPaths, resolvePath } from './utils/path-utils.ts';\n"],"names":["DcrAuthenticator","DynamicClientRegistrar","InteractiveOAuthFlow","OAuthCallbackListener","PromptResponseError","PromptResponseWrapper","ResourceResponseError","ResourceResponseWrapper","ToolResponseError","ToolResponseWrapper","buildCapabilityIndex","createServerRegistry","decorateClient","getLogLevel","logger","probeAuthCapabilities","resolveArgsPaths","resolvePath","search","searchCapabilities","setLogLevel","validateServers"],"mappings":"AAAA;;CAEC,GAED,6BAA6B;;;;;;;;;;;;QAcpBA;eAAAA,oCAAgB;;QAChBC;eAAAA,gDAAsB;;QAVtBC;eAAAA,4CAAoB;;QACpBC;eAAAA,8CAAqB;;QAgB5BC;eAAAA,uCAAmB;;QACnBC;eAAAA,yCAAqB;;QACrBC;eAAAA,yCAAqB;;QACrBC;eAAAA,2CAAuB;;QACvBC;eAAAA,qCAAiB;;QACjBC;eAAAA,uCAAmB;;QAIZC;eAAAA,6BAAoB;;QAEgCC;eAAAA,oCAAoB;;QAzBxEC;eAAAA,+BAAc;;QA4BdC;eAAAA,qBAAW;;QAA8BC;eAAAA,gBAAM;;QAjC/CC;eAAAA,4CAAqB;;QAkCrBC;eAAAA,6BAAgB;;QAAEC;eAAAA,wBAAW;;QANPC;eAAAA,eAAM;;QAAEC;eAAAA,2BAAkB;;QAKCC;eAAAA,qBAAW;;QA1BrCC;eAAAA,iCAAe;;;qCAPT;sCAED;uCACC;+BAE4H;gCAE3G;kCAItB;wCACM;kCAahC;uBAG0D;8BAE+E;wBAGnE;2BAC/B"}
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Monkey patches for MCP SDK bugs
3
+ *
4
+ * These patches fix bugs in dependencies that haven't been fixed upstream yet.
5
+ */
6
+ export {};
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Monkey patches for MCP SDK bugs
3
+ *
4
+ * These patches fix bugs in dependencies that haven't been fixed upstream yet.
5
+ */
6
+ export {};