Skip to main content

n8n-deploy - a simple N8N Workflow Manager with SQLite metadata store

Project description

n8n-deploy: Database-First n8n Workflow Management CLI

GitHub CI/CD Pipeline GitHub stars GitHub last commit GitHub issues

Python 3.9+ License: MIT Project Status: Active Code style: black

Overview

n8n-deploy is a powerful Python CLI tool designed to simplify n8n workflow management through a database-first approach. It provides a flexible, efficient solution for managing n8n workflows, especially in environments without direct web UI access.

Key Features

  • 🗂️ Database-Driven Workflow Management

    • SQLite metadata store for tracking workflows (schema v6)
    • Support for new workflows without server ID (auto-generates draft ID)
    • Flexible base folder configuration
    • Plain text API key storage
  • 🚀 Seamless n8n Server Integration

    • Push and pull workflows directly from remote n8n servers
    • Workflow-server linking for automatic server resolution
    • Priority-based server configuration (linked server → ENV → --remote)
    • Support for multiple server configurations with API key management
  • 📁 Folder Synchronization (NEW in v0.2.0)

    • Bidirectional folder sync between local and n8n server
    • folder CLI command group for folder operations
    • Automatic folder mapping and tracking
  • 📜 Script Synchronization (NEW)

    • Sync external scripts (.js, .cjs, .py) referenced by Execute Command nodes
    • Git-based change detection (only sync modified scripts)
    • Extensible transport plugin system (SCP included)
    • Automatic remote folder creation per workflow
  • 💻 Versatile CLI Interface

    • Emoji-rich output for interactive use
    • Script-friendly mode with --no-emoji flag
    • Verbose logging with -v and -vv flags for debugging
    • Comprehensive workflow operations

Installation

# Pip install
pip install n8n-deploy

# Use uv for faster setup and virtual environment
uv venv --python /usr/bin/python3 .venv
source .venv/bin/activate
uv pip install n8n-deploy

Quick Start

# Initialize database
n8n-deploy db init --data-dir ~/.n8n-deploy

# Create server and add API key
n8n-deploy server create production https://n8n.example.com
echo "your-n8n-api-key" | n8n-deploy apikey add - --name "prod-key"

# Link workflow to server (automatic server resolution)
n8n-deploy wf add workflow.json --link-remote production

# Push/pull uses linked server automatically (no --remote needed!)
n8n-deploy wf push workflow-name  # Uses production server
n8n-deploy wf pull workflow-name  # Uses production server

# Override with --remote for ad-hoc operations
n8n-deploy wf push workflow-name --remote staging

# Delete workflow from local database
n8n-deploy wf delete workflow-name

# List workflows from server
n8n-deploy wf server --remote production

# Folder synchronization (NEW in v0.2.0)
n8n-deploy folder sync --remote production  # Sync folders with server

# Script synchronization (sync .js, .cjs, .py files with workflow push)
n8n-deploy wf push workflow-name \
  --scripts ./scripts \
  --scripts-host n8n.example.com \
  --scripts-user deploy \
  --scripts-key ~/.ssh/id_rsa

# Dry run to see what scripts would sync
n8n-deploy wf push workflow-name --scripts ./scripts --scripts-dry-run

# Enable verbose logging for debugging
n8n-deploy -v wf push workflow-name   # Basic verbose
n8n-deploy -vv wf push workflow-name  # Extended verbose

Community & Support

💬 Get Help & Connect:

  • Discussions - Ask questions, share ideas, showcase workflows
  • Issues - Report bugs or request features
  • Documentation - Complete guides and API reference

Discussion Categories:

  • 📣 Announcements - Project updates and releases
  • 🙏 Q&A - Get help from the community
  • 💡 Ideas - Suggest new features
  • 🎯 Show and Tell - Share your workflows
  • #️⃣ General - Everything else

Configuration

n8n-deploy supports multiple configuration methods:

  1. CLI Flags
  2. Environment Variables
  3. .env Files (in development mode)

Environment Variables

  • N8N_DEPLOY_FLOWS_DIR: Workflow files directory
  • N8N_DEPLOY_DATA_DIR: Application data directory
  • N8N_SERVER_URL: n8n server URL for remote operations
  • N8N_SCRIPTS_HOST: Remote host for script sync
  • N8N_SCRIPTS_USER: Remote username for script sync
  • N8N_SCRIPTS_PORT: SSH port for script sync (default: 22)
  • N8N_SCRIPTS_KEY: SSH key file path for script sync

Documentation

📚 Read the full documentation

Quick Links:

Contributing

We welcome contributions! Please see our Contributing Guide and Code of Conduct.

Quick Links:

License

This project is licensed under the MIT License - see the LICENSE file for details.

Requirements

  • Python 3.9+
  • n8n server (local or remote)
  • Basic understanding of workflow management

Performance Note

Designed for efficient workflow management with minimal overhead. Ideal for DevOps, automation engineers, and workflow enthusiasts.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

n8n_deploy-0.4.1.tar.gz (322.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

n8n_deploy-0.4.1-py3-none-any.whl (99.4 kB view details)

Uploaded Python 3

File details

Details for the file n8n_deploy-0.4.1.tar.gz.

File metadata

  • Download URL: n8n_deploy-0.4.1.tar.gz
  • Upload date:
  • Size: 322.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for n8n_deploy-0.4.1.tar.gz
Algorithm Hash digest
SHA256 81dfce4fd5f3c1bb1dd3794fa5d4c3e23072747720bf4d3be7d989248d059227
MD5 473b22528edc48e37bb6e3df97f463ae
BLAKE2b-256 345d1c7169eef2fbf5fdca8fa926a25e2a07950903499001f37c734691d8f362

See more details on using hashes here.

Provenance

The following attestation bundles were made for n8n_deploy-0.4.1.tar.gz:

Publisher: ci.yml on lehcode/n8n-deploy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file n8n_deploy-0.4.1-py3-none-any.whl.

File metadata

  • Download URL: n8n_deploy-0.4.1-py3-none-any.whl
  • Upload date:
  • Size: 99.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for n8n_deploy-0.4.1-py3-none-any.whl
Algorithm Hash digest
SHA256 3c87fd1e79e479ca355714369f7ac8f7f81ee48fb7660f0ca4815026c5ad5dd4
MD5 6bdae959afff0daac04e0c8c2354d753
BLAKE2b-256 9a43f8607c6d9d54a3b48ef9f7c28516a82409657848ef9f06d036af802186e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for n8n_deploy-0.4.1-py3-none-any.whl:

Publisher: ci.yml on lehcode/n8n-deploy

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page