n8n
What is n8n
The n8n MCP Server is a Model Context Protocol server that facilitates interaction between AI assistants and n8n workflows, allowing command execution through natural language. It acts as a middleware that enables programmatic management of workflows and executions within n8n, a popular automation tool.
Use cases
This server can be utilized for various applications including automating tasks through verbal commands, executing workflows based on AI suggestions, integrating n8n with AI assistants for enhanced productivity, and managing workflows dynamically through natural language processing.
How to use
To use the n8n MCP Server, you need to install it via npm or Docker, configure it with your n8n API details in a .env file, and run the server. Integration with AI assistants involves specifying the server in their configuration files, allowing them to communicate and manage n8n workflows effectively.
Key features
Key features include workflow management tools (listing, creating, updating, and deleting workflows), execution management capabilities (running and stopping workflows, retrieving execution details), webhook support for interactive workflows, and the ability to implement natural language commands for complex automation tasks.
Where to use
You can use the n8n MCP Server in environments where automation and AI integration are beneficial, such as software development, system administration, business process automation, and any area where there’s a need to streamline repetitive tasks through AI assistance.
Overview
What is n8n
The n8n MCP Server is a Model Context Protocol server that facilitates interaction between AI assistants and n8n workflows, allowing command execution through natural language. It acts as a middleware that enables programmatic management of workflows and executions within n8n, a popular automation tool.
Use cases
This server can be utilized for various applications including automating tasks through verbal commands, executing workflows based on AI suggestions, integrating n8n with AI assistants for enhanced productivity, and managing workflows dynamically through natural language processing.
How to use
To use the n8n MCP Server, you need to install it via npm or Docker, configure it with your n8n API details in a .env file, and run the server. Integration with AI assistants involves specifying the server in their configuration files, allowing them to communicate and manage n8n workflows effectively.
Key features
Key features include workflow management tools (listing, creating, updating, and deleting workflows), execution management capabilities (running and stopping workflows, retrieving execution details), webhook support for interactive workflows, and the ability to implement natural language commands for complex automation tasks.
Where to use
You can use the n8n MCP Server in environments where automation and AI integration are beneficial, such as software development, system administration, business process automation, and any area where there’s a need to streamline repetitive tasks through AI assistance.
Content
n8n MCP Server
A Model Context Protocol (MCP) server that allows AI assistants to interact with n8n workflows through natural language.
Overview
This project provides a Model Context Protocol (MCP) server that empowers AI assistants to seamlessly interact with n8n, a popular workflow automation tool. It acts as a bridge, enabling AI assistants to programmatically manage and control n8n workflows and executions using natural language commands.
Installation
Prerequisites
- Node.js 20 or later
- n8n instance with API access enabled
Install from npm
npm install -g @leonardsellem/n8n-mcp-server
Install from source
# Clone the repository
git clone https://github.com/leonardsellem/n8n-mcp-server.git
cd n8n-mcp-server
# Install dependencies
npm install
# Build the project
npm run build
# Optional: Install globally
npm install -g .
Docker Installation
You can also run the server using Docker:
# Pull the image
docker pull leonardsellem/n8n-mcp-server
# Run the container with your n8n API configuration
docker run -e N8N_API_URL=http://your-n8n:5678/api/v1 \
-e N8N_API_KEY=your_n8n_api_key \
-e N8N_WEBHOOK_USERNAME=username \
-e N8N_WEBHOOK_PASSWORD=password \
leonardsellem/n8n-mcp-server
Updating the Server
How you update the server depends on how you initially installed it.
1. Installed globally via npm
If you installed the server using npm install -g @leonardsellem/n8n-mcp-server
:
- Open your terminal or command prompt.
- Run the following command to get the latest version:
npm install -g @leonardsellem/n8n-mcp-server@latest
- If the server is currently running (e.g., as a background process or service), you’ll need to restart it for the changes to take effect.
2. Installed from source
If you cloned the repository and installed from source:
- Open your terminal or command prompt.
- Navigate to the directory where you cloned the project:
cd path/to/n8n-mcp-server
- If you’ve made any local changes to the code that you want to keep, consider stashing them (optional):
You can apply them later withgit stash
git stash pop
. - Pull the latest changes from the repository (assuming you are on the
main
branch):
If you are on a different branch, replacegit pull origin main
main
with your branch name. - Install or update any changed dependencies:
npm install
- Rebuild the project to include the latest updates:
npm run build
- If you previously installed it globally from this source folder using
npm install -g .
, you might want to run this command again to update the global link:npm install -g .
- Restart the server.
- If you run the server directly using a command like
node build/index.js
in your AI assistant’s MCP configuration, ensure the path is still correct. Usingnpm install -g .
and thenn8n-mcp-server
as the command should keep this consistent.
- If you run the server directly using a command like
3. Using Docker
If you are running the server using Docker:
- Pull the latest image from Docker Hub:
docker pull leonardsellem/n8n-mcp-server:latest
- Stop and remove your old container. You’ll need your container’s name or ID (you can find it using
docker ps
):docker stop <your_container_name_or_id> docker rm <your_container_name_or_id>
- Start a new container with the updated image. Use the same
docker run
command you used previously, including all your necessary environment variables (refer to the “Docker Installation” section for an example command). For instance:
Ensure you usedocker run -e N8N_API_URL=http://your-n8n:5678/api/v1 \ -e N8N_API_KEY=your_n8n_api_key \ -e N8N_WEBHOOK_USERNAME=username \ -e N8N_WEBHOOK_PASSWORD=password \ leonardsellem/n8n-mcp-server:latest
:latest
or the specific version tag you intend to run.
Configuration
Create a .env
file in the directory where you’ll run the server, using .env.example
as a template:
cp .env.example .env
Configure the following environment variables:
Variable | Description | Example |
---|---|---|
N8N_API_URL |
Full URL of the n8n API, including /api/v1 |
http://localhost:5678/api/v1 |
N8N_API_KEY |
API key for authenticating with n8n | n8n_api_... |
N8N_WEBHOOK_USERNAME |
Username for webhook authentication (if using webhooks) | username |
N8N_WEBHOOK_PASSWORD |
Password for webhook authentication | password |
DEBUG |
Enable debug logging (optional) | true or false |
Generating an n8n API Key
- Open your n8n instance in a browser
- Go to Settings > API > API Keys
- Create a new API key with appropriate permissions
- Copy the key to your
.env
file
Usage
Running the Server
From the installation directory:
n8n-mcp-server
Or if installed globally:
n8n-mcp-server
Integrating with AI Assistants
After building the server (npm run build
), you need to configure your AI assistant (like VS Code with the Claude extension or the Claude Desktop app) to run it. This typically involves editing a JSON configuration file.
Example Configuration (e.g., in VS Code settings.json
or Claude Desktop claude_desktop_config.json
):
Key Points:
- Replace
/path/to/your/cloned/n8n-mcp-server/
with the actual absolute path where you cloned and built the repository. - Use the correct path separator for your operating system (forward slashes
/
for macOS/Linux, double backslashes\\
for Windows). - Ensure you provide the correct
N8N_API_URL
(including/api/v1
) andN8N_API_KEY
. - The server needs to be built (
npm run build
) before the assistant can run thebuild/index.js
file.
Available Tools
The server provides the following tools:
Using Webhooks
This MCP server supports executing workflows through n8n webhooks. To use this functionality:
- Create a webhook-triggered workflow in n8n.
- Set up Basic Authentication on your webhook node.
- Use the
run_webhook
tool to trigger the workflow, passing just the workflow name.
Example:
const result = await useRunWebhook({
workflowName: "hello-world", // Will call <n8n-url>/webhook/hello-world
data: {
prompt: "Hello from AI assistant!"
}
});
The webhook authentication is handled automatically using the N8N_WEBHOOK_USERNAME
and N8N_WEBHOOK_PASSWORD
environment variables.
Workflow Management
workflow_list
: List all workflowsworkflow_get
: Get details of a specific workflowworkflow_create
: Create a new workflowworkflow_update
: Update an existing workflowworkflow_delete
: Delete a workflowworkflow_activate
: Activate a workflowworkflow_deactivate
: Deactivate a workflow
Execution Management
execution_run
: Execute a workflow via the APIrun_webhook
: Execute a workflow via a webhookexecution_get
: Get details of a specific executionexecution_list
: List executions for a workflowexecution_stop
: Stop a running execution
Resources
The server provides the following resources:
n8n://workflows/list
: List of all workflowsn8n://workflow/{id}
: Details of a specific workflown8n://executions/{workflowId}
: List of executions for a workflown8n://execution/{id}
: Details of a specific execution
Roadmap
The n8n MCP Server is a community-driven project, and its future direction will be shaped by your feedback and contributions!
Currently, our roadmap is flexible and under continuous development. We believe in evolving the server based on the needs and ideas of our users.
We encourage you to get involved in shaping the future of this tool:
- Suggest Features: Have an idea for a new tool, resource, or improvement?
- Discuss Priorities: Want to weigh in on what we should focus on next?
Please share your thoughts, feature requests, and ideas by opening an issue on our GitHub Issues page. Let’s build a powerful tool for AI assistants together!
Development
Building
npm run build
Running in Development Mode
npm run dev
Testing
npm test
Linting
npm run lint
Contributing
We welcome contributions from the community and are excited to see how you can help improve the n8n MCP Server! Whether you’re fixing a bug, proposing a new feature, or improving documentation, your help is valued.
Reporting Bugs
If you encounter a bug, please report it by opening an issue on our GitHub Issues page.
When submitting a bug report, please include the following:
- A clear and descriptive title.
- A detailed description of the problem, including steps to reproduce the bug.
- Information about your environment (e.g., Node.js version, n8n MCP Server version, operating system).
- Any relevant error messages or screenshots.
Suggesting Enhancements
We’re always looking for ways to make the server better. If you have an idea for an enhancement or a new feature, please open an issue on our GitHub Issues page.
Please provide:
- A clear and descriptive title for your suggestion.
- A detailed explanation of the proposed enhancement and why it would be beneficial.
- Any potential use cases or examples.
Submitting Pull Requests
If you’d like to contribute code, please follow these steps:
- Fork the repository: Create your own fork of the n8n-mcp-server repository.
- Create a branch: Create a new branch in your fork for your changes (e.g.,
git checkout -b feature/your-feature-name
orbugfix/issue-number
). - Make your changes: Implement your feature or bug fix.
- Ensure your code adheres to the existing coding style. (We use Prettier for formatting, which can be run with
npm run lint
). - Include tests for your changes if applicable. You can run tests using
npm test
.
- Ensure your code adheres to the existing coding style. (We use Prettier for formatting, which can be run with
- Commit your changes: Write clear and concise commit messages.
- Push to your fork: Push your changes to your forked repository.
- Open a Pull Request (PR): Submit a PR to the
main
branch of the officialn8n-mcp-server
repository.- Provide a clear title and description for your PR, explaining the changes you’ve made and referencing any related issues.
We’ll review your PR as soon as possible and provide feedback. Thank you for your contribution!
License
🚀 Join Our Team: Call for Co-Maintainers!
This project is a vibrant, community-driven tool actively used by AI enthusiasts and developers. Currently, it’s maintained on a part-time basis by a passionate individual who isn’t a seasoned engineer but is dedicated to bridging AI with workflow automation. To help this project flourish, ensure its long-term health, and keep up with its growing user base, we’re looking for enthusiastic co-maintainers to join the team!
Why Contribute?
- Learn and Grow: Sharpen your skills in areas like TypeScript, Node.js, API integration, and AI tool development.
- Collaborate: Work alongside other motivated developers and AI users.
- Make an Impact: Directly shape the future of this project and help build a valuable tool for the AI community.
- Open Source: Gain experience contributing to an open-source project.
How You Can Help
We welcome contributions in many forms! Here are some areas where you could make a big difference:
- Bug Fixing: Help us identify and squash bugs to improve stability.
- Feature Development: Implement new tools and functionalities based on user needs and your ideas.
- Documentation: Improve our guides, examples, and API references to make the project more accessible.
- Testing: Enhance our test suite (unit, integration) to ensure code quality and reliability.
- CI/CD: Help streamline our development and deployment pipelines.
- Code Reviews: Provide feedback on pull requests and help maintain code standards.
- Community Support: Assist users with questions and help manage discussions.
Get Involved!
If you’re excited about the intersection of AI and workflow automation, and you’re looking for a rewarding open-source opportunity, we’d love to hear from you!
Ready to contribute?
- Check out our GitHub Issues page to find existing tasks, suggest new ideas, or express your interest in becoming a co-maintainer.
- You can open an issue titled “Co-maintainer Application” to formally apply, or simply start contributing to existing issues.
- Alternatively, feel free to reach out to the existing maintainers if you have questions.
Let’s build the future of AI-powered workflow automation together! 🙌