Merge pull request #36 from cerc-io/dboreham/tls-proxy
Initial version of automated TLS proxy
This commit is contained in:
commit
4d8da3f145
2
tls-proxy/README.md
Normal file
2
tls-proxy/README.md
Normal file
@ -0,0 +1,2 @@
|
||||
# tls-proxy
|
||||
Automated deployment of TLS reverse proxy provisioned with Let's Encrypt certificate
|
27
tls-proxy/docker-compose.yml
Normal file
27
tls-proxy/docker-compose.yml
Normal file
@ -0,0 +1,27 @@
|
||||
services:
|
||||
|
||||
proxy:
|
||||
image: nginx:stable-bullseye
|
||||
command: "/bin/sh -c 'while :; do sleep 6h & wait $${!}; nginx -s reload; done & nginx -g \"daemon off;\"'"
|
||||
ports:
|
||||
- 80:80
|
||||
- 443:443
|
||||
volumes:
|
||||
- ./nginx/nginx.conf:/etc/nginx/nginx.conf:ro
|
||||
- ./certbot/challenge:/data/certbot-challenge:ro
|
||||
- ./certbot/certificates:/data/certificates:ro
|
||||
|
||||
certbot:
|
||||
image: certbot/certbot:v2.5.0
|
||||
volumes:
|
||||
- ./certbot/certificates:/etc/letsencrypt
|
||||
- ./certbot/challenge:/data-www-challenge
|
||||
entrypoint: "/bin/sh -c 'sleep 300; trap exit TERM; while :; do certbot renew; sleep 12h & wait $${!}; done;'"
|
||||
|
||||
# Hello-world http container useful for test/debugging the proxy
|
||||
# an actual service would be used for production
|
||||
example-webservice:
|
||||
image: crccheck/hello-world
|
||||
ports:
|
||||
- 8000
|
||||
|
20
tls-proxy/initialize-tls-proxy.sh
Executable file
20
tls-proxy/initialize-tls-proxy.sh
Executable file
@ -0,0 +1,20 @@
|
||||
#!/usr/bin/env bash
|
||||
if [[ -n "$CERC_SCRIPT_DEBUG" ]]; then
|
||||
set -x
|
||||
fi
|
||||
# TODO: get from the caller
|
||||
LACONIC_TLS_DOMAIN=example.com
|
||||
# When we're called nginx and certbot container are up and running and certbot is sleeping before executing renew
|
||||
# So we can now ask certbot to issue our initial cert
|
||||
tls_certificate_directory=./certbot/certificates/live/${LACONIC_TLS_DOMAIN}
|
||||
rm -rf ${tls_certificate_directory}
|
||||
# TODO: pass in email from caller
|
||||
# TODO: allow staging/dry-run mode
|
||||
docker compose exec certbot \
|
||||
certbot certonly --webroot -w /data-www-challenge \
|
||||
--staging \
|
||||
--email ${EMAIL} \
|
||||
-d ${LACONIC_TLS_DOMAIN} \
|
||||
--rsa-key-size 4096 \
|
||||
--agree-tos \
|
||||
--force-renewal
|
39
tls-proxy/nginx-config-template
Normal file
39
tls-proxy/nginx-config-template
Normal file
@ -0,0 +1,39 @@
|
||||
events {
|
||||
worker_connections 1024;
|
||||
}
|
||||
|
||||
http {
|
||||
server_tokens off;
|
||||
charset utf-8;
|
||||
|
||||
server {
|
||||
listen 80 default_server;
|
||||
|
||||
server_name _;
|
||||
|
||||
location ~ /.well-known/acme-challenge/ {
|
||||
root /data/certbot-challenge;
|
||||
}
|
||||
|
||||
location / {
|
||||
proxy_pass http://webservice:8000/;
|
||||
}
|
||||
}
|
||||
|
||||
server {
|
||||
listen 443 ssl http2;
|
||||
ssl_certificate /data/certificates/live/${LACONIC_TLS_DOMAIN}/fullchain.pem;
|
||||
ssl_certificate_key /data/certificates/live/${LACONIC_TLS_DOMAIN}/privkey.pem;
|
||||
server_name ${LACONIC_TLS_DOMAIN};
|
||||
root /var/www/html;
|
||||
index index.php index.html index.htm;
|
||||
|
||||
location / {
|
||||
proxy_pass ${LACONIC_ORIGIN_SERVICE_URL};
|
||||
}
|
||||
|
||||
location ~ /.well-known/acme-challenge/ {
|
||||
root /data/certbot-challenge;
|
||||
}
|
||||
}
|
||||
}
|
29
tls-proxy/run-this-first.sh
Executable file
29
tls-proxy/run-this-first.sh
Executable file
@ -0,0 +1,29 @@
|
||||
#!/usr/bin/env bash
|
||||
if [[ -n "$CERC_SCRIPT_DEBUG" ]]; then
|
||||
set -x
|
||||
fi
|
||||
set -e
|
||||
mkdir -p ./nginx
|
||||
mkdir -p ./certbot/certificates
|
||||
mkdir -p ./certbot/challenge
|
||||
# TODO: get from the caller
|
||||
LACONIC_TLS_DOMAIN=example.com
|
||||
LACONIC_ORIGIN_SERVICE_URL=http://example-webservice:8000/
|
||||
# Expand the config template into the nginx config file
|
||||
cat ./nginx-config-template | sed 's/${LACONIC_TLS_DOMAIN}/'${LACONIC_TLS_DOMAIN}'/' | \
|
||||
sed 's/${LACONIC_ORIGIN_SERVICE_URL}/'${LACONIC_ORIGIN_SERVICE_URL}'/' > ./nginx/nginx.conf
|
||||
# Create a self-signed cert so nginx will start without us changing its config between pre and post certbot invocation.
|
||||
# Check if we have a cert already
|
||||
tls_certificate_directory=./certbot/certificates/live/${LACONIC_TLS_DOMAIN}
|
||||
tls_certificate_directory_in_container=/etc/letsencrypt/live/${LACONIC_TLS_DOMAIN}
|
||||
tls_certificate_file_name=${tls_certificate_directory}/fullchain.pem
|
||||
# TODO: this won't work if there's a delay of more than one day between generating the
|
||||
# self signed cert and starting the certbot enrollment process
|
||||
if [[ ! -f ${tls_certificate_file_name} ]] ; then
|
||||
echo "Generating self-signed certificate for ${LACONIC_TLS_DOMAIN}:"
|
||||
mkdir -p ${tls_certificate_directory}
|
||||
docker compose run --rm --entrypoint "\
|
||||
openssl req -x509 -nodes -newkey rsa:4096 -days 1 -keyout '${tls_certificate_directory_in_container}/privkey.pem' \
|
||||
-out '${tls_certificate_directory_in_container}/fullchain.pem' -subj '/CN=${LACONIC_TLS_DOMAIN}'" certbot
|
||||
echo
|
||||
fi
|
Loading…
Reference in New Issue
Block a user