2024-05-04 21:05:33 -07:00
|
|
|
#!/usr/bin/env bash
|
|
|
|
# @file Tailscale
|
|
|
|
# @brief Connects the Tailscale client with the Tailscale network
|
|
|
|
# @description
|
|
|
|
# This script ensures the `tailscaled` system daemon is installed on macOS. Then, on both macOS and Linux, it connects to the Tailscale
|
|
|
|
# network if the `TAILSCALE_AUTH_KEY` variable is provided.
|
2024-05-19 23:06:00 -07:00
|
|
|
#
|
|
|
|
# If CloudFlare WARP is also installed, this script will disconnect from it and then reconnect after Tailscale is connected.
|
|
|
|
# This is a quirk and Tailscale has no roadmap for fixing it for use alongside other VPNs. To setup Tailscale to work alongside
|
|
|
|
# CloudFlare WARP, you will have to set up a [split tunnel](https://www.youtube.com/watch?v=eDFs8hm3xWc) for
|
|
|
|
# [Tailscale IP addresses](https://tailscale.com/kb/1105/other-vpns).
|
|
|
|
|
2024-05-27 04:15:03 -07:00
|
|
|
set -euo pipefail
|
|
|
|
|
2024-05-19 23:06:00 -07:00
|
|
|
### Disconnect from CloudFlare WARP (if connected)
|
|
|
|
if command -v warp-cli > /dev/null; then
|
|
|
|
warp-cli disconnect && logg info 'CloudFlare WARP temporarily disconnected while Tailscale connects'
|
|
|
|
fi
|
2024-05-04 21:05:33 -07:00
|
|
|
|
|
|
|
### Install the Tailscale system daemon
|
2024-05-19 23:06:00 -07:00
|
|
|
if [ -d /Applications ] && [ -d /System ]; then
|
2024-05-04 21:05:33 -07:00
|
|
|
### macOS
|
|
|
|
if command -v tailscaled > /dev/null; then
|
|
|
|
logg info 'Ensuring tailscaled system daemon is installed'
|
|
|
|
sudo tailscaled install-system-daemon
|
|
|
|
logg info 'tailscaled system daemon is now installed and will load on boot'
|
|
|
|
else
|
|
|
|
logg info 'tailscaled does not appear to be installed'
|
|
|
|
fi
|
2024-05-12 20:31:26 -07:00
|
|
|
|
|
|
|
### Open Tailscale.app
|
|
|
|
if [ -d /Applications/Tailscale.app ]; then
|
|
|
|
logg info 'Opening Tailscale.app menu bar widget' && open -a Tailscale
|
|
|
|
else
|
|
|
|
logg info '/Applications/Tailscale.app is missing from the system'
|
|
|
|
fi
|
2024-05-04 21:05:33 -07:00
|
|
|
fi
|
|
|
|
|
2024-05-19 23:06:00 -07:00
|
|
|
### Acquire TAILSCALE_AUTH_KEY
|
2024-05-27 04:15:03 -07:00
|
|
|
if [ -z "$TAILSCALE_AUTH_KEY" ]; then
|
|
|
|
TAILSCALE_AUTH_KEY_FILE="${XDG_DATA_HOME:-$HOME/.local/share}/chezmoi/home/.chezmoitemplates/secrets/TAILSCALE_AUTH_KEY"
|
|
|
|
if [ -f "$TAILSCALE_AUTH_KEY_FILE" ]; then
|
|
|
|
logg info "Found TAILSCALE_AUTH_KEY in ${XDG_DATA_HOME:-$HOME/.local/share}/chezmoi/home/.chezmoitemplates/secrets"
|
|
|
|
if [ -f "${XDG_CONFIG_HOME:-$HOME/.config}/age/chezmoi.txt" ]; then
|
|
|
|
logg info 'Decrypting TAILSCALE_AUTH_KEY token with Age encryption key'
|
|
|
|
TAILSCALE_AUTH_KEY="$(cat "$TAILSCALE_AUTH_KEY_FILE" | chezmoi decrypt)"
|
|
|
|
else
|
|
|
|
logg warn 'Age encryption key is missing from ~/.config/age/chezmoi.txt'
|
|
|
|
exit 1
|
|
|
|
fi
|
2024-05-19 23:06:00 -07:00
|
|
|
else
|
2024-05-27 04:15:03 -07:00
|
|
|
logg warn "TAILSCALE_AUTH_KEY is missing from ${XDG_DATA_HOME:-$HOME/.local/share}/chezmoi/home/.chezmoitemplates/secrets"
|
|
|
|
exit 1
|
2024-05-19 23:06:00 -07:00
|
|
|
fi
|
|
|
|
else
|
2024-05-27 04:15:03 -07:00
|
|
|
logg info 'TAILSCALE_AUTH_KEY provided as environment variable'
|
2024-05-19 23:06:00 -07:00
|
|
|
fi
|
|
|
|
|
2024-05-04 21:05:33 -07:00
|
|
|
### Connect to Tailscale network
|
2024-05-27 04:15:03 -07:00
|
|
|
if get-secret --exists TAILSCALE_AUTH_KEY; then
|
2024-05-12 20:31:26 -07:00
|
|
|
if [ -f /Applications/Tailscale.app/Contents/MacOS/Tailscale ]; then
|
|
|
|
logg info 'Connecting to Tailscale with user-defined authentication key (TAILSCALE_AUTH_KEY)'
|
2024-05-27 04:15:03 -07:00
|
|
|
timeout 30 /Applications/Tailscale.app/Contents/MacOS/Tailscale up --authkey="$(get-secret TAILSCALE_AUTH_KEY)" --accept-routes || EXIT_CODE=$?
|
2024-05-12 20:31:26 -07:00
|
|
|
if [ -n "$EXIT_CODE" ]; then
|
|
|
|
logg warn '/Applications/Tailscale.app/Contents/MacOS/Tailscale timed out'
|
|
|
|
fi
|
2024-05-20 00:48:38 -07:00
|
|
|
logg info 'Disabling update check'
|
|
|
|
/Applications/Tailscale.app/Contents/MacOS/Tailscale set --update-check=false
|
2024-05-27 04:15:03 -07:00
|
|
|
elif command -v tailscale > /dev/null; then
|
2024-05-12 20:31:26 -07:00
|
|
|
logg info 'Connecting to Tailscale with user-defined authentication key (TAILSCALE_AUTH_KEY)'
|
2024-05-27 04:15:03 -07:00
|
|
|
timeout 30 tailscale up --authkey="$(get-secret TAILSCALE_AUTH_KEY)" --accept-routes || EXIT_CODE=$?
|
2024-05-12 20:31:26 -07:00
|
|
|
if [ -n "$EXIT_CODE" ]; then
|
|
|
|
logg warn 'tailscale up timed out'
|
|
|
|
else
|
|
|
|
logg success 'Connected to Tailscale network'
|
|
|
|
fi
|
2024-05-20 00:48:38 -07:00
|
|
|
logg info 'Disabling notifications about updates'
|
|
|
|
tailscale set --update-check=false
|
|
|
|
logg info 'Setting tailscale to auto-update'
|
|
|
|
tailscale set --auto-update
|
2024-05-04 21:05:33 -07:00
|
|
|
else
|
2024-05-12 20:31:26 -07:00
|
|
|
logg info 'tailscale does not appear to be installed'
|
2024-05-04 21:05:33 -07:00
|
|
|
fi
|
2024-05-12 20:31:26 -07:00
|
|
|
else
|
|
|
|
logg info 'TAILSCALE_AUTH_KEY is not defined so not logging into Tailscale network'
|
|
|
|
fi
|
2024-05-19 23:06:00 -07:00
|
|
|
|
|
|
|
### Re-connect CloudFlare WARP after Tailscale is connected
|
|
|
|
if command -v warp-cli > /dev/null; then
|
|
|
|
### Register CloudFlare WARP
|
|
|
|
if warp-cli --accept-tos status | grep 'Registration Missing' > /dev/null; then
|
|
|
|
logg info 'Registering CloudFlare WARP'
|
|
|
|
warp-cli --accept-tos registration new
|
|
|
|
else
|
|
|
|
logg info 'Either there is a misconfiguration or the device is already registered with CloudFlare WARP'
|
|
|
|
fi
|
|
|
|
|
|
|
|
### Connect CloudFlare WARP
|
|
|
|
if warp-cli --accept-tos status | grep 'Disconnected' > /dev/null; then
|
|
|
|
logg info 'Connecting to CloudFlare WARP'
|
|
|
|
warp-cli --accept-tos connect > /dev/null && logg success 'Connected to CloudFlare WARP'
|
|
|
|
else
|
|
|
|
logg info 'Either there is a misconfiguration or the device is already connected with CloudFlare WARP'
|
|
|
|
fi
|
|
|
|
fi
|