Improving Caddyfile build process.
This commit is contained in:
6
.gitignore
vendored
6
.gitignore
vendored
@@ -13,4 +13,8 @@ production.tfvars
|
||||
terraform.tfstate
|
||||
terraform.tfstate.backup
|
||||
|
||||
app
|
||||
app
|
||||
|
||||
apps.config
|
||||
|
||||
all-apps/lb/Caddyfile
|
||||
5
Makefile
5
Makefile
@@ -6,7 +6,10 @@ app/.dirstamp: all-apps/app.service all-apps/docker-compose.yaml $(wildcard all-
|
||||
rm -Rf app/
|
||||
cp -a all-apps app && touch $@
|
||||
|
||||
ignition.json: cl.yaml app/.dirstamp
|
||||
all-apps/lb/Caddyfile: apps.config make-caddyfile.sh
|
||||
./make-caddyfile.sh > all-apps/lb/Caddyfile
|
||||
|
||||
ignition.json: cl.yaml app/.dirstamp all-apps/lb/Caddyfile
|
||||
cat cl.yaml | sudo docker run --rm --volume /home/tjhintz/.ssh/id_rsa.pub:/pwd/ssh-keys --volume ${PWD}:/pwd --workdir /pwd -i quay.io/coreos/butane:latest -d /pwd > ignition.json
|
||||
|
||||
plan: ignition.json
|
||||
|
||||
@@ -1,17 +0,0 @@
|
||||
wg-easy1.nassella.cc {
|
||||
reverse_proxy http://wg-easy:80
|
||||
|
||||
# tls internal
|
||||
# x
|
||||
# log
|
||||
}
|
||||
|
||||
nextcloud1.nassella.cc {
|
||||
reverse_proxy http://nextcloud:80
|
||||
# tls internal
|
||||
}
|
||||
|
||||
root.nassella.cc {
|
||||
reverse_proxy http://nginx:80
|
||||
# tls internal
|
||||
}
|
||||
2
apps.config.tmpl
Normal file
2
apps.config.tmpl
Normal file
@@ -0,0 +1,2 @@
|
||||
ROOT_DOMAIN=example.com
|
||||
APP_CONFIGS="nextcloud,nextcloud wg-easy,wg-easy"
|
||||
42
make-caddyfile.sh
Executable file
42
make-caddyfile.sh
Executable file
@@ -0,0 +1,42 @@
|
||||
#!/bin/bash
|
||||
|
||||
# this script generates the load-balancer
|
||||
# config for the Caddy server.
|
||||
|
||||
# it depends on apps.config which should define:
|
||||
# ROOT_DOMAIN - the root domain for all apps
|
||||
# APP_CONFIGS - app-subdomain pairs, configured via a comma, like:
|
||||
# app1,subdomain1 app2,subdomain2 app3,subdomain3
|
||||
# full example:
|
||||
# ROOT_DOMAIN=nassella.cc
|
||||
# APP_CONFIGS="app1,subdomain1 app2,subdomain2 app3,subdomain3"
|
||||
|
||||
set -e
|
||||
|
||||
. apps.config
|
||||
|
||||
read -r -a APP_CONFIGS <<< "$APP_CONFIGS"
|
||||
APP_CONFIGS+=('lb,root')
|
||||
|
||||
|
||||
declare -A bodys
|
||||
bodys["nextcloud"]=" reverse_proxy http://nextcloud:80"
|
||||
bodys["wg-easy"]=" reverse_proxy http://wg-easy:80"
|
||||
bodys["lb"]=" reverse_proxy http://nginx:80"
|
||||
|
||||
for config_string in ${APP_CONFIGS[@]}; do
|
||||
IFS=','
|
||||
read -r -a config <<< "$config_string"
|
||||
|
||||
app=${config[0]}
|
||||
subdomain=${config[1]}
|
||||
body=${bodys[$app]}
|
||||
fulldomain="$subdomain.$ROOT_DOMAIN"
|
||||
|
||||
echo "$fulldomain {"
|
||||
echo $body
|
||||
echo "}"
|
||||
done
|
||||
|
||||
|
||||
|
||||
Reference in New Issue
Block a user