Skip to main content

CLI for n8n workflow automation

Project description

n8nc

CLI for n8n workflow automation. Sync workflows with Git, author them locally, and manage remote instances from the terminal.

Quick start

# Install (pick one)
cargo install n8nc              # From source
pip install n8nc                # Via pip
uvx n8nc --help                 # Run without installing

# Set up a repo
n8nc init --instance prod --url https://your-instance.app.n8n.cloud
n8nc auth add prod --token <api_key>

# Pull and track workflows
n8nc pull --all --instance prod
n8nc status

Installation

From crates.io

cargo install n8nc

From PyPI

pip install n8nc
# or run without installing:
uvx n8nc ls --instance prod

From GitHub releases

Pre-built binaries for Linux (x64, arm64), macOS (x64, arm64), and Windows (x64) on the releases page.

What it does

n8nc is three things:

  • Git sync for n8n workflows you want to track locally
  • Local authoring for draft workflows and structured node edits
  • Development CLI for listing, pulling, pushing, triggering, and inspecting executions

Every command supports --json for agent and script integration.

Commands

n8nc init                          Set up a workflow repo
n8nc doctor                        Check repo, auth, and API health

n8nc auth add|test|list|remove     Manage API tokens
n8nc auth session add|test|remove  Manage browser-session auth

n8nc ls                            List remote workflows
n8nc get <id-or-name>              Fetch and print a workflow
n8nc pull <id-or-name>             Pull a workflow into the repo
n8nc pull --all [--active]         Pull all workflows
n8nc push <file>                   Push a tracked workflow back
n8nc push --all                    Push all modified tracked workflows
n8nc activate <id-or-name>         Activate a workflow
n8nc deactivate <id-or-name>       Deactivate a workflow

n8nc runs ls                       List recent executions
n8nc runs get <id> [--details]     Inspect one execution
n8nc runs watch                    Watch executions live

n8nc workflow new <name>           Create a local draft
n8nc workflow create <file>        Publish a draft to n8n
n8nc workflow execute <id-or-name> Execute via configured backend
n8nc workflow show <file>          Inspect a local workflow
n8nc workflow rm <target>          Remove a workflow

n8nc node ls|add|set|rename|rm     Edit nodes in local workflows
n8nc conn add|rm                   Edit connections
n8nc expr set                      Set expressions on nodes
n8nc credential ls|schema|set      Discover and assign credentials

n8nc status [--refresh]            Show local sync state
n8nc diff <file> [--refresh]       Show local changes
n8nc trigger <url>                 Call a webhook URL
n8nc fmt [--check]                 Format workflow files
n8nc validate                      Validate workflow files
n8nc completions <shell>           Generate shell completions

Repo model

n8nc init creates:

.
├── n8n.toml           # Instance config
├── workflows/         # Tracked and draft workflow files
└── .n8n/cache/        # Base snapshots for local diff

Tracked workflows are stored as canonical JSON with a metadata sidecar:

workflows/<slug>--<id>.workflow.json
workflows/<slug>--<id>.meta.json

The sidecar binds each file to the instance it came from and records a hash used for safe push (lease check).

Auth

Tokens are resolved in order:

  1. N8NC_TOKEN_<ALIAS> env var
  2. OS keychain entry from n8nc auth add

Optional browser-session auth (for credential inventory fallback):

  1. N8NC_SESSION_COOKIE_<ALIAS> + N8NC_BROWSER_ID_<ALIAS> env vars
  2. OS keychain entries from n8nc auth session add

Workflow execution

trigger calls webhook URLs directly. For non-webhook workflows, configure an external backend in n8n.toml:

[instances.prod.execute]
backend = "command"
program = "uvx"
args = ["your-runner", "execute_workflow", "{workflow_id}", "{instance_alias}"]
stdin_json = true

Then run:

n8nc workflow execute "Nightly Digest" --instance prod --input '{"dryRun":true}'

Design

  • Same-instance first -- tracked files are bound to the instance they were pulled from
  • Agent-safe -- every command supports --json with structured envelopes
  • Deterministic -- workflows are canonicalized before storage and hashing
  • Safe push -- refuses to overwrite remote changes since the last pull
  • Sensitive-data aware -- scans for inline secrets on pull, push, and validate
  • Honest execution -- trigger is for webhooks; workflow execute delegates to a configured backend

Spec

Implementation notes and roadmap live in docs/cli-spec.md.

License

MIT

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

n8nc-0.1.0.tar.gz (112.6 kB view details)

