Files
eventsphere/deploy/install.sh
2026-04-25 21:57:48 +01:00

126 lines
3.7 KiB
Bash

#!/usr/bin/env bash
set -euo pipefail
SCRIPT_DIR="$(cd "$(dirname "${BASH_SOURCE[0]}")" && pwd)"
cd "$SCRIPT_DIR"
if [[ "$(id -u)" -ne 0 ]]; then
echo "Run as root (sudo)."
exit 1
fi
if ! command -v docker >/dev/null 2>&1; then
if command -v apt-get >/dev/null 2>&1; then
apt-get update -y
apt-get install -y ca-certificates curl gnupg
install -m 0755 -d /etc/apt/keyrings
curl -fsSL https://download.docker.com/linux/ubuntu/gpg | gpg --dearmor -o /etc/apt/keyrings/docker.gpg
chmod a+r /etc/apt/keyrings/docker.gpg
echo "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.gpg] https://download.docker.com/linux/ubuntu $(. /etc/os-release && echo "$VERSION_CODENAME") stable" > /etc/apt/sources.list.d/docker.list
apt-get update -y
apt-get install -y docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin
systemctl enable --now docker
else
echo "Docker is not installed and this installer only supports apt-based systems."
exit 1
fi
fi
if ! docker compose version >/dev/null 2>&1; then
echo "Docker Compose plugin is required (docker compose)."
exit 1
fi
ENV_FILE="$SCRIPT_DIR/.env"
rand_hex() {
if command -v openssl >/dev/null 2>&1; then
openssl rand -hex 24
else
head -c 32 /dev/urandom | od -An -tx1 | tr -d " \n"
fi
}
load_env() {
while IFS= read -r line || [[ -n "$line" ]]; do
line="${line%$'\r'}"
line="${line#"${line%%[![:space:]]*}"}"
[[ -z "$line" ]] && continue
[[ "$line" =~ ^[[:space:]]*# ]] && continue
if [[ "$line" =~ ^export[[:space:]]+([A-Za-z_][A-Za-z0-9_]*)=(.*)$ ]]; then
key="${BASH_REMATCH[1]}"
val="${BASH_REMATCH[2]}"
if [[ "$val" =~ ^\"(.*)\"$ ]]; then val="${BASH_REMATCH[1]}"; fi
if [[ "$val" =~ ^\'(.*)\'$ ]]; then val="${BASH_REMATCH[1]}"; fi
export "$key=$val"
elif [[ "$line" =~ ^([A-Za-z_][A-Za-z0-9_]*)=(.*)$ ]]; then
key="${BASH_REMATCH[1]}"
val="${BASH_REMATCH[2]}"
if [[ "$val" =~ ^\"(.*)\"$ ]]; then val="${BASH_REMATCH[1]}"; fi
if [[ "$val" =~ ^\'(.*)\'$ ]]; then val="${BASH_REMATCH[1]}"; fi
export "$key=$val"
fi
done < "$ENV_FILE"
}
if [[ ! -f "$ENV_FILE" ]]; then
POSTGRES_PASSWORD="$(rand_hex)"
JWT_SECRET="$(rand_hex)"
DEFAULT_SUPERADMIN_PASSWORD="$(rand_hex)"
cat > "$ENV_FILE" <<EOF
LETSENCRYPT_EMAIL=admin@brainshare.ng
POSTGRES_DB=eventsphere
POSTGRES_USER=eventsphere
POSTGRES_PASSWORD=${POSTGRES_PASSWORD}
DATABASE_URL=postgresql://eventsphere:${POSTGRES_PASSWORD}@postgres:5432/eventsphere
JWT_SECRET=${JWT_SECRET}
JWT_ACCESS_TTL=15m
JWT_REFRESH_TTL=30d
AUTO_BOOTSTRAP=1
DEFAULT_TENANT_NAME="BrainShare"
DEFAULT_TENANT_SLUG=brainshare
DEFAULT_SUPERADMIN_FULL_NAME="Super Admin"
DEFAULT_SUPERADMIN_EMAIL=superadmin@brainshare.ng
DEFAULT_SUPERADMIN_PASSWORD=${DEFAULT_SUPERADMIN_PASSWORD}
SMTP_HOST=
SMTP_PORT=587
SMTP_USER=
SMTP_PASS=
SMTP_FROM=
AFRICASTALKING_USERNAME=
AFRICASTALKING_API_KEY=
AFRICASTALKING_SENDER_ID=
AFRICASTALKING_WHATSAPP_URL=
PAYSTACK_SECRET_KEY=
EOF
chmod 600 "$ENV_FILE"
echo "Created deploy/.env"
echo "Superadmin credentials:"
echo " email: superadmin@brainshare.ng"
echo " password: ${DEFAULT_SUPERADMIN_PASSWORD}"
echo "Update deploy/.env (LETSENCRYPT_EMAIL and any integration keys) before continuing if needed."
fi
load_env
if [[ -z "${LETSENCRYPT_EMAIL:-}" ]]; then
echo "LETSENCRYPT_EMAIL is required (set it in deploy/.env)."
exit 1
fi
docker compose --env-file "$ENV_FILE" pull
docker compose --env-file "$ENV_FILE" build
docker compose --env-file "$ENV_FILE" up -d
echo "Deployment started."
echo "Web: https://even.brainshare.ng"
echo "API: https://apil.event.brainshare.ng/api/v1/health"