mcp4openapi 0.2.7 → 0.3.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.
- package/README.md +147 -63
- package/dist/scripts/validate-profile.js +3 -3
- package/dist/scripts/validate-profile.js.map +1 -1
- package/dist/src/{oauth-provider.d.ts → auth/oauth-provider.d.ts} +7 -2
- package/dist/src/auth/oauth-provider.d.ts.map +1 -0
- package/dist/src/{oauth-provider.js → auth/oauth-provider.js} +30 -2
- package/dist/src/auth/oauth-provider.js.map +1 -0
- package/dist/src/core/cli-config.d.ts +9 -0
- package/dist/src/core/cli-config.d.ts.map +1 -0
- package/dist/src/core/cli-config.js +124 -0
- package/dist/src/core/cli-config.js.map +1 -0
- package/dist/src/{constants.d.ts → core/constants.d.ts} +1 -0
- package/dist/src/core/constants.d.ts.map +1 -0
- package/dist/src/{constants.js → core/constants.js} +1 -0
- package/dist/src/core/constants.js.map +1 -0
- package/dist/src/{errors.d.ts → core/errors.d.ts} +6 -0
- package/dist/src/core/errors.d.ts.map +1 -0
- package/dist/src/{errors.js → core/errors.js} +15 -6
- package/dist/src/core/errors.js.map +1 -0
- package/dist/src/core/filtering.d.ts +19 -0
- package/dist/src/core/filtering.d.ts.map +1 -0
- package/dist/src/core/filtering.js +292 -0
- package/dist/src/core/filtering.js.map +1 -0
- package/dist/src/core/index.d.ts +26 -0
- package/dist/src/core/index.d.ts.map +1 -0
- package/dist/src/core/index.js +275 -0
- package/dist/src/core/index.js.map +1 -0
- package/dist/src/core/lib.d.ts +8 -0
- package/dist/src/core/lib.d.ts.map +1 -0
- package/dist/src/core/lib.js +7 -0
- package/dist/src/core/lib.js.map +1 -0
- package/dist/src/{logger.d.ts → core/logger.d.ts} +6 -13
- package/dist/src/core/logger.d.ts.map +1 -0
- package/dist/src/core/logger.js +197 -0
- package/dist/src/core/logger.js.map +1 -0
- package/dist/src/{metrics.d.ts → core/metrics.d.ts} +11 -0
- package/dist/src/core/metrics.d.ts.map +1 -0
- package/dist/src/{metrics.js → core/metrics.js} +61 -0
- package/dist/src/core/metrics.js.map +1 -0
- package/dist/src/core/naming-warnings.d.ts.map +1 -0
- package/dist/src/{naming-warnings.js → core/naming-warnings.js} +6 -6
- package/dist/src/core/naming-warnings.js.map +1 -0
- package/dist/src/core/naming.d.ts.map +1 -0
- package/dist/src/core/naming.js.map +1 -0
- package/dist/src/generated-schemas.d.ts +281 -79
- package/dist/src/generated-schemas.d.ts.map +1 -1
- package/dist/src/generated-schemas.js +17 -3
- package/dist/src/generated-schemas.js.map +1 -1
- package/dist/src/index.d.ts +1 -6
- package/dist/src/index.d.ts.map +1 -1
- package/dist/src/index.js +1 -156
- package/dist/src/index.js.map +1 -1
- package/dist/src/lib.d.ts +1 -7
- package/dist/src/lib.d.ts.map +1 -1
- package/dist/src/lib.js +1 -6
- package/dist/src/lib.js.map +1 -1
- package/dist/src/mcp/mcp-server-manager.d.ts +20 -0
- package/dist/src/mcp/mcp-server-manager.d.ts.map +1 -0
- package/dist/src/mcp/mcp-server-manager.js +38 -0
- package/dist/src/mcp/mcp-server-manager.js.map +1 -0
- package/dist/src/{mcp-server.d.ts → mcp/mcp-server.d.ts} +43 -3
- package/dist/src/mcp/mcp-server.d.ts.map +1 -0
- package/dist/src/{mcp-server.js → mcp/mcp-server.js} +639 -123
- package/dist/src/mcp/mcp-server.js.map +1 -0
- package/dist/src/{openapi-parser.d.ts → openapi/openapi-parser.d.ts} +1 -1
- package/dist/src/openapi/openapi-parser.d.ts.map +1 -0
- package/dist/src/{openapi-parser.js → openapi/openapi-parser.js} +2 -2
- package/dist/src/openapi/openapi-parser.js.map +1 -0
- package/dist/src/{profile-loader.d.ts → profile/profile-loader.d.ts} +3 -2
- package/dist/src/profile/profile-loader.d.ts.map +1 -0
- package/dist/src/{profile-loader.js → profile/profile-loader.js} +17 -6
- package/dist/src/profile/profile-loader.js.map +1 -0
- package/dist/src/profile/profile-registry.d.ts +18 -0
- package/dist/src/profile/profile-registry.d.ts.map +1 -0
- package/dist/src/profile/profile-registry.js +26 -0
- package/dist/src/profile/profile-registry.js.map +1 -0
- package/dist/src/profile/profile-resolver.d.ts +25 -0
- package/dist/src/profile/profile-resolver.d.ts.map +1 -0
- package/dist/src/profile/profile-resolver.js +204 -0
- package/dist/src/profile/profile-resolver.js.map +1 -0
- package/dist/src/profile/startup-profile.d.ts +17 -0
- package/dist/src/profile/startup-profile.d.ts.map +1 -0
- package/dist/src/profile/startup-profile.js +30 -0
- package/dist/src/profile/startup-profile.js.map +1 -0
- package/dist/src/profile/startup-validation.d.ts +11 -0
- package/dist/src/profile/startup-validation.d.ts.map +1 -0
- package/dist/src/profile/startup-validation.js +21 -0
- package/dist/src/profile/startup-validation.js.map +1 -0
- package/dist/src/testing/dynamic-mock-server.d.ts +24 -0
- package/dist/src/testing/dynamic-mock-server.d.ts.map +1 -0
- package/dist/src/testing/dynamic-mock-server.js +138 -0
- package/dist/src/testing/dynamic-mock-server.js.map +1 -0
- package/dist/src/testing/listen-support.d.ts +3 -0
- package/dist/src/testing/listen-support.d.ts.map +1 -0
- package/dist/src/testing/listen-support.js +50 -0
- package/dist/src/testing/listen-support.js.map +1 -0
- package/dist/src/testing/request-assertions.d.ts +5 -0
- package/dist/src/testing/request-assertions.d.ts.map +1 -0
- package/dist/src/testing/request-assertions.js +165 -0
- package/dist/src/testing/request-assertions.js.map +1 -0
- package/dist/src/testing/template-utils.d.ts +10 -0
- package/dist/src/testing/template-utils.d.ts.map +1 -0
- package/dist/src/testing/template-utils.js +72 -0
- package/dist/src/testing/template-utils.js.map +1 -0
- package/dist/src/testing/test-http-utils.d.ts +1 -1
- package/dist/src/testing/test-http-utils.d.ts.map +1 -1
- package/dist/src/testing/test-http-utils.js +1 -1
- package/dist/src/testing/test-http-utils.js.map +1 -1
- package/dist/src/testing/test-loader.d.ts +6 -0
- package/dist/src/testing/test-loader.d.ts.map +1 -0
- package/dist/src/testing/test-loader.js +212 -0
- package/dist/src/testing/test-loader.js.map +1 -0
- package/dist/src/testing/test-schema.d.ts +1270 -0
- package/dist/src/testing/test-schema.d.ts.map +1 -0
- package/dist/src/testing/test-schema.js +76 -0
- package/dist/src/testing/test-schema.js.map +1 -0
- package/dist/src/tool-filter/compat.d.ts +49 -0
- package/dist/src/tool-filter/compat.d.ts.map +1 -0
- package/dist/src/tool-filter/compat.js +72 -0
- package/dist/src/tool-filter/compat.js.map +1 -0
- package/dist/src/tool-filter/config/env-config-parser.d.ts +38 -0
- package/dist/src/tool-filter/config/env-config-parser.d.ts.map +1 -0
- package/dist/src/tool-filter/config/env-config-parser.js +103 -0
- package/dist/src/tool-filter/config/env-config-parser.js.map +1 -0
- package/dist/src/tool-filter/config/header-config-parser.d.ts +37 -0
- package/dist/src/tool-filter/config/header-config-parser.d.ts.map +1 -0
- package/dist/src/tool-filter/config/header-config-parser.js +118 -0
- package/dist/src/tool-filter/config/header-config-parser.js.map +1 -0
- package/dist/src/tool-filter/errors.d.ts +18 -0
- package/dist/src/tool-filter/errors.d.ts.map +1 -0
- package/dist/src/tool-filter/errors.js +21 -0
- package/dist/src/tool-filter/errors.js.map +1 -0
- package/dist/src/tool-filter/filter/filter-engine.d.ts +45 -0
- package/dist/src/tool-filter/filter/filter-engine.d.ts.map +1 -0
- package/dist/src/tool-filter/filter/filter-engine.js +94 -0
- package/dist/src/tool-filter/filter/filter-engine.js.map +1 -0
- package/dist/src/tool-filter/filter/filter-rules.d.ts +44 -0
- package/dist/src/tool-filter/filter/filter-rules.d.ts.map +1 -0
- package/dist/src/tool-filter/filter/filter-rules.js +72 -0
- package/dist/src/tool-filter/filter/filter-rules.js.map +1 -0
- package/dist/src/tool-filter/filter/global-tool-filter.d.ts +40 -0
- package/dist/src/tool-filter/filter/global-tool-filter.d.ts.map +1 -0
- package/dist/src/tool-filter/filter/global-tool-filter.js +92 -0
- package/dist/src/tool-filter/filter/global-tool-filter.js.map +1 -0
- package/dist/src/tool-filter/filter/session-tool-filter.d.ts +29 -0
- package/dist/src/tool-filter/filter/session-tool-filter.d.ts.map +1 -0
- package/dist/src/tool-filter/filter/session-tool-filter.js +69 -0
- package/dist/src/tool-filter/filter/session-tool-filter.js.map +1 -0
- package/dist/src/tool-filter/index.d.ts +25 -0
- package/dist/src/tool-filter/index.d.ts.map +1 -0
- package/dist/src/tool-filter/index.js +30 -0
- package/dist/src/tool-filter/index.js.map +1 -0
- package/dist/src/tool-filter/integration/tool-filter-service.d.ts +44 -0
- package/dist/src/tool-filter/integration/tool-filter-service.d.ts.map +1 -0
- package/dist/src/tool-filter/integration/tool-filter-service.js +68 -0
- package/dist/src/tool-filter/integration/tool-filter-service.js.map +1 -0
- package/dist/src/tool-filter/operation/operation-classifier.d.ts +20 -0
- package/dist/src/tool-filter/operation/operation-classifier.d.ts.map +1 -0
- package/dist/src/tool-filter/operation/operation-classifier.js +26 -0
- package/dist/src/tool-filter/operation/operation-classifier.js.map +1 -0
- package/dist/src/tool-filter/operation/operation-detector.d.ts +30 -0
- package/dist/src/tool-filter/operation/operation-detector.d.ts.map +1 -0
- package/dist/src/tool-filter/operation/operation-detector.js +96 -0
- package/dist/src/tool-filter/operation/operation-detector.js.map +1 -0
- package/dist/src/tool-filter/operation/operation-resolver.d.ts +22 -0
- package/dist/src/tool-filter/operation/operation-resolver.d.ts.map +1 -0
- package/dist/src/tool-filter/operation/operation-resolver.js +32 -0
- package/dist/src/tool-filter/operation/operation-resolver.js.map +1 -0
- package/dist/src/tool-filter/regex/regex-compiler.d.ts +22 -0
- package/dist/src/tool-filter/regex/regex-compiler.d.ts.map +1 -0
- package/dist/src/tool-filter/regex/regex-compiler.js +56 -0
- package/dist/src/tool-filter/regex/regex-compiler.js.map +1 -0
- package/dist/src/tool-filter/regex/regex-validator.d.ts +24 -0
- package/dist/src/tool-filter/regex/regex-validator.d.ts.map +1 -0
- package/dist/src/tool-filter/regex/regex-validator.js +58 -0
- package/dist/src/tool-filter/regex/regex-validator.js.map +1 -0
- package/dist/src/tool-filter/types.d.ts +92 -0
- package/dist/src/tool-filter/types.d.ts.map +1 -0
- package/dist/src/tool-filter/types.js +5 -0
- package/dist/src/tool-filter/types.js.map +1 -0
- package/dist/src/tool-filter/utils.d.ts +11 -0
- package/dist/src/tool-filter/utils.d.ts.map +1 -0
- package/dist/src/tool-filter/utils.js +13 -0
- package/dist/src/tool-filter/utils.js.map +1 -0
- package/dist/src/{composite-executor.d.ts → tooling/composite-executor.d.ts} +3 -3
- package/dist/src/tooling/composite-executor.d.ts.map +1 -0
- package/dist/src/{composite-executor.js → tooling/composite-executor.js} +1 -1
- package/dist/src/tooling/composite-executor.js.map +1 -0
- package/dist/src/{dag-executor.d.ts → tooling/dag-executor.d.ts} +1 -1
- package/dist/src/tooling/dag-executor.d.ts.map +1 -0
- package/dist/src/tooling/dag-executor.js.map +1 -0
- package/dist/src/{proxy-executor.d.ts → tooling/proxy-executor.d.ts} +19 -4
- package/dist/src/tooling/proxy-executor.d.ts.map +1 -0
- package/dist/src/tooling/proxy-executor.js +497 -0
- package/dist/src/tooling/proxy-executor.js.map +1 -0
- package/dist/src/{tool-generator.d.ts → tooling/tool-generator.d.ts} +4 -3
- package/dist/src/tooling/tool-generator.d.ts.map +1 -0
- package/dist/src/{tool-generator.js → tooling/tool-generator.js} +23 -7
- package/dist/src/tooling/tool-generator.js.map +1 -0
- package/dist/src/{http-client-factory.d.ts → transport/http-client-factory.d.ts} +4 -1
- package/dist/src/transport/http-client-factory.d.ts.map +1 -0
- package/dist/src/{http-client-factory.js → transport/http-client-factory.js} +13 -3
- package/dist/src/transport/http-client-factory.js.map +1 -0
- package/dist/src/transport/http-transport-config.d.ts +6 -0
- package/dist/src/transport/http-transport-config.d.ts.map +1 -0
- package/dist/src/transport/http-transport-config.js +62 -0
- package/dist/src/transport/http-transport-config.js.map +1 -0
- package/dist/src/{http-transport.d.ts → transport/http-transport.d.ts} +72 -14
- package/dist/src/transport/http-transport.d.ts.map +1 -0
- package/dist/src/transport/http-transport.js +2522 -0
- package/dist/src/transport/http-transport.js.map +1 -0
- package/dist/src/{interceptors.d.ts → transport/interceptors.d.ts} +6 -2
- package/dist/src/transport/interceptors.d.ts.map +1 -0
- package/dist/src/{interceptors.js → transport/interceptors.js} +77 -46
- package/dist/src/transport/interceptors.js.map +1 -0
- package/dist/src/types/http-transport.d.ts +25 -0
- package/dist/src/types/http-transport.d.ts.map +1 -1
- package/dist/src/types/profile.d.ts +31 -1
- package/dist/src/types/profile.d.ts.map +1 -1
- package/dist/src/validation/argument-normalizer.d.ts +6 -0
- package/dist/src/validation/argument-normalizer.d.ts.map +1 -0
- package/dist/src/validation/argument-normalizer.js +70 -0
- package/dist/src/validation/argument-normalizer.js.map +1 -0
- package/dist/src/validation/jsonrpc-validator.d.ts.map +1 -0
- package/dist/src/validation/jsonrpc-validator.js.map +1 -0
- package/dist/src/{schema-validator.d.ts → validation/schema-validator.d.ts} +2 -2
- package/dist/src/validation/schema-validator.d.ts.map +1 -0
- package/dist/src/validation/schema-validator.js.map +1 -0
- package/dist/src/validation/validation-utils.d.ts.map +1 -0
- package/dist/src/validation/validation-utils.js.map +1 -0
- package/package.json +9 -3
- package/profile-schema.json +75 -3
- package/profiles/gitlab/developer-profile-oauth.json +1520 -0
- package/profiles/gitlab/developer-profile-oauth.test.json +3432 -0
- package/profiles/gitlab/openapi.yaml +6891 -0
- package/profiles/n8n/openapi.yaml +2441 -0
- package/profiles/n8n/profile-optimized.json +965 -0
- package/profiles/n8n/profile-optimized.test.json +1078 -0
- package/profiles/n8n/profile.json +1033 -0
- package/profiles/n8n/profile.test.json +983 -0
- package/profiles/n8n-nodes/openapi.yaml +24 -0
- package/profiles/n8n-nodes/profile-nodes.json +44 -0
- package/profiles/n8n-nodes/profile-nodes.test.json +91 -0
- package/profiles/semgrep/openapi.yaml +4706 -0
- package/profiles/semgrep/profile.json +692 -0
- package/profiles/semgrep/profile.test.json +471 -0
- package/profiles/youtrack/openapi.json +16976 -0
- package/profiles/youtrack/profile.json +608 -0
- package/profiles/youtrack/profile.test.json +1926 -0
- package/dist/src/composite-executor.d.ts.map +0 -1
- package/dist/src/composite-executor.js.map +0 -1
- package/dist/src/constants.d.ts.map +0 -1
- package/dist/src/constants.js.map +0 -1
- package/dist/src/dag-executor.d.ts.map +0 -1
- package/dist/src/dag-executor.js.map +0 -1
- package/dist/src/errors.d.ts.map +0 -1
- package/dist/src/errors.js.map +0 -1
- package/dist/src/http-client-factory.d.ts.map +0 -1
- package/dist/src/http-client-factory.js.map +0 -1
- package/dist/src/http-transport.d.ts.map +0 -1
- package/dist/src/http-transport.js +0 -1826
- package/dist/src/http-transport.js.map +0 -1
- package/dist/src/interceptors.d.ts.map +0 -1
- package/dist/src/interceptors.js.map +0 -1
- package/dist/src/jsonrpc-validator.d.ts.map +0 -1
- package/dist/src/jsonrpc-validator.js.map +0 -1
- package/dist/src/logger.d.ts.map +0 -1
- package/dist/src/logger.js +0 -177
- package/dist/src/logger.js.map +0 -1
- package/dist/src/mcp-server.d.ts.map +0 -1
- package/dist/src/mcp-server.js.map +0 -1
- package/dist/src/metrics.d.ts.map +0 -1
- package/dist/src/metrics.js.map +0 -1
- package/dist/src/naming-warnings.d.ts.map +0 -1
- package/dist/src/naming-warnings.js.map +0 -1
- package/dist/src/naming.d.ts.map +0 -1
- package/dist/src/naming.js.map +0 -1
- package/dist/src/oauth-provider.d.ts.map +0 -1
- package/dist/src/oauth-provider.js.map +0 -1
- package/dist/src/openapi-parser.d.ts.map +0 -1
- package/dist/src/openapi-parser.js.map +0 -1
- package/dist/src/profile-loader.d.ts.map +0 -1
- package/dist/src/profile-loader.js.map +0 -1
- package/dist/src/proxy-executor.d.ts.map +0 -1
- package/dist/src/proxy-executor.js +0 -240
- package/dist/src/proxy-executor.js.map +0 -1
- package/dist/src/schema-validator.d.ts.map +0 -1
- package/dist/src/schema-validator.js.map +0 -1
- package/dist/src/testing/fixtures.d.ts +0 -684
- package/dist/src/testing/fixtures.d.ts.map +0 -1
- package/dist/src/testing/fixtures.js +0 -528
- package/dist/src/testing/fixtures.js.map +0 -1
- package/dist/src/testing/mock-gitlab-server.d.ts +0 -43
- package/dist/src/testing/mock-gitlab-server.d.ts.map +0 -1
- package/dist/src/testing/mock-gitlab-server.js +0 -1026
- package/dist/src/testing/mock-gitlab-server.js.map +0 -1
- package/dist/src/testing/mock-semgrep-server.d.ts +0 -32
- package/dist/src/testing/mock-semgrep-server.d.ts.map +0 -1
- package/dist/src/testing/mock-semgrep-server.js +0 -213
- package/dist/src/testing/mock-semgrep-server.js.map +0 -1
- package/dist/src/testing/mock-youtrack-server.d.ts +0 -11
- package/dist/src/testing/mock-youtrack-server.d.ts.map +0 -1
- package/dist/src/testing/mock-youtrack-server.js +0 -138
- package/dist/src/testing/mock-youtrack-server.js.map +0 -1
- package/dist/src/tool-generator.d.ts.map +0 -1
- package/dist/src/tool-generator.js.map +0 -1
- package/dist/src/validation-utils.d.ts.map +0 -1
- package/dist/src/validation-utils.js.map +0 -1
- /package/dist/src/{naming-warnings.d.ts → core/naming-warnings.d.ts} +0 -0
- /package/dist/src/{naming.d.ts → core/naming.d.ts} +0 -0
- /package/dist/src/{naming.js → core/naming.js} +0 -0
- /package/dist/src/{dag-executor.js → tooling/dag-executor.js} +0 -0
- /package/dist/src/{jsonrpc-validator.d.ts → validation/jsonrpc-validator.d.ts} +0 -0
- /package/dist/src/{jsonrpc-validator.js → validation/jsonrpc-validator.js} +0 -0
- /package/dist/src/{schema-validator.js → validation/schema-validator.js} +0 -0
- /package/dist/src/{validation-utils.d.ts → validation/validation-utils.d.ts} +0 -0
- /package/dist/src/{validation-utils.js → validation/validation-utils.js} +0 -0
|
@@ -0,0 +1,275 @@
|
|
|
1
|
+
#!/usr/bin/env node
|
|
2
|
+
/**
|
|
3
|
+
* CLI entry point
|
|
4
|
+
*
|
|
5
|
+
* Why: Reads env vars, initializes server, handles errors gracefully.
|
|
6
|
+
*/
|
|
7
|
+
import 'dotenv/config';
|
|
8
|
+
import { MCPServer } from '../mcp/mcp-server.js';
|
|
9
|
+
import { ConsoleLogger, JsonLogger } from './logger.js';
|
|
10
|
+
import { OAUTH_PATHS } from './constants.js';
|
|
11
|
+
import { applyCliEnvOverrides, parseCliArgs } from './cli-config.js';
|
|
12
|
+
import { buildHttpTransportBaseConfig } from '../transport/http-transport-config.js';
|
|
13
|
+
import { ProfileRegistry } from '../profile/profile-registry.js';
|
|
14
|
+
import { MCPServerManager } from '../mcp/mcp-server-manager.js';
|
|
15
|
+
import { getHttpProfileRoutingErrorMessage } from '../profile/startup-validation.js';
|
|
16
|
+
import { listProfiles } from '../profile/profile-resolver.js';
|
|
17
|
+
import { resolveStartupProfile } from '../profile/startup-profile.js';
|
|
18
|
+
/**
|
|
19
|
+
* Fetch OAuth Authorization Server Metadata (RFC 8414)
|
|
20
|
+
* Returns authorization_endpoint and token_endpoint
|
|
21
|
+
*/
|
|
22
|
+
export async function fetchOAuthMetadata(issuerUrl) {
|
|
23
|
+
try {
|
|
24
|
+
// Use URL constructor to properly handle trailing slashes
|
|
25
|
+
const metadataUrl = new URL(OAUTH_PATHS.WELL_KNOWN_AUTHORIZATION_SERVER, issuerUrl).toString();
|
|
26
|
+
const response = await fetch(metadataUrl, {
|
|
27
|
+
headers: { 'Accept': 'application/json' },
|
|
28
|
+
signal: AbortSignal.timeout(5000), // 5 second timeout
|
|
29
|
+
});
|
|
30
|
+
if (!response.ok) {
|
|
31
|
+
return null;
|
|
32
|
+
}
|
|
33
|
+
const metadata = await response.json();
|
|
34
|
+
return {
|
|
35
|
+
authorization_endpoint: metadata.authorization_endpoint,
|
|
36
|
+
token_endpoint: metadata.token_endpoint,
|
|
37
|
+
};
|
|
38
|
+
}
|
|
39
|
+
catch (error) {
|
|
40
|
+
return null;
|
|
41
|
+
}
|
|
42
|
+
}
|
|
43
|
+
/**
|
|
44
|
+
* Derive OAuth issuer from API base URL
|
|
45
|
+
* Example: https://www.gitlab.com/api/v4 -> https://www.gitlab.com
|
|
46
|
+
*/
|
|
47
|
+
export function deriveIssuerFromBaseUrl(baseUrl) {
|
|
48
|
+
try {
|
|
49
|
+
const url = new URL(baseUrl);
|
|
50
|
+
return url.origin;
|
|
51
|
+
}
|
|
52
|
+
catch {
|
|
53
|
+
return null;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
export function resolveHttpHostPort() {
|
|
57
|
+
const host = process.env.MCP4_HOST || '127.0.0.1';
|
|
58
|
+
const port = parseInt(process.env.MCP4_PORT || '3003', 10);
|
|
59
|
+
if (Number.isNaN(port)) {
|
|
60
|
+
throw new Error(`Invalid MCP4_PORT: ${process.env.MCP4_PORT}`);
|
|
61
|
+
}
|
|
62
|
+
return { host, port };
|
|
63
|
+
}
|
|
64
|
+
export async function main() {
|
|
65
|
+
const cliArgs = parseCliArgs(process.argv.slice(2));
|
|
66
|
+
applyCliEnvOverrides(cliArgs);
|
|
67
|
+
// Create logger early so startup/autodiscovery logs are structured and redacted consistently
|
|
68
|
+
const logFormat = process.env.MCP4_LOG_FORMAT || 'console';
|
|
69
|
+
const logger = logFormat === 'json' ? new JsonLogger() : new ConsoleLogger();
|
|
70
|
+
const profilesDir = process.env.MCP4_PROFILES_DIR;
|
|
71
|
+
if (cliArgs['list-profiles'] === 'true') {
|
|
72
|
+
const profiles = await listProfiles(profilesDir);
|
|
73
|
+
if (profiles.length === 0) {
|
|
74
|
+
console.log('No profiles found.');
|
|
75
|
+
return;
|
|
76
|
+
}
|
|
77
|
+
console.log('Available profiles:');
|
|
78
|
+
for (const profile of profiles) {
|
|
79
|
+
const details = [];
|
|
80
|
+
if (profile.profileName !== profile.profileId) {
|
|
81
|
+
details.push(`name: ${profile.profileName}`);
|
|
82
|
+
}
|
|
83
|
+
if (profile.profileAliases.length > 0) {
|
|
84
|
+
details.push(`aliases: ${profile.profileAliases.join(', ')}`);
|
|
85
|
+
}
|
|
86
|
+
const detailSuffix = details.length > 0 ? ` (${details.join(', ')})` : '';
|
|
87
|
+
console.log(`- ${profile.profileId}${detailSuffix}`);
|
|
88
|
+
}
|
|
89
|
+
return;
|
|
90
|
+
}
|
|
91
|
+
// OAuth Configuration Priority:
|
|
92
|
+
// 1. Explicit env vars (MCP4_OAUTH_AUTHORIZATION_URL, MCP4_OAUTH_TOKEN_URL)
|
|
93
|
+
// 2. Explicit issuer (MCP4_OAUTH_ISSUER)
|
|
94
|
+
// 3. Autodiscovery from MCP4_API_BASE_URL
|
|
95
|
+
const hasOAuthCredentials = process.env.MCP4_OAUTH_CLIENT_ID &&
|
|
96
|
+
process.env.MCP4_OAUTH_CLIENT_SECRET &&
|
|
97
|
+
process.env.MCP4_OAUTH_REDIRECT_URI;
|
|
98
|
+
const hasExplicitOAuthUrls = process.env.MCP4_OAUTH_AUTHORIZATION_URL &&
|
|
99
|
+
process.env.MCP4_OAUTH_TOKEN_URL;
|
|
100
|
+
if (hasOAuthCredentials && !hasExplicitOAuthUrls) {
|
|
101
|
+
// Try OAuth autodiscovery
|
|
102
|
+
let issuer = process.env.MCP4_OAUTH_ISSUER;
|
|
103
|
+
// If no explicit issuer, try to derive from API base URL
|
|
104
|
+
if (!issuer && process.env.MCP4_API_BASE_URL) {
|
|
105
|
+
const derivedIssuer = deriveIssuerFromBaseUrl(process.env.MCP4_API_BASE_URL);
|
|
106
|
+
if (derivedIssuer) {
|
|
107
|
+
issuer = derivedIssuer;
|
|
108
|
+
// Log origin only, not full URL to avoid logging sensitive paths
|
|
109
|
+
const issuerOrigin = new URL(derivedIssuer).origin;
|
|
110
|
+
logger.info('OAuth autodiscovery: derived issuer from MCP4_API_BASE_URL', { issuerOrigin });
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
if (issuer) {
|
|
114
|
+
// Try to fetch OAuth metadata
|
|
115
|
+
// Log origin only, not full URL to avoid logging sensitive paths
|
|
116
|
+
const issuerOrigin = new URL(issuer).origin;
|
|
117
|
+
logger.info('OAuth autodiscovery: fetching metadata', { issuerOrigin });
|
|
118
|
+
const metadata = await fetchOAuthMetadata(issuer);
|
|
119
|
+
if (metadata) {
|
|
120
|
+
logger.info('OAuth autodiscovery: successfully discovered OAuth endpoints');
|
|
121
|
+
if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
|
|
122
|
+
process.env.MCP4_OAUTH_AUTHORIZATION_URL = metadata.authorization_endpoint;
|
|
123
|
+
let authorizationEndpointOrigin;
|
|
124
|
+
try {
|
|
125
|
+
authorizationEndpointOrigin = new URL(metadata.authorization_endpoint).origin;
|
|
126
|
+
}
|
|
127
|
+
catch {
|
|
128
|
+
authorizationEndpointOrigin = undefined;
|
|
129
|
+
}
|
|
130
|
+
logger.info('OAuth autodiscovery: set authorization_endpoint', { authorizationEndpointOrigin });
|
|
131
|
+
}
|
|
132
|
+
if (!process.env.MCP4_OAUTH_TOKEN_URL) {
|
|
133
|
+
process.env.MCP4_OAUTH_TOKEN_URL = metadata.token_endpoint;
|
|
134
|
+
let tokenEndpointOrigin;
|
|
135
|
+
try {
|
|
136
|
+
tokenEndpointOrigin = new URL(metadata.token_endpoint).origin;
|
|
137
|
+
}
|
|
138
|
+
catch {
|
|
139
|
+
tokenEndpointOrigin = undefined;
|
|
140
|
+
}
|
|
141
|
+
logger.info('OAuth autodiscovery: set token_endpoint', { tokenEndpointOrigin });
|
|
142
|
+
}
|
|
143
|
+
}
|
|
144
|
+
else {
|
|
145
|
+
// Fallback to standard OAuth paths
|
|
146
|
+
logger.warn('OAuth autodiscovery: metadata fetch failed, using standard OAuth paths', {
|
|
147
|
+
issuerOrigin,
|
|
148
|
+
});
|
|
149
|
+
if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
|
|
150
|
+
process.env.MCP4_OAUTH_AUTHORIZATION_URL = `${issuer}/oauth/authorize`;
|
|
151
|
+
}
|
|
152
|
+
if (!process.env.MCP4_OAUTH_TOKEN_URL) {
|
|
153
|
+
process.env.MCP4_OAUTH_TOKEN_URL = `${issuer}/oauth/token`;
|
|
154
|
+
}
|
|
155
|
+
}
|
|
156
|
+
}
|
|
157
|
+
}
|
|
158
|
+
else if (process.env.MCP4_OAUTH_ISSUER && !hasExplicitOAuthUrls) {
|
|
159
|
+
// Legacy behavior: derive from explicit issuer
|
|
160
|
+
const issuer = process.env.MCP4_OAUTH_ISSUER;
|
|
161
|
+
if (!process.env.MCP4_OAUTH_AUTHORIZATION_URL) {
|
|
162
|
+
process.env.MCP4_OAUTH_AUTHORIZATION_URL = `${issuer}/oauth/authorize`;
|
|
163
|
+
}
|
|
164
|
+
if (!process.env.MCP4_OAUTH_TOKEN_URL) {
|
|
165
|
+
process.env.MCP4_OAUTH_TOKEN_URL = `${issuer}/oauth/token`;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
const specPathOverride = process.env.MCP4_OPENAPI_SPEC_PATH;
|
|
169
|
+
const { specPath, profilePath, profileId, defaultProfile, hasExplicitSpecPath, } = await resolveStartupProfile({
|
|
170
|
+
specPathEnv: specPathOverride,
|
|
171
|
+
profilePath: process.env.MCP4_PROFILE_PATH,
|
|
172
|
+
profileId: process.env.MCP4_PROFILE,
|
|
173
|
+
profilesDir,
|
|
174
|
+
});
|
|
175
|
+
const transport = process.env.MCP4_TRANSPORT || 'stdio';
|
|
176
|
+
const httpProfileRoutingEnabled = process.env.MCP4_HTTP_PROFILE_ROUTING === 'true';
|
|
177
|
+
const hasDefaultProfile = !!defaultProfile;
|
|
178
|
+
const hasSpecPath = !!specPath;
|
|
179
|
+
const routingError = getHttpProfileRoutingErrorMessage({
|
|
180
|
+
transport,
|
|
181
|
+
profileRoutingEnabled: httpProfileRoutingEnabled,
|
|
182
|
+
hasDefaultProfile,
|
|
183
|
+
hasSpecPath,
|
|
184
|
+
});
|
|
185
|
+
if (routingError) {
|
|
186
|
+
logger.error(routingError);
|
|
187
|
+
process.exit(1);
|
|
188
|
+
}
|
|
189
|
+
const requiresSpecPath = transport !== 'http' || !httpProfileRoutingEnabled || hasDefaultProfile;
|
|
190
|
+
if (!specPath && requiresSpecPath) {
|
|
191
|
+
logger.error('MCP4_OPENAPI_SPEC_PATH is required. Provide --openapi-spec-path (or MCP4_OPENAPI_SPEC_PATH), or use --profile with openapi_spec_path in the profile.');
|
|
192
|
+
process.exit(1);
|
|
193
|
+
}
|
|
194
|
+
try {
|
|
195
|
+
if (transport === 'http' && httpProfileRoutingEnabled) {
|
|
196
|
+
const { host, port } = resolveHttpHostPort();
|
|
197
|
+
const baseConfig = buildHttpTransportBaseConfig(host, port);
|
|
198
|
+
const { HttpTransport } = await import('../transport/http-transport.js');
|
|
199
|
+
const httpTransport = new HttpTransport({
|
|
200
|
+
...baseConfig,
|
|
201
|
+
profileRoutingEnabled: true,
|
|
202
|
+
defaultProfileId: defaultProfile?.profileId,
|
|
203
|
+
}, logger);
|
|
204
|
+
const registry = new ProfileRegistry({
|
|
205
|
+
profilesDir,
|
|
206
|
+
defaultProfile,
|
|
207
|
+
specPathOverride: hasExplicitSpecPath ? specPathOverride : undefined,
|
|
208
|
+
});
|
|
209
|
+
const manager = new MCPServerManager(registry, logger, httpTransport);
|
|
210
|
+
httpTransport.setProfileContextProvider(async (id) => manager.getProfileContext(id));
|
|
211
|
+
httpTransport.setMessageHandler(async (message, sessionId, profileId) => {
|
|
212
|
+
if (!profileId) {
|
|
213
|
+
throw new Error('Profile ID is required for HTTP routing.');
|
|
214
|
+
}
|
|
215
|
+
const server = await manager.getServer(profileId);
|
|
216
|
+
return server.handleHttpMessage(message, sessionId, profileId);
|
|
217
|
+
});
|
|
218
|
+
httpTransport.onSessionDestroyed(async (profileId, sessionId) => {
|
|
219
|
+
try {
|
|
220
|
+
const server = await manager.getServer(profileId);
|
|
221
|
+
server.handleSessionDestroyed(profileId, sessionId);
|
|
222
|
+
}
|
|
223
|
+
catch (error) {
|
|
224
|
+
logger.error('Session cleanup failed', error, { profileId, sessionId });
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
await httpTransport.start();
|
|
228
|
+
logger.info('MCP server running on HTTP', { host, port });
|
|
229
|
+
const shutdown = async (signal) => {
|
|
230
|
+
logger.info(`Received ${signal}, shutting down gracefully...`);
|
|
231
|
+
try {
|
|
232
|
+
await httpTransport.stop();
|
|
233
|
+
logger.info('Server stopped successfully');
|
|
234
|
+
process.exit(0);
|
|
235
|
+
}
|
|
236
|
+
catch (error) {
|
|
237
|
+
logger.error('Error during shutdown', error);
|
|
238
|
+
process.exit(1);
|
|
239
|
+
}
|
|
240
|
+
};
|
|
241
|
+
process.on('SIGTERM', () => shutdown('SIGTERM'));
|
|
242
|
+
process.on('SIGINT', () => shutdown('SIGINT'));
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
const server = new MCPServer(logger);
|
|
246
|
+
await server.initialize(specPath, profilePath);
|
|
247
|
+
if (transport === 'http') {
|
|
248
|
+
const { host, port } = resolveHttpHostPort();
|
|
249
|
+
await server.runHttp(host, port);
|
|
250
|
+
}
|
|
251
|
+
else {
|
|
252
|
+
await server.runStdio();
|
|
253
|
+
}
|
|
254
|
+
// Graceful shutdown handlers
|
|
255
|
+
const shutdown = async (signal) => {
|
|
256
|
+
logger.info(`Received ${signal}, shutting down gracefully...`);
|
|
257
|
+
try {
|
|
258
|
+
await server.stop();
|
|
259
|
+
logger.info('Server stopped successfully');
|
|
260
|
+
process.exit(0);
|
|
261
|
+
}
|
|
262
|
+
catch (error) {
|
|
263
|
+
logger.error('Error during shutdown', error);
|
|
264
|
+
process.exit(1);
|
|
265
|
+
}
|
|
266
|
+
};
|
|
267
|
+
process.on('SIGTERM', () => shutdown('SIGTERM'));
|
|
268
|
+
process.on('SIGINT', () => shutdown('SIGINT'));
|
|
269
|
+
}
|
|
270
|
+
catch (error) {
|
|
271
|
+
logger.error('Fatal error', error);
|
|
272
|
+
process.exit(1);
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/core/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Library exports for programmatic usage
|
|
3
|
+
*/
|
|
4
|
+
export { MCPServer } from '../mcp/mcp-server.js';
|
|
5
|
+
export { HttpTransport } from '../transport/http-transport.js';
|
|
6
|
+
export { ConsoleLogger, JsonLogger } from './logger.js';
|
|
7
|
+
export type { Profile, ToolDefinition, InterceptorConfig } from '../types/profile.js';
|
|
8
|
+
//# sourceMappingURL=lib.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lib.d.ts","sourceRoot":"","sources":["../../../src/core/lib.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACxD,YAAY,EAAE,OAAO,EAAE,cAAc,EAAE,iBAAiB,EAAE,MAAM,qBAAqB,CAAC"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"lib.js","sourceRoot":"","sources":["../../../src/core/lib.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AACjD,OAAO,EAAE,aAAa,EAAE,MAAM,gCAAgC,CAAC;AAC/D,OAAO,EAAE,aAAa,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC"}
|
|
@@ -6,7 +6,12 @@
|
|
|
6
6
|
*
|
|
7
7
|
* Security: Profile-aware token redaction prevents sensitive data leakage.
|
|
8
8
|
*/
|
|
9
|
-
import type { AuthInterceptor } from '
|
|
9
|
+
import type { AuthInterceptor } from '../types/profile.js';
|
|
10
|
+
/**
|
|
11
|
+
* Sanitize log message to prevent log injection
|
|
12
|
+
* Strips ANSI codes and escapes control characters
|
|
13
|
+
*/
|
|
14
|
+
export declare function sanitizeLogMessage(message: string): string;
|
|
10
15
|
export declare enum LogLevel {
|
|
11
16
|
DEBUG = 0,
|
|
12
17
|
INFO = 1,
|
|
@@ -34,12 +39,6 @@ export declare class ConsoleLogger implements Logger {
|
|
|
34
39
|
warn(message: string, context?: Record<string, unknown>): void;
|
|
35
40
|
error(message: string, error?: Error, context?: Record<string, unknown>): void;
|
|
36
41
|
private write;
|
|
37
|
-
/**
|
|
38
|
-
* Redact sensitive data based on auth configuration
|
|
39
|
-
*
|
|
40
|
-
* Why: Prevent token leakage in logs
|
|
41
|
-
*/
|
|
42
|
-
private redactSensitive;
|
|
43
42
|
}
|
|
44
43
|
/**
|
|
45
44
|
* Structured JSON logger for production
|
|
@@ -56,11 +55,5 @@ export declare class JsonLogger implements Logger {
|
|
|
56
55
|
warn(message: string, context?: Record<string, unknown>): void;
|
|
57
56
|
error(message: string, error?: Error, context?: Record<string, unknown>): void;
|
|
58
57
|
private write;
|
|
59
|
-
/**
|
|
60
|
-
* Redact sensitive data based on auth configuration
|
|
61
|
-
*
|
|
62
|
-
* Why: Prevent token leakage in logs (same logic as ConsoleLogger)
|
|
63
|
-
*/
|
|
64
|
-
private redactSensitive;
|
|
65
58
|
}
|
|
66
59
|
//# sourceMappingURL=logger.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.d.ts","sourceRoot":"","sources":["../../../src/core/logger.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AAGH,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AA8C3D;;;GAGG;AACH,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,GAAG,MAAM,CAuB1D;AAwCD,oBAAY,QAAQ;IAClB,KAAK,IAAI;IACT,IAAI,IAAI;IACR,IAAI,IAAI;IACR,KAAK,IAAI;IACT,MAAM,IAAI;CACX;AAED,MAAM,WAAW,MAAM;IACrB,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAChE,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;IAC/D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI,CAAC;CAChF;AAED;;;;GAIG;AACH,qBAAa,aAAc,YAAW,MAAM;IAC1C,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,UAAU,CAAC,CAAkB;gBAEzB,KAAK,CAAC,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,eAAe;IAK1D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAW9E,OAAO,CAAC,KAAK;CAOd;AAED;;;;;GAKG;AACH,qBAAa,UAAW,YAAW,MAAM;IACvC,OAAO,CAAC,KAAK,CAAW;IACxB,OAAO,CAAC,UAAU,CAAC,CAAkB;gBAEzB,KAAK,CAAC,EAAE,QAAQ,EAAE,UAAU,CAAC,EAAE,eAAe;IAK1D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM/D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAM9D,KAAK,CAAC,OAAO,EAAE,MAAM,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,OAAO,CAAC,EAAE,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,GAAG,IAAI;IAU9E,OAAO,CAAC,KAAK;CAUd"}
|
|
@@ -0,0 +1,197 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Logger interfaces and implementations
|
|
3
|
+
*
|
|
4
|
+
* Why: Replaces console.error with structured, level-based logging.
|
|
5
|
+
* Enables production-ready logging with context and proper error handling.
|
|
6
|
+
*
|
|
7
|
+
* Security: Profile-aware token redaction prevents sensitive data leakage.
|
|
8
|
+
*/
|
|
9
|
+
import { stripVTControlCharacters } from 'node:util';
|
|
10
|
+
import { redactHeader, redactQueryParam, redactParam } from '../validation/validation-utils.js';
|
|
11
|
+
const WELL_KNOWN_SECRET_KEYS = new Set([
|
|
12
|
+
'access_token',
|
|
13
|
+
'refresh_token',
|
|
14
|
+
'id_token',
|
|
15
|
+
'client_secret',
|
|
16
|
+
'client_assertion',
|
|
17
|
+
'code',
|
|
18
|
+
'code_verifier',
|
|
19
|
+
]);
|
|
20
|
+
function deepRedactWellKnownSecrets(value, depth = 0, seen) {
|
|
21
|
+
if (depth > 20)
|
|
22
|
+
return value;
|
|
23
|
+
if (value === null || typeof value !== 'object')
|
|
24
|
+
return value;
|
|
25
|
+
if (!seen)
|
|
26
|
+
seen = new WeakSet();
|
|
27
|
+
if (seen.has(value))
|
|
28
|
+
return value;
|
|
29
|
+
seen.add(value);
|
|
30
|
+
if (Array.isArray(value)) {
|
|
31
|
+
return value.map(item => deepRedactWellKnownSecrets(item, depth + 1, seen));
|
|
32
|
+
}
|
|
33
|
+
const record = value;
|
|
34
|
+
const out = {};
|
|
35
|
+
for (const [key, val] of Object.entries(record)) {
|
|
36
|
+
if (WELL_KNOWN_SECRET_KEYS.has(key)) {
|
|
37
|
+
out[key] = '[REDACTED]';
|
|
38
|
+
continue;
|
|
39
|
+
}
|
|
40
|
+
out[key] = deepRedactWellKnownSecrets(val, depth + 1, seen);
|
|
41
|
+
}
|
|
42
|
+
return out;
|
|
43
|
+
}
|
|
44
|
+
function resolveLogLevel(explicitLevel) {
|
|
45
|
+
if (explicitLevel !== undefined)
|
|
46
|
+
return explicitLevel;
|
|
47
|
+
const envLevel = process.env.MCP4_LOG_LEVEL?.toUpperCase();
|
|
48
|
+
return envLevel && envLevel in LogLevel
|
|
49
|
+
? LogLevel[envLevel]
|
|
50
|
+
: LogLevel.INFO;
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Sanitize log message to prevent log injection
|
|
54
|
+
* Strips ANSI codes and escapes control characters
|
|
55
|
+
*/
|
|
56
|
+
export function sanitizeLogMessage(message) {
|
|
57
|
+
// 1. Strip ANSI escape codes
|
|
58
|
+
let safe = stripVTControlCharacters(message);
|
|
59
|
+
// 2. Escape control characters (0x00-0x1F, 0x7F)
|
|
60
|
+
// We use a replacement function to handle various control characters
|
|
61
|
+
safe = safe.replace(/[\x00-\x1F\x7F]/g, (char) => {
|
|
62
|
+
switch (char) {
|
|
63
|
+
case '\n': return '\\n';
|
|
64
|
+
case '\r': return '\\r';
|
|
65
|
+
case '\t': return '\\t';
|
|
66
|
+
case '\b': return '\\b';
|
|
67
|
+
case '\f': return '\\f';
|
|
68
|
+
case '\v': return '\\v';
|
|
69
|
+
case '\0': return '\\0';
|
|
70
|
+
default:
|
|
71
|
+
// Hex escape for other control chars (e.g. \x07)
|
|
72
|
+
const hex = char.charCodeAt(0).toString(16).padStart(2, '0');
|
|
73
|
+
return `\\x${hex}`;
|
|
74
|
+
}
|
|
75
|
+
});
|
|
76
|
+
return safe;
|
|
77
|
+
}
|
|
78
|
+
function redactSensitiveContext(data, authConfig) {
|
|
79
|
+
const redacted = deepRedactWellKnownSecrets(data);
|
|
80
|
+
if (!authConfig)
|
|
81
|
+
return redacted;
|
|
82
|
+
switch (authConfig.type) {
|
|
83
|
+
case 'bearer':
|
|
84
|
+
redacted.headers = redactHeader(redacted.headers, 'authorization');
|
|
85
|
+
break;
|
|
86
|
+
case 'custom-header':
|
|
87
|
+
if (authConfig.header_name) {
|
|
88
|
+
redacted.headers = redactHeader(redacted.headers, authConfig.header_name.toLowerCase());
|
|
89
|
+
}
|
|
90
|
+
break;
|
|
91
|
+
case 'query':
|
|
92
|
+
if (authConfig.query_param) {
|
|
93
|
+
redacted.url = redactQueryParam(redacted.url, authConfig.query_param);
|
|
94
|
+
redacted.params = redactParam(redacted.params, authConfig.query_param);
|
|
95
|
+
}
|
|
96
|
+
break;
|
|
97
|
+
}
|
|
98
|
+
return redacted;
|
|
99
|
+
}
|
|
100
|
+
export var LogLevel;
|
|
101
|
+
(function (LogLevel) {
|
|
102
|
+
LogLevel[LogLevel["DEBUG"] = 0] = "DEBUG";
|
|
103
|
+
LogLevel[LogLevel["INFO"] = 1] = "INFO";
|
|
104
|
+
LogLevel[LogLevel["WARN"] = 2] = "WARN";
|
|
105
|
+
LogLevel[LogLevel["ERROR"] = 3] = "ERROR";
|
|
106
|
+
LogLevel[LogLevel["SILENT"] = 4] = "SILENT";
|
|
107
|
+
})(LogLevel || (LogLevel = {}));
|
|
108
|
+
/**
|
|
109
|
+
* Default logger - writes to stderr, respects MCP4_LOG_LEVEL env var
|
|
110
|
+
*
|
|
111
|
+
* Security: Redacts auth tokens based on profile configuration
|
|
112
|
+
*/
|
|
113
|
+
export class ConsoleLogger {
|
|
114
|
+
constructor(level, authConfig) {
|
|
115
|
+
this.level = resolveLogLevel(level);
|
|
116
|
+
this.authConfig = authConfig;
|
|
117
|
+
}
|
|
118
|
+
debug(message, context) {
|
|
119
|
+
if (this.level <= LogLevel.DEBUG) {
|
|
120
|
+
this.write('DEBUG', message, context);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
info(message, context) {
|
|
124
|
+
if (this.level <= LogLevel.INFO) {
|
|
125
|
+
this.write('INFO', message, context);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
warn(message, context) {
|
|
129
|
+
if (this.level <= LogLevel.WARN) {
|
|
130
|
+
this.write('WARN', message, context);
|
|
131
|
+
}
|
|
132
|
+
}
|
|
133
|
+
error(message, error, context) {
|
|
134
|
+
if (this.level <= LogLevel.ERROR) {
|
|
135
|
+
const errorContext = error ? {
|
|
136
|
+
error: error.message,
|
|
137
|
+
stack: error.stack,
|
|
138
|
+
...context,
|
|
139
|
+
} : context;
|
|
140
|
+
this.write('ERROR', message, errorContext);
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
write(level, message, context) {
|
|
144
|
+
const timestamp = new Date().toISOString();
|
|
145
|
+
const redacted = context ? redactSensitiveContext(context, this.authConfig) : undefined;
|
|
146
|
+
const ctx = redacted ? ` ${JSON.stringify(redacted)}` : '';
|
|
147
|
+
const safeMessage = sanitizeLogMessage(message);
|
|
148
|
+
console.error(`[${timestamp}] ${level}: ${safeMessage}${ctx}`);
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
/**
|
|
152
|
+
* Structured JSON logger for production
|
|
153
|
+
*
|
|
154
|
+
* Why: Machine-readable logs for log aggregation systems (ELK, Splunk, etc.)
|
|
155
|
+
* Security: Redacts auth tokens based on profile configuration
|
|
156
|
+
*/
|
|
157
|
+
export class JsonLogger {
|
|
158
|
+
constructor(level, authConfig) {
|
|
159
|
+
this.level = resolveLogLevel(level);
|
|
160
|
+
this.authConfig = authConfig;
|
|
161
|
+
}
|
|
162
|
+
debug(message, context) {
|
|
163
|
+
if (this.level <= LogLevel.DEBUG) {
|
|
164
|
+
this.write('debug', message, context);
|
|
165
|
+
}
|
|
166
|
+
}
|
|
167
|
+
info(message, context) {
|
|
168
|
+
if (this.level <= LogLevel.INFO) {
|
|
169
|
+
this.write('info', message, context);
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
warn(message, context) {
|
|
173
|
+
if (this.level <= LogLevel.WARN) {
|
|
174
|
+
this.write('warn', message, context);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
error(message, error, context) {
|
|
178
|
+
if (this.level <= LogLevel.ERROR) {
|
|
179
|
+
this.write('error', message, {
|
|
180
|
+
error: error?.message,
|
|
181
|
+
stack: error?.stack,
|
|
182
|
+
...context,
|
|
183
|
+
});
|
|
184
|
+
}
|
|
185
|
+
}
|
|
186
|
+
write(level, message, context) {
|
|
187
|
+
const redacted = context ? redactSensitiveContext(context, this.authConfig) : undefined;
|
|
188
|
+
const log = {
|
|
189
|
+
timestamp: new Date().toISOString(),
|
|
190
|
+
level,
|
|
191
|
+
message,
|
|
192
|
+
...redacted,
|
|
193
|
+
};
|
|
194
|
+
console.error(JSON.stringify(log));
|
|
195
|
+
}
|
|
196
|
+
}
|
|
197
|
+
//# sourceMappingURL=logger.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"logger.js","sourceRoot":"","sources":["../../../src/core/logger.ts"],"names":[],"mappings":"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"}
|
|
@@ -25,6 +25,11 @@ export declare class MetricsCollector {
|
|
|
25
25
|
private mcpToolCallsTotal;
|
|
26
26
|
private mcpToolCallDuration;
|
|
27
27
|
private mcpToolCallErrors;
|
|
28
|
+
private toolsTotal;
|
|
29
|
+
private toolsFiltered;
|
|
30
|
+
private toolsSession;
|
|
31
|
+
private toolFilterRejections;
|
|
32
|
+
private toolFilterPatterns;
|
|
28
33
|
private apiCallsTotal;
|
|
29
34
|
private apiCallDuration;
|
|
30
35
|
private apiCallErrors;
|
|
@@ -49,6 +54,12 @@ export declare class MetricsCollector {
|
|
|
49
54
|
* Record MCP tool call error
|
|
50
55
|
*/
|
|
51
56
|
recordToolCallError(tool: string, errorType: string): void;
|
|
57
|
+
recordToolsTotal(source: string, count: number): void;
|
|
58
|
+
recordToolsFiltered(source: string, action: string, count: number): void;
|
|
59
|
+
recordToolsSession(sessionId: string, count: number): void;
|
|
60
|
+
clearToolsSession(sessionId: string): void;
|
|
61
|
+
recordToolFilterRejection(tool: string, source: string): void;
|
|
62
|
+
recordToolFilterPatternCount(type: string, count: number): void;
|
|
52
63
|
/**
|
|
53
64
|
* Record API call to backend
|
|
54
65
|
*/
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"metrics.d.ts","sourceRoot":"","sources":["../../../src/core/metrics.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;GAUG;AAEH,OAAO,EAAE,QAAQ,EAA6B,MAAM,aAAa,CAAC;AAElE,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,OAAO,CAAC;IACjB,MAAM,CAAC,EAAE,MAAM,CAAC;CACjB;AAED,qBAAa,gBAAgB;IAC3B,OAAO,CAAC,QAAQ,CAAW;IAC3B,OAAO,CAAC,OAAO,CAAU;IAGzB,OAAO,CAAC,iBAAiB,CAAU;IACnC,OAAO,CAAC,mBAAmB,CAAY;IAGvC,OAAO,CAAC,cAAc,CAAQ;IAC9B,OAAO,CAAC,oBAAoB,CAAU;IACtC,OAAO,CAAC,sBAAsB,CAAU;IAGxC,OAAO,CAAC,iBAAiB,CAAU;IACnC,OAAO,CAAC,mBAAmB,CAAY;IACvC,OAAO,CAAC,iBAAiB,CAAU;IAGnC,OAAO,CAAC,UAAU,CAAQ;IAC1B,OAAO,CAAC,aAAa,CAAQ;IAC7B,OAAO,CAAC,YAAY,CAAQ;IAC5B,OAAO,CAAC,oBAAoB,CAAU;IACtC,OAAO,CAAC,kBAAkB,CAAQ;IAGlC,OAAO,CAAC,aAAa,CAAU;IAC/B,OAAO,CAAC,eAAe,CAAY;IACnC,OAAO,CAAC,aAAa,CAAU;gBAEnB,MAAM,EAAE,sBAAsB;IA4H1C;;OAEG;IACH,iBAAiB,CAAC,MAAM,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,IAAI;IAmB9F;;OAEG;IACH,oBAAoB,IAAI,IAAI;IAM5B;;OAEG;IACH,sBAAsB,IAAI,IAAI;IAM9B;;OAEG;IACH,cAAc,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,SAAS,GAAG,OAAO,EAAE,eAAe,EAAE,MAAM,GAAG,IAAI;IAOxF;;OAEG;IACH,mBAAmB,CAAC,IAAI,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAK1D,gBAAgB,CAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAKrD,mBAAmB,CAAC,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAKxE,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAK1D,iBAAiB,CAAC,SAAS,EAAE,MAAM,GAAG,IAAI;IAK1C,yBAAyB,CAAC,IAAI,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAG,IAAI;IAK7D,4BAA4B,CAAC,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,GAAG,IAAI;IAK/D;;OAEG;IACH,aAAa,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,eAAe,EAAE,MAAM,GAAG,IAAI;IAS/E;;OAEG;IACH,kBAAkB,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,MAAM,GAAG,IAAI;IAK9D;;OAEG;IACG,UAAU,IAAI,OAAO,CAAC,MAAM,CAAC;IAOnC;;OAEG;IACH,WAAW,IAAI,QAAQ;IAIvB;;;;;;;;;OASG;IACH,OAAO,CAAC,aAAa;IAcrB;;;;OAIG;IACH,OAAO,CAAC,cAAc;CAOvB"}
|