@mcp-z/cli 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 (126) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +166 -0
  3. package/bin/cli.js +5 -0
  4. package/dist/cjs/cli.d.cts +1 -0
  5. package/dist/cjs/cli.d.ts +1 -0
  6. package/dist/cjs/cli.js +576 -0
  7. package/dist/cjs/cli.js.map +1 -0
  8. package/dist/cjs/commands/call-tool.d.cts +26 -0
  9. package/dist/cjs/commands/call-tool.d.ts +26 -0
  10. package/dist/cjs/commands/call-tool.js +362 -0
  11. package/dist/cjs/commands/call-tool.js.map +1 -0
  12. package/dist/cjs/commands/get-prompt.d.cts +26 -0
  13. package/dist/cjs/commands/get-prompt.d.ts +26 -0
  14. package/dist/cjs/commands/get-prompt.js +335 -0
  15. package/dist/cjs/commands/get-prompt.js.map +1 -0
  16. package/dist/cjs/commands/inspect.d.cts +35 -0
  17. package/dist/cjs/commands/inspect.d.ts +35 -0
  18. package/dist/cjs/commands/inspect.js +896 -0
  19. package/dist/cjs/commands/inspect.js.map +1 -0
  20. package/dist/cjs/commands/manifest/env-prompting.d.cts +21 -0
  21. package/dist/cjs/commands/manifest/env-prompting.d.ts +21 -0
  22. package/dist/cjs/commands/manifest/env-prompting.js +657 -0
  23. package/dist/cjs/commands/manifest/env-prompting.js.map +1 -0
  24. package/dist/cjs/commands/manifest/generate.d.cts +124 -0
  25. package/dist/cjs/commands/manifest/generate.d.ts +124 -0
  26. package/dist/cjs/commands/manifest/generate.js +2541 -0
  27. package/dist/cjs/commands/manifest/generate.js.map +1 -0
  28. package/dist/cjs/commands/manifest/index.d.cts +2 -0
  29. package/dist/cjs/commands/manifest/index.d.ts +2 -0
  30. package/dist/cjs/commands/manifest/index.js +229 -0
  31. package/dist/cjs/commands/manifest/index.js.map +1 -0
  32. package/dist/cjs/commands/manifest/metadata-reader.d.cts +71 -0
  33. package/dist/cjs/commands/manifest/metadata-reader.d.ts +71 -0
  34. package/dist/cjs/commands/manifest/metadata-reader.js +441 -0
  35. package/dist/cjs/commands/manifest/metadata-reader.js.map +1 -0
  36. package/dist/cjs/commands/manifest/validate.d.cts +1 -0
  37. package/dist/cjs/commands/manifest/validate.d.ts +1 -0
  38. package/dist/cjs/commands/manifest/validate.js +525 -0
  39. package/dist/cjs/commands/manifest/validate.js.map +1 -0
  40. package/dist/cjs/commands/read-resource.d.cts +24 -0
  41. package/dist/cjs/commands/read-resource.d.ts +24 -0
  42. package/dist/cjs/commands/read-resource.js +311 -0
  43. package/dist/cjs/commands/read-resource.js.map +1 -0
  44. package/dist/cjs/commands/search.d.cts +31 -0
  45. package/dist/cjs/commands/search.d.ts +31 -0
  46. package/dist/cjs/commands/search.js +464 -0
  47. package/dist/cjs/commands/search.js.map +1 -0
  48. package/dist/cjs/commands/up.d.cts +49 -0
  49. package/dist/cjs/commands/up.d.ts +49 -0
  50. package/dist/cjs/commands/up.js +235 -0
  51. package/dist/cjs/commands/up.js.map +1 -0
  52. package/dist/cjs/index.d.cts +7 -0
  53. package/dist/cjs/index.d.ts +7 -0
  54. package/dist/cjs/index.js +85 -0
  55. package/dist/cjs/index.js.map +1 -0
  56. package/dist/cjs/lib/find-config.d.cts +14 -0
  57. package/dist/cjs/lib/find-config.d.ts +14 -0
  58. package/dist/cjs/lib/find-config.js +93 -0
  59. package/dist/cjs/lib/find-config.js.map +1 -0
  60. package/dist/cjs/lib/json-schema.d.cts +18 -0
  61. package/dist/cjs/lib/json-schema.d.ts +18 -0
  62. package/dist/cjs/lib/json-schema.js +306 -0
  63. package/dist/cjs/lib/json-schema.js.map +1 -0
  64. package/dist/cjs/lib/resolve-server-config.d.cts +50 -0
  65. package/dist/cjs/lib/resolve-server-config.d.ts +50 -0
  66. package/dist/cjs/lib/resolve-server-config.js +214 -0
  67. package/dist/cjs/lib/resolve-server-config.js.map +1 -0
  68. package/dist/cjs/package.json +1 -0
  69. package/dist/cjs/types.d.cts +21 -0
  70. package/dist/cjs/types.d.ts +21 -0
  71. package/dist/cjs/types.js +32 -0
  72. package/dist/cjs/types.js.map +1 -0
  73. package/dist/esm/cli.d.ts +1 -0
  74. package/dist/esm/cli.js +129 -0
  75. package/dist/esm/cli.js.map +1 -0
  76. package/dist/esm/commands/call-tool.d.ts +26 -0
  77. package/dist/esm/commands/call-tool.js +151 -0
  78. package/dist/esm/commands/call-tool.js.map +1 -0
  79. package/dist/esm/commands/get-prompt.d.ts +26 -0
  80. package/dist/esm/commands/get-prompt.js +118 -0
  81. package/dist/esm/commands/get-prompt.js.map +1 -0
  82. package/dist/esm/commands/inspect.d.ts +35 -0
  83. package/dist/esm/commands/inspect.js +438 -0
  84. package/dist/esm/commands/inspect.js.map +1 -0
  85. package/dist/esm/commands/manifest/env-prompting.d.ts +21 -0
  86. package/dist/esm/commands/manifest/env-prompting.js +213 -0
  87. package/dist/esm/commands/manifest/env-prompting.js.map +1 -0
  88. package/dist/esm/commands/manifest/generate.d.ts +124 -0
  89. package/dist/esm/commands/manifest/generate.js +1087 -0
  90. package/dist/esm/commands/manifest/generate.js.map +1 -0
  91. package/dist/esm/commands/manifest/index.d.ts +2 -0
  92. package/dist/esm/commands/manifest/index.js +23 -0
  93. package/dist/esm/commands/manifest/index.js.map +1 -0
  94. package/dist/esm/commands/manifest/metadata-reader.d.ts +71 -0
  95. package/dist/esm/commands/manifest/metadata-reader.js +143 -0
  96. package/dist/esm/commands/manifest/metadata-reader.js.map +1 -0
  97. package/dist/esm/commands/manifest/validate.d.ts +1 -0
  98. package/dist/esm/commands/manifest/validate.js +167 -0
  99. package/dist/esm/commands/manifest/validate.js.map +1 -0
  100. package/dist/esm/commands/read-resource.d.ts +24 -0
  101. package/dist/esm/commands/read-resource.js +95 -0
  102. package/dist/esm/commands/read-resource.js.map +1 -0
  103. package/dist/esm/commands/search.d.ts +31 -0
  104. package/dist/esm/commands/search.js +145 -0
  105. package/dist/esm/commands/search.js.map +1 -0
  106. package/dist/esm/commands/up.d.ts +49 -0
  107. package/dist/esm/commands/up.js +74 -0
  108. package/dist/esm/commands/up.js.map +1 -0
  109. package/dist/esm/index.d.ts +7 -0
  110. package/dist/esm/index.js +11 -0
  111. package/dist/esm/index.js.map +1 -0
  112. package/dist/esm/lib/find-config.d.ts +14 -0
  113. package/dist/esm/lib/find-config.js +42 -0
  114. package/dist/esm/lib/find-config.js.map +1 -0
  115. package/dist/esm/lib/json-schema.d.ts +18 -0
  116. package/dist/esm/lib/json-schema.js +66 -0
  117. package/dist/esm/lib/json-schema.js.map +1 -0
  118. package/dist/esm/lib/resolve-server-config.d.ts +50 -0
  119. package/dist/esm/lib/resolve-server-config.js +154 -0
  120. package/dist/esm/lib/resolve-server-config.js.map +1 -0
  121. package/dist/esm/package.json +1 -0
  122. package/dist/esm/types.d.ts +21 -0
  123. package/dist/esm/types.js +11 -0
  124. package/dist/esm/types.js.map +1 -0
  125. package/package.json +99 -0
  126. package/schemas/server.schema.json +489 -0
