#!/bin/bash HOST_BASE="/opt/gbo/tenants/$PARAM_TENANT/dns" HOST_CONF="$HOST_BASE/conf" HOST_DATA="$HOST_BASE/data" HOST_LOGS="$HOST_BASE/logs" mkdir -p "$HOST_BASE" "$HOST_CONF" "$HOST_DATA" "$HOST_LOGS" chmod -R 750 "$HOST_BASE" # Clear existing rules sudo iptables -F # Allow DNS traffic sudo iptables -A INPUT -p udp --dport 53 -j ACCEPT sudo iptables -A INPUT -p tcp --dport 53 -j ACCEPT sudo iptables -A FORWARD -p udp --dport 53 -j ACCEPT sudo iptables -A FORWARD -p tcp --dport 53 -j ACCEPT # Enable NAT sudo iptables -t nat -A POSTROUTING -o eth0 -j MASQUERADE # Save rules (if using iptables-persistent) sudo netfilter-persistent save lxc launch images:debian/12 "${PARAM_TENANT}-dns" -c security.privileged=true until lxc exec "${PARAM_TENANT}-dns" -- true; do sleep 3; done lxc config device remove pragmatismo-dns dns-udp lxc config device remove pragmatismo-dns dns-tcp # Forward HOST's public IP:53 → CONTAINER's 0.0.0.0:53 lxc config device add pragmatismo-dns dns-udp proxy listen=udp:$GB_PUBLIC_IP:53 connect=udp:0.0.0.0:53 lxc config device add pragmatismo-dns dns-tcp proxy listen=tcp:$GB_PUBLIC_IP:53 connect=tcp:0.0.0.0:53 lxc exec "${PARAM_TENANT}-dns" -- bash -c " mkdir /opt/gbo mkdir /opt/gbo/{bin,conf,data,logs} echo 'nameserver 8.8.8.8' > /etc/resolv.conf apt-get upgrade -y && apt-get install -y wget wget -qO /opt/gbo/bin/coredns https://github.com/coredns/coredns/releases/download/v1.11.1/coredns_1.11.1_linux_amd64.tgz tar -xzf /opt/gbo/bin/coredns -C /opt/gbo/bin/ useradd --system --no-create-home --shell /bin/false gbuser setcap cap_net_bind_service=+ep /opt/gbo/bin/coredns cat > /etc/systemd/system/dns.service <