The MCP Tool Chainer Server is a powerful solution for chaining multiple MCP (Model Context Protocol) tools together, enabling sequential execution with result passing. Designed to address modelcontextprotocol/specification#215, this server minimizes token usage and simplifies complex workflows.
CHAIN_RESULT
placeholder to pass results between tools.inputPath
and outputPath
parameters.mcp_chain
: Chains multiple MCP servers together.chainable_tools
: Discovers tools from all MCP servers for use with mcp_chain
.discover_tools
: Rediscover tools from all MCP servers.# Install
npm install @thirdstrandstudio/mcp-tool-chainer
# Or use with npx directly
npx -y @thirdstrandstudio/mcp-tool-chainer
# Clone the repository
git clone https://github.com/thirdstrandstudio/mcp-tool-chainer.git
cd mcp-tool-chainer
# Install dependencies
npm install
# Build the package
npm run build
Ensure the MCP Tool Chainer is the last MCP server to run. Add the following to your claude_desktop_config.json
or mcp.json
:
{
"mcpServers": {
"mcp_tool_chainer": {
"command": "npx",
"args": ["-y", "@thirdstrandstudio/mcp-tool-chainer", "`claude_desktop_config.json` or `mcp.json`"],
"env": {}
}
}
}
{
"mcpServers": {
"mcp_tool_chainer": {
"command": "node",
"args": ["/path/to/mcp-tool-chainer/dist/index.js", "`claude_desktop_config.json` or `mcp.json`"],
"env": {}
}
}
}
Replace /path/to/mcp-tool-chainer
with the actual path to your repository.
// Fetch a webpage and then extract specific content with XPath
const result = await callTool("mcp_chain", {
"mcpPath": [
{
"toolName": "mcp_browser_mcp_fetch_url",
"toolArgs": "{\"url\": \"https://example.com\"}"
},
{
"toolName": "mcp_xpath_xpath",
"toolArgs": "{\"xml\": CHAIN_RESULT, \"query\": \"//h1\"}"
}
]
});
// Fetch a webpage, extract specific content with XPath, then extract part of the result
const result = await callTool("mcp_chain", {
"mcpPath": [
{
"toolName": "mcp_fetch_fetch",
"toolArgs": "{\"url\": \"https://api.example.com/data\"}"
},
{
"toolName": "web_search",
"toolArgs": "{\"search_term\": CHAIN_RESULT}",
"inputPath": "$.results[0].title", // Extract only the first result's title from previous output
"outputPath": "$.snippets[*].text" // Extract only the text snippets from the search results
},
{
"toolName": "another_tool",
"toolArgs": "{\"content\": CHAIN_RESULT}"
}
]
});
The MCP Tool Chainer supports AWS Step Functions-style inputPath
and outputPath
features:
inputPath
: JsonPath expression to extract specific portions of the input before passing to a tool.outputPath
: JsonPath expression to extract specific portions of the output before passing to the next tool.For JsonPath syntax reference, see JsonPath Syntax.
# Install dependencies
npm install
# Start the server
node dist/index.js config.json
# List available tools
node dist/index.js config.json discover_tools
This MCP server is licensed under the MIT License.
Created by Third Strand Studio.