2020-04-28 15:53:56 +02:00
|
|
|
#!/bin/sh
|
|
|
|
|
|
|
|
[ -z "${PROXY_HTTP_PORT}" ] && export PROXY_HTTP_PORT=80
|
|
|
|
[ -z "${PROXY_HTTPS_PORT}" ] && export PROXY_HTTPS_PORT=443
|
2020-03-24 17:18:37 +01:00
|
|
|
|
2020-03-25 12:42:26 +01:00
|
|
|
# Start with default certbot conf
|
2020-04-28 15:53:56 +02:00
|
|
|
nginx -g "daemon on;"
|
2020-03-25 12:42:26 +01:00
|
|
|
|
|
|
|
# Show input enviroment variables
|
2020-04-28 15:53:56 +02:00
|
|
|
echo "Http Port: ${PROXY_HTTP_PORT}"
|
|
|
|
echo "Https Port: ${PROXY_HTTPS_PORT}"
|
2020-03-25 12:42:26 +01:00
|
|
|
echo "Domain name: ${DOMAIN_OR_PUBLIC_IP}"
|
|
|
|
echo "Certificated: ${CERTIFICATE_TYPE}"
|
|
|
|
echo "Letsencrypt Email: ${LETSENCRYPT_EMAIL}"
|
2020-04-09 16:33:26 +02:00
|
|
|
echo "Proxy mode: ${PROXY_MODE:-CE}"
|
|
|
|
echo "Demos mode: ${WITH_DEMOS:-true}"
|
2020-03-27 12:53:04 +01:00
|
|
|
|
2020-03-25 12:42:26 +01:00
|
|
|
case ${CERTIFICATE_TYPE} in
|
|
|
|
|
|
|
|
"selfsigned")
|
2020-03-27 12:53:04 +01:00
|
|
|
echo "===Mode selfsigned==="
|
|
|
|
|
2020-04-09 16:33:26 +02:00
|
|
|
if [[ ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/privkey.pem" && ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/fullchain.pem" ]]; then
|
2020-03-27 12:53:04 +01:00
|
|
|
echo "Generating certificated..."
|
|
|
|
|
|
|
|
rm -rf /etc/letsencrypt/live/*
|
2020-04-28 15:53:56 +02:00
|
|
|
mkdir -p "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}"
|
2020-03-27 12:53:04 +01:00
|
|
|
|
|
|
|
openssl req -new -nodes -x509 \
|
2020-04-09 16:33:26 +02:00
|
|
|
-subj "/CN=${DOMAIN_OR_PUBLIC_IP}" -days 365 \
|
2020-04-28 15:53:56 +02:00
|
|
|
-keyout "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/privkey.pem" \
|
|
|
|
-out "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/fullchain.pem" -extensions v3_ca
|
2020-03-27 12:53:04 +01:00
|
|
|
else
|
|
|
|
echo "The certificate already exists, using them..."
|
|
|
|
fi
|
2020-03-25 12:42:26 +01:00
|
|
|
;;
|
|
|
|
|
|
|
|
"owncert")
|
2020-03-27 12:53:04 +01:00
|
|
|
echo "===Mode owncert==="
|
|
|
|
|
|
|
|
if [[ ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/privkey.pem" && ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/fullchain.pem" ]]; then
|
|
|
|
echo "Using owmcert..."
|
|
|
|
|
|
|
|
rm -rf /etc/letsencrypt/live/*
|
2020-04-28 15:53:56 +02:00
|
|
|
mkdir -p "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}"
|
|
|
|
cp /owncert/certificate.key "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/privkey.pem"
|
|
|
|
cp /owncert/certificate.cert "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/fullchain.pem"
|
2020-03-25 12:42:26 +01:00
|
|
|
|
2020-03-27 12:53:04 +01:00
|
|
|
else
|
|
|
|
echo "The certificate already exists, using them..."
|
|
|
|
fi
|
2020-03-25 12:42:26 +01:00
|
|
|
;;
|
|
|
|
|
|
|
|
"letsencrypt")
|
2020-03-27 12:53:04 +01:00
|
|
|
echo "===Mode letsencrypt==="
|
|
|
|
|
|
|
|
# Auto renew cert
|
2020-04-28 15:53:56 +02:00
|
|
|
echo "0 12 * * * certbot renew >> /var/log/nginx/cron-letsencrypt.log" | crontab -
|
2020-03-27 12:53:04 +01:00
|
|
|
|
|
|
|
if [[ ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/privkey.pem" && ! -f "/etc/letsencrypt/live/${DOMAIN_OR_PUBLIC_IP}/fullchain.pem" ]]; then
|
|
|
|
echo "Requesting certificate..."
|
2020-03-24 17:18:37 +01:00
|
|
|
|
2020-04-28 15:53:56 +02:00
|
|
|
certbot certonly -n --webroot -w /var/www/certbot -m "${LETSENCRYPT_EMAIL}" --agree-tos -d "${DOMAIN_OR_PUBLIC_IP}"
|
2020-03-27 12:53:04 +01:00
|
|
|
else
|
|
|
|
echo "The certificate already exists, using them..."
|
|
|
|
fi
|
2020-03-25 12:42:26 +01:00
|
|
|
;;
|
|
|
|
esac
|
2020-03-24 17:18:37 +01:00
|
|
|
|
2020-03-27 12:53:04 +01:00
|
|
|
# All permission certificated folder
|
|
|
|
chmod -R 777 /etc/letsencrypt
|
|
|
|
|
2020-04-09 16:33:26 +02:00
|
|
|
# Use certificates in folder '/default_nginx_conf'
|
|
|
|
if [ "${PROXY_MODE}" == "CE" ]; then
|
|
|
|
if [ "${WITH_DEMOS}" == "true" ]; then
|
|
|
|
mv /default_nginx_conf/ce/default-app.conf /default_nginx_conf/default-app.conf
|
|
|
|
mv /default_nginx_conf/ce/default.conf /default_nginx_conf/default.conf
|
|
|
|
else
|
|
|
|
mv /default_nginx_conf/ce/default-app-without-demos.conf /default_nginx_conf/default-app.conf
|
|
|
|
mv /default_nginx_conf/ce/default.conf /default_nginx_conf/default.conf
|
|
|
|
fi
|
|
|
|
|
|
|
|
rm -rf /default_nginx_conf/ce
|
|
|
|
rm -rf /default_nginx_conf/pro
|
2020-03-27 12:53:04 +01:00
|
|
|
fi
|
|
|
|
|
2020-04-09 16:33:26 +02:00
|
|
|
if [ "${PROXY_MODE}" == "PRO" ]; then
|
|
|
|
if [ "${WITH_DEMOS}" == "true" ]; then
|
|
|
|
mv /default_nginx_conf/pro/default.conf /default_nginx_conf/default.conf
|
|
|
|
else
|
|
|
|
mv /default_nginx_conf/pro/default-app-without-demos.conf /default_nginx_conf/default.conf
|
|
|
|
fi
|
|
|
|
|
|
|
|
rm -rf /default_nginx_conf/ce
|
|
|
|
rm -rf /default_nginx_conf/pro
|
|
|
|
fi
|
|
|
|
|
|
|
|
# Create index.html
|
|
|
|
mkdir -p /var/www/html
|
|
|
|
cat> /var/www/html/index.html<<EOF
|
|
|
|
Welcome to OpenVidu Server
|
|
|
|
EOF
|
|
|
|
|
|
|
|
# Load nginx conf files
|
|
|
|
rm /etc/nginx/conf.d/*
|
|
|
|
cp /default_nginx_conf/* /etc/nginx/conf.d
|
2020-04-28 15:53:56 +02:00
|
|
|
sed -i "s/{domain_name}/${DOMAIN_OR_PUBLIC_IP}/g" /etc/nginx/conf.d/*
|
|
|
|
sed -i "s/{http_port}/${PROXY_HTTP_PORT}/g" /etc/nginx/conf.d/*
|
|
|
|
sed -i "s/{https_port}/${PROXY_HTTPS_PORT}/g" /etc/nginx/conf.d/*
|
2020-03-24 17:18:37 +01:00
|
|
|
|
2020-03-27 12:53:04 +01:00
|
|
|
# Restart nginx service
|
2020-04-28 15:53:56 +02:00
|
|
|
nginx -s reload
|
2020-03-27 12:53:04 +01:00
|
|
|
|
|
|
|
# Init cron
|
2020-04-28 15:53:56 +02:00
|
|
|
/usr/sbin/crond -f &
|
2020-03-27 12:53:04 +01:00
|
|
|
|
2020-04-28 15:53:56 +02:00
|
|
|
# nginx logs
|
2020-03-24 17:18:37 +01:00
|
|
|
tail -f /var/log/nginx/*.log
|