Files
Connect-5/setup-cloudsticks-simple.sh
DeNNiiInc 14598ac343 Add simple CloudSticks Nginx setup using conf.d
- Creates separate config file in /etc/nginx-cs/conf.d/
- Avoids modifying main nginx.conf
- Simpler and safer approach
- Complete server block with SSL and proxy rules
2025-12-21 17:05:31 +11:00

132 lines
3.8 KiB
Bash

#!/bin/bash
# Simple CloudSticks Nginx Proxy Setup
# Adds proxy config to http block
set -e
echo "🔧 CloudSticks Nginx Proxy Setup (Simple Method)"
echo "================================================="
echo ""
GREEN='\033[0;32m'
YELLOW='\033[1;33m'
RED='\033[0;31m'
NC='\033[0m'
if [ "$EUID" -ne 0 ]; then
echo -e "${RED}❌ Run with sudo${NC}"
exit 1
fi
CONFIG_FILE="/etc/nginx-cs/nginx.conf"
echo "Step 1: Backing up config..."
cp "$CONFIG_FILE" "${CONFIG_FILE}.backup.$(date +%Y%m%d_%H%M%S)"
echo -e "${GREEN}✅ Backup created${NC}"
echo ""
echo "Step 2: Adding proxy configuration..."
# Create a separate config file for Connect-5
cat > /etc/nginx-cs/conf.d/connect5-proxy.conf << 'EOF'
# Connect-5 Proxy Configuration
server {
listen 443 ssl;
server_name connect5.beyondcloud.technology;
# SSL certificates (CloudSticks should handle these)
# ssl_certificate and ssl_certificate_key are managed by CloudSticks
# Root directory
root /home/github2/apps/app-connect5;
index index.html;
# Serve static files
location / {
try_files $uri $uri/ /index.html;
}
# Proxy API requests to Node.js
location /api {
proxy_pass http://localhost:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection 'upgrade';
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
# Proxy Socket.io WebSocket requests
location /socket.io {
proxy_pass http://localhost:3000;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection "upgrade";
proxy_set_header Host $host;
proxy_cache_bypass $http_upgrade;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
proxy_set_header X-Forwarded-Proto $scheme;
}
}
EOF
echo -e "${GREEN}✅ Proxy config created at /etc/nginx-cs/conf.d/connect5-proxy.conf${NC}"
echo ""
echo "Step 3: Testing Nginx configuration..."
if nginx -t 2>&1 | grep -q "successful\|syntax is ok"; then
echo -e "${GREEN}✅ Config valid${NC}"
else
echo -e "${RED}❌ Config error${NC}"
nginx -t
echo ""
echo "Restoring backup..."
rm /etc/nginx-cs/conf.d/connect5-proxy.conf 2>/dev/null || true
exit 1
fi
echo ""
echo "Step 4: Reloading Nginx..."
systemctl reload nginx 2>/dev/null || service nginx reload 2>/dev/null || nginx -s reload
echo -e "${GREEN}✅ Nginx reloaded${NC}"
echo ""
echo "Step 5: Checking Node.js..."
if pgrep -f "node server.js" > /dev/null; then
echo -e "${GREEN}✅ Node.js running${NC}"
else
echo -e "${YELLOW}⚠️ Starting Node.js...${NC}"
cd /home/github2/apps/app-connect5
nohup node server.js > server.log 2>&1 &
sleep 2
echo -e "${GREEN}✅ Node.js started${NC}"
fi
echo ""
echo "Step 6: Testing..."
sleep 2
LOCAL=$(curl -s -o /dev/null -w "%{http_code}" http://localhost:3000/api/db-status 2>/dev/null || echo "000")
PROD=$(curl -s -o /dev/null -w "%{http_code}" https://connect5.beyondcloud.technology/api/db-status 2>/dev/null || echo "000")
echo "Local endpoint: HTTP $LOCAL"
echo "Production endpoint: HTTP $PROD"
if [ "$PROD" = "200" ]; then
echo ""
echo -e "${GREEN}✅ SUCCESS! Production is working!${NC}"
echo ""
curl -s https://connect5.beyondcloud.technology/api/db-status | python3 -m json.tool 2>/dev/null || curl -s https://connect5.beyondcloud.technology/api/db-status
fi
echo ""
echo "================================================="
echo -e "${GREEN}🎉 Setup Complete!${NC}"
echo ""
echo "Visit: https://connect5.beyondcloud.technology/"
echo "================================================="