ts/docs/api/mcp.md
The MCP (Model Control Protocol) API provides advanced server management capabilities for creating, configuring, and managing MCP servers with enhanced features.
The MCP class offers comprehensive CRUD operations for MCP servers, including:
import { Composio } from '@composio/core';
const composio = new Composio();
const userId = "xxx-oooo-xxx";
// create an MCP Server Config
const server = await composio.mcp.create('my-mcp-server', {
toolkits: [
{
toolkit: 'slack',
authConfigId: 'ac_12324343',
allowedTools: ['SLACK_SEND_MESSAGE'],
},
],
});
// get an instance for a user
const mcp = await server.generate(userId);
// using the global api
const mcp = await composio.mcp.generate(userId, server.id);
/** mcp
* {
* ...
* id: "serverid",
* url: "mcp-server.com/mcp",
* ...
* }
* /
// use the mcp with your mcp-client
Creates a new MCP server configuration with specified toolkits and authentication settings.
Parameters:
name (string): Unique name for the MCP configurationconfig (MCPConfigCreationParams): Configuration object containing:
toolkits (Array): Array of toolkit configurations
toolkit (string, optional): Toolkit identifier (e.g., "github", "slack")authConfigId (string, optional): Auth configuration IDallowedTools (string[], optional): Specific tools to enablemanuallyManageConnections (boolean, optional): Whether to manually manage account connections (default: false)Returns: Promise<MCPConfigCreateResponse>
Example:
const server = await composio.mcp.create('personal-mcp-server', {
toolkits: [
{
toolkit: 'github',
authConfigId: 'ac_xyz',
allowedTools: ['GITHUB_CREATE_ISSUE', 'GITHUB_LIST_REPOS'],
},
{
toolkit: 'slack',
authConfigId: 'ac_abc',
allowedTools: ['SLACK_SEND_MESSAGE'],
},
],
manuallyManageConnections: false,
});
// Get server instance for a user
const mcp = await server.generate('user_12345');
Lists MCP servers with optional filtering and pagination.
Parameters:
options (MCPListParams): Filtering and pagination options
page (number, optional): Page number for pagination (default: 1)limit (number, optional): Maximum items per page (default: 10)toolkits (string[], optional): Filter by toolkit namesauthConfigs (string[], optional): Filter by auth configuration IDsname (string, optional): Filter by server name (partial match)Returns: Promise<MCPListResponse>
Example:
// List all servers
const allServers = await composio.mcp.list({});
// Paginated listing
const pagedServers = await composio.mcp.list({
page: 2,
limit: 5,
});
// Filter by toolkit
const githubServers = await composio.mcp.list({
toolkits: ['github', 'slack'],
});
// Filter by name
const personalServers = await composio.mcp.list({
name: 'personal',
});
Retrieves detailed information about a specific MCP server/config.
Parameters:
serverId (string): The unique identifier of the MCP server/configReturns: Promise<MCPItem>
Example:
const server = await composio.mcp.get('mcp_12345');
console.log(server.name); // "My Personal MCP Server"
console.log(server.allowedTools); // ["GITHUB_CREATE_ISSUE", "SLACK_SEND_MESSAGE"]
console.log(server.toolkits); // ["github", "slack"]
console.log(server.serverInstanceCount); // 3
// Access setup commands for different clients
console.log(server.commands.claude); // Claude setup command
console.log(server.commands.cursor); // Cursor setup command
console.log(server.commands.windsurf); // Windsurf setup command
Updates an existing MCP server configuration.
Parameters:
serverId (string): The unique identifier of the MCP server to updateconfig (MCPUpdateParams): Update configuration parameters
name (string, optional): New server nametoolkits (Array, optional): Updated toolkit configurationsmanuallyManageConnections (boolean, optional): Connection management settingReturns: Promise<MCPItem>
Example:
// Update server name only
const updatedServer = await composio.mcp.update('mcp_12345', {
name: 'My Updated MCP Server',
});
// Update toolkits and tools
const serverWithNewTools = await composio.mcp.update('mcp_12345', {
toolkits: [
{
toolkit: 'github',
authConfigId: 'auth_abc123',
allowedTools: ['GITHUB_CREATE_ISSUE', 'GITHUB_LIST_REPOS'],
},
{
toolkit: 'slack',
authConfigId: 'auth_xyz789',
allowedTools: ['SLACK_SEND_MESSAGE', 'SLACK_LIST_CHANNELS'],
},
],
});
// Complete update
const fullyUpdatedServer = await composio.mcp.update('mcp_12345', {
name: 'Production MCP Server',
toolkits: [
{
toolkit: 'gmail',
authConfigId: 'auth_gmail_prod',
allowedTools: ['GMAIL_SEND_EMAIL', 'GMAIL_FETCH_EMAILS'],
},
],
manuallyManageConnections: false,
});
Permanently deletes an MCP server configuration.
Parameters:
serverId (string): The unique identifier of the MCP server to deleteReturns: Promise<{id: string; deleted: boolean}>
Example:
// Delete a server
const result = await composio.mcp.delete('mcp_12345');
if (result.deleted) {
console.log(`Server ${result.id} has been successfully deleted`);
} else {
console.log(`Failed to delete server ${result.id}`);
}
// With error handling
try {
const result = await composio.mcp.delete('mcp_12345');
console.log('Deletion successful:', result);
} catch (error) {
console.error('Failed to delete MCP server:', error.message);
}
// Verify deletion
await composio.mcp.delete('mcp_12345');
const servers = await composio.mcp.list({});
const serverExists = servers.items.some(server => server.id === 'mcp_12345');
console.log('Server still exists:', serverExists); // Should be false
Creates a server instance for a specific user.
Parameters:
userId (string): External user ID from your databasemcpConfigId (string): MCP configuration IDoptions (MCPGetInstanceParams, optional): Additional options
manuallyManageConnections (boolean, optional): Whether to manually manage connectionsReturns: Promise<MCPServerInstance>
Example:
const mcp = await composio.mcp.generate('user_12345', 'mcp_67890', {
manuallyManageConnections: false,
});
console.log(mcp.url); // Server URL for the user
console.log(mcp.allowedTools); // Available tools
Complete MCP server information including:
id: Unique server identifiername: Human-readable server nameallowedTools: Array of enabled tool identifiersauthConfigIds: Array of auth configuration IDstoolkits: Array of toolkit namescommands: Setup commands for different clients (Claude, Cursor, Windsurf)MCPUrl: Server connection URLtoolkitIcons: Map of toolkit iconsserverInstanceCount: Number of active instancesPaginated list response containing:
items: Array of MCPItem objectscurrentPage: Current page numbertotalPages: Total number of pagesUser-specific server instance containing:
id: Server identifiername: Server nametype: Connection type (always 'streamable_http')url: User-specific connection URLuserId: Associated user IDallowedTools: Available tools for the userauthConfigs: Associated auth configurationsAll methods can throw the following exceptions:
try {
const server = await composio.mcp.create('test-server', config);
} catch (error) {
if (error instanceof ValidationError) {
console.error('Invalid configuration:', error.message);
} else {
console.error('API error:', error.message);
}
}
Use descriptive, unique names for your MCP servers:
// Good
'production-github-slack-server';
'dev-testing-environment';
'user-personal-tools';
// Avoid
'server1';
'test';
'mcp';
Be specific about allowed tools to maintain security:
// Specific tools (recommended)
{
toolkit: "github",
allowedTools: ["GITHUB_CREATE_ISSUE", "GITHUB_LIST_REPOS"]
}
// Avoid allowing all tools unless necessary
{
toolkit: "github"
// No allowedTools = all tools enabled
}
Choose the appropriate connection management strategy:
// For chat based agents
{
manuallyManageConnections: false;
}
// For background agents, where you have to pre connect all the accounts
{
manuallyManageConnections: true;
}
Use pagination for large server lists:
let page = 1;
let allServers = [];
while (true) {
const response = await composio.mcp.list({
page,
limit: 50,
});
allServers.push(...response.items);
if (page >= response.totalPages) break;
page++;
}
For issues with the MCP API: