@teambit/cli-mcp-server 0.0.9 → 0.0.11

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.docs.mdx CHANGED
@@ -4,7 +4,7 @@ The Bit CLI MCP Server provides a [Model Context Protocol (MCP)](https://github.
4
4
 
5
5
  ## Overview
6
6
 
7
- This server acts as a bridge between MCP clients (such as VS Code, AI tools, or your own applications) and the Bit CLI. It translates MCP tool calls into Bit CLI commands, runs them, and returns the results in a format that MCP clients can understand.
7
+ This server acts as a bridge between MCP clients (such as VS Code, AI tools, or your own applications) and the Bit CLI. It leverages the Bit server API for efficient communication and provides both individual CLI command tools and specialized composite tools for common workflows. The server automatically manages a Bit server instance in the background for optimal performance.
8
8
 
9
9
  ## Installation
10
10
 
@@ -106,36 +106,27 @@ async function example() {
106
106
 
107
107
  ## Available Tools
108
108
 
109
- The Bit CLI MCP Server operates in three modes:
109
+ The Bit CLI MCP Server operates in three modes and provides several specialized tools:
110
110
 
111
111
  ### Default Mode
112
112
 
113
- In default mode, the server exposes a focused set of essential Bit CLI commands (~22 tools). This ensures optimal performance and safety. These are the most commonly used Bit operations:
114
-
115
- - `bit_status`: Show component status and potential issues
116
- - `bit_list`: List components in a workspace or remote scope
117
- - `bit_add`: Track directories as components
118
- - `bit_init`: Create or initialize a workspace
119
- - `bit_show`: Display component information
120
- - `bit_tag`: Create an immutable, exportable component version
121
- - `bit_snap`: Create a non-release component snapshot
122
- - `bit_import`: Import components from remote scopes
123
- - `bit_export`: Export components to remote scopes
124
- - `bit_remove`: Remove components from workspace
125
- - `bit_log`: Show component version history
126
- - `bit_test`: Test components
127
- - `bit_diff`: Show differences between component versions
128
- - `bit_install`: Install dependencies
129
- - `bit_lane_show`: Display lane details
130
- - `bit_lane_create`: Create a new development lane
131
- - `bit_lane_switch`: Switch between lanes
132
- - `bit_lane_merge`: Merge lane changes
133
- - `bit_create`: Generate components from templates
134
- - `bit_templates`: List available templates
135
- - `bit_reset`: Revert tags or snaps
136
- - `bit_checkout`: Switch versions or remove changes
137
- - `bit_schema`: Retrieve component API schema from workspace or remote scopes
138
- - `bit_remote_search`: Search for components in remote scopes
113
+ In default mode, the server exposes a minimal set of essential tools focused on component discovery and creation. This ensures optimal performance and safety:
114
+
115
+ - **Individual CLI Command Tools:**
116
+
117
+ - `bit_create`: Generate components from templates
118
+ - `bit_schema`: Retrieve component API schema from workspace or remote scopes
119
+ - `bit_remote_search`: Search for components in remote scopes
120
+
121
+ - **Specialized Composite Tools:**
122
+
123
+ - `bit_workspace_info`: Get comprehensive workspace information including status, components list, apps, templates, and dependency graph
124
+ - `bit_component_details`: Get detailed information about a specific component including basic info and optionally its public API schema
125
+ - `bit_commands_info`: Get information about available Bit commands and their groups
126
+
127
+ - **Generic Execution Tools:**
128
+ - `bit_query`: Execute read-only Bit commands that safely inspect workspace and component state without making modifications
129
+ - `bit_execute`: Execute any Bit command, including those that modify workspace or repository state (use with caution)
139
130
 
140
131
  ### Consumer Project Mode (--consumer-project)
141
132
 
@@ -4,7 +4,7 @@ The Bit CLI MCP Server provides a [Model Context Protocol (MCP)](https://github.
4
4
 
5
5
  ## Overview
6
6
 
7
- This server acts as a bridge between MCP clients (such as VS Code, AI tools, or your own applications) and the Bit CLI. It translates MCP tool calls into Bit CLI commands, runs them, and returns the results in a format that MCP clients can understand.
7
+ This server acts as a bridge between MCP clients (such as VS Code, AI tools, or your own applications) and the Bit CLI. It leverages the Bit server API for efficient communication and provides both individual CLI command tools and specialized composite tools for common workflows. The server automatically manages a Bit server instance in the background for optimal performance.
8
8
 
9
9
  ## Installation
10
10
 
@@ -106,36 +106,27 @@ async function example() {
106
106
 
107
107
  ## Available Tools
108
108
 
109
- The Bit CLI MCP Server operates in three modes:
109
+ The Bit CLI MCP Server operates in three modes and provides several specialized tools:
110
110
 
111
111
  ### Default Mode
112
112
 
113
- In default mode, the server exposes a focused set of essential Bit CLI commands (~22 tools). This ensures optimal performance and safety. These are the most commonly used Bit operations:
114
-
115
- - `bit_status`: Show component status and potential issues
116
- - `bit_list`: List components in a workspace or remote scope
117
- - `bit_add`: Track directories as components
118
- - `bit_init`: Create or initialize a workspace
119
- - `bit_show`: Display component information
120
- - `bit_tag`: Create an immutable, exportable component version
121
- - `bit_snap`: Create a non-release component snapshot
122
- - `bit_import`: Import components from remote scopes
123
- - `bit_export`: Export components to remote scopes
124
- - `bit_remove`: Remove components from workspace
125
- - `bit_log`: Show component version history
126
- - `bit_test`: Test components
127
- - `bit_diff`: Show differences between component versions
128
- - `bit_install`: Install dependencies
129
- - `bit_lane_show`: Display lane details
130
- - `bit_lane_create`: Create a new development lane
131
- - `bit_lane_switch`: Switch between lanes
132
- - `bit_lane_merge`: Merge lane changes
133
- - `bit_create`: Generate components from templates
134
- - `bit_templates`: List available templates
135
- - `bit_reset`: Revert tags or snaps
136
- - `bit_checkout`: Switch versions or remove changes
137
- - `bit_schema`: Retrieve component API schema from workspace or remote scopes
138
- - `bit_remote_search`: Search for components in remote scopes
113
+ In default mode, the server exposes a minimal set of essential tools focused on component discovery and creation. This ensures optimal performance and safety:
114
+
115
+ - **Individual CLI Command Tools:**
116
+
117
+ - `bit_create`: Generate components from templates
118
+ - `bit_schema`: Retrieve component API schema from workspace or remote scopes
119
+ - `bit_remote_search`: Search for components in remote scopes
120
+
121
+ - **Specialized Composite Tools:**
122
+
123
+ - `bit_workspace_info`: Get comprehensive workspace information including status, components list, apps, templates, and dependency graph
124
+ - `bit_component_details`: Get detailed information about a specific component including basic info and optionally its public API schema
125
+ - `bit_commands_info`: Get information about available Bit commands and their groups
126
+
127
+ - **Generic Execution Tools:**
128
+ - `bit_query`: Execute read-only Bit commands that safely inspect workspace and component state without making modifications
129
+ - `bit_execute`: Execute any Bit command, including those that modify workspace or repository state (use with caution)
139
130
 
140
131
  ### Consumer Project Mode (--consumer-project)
141
132
 
@@ -7,8 +7,21 @@ export declare class CliMcpServerMain {
7
7
  private bitBin;
8
8
  private _http;
9
9
  private isConsumerProjectMode;
10
+ private serverPort?;
11
+ private serverUrl?;
12
+ private serverProcess;
13
+ private readonly readOnlyCommands;
10
14
  constructor(cli: CLIMain, logger: Logger);
11
15
  getHttp(): Promise<Http>;
16
+ private getBitServerPort;
17
+ /**
18
+ * Start a new bit-server process
19
+ */
20
+ private startBitServer;
21
+ /**
22
+ * Call bit-server API endpoint using cli-raw route
23
+ */
24
+ private callBitServerAPI;
12
25
  runMcpServer(options: {
13
26
  extended?: boolean;
14
27
  includeOnly?: string;
@@ -24,8 +37,29 @@ export declare class CliMcpServerMain {
24
37
  private registerToolForCommand;
25
38
  private registerToolForRemote;
26
39
  private registerRemoteSearchTool;
40
+ private registerWorkspaceInfoTool;
41
+ private registerComponentDetailsTool;
42
+ private registerCommandsInfoTool;
43
+ private registerQueryTool;
44
+ private registerExecuteTool;
27
45
  private processSubCommands;
28
46
  private runBit;
47
+ /**
48
+ * Helper method to execute a bit-server API call with standardized error handling
49
+ */
50
+ private executeBitServerCommand;
51
+ /**
52
+ * Helper method to format any result as CallToolResult
53
+ */
54
+ private formatAsCallToolResult;
55
+ /**
56
+ * Helper method to format error as CallToolResult
57
+ */
58
+ private formatErrorAsCallToolResult;
59
+ /**
60
+ * Helper method to safely execute a bit command with error handling
61
+ */
62
+ private safeBitCommandExecution;
29
63
  static slots: never[];
30
64
  static dependencies: import("@teambit/harmony").Aspect[];
31
65
  static runtime: import("@teambit/harmony").RuntimeDefinition;
@@ -74,7 +74,16 @@ function _legacy() {
74
74
  };
75
75
  return data;
76
76
  }
77
+ function _nodeFetch() {
78
+ const data = _interopRequireDefault(require("node-fetch"));
79
+ _nodeFetch = function () {
80
+ return data;
81
+ };
82
+ return data;
83
+ }
77
84
  function _interopRequireDefault(e) { return e && e.__esModule ? e : { default: e }; }
85
+ function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
86
+ function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
78
87
  function _defineProperty(e, r, t) { return (r = _toPropertyKey(r)) in e ? Object.defineProperty(e, r, { value: t, enumerable: !0, configurable: !0, writable: !0 }) : e[r] = t, e; }
79
88
  function _toPropertyKey(t) { var i = _toPrimitive(t, "string"); return "symbol" == typeof i ? i : i + ""; }
80
89
  function _toPrimitive(t, r) { if ("object" != typeof t || !t) return t; var e = t[Symbol.toPrimitive]; if (void 0 !== e) { var i = e.call(t, r || "default"); if ("object" != typeof i) return i; throw new TypeError("@@toPrimitive must return a primitive value."); } return ("string" === r ? String : Number)(t); } /* eslint-disable import/extensions */ /* eslint-disable import/no-unresolved */
@@ -85,6 +94,11 @@ class CliMcpServerMain {
85
94
  _defineProperty(this, "bitBin", 'bit');
86
95
  _defineProperty(this, "_http", void 0);
87
96
  _defineProperty(this, "isConsumerProjectMode", false);
97
+ _defineProperty(this, "serverPort", void 0);
98
+ _defineProperty(this, "serverUrl", void 0);
99
+ _defineProperty(this, "serverProcess", null);
100
+ // Whitelist of commands that are considered read-only/query operations
101
+ _defineProperty(this, "readOnlyCommands", new Set(['status', 'list', 'info', 'show', 'schema', 'artifacts', 'diff', 'log', 'graph', 'deps get', 'deps blame', 'why', 'config get', 'envs list', 'envs get', 'remote list', 'templates', 'cat-component', 'cat-lane', 'cat-object', 'cat-scope', 'lane show', 'lane list', 'lane diff', 'lane history', 'lane history-diff', 'test', 'help', 'version']));
88
102
  }
89
103
  async getHttp() {
90
104
  if (!this._http) {
@@ -92,13 +106,188 @@ class CliMcpServerMain {
92
106
  }
93
107
  return this._http;
94
108
  }
109
+ async getBitServerPort(cwd, skipValidatePortFlag = false) {
110
+ try {
111
+ const existingPort = _child_process().default.execSync(`${this.bitBin} cli-server-port ${skipValidatePortFlag}`, {
112
+ cwd,
113
+ env: _objectSpread(_objectSpread({}, process.env), {}, {
114
+ BIT_CLI_SERVER: 'true'
115
+ })
116
+ }).toString().trim();
117
+ if (!existingPort) return undefined;
118
+ return parseInt(existingPort, 10);
119
+ } catch (err) {
120
+ this.logger.error(`[MCP-DEBUG] error getting existing port from bit server at ${cwd}. err: ${err.message}`);
121
+ return undefined;
122
+ }
123
+ }
124
+
125
+ /**
126
+ * Start a new bit-server process
127
+ */
128
+ async startBitServer(cwd) {
129
+ this.logger.debug('[MCP-DEBUG] Starting new bit-server process');
130
+ return new Promise((resolve, reject) => {
131
+ try {
132
+ const serverProcess = _child_process().default.spawn(this.bitBin, ['server'], {
133
+ cwd,
134
+ stdio: ['pipe', 'pipe', 'pipe'],
135
+ detached: false
136
+ });
137
+ this.serverProcess = serverProcess;
138
+ let serverStarted = false;
139
+ let outputBuffer = '';
140
+ const timeout = setTimeout(() => {
141
+ if (!serverStarted) {
142
+ this.logger.error('[MCP-DEBUG] Timeout waiting for bit-server to start');
143
+ serverProcess.kill();
144
+ resolve(null);
145
+ }
146
+ }, 30000); // 30 second timeout
147
+
148
+ serverProcess.stdout?.on('data', data => {
149
+ const output = data.toString();
150
+ outputBuffer += output;
151
+ this.logger.debug(`[MCP-DEBUG] bit-server stdout: ${output}`);
152
+ if (output.includes('listening on port')) {
153
+ clearTimeout(timeout);
154
+ if (!serverStarted) {
155
+ serverStarted = true;
156
+ // Extract the port from the output
157
+ const portMatch = output.match(/listening on port (\d+)/);
158
+ if (portMatch && portMatch[1]) {
159
+ const port = parseInt(portMatch[1], 10);
160
+ this.logger.debug(`[MCP-DEBUG] bit-server started on port ${port}`);
161
+ this.serverPort = port;
162
+ this.serverUrl = `http://localhost:${port}/api`;
163
+ resolve(port);
164
+ }
165
+ }
166
+ }
167
+ });
168
+ serverProcess.stderr?.on('data', data => {
169
+ const error = data.toString();
170
+ outputBuffer += error;
171
+ this.logger.debug(`[MCP-DEBUG] bit-server stderr: ${error}`);
172
+ });
173
+ serverProcess.on('error', err => {
174
+ clearTimeout(timeout);
175
+ this.logger.error(`[MCP-DEBUG] Failed to start bit-server: ${err.message}`);
176
+ reject(err);
177
+ });
178
+ serverProcess.on('exit', (code, signal) => {
179
+ clearTimeout(timeout);
180
+ if (!serverStarted) {
181
+ this.logger.error(`[MCP-DEBUG] bit-server exited with code ${code}, signal ${signal}`);
182
+ this.logger.debug(`[MCP-DEBUG] bit-server output: ${outputBuffer}`);
183
+ resolve(null);
184
+ }
185
+ });
186
+ const killServerProcess = () => {
187
+ if (this.serverProcess && !this.serverProcess.killed) {
188
+ this.logger.debug('[MCP-DEBUG] Killing bit-server process');
189
+ this.serverProcess.kill();
190
+ }
191
+ };
192
+
193
+ // Handle process cleanup
194
+ process.on('exit', () => {
195
+ killServerProcess();
196
+ });
197
+ process.on('SIGINT', () => {
198
+ killServerProcess();
199
+ process.exit();
200
+ });
201
+ process.on('SIGTERM', () => {
202
+ killServerProcess();
203
+ process.exit();
204
+ });
205
+ } catch (err) {
206
+ this.logger.error(`[MCP-DEBUG] Error spawning bit-server: ${err.message}`);
207
+ reject(err);
208
+ }
209
+ });
210
+ }
211
+
212
+ /**
213
+ * Call bit-server API endpoint using cli-raw route
214
+ */
215
+ async callBitServerAPI(command, args = [], flags = {}, cwd, isReTrying = false) {
216
+ if (!this.serverPort) {
217
+ if (!cwd) throw new Error('CWD is required to call bit-server API');
218
+ this.serverPort = await this.getBitServerPort(cwd);
219
+ if (this.serverPort) {
220
+ this.serverUrl = `http://localhost:${this.serverPort}/api`;
221
+ } else {
222
+ // No server running, try to start one
223
+ this.logger.debug('[MCP-DEBUG] No bit-server found, attempting to start one');
224
+ const startedPort = await this.startBitServer(cwd);
225
+ if (startedPort) {
226
+ this.serverPort = startedPort;
227
+ this.serverUrl = `http://localhost:${this.serverPort}/api`;
228
+ }
229
+ }
230
+ }
231
+ if (!this.serverUrl) {
232
+ throw new Error('Unable to connect to bit-server. Please ensure you are in a valid Bit workspace.');
233
+ }
234
+
235
+ // Build the command array: [command, ...args, ...flagsAsArgs]
236
+ const commandArray = [command, ...args];
237
+
238
+ // Convert flags to command line arguments
239
+ for (const [key, value] of Object.entries(flags)) {
240
+ if (value === true) {
241
+ commandArray.push(`--${key}`);
242
+ } else if (value !== false && value !== undefined) {
243
+ commandArray.push(`--${key}`, String(value));
244
+ }
245
+ }
246
+
247
+ // Resolve the real path to handle symlinks (e.g., /tmp -> /private/tmp on macOS)
248
+ const fs = require('fs');
249
+ const realCwd = fs.realpathSync(cwd);
250
+ const body = {
251
+ command: commandArray,
252
+ pwd: realCwd
253
+ };
254
+ try {
255
+ const response = await (0, _nodeFetch().default)(`${this.serverUrl}/cli-raw`, {
256
+ method: 'POST',
257
+ headers: {
258
+ 'Content-Type': 'application/json'
259
+ },
260
+ body: JSON.stringify(body)
261
+ });
262
+ if (!response.ok) {
263
+ let errorMessage = `HTTP ${response.status}: ${response.statusText}`;
264
+ try {
265
+ const errorJson = await response.json();
266
+ errorMessage = errorJson.message || errorMessage;
267
+ } catch {
268
+ // Ignore JSON parse errors
269
+ }
270
+ throw new Error(errorMessage);
271
+ }
272
+ return await response.json();
273
+ } catch (err) {
274
+ if (err.code === 'ECONNREFUSED' && !isReTrying) {
275
+ // Server is no longer running, reset cached values and try to restart
276
+ this.serverPort = undefined;
277
+ this.serverUrl = undefined;
278
+ this.logger.debug('[MCP-DEBUG] Connection refused, attempting to restart bit-server');
279
+ return this.callBitServerAPI(command, args, flags, cwd, true);
280
+ }
281
+ throw err;
282
+ }
283
+ }
95
284
  async runMcpServer(options) {
96
285
  this.logger.debug(`[MCP-DEBUG] Starting MCP server with options: ${JSON.stringify(options)}`);
97
286
  const commands = this.cli.commands;
98
287
  const extended = Boolean(options.extended);
99
288
  this.bitBin = options.bitBin || this.bitBin;
100
289
  // Default set of tools to include
101
- const defaultTools = new Set(['status', 'list', 'add', 'init', 'show', 'tag', 'snap', 'import', 'export', 'remove', 'log', 'test', 'diff', 'install', 'lane show', 'lane create', 'lane switch', 'lane merge', 'create', 'templates', 'reset', 'checkout', 'schema', 'remote-search']);
290
+ const defaultTools = new Set(['create', 'schema', 'remote-search']);
102
291
 
103
292
  // Tools to always exclude
104
293
  const alwaysExcludeTools = new Set(['login', 'logout', 'completion', 'mcp-server', 'start', 'run-action', 'watch', 'run', 'resume-export', 'server', 'serve-preview']);
@@ -169,6 +358,19 @@ class CliMcpServerMain {
169
358
  this.registerToolForRemote(server, cmdName);
170
359
  }
171
360
  });
361
+
362
+ // Register the bit_workspace_info tool
363
+ this.registerWorkspaceInfoTool(server);
364
+
365
+ // Register the bit_component_details tool
366
+ this.registerComponentDetailsTool(server);
367
+
368
+ // Register the bit_commands_info tool
369
+ this.registerCommandsInfoTool(server);
370
+
371
+ // Register arbitrary command execution tools
372
+ this.registerQueryTool(server);
373
+ this.registerExecuteTool(server);
172
374
  await server.connect(new (_stdio().StdioServerTransport)());
173
375
  }
174
376
  shouldIncludeCommand(cmdName, options) {
@@ -328,6 +530,321 @@ class CliMcpServerMain {
328
530
  };
329
531
  });
330
532
  }
533
+ registerWorkspaceInfoTool(server) {
534
+ const toolName = 'bit_workspace_info';
535
+ const description = 'Get comprehensive workspace information including status, components list, apps, templates, and dependency graph';
536
+ const schema = {
537
+ cwd: _zod().z.string().describe('Path to workspace directory'),
538
+ includeStatus: _zod().z.boolean().optional().describe('Include workspace status (default: true)'),
539
+ includeList: _zod().z.boolean().optional().describe('Include components list (default: true)'),
540
+ includeApps: _zod().z.boolean().optional().describe('Include apps list (default: false)'),
541
+ includeTemplates: _zod().z.boolean().optional().describe('Include templates list (default: false)'),
542
+ includeGraph: _zod().z.boolean().optional().describe('Include dependency graph (default: false)')
543
+ };
544
+ server.tool(toolName, description, schema, async params => {
545
+ try {
546
+ const includeStatus = params.includeStatus !== false; // Default to true
547
+ const includeList = params.includeList !== false; // Default to true
548
+ const includeApps = params.includeApps === true;
549
+ const includeTemplates = params.includeTemplates === true;
550
+ const includeGraph = params.includeGraph === true;
551
+ const workspaceInfo = {};
552
+
553
+ // Get workspace status using bit-server API with error handling
554
+ if (includeStatus) {
555
+ const statusExecution = await this.safeBitCommandExecution('status', [], {
556
+ json: true
557
+ }, params.cwd, 'get workspace status', true);
558
+ workspaceInfo.status = statusExecution.result;
559
+ }
560
+
561
+ // Get components list if requested
562
+ if (includeList) {
563
+ const listExecution = await this.safeBitCommandExecution('list', [], {
564
+ json: true
565
+ }, params.cwd, 'get components list', true);
566
+ workspaceInfo.list = listExecution.result;
567
+ }
568
+
569
+ // Get apps list if requested
570
+ if (includeApps) {
571
+ const appsExecution = await this.safeBitCommandExecution('app', ['list'], {
572
+ json: true
573
+ }, params.cwd, 'get apps list', true);
574
+ workspaceInfo.apps = appsExecution.result;
575
+ }
576
+
577
+ // Get templates list if requested
578
+ if (includeTemplates) {
579
+ const templatesExecution = await this.safeBitCommandExecution('templates', [], {
580
+ json: true
581
+ }, params.cwd, 'get templates list', true);
582
+ workspaceInfo.templates = templatesExecution.result;
583
+ }
584
+
585
+ // Get dependency graph if requested
586
+ if (includeGraph) {
587
+ const graphExecution = await this.safeBitCommandExecution('graph', [], {
588
+ json: true
589
+ }, params.cwd, 'get dependency graph', true);
590
+ workspaceInfo.graph = graphExecution.result;
591
+ }
592
+ return this.formatAsCallToolResult(workspaceInfo);
593
+ } catch (error) {
594
+ this.logger.error(`[MCP-DEBUG] Error in bit_workspace_info tool: ${error.message}`);
595
+ return this.formatErrorAsCallToolResult(error, 'getting workspace info');
596
+ }
597
+ });
598
+ }
599
+ registerComponentDetailsTool(server) {
600
+ const toolName = 'bit_component_details';
601
+ const description = 'Get detailed information about a specific component including basic info and optionally its public API schema';
602
+ const schema = {
603
+ cwd: _zod().z.string().describe('Path to workspace directory'),
604
+ componentName: _zod().z.string().describe('Component name or component ID to get details for'),
605
+ includeSchema: _zod().z.boolean().optional().describe('Include component public API schema (default: false)'),
606
+ remote: _zod().z.boolean().optional().describe('Get details from remote scope (default: false)')
607
+ };
608
+ server.tool(toolName, description, schema, async params => {
609
+ try {
610
+ const includeSchema = params.includeSchema === true;
611
+ const remote = params.remote === true;
612
+ const componentName = params.componentName;
613
+ const componentDetails = {};
614
+
615
+ // Get basic component information using bit show
616
+ const showFlags = {
617
+ json: true
618
+ };
619
+ if (remote) {
620
+ showFlags.remote = true;
621
+ }
622
+ const showExecution = await this.safeBitCommandExecution('show', [componentName], showFlags, params.cwd, 'get component show info', true);
623
+ componentDetails.show = showExecution.result;
624
+
625
+ // Get component schema (public API) if requested
626
+ if (includeSchema) {
627
+ const schemaFlags = {
628
+ json: true
629
+ };
630
+ if (remote) {
631
+ schemaFlags.remote = true;
632
+ }
633
+ const schemaExecution = await this.safeBitCommandExecution('schema', [componentName], schemaFlags, params.cwd, 'get component schema', true);
634
+ componentDetails.schema = schemaExecution.result;
635
+ }
636
+ return this.formatAsCallToolResult(componentDetails);
637
+ } catch (error) {
638
+ this.logger.error(`[MCP-DEBUG] Error in bit_component_details tool: ${error.message}`);
639
+ return this.formatErrorAsCallToolResult(error, 'getting component details');
640
+ }
641
+ });
642
+ }
643
+ registerCommandsInfoTool(server) {
644
+ const toolName = 'bit_commands_info';
645
+ const description = 'Get information about Bit commands and their groups. Specify command or subcommand to get detailed info.';
646
+ const schema = {
647
+ extendedDescription: _zod().z.boolean().optional().describe('Include extended descriptions for commands (default: false)'),
648
+ internal: _zod().z.boolean().optional().describe('Include internal/debug commands (default: false)'),
649
+ command: _zod().z.string().optional().describe('Get info for a specific command only'),
650
+ subcommand: _zod().z.string().optional().describe('Get info for subcommands of a specific main command')
651
+ };
652
+ server.tool(toolName, description, schema, async params => {
653
+ try {
654
+ const {
655
+ extendedDescription = false,
656
+ internal = false,
657
+ command: specificCommand,
658
+ subcommand: specificSubcommand
659
+ } = params;
660
+ const commandsInfo = [];
661
+ const shouldSkipCommand = cmd => {
662
+ return Boolean(cmd.private && !internal || cmd.description.startsWith('DEPRECATED'));
663
+ };
664
+ const buildCommandInfo = (cmd, parentName, parentGroup, detailed = false) => {
665
+ if (shouldSkipCommand(cmd)) return null;
666
+ const cmdName = parentName ? `${parentName} ${(0, _cli().getCommandName)(cmd)}` : (0, _cli().getCommandName)(cmd);
667
+ const groupKey = cmd.group || parentGroup;
668
+ const commandInfo = {
669
+ name: cmdName,
670
+ description: cmd.description || ''
671
+ };
672
+ if (extendedDescription && cmd.extendedDescription) {
673
+ commandInfo.extendedDescription = cmd.extendedDescription;
674
+ }
675
+ if (groupKey) commandInfo.group = this.cli.groups[groupKey] || groupKey;
676
+ if (!detailed) return commandInfo;
677
+
678
+ // Add detailed information
679
+ if (cmd.helpUrl) commandInfo.helpUrl = cmd.helpUrl;
680
+ const argsData = (0, _cli().getArgsData)(cmd);
681
+ if (argsData.length > 0) {
682
+ commandInfo.arguments = argsData.map(arg => ({
683
+ name: arg.nameRaw,
684
+ description: arg.description || '',
685
+ required: arg.required,
686
+ isArray: arg.isArray
687
+ }));
688
+ }
689
+ commandInfo.options = (0, _cli().getFlagsData)(cmd);
690
+ commandInfo.examples = cmd.examples;
691
+ if (cmd.commands && cmd.commands.length > 0) {
692
+ commandInfo.subcommands = cmd.commands.filter(subCmd => !shouldSkipCommand(subCmd)).map(subCmd => ({
693
+ name: `${cmdName} ${(0, _cli().getCommandName)(subCmd)}`,
694
+ description: subCmd.description || '',
695
+ alias: subCmd.alias || '',
696
+ private: Boolean(subCmd.private)
697
+ }));
698
+ }
699
+ return commandInfo;
700
+ };
701
+
702
+ // Handle specific command + subcommand lookup
703
+ if (specificCommand && specificSubcommand) {
704
+ this.cli.commands.forEach(cmd => {
705
+ if ((0, _cli().getCommandName)(cmd) === specificCommand && cmd.commands) {
706
+ const subCmd = cmd.commands.find(sub => (0, _cli().getCommandName)(sub) === specificSubcommand);
707
+ if (subCmd) {
708
+ const info = buildCommandInfo(subCmd, specificCommand, cmd.group, true);
709
+ if (info) commandsInfo.push(info);
710
+ }
711
+ }
712
+ });
713
+ }
714
+ // Handle subcommand-only lookup
715
+ else if (specificSubcommand && !specificCommand) {
716
+ this.cli.commands.forEach(cmd => {
717
+ if ((0, _cli().getCommandName)(cmd) === specificSubcommand && cmd.commands) {
718
+ cmd.commands.forEach(subCmd => {
719
+ const info = buildCommandInfo(subCmd, specificSubcommand, cmd.group);
720
+ if (info) commandsInfo.push(info);
721
+ });
722
+ }
723
+ });
724
+ }
725
+ // Handle specific command lookup or general listing
726
+ else {
727
+ const isDetailedMode = Boolean(specificCommand);
728
+ this.cli.commands.forEach(cmd => {
729
+ const mainCmdName = (0, _cli().getCommandName)(cmd);
730
+
731
+ // Process main command
732
+ if (!specificCommand || mainCmdName === specificCommand) {
733
+ const info = buildCommandInfo(cmd, undefined, undefined, isDetailedMode);
734
+ if (info && (!specificCommand || info.name === specificCommand)) {
735
+ commandsInfo.push(info);
736
+ }
737
+ }
738
+
739
+ // Process subcommands
740
+ if (cmd.commands) {
741
+ cmd.commands.forEach(subCmd => {
742
+ const subCmdInfo = buildCommandInfo(subCmd, mainCmdName, cmd.group, isDetailedMode);
743
+ if (subCmdInfo && (!specificCommand || subCmdInfo.name === specificCommand)) {
744
+ commandsInfo.push(subCmdInfo);
745
+ }
746
+ });
747
+ }
748
+ });
749
+ }
750
+ commandsInfo.sort((a, b) => a.name.localeCompare(b.name));
751
+ if (commandsInfo.length === 0) {
752
+ let errorMessage = 'No commands found';
753
+ if (specificCommand && specificSubcommand) {
754
+ errorMessage = `No subcommand "${specificSubcommand}" found for command: ${specificCommand}`;
755
+ } else if (specificCommand) {
756
+ errorMessage = `No command found with name: ${specificCommand}`;
757
+ } else if (specificSubcommand) {
758
+ errorMessage = `No subcommands found for command: ${specificSubcommand}`;
759
+ }
760
+ return this.formatAsCallToolResult(errorMessage);
761
+ }
762
+ const result = JSON.stringify({
763
+ total: commandsInfo.length,
764
+ commands: commandsInfo
765
+ }, null, 2);
766
+ this.logger.debug(`[MCP-DEBUG] Successfully retrieved commands info. Total: ${commandsInfo.length}`);
767
+ return this.formatAsCallToolResult(result);
768
+ } catch (error) {
769
+ this.logger.error(`[MCP-DEBUG] Error in bit_commands_info tool: ${error.message}`);
770
+ return this.formatErrorAsCallToolResult(error, 'getting commands info');
771
+ }
772
+ });
773
+ }
774
+ registerQueryTool(server) {
775
+ const toolName = 'bit_query';
776
+ const description = 'Execute read-only Bit commands that safely inspect workspace and component state without making modifications. Only whitelisted query commands are allowed for safety.';
777
+ const schema = {
778
+ cwd: _zod().z.string().describe('Path to workspace directory'),
779
+ command: _zod().z.string().describe('The Bit command to execute (e.g., "status", "show", "list")'),
780
+ args: _zod().z.array(_zod().z.string()).optional().describe('Arguments to pass to the command'),
781
+ flags: _zod().z.record(_zod().z.union([_zod().z.string(), _zod().z.boolean()])).optional().describe('Flags to pass to the command as key-value pairs')
782
+ };
783
+ server.tool(toolName, description, schema, async params => {
784
+ try {
785
+ const {
786
+ command,
787
+ args = [],
788
+ flags = {},
789
+ cwd
790
+ } = params;
791
+
792
+ // Check if command is in the read-only whitelist
793
+ // Support both single commands and subcommands (e.g., "lane show")
794
+ const fullCommand = args.length > 0 ? `${command} ${args[0]}` : command;
795
+ const isAllowed = this.readOnlyCommands.has(command) || this.readOnlyCommands.has(fullCommand);
796
+ if (!isAllowed) {
797
+ const allowedCommands = Array.from(this.readOnlyCommands).sort().join(', ');
798
+ return this.formatAsCallToolResult(`Error: Command "${command}" is not allowed in query mode. Allowed read-only commands: ${allowedCommands}`);
799
+ }
800
+
801
+ // Build command arguments
802
+ const commandArgs = [command, ...args];
803
+
804
+ // Add flags to arguments
805
+ Object.entries(flags).forEach(([key, value]) => {
806
+ if (typeof value === 'boolean' && value) {
807
+ commandArgs.push(`--${key}`);
808
+ } else if (typeof value === 'string' && value) {
809
+ commandArgs.push(`--${key}`);
810
+ commandArgs.push(value);
811
+ }
812
+ });
813
+ this.logger.debug(`[MCP-DEBUG] Executing query command: ${command} with args: ${JSON.stringify(commandArgs)}`);
814
+ const result = await this.callBitServerAPI(command, args, flags, cwd);
815
+ return this.formatAsCallToolResult(result);
816
+ } catch (error) {
817
+ this.logger.error(`[MCP-DEBUG] Error in bit_query tool: ${error.message}`);
818
+ return this.formatErrorAsCallToolResult(error, 'executing query command');
819
+ }
820
+ });
821
+ }
822
+ registerExecuteTool(server) {
823
+ const toolName = 'bit_execute';
824
+ const description = 'Execute any Bit command, including those that modify workspace or repository state. ⚠️ Use with caution as this can make permanent changes to your project. Consider using bit_query for read-only operations.';
825
+ const schema = {
826
+ cwd: _zod().z.string().describe('Path to workspace directory'),
827
+ command: _zod().z.string().describe('The Bit command to execute (e.g., "add", "tag", "export", "remove")'),
828
+ args: _zod().z.array(_zod().z.string()).optional().describe('Arguments to pass to the command'),
829
+ flags: _zod().z.record(_zod().z.union([_zod().z.string(), _zod().z.boolean()])).optional().describe('Flags to pass to the command as key-value pairs')
830
+ };
831
+ server.tool(toolName, description, schema, async params => {
832
+ try {
833
+ const {
834
+ command,
835
+ args = [],
836
+ flags = {},
837
+ cwd
838
+ } = params;
839
+ this.logger.debug(`[MCP-DEBUG] Executing command: ${command} with args: ${JSON.stringify(args)} and flags: ${JSON.stringify(flags)}`);
840
+ const result = await this.callBitServerAPI(command, args, flags, cwd);
841
+ return this.formatAsCallToolResult(result);
842
+ } catch (error) {
843
+ this.logger.error(`[MCP-DEBUG] Error in bit_execute tool: ${error.message}`);
844
+ return this.formatErrorAsCallToolResult(error, 'executing command');
845
+ }
846
+ });
847
+ }
331
848
  processSubCommands(server, parentCmd, options) {
332
849
  const parentCmdName = (0, _cli().getCommandName)(parentCmd);
333
850
  parentCmd.commands?.forEach(subCmd => {
@@ -362,6 +879,85 @@ class CliMcpServerMain {
362
879
  };
363
880
  }
364
881
  }
882
+
883
+ /**
884
+ * Helper method to execute a bit-server API call with standardized error handling
885
+ */
886
+ async executeBitServerCommand(command, args = [], flags = {}, cwd, operationName) {
887
+ try {
888
+ const result = await this.callBitServerAPI(command, args, flags, cwd);
889
+ this.logger.debug(`[MCP-DEBUG] Successfully executed ${operationName} via bit-server`);
890
+ return result;
891
+ } catch (error) {
892
+ this.logger.warn(`[MCP-DEBUG] Failed to execute ${operationName} via bit-server: ${error.message}`);
893
+ throw error;
894
+ }
895
+ }
896
+
897
+ /**
898
+ * Helper method to format any result as CallToolResult
899
+ */
900
+ formatAsCallToolResult(result) {
901
+ if (typeof result === 'string') {
902
+ return {
903
+ content: [{
904
+ type: 'text',
905
+ text: result
906
+ }]
907
+ };
908
+ } else if (typeof result === 'object') {
909
+ return {
910
+ content: [{
911
+ type: 'text',
912
+ text: JSON.stringify(result, null, 2)
913
+ }]
914
+ };
915
+ } else {
916
+ return {
917
+ content: [{
918
+ type: 'text',
919
+ text: String(result)
920
+ }]
921
+ };
922
+ }
923
+ }
924
+
925
+ /**
926
+ * Helper method to format error as CallToolResult
927
+ */
928
+ formatErrorAsCallToolResult(error, operation) {
929
+ return {
930
+ content: [{
931
+ type: 'text',
932
+ text: `Error ${operation}: ${error.message}`
933
+ }]
934
+ };
935
+ }
936
+
937
+ /**
938
+ * Helper method to safely execute a bit command with error handling
939
+ */
940
+ async safeBitCommandExecution(command, args = [], flags = {}, cwd, operationName, includeErrorInResult = false) {
941
+ try {
942
+ const result = await this.executeBitServerCommand(command, args, flags, cwd, operationName);
943
+ return {
944
+ success: true,
945
+ result
946
+ };
947
+ } catch (error) {
948
+ if (includeErrorInResult) {
949
+ return {
950
+ success: false,
951
+ result: {
952
+ error: `Failed to ${operationName}: ${error.message}`
953
+ },
954
+ error: error.message
955
+ };
956
+ } else {
957
+ throw error;
958
+ }
959
+ }
960
+ }
365
961
  static async provider([cli, loggerMain]) {
366
962
  const logger = loggerMain.createLogger(_cliMcpServer().CliMcpServerAspect.id);
367
963
  const mcpServer = new CliMcpServerMain(cli, logger);
@@ -1 +1 @@
1
- {"version":3,"names":["_cli","data","require","_child_process","_interopRequireDefault","_cliMcpServer","_mcpServer","_mcp","_stdio","_zod","_logger","_scope","_legacy","e","__esModule","default","_defineProperty","r","t","_toPropertyKey","Object","defineProperty","value","enumerable","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","CliMcpServerMain","constructor","cli","logger","getHttp","_http","Http","connect","SYMPHONY_GRAPHQL","CENTRAL_BIT_HUB_NAME","runMcpServer","options","debug","JSON","stringify","commands","extended","Boolean","bitBin","defaultTools","Set","alwaysExcludeTools","includeOnlySet","includeOnly","split","map","cmd","trim","Array","from","join","additionalCommandsSet","includeAdditional","userExcludeSet","exclude","server","McpServer","name","version","consumerProjectTools","consumerProject","isConsumerProjectMode","warn","filterOptions","forEach","cmdName","getCommandName","shouldIncludeCommand","registerToolForCommand","length","processSubCommands","remoteCommands","registerToolForRemote","StdioServerTransport","has","shouldInclude","buildZodSchema","config","schema","cwd","z","string","describe","argsData","arg","desc","description","nameRaw","isArray","nameCamelCase","required","array","optional","flagsData","flag","type","boolean","buildCommandArgs","params","args","val","undefined","item","push","stringValue","includes","getToolName","replace","parentCmd","toolName","extendedDescription","getArgsData","getFlagsData","tool","argsToRun","runBit","registerRemoteSearchTool","queryStr","http","results","search","components","content","text","formattedResults","result","parentCmdName","subCmd","subCmdName","fullCmdName","cmdOutput","childProcess","execSync","toString","error","message","provider","loggerMain","createLogger","CliMcpServerAspect","id","mcpServer","register","McpServerCmd","exports","CLIAspect","LoggerAspect","MainRuntime","addRuntime","_default"],"sources":["cli-mcp-server.main.runtime.ts"],"sourcesContent":["/* eslint-disable import/extensions */\n/* eslint-disable import/no-unresolved */\n\nimport { CLIAspect, CLIMain, Command, getArgsData, getCommandName, getFlagsData, MainRuntime } from '@teambit/cli';\nimport childProcess from 'child_process';\nimport { CliMcpServerAspect } from './cli-mcp-server.aspect';\nimport { McpServerCmd } from './mcp-server.cmd';\nimport { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';\nimport { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { z } from 'zod';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { Http } from '@teambit/scope.network';\nimport { CENTRAL_BIT_HUB_NAME, SYMPHONY_GRAPHQL } from '@teambit/legacy.constants';\n\ninterface CommandFilterOptions {\n defaultTools: Set<string>;\n additionalCommandsSet?: Set<string>;\n userExcludeSet?: Set<string>;\n alwaysExcludeTools: Set<string>;\n extended: boolean;\n includeOnlySet?: Set<string>;\n consumerProject: boolean;\n consumerProjectTools: Set<string>;\n}\n\ninterface CommandConfig {\n name: string;\n description: string;\n argsData: ReturnType<typeof getArgsData>;\n flagsData: ReturnType<typeof getFlagsData>;\n}\n\nexport class CliMcpServerMain {\n private bitBin = 'bit';\n private _http: Http;\n private isConsumerProjectMode: boolean = false;\n constructor(\n private cli: CLIMain,\n private logger: Logger\n ) {}\n\n async getHttp(): Promise<Http> {\n if (!this._http) {\n this._http = await Http.connect(SYMPHONY_GRAPHQL, CENTRAL_BIT_HUB_NAME);\n }\n return this._http;\n }\n\n async runMcpServer(options: {\n extended?: boolean;\n includeOnly?: string;\n includeAdditional?: string;\n exclude?: string;\n bitBin?: string;\n consumerProject?: boolean;\n }) {\n this.logger.debug(`[MCP-DEBUG] Starting MCP server with options: ${JSON.stringify(options)}`);\n const commands = this.cli.commands;\n const extended = Boolean(options.extended);\n this.bitBin = options.bitBin || this.bitBin;\n // Default set of tools to include\n const defaultTools = new Set([\n 'status',\n 'list',\n 'add',\n 'init',\n 'show',\n 'tag',\n 'snap',\n 'import',\n 'export',\n 'remove',\n 'log',\n 'test',\n 'diff',\n 'install',\n 'lane show',\n 'lane create',\n 'lane switch',\n 'lane merge',\n 'create',\n 'templates',\n 'reset',\n 'checkout',\n 'schema',\n 'remote-search',\n ]);\n\n // Tools to always exclude\n const alwaysExcludeTools = new Set([\n 'login',\n 'logout',\n 'completion',\n 'mcp-server',\n 'start',\n 'run-action',\n 'watch',\n 'run',\n 'resume-export',\n 'server',\n 'serve-preview',\n ]);\n\n // Parse command strings from flag options\n let includeOnlySet: Set<string> | undefined;\n if (options.includeOnly) {\n includeOnlySet = new Set(options.includeOnly.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Including only commands: ${Array.from(includeOnlySet).join(', ')}`);\n }\n\n let additionalCommandsSet: Set<string> | undefined;\n if (options.includeAdditional) {\n additionalCommandsSet = new Set(options.includeAdditional.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Including additional commands: ${Array.from(additionalCommandsSet).join(', ')}`);\n }\n\n let userExcludeSet: Set<string> | undefined;\n if (options.exclude) {\n userExcludeSet = new Set(options.exclude.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Excluding commands: ${Array.from(userExcludeSet).join(', ')}`);\n }\n\n const server = new McpServer({\n name: 'bit-cli-mcp',\n version: '0.0.1',\n });\n\n // Set of tools for consumer projects (non-Bit workspaces)\n const consumerProjectTools = new Set(['schema', 'show', 'remote-search']);\n\n const consumerProject = Boolean(options.consumerProject);\n\n // Store consumer project mode globally in the class\n this.isConsumerProjectMode = consumerProject;\n\n // Validate flags combination\n if (consumerProject) {\n this.logger.debug(\n `[MCP-DEBUG] Running MCP server in consumer project mode (for non-Bit workspaces) with tools: ${Array.from(consumerProjectTools).join(', ')}`\n );\n if (options.includeAdditional) {\n this.logger.debug(\n `[MCP-DEBUG] Additional tools enabled in consumer project mode: ${options.includeAdditional}`\n );\n }\n if (extended) {\n this.logger.warn(\n '[MCP-DEBUG] Warning: --consumer-project and --extended flags were both provided. The --extended flag will be ignored.'\n );\n }\n }\n\n const filterOptions: CommandFilterOptions = {\n defaultTools,\n additionalCommandsSet,\n userExcludeSet,\n alwaysExcludeTools,\n extended: consumerProject ? false : extended, // Ignore extended when consumerProject is true\n includeOnlySet,\n consumerProject,\n consumerProjectTools,\n };\n\n commands.forEach((cmd) => {\n const cmdName = getCommandName(cmd);\n\n if (this.shouldIncludeCommand(cmdName, filterOptions)) {\n this.registerToolForCommand(server, cmd);\n }\n\n // Process sub-commands\n if (cmd.commands && cmd.commands.length) {\n this.processSubCommands(server, cmd, filterOptions);\n }\n });\n\n const remoteCommands = ['remote-search'];\n remoteCommands.forEach((cmdName) => {\n if (this.shouldIncludeCommand(cmdName, filterOptions)) {\n this.registerToolForRemote(server, cmdName);\n }\n });\n\n await server.connect(new StdioServerTransport());\n }\n\n private shouldIncludeCommand(cmdName: string, options: CommandFilterOptions): boolean {\n // Always exclude certain commands\n if (options.alwaysExcludeTools.has(cmdName)) return false;\n\n // User-specified exclude takes precedence\n if (options.userExcludeSet?.has(cmdName)) {\n this.logger.debug(`[MCP-DEBUG] Excluding command due to --exclude flag: ${cmdName}`);\n return false;\n }\n\n // If includeOnly is specified, only include those specific commands\n if (options.includeOnlySet) {\n const shouldInclude = options.includeOnlySet.has(cmdName);\n if (shouldInclude) {\n this.logger.debug(`[MCP-DEBUG] Including command due to --include-only flag: ${cmdName}`);\n }\n return shouldInclude;\n }\n\n // Extended mode includes all commands except excluded ones\n if (options.extended) return true;\n\n // Consumer project mode: only include consumer project tools + any additional specified\n if (options.consumerProject) {\n const shouldInclude =\n options.consumerProjectTools.has(cmdName) || (options.additionalCommandsSet?.has(cmdName) ?? false);\n if (shouldInclude) {\n this.logger.debug(`[MCP-DEBUG] Including command in consumer project mode: ${cmdName}`);\n }\n return shouldInclude;\n }\n\n // Default mode: include default tools + any additional specified\n return options.defaultTools.has(cmdName) || (options.additionalCommandsSet?.has(cmdName) ?? false);\n }\n\n private buildZodSchema(config: CommandConfig): Record<string, any> {\n const schema: Record<string, any> = {\n // Add cwd parameter as mandatory to all commands\n cwd: z.string().describe('Path to workspace'),\n };\n\n config.argsData.forEach((arg) => {\n const desc = arg.description || `Positional argument: ${arg.nameRaw}`;\n if (arg.isArray) {\n schema[arg.nameCamelCase] = arg.required\n ? z.array(z.string()).describe(desc)\n : z.array(z.string()).optional().describe(desc);\n } else {\n schema[arg.nameCamelCase] = arg.required ? z.string().describe(desc) : z.string().optional().describe(desc);\n }\n });\n\n config.flagsData.forEach((flag) => {\n const type = flag.type;\n schema[flag.name] =\n type === 'string'\n ? z.string().optional().describe(flag.description)\n : z.boolean().optional().describe(flag.description);\n });\n\n return schema;\n }\n\n private buildCommandArgs(config: CommandConfig, params: any): string[] {\n // Split the command name on spaces to properly handle subcommands\n const args: string[] = config.name.split(' ');\n\n // Add positional arguments in order\n config.argsData.forEach((arg) => {\n const val = params[arg.nameCamelCase];\n if (val === undefined) return;\n\n if (arg.isArray && Array.isArray(val)) {\n val.forEach((item) => args.push(item));\n } else {\n args.push(val);\n }\n });\n\n // Add options as flags\n config.flagsData.forEach((flag) => {\n const name = flag.name;\n const type = flag.type;\n const val = params[name];\n if (val === undefined) return;\n if (type === 'boolean' && val) {\n args.push(`--${name}`);\n } else if (type === 'string' && val) {\n // Check if the string value contains spaces and quote it if necessary\n const stringValue = String(val);\n if (stringValue.includes(' ')) {\n args.push(`--${name}`, `\"${stringValue}\"`);\n } else {\n args.push(`--${name}`, stringValue);\n }\n }\n });\n\n return args;\n }\n\n private getToolName(name: string): string {\n // replace white spaces (\\s) and dashes (-) with underscores (_)\n return `bit_${name}`.replace(/[-\\s]/g, '_');\n }\n\n private registerToolForCommand(server: McpServer, cmd: Command, parentCmd?: Command) {\n const cmdName = parentCmd ? `${getCommandName(parentCmd)} ${getCommandName(cmd)}` : getCommandName(cmd);\n const toolName = this.getToolName(cmdName);\n\n // Modify description for show and schema commands in consumer project mode\n let description = `${cmd.description}${cmd.extendedDescription ? `.\\n(${cmd.extendedDescription})` : ''}`;\n if (this.isConsumerProjectMode && (cmdName === 'show' || cmdName === 'schema')) {\n description += `\\n(In consumer project mode, --remote flag is automatically added)`;\n }\n\n const config: CommandConfig = {\n name: cmdName,\n description,\n argsData: getArgsData(cmd),\n flagsData: getFlagsData(cmd),\n };\n\n const schema = this.buildZodSchema(config);\n\n server.tool(toolName, config.description, schema, async (params: any) => {\n const argsToRun = this.buildCommandArgs(config, params);\n\n // Special handling for consumer projects - auto-add --remote flag for show and schema commands\n if (this.isConsumerProjectMode && (cmdName === 'show' || cmdName === 'schema')) {\n if (!argsToRun.includes('--remote')) {\n this.logger.debug(`[MCP-DEBUG] Auto-adding --remote flag for ${cmdName} in consumer project mode`);\n argsToRun.push('--remote');\n }\n if (cmdName === 'show' && !argsToRun.includes('--legacy')) {\n this.logger.debug(`[MCP-DEBUG] Auto-adding --legacy flag for ${cmdName} in consumer project mode`);\n argsToRun.push('--legacy');\n }\n }\n\n return this.runBit(argsToRun, params.cwd);\n });\n }\n\n private registerToolForRemote(server: McpServer, name: string) {\n if (name === 'remote-search') {\n this.registerRemoteSearchTool(server);\n }\n }\n\n private registerRemoteSearchTool(server: McpServer) {\n const toolName = this.getToolName('remote-search');\n const description = 'Search for components in remote scopes';\n const schema: Record<string, any> = {\n queryStr: z.string().describe('Search query string'),\n };\n server.tool(toolName, description, schema, async (params: any) => {\n const http = await this.getHttp();\n const results = await http.search(params.queryStr);\n this.logger.debug(`[MCP-DEBUG] Search results: ${JSON.stringify(results)}`);\n if (!results?.components || results.components.length === 0) {\n return { content: [{ type: 'text', text: 'No results found' }] };\n }\n const formattedResults = results.components.map((result) => ({\n type: 'text',\n text: result,\n }));\n return { content: formattedResults } as CallToolResult;\n });\n }\n\n private processSubCommands(server: McpServer, parentCmd: Command, options: CommandFilterOptions) {\n const parentCmdName = getCommandName(parentCmd);\n\n parentCmd.commands?.forEach((subCmd) => {\n const subCmdName = getCommandName(subCmd);\n const fullCmdName = `${parentCmdName} ${subCmdName}`;\n\n if (this.shouldIncludeCommand(fullCmdName, options)) {\n this.registerToolForCommand(server, subCmd, parentCmd);\n }\n });\n }\n\n private async runBit(args: string[], cwd: string): Promise<CallToolResult> {\n this.logger.debug(`[MCP-DEBUG] Running: ${this.bitBin} ${args.join(' ')} in ${cwd}`);\n const cmd = `${this.bitBin} ${args.join(' ')}`;\n try {\n const cmdOutput = childProcess.execSync(cmd, { cwd });\n this.logger.debug(`[MCP-DEBUG] result. stdout: ${cmdOutput}`);\n\n return { content: [{ type: 'text', text: cmdOutput.toString() }] };\n } catch (error: any) {\n this.logger.error(`[MCP-DEBUG] Error executing ${cmd}`, error);\n\n return { content: [{ type: 'text', text: error.message }] };\n }\n }\n\n static slots = [];\n static dependencies = [CLIAspect, LoggerAspect];\n static runtime = MainRuntime;\n static async provider([cli, loggerMain]: [CLIMain, LoggerMain]) {\n const logger = loggerMain.createLogger(CliMcpServerAspect.id);\n const mcpServer = new CliMcpServerMain(cli, logger);\n cli.register(new McpServerCmd(mcpServer));\n return mcpServer;\n }\n}\n\nCliMcpServerAspect.addRuntime(CliMcpServerMain);\n\nexport default CliMcpServerMain;\n"],"mappings":"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","ignoreList":[]}
1
+ {"version":3,"names":["_cli","data","require","_child_process","_interopRequireDefault","_cliMcpServer","_mcpServer","_mcp","_stdio","_zod","_logger","_scope","_legacy","_nodeFetch","e","__esModule","default","ownKeys","r","t","Object","keys","getOwnPropertySymbols","o","filter","getOwnPropertyDescriptor","enumerable","push","apply","_objectSpread","arguments","length","forEach","_defineProperty","getOwnPropertyDescriptors","defineProperties","defineProperty","_toPropertyKey","value","configurable","writable","i","_toPrimitive","Symbol","toPrimitive","call","TypeError","String","Number","CliMcpServerMain","constructor","cli","logger","Set","getHttp","_http","Http","connect","SYMPHONY_GRAPHQL","CENTRAL_BIT_HUB_NAME","getBitServerPort","cwd","skipValidatePortFlag","existingPort","childProcess","execSync","bitBin","env","process","BIT_CLI_SERVER","toString","trim","undefined","parseInt","err","error","message","startBitServer","debug","Promise","resolve","reject","serverProcess","spawn","stdio","detached","serverStarted","outputBuffer","timeout","setTimeout","kill","stdout","on","output","includes","clearTimeout","portMatch","match","port","serverPort","serverUrl","stderr","code","signal","killServerProcess","killed","exit","callBitServerAPI","command","args","flags","isReTrying","Error","startedPort","commandArray","key","entries","fs","realCwd","realpathSync","body","pwd","response","fetch","method","headers","JSON","stringify","ok","errorMessage","status","statusText","errorJson","json","runMcpServer","options","commands","extended","Boolean","defaultTools","alwaysExcludeTools","includeOnlySet","includeOnly","split","map","cmd","Array","from","join","additionalCommandsSet","includeAdditional","userExcludeSet","exclude","server","McpServer","name","version","consumerProjectTools","consumerProject","isConsumerProjectMode","warn","filterOptions","cmdName","getCommandName","shouldIncludeCommand","registerToolForCommand","processSubCommands","remoteCommands","registerToolForRemote","registerWorkspaceInfoTool","registerComponentDetailsTool","registerCommandsInfoTool","registerQueryTool","registerExecuteTool","StdioServerTransport","has","shouldInclude","buildZodSchema","config","schema","z","string","describe","argsData","arg","desc","description","nameRaw","isArray","nameCamelCase","required","array","optional","flagsData","flag","type","boolean","buildCommandArgs","params","val","item","stringValue","getToolName","replace","parentCmd","toolName","extendedDescription","getArgsData","getFlagsData","tool","argsToRun","runBit","registerRemoteSearchTool","queryStr","http","results","search","components","content","text","formattedResults","result","includeStatus","includeList","includeApps","includeTemplates","includeGraph","workspaceInfo","statusExecution","safeBitCommandExecution","listExecution","list","appsExecution","apps","templatesExecution","templates","graphExecution","graph","formatAsCallToolResult","formatErrorAsCallToolResult","componentName","includeSchema","remote","componentDetails","showFlags","showExecution","show","schemaFlags","schemaExecution","internal","subcommand","specificCommand","specificSubcommand","commandsInfo","shouldSkipCommand","private","startsWith","buildCommandInfo","parentName","parentGroup","detailed","groupKey","group","commandInfo","groups","helpUrl","examples","subcommands","subCmd","alias","find","sub","info","isDetailedMode","mainCmdName","subCmdInfo","sort","a","b","localeCompare","total","record","union","fullCommand","isAllowed","readOnlyCommands","allowedCommands","commandArgs","parentCmdName","subCmdName","fullCmdName","cmdOutput","executeBitServerCommand","operationName","operation","includeErrorInResult","success","provider","loggerMain","createLogger","CliMcpServerAspect","id","mcpServer","register","McpServerCmd","exports","CLIAspect","LoggerAspect","MainRuntime","addRuntime","_default"],"sources":["cli-mcp-server.main.runtime.ts"],"sourcesContent":["/* eslint-disable import/extensions */\n/* eslint-disable import/no-unresolved */\n\nimport { CLIAspect, CLIMain, Command, getArgsData, getCommandName, getFlagsData, MainRuntime } from '@teambit/cli';\nimport childProcess from 'child_process';\nimport { CliMcpServerAspect } from './cli-mcp-server.aspect';\nimport { McpServerCmd } from './mcp-server.cmd';\nimport { McpServer } from '@modelcontextprotocol/sdk/server/mcp.js';\nimport { StdioServerTransport } from '@modelcontextprotocol/sdk/server/stdio.js';\nimport { CallToolResult } from '@modelcontextprotocol/sdk/types.js';\nimport { z } from 'zod';\nimport { Logger, LoggerAspect, LoggerMain } from '@teambit/logger';\nimport { Http } from '@teambit/scope.network';\nimport { CENTRAL_BIT_HUB_NAME, SYMPHONY_GRAPHQL } from '@teambit/legacy.constants';\nimport fetch from 'node-fetch';\n\ninterface CommandFilterOptions {\n defaultTools: Set<string>;\n additionalCommandsSet?: Set<string>;\n userExcludeSet?: Set<string>;\n alwaysExcludeTools: Set<string>;\n extended: boolean;\n includeOnlySet?: Set<string>;\n consumerProject: boolean;\n consumerProjectTools: Set<string>;\n}\n\ninterface CommandConfig {\n name: string;\n description: string;\n argsData: ReturnType<typeof getArgsData>;\n flagsData: ReturnType<typeof getFlagsData>;\n}\n\nexport class CliMcpServerMain {\n private bitBin = 'bit';\n private _http: Http;\n private isConsumerProjectMode: boolean = false;\n private serverPort?: number;\n private serverUrl?: string;\n private serverProcess: childProcess.ChildProcess | null = null;\n\n // Whitelist of commands that are considered read-only/query operations\n private readonly readOnlyCommands = new Set([\n 'status',\n 'list',\n 'info',\n 'show',\n 'schema',\n 'artifacts',\n 'diff',\n 'log',\n 'graph',\n 'deps get',\n 'deps blame',\n 'why',\n 'config get',\n 'envs list',\n 'envs get',\n 'remote list',\n 'templates',\n 'cat-component',\n 'cat-lane',\n 'cat-object',\n 'cat-scope',\n 'lane show',\n 'lane list',\n 'lane diff',\n 'lane history',\n 'lane history-diff',\n 'test',\n 'help',\n 'version',\n ]);\n\n constructor(\n private cli: CLIMain,\n private logger: Logger\n ) {}\n\n async getHttp(): Promise<Http> {\n if (!this._http) {\n this._http = await Http.connect(SYMPHONY_GRAPHQL, CENTRAL_BIT_HUB_NAME);\n }\n return this._http;\n }\n\n private async getBitServerPort(cwd: string, skipValidatePortFlag = false): Promise<number | undefined> {\n try {\n const existingPort = childProcess\n .execSync(`${this.bitBin} cli-server-port ${skipValidatePortFlag}`, {\n cwd,\n env: { ...process.env, BIT_CLI_SERVER: 'true' },\n })\n .toString()\n .trim();\n if (!existingPort) return undefined;\n return parseInt(existingPort, 10);\n } catch (err: any) {\n this.logger.error(`[MCP-DEBUG] error getting existing port from bit server at ${cwd}. err: ${err.message}`);\n return undefined;\n }\n }\n\n /**\n * Start a new bit-server process\n */\n private async startBitServer(cwd: string): Promise<number | null> {\n this.logger.debug('[MCP-DEBUG] Starting new bit-server process');\n\n return new Promise((resolve, reject) => {\n try {\n const serverProcess = childProcess.spawn(this.bitBin, ['server'], {\n cwd,\n stdio: ['pipe', 'pipe', 'pipe'],\n detached: false,\n });\n\n this.serverProcess = serverProcess;\n\n let serverStarted = false;\n let outputBuffer = '';\n\n const timeout = setTimeout(() => {\n if (!serverStarted) {\n this.logger.error('[MCP-DEBUG] Timeout waiting for bit-server to start');\n serverProcess.kill();\n resolve(null);\n }\n }, 30000); // 30 second timeout\n\n serverProcess.stdout?.on('data', (data) => {\n const output = data.toString();\n outputBuffer += output;\n this.logger.debug(`[MCP-DEBUG] bit-server stdout: ${output}`);\n if (output.includes('listening on port')) {\n clearTimeout(timeout);\n if (!serverStarted) {\n serverStarted = true;\n // Extract the port from the output\n const portMatch = output.match(/listening on port (\\d+)/);\n if (portMatch && portMatch[1]) {\n const port = parseInt(portMatch[1], 10);\n this.logger.debug(`[MCP-DEBUG] bit-server started on port ${port}`);\n this.serverPort = port;\n this.serverUrl = `http://localhost:${port}/api`;\n resolve(port);\n }\n }\n }\n });\n\n serverProcess.stderr?.on('data', (data) => {\n const error = data.toString();\n outputBuffer += error;\n this.logger.debug(`[MCP-DEBUG] bit-server stderr: ${error}`);\n });\n\n serverProcess.on('error', (err) => {\n clearTimeout(timeout);\n this.logger.error(`[MCP-DEBUG] Failed to start bit-server: ${err.message}`);\n reject(err);\n });\n\n serverProcess.on('exit', (code, signal) => {\n clearTimeout(timeout);\n if (!serverStarted) {\n this.logger.error(`[MCP-DEBUG] bit-server exited with code ${code}, signal ${signal}`);\n this.logger.debug(`[MCP-DEBUG] bit-server output: ${outputBuffer}`);\n resolve(null);\n }\n });\n\n const killServerProcess = () => {\n if (this.serverProcess && !this.serverProcess.killed) {\n this.logger.debug('[MCP-DEBUG] Killing bit-server process');\n this.serverProcess.kill();\n }\n };\n\n // Handle process cleanup\n process.on('exit', () => {\n killServerProcess();\n });\n\n process.on('SIGINT', () => {\n killServerProcess();\n process.exit();\n });\n\n process.on('SIGTERM', () => {\n killServerProcess();\n process.exit();\n });\n } catch (err) {\n this.logger.error(`[MCP-DEBUG] Error spawning bit-server: ${(err as Error).message}`);\n reject(err);\n }\n });\n }\n\n /**\n * Call bit-server API endpoint using cli-raw route\n */\n private async callBitServerAPI(\n command: string,\n args: string[] = [],\n flags: Record<string, any> = {},\n cwd: string,\n isReTrying = false\n ): Promise<any> {\n if (!this.serverPort) {\n if (!cwd) throw new Error('CWD is required to call bit-server API');\n this.serverPort = await this.getBitServerPort(cwd);\n if (this.serverPort) {\n this.serverUrl = `http://localhost:${this.serverPort}/api`;\n } else {\n // No server running, try to start one\n this.logger.debug('[MCP-DEBUG] No bit-server found, attempting to start one');\n const startedPort = await this.startBitServer(cwd);\n if (startedPort) {\n this.serverPort = startedPort;\n this.serverUrl = `http://localhost:${this.serverPort}/api`;\n }\n }\n }\n\n if (!this.serverUrl) {\n throw new Error('Unable to connect to bit-server. Please ensure you are in a valid Bit workspace.');\n }\n\n // Build the command array: [command, ...args, ...flagsAsArgs]\n const commandArray = [command, ...args];\n\n // Convert flags to command line arguments\n for (const [key, value] of Object.entries(flags)) {\n if (value === true) {\n commandArray.push(`--${key}`);\n } else if (value !== false && value !== undefined) {\n commandArray.push(`--${key}`, String(value));\n }\n }\n\n // Resolve the real path to handle symlinks (e.g., /tmp -> /private/tmp on macOS)\n const fs = require('fs');\n const realCwd = fs.realpathSync(cwd);\n\n const body = {\n command: commandArray,\n pwd: realCwd,\n };\n\n try {\n const response = await fetch(`${this.serverUrl}/cli-raw`, {\n method: 'POST',\n headers: { 'Content-Type': 'application/json' },\n body: JSON.stringify(body),\n });\n\n if (!response.ok) {\n let errorMessage = `HTTP ${response.status}: ${response.statusText}`;\n try {\n const errorJson = await response.json();\n errorMessage = errorJson.message || errorMessage;\n } catch {\n // Ignore JSON parse errors\n }\n throw new Error(errorMessage);\n }\n\n return await response.json();\n } catch (err: any) {\n if (err.code === 'ECONNREFUSED' && !isReTrying) {\n // Server is no longer running, reset cached values and try to restart\n this.serverPort = undefined;\n this.serverUrl = undefined;\n this.logger.debug('[MCP-DEBUG] Connection refused, attempting to restart bit-server');\n return this.callBitServerAPI(command, args, flags, cwd, true);\n }\n throw err;\n }\n }\n\n async runMcpServer(options: {\n extended?: boolean;\n includeOnly?: string;\n includeAdditional?: string;\n exclude?: string;\n bitBin?: string;\n consumerProject?: boolean;\n }) {\n this.logger.debug(`[MCP-DEBUG] Starting MCP server with options: ${JSON.stringify(options)}`);\n const commands = this.cli.commands;\n const extended = Boolean(options.extended);\n this.bitBin = options.bitBin || this.bitBin;\n // Default set of tools to include\n const defaultTools = new Set(['create', 'schema', 'remote-search']);\n\n // Tools to always exclude\n const alwaysExcludeTools = new Set([\n 'login',\n 'logout',\n 'completion',\n 'mcp-server',\n 'start',\n 'run-action',\n 'watch',\n 'run',\n 'resume-export',\n 'server',\n 'serve-preview',\n ]);\n\n // Parse command strings from flag options\n let includeOnlySet: Set<string> | undefined;\n if (options.includeOnly) {\n includeOnlySet = new Set(options.includeOnly.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Including only commands: ${Array.from(includeOnlySet).join(', ')}`);\n }\n\n let additionalCommandsSet: Set<string> | undefined;\n if (options.includeAdditional) {\n additionalCommandsSet = new Set(options.includeAdditional.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Including additional commands: ${Array.from(additionalCommandsSet).join(', ')}`);\n }\n\n let userExcludeSet: Set<string> | undefined;\n if (options.exclude) {\n userExcludeSet = new Set(options.exclude.split(',').map((cmd) => cmd.trim()));\n this.logger.debug(`[MCP-DEBUG] Excluding commands: ${Array.from(userExcludeSet).join(', ')}`);\n }\n\n const server = new McpServer({\n name: 'bit-cli-mcp',\n version: '0.0.1',\n });\n\n // Set of tools for consumer projects (non-Bit workspaces)\n const consumerProjectTools = new Set(['schema', 'show', 'remote-search']);\n\n const consumerProject = Boolean(options.consumerProject);\n\n // Store consumer project mode globally in the class\n this.isConsumerProjectMode = consumerProject;\n\n // Validate flags combination\n if (consumerProject) {\n this.logger.debug(\n `[MCP-DEBUG] Running MCP server in consumer project mode (for non-Bit workspaces) with tools: ${Array.from(consumerProjectTools).join(', ')}`\n );\n if (options.includeAdditional) {\n this.logger.debug(\n `[MCP-DEBUG] Additional tools enabled in consumer project mode: ${options.includeAdditional}`\n );\n }\n if (extended) {\n this.logger.warn(\n '[MCP-DEBUG] Warning: --consumer-project and --extended flags were both provided. The --extended flag will be ignored.'\n );\n }\n }\n\n const filterOptions: CommandFilterOptions = {\n defaultTools,\n additionalCommandsSet,\n userExcludeSet,\n alwaysExcludeTools,\n extended: consumerProject ? false : extended, // Ignore extended when consumerProject is true\n includeOnlySet,\n consumerProject,\n consumerProjectTools,\n };\n\n commands.forEach((cmd) => {\n const cmdName = getCommandName(cmd);\n\n if (this.shouldIncludeCommand(cmdName, filterOptions)) {\n this.registerToolForCommand(server, cmd);\n }\n\n // Process sub-commands\n if (cmd.commands && cmd.commands.length) {\n this.processSubCommands(server, cmd, filterOptions);\n }\n });\n\n const remoteCommands = ['remote-search'];\n remoteCommands.forEach((cmdName) => {\n if (this.shouldIncludeCommand(cmdName, filterOptions)) {\n this.registerToolForRemote(server, cmdName);\n }\n });\n\n // Register the bit_workspace_info tool\n this.registerWorkspaceInfoTool(server);\n\n // Register the bit_component_details tool\n this.registerComponentDetailsTool(server);\n\n // Register the bit_commands_info tool\n this.registerCommandsInfoTool(server);\n\n // Register arbitrary command execution tools\n this.registerQueryTool(server);\n this.registerExecuteTool(server);\n\n await server.connect(new StdioServerTransport());\n }\n\n private shouldIncludeCommand(cmdName: string, options: CommandFilterOptions): boolean {\n // Always exclude certain commands\n if (options.alwaysExcludeTools.has(cmdName)) return false;\n\n // User-specified exclude takes precedence\n if (options.userExcludeSet?.has(cmdName)) {\n this.logger.debug(`[MCP-DEBUG] Excluding command due to --exclude flag: ${cmdName}`);\n return false;\n }\n\n // If includeOnly is specified, only include those specific commands\n if (options.includeOnlySet) {\n const shouldInclude = options.includeOnlySet.has(cmdName);\n if (shouldInclude) {\n this.logger.debug(`[MCP-DEBUG] Including command due to --include-only flag: ${cmdName}`);\n }\n return shouldInclude;\n }\n\n // Extended mode includes all commands except excluded ones\n if (options.extended) return true;\n\n // Consumer project mode: only include consumer project tools + any additional specified\n if (options.consumerProject) {\n const shouldInclude =\n options.consumerProjectTools.has(cmdName) || (options.additionalCommandsSet?.has(cmdName) ?? false);\n if (shouldInclude) {\n this.logger.debug(`[MCP-DEBUG] Including command in consumer project mode: ${cmdName}`);\n }\n return shouldInclude;\n }\n\n // Default mode: include default tools + any additional specified\n return options.defaultTools.has(cmdName) || (options.additionalCommandsSet?.has(cmdName) ?? false);\n }\n\n private buildZodSchema(config: CommandConfig): Record<string, any> {\n const schema: Record<string, any> = {\n // Add cwd parameter as mandatory to all commands\n cwd: z.string().describe('Path to workspace'),\n };\n\n config.argsData.forEach((arg) => {\n const desc = arg.description || `Positional argument: ${arg.nameRaw}`;\n if (arg.isArray) {\n schema[arg.nameCamelCase] = arg.required\n ? z.array(z.string()).describe(desc)\n : z.array(z.string()).optional().describe(desc);\n } else {\n schema[arg.nameCamelCase] = arg.required ? z.string().describe(desc) : z.string().optional().describe(desc);\n }\n });\n\n config.flagsData.forEach((flag) => {\n const type = flag.type;\n schema[flag.name] =\n type === 'string'\n ? z.string().optional().describe(flag.description)\n : z.boolean().optional().describe(flag.description);\n });\n\n return schema;\n }\n\n private buildCommandArgs(config: CommandConfig, params: any): string[] {\n // Split the command name on spaces to properly handle subcommands\n const args: string[] = config.name.split(' ');\n\n // Add positional arguments in order\n config.argsData.forEach((arg) => {\n const val = params[arg.nameCamelCase];\n if (val === undefined) return;\n\n if (arg.isArray && Array.isArray(val)) {\n val.forEach((item) => args.push(item));\n } else {\n args.push(val);\n }\n });\n\n // Add options as flags\n config.flagsData.forEach((flag) => {\n const name = flag.name;\n const type = flag.type;\n const val = params[name];\n if (val === undefined) return;\n if (type === 'boolean' && val) {\n args.push(`--${name}`);\n } else if (type === 'string' && val) {\n // Check if the string value contains spaces and quote it if necessary\n const stringValue = String(val);\n if (stringValue.includes(' ')) {\n args.push(`--${name}`, `\"${stringValue}\"`);\n } else {\n args.push(`--${name}`, stringValue);\n }\n }\n });\n\n return args;\n }\n\n private getToolName(name: string): string {\n // replace white spaces (\\s) and dashes (-) with underscores (_)\n return `bit_${name}`.replace(/[-\\s]/g, '_');\n }\n\n private registerToolForCommand(server: McpServer, cmd: Command, parentCmd?: Command) {\n const cmdName = parentCmd ? `${getCommandName(parentCmd)} ${getCommandName(cmd)}` : getCommandName(cmd);\n const toolName = this.getToolName(cmdName);\n\n // Modify description for show and schema commands in consumer project mode\n let description = `${cmd.description}${cmd.extendedDescription ? `.\\n(${cmd.extendedDescription})` : ''}`;\n if (this.isConsumerProjectMode && (cmdName === 'show' || cmdName === 'schema')) {\n description += `\\n(In consumer project mode, --remote flag is automatically added)`;\n }\n\n const config: CommandConfig = {\n name: cmdName,\n description,\n argsData: getArgsData(cmd),\n flagsData: getFlagsData(cmd),\n };\n\n const schema = this.buildZodSchema(config);\n\n server.tool(toolName, config.description, schema, async (params: any) => {\n const argsToRun = this.buildCommandArgs(config, params);\n\n // Special handling for consumer projects - auto-add --remote flag for show and schema commands\n if (this.isConsumerProjectMode && (cmdName === 'show' || cmdName === 'schema')) {\n if (!argsToRun.includes('--remote')) {\n this.logger.debug(`[MCP-DEBUG] Auto-adding --remote flag for ${cmdName} in consumer project mode`);\n argsToRun.push('--remote');\n }\n if (cmdName === 'show' && !argsToRun.includes('--legacy')) {\n this.logger.debug(`[MCP-DEBUG] Auto-adding --legacy flag for ${cmdName} in consumer project mode`);\n argsToRun.push('--legacy');\n }\n }\n\n return this.runBit(argsToRun, params.cwd);\n });\n }\n\n private registerToolForRemote(server: McpServer, name: string) {\n if (name === 'remote-search') {\n this.registerRemoteSearchTool(server);\n }\n }\n\n private registerRemoteSearchTool(server: McpServer) {\n const toolName = this.getToolName('remote-search');\n const description = 'Search for components in remote scopes';\n const schema: Record<string, any> = {\n queryStr: z.string().describe('Search query string'),\n };\n server.tool(toolName, description, schema, async (params: any) => {\n const http = await this.getHttp();\n const results = await http.search(params.queryStr);\n this.logger.debug(`[MCP-DEBUG] Search results: ${JSON.stringify(results)}`);\n if (!results?.components || results.components.length === 0) {\n return { content: [{ type: 'text', text: 'No results found' }] };\n }\n const formattedResults = results.components.map((result) => ({\n type: 'text',\n text: result,\n }));\n return { content: formattedResults } as CallToolResult;\n });\n }\n\n private registerWorkspaceInfoTool(server: McpServer) {\n const toolName = 'bit_workspace_info';\n const description =\n 'Get comprehensive workspace information including status, components list, apps, templates, and dependency graph';\n const schema: Record<string, any> = {\n cwd: z.string().describe('Path to workspace directory'),\n includeStatus: z.boolean().optional().describe('Include workspace status (default: true)'),\n includeList: z.boolean().optional().describe('Include components list (default: true)'),\n includeApps: z.boolean().optional().describe('Include apps list (default: false)'),\n includeTemplates: z.boolean().optional().describe('Include templates list (default: false)'),\n includeGraph: z.boolean().optional().describe('Include dependency graph (default: false)'),\n };\n\n server.tool(toolName, description, schema, async (params: any) => {\n try {\n const includeStatus = params.includeStatus !== false; // Default to true\n const includeList = params.includeList !== false; // Default to true\n const includeApps = params.includeApps === true;\n const includeTemplates = params.includeTemplates === true;\n const includeGraph = params.includeGraph === true;\n\n const workspaceInfo: any = {};\n\n // Get workspace status using bit-server API with error handling\n if (includeStatus) {\n const statusExecution = await this.safeBitCommandExecution(\n 'status',\n [],\n { json: true },\n params.cwd,\n 'get workspace status',\n true\n );\n workspaceInfo.status = statusExecution.result;\n }\n\n // Get components list if requested\n if (includeList) {\n const listExecution = await this.safeBitCommandExecution(\n 'list',\n [],\n { json: true },\n params.cwd,\n 'get components list',\n true\n );\n workspaceInfo.list = listExecution.result;\n }\n\n // Get apps list if requested\n if (includeApps) {\n const appsExecution = await this.safeBitCommandExecution(\n 'app',\n ['list'],\n { json: true },\n params.cwd,\n 'get apps list',\n true\n );\n workspaceInfo.apps = appsExecution.result;\n }\n\n // Get templates list if requested\n if (includeTemplates) {\n const templatesExecution = await this.safeBitCommandExecution(\n 'templates',\n [],\n { json: true },\n params.cwd,\n 'get templates list',\n true\n );\n workspaceInfo.templates = templatesExecution.result;\n }\n\n // Get dependency graph if requested\n if (includeGraph) {\n const graphExecution = await this.safeBitCommandExecution(\n 'graph',\n [],\n { json: true },\n params.cwd,\n 'get dependency graph',\n true\n );\n workspaceInfo.graph = graphExecution.result;\n }\n\n return this.formatAsCallToolResult(workspaceInfo);\n } catch (error) {\n this.logger.error(`[MCP-DEBUG] Error in bit_workspace_info tool: ${(error as Error).message}`);\n return this.formatErrorAsCallToolResult(error as Error, 'getting workspace info');\n }\n });\n }\n\n private registerComponentDetailsTool(server: McpServer) {\n const toolName = 'bit_component_details';\n const description =\n 'Get detailed information about a specific component including basic info and optionally its public API schema';\n const schema: Record<string, any> = {\n cwd: z.string().describe('Path to workspace directory'),\n componentName: z.string().describe('Component name or component ID to get details for'),\n includeSchema: z.boolean().optional().describe('Include component public API schema (default: false)'),\n remote: z.boolean().optional().describe('Get details from remote scope (default: false)'),\n };\n\n server.tool(toolName, description, schema, async (params: any) => {\n try {\n const includeSchema = params.includeSchema === true;\n const remote = params.remote === true;\n const componentName = params.componentName;\n\n const componentDetails: any = {};\n\n // Get basic component information using bit show\n const showFlags: Record<string, any> = { json: true };\n if (remote) {\n showFlags.remote = true;\n }\n\n const showExecution = await this.safeBitCommandExecution(\n 'show',\n [componentName],\n showFlags,\n params.cwd,\n 'get component show info',\n true\n );\n componentDetails.show = showExecution.result;\n\n // Get component schema (public API) if requested\n if (includeSchema) {\n const schemaFlags: Record<string, any> = { json: true };\n if (remote) {\n schemaFlags.remote = true;\n }\n\n const schemaExecution = await this.safeBitCommandExecution(\n 'schema',\n [componentName],\n schemaFlags,\n params.cwd,\n 'get component schema',\n true\n );\n componentDetails.schema = schemaExecution.result;\n }\n\n return this.formatAsCallToolResult(componentDetails);\n } catch (error) {\n this.logger.error(`[MCP-DEBUG] Error in bit_component_details tool: ${(error as Error).message}`);\n return this.formatErrorAsCallToolResult(error as Error, 'getting component details');\n }\n });\n }\n\n private registerCommandsInfoTool(server: McpServer) {\n const toolName = 'bit_commands_info';\n const description =\n 'Get information about Bit commands and their groups. Specify command or subcommand to get detailed info.';\n const schema: Record<string, any> = {\n extendedDescription: z\n .boolean()\n .optional()\n .describe('Include extended descriptions for commands (default: false)'),\n internal: z.boolean().optional().describe('Include internal/debug commands (default: false)'),\n command: z.string().optional().describe('Get info for a specific command only'),\n subcommand: z.string().optional().describe('Get info for subcommands of a specific main command'),\n };\n\n server.tool(toolName, description, schema, async (params: any) => {\n try {\n const {\n extendedDescription = false,\n internal = false,\n command: specificCommand,\n subcommand: specificSubcommand,\n } = params;\n const commandsInfo: any[] = [];\n\n const shouldSkipCommand = (cmd: Command): boolean => {\n return Boolean((cmd.private && !internal) || cmd.description.startsWith('DEPRECATED'));\n };\n\n const buildCommandInfo = (cmd: Command, parentName?: string, parentGroup?: string, detailed = false) => {\n if (shouldSkipCommand(cmd)) return null;\n\n const cmdName = parentName ? `${parentName} ${getCommandName(cmd)}` : getCommandName(cmd);\n const groupKey = cmd.group || parentGroup;\n\n const commandInfo: any = {\n name: cmdName,\n description: cmd.description || '',\n };\n\n if (extendedDescription && cmd.extendedDescription) {\n commandInfo.extendedDescription = cmd.extendedDescription;\n }\n if (groupKey) commandInfo.group = this.cli.groups[groupKey] || groupKey;\n\n if (!detailed) return commandInfo;\n\n // Add detailed information\n if (cmd.helpUrl) commandInfo.helpUrl = cmd.helpUrl;\n\n const argsData = getArgsData(cmd);\n if (argsData.length > 0) {\n commandInfo.arguments = argsData.map((arg) => ({\n name: arg.nameRaw,\n description: arg.description || '',\n required: arg.required,\n isArray: arg.isArray,\n }));\n }\n\n commandInfo.options = getFlagsData(cmd);\n commandInfo.examples = cmd.examples;\n\n if (cmd.commands && cmd.commands.length > 0) {\n commandInfo.subcommands = cmd.commands\n .filter((subCmd) => !shouldSkipCommand(subCmd))\n .map((subCmd) => ({\n name: `${cmdName} ${getCommandName(subCmd)}`,\n description: subCmd.description || '',\n alias: subCmd.alias || '',\n private: Boolean(subCmd.private),\n }));\n }\n\n return commandInfo;\n };\n\n // Handle specific command + subcommand lookup\n if (specificCommand && specificSubcommand) {\n this.cli.commands.forEach((cmd) => {\n if (getCommandName(cmd) === specificCommand && cmd.commands) {\n const subCmd = cmd.commands.find((sub) => getCommandName(sub) === specificSubcommand);\n if (subCmd) {\n const info = buildCommandInfo(subCmd, specificCommand, cmd.group, true);\n if (info) commandsInfo.push(info);\n }\n }\n });\n }\n // Handle subcommand-only lookup\n else if (specificSubcommand && !specificCommand) {\n this.cli.commands.forEach((cmd) => {\n if (getCommandName(cmd) === specificSubcommand && cmd.commands) {\n cmd.commands.forEach((subCmd) => {\n const info = buildCommandInfo(subCmd, specificSubcommand, cmd.group);\n if (info) commandsInfo.push(info);\n });\n }\n });\n }\n // Handle specific command lookup or general listing\n else {\n const isDetailedMode = Boolean(specificCommand);\n\n this.cli.commands.forEach((cmd) => {\n const mainCmdName = getCommandName(cmd);\n\n // Process main command\n if (!specificCommand || mainCmdName === specificCommand) {\n const info = buildCommandInfo(cmd, undefined, undefined, isDetailedMode);\n if (info && (!specificCommand || info.name === specificCommand)) {\n commandsInfo.push(info);\n }\n }\n\n // Process subcommands\n if (cmd.commands) {\n cmd.commands.forEach((subCmd) => {\n const subCmdInfo = buildCommandInfo(subCmd, mainCmdName, cmd.group, isDetailedMode);\n if (subCmdInfo && (!specificCommand || subCmdInfo.name === specificCommand)) {\n commandsInfo.push(subCmdInfo);\n }\n });\n }\n });\n }\n\n commandsInfo.sort((a, b) => a.name.localeCompare(b.name));\n\n if (commandsInfo.length === 0) {\n let errorMessage = 'No commands found';\n if (specificCommand && specificSubcommand) {\n errorMessage = `No subcommand \"${specificSubcommand}\" found for command: ${specificCommand}`;\n } else if (specificCommand) {\n errorMessage = `No command found with name: ${specificCommand}`;\n } else if (specificSubcommand) {\n errorMessage = `No subcommands found for command: ${specificSubcommand}`;\n }\n return this.formatAsCallToolResult(errorMessage);\n }\n\n const result = JSON.stringify({ total: commandsInfo.length, commands: commandsInfo }, null, 2);\n this.logger.debug(`[MCP-DEBUG] Successfully retrieved commands info. Total: ${commandsInfo.length}`);\n return this.formatAsCallToolResult(result);\n } catch (error) {\n this.logger.error(`[MCP-DEBUG] Error in bit_commands_info tool: ${(error as Error).message}`);\n return this.formatErrorAsCallToolResult(error as Error, 'getting commands info');\n }\n });\n }\n\n private registerQueryTool(server: McpServer) {\n const toolName = 'bit_query';\n const description =\n 'Execute read-only Bit commands that safely inspect workspace and component state without making modifications. Only whitelisted query commands are allowed for safety.';\n const schema: Record<string, any> = {\n cwd: z.string().describe('Path to workspace directory'),\n command: z.string().describe('The Bit command to execute (e.g., \"status\", \"show\", \"list\")'),\n args: z.array(z.string()).optional().describe('Arguments to pass to the command'),\n flags: z\n .record(z.union([z.string(), z.boolean()]))\n .optional()\n .describe('Flags to pass to the command as key-value pairs'),\n };\n\n server.tool(toolName, description, schema, async (params: any) => {\n try {\n const { command, args = [], flags = {}, cwd } = params;\n\n // Check if command is in the read-only whitelist\n // Support both single commands and subcommands (e.g., \"lane show\")\n const fullCommand = args.length > 0 ? `${command} ${args[0]}` : command;\n const isAllowed = this.readOnlyCommands.has(command) || this.readOnlyCommands.has(fullCommand);\n\n if (!isAllowed) {\n const allowedCommands = Array.from(this.readOnlyCommands).sort().join(', ');\n return this.formatAsCallToolResult(\n `Error: Command \"${command}\" is not allowed in query mode. Allowed read-only commands: ${allowedCommands}`\n );\n }\n\n // Build command arguments\n const commandArgs = [command, ...args];\n\n // Add flags to arguments\n Object.entries(flags).forEach(([key, value]) => {\n if (typeof value === 'boolean' && value) {\n commandArgs.push(`--${key}`);\n } else if (typeof value === 'string' && value) {\n commandArgs.push(`--${key}`);\n commandArgs.push(value);\n }\n });\n\n this.logger.debug(`[MCP-DEBUG] Executing query command: ${command} with args: ${JSON.stringify(commandArgs)}`);\n\n const result = await this.callBitServerAPI(command, args, flags, cwd);\n\n return this.formatAsCallToolResult(result);\n } catch (error) {\n this.logger.error(`[MCP-DEBUG] Error in bit_query tool: ${(error as Error).message}`);\n return this.formatErrorAsCallToolResult(error as Error, 'executing query command');\n }\n });\n }\n\n private registerExecuteTool(server: McpServer) {\n const toolName = 'bit_execute';\n const description =\n 'Execute any Bit command, including those that modify workspace or repository state. ⚠️ Use with caution as this can make permanent changes to your project. Consider using bit_query for read-only operations.';\n const schema: Record<string, any> = {\n cwd: z.string().describe('Path to workspace directory'),\n command: z.string().describe('The Bit command to execute (e.g., \"add\", \"tag\", \"export\", \"remove\")'),\n args: z.array(z.string()).optional().describe('Arguments to pass to the command'),\n flags: z\n .record(z.union([z.string(), z.boolean()]))\n .optional()\n .describe('Flags to pass to the command as key-value pairs'),\n };\n\n server.tool(toolName, description, schema, async (params: any) => {\n try {\n const { command, args = [], flags = {}, cwd } = params;\n this.logger.debug(\n `[MCP-DEBUG] Executing command: ${command} with args: ${JSON.stringify(args)} and flags: ${JSON.stringify(flags)}`\n );\n const result = await this.callBitServerAPI(command, args, flags, cwd);\n return this.formatAsCallToolResult(result);\n } catch (error) {\n this.logger.error(`[MCP-DEBUG] Error in bit_execute tool: ${(error as Error).message}`);\n return this.formatErrorAsCallToolResult(error as Error, 'executing command');\n }\n });\n }\n\n private processSubCommands(server: McpServer, parentCmd: Command, options: CommandFilterOptions) {\n const parentCmdName = getCommandName(parentCmd);\n\n parentCmd.commands?.forEach((subCmd) => {\n const subCmdName = getCommandName(subCmd);\n const fullCmdName = `${parentCmdName} ${subCmdName}`;\n\n if (this.shouldIncludeCommand(fullCmdName, options)) {\n this.registerToolForCommand(server, subCmd, parentCmd);\n }\n });\n }\n\n private async runBit(args: string[], cwd: string): Promise<CallToolResult> {\n this.logger.debug(`[MCP-DEBUG] Running: ${this.bitBin} ${args.join(' ')} in ${cwd}`);\n const cmd = `${this.bitBin} ${args.join(' ')}`;\n try {\n const cmdOutput = childProcess.execSync(cmd, { cwd });\n this.logger.debug(`[MCP-DEBUG] result. stdout: ${cmdOutput}`);\n\n return { content: [{ type: 'text', text: cmdOutput.toString() }] };\n } catch (error: any) {\n this.logger.error(`[MCP-DEBUG] Error executing ${cmd}`, error);\n\n return { content: [{ type: 'text', text: error.message }] };\n }\n }\n\n /**\n * Helper method to execute a bit-server API call with standardized error handling\n */\n private async executeBitServerCommand(\n command: string,\n args: string[] = [],\n flags: Record<string, any> = {},\n cwd: string,\n operationName: string\n ): Promise<any> {\n try {\n const result = await this.callBitServerAPI(command, args, flags, cwd);\n this.logger.debug(`[MCP-DEBUG] Successfully executed ${operationName} via bit-server`);\n return result;\n } catch (error) {\n this.logger.warn(`[MCP-DEBUG] Failed to execute ${operationName} via bit-server: ${(error as Error).message}`);\n throw error;\n }\n }\n\n /**\n * Helper method to format any result as CallToolResult\n */\n private formatAsCallToolResult(result: any): CallToolResult {\n if (typeof result === 'string') {\n return { content: [{ type: 'text', text: result }] } as CallToolResult;\n } else if (typeof result === 'object') {\n return { content: [{ type: 'text', text: JSON.stringify(result, null, 2) }] } as CallToolResult;\n } else {\n return { content: [{ type: 'text', text: String(result) }] } as CallToolResult;\n }\n }\n\n /**\n * Helper method to format error as CallToolResult\n */\n private formatErrorAsCallToolResult(error: Error, operation: string): CallToolResult {\n return {\n content: [\n {\n type: 'text',\n text: `Error ${operation}: ${error.message}`,\n },\n ],\n } as CallToolResult;\n }\n\n /**\n * Helper method to safely execute a bit command with error handling\n */\n private async safeBitCommandExecution(\n command: string,\n args: string[] = [],\n flags: Record<string, any> = {},\n cwd: string,\n operationName: string,\n includeErrorInResult = false\n ): Promise<{ success: boolean; result: any; error?: string }> {\n try {\n const result = await this.executeBitServerCommand(command, args, flags, cwd, operationName);\n return { success: true, result };\n } catch (error) {\n if (includeErrorInResult) {\n return {\n success: false,\n result: { error: `Failed to ${operationName}: ${(error as Error).message}` },\n error: (error as Error).message,\n };\n } else {\n throw error;\n }\n }\n }\n\n static slots = [];\n static dependencies = [CLIAspect, LoggerAspect];\n static runtime = MainRuntime;\n static async provider([cli, loggerMain]: [CLIMain, LoggerMain]) {\n const logger = loggerMain.createLogger(CliMcpServerAspect.id);\n const mcpServer = new CliMcpServerMain(cli, logger);\n cli.register(new McpServerCmd(mcpServer));\n return mcpServer;\n }\n}\n\nCliMcpServerAspect.addRuntime(CliMcpServerMain);\n\nexport default CliMcpServerMain;\n"],"mappings":"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","ignoreList":[]}
@@ -13,7 +13,7 @@ class McpServerCmd {
13
13
  _defineProperty(this, "name", 'mcp-server');
14
14
  _defineProperty(this, "description", 'Start the Bit CLI Model Context Protocol (MCP) server for programmatic and remote access to Bit commands.');
15
15
  _defineProperty(this, "alias", '');
16
- _defineProperty(this, "group", 'development');
16
+ _defineProperty(this, "group", 'advanced');
17
17
  _defineProperty(this, "loader", false);
18
18
  _defineProperty(this, "options", [['e', 'extended', 'Enable the full set of Bit CLI commands as MCP tools'], ['', 'include-only <commands>', 'Specify a subset of commands to expose as MCP tools. Use comma-separated list in quotes, e.g. "status,install,compile"'], ['', 'include-additional <commands>', 'Add specific commands to the default MCP tools set. Use comma-separated list in quotes. Only applies when --extended is not used'], ['', 'exclude <commands>', 'Prevent specific commands from being exposed as MCP tools. Use comma-separated list in quotes'], ['', 'bit-bin <binary>', 'Specify the binary to use for running Bit commands (default: "bit")'], ['', 'consumer-project', 'For non-Bit workspaces that only consume Bit component packages. Enables only "schema", "show", and "remote_search" tools']]);
19
19
  }
@@ -1 +1 @@
1
- {"version":3,"names":["McpServerCmd","constructor","mcpServer","_defineProperty","wait","args","flags","runMcpServer","exports"],"sources":["mcp-server.cmd.ts"],"sourcesContent":["import { CLIArgs, Command, CommandOptions } from '@teambit/cli';\nimport { CliMcpServerMain } from './cli-mcp-server.main.runtime';\n\nexport type McpServerCmdOptions = {\n extended?: boolean;\n includeOnly?: string;\n includeAdditional?: string;\n exclude?: string;\n bitBin?: string;\n consumerProject?: boolean;\n};\n\nexport class McpServerCmd implements Command {\n name = 'mcp-server';\n description =\n 'Start the Bit CLI Model Context Protocol (MCP) server for programmatic and remote access to Bit commands.';\n alias = '';\n group = 'development';\n loader = false;\n options = [\n ['e', 'extended', 'Enable the full set of Bit CLI commands as MCP tools'],\n [\n '',\n 'include-only <commands>',\n 'Specify a subset of commands to expose as MCP tools. Use comma-separated list in quotes, e.g. \"status,install,compile\"',\n ],\n [\n '',\n 'include-additional <commands>',\n 'Add specific commands to the default MCP tools set. Use comma-separated list in quotes. Only applies when --extended is not used',\n ],\n [\n '',\n 'exclude <commands>',\n 'Prevent specific commands from being exposed as MCP tools. Use comma-separated list in quotes',\n ],\n ['', 'bit-bin <binary>', 'Specify the binary to use for running Bit commands (default: \"bit\")'],\n [\n '',\n 'consumer-project',\n 'For non-Bit workspaces that only consume Bit component packages. Enables only \"schema\", \"show\", and \"remote_search\" tools',\n ],\n ] as CommandOptions;\n\n constructor(private mcpServer: CliMcpServerMain) {}\n\n async wait(args: CLIArgs, flags: McpServerCmdOptions): Promise<void> {\n await this.mcpServer.runMcpServer(flags);\n }\n}\n"],"mappings":";;;;;;;;;AAYO,MAAMA,YAAY,CAAoB;EAgC3CC,WAAWA,CAASC,SAA2B,EAAE;IAAA,KAA7BA,SAA2B,GAA3BA,SAA2B;IAAAC,eAAA,eA/BxC,YAAY;IAAAA,eAAA,sBAEjB,2GAA2G;IAAAA,eAAA,gBACrG,EAAE;IAAAA,eAAA,gBACF,aAAa;IAAAA,eAAA,iBACZ,KAAK;IAAAA,eAAA,kBACJ,CACR,CAAC,GAAG,EAAE,UAAU,EAAE,sDAAsD,CAAC,EACzE,CACE,EAAE,EACF,yBAAyB,EACzB,wHAAwH,CACzH,EACD,CACE,EAAE,EACF,+BAA+B,EAC/B,kIAAkI,CACnI,EACD,CACE,EAAE,EACF,oBAAoB,EACpB,+FAA+F,CAChG,EACD,CAAC,EAAE,EAAE,kBAAkB,EAAE,qEAAqE,CAAC,EAC/F,CACE,EAAE,EACF,kBAAkB,EAClB,2HAA2H,CAC5H,CACF;EAEiD;EAElD,MAAMC,IAAIA,CAACC,IAAa,EAAEC,KAA0B,EAAiB;IACnE,MAAM,IAAI,CAACJ,SAAS,CAACK,YAAY,CAACD,KAAK,CAAC;EAC1C;AACF;AAACE,OAAA,CAAAR,YAAA,GAAAA,YAAA","ignoreList":[]}
1
+ {"version":3,"names":["McpServerCmd","constructor","mcpServer","_defineProperty","wait","args","flags","runMcpServer","exports"],"sources":["mcp-server.cmd.ts"],"sourcesContent":["import { CLIArgs, Command, CommandOptions } from '@teambit/cli';\nimport { CliMcpServerMain } from './cli-mcp-server.main.runtime';\n\nexport type McpServerCmdOptions = {\n extended?: boolean;\n includeOnly?: string;\n includeAdditional?: string;\n exclude?: string;\n bitBin?: string;\n consumerProject?: boolean;\n};\n\nexport class McpServerCmd implements Command {\n name = 'mcp-server';\n description =\n 'Start the Bit CLI Model Context Protocol (MCP) server for programmatic and remote access to Bit commands.';\n alias = '';\n group = 'advanced';\n loader = false;\n options = [\n ['e', 'extended', 'Enable the full set of Bit CLI commands as MCP tools'],\n [\n '',\n 'include-only <commands>',\n 'Specify a subset of commands to expose as MCP tools. Use comma-separated list in quotes, e.g. \"status,install,compile\"',\n ],\n [\n '',\n 'include-additional <commands>',\n 'Add specific commands to the default MCP tools set. Use comma-separated list in quotes. Only applies when --extended is not used',\n ],\n [\n '',\n 'exclude <commands>',\n 'Prevent specific commands from being exposed as MCP tools. Use comma-separated list in quotes',\n ],\n ['', 'bit-bin <binary>', 'Specify the binary to use for running Bit commands (default: \"bit\")'],\n [\n '',\n 'consumer-project',\n 'For non-Bit workspaces that only consume Bit component packages. Enables only \"schema\", \"show\", and \"remote_search\" tools',\n ],\n ] as CommandOptions;\n\n constructor(private mcpServer: CliMcpServerMain) {}\n\n async wait(args: CLIArgs, flags: McpServerCmdOptions): Promise<void> {\n await this.mcpServer.runMcpServer(flags);\n }\n}\n"],"mappings":";;;;;;;;;AAYO,MAAMA,YAAY,CAAoB;EAgC3CC,WAAWA,CAASC,SAA2B,EAAE;IAAA,KAA7BA,SAA2B,GAA3BA,SAA2B;IAAAC,eAAA,eA/BxC,YAAY;IAAAA,eAAA,sBAEjB,2GAA2G;IAAAA,eAAA,gBACrG,EAAE;IAAAA,eAAA,gBACF,UAAU;IAAAA,eAAA,iBACT,KAAK;IAAAA,eAAA,kBACJ,CACR,CAAC,GAAG,EAAE,UAAU,EAAE,sDAAsD,CAAC,EACzE,CACE,EAAE,EACF,yBAAyB,EACzB,wHAAwH,CACzH,EACD,CACE,EAAE,EACF,+BAA+B,EAC/B,kIAAkI,CACnI,EACD,CACE,EAAE,EACF,oBAAoB,EACpB,+FAA+F,CAChG,EACD,CAAC,EAAE,EAAE,kBAAkB,EAAE,qEAAqE,CAAC,EAC/F,CACE,EAAE,EACF,kBAAkB,EAClB,2HAA2H,CAC5H,CACF;EAEiD;EAElD,MAAMC,IAAIA,CAACC,IAAa,EAAEC,KAA0B,EAAiB;IACnE,MAAM,IAAI,CAACJ,SAAS,CAACK,YAAY,CAACD,KAAK,CAAC;EAC1C;AACF;AAACE,OAAA,CAAAR,YAAA,GAAAA,YAAA","ignoreList":[]}
@@ -1,5 +1,5 @@
1
1
  ;
2
- import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.mcp_cli-mcp-server@0.0.9/dist/README.docs.mdx';
2
+ import * as overview_0 from '/home/circleci/Library/Caches/Bit/capsules/8891be5ad/teambit.mcp_cli-mcp-server@0.0.11/dist/README.docs.mdx';
3
3
 
4
4
  export const compositions = [];
5
5
  export const overview = [overview_0];
package/package.json CHANGED
@@ -1,23 +1,25 @@
1
1
  {
2
2
  "name": "@teambit/cli-mcp-server",
3
- "version": "0.0.9",
3
+ "version": "0.0.11",
4
4
  "homepage": "https://bit.cloud/teambit/mcp/cli-mcp-server",
5
5
  "main": "dist/index.js",
6
6
  "componentId": {
7
7
  "scope": "teambit.mcp",
8
8
  "name": "cli-mcp-server",
9
- "version": "0.0.9"
9
+ "version": "0.0.11"
10
10
  },
11
11
  "dependencies": {
12
+ "node-fetch": "2.6.7",
12
13
  "zod": "^3.24.4",
13
- "@modelcontextprotocol/sdk": "^1.11.0",
14
+ "@modelcontextprotocol/sdk": "^1.12.0",
14
15
  "@teambit/harmony": "0.4.7",
15
- "@teambit/cli": "0.0.1200",
16
+ "@teambit/cli": "0.0.1201",
16
17
  "@teambit/legacy.constants": "0.0.11",
17
- "@teambit/logger": "0.0.1293",
18
+ "@teambit/logger": "0.0.1294",
18
19
  "@teambit/scope.network": "0.0.50"
19
20
  },
20
21
  "devDependencies": {
22
+ "@types/node-fetch": "2.5.12",
21
23
  "@teambit/harmony.envs.core-aspect-env": "0.0.69"
22
24
  },
23
25
  "peerDependencies": {},