126 lines
3.7 KiB
Bash
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"
|