n8n-free / README.md
EnzGamers's picture
Update README.md
08109f7 verified
---
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.