Laminar/cfg/jobs/adguard.run

61 lines
1.6 KiB
Text
Raw Normal View History

2024-11-21 20:56:04 +09:00
#!/bin/env bash
# Upstream doc: https://adguard-dns.io/kb/adguard-home/getting-started/
set -euxo pipefail
IMAGE="ubuntu/24.04"
DIST="${IMAGE%%/*}"
VER="${IMAGE#*/}"
VER="${VER%/*}"
VER="${VER//./-}"
UPSTREAM_VER="0.107.54"
UPSTREAM_VER_DASH="${UPSTREAM_VER//./-}"
UPSTREAM_NAME="adguard"
2024-11-21 21:07:33 +09:00
SERIAL="2benoitjpnet"
2024-11-21 20:56:04 +09:00
CNAME="$UPSTREAM_NAME-$UPSTREAM_VER_DASH-$SERIAL-$DIST-$VER"
ALIAS="$UPSTREAM_NAME-$UPSTREAM_VER-$SERIAL"
cd "$WORKSPACE"
incus launch images:$IMAGE "$CNAME" --quiet
wait_network "$CNAME"
incus exec "$CNAME" -- bash -c '
apt-get update && apt-get upgrade -y && apt-get install -y --no-install-recommends wget
adduser \
--system \
--shell /bin/bash \
--gecos "AdGuard Home DNS Server" \
--group \
--disabled-password \
--home /opt/adguard \
adguard
cd /tmp && \
wget --quiet https://github.com/AdguardTeam/AdGuardHome/releases/download/v'"$UPSTREAM_VER"'/AdGuardHome_linux_amd64.tar.gz && \
2024-11-21 21:07:33 +09:00
tar -xzf AdGuardHome_linux_amd64.tar.gz -C /opt/adguard --strip-components=2 && \
2024-11-21 20:56:04 +09:00
rm AdGuardHome_linux_amd64.tar.gz
2024-11-21 21:07:33 +09:00
setcap "CAP_NET_BIND_SERVICE=+eip CAP_NET_RAW=+eip" /opt/adguard/AdGuardHome
2024-11-21 20:56:04 +09:00
install -d -m 755 -o adguard -g adguard /opt/adguard/{data,config}
2024-11-27 22:18:58 +09:00
#https://github.com/AdguardTeam/AdGuardHome/wiki/FAQ#bindinuse
mkdir -p /etc/systemd/resolved.conf.d
cat <<EOT> /etc/systemd/resolved.conf.d/adguardhome.conf
[Resolve]
DNS=127.0.0.1
DNSStubListener=no
EOT
2024-11-21 20:56:04 +09:00
'
incus file push adguard.service "$CNAME"/etc/systemd/system/
incus exec "$CNAME" -- systemctl enable adguard
laminarc run incus_publish \
CNAME="$CNAME" \
2024-11-21 20:58:40 +09:00
UPSTREAM_NAME=$UPSTREAM_NAME \
2024-11-21 20:56:04 +09:00
UPSTREAM_VER=$UPSTREAM_VER \
IMAGE=$IMAGE \
SERIAL=$SERIAL \
ALIAS=$ALIAS