Uploaded Source

Built Distributions

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

n8nc-0.1.0-py3-none-win_amd64.whl (3.3 MB view details)

Uploaded Python 3Windows x86-64

n8nc-0.1.0-py3-none-manylinux_2_28_x86_64.whl (3.3 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ x86-64

n8nc-0.1.0-py3-none-manylinux_2_28_aarch64.whl (3.2 MB view details)

Uploaded Python 3manylinux: glibc 2.28+ ARM64

n8nc-0.1.0-py3-none-macosx_11_0_arm64.whl (3.1 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

n8nc-0.1.0-py3-none-macosx_10_12_x86_64.whl (3.2 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

Details for the file n8nc-0.1.0.tar.gz.

File metadata

  • Download URL: n8nc-0.1.0.tar.gz
  • Upload date:
  • Size: 112.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for n8nc-0.1.0.tar.gz
Algorithm Hash digest
SHA256 7ffaa2be69a83db27a1df0e537ed2a98fc5eef84ec82cd5bef8ba7c4a0e5c1ea
MD5 3214de276b4482825ccea9403ef785ae
BLAKE2b-256 22ca3a4d1342daee73119269f93d983f22de12bdbcfc5be03caa0a505d47512d

See more details on using hashes here.

File details

Details for the file n8nc-0.1.0-py3-none-win_amd64.whl.

File metadata

  • Download URL: n8nc-0.1.0-py3-none-win_amd64.whl
  • Upload date:
  • Size: 3.3 MB
  • Tags: Python 3, Windows x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for n8nc-0.1.0-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 a98de91a0739e7d11c1eb19e4cce8dff3cc0c7a3f6c2390f913ee6f62e633c05
MD5 f941cb264433dcfa6eacb1261b8fa076
BLAKE2b-256 791a853eb50e366c8f6ef9164ee54ba690457549ad3d51e188356c61ad2e706b

See more details on using hashes here.

File details

Details for the file n8nc-0.1.0-py3-none-manylinux_2_28_x86_64.whl.

File metadata

  • Download URL: n8nc-0.1.0-py3-none-manylinux_2_28_x86_64.whl
  • Upload date:
  • Size: 3.3 MB
  • Tags: Python 3, manylinux: glibc 2.28+ x86-64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for n8nc-0.1.0-py3-none-manylinux_2_28_x86_64.whl
Algorithm Hash digest
SHA256 f52ba6e485f83c59a22a27405605060d7bdc6c0e13dcee21f7faa9fc8a11cbe9
MD5 fb77bbec191e33d7f38846c89cd6685c
BLAKE2b-256 f2bd88cec55567c8c218fab308ac149efc40517a33bc34e6b71f42a9f6ef10a0

See more details on using hashes here.

File details

Details for the file n8nc-0.1.0-py3-none-manylinux_2_28_aarch64.whl.

File metadata

File hashes

Hashes for n8nc-0.1.0-py3-none-manylinux_2_28_aarch64.whl
Algorithm Hash digest
SHA256 970f34802ca89f2351296201268761bb809689a88ef7bb34cdf0d5dfaaf418e9
MD5 073e1eda4b66667a5e2f981a89e4c852
BLAKE2b-256 3673cfd421be1e18d5a42308dd837e27d2023239c42e685f2106e9d312c4c544

See more details on using hashes here.

File details

Details for the file n8nc-0.1.0-py3-none-macosx_11_0_arm64.whl.

File metadata

  • Download URL: n8nc-0.1.0-py3-none-macosx_11_0_arm64.whl
  • Upload date:
  • Size: 3.1 MB
  • Tags: Python 3, macOS 11.0+ ARM64
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.3

File hashes

Hashes for n8nc-0.1.0-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 f156ac738a6830ba96388a3d02c5c517f523b07ba7871b81a0fe22090aa8085f
MD5 0e524082df574c6cb3f0bffa06264a8e
BLAKE2b-256 61f2ef8ff8ba1f25a3ffd85b57140fd098e2cc463c048e23358170c4ff28f7ca

See more details on using hashes here.

File details

Details for the file n8nc-0.1.0-py3-none-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for n8nc-0.1.0-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 1e8ab8ae15710d42acfad9326e2c326f458e8e8baa8033b9fd3e31f141f20e9f
MD5 686074f77ccfb95dc153d131f01b1e03
BLAKE2b-256 2cb4d583534b82a9397c621f4e6a76c46757f25efa15ba3dc3ed2ad4dee558cd

See more details on using hashes here.

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