#!/bin/sh set -e export PORT=${PORT:-8080} export ENABLE_SSL=${ENABLE_SSL:-false} export SSL_PORT=${SSL_PORT:-8443} export SSL_CERT_PATH=${SSL_CERT_PATH:-/app/data/ssl/termix.crt} export SSL_KEY_PATH=${SSL_KEY_PATH:-/app/data/ssl/termix.key} echo "Configuring web UI to run on port: $PORT" if [ "$ENABLE_SSL" = "true" ]; then echo "SSL enabled - using HTTPS configuration with redirect" NGINX_CONF_SOURCE="/etc/nginx/nginx-https.conf" else echo "SSL disabled - using HTTP-only configuration (default)" NGINX_CONF_SOURCE="/etc/nginx/nginx.conf" fi envsubst '${PORT} ${SSL_PORT} ${SSL_CERT_PATH} ${SSL_KEY_PATH}' < $NGINX_CONF_SOURCE > /etc/nginx/nginx.conf.tmp mv /etc/nginx/nginx.conf.tmp /etc/nginx/nginx.conf mkdir -p /app/data /app/uploads chown -R node:node /app/data /app/uploads chmod 755 /app/data /app/uploads if [ "$ENABLE_SSL" = "true" ]; then echo "Checking SSL certificate configuration..." mkdir -p /app/data/ssl chown -R node:node /app/data/ssl chmod 755 /app/data/ssl DOMAIN=${SSL_DOMAIN:-localhost} if [ -f "/app/data/ssl/termix.crt" ] && [ -f "/app/data/ssl/termix.key" ]; then echo "SSL certificates found, checking validity..." if openssl x509 -in /app/data/ssl/termix.crt -checkend 2592000 -noout >/dev/null 2>&1; then echo "SSL certificates are valid and will be reused for domain: $DOMAIN" else echo "SSL certificate is expired or expiring soon, regenerating..." rm -f /app/data/ssl/termix.crt /app/data/ssl/termix.key fi else echo "SSL certificates not found, will generate new ones..." fi if [ ! -f "/app/data/ssl/termix.crt" ] || [ ! -f "/app/data/ssl/termix.key" ]; then echo "Generating SSL certificates for domain: $DOMAIN" cat > /app/data/ssl/openssl.conf << EOF [req] default_bits = 2048 prompt = no default_md = sha256 distinguished_name = dn req_extensions = v3_req [dn] C=US ST=State L=City O=Termix OU=IT Department CN=$DOMAIN [v3_req] basicConstraints = CA:FALSE keyUsage = nonRepudiation, digitalSignature, keyEncipherment subjectAltName = @alt_names [alt_names] DNS.1 = $DOMAIN DNS.2 = localhost DNS.3 = 127.0.0.1 IP.1 = 127.0.0.1 IP.2 = ::1 IP.3 = 0.0.0.0 EOF openssl genrsa -out /app/data/ssl/termix.key 2048 openssl req -new -x509 -key /app/data/ssl/termix.key -out /app/data/ssl/termix.crt -days 365 -config /app/data/ssl/openssl.conf -extensions v3_req chmod 600 /app/data/ssl/termix.key chmod 644 /app/data/ssl/termix.crt chown node:node /app/data/ssl/termix.key /app/data/ssl/termix.crt rm -f /app/data/ssl/openssl.conf echo "SSL certificates generated successfully for domain: $DOMAIN" fi fi echo "Starting nginx..." nginx echo "Starting backend services..." cd /app export NODE_ENV=production if [ -f "package.json" ]; then VERSION=$(grep '"version"' package.json | sed 's/.*"version": *"\([^"]*\)".*/\1/') if [ -n "$VERSION" ]; then export VERSION else echo "Warning: Could not extract version from package.json" fi else echo "Warning: package.json not found" fi if command -v su-exec > /dev/null 2>&1; then su-exec node node dist/backend/backend/starter.js else su -s /bin/sh node -c "node dist/backend/backend/starter.js" fi echo "All services started" tail -f /dev/null