Files
n8n-mcp/docker
czlonkowski 71cd20bf95 fix: address security issues and improve Docker implementation
Security Fixes:
- Add command injection prevention in n8n-mcp wrapper with whitelist validation
- Fix race condition in database initialization with proper lock directory creation
- Add flock availability check with fallback behavior
- Implement comprehensive input sanitization in parse-config.js

Improvements:
- Add debug logging support to parse-config.js (DEBUG_CONFIG=true)
- Improve test cleanup error handling with proper error tracking
- Increase integration test timeouts for CI compatibility
- Update test assertions to check environment variables instead of processes

All critical security vulnerabilities identified by code review have been addressed.

🤖 Generated with [Claude Code](https://claude.ai/code)

Co-Authored-By: Claude <noreply@anthropic.com>
2025-07-31 13:04:25 +02:00
..

Docker Usage Guide for n8n-mcp

Running in HTTP Mode

The n8n-mcp Docker container can be run in HTTP mode using several methods:

docker run -d -p 3000:3000 \
  --name n8n-mcp-server \
  -e MCP_MODE=http \
  -e AUTH_TOKEN=your-secure-token-here \
  ghcr.io/czlonkowski/n8n-mcp:latest

Method 2: Using docker-compose

# Create a .env file
cat > .env << EOF
MCP_MODE=http
AUTH_TOKEN=your-secure-token-here
PORT=3000
EOF

# Run with docker-compose
docker-compose up -d

Method 3: Using a Configuration File

Create a config.json file:

{
  "MCP_MODE": "http",
  "AUTH_TOKEN": "your-secure-token-here",
  "PORT": "3000",
  "LOG_LEVEL": "info"
}

Run with the config file:

docker run -d -p 3000:3000 \
  --name n8n-mcp-server \
  -v $(pwd)/config.json:/app/config.json:ro \
  ghcr.io/czlonkowski/n8n-mcp:latest

Method 4: Using the n8n-mcp serve Command

docker run -d -p 3000:3000 \
  --name n8n-mcp-server \
  -e AUTH_TOKEN=your-secure-token-here \
  ghcr.io/czlonkowski/n8n-mcp:latest \
  n8n-mcp serve

Important Notes

  1. AUTH_TOKEN is required for HTTP mode. Generate a secure token:

    openssl rand -base64 32
    
  2. Environment variables take precedence over config file values

  3. Default mode is stdio if MCP_MODE is not specified

  4. Health check endpoint is available at http://localhost:3000/health

Troubleshooting

Container exits immediately

  • Check logs: docker logs n8n-mcp-server
  • Ensure AUTH_TOKEN is set for HTTP mode

"n8n-mcp: not found" error

  • This has been fixed in the latest version
  • Use the full command: node /app/dist/mcp/index.js as a workaround

Config file not working

  • Ensure the file is valid JSON
  • Mount as read-only: -v $(pwd)/config.json:/app/config.json:ro
  • Check that the config parser is present: docker exec n8n-mcp-server ls -la /app/docker/