@@ -0,0 +1 @@
1
+ {"version":3,"sources":["/Users/kevin/Dev/Projects/ai/mcp-z/cli/src/commands/manifest/env-prompting.ts"],"sourcesContent":["import confirm from '@inquirer/confirm';\nimport input from '@inquirer/input';\nimport password from '@inquirer/password';\nimport select from '@inquirer/select';\nimport type { EnvVarMetadata } from './metadata-reader.ts';\n\n/**\n * Redact sensitive values for display, showing only first 4 characters\n * Example: \"sk-1234567890abcdef\" -> \"sk-1XXX\"\n */\nfunction redactValue(value: string, isSecret: boolean): string {\n if (!isSecret) {\n return value;\n }\n\n if (value.length <= 6) {\n return 'XXX';\n }\n\n return `${value.substring(0, 4)}XXX`;\n}\n\n/**\n * Substitute template variables in a string\n * Replaces any {VARIABLE_NAME} with the corresponding value from the variables map\n * Variable names are case-insensitive\n */\nexport function substituteTemplateVars(template: string | undefined, variables?: Record<string, string>): string | undefined {\n if (!template || !variables) {\n return template;\n }\n\n // Replace any {VARIABLE_NAME} with corresponding value from variables map\n return template.replace(/\\{([^}]+)\\}/g, (match, varName) => {\n // Case-insensitive lookup\n const key = Object.keys(variables).find((k) => k.toLowerCase() === varName.toLowerCase());\n return key ? variables[key] : match;\n });\n}\n\n/**\n * Get dynamic placeholder for env vars by substituting template variables\n */\nfunction getDynamicPlaceholder(envVar: EnvVarMetadata, variables?: Record<string, string>): string | undefined {\n return substituteTemplateVars(envVar.placeholder, variables);\n}\n\n/**\n * Prompt user for environment variables with support for:\n * - Environment variable detection with partial redaction\n * - Interactive prompts for required fields\n * - Choice-based selection\n * - Password input for secrets\n * - Default values\n * - Non-interactive mode (-y flag)\n * - Dynamic placeholders via template variable substitution\n */\nexport async function promptForEnvVars(serverName: string, envVars: EnvVarMetadata[], options: { yes?: boolean; templateVars?: Record<string, string> } = {}): Promise<Record<string, string>> {\n const env: Record<string, string> = {};\n\n for (const envVar of envVars) {\n const envValue = process.env[envVar.name];\n // Support both 'default' (MCP schema standard) and 'value' (legacy) fields\n const defaultValue = envVar.default ?? envVar.value;\n\n if (defaultValue) {\n // Use default value from metadata if available\n env[envVar.name] = defaultValue;\n } else if (envValue && !options.yes && process.stdin.isTTY) {\n // Environment variable exists - present option with partial redaction\n const redactedValue = redactValue(envValue, envVar.isSecret);\n const useEnvChoice = `${redactedValue} (environment)`;\n\n if (envVar.choices && envVar.choices.length > 0) {\n // Has choices - add environment value as an option\n const choices = [useEnvChoice, ...envVar.choices, 'Enter custom value'];\n\n // Add skip option for optional fields\n if (!envVar.isRequired) {\n choices.push('Skip (optional)');\n }\n\n const message = `[${serverName}] ${envVar.name}`;\n\n const value = await select({\n message,\n choices,\n });\n\n if (value === useEnvChoice) {\n env[envVar.name] = envValue;\n } else if (value === 'Skip (optional)') {\n // Skip this optional env var - don't add to env object\n } else if (value === 'Enter custom value') {\n const promptFn = envVar.isSecret ? password : input;\n const customValue = await promptFn({\n message: `[${serverName}] ${envVar.name} (enter value)`,\n validate: (input: string) => {\n if (envVar.isRequired && (!input || input.trim() === '')) {\n return 'This field is required';\n }\n return true;\n },\n });\n env[envVar.name] = customValue as string;\n } else {\n env[envVar.name] = value as string;\n }\n } else {\n // No choices - simple confirmation or new value\n const actionChoices = [\n { name: `Use ${useEnvChoice}`, value: 'use-env' },\n { name: 'Enter new value', value: 'enter-new' },\n ];\n\n // Add skip option for optional fields\n if (!envVar.isRequired) {\n actionChoices.push({ name: 'Skip (optional)', value: 'skip' });\n }\n\n const message = `[${serverName}] ${envVar.name}`;\n\n const action = await select({\n message,\n choices: actionChoices,\n });\n\n if (action === 'use-env') {\n env[envVar.name] = envValue;\n } else if (action === 'skip') {\n // Skip this optional env var - don't add to env object\n } else {\n const promptFn = envVar.isSecret ? password : input;\n const newValue = await promptFn({\n message: `[${serverName}] ${envVar.name} (enter value)`,\n validate: (input: string) => {\n if (envVar.isRequired && (!input || input.trim() === '')) {\n return 'This field is required';\n }\n return true;\n },\n });\n env[envVar.name] = newValue as string;\n }\n }\n } else if (options.yes) {\n // -y mode: skip required vars without defaults (trust shell environment)\n if (envVar.choices && envVar.choices.length > 0 && envVar.choices[0]) {\n // Has choices - use first choice\n env[envVar.name] = envVar.choices[0];\n } else if (envVar.isRequired) {\n // Required but no default - skip with warning\n console.log(` ⚠️ Skipping ${envVar.name}`);\n }\n // Optional vars without defaults: skip silently\n } else if (envVar.choices && envVar.choices.length > 0 && envVar.choices[0]) {\n if (process.stdin.isTTY) {\n // Interactive mode with choices - prompt user to select\n const choices = [...envVar.choices];\n\n // Add skip option for optional fields\n if (!envVar.isRequired) {\n choices.push('Skip (optional)');\n }\n\n const value = await select({\n message: `[${serverName}] ${envVar.name}`,\n choices,\n });\n\n if (value !== 'Skip (optional)') {\n env[envVar.name] = value as string;\n }\n // If 'Skip (optional)' selected, don't add to env object\n } else {\n // Non-interactive: use first choice\n env[envVar.name] = envVar.choices[0];\n }\n } else if (envVar.isRequired) {\n if (process.stdin.isTTY) {\n // Interactive mode - required field - prompt for value\n const promptFn = envVar.isSecret ? password : input;\n const placeholder = getDynamicPlaceholder(envVar, options.templateVars);\n const value = await promptFn({\n message: `[${serverName}] ${envVar.name} (required)`,\n ...(placeholder ? { default: placeholder } : {}),\n validate: (input: string) => {\n if (!input || input.trim() === '') {\n return 'This field is required';\n }\n return true;\n },\n });\n env[envVar.name] = value as string;\n }\n // Non-interactive without -y: skip (will fail at runtime if truly required)\n } else if (!envVar.isRequired && !options.yes && process.stdin.isTTY) {\n // Interactive mode - optional env var without defaults\n // Ask user if they want to set it\n const shouldSet = await confirm({\n message: `[${serverName}] Set optional ${envVar.name}? (${envVar.description || 'optional'})`,\n default: false,\n });\n\n if (shouldSet) {\n const promptFn = envVar.isSecret ? password : input;\n const placeholder = getDynamicPlaceholder(envVar, options.templateVars);\n const value = await promptFn({\n message: `[${serverName}] ${envVar.name}`,\n ...(placeholder ? { default: placeholder } : {}),\n });\n\n if (value && (value as string).trim() !== '') {\n env[envVar.name] = value as string;\n }\n }\n }\n // Other optional env vars are skipped\n }\n\n return env;\n}\n"],"names":["promptForEnvVars","substituteTemplateVars","redactValue","value","isSecret","length","substring","template","variables","replace","match","varName","key","Object","keys","find","k","toLowerCase","getDynamicPlaceholder","envVar","placeholder","serverName","envVars","options","env","envValue","defaultValue","redactedValue","useEnvChoice","choices","message","promptFn","customValue","actionChoices","action","newValue","shouldSet","process","name","default","yes","stdin","isTTY","isRequired","push","select","password","input","validate","trim","console","log","templateVars","confirm","description"],"mappings":"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"}
@@ -0,0 +1,124 @@
1
+ import type { MCPConfiguration } from '../../types.js';
2
+ import { promptForEnvVars } from './env-prompting.js';
3
+ import { MetadataReader, type ServerMetadata } from './metadata-reader.js';
4
+ export type ConfigurationMode = 'env' | 'args' | 'both' | 'none';
5
+ export interface Dimension {
6
+ name: string;
7
+ type: 'env' | 'arg';
8
+ choices: string[];
9
+ }
10
+ export interface Combination {
11
+ name: string;
12
+ envKeys: string[];
13
+ argNames: string[];
14
+ defaults: Record<string, string>;
15
+ argDefaults: Record<string, string>;
16
+ dimensionValues: Record<string, string>;
17
+ }
18
+ export interface ConfigChoice {
19
+ combination: Combination;
20
+ transport: 'stdio' | 'streamable-http';
21
+ label: string;
22
+ }
23
+ /** Maps user-facing transport names to internal types */
24
+ export declare const TRANSPORT_MAP: Record<string, 'stdio' | 'streamable-http'>;
25
+ /**
26
+ * Build config choices from combinations and transports.
27
+ * Used for both "select all" and "select specific" flows.
28
+ * @param combinations - Array of config combinations
29
+ * @param transports - Array of transport names ('stdio', 'http', or 'streamable-http')
30
+ * @returns Array of ConfigChoice objects
31
+ */
32
+ export declare function createConfigChoices(combinations: Combination[], transports: string[]): ConfigChoice[];
33
+ /**
34
+ * Filter config choices by selected labels.
35
+ * @param allChoices - All available config choices
36
+ * @param selectedLabels - Labels of configs to include
37
+ * @returns Filtered array of ConfigChoice objects
38
+ */
39
+ export declare function filterConfigChoices(allChoices: ConfigChoice[], selectedLabels: string[]): ConfigChoice[];
40
+ /**
41
+ * Generate combinations from env vars with choices (simple cartesian product).
42
+ * All combinations are generated - user can filter via selection pass.
43
+ */
44
+ export declare function generateMatrixCombinations(envVars: Array<{
45
+ name: string;
46
+ choices: string[];
47
+ }>): Combination[];
48
+ /**
49
+ * Generate combinations respecting dependsOn relationships.
50
+ * Conditional dimensions are only included when their dependencies are satisfied.
51
+ * Example: DCR_MODE only generates variations when AUTH_MODE=dcr
52
+ */
53
+ export declare function generateConditionalCombinations(envVars: Array<{
54
+ name: string;
55
+ choices: string[];
56
+ dependsOn?: Record<string, string[]>;
57
+ }>): Combination[];
58
+ /**
59
+ * Check if an environment variable should be prompted based on dependsOn conditions.
60
+ * Returns true if the envVar has no dependencies, or if all dependencies are satisfied.
61
+ *
62
+ * @param envVar - Environment variable metadata with optional dependsOn field
63
+ * @param selectedValues - Currently selected dimension values (e.g., { AUTH_MODE: 'loopback-oauth' })
64
+ * @returns true if the env var should be prompted, false if it should be skipped
65
+ */
66
+ export declare function shouldPromptEnvVar(envVar: {
67
+ dependsOn?: Record<string, string[]>;
68
+ }, selectedValues: Record<string, string>): boolean;
69
+ /**
70
+ * Generate server configuration interactively.
71
+ * Discovers server.json in current directory, prompts for configuration,
72
+ * and generates config files for selected combinations and transports.
73
+ *
74
+ * @param options - Command options
75
+ * @param options.source - Use source code paths (node instead of npx)
76
+ * @param options.json - Output to stdout instead of writing files
77
+ * @param options.matrix - Non-interactive mode: generate all matrix combinations
78
+ * @param options.output - Output directory (default: examples for --matrix, . otherwise)
79
+ * @param options.quick - Skip all optional env var prompts, use defaults
80
+ */
81
+ export declare function generateCommand(options?: {
82
+ source?: boolean;
83
+ json?: boolean;
84
+ matrix?: boolean;
85
+ output?: string;
86
+ quick?: boolean;
87
+ }): Promise<void>;
88
+ /** Exported for testing */
89
+ export declare function discoverServerJson(basePath?: string): string | null;
90
+ /** Exported for testing */
91
+ export declare function extractServerName(packageName: string): string;
92
+ /** Generate config object (for JSON output or testing) - Exported for testing */
93
+ export declare function generateConfigObject(params: {
94
+ serverName: string;
95
+ combination: Combination;
96
+ transport: string;
97
+ packageName: string;
98
+ packageDir?: string;
99
+ binPath?: string;
100
+ metadata: ServerMetadata;
101
+ metadataReader: Pick<MetadataReader, 'getPackageForTransport'>;
102
+ httpHost?: string;
103
+ httpPort?: number;
104
+ useSource?: boolean;
105
+ quick?: boolean;
106
+ optionalVarsToPrompt?: Set<string>;
107
+ }, envPromptFn?: typeof promptForEnvVars): Promise<MCPConfiguration>;
108
+ /** Generate config file - Exported for testing */
109
+ export declare function generateConfigFile(params: {
110
+ serverName: string;
111
+ combination: Combination;
112
+ transport: string;
113
+ outputDir: string;
114
+ packageName: string;
115
+ packageDir?: string;
116
+ binPath?: string;
117
+ metadata: ServerMetadata;
118
+ metadataReader: Pick<MetadataReader, 'getPackageForTransport'>;
119
+ httpHost?: string;
120
+ httpPort?: number;
121
+ useSource?: boolean;
122
+ quick?: boolean;
123
+ optionalVarsToPrompt?: Set<string>;
124
+ }, envPromptFn?: typeof promptForEnvVars): Promise<boolean>;
@@ -0,0 +1,124 @@
1
+ import type { MCPConfiguration } from '../../types.js';
2
+ import { promptForEnvVars } from './env-prompting.js';
3
+ import { MetadataReader, type ServerMetadata } from './metadata-reader.js';
4
+ export type ConfigurationMode = 'env' | 'args' | 'both' | 'none';
5
+ export interface Dimension {
6
+ name: string;
7
+ type: 'env' | 'arg';
8
+ choices: string[];
9
+ }
10
+ export interface Combination {
11
+ name: string;
12
+ envKeys: string[];
13
+ argNames: string[];
14
+ defaults: Record<string, string>;
15
+ argDefaults: Record<string, string>;
16
+ dimensionValues: Record<string, string>;
17
+ }
18
+ export interface ConfigChoice {
19
+ combination: Combination;
20
+ transport: 'stdio' | 'streamable-http';
21
+ label: string;
22
+ }
23
+ /** Maps user-facing transport names to internal types */
24
+ export declare const TRANSPORT_MAP: Record<string, 'stdio' | 'streamable-http'>;
25
+ /**
26
+ * Build config choices from combinations and transports.
27
+ * Used for both "select all" and "select specific" flows.
28
+ * @param combinations - Array of config combinations
29
+ * @param transports - Array of transport names ('stdio', 'http', or 'streamable-http')
30
+ * @returns Array of ConfigChoice objects
31
+ */
32
+ export declare function createConfigChoices(combinations: Combination[], transports: string[]): ConfigChoice[];
33
+ /**
34
+ * Filter config choices by selected labels.
35
+ * @param allChoices - All available config choices
36
+ * @param selectedLabels - Labels of configs to include
37
+ * @returns Filtered array of ConfigChoice objects
38
+ */
39
+ export declare function filterConfigChoices(allChoices: ConfigChoice[], selectedLabels: string[]): ConfigChoice[];
40
+ /**
41
+ * Generate combinations from env vars with choices (simple cartesian product).
42
+ * All combinations are generated - user can filter via selection pass.
43
+ */
44
+ export declare function generateMatrixCombinations(envVars: Array<{
45
+ name: string;
46
+ choices: string[];
47
+ }>): Combination[];
48
+ /**
49
+ * Generate combinations respecting dependsOn relationships.
50
+ * Conditional dimensions are only included when their dependencies are satisfied.
51
+ * Example: DCR_MODE only generates variations when AUTH_MODE=dcr
52
+ */
53
+ export declare function generateConditionalCombinations(envVars: Array<{
54
+ name: string;
55
+ choices: string[];
56
+ dependsOn?: Record<string, string[]>;
57
+ }>): Combination[];
58
+ /**
59
+ * Check if an environment variable should be prompted based on dependsOn conditions.
60
+ * Returns true if the envVar has no dependencies, or if all dependencies are satisfied.
61
+ *
62
+ * @param envVar - Environment variable metadata with optional dependsOn field
63
+ * @param selectedValues - Currently selected dimension values (e.g., { AUTH_MODE: 'loopback-oauth' })
64
+ * @returns true if the env var should be prompted, false if it should be skipped
65
+ */
66
+ export declare function shouldPromptEnvVar(envVar: {
67
+ dependsOn?: Record<string, string[]>;
68
+ }, selectedValues: Record<string, string>): boolean;
69
+ /**
70
+ * Generate server configuration interactively.
71
+ * Discovers server.json in current directory, prompts for configuration,
72
+ * and generates config files for selected combinations and transports.
73
+ *
74
+ * @param options - Command options
75
+ * @param options.source - Use source code paths (node instead of npx)
76
+ * @param options.json - Output to stdout instead of writing files
77
+ * @param options.matrix - Non-interactive mode: generate all matrix combinations
78
+ * @param options.output - Output directory (default: examples for --matrix, . otherwise)
79
+ * @param options.quick - Skip all optional env var prompts, use defaults
80
+ */
81
+ export declare function generateCommand(options?: {
82
+ source?: boolean;
83
+ json?: boolean;
84
+ matrix?: boolean;
85
+ output?: string;
86
+ quick?: boolean;
87
+ }): Promise<void>;
88
+ /** Exported for testing */
89
+ export declare function discoverServerJson(basePath?: string): string | null;
90
+ /** Exported for testing */
91
+ export declare function extractServerName(packageName: string): string;
92
+ /** Generate config object (for JSON output or testing) - Exported for testing */
93
+ export declare function generateConfigObject(params: {
94
+ serverName: string;
95
+ combination: Combination;
96
+ transport: string;
97
+ packageName: string;
98
+ packageDir?: string;
99
+ binPath?: string;
100
+ metadata: ServerMetadata;
101
+ metadataReader: Pick<MetadataReader, 'getPackageForTransport'>;
102
+ httpHost?: string;
103
+ httpPort?: number;
104
+ useSource?: boolean;
105
+ quick?: boolean;
106
+ optionalVarsToPrompt?: Set<string>;
107
+ }, envPromptFn?: typeof promptForEnvVars): Promise<MCPConfiguration>;
108
+ /** Generate config file - Exported for testing */
109
+ export declare function generateConfigFile(params: {
110
+ serverName: string;
111
+ combination: Combination;
112
+ transport: string;
113
+ outputDir: string;
114
+ packageName: string;
115
+ packageDir?: string;
116
+ binPath?: string;
117
+ metadata: ServerMetadata;
118
+ metadataReader: Pick<MetadataReader, 'getPackageForTransport'>;
119
+ httpHost?: string;
120
+ httpPort?: number;
121
+ useSource?: boolean;
122
+ quick?: boolean;
123
+ optionalVarsToPrompt?: Set<string>;
124
+ }, envPromptFn?: typeof promptForEnvVars): Promise<boolean>;