mirror of
https://github.com/kossakovsky/n8n-install.git
synced 2026-03-08 06:43:22 +00:00
update configure services to call generate_n8n_workers.sh instead of prompting for separate runner count. update start_services.py and apply_update.sh to include docker-compose.n8n-workers.yml when present.
203 lines
8.1 KiB
Bash
203 lines
8.1 KiB
Bash
#!/bin/bash
|
|
|
|
set -e
|
|
|
|
# Source the utilities file
|
|
source "$(dirname "$0")/utils.sh"
|
|
|
|
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
|
|
PROJECT_ROOT="$(cd "$SCRIPT_DIR/.." && pwd)"
|
|
ENV_FILE="$PROJECT_ROOT/.env"
|
|
|
|
# Ensure .env exists
|
|
if [ ! -f "$ENV_FILE" ]; then
|
|
touch "$ENV_FILE"
|
|
fi
|
|
|
|
# Helper: read value from .env (without surrounding quotes)
|
|
read_env_var() {
|
|
local var_name="$1"
|
|
if grep -q "^${var_name}=" "$ENV_FILE"; then
|
|
grep "^${var_name}=" "$ENV_FILE" | cut -d'=' -f2- | sed 's/^"//' | sed 's/"$//'
|
|
else
|
|
echo ""
|
|
fi
|
|
}
|
|
|
|
# Helper: upsert value into .env (quote the value)
|
|
write_env_var() {
|
|
local var_name="$1"
|
|
local var_value="$2"
|
|
if grep -q "^${var_name}=" "$ENV_FILE"; then
|
|
# use different delimiter to be safe
|
|
sed -i.bak "\|^${var_name}=|d" "$ENV_FILE"
|
|
fi
|
|
echo "${var_name}=\"${var_value}\"" >> "$ENV_FILE"
|
|
}
|
|
|
|
log_info "Configuring service options in .env..."
|
|
|
|
|
|
# ----------------------------------------------------------------
|
|
# Prompt for OpenAI API key (optional) using .env value as source of truth
|
|
# ----------------------------------------------------------------
|
|
EXISTING_OPENAI_API_KEY="$(read_env_var OPENAI_API_KEY)"
|
|
OPENAI_API_KEY=""
|
|
if [[ -z "$EXISTING_OPENAI_API_KEY" ]]; then
|
|
require_whiptail
|
|
OPENAI_API_KEY=$(wt_input "OpenAI API Key" "Optional: Used by Supabase AI (SQL assistance) and Crawl4AI. Leave empty to skip." "") || true
|
|
if [[ -n "$OPENAI_API_KEY" ]]; then
|
|
write_env_var "OPENAI_API_KEY" "$OPENAI_API_KEY"
|
|
fi
|
|
else
|
|
# Reuse existing value without prompting
|
|
OPENAI_API_KEY="$EXISTING_OPENAI_API_KEY"
|
|
fi
|
|
|
|
|
|
# ----------------------------------------------------------------
|
|
# Logic for n8n workflow import (RUN_N8N_IMPORT)
|
|
# ----------------------------------------------------------------
|
|
final_run_n8n_import_decision="false"
|
|
require_whiptail
|
|
if wt_yesno "Import n8n Workflows" "Import ~300 ready-made n8n workflows now? This can take ~30 minutes." "no"; then
|
|
final_run_n8n_import_decision="true"
|
|
else
|
|
final_run_n8n_import_decision="false"
|
|
fi
|
|
|
|
# Persist RUN_N8N_IMPORT to .env
|
|
write_env_var "RUN_N8N_IMPORT" "$final_run_n8n_import_decision"
|
|
|
|
|
|
# ----------------------------------------------------------------
|
|
# Prompt for number of n8n workers
|
|
# ----------------------------------------------------------------
|
|
echo "" # Add a newline for better formatting
|
|
log_info "Configuring n8n worker count..."
|
|
EXISTING_N8N_WORKER_COUNT="$(read_env_var N8N_WORKER_COUNT)"
|
|
require_whiptail
|
|
if [[ -n "$EXISTING_N8N_WORKER_COUNT" ]]; then
|
|
N8N_WORKER_COUNT_CURRENT="$EXISTING_N8N_WORKER_COUNT"
|
|
N8N_WORKER_COUNT_INPUT_RAW=$(wt_input "n8n Workers (instances)" "Enter new number of n8n workers, or leave as current ($N8N_WORKER_COUNT_CURRENT)." "") || true
|
|
if [[ -z "$N8N_WORKER_COUNT_INPUT_RAW" ]]; then
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_CURRENT"
|
|
else
|
|
if [[ "$N8N_WORKER_COUNT_INPUT_RAW" =~ ^0*[1-9][0-9]*$ ]]; then
|
|
N8N_WORKER_COUNT_TEMP="$((10#$N8N_WORKER_COUNT_INPUT_RAW))"
|
|
if [[ "$N8N_WORKER_COUNT_TEMP" -ge 1 ]]; then
|
|
if wt_yesno "Confirm Workers" "Update n8n workers to $N8N_WORKER_COUNT_TEMP?" "yes"; then
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_TEMP"
|
|
else
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_CURRENT"
|
|
log_info "Change declined. Keeping N8N_WORKER_COUNT at $N8N_WORKER_COUNT."
|
|
fi
|
|
else
|
|
log_warning "Invalid input '$N8N_WORKER_COUNT_INPUT_RAW'. Number must be positive. Keeping $N8N_WORKER_COUNT_CURRENT."
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_CURRENT"
|
|
fi
|
|
else
|
|
log_warning "Invalid input '$N8N_WORKER_COUNT_INPUT_RAW'. Please enter a positive integer. Keeping $N8N_WORKER_COUNT_CURRENT."
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_CURRENT"
|
|
fi
|
|
fi
|
|
else
|
|
while true; do
|
|
N8N_WORKER_COUNT_INPUT_RAW=$(wt_input "n8n Workers" "Enter number of n8n workers to run (default 1)." "1") || true
|
|
N8N_WORKER_COUNT_CANDIDATE="${N8N_WORKER_COUNT_INPUT_RAW:-1}"
|
|
if [[ "$N8N_WORKER_COUNT_CANDIDATE" =~ ^0*[1-9][0-9]*$ ]]; then
|
|
N8N_WORKER_COUNT_VALIDATED="$((10#$N8N_WORKER_COUNT_CANDIDATE))"
|
|
if [[ "$N8N_WORKER_COUNT_VALIDATED" -ge 1 ]]; then
|
|
if wt_yesno "Confirm Workers" "Run $N8N_WORKER_COUNT_VALIDATED n8n worker(s)?" "yes"; then
|
|
N8N_WORKER_COUNT="$N8N_WORKER_COUNT_VALIDATED"
|
|
break
|
|
fi
|
|
else
|
|
log_error "Number of workers must be a positive integer." >&2
|
|
fi
|
|
else
|
|
log_error "Invalid input '$N8N_WORKER_COUNT_CANDIDATE'. Please enter a positive integer (e.g., 1, 2)." >&2
|
|
fi
|
|
done
|
|
fi
|
|
# Ensure N8N_WORKER_COUNT is definitely set (should be by logic above)
|
|
N8N_WORKER_COUNT="${N8N_WORKER_COUNT:-1}"
|
|
|
|
# Persist N8N_WORKER_COUNT to .env
|
|
write_env_var "N8N_WORKER_COUNT" "$N8N_WORKER_COUNT"
|
|
|
|
# Generate worker-runner pairs configuration
|
|
# Each worker gets its own dedicated task runner sidecar
|
|
log_info "Generating n8n worker-runner pairs configuration..."
|
|
bash "$SCRIPT_DIR/generate_n8n_workers.sh"
|
|
|
|
|
|
# ----------------------------------------------------------------
|
|
# Cloudflare Tunnel Token (if cloudflare-tunnel profile is active)
|
|
# ----------------------------------------------------------------
|
|
# If Cloudflare Tunnel is selected (based on COMPOSE_PROFILES), prompt for the token and write to .env
|
|
COMPOSE_PROFILES_VALUE="$(read_env_var COMPOSE_PROFILES)"
|
|
cloudflare_selected=0
|
|
if [[ "$COMPOSE_PROFILES_VALUE" == *"cloudflare-tunnel"* ]]; then
|
|
cloudflare_selected=1
|
|
fi
|
|
|
|
if [ $cloudflare_selected -eq 1 ]; then
|
|
existing_cf_token=""
|
|
if grep -q "^CLOUDFLARE_TUNNEL_TOKEN=" "$ENV_FILE"; then
|
|
existing_cf_token=$(grep "^CLOUDFLARE_TUNNEL_TOKEN=" "$ENV_FILE" | cut -d'=' -f2- | sed 's/^\"//' | sed 's/\"$//')
|
|
fi
|
|
|
|
if [ -n "$existing_cf_token" ]; then
|
|
log_info "Cloudflare Tunnel token found in .env; reusing it."
|
|
# Do not prompt; keep existing token as-is
|
|
else
|
|
require_whiptail
|
|
input_cf_token=$(wt_input "Cloudflare Tunnel Token" "Enter your Cloudflare Tunnel token (leave empty to skip)." "") || true
|
|
token_to_write="$input_cf_token"
|
|
|
|
# Update the .env with the token (may be empty if user skipped)
|
|
if grep -q "^CLOUDFLARE_TUNNEL_TOKEN=" "$ENV_FILE"; then
|
|
sed -i.bak "/^CLOUDFLARE_TUNNEL_TOKEN=/d" "$ENV_FILE"
|
|
fi
|
|
echo "CLOUDFLARE_TUNNEL_TOKEN=\"$token_to_write\"" >> "$ENV_FILE"
|
|
|
|
if [ -n "$token_to_write" ]; then
|
|
log_success "Cloudflare Tunnel token saved to .env."
|
|
echo ""
|
|
echo "🔒 After confirming the tunnel works, consider closing ports 80, 443, and 7687 in your firewall."
|
|
else
|
|
log_warning "Cloudflare Tunnel token was left empty. You can set it later in .env."
|
|
fi
|
|
fi
|
|
fi
|
|
|
|
|
|
# ----------------------------------------------------------------
|
|
# Safety: If Supabase is present, remove Dify from COMPOSE_PROFILES (no prompts)
|
|
# ----------------------------------------------------------------
|
|
if [[ -n "$COMPOSE_PROFILES_VALUE" && "$COMPOSE_PROFILES_VALUE" == *"supabase"* ]]; then
|
|
IFS=',' read -r -a profiles_array <<< "$COMPOSE_PROFILES_VALUE"
|
|
new_profiles=()
|
|
for p in "${profiles_array[@]}"; do
|
|
if [[ "$p" != "dify" ]]; then
|
|
new_profiles+=("$p")
|
|
fi
|
|
done
|
|
COMPOSE_PROFILES_VALUE_UPDATED=$(IFS=','; echo "${new_profiles[*]}")
|
|
if [[ "$COMPOSE_PROFILES_VALUE_UPDATED" != "$COMPOSE_PROFILES_VALUE" ]]; then
|
|
write_env_var "COMPOSE_PROFILES" "$COMPOSE_PROFILES_VALUE_UPDATED"
|
|
log_info "Supabase present: removed 'dify' from COMPOSE_PROFILES due to conflict with Supabase."
|
|
COMPOSE_PROFILES_VALUE="$COMPOSE_PROFILES_VALUE_UPDATED"
|
|
fi
|
|
fi
|
|
|
|
# ----------------------------------------------------------------
|
|
# Ensure Supabase Analytics targets the correct Postgres service name used by Supabase docker compose
|
|
# ----------------------------------------------------------------
|
|
write_env_var "POSTGRES_HOST" "db"
|
|
# ----------------------------------------------------------------
|
|
|
|
log_success "Service configuration complete. .env updated at $ENV_FILE"
|
|
|
|
exit 0 |