UNPKG

@cequenceai/mcp-cli

Version:

Cequence MCP CLI - Command-line tool for setting up Cequence MCP servers with AI clients

133 lines (132 loc) 5.38 kB
"use strict"; var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) { if (k2 === undefined) k2 = k; var desc = Object.getOwnPropertyDescriptor(m, k); if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) { desc = { enumerable: true, get: function() { return m[k]; } }; } Object.defineProperty(o, k2, desc); }) : (function(o, m, k, k2) { if (k2 === undefined) k2 = k; o[k2] = m[k]; })); var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) { Object.defineProperty(o, "default", { enumerable: true, value: v }); }) : function(o, v) { o["default"] = v; }); var __importStar = (this && this.__importStar) || (function () { var ownKeys = function(o) { ownKeys = Object.getOwnPropertyNames || function (o) { var ar = []; for (var k in o) if (Object.prototype.hasOwnProperty.call(o, k)) ar[ar.length] = k; return ar; }; return ownKeys(o); }; return function (mod) { if (mod && mod.__esModule) return mod; var result = {}; if (mod != null) for (var k = ownKeys(mod), i = 0; i < k.length; i++) if (k[i] !== "default") __createBinding(result, mod, k[i]); __setModuleDefault(result, mod); return result; }; })(); Object.defineProperty(exports, "__esModule", { value: true }); exports.setupVSCode = setupVSCode; const fs = __importStar(require("fs-extra")); const path = __importStar(require("path")); const os = __importStar(require("os")); const validation_1 = require("../utils/validation"); /** * Gets the VS Code MCP configuration file path * @param global - If true, returns the global user config path; otherwise returns workspace path * @param workspacePath - The workspace path for project-specific config */ function getVSCodeMcpConfigPath(global = false, workspacePath) { if (global) { const homeDir = os.homedir(); // VS Code global settings location varies by platform switch (process.platform) { case 'darwin': // macOS return path.join(homeDir, 'Library', 'Application Support', 'Code', 'User', 'mcp.json'); case 'win32': // Windows return path.join(homeDir, 'AppData', 'Roaming', 'Code', 'User', 'mcp.json'); case 'linux': // Linux return path.join(homeDir, '.config', 'Code', 'User', 'mcp.json'); default: throw new Error(`Unsupported platform: ${process.platform}`); } } else { // Workspace-specific config const basePath = workspacePath || process.cwd(); return path.join(basePath, '.vscode', 'mcp.json'); } } /** * Reads the current VS Code MCP configuration */ async function readVSCodeMcpConfig(configPath) { try { if (await fs.pathExists(configPath)) { const content = await fs.readFile(configPath, 'utf-8'); return JSON.parse(content); } } catch (error) { // If file doesn't exist or is invalid JSON, return empty object console.warn('Could not read existing VS Code MCP configuration, creating new configuration'); } return {}; } /** * Writes the VS Code MCP configuration */ async function writeVSCodeMcpConfig(configPath, config) { const configDir = path.dirname(configPath); // Ensure the directory exists await fs.ensureDir(configDir); // Write configuration with proper formatting await fs.writeFile(configPath, JSON.stringify(config, null, 2), 'utf-8'); } /** * Sets up Cequence MCP server configuration for VS Code * @param config - The MCP server configuration * @param global - If true, configures globally; otherwise configures for current workspace * @param workspacePath - Optional workspace path for project-specific config */ async function setupVSCode(config, global = false, workspacePath) { try { const serverKey = (0, validation_1.sanitizeServerName)(config.name).toLowerCase().replace(/\s+/g, '-'); const configPath = getVSCodeMcpConfigPath(global, workspacePath); // Read existing MCP configuration const mcpConfig = await readVSCodeMcpConfig(configPath); // Initialize servers if it doesn't exist (VS Code uses "servers" not "mcpServers") if (!mcpConfig.servers) { mcpConfig.servers = {}; } // Create the MCP server configuration using VS Code's format // VS Code supports type: "http" for HTTP/SSE servers const serverConfig = { type: 'http', url: config.url }; // Add the server configuration mcpConfig.servers[serverKey] = serverConfig; // Write the updated configuration await writeVSCodeMcpConfig(configPath, mcpConfig); const configType = global ? 'global (user)' : 'workspace'; return { success: true, message: `Cequence MCP server "${config.name}" configured successfully for VS Code (${configType})`, configPath: configPath }; } catch (error) { return { success: false, message: `Failed to configure Cequence MCP server for VS Code: ${error instanceof Error ? error.message : String(error)}` }; } }