Skip to content

Instantly share code, notes, and snippets.

@nicolasguzca
Forked from sparkcodeuk/floating-ip-gateway.sh
Last active August 18, 2021 15:24
Show Gist options
  • Save nicolasguzca/2f31757868bfd9fe805579473a8d4f81 to your computer and use it in GitHub Desktop.
Save nicolasguzca/2f31757868bfd9fe805579473a8d4f81 to your computer and use it in GitHub Desktop.
Digital Ocean floating IP gateway script (force droplet to use the assigned floating IP for outbound traffic as well as inbound traffic)
#!/bin/bash
# Force outbound traffic through the attached floating IP
NET_INT="eth0"
CURL_TIMEOUT=3
echo -n "Setting floating IP as the default gateway: "
# Check there's a floating IP attached to this droplet
if [ "$(curl -s --connect-timeout $CURL_TIMEOUT http://169.254.169.254/metadata/v1/floating_ip/ipv4/active)" != "true" ]; then
echo "Error: this droplet doesn't have a floating IP assigned to it."
exit 1
fi
# Get the gateway IP for the floating IP
GATEWAY_IP=$(curl -s --connect-timeout $CURL_TIMEOUT http://169.254.169.254/metadata/v1/interfaces/public/0/anchor_ipv4/gateway)
if [ -z "$GATEWAY_IP" ]; then
echo "Error: failed getting gateway IP for this droplet."
exit 1
fi
# Check we haven't already got the floating IP as a default gateway
if [ ! -z $(ip route ls 0/0|awk '{print $3}'|grep "$GATEWAY_IP") ]; then
echo "Error: gateway IP already a default route."
exit 1
fi
# Replace old route with new route
sudo ip route replace default via $GATEWAY_IP dev $NET_INT
echo "Done."
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment