xiaozhi-client 1.0.7-beta.1 → 1.0.7
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/dist/autoCompletion.js.map +1 -1
- package/dist/cli.js.map +1 -1
- package/dist/configManager.js.map +1 -1
- package/dist/mcpCommands.js.map +1 -1
- package/dist/mcpPipe.js +0 -0
- package/dist/mcpPipe.js.map +1 -1
- package/dist/mcpServerProxy.js +0 -0
- package/dist/mcpServerProxy.js.map +1 -1
- package/dist/package.json +1 -1
- package/package.json +18 -18
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sources":["../src/autoCompletion.ts","../src/configManager.ts"],"sourcesContent":["import omelette from \"omelette\";\nimport { configManager } from \"./configManager\";\n\n/**\n * 自动补全功能模块\n */\n\n/**\n * 获取所有可用的MCP服务器名称\n */\nfunction getMcpServerNames(): string[] {\n try {\n if (!configManager.configExists()) {\n return [];\n }\n const mcpServers = configManager.getMcpServers();\n return Object.keys(mcpServers);\n } catch (error) {\n return [];\n }\n}\n\n/**\n * 获取指定服务器的工具名称\n */\nfunction getServerToolNames(serverName: string): string[] {\n try {\n if (!configManager.configExists()) {\n return [];\n }\n const toolsConfig = configManager.getServerToolsConfig(serverName);\n return Object.keys(toolsConfig);\n } catch (error) {\n return [];\n }\n}\n\n/**\n * 设置自动补全功能\n */\nexport function setupAutoCompletion(): void {\n // 创建 omelette 实例,使用简单的模板\n const completion = omelette(\"xiaozhi <command>\");\n\n // 处理主命令补全\n completion.on(\"command\", ({ reply }) => {\n reply([\n \"create\",\n \"init\",\n \"config\",\n \"start\",\n \"stop\",\n \"status\",\n \"attach\",\n \"restart\",\n \"mcp\",\n \"completion\",\n ]);\n });\n\n // 处理复杂的多级命令补全\n completion.on(\"complete\", (fragment, { line, before, reply }) => {\n // 调试信息\n if (process.env.XIAOZHI_DEBUG_COMPLETION) {\n console.error(\n `Debug completion - line: \"${line}\", before: \"${before}\", fragment: \"${fragment}\"`\n );\n }\n\n const parts = line.trim().split(/\\s+/);\n const endsWithSpace = line !== line.trim();\n const currentIndex = endsWithSpace ? parts.length : parts.length - 1;\n\n // MCP 相关的补全\n if (parts[1] === \"mcp\") {\n const subcommand = parts[2];\n\n if (currentIndex === 2) {\n // mcp 子命令\n const subcommands = [\"list\", \"server\", \"tool\"];\n const current = parts[2] || \"\";\n const matches = subcommands.filter((cmd) => cmd.startsWith(current));\n reply(matches);\n return;\n }\n\n if (currentIndex === 3) {\n switch (subcommand) {\n case \"list\": {\n const options = [\"--tools\"];\n const current = parts[3] || \"\";\n const matches = options.filter((opt) => opt.startsWith(current));\n reply(matches);\n break;\n }\n case \"server\":\n case \"tool\": {\n const serverNames = getMcpServerNames();\n const current = parts[3] || \"\";\n const matches = serverNames.filter((name) =>\n name.startsWith(current)\n );\n reply(matches);\n break;\n }\n default:\n reply([]);\n }\n return;\n }\n\n if (currentIndex === 4 && subcommand === \"tool\") {\n const serverName = parts[3];\n const toolNames = getServerToolNames(serverName);\n const current = parts[4] || \"\";\n const matches = toolNames.filter((name) => name.startsWith(current));\n reply(matches);\n return;\n }\n\n if (currentIndex === 5 && subcommand === \"tool\") {\n const actions = [\"enable\", \"disable\"];\n const current = parts[5] || \"\";\n const matches = actions.filter((action) => action.startsWith(current));\n reply(matches);\n return;\n }\n }\n\n // 其他命令的子参数补全\n if (currentIndex === 2) {\n const command = parts[1];\n switch (command) {\n case \"create\":\n reply([\"--template\", \"-t\"]);\n break;\n case \"start\":\n case \"restart\":\n reply([\"--daemon\", \"-d\"]);\n break;\n case \"completion\":\n reply([\"install\", \"uninstall\"]);\n break;\n default:\n reply([]);\n }\n return;\n }\n\n // 默认情况\n reply([]);\n });\n\n // 处理补全相关的命令行参数\n if (process.argv.includes(\"--completion\")) {\n // 输出补全脚本供shell使用\n try {\n console.log(completion.setupShellInitFile());\n } catch (error) {\n console.error(\"生成自动补全脚本时出错:\", error);\n }\n process.exit(0);\n }\n\n if (process.argv.includes(\"--completion-fish\")) {\n // Fish shell 补全\n console.log(completion.setupShellInitFile(\"fish\"));\n process.exit(0);\n }\n\n if (\n process.argv.includes(\"--compzsh\") ||\n process.argv.includes(\"--compbash\")\n ) {\n // 处理实际的补全请求 - 这些是omelette内部使用的参数\n // 不需要手动处理,让omelette自己处理\n }\n\n // 初始化补全\n completion.init();\n}\n\n/**\n * 显示自动补全安装说明\n */\nexport function showCompletionHelp(): void {\n console.log(\"🚀 xiaozhi 自动补全设置\");\n console.log();\n console.log(\"要启用自动补全,请根据你的shell执行以下命令:\");\n console.log();\n console.log(\"📝 Zsh (推荐):\");\n console.log(\" xiaozhi --completion >> ~/.xiaozhi-completion.zsh\");\n console.log(\" echo 'source ~/.xiaozhi-completion.zsh' >> ~/.zshrc\");\n console.log(\" source ~/.zshrc\");\n console.log();\n console.log(\"📝 Bash:\");\n console.log(\" xiaozhi --completion >> ~/.xiaozhi-completion.bash\");\n console.log(\" echo 'source ~/.xiaozhi-completion.bash' >> ~/.bash_profile\");\n console.log(\" source ~/.bash_profile\");\n console.log();\n console.log(\"📝 Fish:\");\n console.log(\n \" xiaozhi --completion-fish >> ~/.config/fish/completions/xiaozhi.fish\"\n );\n console.log();\n console.log(\"✨ 设置完成后,你就可以使用 Tab 键进行自动补全了!\");\n console.log();\n console.log(\"💡 示例:\");\n console.log(\" xiaozhi m<Tab> # → mcp\");\n console.log(\" xiaozhi mcp l<Tab> # → list\");\n console.log(\" xiaozhi mcp tool <Tab> # → 显示所有服务器名称\");\n}\n","import { copyFileSync, existsSync, readFileSync, writeFileSync } from \"node:fs\";\nimport { dirname, resolve } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\n\n// 在 ESM 中,需要从 import.meta.url 获取当前文件目录\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\n// 默认连接配置\nconst DEFAULT_CONNECTION_CONFIG: Required<ConnectionConfig> = {\n heartbeatInterval: 30000, // 30秒心跳间隔\n heartbeatTimeout: 10000, // 10秒心跳超时\n reconnectInterval: 5000, // 5秒重连间隔\n};\n\n// 配置文件接口定义\nexport interface MCPServerConfig {\n command: string;\n args: string[];\n env?: Record<string, string>;\n}\n\nexport interface MCPToolConfig {\n description?: string;\n enable: boolean;\n}\n\nexport interface MCPServerToolsConfig {\n tools: Record<string, MCPToolConfig>;\n}\n\nexport interface ConnectionConfig {\n heartbeatInterval?: number; // 心跳检测间隔(毫秒),默认30000\n heartbeatTimeout?: number; // 心跳超时时间(毫秒),默认10000 \n reconnectInterval?: number; // 重连间隔(毫秒),默认5000\n}\n\nexport interface AppConfig {\n mcpEndpoint: string;\n mcpServers: Record<string, MCPServerConfig>;\n mcpServerConfig?: Record<string, MCPServerToolsConfig>;\n connection?: ConnectionConfig; // 连接配置(可选,用于向后兼容)\n}\n\n/**\n * 配置管理类\n * 负责管理应用配置,提供只读访问和安全的配置更新功能\n */\nexport class ConfigManager {\n private static instance: ConfigManager;\n private defaultConfigPath: string;\n private config: AppConfig | null = null;\n\n private constructor() {\n this.defaultConfigPath = resolve(__dirname, \"xiaozhi.config.default.json\");\n }\n\n /**\n * 获取配置文件路径(动态计算)\n */\n private getConfigFilePath(): string {\n // 配置文件路径 - 优先使用环境变量指定的目录,否则使用当前工作目录\n const configDir = process.env.XIAOZHI_CONFIG_DIR || process.cwd();\n return resolve(configDir, \"xiaozhi.config.json\");\n }\n\n /**\n * 获取配置管理器单例实例\n */\n public static getInstance(): ConfigManager {\n if (!ConfigManager.instance) {\n ConfigManager.instance = new ConfigManager();\n }\n return ConfigManager.instance;\n }\n\n /**\n * 检查配置文件是否存在\n */\n public configExists(): boolean {\n const configPath = this.getConfigFilePath();\n return existsSync(configPath);\n }\n\n /**\n * 初始化配置文件\n * 从 config.default.json 复制到 config.json\n */\n public initConfig(): void {\n if (!existsSync(this.defaultConfigPath)) {\n throw new Error(\"默认配置文件 xiaozhi.config.default.json 不存在\");\n }\n\n if (this.configExists()) {\n throw new Error(\"配置文件 xiaozhi.config.json 已存在,无需重复初始化\");\n }\n\n const configPath = this.getConfigFilePath();\n copyFileSync(this.defaultConfigPath, configPath);\n this.config = null; // 重置缓存\n }\n\n /**\n * 加载配置文件\n */\n private loadConfig(): AppConfig {\n if (!this.configExists()) {\n throw new Error(\n \"配置文件 xiaozhi.config.json 不存在,请先运行 xiaozhi init 初始化配置\"\n );\n }\n\n try {\n const configPath = this.getConfigFilePath();\n const configData = readFileSync(configPath, \"utf8\");\n const config = JSON.parse(configData) as AppConfig;\n\n // 验证配置结构\n this.validateConfig(config);\n\n return config;\n } catch (error) {\n if (error instanceof SyntaxError) {\n throw new Error(`配置文件格式错误: ${error.message}`);\n }\n throw error;\n }\n }\n\n /**\n * 验证配置文件结构\n */\n private validateConfig(config: unknown): void {\n if (!config || typeof config !== \"object\") {\n throw new Error(\"配置文件格式错误:根对象无效\");\n }\n\n const configObj = config as Record<string, unknown>;\n\n if (!configObj.mcpEndpoint || typeof configObj.mcpEndpoint !== \"string\") {\n throw new Error(\"配置文件格式错误:mcpEndpoint 字段无效\");\n }\n\n if (!configObj.mcpServers || typeof configObj.mcpServers !== \"object\") {\n throw new Error(\"配置文件格式错误:mcpServers 字段无效\");\n }\n\n // 验证每个 MCP 服务配置\n for (const [serverName, serverConfig] of Object.entries(\n configObj.mcpServers as Record<string, unknown>\n )) {\n if (!serverConfig || typeof serverConfig !== \"object\") {\n throw new Error(`配置文件格式错误:mcpServers.${serverName} 无效`);\n }\n\n const sc = serverConfig as Record<string, unknown>;\n if (!sc.command || typeof sc.command !== \"string\") {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.command 无效`\n );\n }\n\n if (!Array.isArray(sc.args)) {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.args 必须是数组`\n );\n }\n\n if (sc.env && typeof sc.env !== \"object\") {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.env 必须是对象`\n );\n }\n }\n }\n\n /**\n * 获取配置(只读)\n */\n public getConfig(): Readonly<AppConfig> {\n if (!this.config) {\n this.config = this.loadConfig();\n }\n\n // 返回深度只读副本\n return JSON.parse(JSON.stringify(this.config));\n }\n\n /**\n * 获取 MCP 端点\n */\n public getMcpEndpoint(): string {\n const config = this.getConfig();\n return config.mcpEndpoint;\n }\n\n /**\n * 获取 MCP 服务配置\n */\n public getMcpServers(): Readonly<Record<string, MCPServerConfig>> {\n const config = this.getConfig();\n return config.mcpServers;\n }\n\n /**\n * 获取 MCP 服务工具配置\n */\n public getMcpServerConfig(): Readonly<Record<string, MCPServerToolsConfig>> {\n const config = this.getConfig();\n return config.mcpServerConfig || {};\n }\n\n /**\n * 获取指定服务的工具配置\n */\n public getServerToolsConfig(\n serverName: string\n ): Readonly<Record<string, MCPToolConfig>> {\n const serverConfig = this.getMcpServerConfig();\n return serverConfig[serverName]?.tools || {};\n }\n\n /**\n * 检查工具是否启用\n */\n public isToolEnabled(serverName: string, toolName: string): boolean {\n const toolsConfig = this.getServerToolsConfig(serverName);\n const toolConfig = toolsConfig[toolName];\n return toolConfig?.enable !== false; // 默认启用\n }\n\n /**\n * 更新 MCP 端点\n */\n public updateMcpEndpoint(endpoint: string): void {\n if (!endpoint || typeof endpoint !== \"string\") {\n throw new Error(\"MCP 端点必须是非空字符串\");\n }\n\n const config = this.getConfig();\n const newConfig = { ...config, mcpEndpoint: endpoint };\n this.saveConfig(newConfig);\n }\n\n /**\n * 更新 MCP 服务配置\n */\n public updateMcpServer(\n serverName: string,\n serverConfig: MCPServerConfig\n ): void {\n if (!serverName || typeof serverName !== \"string\") {\n throw new Error(\"服务名称必须是非空字符串\");\n }\n\n // 验证服务配置\n if (!serverConfig.command || typeof serverConfig.command !== \"string\") {\n throw new Error(\"服务配置的 command 字段必须是非空字符串\");\n }\n\n if (!Array.isArray(serverConfig.args)) {\n throw new Error(\"服务配置的 args 字段必须是数组\");\n }\n\n if (serverConfig.env && typeof serverConfig.env !== \"object\") {\n throw new Error(\"服务配置的 env 字段必须是对象\");\n }\n\n const config = this.getConfig();\n const newConfig = {\n ...config,\n mcpServers: {\n ...config.mcpServers,\n [serverName]: serverConfig,\n },\n };\n this.saveConfig(newConfig);\n }\n\n /**\n * 删除 MCP 服务配置\n */\n public removeMcpServer(serverName: string): void {\n if (!serverName || typeof serverName !== \"string\") {\n throw new Error(\"服务名称必须是非空字符串\");\n }\n\n const config = this.getConfig();\n if (!config.mcpServers[serverName]) {\n throw new Error(`服务 ${serverName} 不存在`);\n }\n\n const newMcpServers = { ...config.mcpServers };\n delete newMcpServers[serverName];\n\n const newConfig = {\n ...config,\n mcpServers: newMcpServers,\n };\n this.saveConfig(newConfig);\n }\n\n /**\n * 更新服务工具配置\n */\n public updateServerToolsConfig(\n serverName: string,\n toolsConfig: Record<string, MCPToolConfig>\n ): void {\n const config = this.getConfig();\n const newConfig = { ...config };\n\n // 确保 mcpServerConfig 存在\n if (!newConfig.mcpServerConfig) {\n newConfig.mcpServerConfig = {};\n }\n\n // 更新指定服务的工具配置\n newConfig.mcpServerConfig[serverName] = {\n tools: toolsConfig,\n };\n\n this.saveConfig(newConfig);\n }\n\n /**\n * 设置工具启用状态\n */\n public setToolEnabled(\n serverName: string,\n toolName: string,\n enabled: boolean,\n description?: string\n ): void {\n const config = this.getConfig();\n const newConfig = { ...config };\n\n // 确保 mcpServerConfig 存在\n if (!newConfig.mcpServerConfig) {\n newConfig.mcpServerConfig = {};\n }\n\n // 确保服务配置存在\n if (!newConfig.mcpServerConfig[serverName]) {\n newConfig.mcpServerConfig[serverName] = { tools: {} };\n }\n\n // 更新工具配置\n newConfig.mcpServerConfig[serverName].tools[toolName] = {\n enable: enabled,\n ...(description && { description }),\n };\n\n this.saveConfig(newConfig);\n }\n\n /**\n * 保存配置到文件\n */\n private saveConfig(config: AppConfig): void {\n try {\n // 验证配置\n this.validateConfig(config);\n\n // 格式化 JSON 并保存\n const configPath = this.getConfigFilePath();\n const configJson = JSON.stringify(config, null, 2);\n writeFileSync(configPath, configJson, \"utf8\");\n\n // 更新缓存\n this.config = config;\n } catch (error) {\n throw new Error(\n `保存配置失败: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n }\n\n /**\n * 重新加载配置(清除缓存)\n */\n public reloadConfig(): void {\n this.config = null;\n }\n\n /**\n * 获取配置文件路径\n */\n public getConfigPath(): string {\n return this.getConfigFilePath();\n }\n\n /**\n * 获取默认配置文件路径\n */\n public getDefaultConfigPath(): string {\n return this.defaultConfigPath;\n }\n\n /**\n * 获取连接配置(包含默认值)\n */\n public getConnectionConfig(): Required<ConnectionConfig> {\n const config = this.getConfig();\n const connectionConfig = config.connection || {};\n \n return {\n heartbeatInterval: connectionConfig.heartbeatInterval ?? DEFAULT_CONNECTION_CONFIG.heartbeatInterval,\n heartbeatTimeout: connectionConfig.heartbeatTimeout ?? DEFAULT_CONNECTION_CONFIG.heartbeatTimeout,\n reconnectInterval: connectionConfig.reconnectInterval ?? DEFAULT_CONNECTION_CONFIG.reconnectInterval,\n };\n }\n\n /**\n * 获取心跳检测间隔(毫秒)\n */\n public getHeartbeatInterval(): number {\n return this.getConnectionConfig().heartbeatInterval;\n }\n\n /**\n * 获取心跳超时时间(毫秒)\n */\n public getHeartbeatTimeout(): number {\n return this.getConnectionConfig().heartbeatTimeout;\n }\n\n /**\n * 获取重连间隔(毫秒)\n */\n public getReconnectInterval(): number {\n return this.getConnectionConfig().reconnectInterval;\n }\n\n /**\n * 更新连接配置\n */\n public updateConnectionConfig(connectionConfig: Partial<ConnectionConfig>): void {\n const config = this.getConfig();\n const currentConnectionConfig = config.connection || {};\n \n const newConnectionConfig = {\n ...currentConnectionConfig,\n ...connectionConfig,\n };\n \n const newConfig = {\n ...config,\n connection: newConnectionConfig,\n };\n \n this.saveConfig(newConfig);\n }\n\n /**\n * 设置心跳检测间隔\n */\n public setHeartbeatInterval(interval: number): void {\n if (interval <= 0) {\n throw new Error(\"心跳检测间隔必须大于0\");\n }\n this.updateConnectionConfig({ heartbeatInterval: interval });\n }\n\n /**\n * 设置心跳超时时间\n */\n public setHeartbeatTimeout(timeout: number): void {\n if (timeout <= 0) {\n throw new Error(\"心跳超时时间必须大于0\");\n }\n this.updateConnectionConfig({ heartbeatTimeout: timeout });\n }\n\n /**\n * 设置重连间隔\n */\n public setReconnectInterval(interval: number): void {\n if (interval <= 0) {\n throw new Error(\"重连间隔必须大于0\");\n }\n this.updateConnectionConfig({ reconnectInterval: interval });\n }\n}\n\n// 导出单例实例\nexport const configManager = ConfigManager.getInstance();\n"],"mappings":"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","names":["omelette","copyFileSync","existsSync","readFileSync","writeFileSync","dirname","resolve","fileURLToPath","__dirname","dirname","fileURLToPath","DEFAULT_CONNECTION_CONFIG","ConfigManager","_ConfigManager","__name","resolve","configDir","configPath","existsSync","copyFileSync","configData","readFileSync","config","error","configObj","serverName","serverConfig","sc","toolName","endpoint","newConfig","newMcpServers","toolsConfig","enabled","description","configJson","writeFileSync","connectionConfig","newConnectionConfig","interval","timeout","configManager","getMcpServerNames","configManager","mcpServers","__name","getServerToolNames","serverName","toolsConfig","setupAutoCompletion","completion","omelette","reply","fragment","line","before","parts","currentIndex","subcommand","subcommands","current","matches","cmd","options","opt","serverNames","name","toolNames","actions","action","error","showCompletionHelp"]}
|
|
1
|
+
{"version":3,"sources":["../src/autoCompletion.ts","../src/configManager.ts"],"sourcesContent":["import omelette from \"omelette\";\nimport { configManager } from \"./configManager\";\n\n/**\n * 自动补全功能模块\n */\n\n/**\n * 获取所有可用的MCP服务器名称\n */\nfunction getMcpServerNames(): string[] {\n try {\n if (!configManager.configExists()) {\n return [];\n }\n const mcpServers = configManager.getMcpServers();\n return Object.keys(mcpServers);\n } catch (error) {\n return [];\n }\n}\n\n/**\n * 获取指定服务器的工具名称\n */\nfunction getServerToolNames(serverName: string): string[] {\n try {\n if (!configManager.configExists()) {\n return [];\n }\n const toolsConfig = configManager.getServerToolsConfig(serverName);\n return Object.keys(toolsConfig);\n } catch (error) {\n return [];\n }\n}\n\n/**\n * 设置自动补全功能\n */\nexport function setupAutoCompletion(): void {\n // 创建 omelette 实例,使用简单的模板\n const completion = omelette(\"xiaozhi <command>\");\n\n // 处理主命令补全\n completion.on(\"command\", ({ reply }) => {\n reply([\n \"create\",\n \"init\",\n \"config\",\n \"start\",\n \"stop\",\n \"status\",\n \"attach\",\n \"restart\",\n \"mcp\",\n \"completion\",\n ]);\n });\n\n // 处理复杂的多级命令补全\n completion.on(\"complete\", (fragment, { line, before, reply }) => {\n // 调试信息\n if (process.env.XIAOZHI_DEBUG_COMPLETION) {\n console.error(\n `Debug completion - line: \"${line}\", before: \"${before}\", fragment: \"${fragment}\"`\n );\n }\n\n const parts = line.trim().split(/\\s+/);\n const endsWithSpace = line !== line.trim();\n const currentIndex = endsWithSpace ? parts.length : parts.length - 1;\n\n // MCP 相关的补全\n if (parts[1] === \"mcp\") {\n const subcommand = parts[2];\n\n if (currentIndex === 2) {\n // mcp 子命令\n const subcommands = [\"list\", \"server\", \"tool\"];\n const current = parts[2] || \"\";\n const matches = subcommands.filter((cmd) => cmd.startsWith(current));\n reply(matches);\n return;\n }\n\n if (currentIndex === 3) {\n switch (subcommand) {\n case \"list\": {\n const options = [\"--tools\"];\n const current = parts[3] || \"\";\n const matches = options.filter((opt) => opt.startsWith(current));\n reply(matches);\n break;\n }\n case \"server\":\n case \"tool\": {\n const serverNames = getMcpServerNames();\n const current = parts[3] || \"\";\n const matches = serverNames.filter((name) =>\n name.startsWith(current)\n );\n reply(matches);\n break;\n }\n default:\n reply([]);\n }\n return;\n }\n\n if (currentIndex === 4 && subcommand === \"tool\") {\n const serverName = parts[3];\n const toolNames = getServerToolNames(serverName);\n const current = parts[4] || \"\";\n const matches = toolNames.filter((name) => name.startsWith(current));\n reply(matches);\n return;\n }\n\n if (currentIndex === 5 && subcommand === \"tool\") {\n const actions = [\"enable\", \"disable\"];\n const current = parts[5] || \"\";\n const matches = actions.filter((action) => action.startsWith(current));\n reply(matches);\n return;\n }\n }\n\n // 其他命令的子参数补全\n if (currentIndex === 2) {\n const command = parts[1];\n switch (command) {\n case \"create\":\n reply([\"--template\", \"-t\"]);\n break;\n case \"start\":\n case \"restart\":\n reply([\"--daemon\", \"-d\"]);\n break;\n case \"completion\":\n reply([\"install\", \"uninstall\"]);\n break;\n default:\n reply([]);\n }\n return;\n }\n\n // 默认情况\n reply([]);\n });\n\n // 处理补全相关的命令行参数\n if (process.argv.includes(\"--completion\")) {\n // 输出补全脚本供shell使用\n try {\n console.log(completion.setupShellInitFile());\n } catch (error) {\n console.error(\"生成自动补全脚本时出错:\", error);\n }\n process.exit(0);\n }\n\n if (process.argv.includes(\"--completion-fish\")) {\n // Fish shell 补全\n console.log(completion.setupShellInitFile(\"fish\"));\n process.exit(0);\n }\n\n if (\n process.argv.includes(\"--compzsh\") ||\n process.argv.includes(\"--compbash\")\n ) {\n // 处理实际的补全请求 - 这些是omelette内部使用的参数\n // 不需要手动处理,让omelette自己处理\n }\n\n // 初始化补全\n completion.init();\n}\n\n/**\n * 显示自动补全安装说明\n */\nexport function showCompletionHelp(): void {\n console.log(\"🚀 xiaozhi 自动补全设置\");\n console.log();\n console.log(\"要启用自动补全,请根据你的shell执行以下命令:\");\n console.log();\n console.log(\"📝 Zsh (推荐):\");\n console.log(\" xiaozhi --completion >> ~/.xiaozhi-completion.zsh\");\n console.log(\" echo 'source ~/.xiaozhi-completion.zsh' >> ~/.zshrc\");\n console.log(\" source ~/.zshrc\");\n console.log();\n console.log(\"📝 Bash:\");\n console.log(\" xiaozhi --completion >> ~/.xiaozhi-completion.bash\");\n console.log(\" echo 'source ~/.xiaozhi-completion.bash' >> ~/.bash_profile\");\n console.log(\" source ~/.bash_profile\");\n console.log();\n console.log(\"📝 Fish:\");\n console.log(\n \" xiaozhi --completion-fish >> ~/.config/fish/completions/xiaozhi.fish\"\n );\n console.log();\n console.log(\"✨ 设置完成后,你就可以使用 Tab 键进行自动补全了!\");\n console.log();\n console.log(\"💡 示例:\");\n console.log(\" xiaozhi m<Tab> # → mcp\");\n console.log(\" xiaozhi mcp l<Tab> # → list\");\n console.log(\" xiaozhi mcp tool <Tab> # → 显示所有服务器名称\");\n}\n","import { copyFileSync, existsSync, readFileSync, writeFileSync } from \"node:fs\";\nimport { dirname, resolve } from \"node:path\";\nimport { fileURLToPath } from \"node:url\";\n\n// 在 ESM 中,需要从 import.meta.url 获取当前文件目录\nconst __dirname = dirname(fileURLToPath(import.meta.url));\n\n// 默认连接配置\nconst DEFAULT_CONNECTION_CONFIG: Required<ConnectionConfig> = {\n heartbeatInterval: 30000, // 30秒心跳间隔\n heartbeatTimeout: 10000, // 10秒心跳超时\n reconnectInterval: 5000, // 5秒重连间隔\n};\n\n// 配置文件接口定义\nexport interface MCPServerConfig {\n command: string;\n args: string[];\n env?: Record<string, string>;\n}\n\nexport interface MCPToolConfig {\n description?: string;\n enable: boolean;\n}\n\nexport interface MCPServerToolsConfig {\n tools: Record<string, MCPToolConfig>;\n}\n\nexport interface ConnectionConfig {\n heartbeatInterval?: number; // 心跳检测间隔(毫秒),默认30000\n heartbeatTimeout?: number; // 心跳超时时间(毫秒),默认10000\n reconnectInterval?: number; // 重连间隔(毫秒),默认5000\n}\n\nexport interface AppConfig {\n mcpEndpoint: string;\n mcpServers: Record<string, MCPServerConfig>;\n mcpServerConfig?: Record<string, MCPServerToolsConfig>;\n connection?: ConnectionConfig; // 连接配置(可选,用于向后兼容)\n}\n\n/**\n * 配置管理类\n * 负责管理应用配置,提供只读访问和安全的配置更新功能\n */\nexport class ConfigManager {\n private static instance: ConfigManager;\n private defaultConfigPath: string;\n private config: AppConfig | null = null;\n\n private constructor() {\n this.defaultConfigPath = resolve(__dirname, \"xiaozhi.config.default.json\");\n }\n\n /**\n * 获取配置文件路径(动态计算)\n */\n private getConfigFilePath(): string {\n // 配置文件路径 - 优先使用环境变量指定的目录,否则使用当前工作目录\n const configDir = process.env.XIAOZHI_CONFIG_DIR || process.cwd();\n return resolve(configDir, \"xiaozhi.config.json\");\n }\n\n /**\n * 获取配置管理器单例实例\n */\n public static getInstance(): ConfigManager {\n if (!ConfigManager.instance) {\n ConfigManager.instance = new ConfigManager();\n }\n return ConfigManager.instance;\n }\n\n /**\n * 检查配置文件是否存在\n */\n public configExists(): boolean {\n const configPath = this.getConfigFilePath();\n return existsSync(configPath);\n }\n\n /**\n * 初始化配置文件\n * 从 config.default.json 复制到 config.json\n */\n public initConfig(): void {\n if (!existsSync(this.defaultConfigPath)) {\n throw new Error(\"默认配置文件 xiaozhi.config.default.json 不存在\");\n }\n\n if (this.configExists()) {\n throw new Error(\"配置文件 xiaozhi.config.json 已存在,无需重复初始化\");\n }\n\n const configPath = this.getConfigFilePath();\n copyFileSync(this.defaultConfigPath, configPath);\n this.config = null; // 重置缓存\n }\n\n /**\n * 加载配置文件\n */\n private loadConfig(): AppConfig {\n if (!this.configExists()) {\n throw new Error(\n \"配置文件 xiaozhi.config.json 不存在,请先运行 xiaozhi init 初始化配置\"\n );\n }\n\n try {\n const configPath = this.getConfigFilePath();\n const configData = readFileSync(configPath, \"utf8\");\n const config = JSON.parse(configData) as AppConfig;\n\n // 验证配置结构\n this.validateConfig(config);\n\n return config;\n } catch (error) {\n if (error instanceof SyntaxError) {\n throw new Error(`配置文件格式错误: ${error.message}`);\n }\n throw error;\n }\n }\n\n /**\n * 验证配置文件结构\n */\n private validateConfig(config: unknown): void {\n if (!config || typeof config !== \"object\") {\n throw new Error(\"配置文件格式错误:根对象无效\");\n }\n\n const configObj = config as Record<string, unknown>;\n\n if (!configObj.mcpEndpoint || typeof configObj.mcpEndpoint !== \"string\") {\n throw new Error(\"配置文件格式错误:mcpEndpoint 字段无效\");\n }\n\n if (!configObj.mcpServers || typeof configObj.mcpServers !== \"object\") {\n throw new Error(\"配置文件格式错误:mcpServers 字段无效\");\n }\n\n // 验证每个 MCP 服务配置\n for (const [serverName, serverConfig] of Object.entries(\n configObj.mcpServers as Record<string, unknown>\n )) {\n if (!serverConfig || typeof serverConfig !== \"object\") {\n throw new Error(`配置文件格式错误:mcpServers.${serverName} 无效`);\n }\n\n const sc = serverConfig as Record<string, unknown>;\n if (!sc.command || typeof sc.command !== \"string\") {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.command 无效`\n );\n }\n\n if (!Array.isArray(sc.args)) {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.args 必须是数组`\n );\n }\n\n if (sc.env && typeof sc.env !== \"object\") {\n throw new Error(\n `配置文件格式错误:mcpServers.${serverName}.env 必须是对象`\n );\n }\n }\n }\n\n /**\n * 获取配置(只读)\n */\n public getConfig(): Readonly<AppConfig> {\n if (!this.config) {\n this.config = this.loadConfig();\n }\n\n // 返回深度只读副本\n return JSON.parse(JSON.stringify(this.config));\n }\n\n /**\n * 获取 MCP 端点\n */\n public getMcpEndpoint(): string {\n const config = this.getConfig();\n return config.mcpEndpoint;\n }\n\n /**\n * 获取 MCP 服务配置\n */\n public getMcpServers(): Readonly<Record<string, MCPServerConfig>> {\n const config = this.getConfig();\n return config.mcpServers;\n }\n\n /**\n * 获取 MCP 服务工具配置\n */\n public getMcpServerConfig(): Readonly<Record<string, MCPServerToolsConfig>> {\n const config = this.getConfig();\n return config.mcpServerConfig || {};\n }\n\n /**\n * 获取指定服务的工具配置\n */\n public getServerToolsConfig(\n serverName: string\n ): Readonly<Record<string, MCPToolConfig>> {\n const serverConfig = this.getMcpServerConfig();\n return serverConfig[serverName]?.tools || {};\n }\n\n /**\n * 检查工具是否启用\n */\n public isToolEnabled(serverName: string, toolName: string): boolean {\n const toolsConfig = this.getServerToolsConfig(serverName);\n const toolConfig = toolsConfig[toolName];\n return toolConfig?.enable !== false; // 默认启用\n }\n\n /**\n * 更新 MCP 端点\n */\n public updateMcpEndpoint(endpoint: string): void {\n if (!endpoint || typeof endpoint !== \"string\") {\n throw new Error(\"MCP 端点必须是非空字符串\");\n }\n\n const config = this.getConfig();\n const newConfig = { ...config, mcpEndpoint: endpoint };\n this.saveConfig(newConfig);\n }\n\n /**\n * 更新 MCP 服务配置\n */\n public updateMcpServer(\n serverName: string,\n serverConfig: MCPServerConfig\n ): void {\n if (!serverName || typeof serverName !== \"string\") {\n throw new Error(\"服务名称必须是非空字符串\");\n }\n\n // 验证服务配置\n if (!serverConfig.command || typeof serverConfig.command !== \"string\") {\n throw new Error(\"服务配置的 command 字段必须是非空字符串\");\n }\n\n if (!Array.isArray(serverConfig.args)) {\n throw new Error(\"服务配置的 args 字段必须是数组\");\n }\n\n if (serverConfig.env && typeof serverConfig.env !== \"object\") {\n throw new Error(\"服务配置的 env 字段必须是对象\");\n }\n\n const config = this.getConfig();\n const newConfig = {\n ...config,\n mcpServers: {\n ...config.mcpServers,\n [serverName]: serverConfig,\n },\n };\n this.saveConfig(newConfig);\n }\n\n /**\n * 删除 MCP 服务配置\n */\n public removeMcpServer(serverName: string): void {\n if (!serverName || typeof serverName !== \"string\") {\n throw new Error(\"服务名称必须是非空字符串\");\n }\n\n const config = this.getConfig();\n if (!config.mcpServers[serverName]) {\n throw new Error(`服务 ${serverName} 不存在`);\n }\n\n const newMcpServers = { ...config.mcpServers };\n delete newMcpServers[serverName];\n\n const newConfig = {\n ...config,\n mcpServers: newMcpServers,\n };\n this.saveConfig(newConfig);\n }\n\n /**\n * 更新服务工具配置\n */\n public updateServerToolsConfig(\n serverName: string,\n toolsConfig: Record<string, MCPToolConfig>\n ): void {\n const config = this.getConfig();\n const newConfig = { ...config };\n\n // 确保 mcpServerConfig 存在\n if (!newConfig.mcpServerConfig) {\n newConfig.mcpServerConfig = {};\n }\n\n // 更新指定服务的工具配置\n newConfig.mcpServerConfig[serverName] = {\n tools: toolsConfig,\n };\n\n this.saveConfig(newConfig);\n }\n\n /**\n * 设置工具启用状态\n */\n public setToolEnabled(\n serverName: string,\n toolName: string,\n enabled: boolean,\n description?: string\n ): void {\n const config = this.getConfig();\n const newConfig = { ...config };\n\n // 确保 mcpServerConfig 存在\n if (!newConfig.mcpServerConfig) {\n newConfig.mcpServerConfig = {};\n }\n\n // 确保服务配置存在\n if (!newConfig.mcpServerConfig[serverName]) {\n newConfig.mcpServerConfig[serverName] = { tools: {} };\n }\n\n // 更新工具配置\n newConfig.mcpServerConfig[serverName].tools[toolName] = {\n enable: enabled,\n ...(description && { description }),\n };\n\n this.saveConfig(newConfig);\n }\n\n /**\n * 保存配置到文件\n */\n private saveConfig(config: AppConfig): void {\n try {\n // 验证配置\n this.validateConfig(config);\n\n // 格式化 JSON 并保存\n const configPath = this.getConfigFilePath();\n const configJson = JSON.stringify(config, null, 2);\n writeFileSync(configPath, configJson, \"utf8\");\n\n // 更新缓存\n this.config = config;\n } catch (error) {\n throw new Error(\n `保存配置失败: ${error instanceof Error ? error.message : String(error)}`\n );\n }\n }\n\n /**\n * 重新加载配置(清除缓存)\n */\n public reloadConfig(): void {\n this.config = null;\n }\n\n /**\n * 获取配置文件路径\n */\n public getConfigPath(): string {\n return this.getConfigFilePath();\n }\n\n /**\n * 获取默认配置文件路径\n */\n public getDefaultConfigPath(): string {\n return this.defaultConfigPath;\n }\n\n /**\n * 获取连接配置(包含默认值)\n */\n public getConnectionConfig(): Required<ConnectionConfig> {\n const config = this.getConfig();\n const connectionConfig = config.connection || {};\n\n return {\n heartbeatInterval:\n connectionConfig.heartbeatInterval ??\n DEFAULT_CONNECTION_CONFIG.heartbeatInterval,\n heartbeatTimeout:\n connectionConfig.heartbeatTimeout ??\n DEFAULT_CONNECTION_CONFIG.heartbeatTimeout,\n reconnectInterval:\n connectionConfig.reconnectInterval ??\n DEFAULT_CONNECTION_CONFIG.reconnectInterval,\n };\n }\n\n /**\n * 获取心跳检测间隔(毫秒)\n */\n public getHeartbeatInterval(): number {\n return this.getConnectionConfig().heartbeatInterval;\n }\n\n /**\n * 获取心跳超时时间(毫秒)\n */\n public getHeartbeatTimeout(): number {\n return this.getConnectionConfig().heartbeatTimeout;\n }\n\n /**\n * 获取重连间隔(毫秒)\n */\n public getReconnectInterval(): number {\n return this.getConnectionConfig().reconnectInterval;\n }\n\n /**\n * 更新连接配置\n */\n public updateConnectionConfig(\n connectionConfig: Partial<ConnectionConfig>\n ): void {\n const config = this.getConfig();\n const currentConnectionConfig = config.connection || {};\n\n const newConnectionConfig = {\n ...currentConnectionConfig,\n ...connectionConfig,\n };\n\n const newConfig = {\n ...config,\n connection: newConnectionConfig,\n };\n\n this.saveConfig(newConfig);\n }\n\n /**\n * 设置心跳检测间隔\n */\n public setHeartbeatInterval(interval: number): void {\n if (interval <= 0) {\n throw new Error(\"心跳检测间隔必须大于0\");\n }\n this.updateConnectionConfig({ heartbeatInterval: interval });\n }\n\n /**\n * 设置心跳超时时间\n */\n public setHeartbeatTimeout(timeout: number): void {\n if (timeout <= 0) {\n throw new Error(\"心跳超时时间必须大于0\");\n }\n this.updateConnectionConfig({ heartbeatTimeout: timeout });\n }\n\n /**\n * 设置重连间隔\n */\n public setReconnectInterval(interval: number): void {\n if (interval <= 0) {\n throw new Error(\"重连间隔必须大于0\");\n }\n this.updateConnectionConfig({ reconnectInterval: interval });\n }\n}\n\n// 导出单例实例\nexport const configManager = ConfigManager.getInstance();\n"],"mappings":"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","names":["omelette","copyFileSync","existsSync","readFileSync","writeFileSync","dirname","resolve","fileURLToPath","__dirname","dirname","fileURLToPath","DEFAULT_CONNECTION_CONFIG","ConfigManager","_ConfigManager","__name","resolve","configDir","configPath","existsSync","copyFileSync","configData","readFileSync","config","error","configObj","serverName","serverConfig","sc","toolName","endpoint","newConfig","newMcpServers","toolsConfig","enabled","description","configJson","writeFileSync","connectionConfig","newConnectionConfig","interval","timeout","configManager","getMcpServerNames","configManager","mcpServers","__name","getServerToolNames","serverName","toolsConfig","setupAutoCompletion","completion","omelette","reply","fragment","line","before","parts","currentIndex","subcommand","subcommands","current","matches","cmd","options","opt","serverNames","name","toolNames","actions","action","error","showCompletionHelp"]}
|