https://github.com/pigri/cf-n8n-proxy
Cloudflare worker for n8n proxy
https://github.com/pigri/cf-n8n-proxy
cf cloudflare firewall n8n proxy rate-limit security
Last synced: 6 months ago
JSON representation
Cloudflare worker for n8n proxy
- Host: GitHub
- URL: https://github.com/pigri/cf-n8n-proxy
- Owner: pigri
- License: apache-2.0
- Created: 2024-03-09T12:05:28.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2025-07-26T02:07:55.000Z (11 months ago)
- Last Synced: 2025-07-26T08:54:12.729Z (11 months ago)
- Topics: cf, cloudflare, firewall, n8n, proxy, rate-limit, security
- Language: TypeScript
- Homepage:
- Size: 394 KB
- Stars: 35
- Watchers: 2
- Forks: 2
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Security: SECURITY.md
Awesome Lists containing this project
README
# cf-n8n-proxy
Cloudflare worker for n8n proxy
### Why do you need this?
- You can use this service to protect your n8n instance from DDoS attacks.
- You can use this service to hide your n8n instance from the public.
- You can use this service to add rate limiting to your n8n instance.
- You can use this service to add deduplication to your n8n instance.
- You can use this service to add a queue to your n8n instance.
- You can use this service to add a retry mechanism to your n8n instance.
### Requirements:
- You need a paid Worker plan ($5 USD) for this service due to the queue.
- A cloudflare domain
### Architecture:
cloudflare -> cloudflare worker -> n8n
## How to use?
### Wrangler install
```
npm install -g wrangler pnpm
```
### NPM package install
```
pnpm install
```
### Wrangler login
```
wrangler login
```
### Create your wrangler config
```
cp wrangler.toml_example wrangler.toml
```
- Change everywhere `example.com` to your domain
### Create queue
```
wrangler queues create cf-n8n-proxy-production -e production
wrangler queues create dlq-cf-n8n-proxy-production -e production
```
### Enable deduplication feature
```
wrangler kv:namespace create cf-n8n-proxy
```
- Replace `` with the response ID in the wrangler.toml file.
- Change `DEDUPLICATION_ENABLED=false` to `DEDUPLICATION_ENABLED=true` in the wrangler.toml file.
### IMPORTANT NOTES ABOUT DEDUPLICATION "As of January 2022, expiration targets that are less than 60 seconds into the future are not supported. This is true for both expiration methods."
- `DEDUPLICATION_TTL` is optional; by default, it is set to 60 seconds.
### Rate limiting
- Change `RATE_LIMITING_ENABLED=false` to `RATE_LIMITING_ENABLED=true` in the wrangler.toml file.
#### Default 100 requests per minute
```
simple = { limit = 100, period = 60 }
```
### Deploy your service
```
wrangler deploy -e production
```
### How to test in local?
```
wrangler dev
```