Spaces:
Running
Running
| title: N8n | |
| emoji: ⚡ | |
| colorFrom: blue | |
| colorTo: gray | |
| sdk: docker | |
| pinned: false | |
| license: mit | |
| short_description: n8n free hosted with supebase | |
| Created by **[ABCDO](https://abcdo.tn/)** & [EnzGamers](https://huggingface.co/EnzGamers) . | |
| Check out the configuration reference at [spaces-config-reference](https://huggingface.co/docs/hub/spaces-config-reference) . | |
| -- | |
| # n8n - Extended Workflow Automation on Hugging Face Spaces | |
| This Hugging Face Space runs a powerful, extended instance of [n8n](https://n8n.io/), an open-source, fair-code, and self-hostable workflow automation tool. | |
| This isn't just the standard n8n. This custom Docker image comes pre-loaded with a wide range of system dependencies, designed to support a vast array of community nodes and complex workflows right out of the box, without any extra configuration. | |
| ## ✨ Key Features of This Custom Image | |
| - **Based on Node.js 20**: Built on a modern and efficient `node:20-alpine` base image. | |
| - **Chromium Included**: Full support for browser automation, web scraping, and PDF generation nodes thanks to the pre-installed `chromium`. | |
| - **Python & Git Ready**: Comes with `python3`, `pip`, and `git` installed, allowing you to run scripts and interact with repositories directly within your workflows. | |
| - **Build Tools Pre-installed**: Includes `build-base`, `g++`, and `make` to ensure compatibility with nodes that require compiling native addons. | |
| - **Database Clients**: `postgresql-client` is included for easy connection to external PostgreSQL databases. | |
| - **Graphics Libraries**: `cairo-dev` and `pango-dev` are available for nodes that perform canvas or image manipulation. | |
| ## 🚀 How to Use | |
| 1. **Launch the Space**: This Space will build the Docker container and start n8n automatically. Please be patient during the initial startup. | |
| 2. **Access n8n**: Once the application is running, the n8n editor will be available to use. | |
| 3. **Start Automating**: Begin building your workflows! You can now use many community nodes that would typically fail in a standard setup. | |
| ### Data Persistence | |
| By default, this Space uses SQLite to store your workflows and credentials, which are saved to the container's local filesystem (`/root/.n8n`). | |
| **Important**: The filesystem of a Hugging Face Space is ephemeral. To ensure your workflows are not lost when the Space restarts, you should: | |
| 1. **Download Your Workflows**: Regularly download your important workflows as JSON files from the n8n UI. | |
| 2. **Commit to Repository**: For a more advanced setup, you can configure a process to commit your workflow files (`/root/.n8n/workflows/*.json`) back to the Space's Git repository. | |
| ## ⚙️ Configuration (Using Space Secrets) | |
| For a secure and customized setup, you should configure n8n using Hugging Face Space Secrets. You can find these in your Space's **Settings** tab. | |
| | Secret Key | Description | Example Value | | |
| | --------------------------- | ---------------------------------------------------------------------------------------------------------------------------------------- | ------------------------------------------ | | |
| | `N8N_ENCRYPTION_KEY` | **(Highly Recommended)** A long, random, and secret key to encrypt your credentials. If not set, credentials are less secure. | `your_very_secret_and_long_encryption_key` | | |
| | `GENERIC_TIMEZONE` | Sets the server timezone to ensure CRON nodes and date-based triggers run at the correct time. A list of timezones can be found [here](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones). | `Europe/Berlin` | | |
| | `NODE_FUNCTION_ALLOW_EXTERNAL` | Comma-separated list of external npm modules to allow in the Function and Edit Fields nodes (e.g., `axios,lodash`). | `axios,moment` | | |
| | `WEBHOOK_URL` | **(Required for Production)** Manually set the public-facing webhook URL. It should be the URL of your Hugging Face Space. | `https://your-space-name.hf.space/` | | |
| ### Connecting to an External Database | |
| While SQLite is fine for testing, you can connect to an external PostgreSQL database (ex: Supabase 😉) for a more robust, production-ready setup. Simply set the following secrets: | |
| - `DB_TYPE`: `postgresdb` | |
| - `DB_POSTGRESDB_HOST`: Your database host | |
| - `DB_POSTGRESDB_DATABASE`: Your database name | |
| - `DB_POSTGRESDB_USER`: Your database user | |
| - `DB_POSTGRESDB_PASSWORD`: Your database password | |
| - `DB_POSTGRESDB_PORT`: `5432` | |
| ## 🐳 About the Dockerfile | |
| This instance is built from the provided `Dockerfile`. Here is a summary of its setup: | |
| - **Base Image**: `node:20-alpine` | |
| - **n8n Version**: `Latset` | |
| - **System Dependencies**: Installs `git`, `python3`, `chromium`, `build-base`, `postgresql-client`, and more using `apk`. | |
| - **Environment**: Sets up `PUPPETEER_EXECUTABLE_PATH` to work with the bundled Chromium. | |
| - **Directories**: Creates and sets appropriate permissions for the n8n data directory at `/root/.n8n`. | |
| - **Execution**: Starts n8n using the default `n8n start` command. |