test/lib/wireguard.sh
2023-06-06 19:05:04 +00:00

95 lines
2.2 KiB
Bash

#!/bin/bash
#
# Wireguard / VPN Service
PATH=$HOME/.docker/cli-plugins:/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
config_wireguard() {
echo -ne "\n* Configuring /federated/apps/wireguard container.."
spin &
SPINPID=$!
if [ ! -d "/federated/apps/wireguard" ]; then
mkdir -p /federated/apps/wireguard/data/config
fi
cat > /federated/apps/wireguard/docker-compose.yml <<EOF
version: "3.7"
services:
wireguard:
image: linuxserver/wireguard:\${IMAGE_VERSION}
container_name: wireguard
hostname: wireguard.$DOMAIN
domainname: $DOMAIN
restart: always
networks:
federated:
ipv4_address: 172.99.0.24
ports:
- 51820:51820/udp
volumes:
- ./data/config:/config
- ./data/etc/coredns/Corefile:/etc/coredns/Corefile
- /lib/modules:/lib/modules
env_file:
- ./.env
cap_add:
- NET_ADMIN
- SYS_MODULE
sysctls:
- net.ipv4.conf.all.src_valid_mark=1
networks:
federated:
external: true
EOF
cat > /federated/apps/wireguard/.env <<EOF
IMAGE_VERSION="1.0.20210914"
PUID=1000
PGID=1000
SERVERURL=wireguard.$DOMAIN
SERVERPORT=51820
PEERS=1
PEERDNS=auto
ALLOWEDIPS=0.0.0.0/0,::/0,172.99.0.0/16,192.160.0.0/16,10.13.13.1/32
LOG_CONFS=true
EOF
chmod 600 /federated/apps/wireguard/.env
cat /federated/apps/wireguard/data/config/coredns/Corefile <<EOF
. {
hosts {
172.99.0.12 powerdns.$DOMAIN
172.99.0.13 traefik.$DOMAIN
172.99.0.23 panel.$DOMAIN
172.99.0.18 nextcloud.$DOMAIN
172.99.0.21 listmonk.$DOMAIN
172.99.0.22 vaultwarden.$DOMAIN
172.99.0.25 jitsi.$DOMAIN
172.99.0.20 element.$DOMAIN
172.99.0.29 baserow.$DOMAIN
172.99.0.30 gitea.$DOMAIN
fallthrough
}
loop
health
forward . /etc/resolv.conf
}
EOF
kill -9 $SPINPID &> /dev/null
echo -ne "done."
}
start_wireguard() {
# Grab the container IP from docker-compose above
SERVICE_IP=`grep ipv4_address /federated/apps/wireguard/docker-compose.yml | awk '{ print $2 }'`
# Start service with command to make sure it's up before proceeding
start_service "wireguard" "nc -uvz $SERVICE_IP 51820 &> /dev/null"
kill -9 $SPINPID &> /dev/null
echo -ne "done."
}