--- 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.