This major update adds comprehensive n8n integration, enabling n8n-mcp to run as an MCP server within n8n workflows using the MCP Client Tool node. ## Key Features ### n8n Integration (NEW) - Full MCP Client Tool compatibility with protocol version negotiation - Dedicated n8n mode with optimized Docker deployment - Workflow examples and n8n-friendly tool descriptions - Quick deployment script for easy setup ### Protocol & Compatibility - Intelligent protocol version selection (2024-11-05 for n8n, 2025-03-26 for others) - Fixed schema validation issues with n8n's nested output format - Enhanced parameter validation with clear error messages - Comprehensive test suite for protocol negotiation ### Security Enhancements - Dynamic UID/GID generation (10000-59999) for Docker containers - Improved error sanitization for production environments - Fixed information leakage in error responses - Enhanced permission handling for mounted volumes ### Performance Optimizations - Docker build time reduced from 13+ minutes to 1-2 minutes - Image size reduced from ~1.5GB to ~280MB - Fixed ARM64 build failures - Optimized to use runtime-only dependencies ### Developer Experience - Comprehensive parameter validation for all MCP tools - Made README version badge dynamic from package.json - Enhanced test coverage with session management tests - Improved CI/CD with informational patch coverage ### Documentation - Added comprehensive N8N_DEPLOYMENT.md guide - Updated CHANGELOG.md for version 2.9.0 - Enhanced CLAUDE.md with n8n-specific instructions - Added deployment scripts and examples ## Technical Details Files Added: - Dockerfile.n8n, docker-compose.n8n.yml for n8n deployment - Protocol version negotiation utilities - n8n integration test suite - Session management tests - Deployment and test scripts - Version badge update scripts Files Modified: - Enhanced MCP server with n8n mode support - Improved HTTP server with better error handling - Updated Docker configurations for security - Enhanced logging for n8n compatibility - CHANGELOG.md with comprehensive update description This update makes n8n-mcp a first-class citizen in the n8n ecosystem, enabling powerful AI-assisted workflow automation. 🤖 Generated with [Claude Code](https://claude.ai/code) Co-Authored-By: Claude <noreply@anthropic.com>
54 lines
1.8 KiB
JavaScript
Executable File
54 lines
1.8 KiB
JavaScript
Executable File
#!/usr/bin/env node
|
|
|
|
/**
|
|
* Sync version from package.json to package.runtime.json and README.md
|
|
* This ensures all files always have the same version
|
|
*/
|
|
|
|
const fs = require('fs');
|
|
const path = require('path');
|
|
|
|
const packageJsonPath = path.join(__dirname, '..', 'package.json');
|
|
const packageRuntimePath = path.join(__dirname, '..', 'package.runtime.json');
|
|
const readmePath = path.join(__dirname, '..', 'README.md');
|
|
|
|
try {
|
|
// Read package.json
|
|
const packageJson = JSON.parse(fs.readFileSync(packageJsonPath, 'utf-8'));
|
|
const version = packageJson.version;
|
|
|
|
// Read package.runtime.json
|
|
const packageRuntime = JSON.parse(fs.readFileSync(packageRuntimePath, 'utf-8'));
|
|
|
|
// Update version if different
|
|
if (packageRuntime.version !== version) {
|
|
packageRuntime.version = version;
|
|
|
|
// Write back with proper formatting
|
|
fs.writeFileSync(
|
|
packageRuntimePath,
|
|
JSON.stringify(packageRuntime, null, 2) + '\n',
|
|
'utf-8'
|
|
);
|
|
|
|
console.log(`✅ Updated package.runtime.json version to ${version}`);
|
|
} else {
|
|
console.log(`✓ package.runtime.json already at version ${version}`);
|
|
}
|
|
|
|
// Update README.md version badge
|
|
let readmeContent = fs.readFileSync(readmePath, 'utf-8');
|
|
const versionBadgeRegex = /(\[!\[Version\]\(https:\/\/img\.shields\.io\/badge\/version-)[^-]+(-.+?\)\])/;
|
|
const newVersionBadge = `$1${version}$2`;
|
|
const updatedReadmeContent = readmeContent.replace(versionBadgeRegex, newVersionBadge);
|
|
|
|
if (updatedReadmeContent !== readmeContent) {
|
|
fs.writeFileSync(readmePath, updatedReadmeContent);
|
|
console.log(`✅ Updated README.md version badge to ${version}`);
|
|
} else {
|
|
console.log(`✓ README.md already has version badge ${version}`);
|
|
}
|
|
} catch (error) {
|
|
console.error('❌ Error syncing version:', error.message);
|
|
process.exit(1);
|
|
} |