aboutsummaryrefslogtreecommitdiff
path: root/playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh
diff options
context:
space:
mode:
authorElizabeth Hunt <me@liz.coffee>2025-04-27 21:15:30 -0700
committerElizabeth Hunt <me@liz.coffee>2025-04-27 21:25:52 -0700
commitdaef0cf448af17357b552245f39067a9d340ce3d (patch)
treef65a660f7232f057b0c14e477c166006bfb83f87 /playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh
parent1dcdfe34a74708f88aad68af965f4bb5c79adff1 (diff)
downloadoldinfra-daef0cf448af17357b552245f39067a9d340ce3d.tar.gz
oldinfra-daef0cf448af17357b552245f39067a9d340ce3d.zip
Waow
Diffstat (limited to 'playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh')
-rwxr-xr-xplaybooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh33
1 files changed, 33 insertions, 0 deletions
diff --git a/playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh b/playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh
new file mode 100755
index 0000000..da273a9
--- /dev/null
+++ b/playbooks/roles/outbound/templates/proxy/nginx/wait-for-bridge.sh
@@ -0,0 +1,33 @@
+#!/bin/sh
+
+set -e
+
+echo "[+] Waiting for headscale-client to be resolvable..."
+
+# Loop until headscale-client IP is found or timeout
+timeout=30
+start_time=$(date +%s)
+
+HEADSCALE_IP=""
+while [ -z "$HEADSCALE_IP" ]; do
+ HEADSCALE_IP=$(getent hosts headscale-client | awk '{ print $1 }' | head -n 1)
+ current_time=$(date +%s)
+ if [ $((current_time - start_time)) -ge $timeout ]; then
+ echo "[-] Timeout waiting for headscale-client DNS resolution." >&2
+ exit 1
+ fi
+ if [ -z "$HEADSCALE_IP" ]; then
+ sleep 1
+ fi
+done
+
+echo "[+] Found headscale-client IP: $HEADSCALE_IP"
+echo "[+] Attempting to modify routing table..."
+
+apt update && apt install -y iproute2
+ip route del default || echo "[-] Warning: Failed to delete default route (maybe none existed)."
+ip route add default via $HEADSCALE_IP
+echo "[+] Default route set via $HEADSCALE_IP."
+
+echo "[+] Starting Nginx..."
+nginx -g "daemon off;"