mirror of
https://github.com/flynx/proxmox-utils.git
synced 2025-10-28 10:40:07 +00:00
added basic tailscale setup...
Signed-off-by: Alex A. Naanou <alex.nanou@gmail.com>
This commit is contained in:
parent
080a42c853
commit
84389237da
101
tailscale/make.sh
Normal file
101
tailscale/make.sh
Normal file
@ -0,0 +1,101 @@
|
|||||||
|
#!/usr/bin/bash
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
cd $(dirname $0)
|
||||||
|
PATH=$PATH:$(dirname "$(pwd)")
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
source ../.pct-helpers
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
readConfig
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
DFL_ID=${DFL_ID:=1020}
|
||||||
|
DFL_CTHOSTNAME=${DFL_CTHOSTNAME:=tailscale}
|
||||||
|
|
||||||
|
DFL_CORES=${DFL_CORES:=1}
|
||||||
|
DFL_RAM=${DFL_RAM:=1024}
|
||||||
|
DFL_SWAP=${DFL_SWAP:=${DFL_RAM}}
|
||||||
|
DFL_DRIVE=${DFL_DRIVE:=8}
|
||||||
|
|
||||||
|
WAN_IP=SKIP
|
||||||
|
WAN_GATE=SKIP
|
||||||
|
ADMIN_IP=SKIP
|
||||||
|
ADMIN_GATE=SKIP
|
||||||
|
LAN_IP=SKIP
|
||||||
|
LAN_GATE=SKIP
|
||||||
|
|
||||||
|
REBOOT=${REBOOT:=1}
|
||||||
|
|
||||||
|
xread "Tailscale Auth Key: " TAILSCALE_AUTH_KEY
|
||||||
|
|
||||||
|
readVars
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
INTERFACES=(
|
||||||
|
"name=lan,bridge=vmbr${LAN_BRIDGE},firewall=1,ip=dhcp,type=veth"
|
||||||
|
"name=admin,bridge=vmbr${ADMIN_BRIDGE},firewall=1,ip=dhcp,type=veth"
|
||||||
|
)
|
||||||
|
|
||||||
|
OPTS_STAGE_2="\
|
||||||
|
--onboot 1 \
|
||||||
|
"
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
|
||||||
|
echo "# Building config..."
|
||||||
|
buildAssets
|
||||||
|
|
||||||
|
echo "# Creating CT..."
|
||||||
|
pctCreateAlpine $ID "$PASS"
|
||||||
|
|
||||||
|
echo "# Enabling TUN for CT..."
|
||||||
|
# XXX can we do this with pct set ... ???
|
||||||
|
cat >> $CT_DIR/$ID <<EOF
|
||||||
|
lxc.cgroup2.devices.allow: c 10:200 rwm
|
||||||
|
lxc.mount.entry: /dev/net/tun dev/net/tun none bind,create=file
|
||||||
|
EOF
|
||||||
|
pct reboot $ID
|
||||||
|
|
||||||
|
echo "# Installing dependencies..."
|
||||||
|
@ lxc-attach $ID apk add tailscale logrotate
|
||||||
|
|
||||||
|
echo "# Copying assets..."
|
||||||
|
pctPushAssets $ID
|
||||||
|
|
||||||
|
echo "# Setup: sysctl..."
|
||||||
|
@ lxc-attach $ID rc-update add sysctl
|
||||||
|
|
||||||
|
echo "# Setup: tailscale..."
|
||||||
|
@ lxc-attach $ID rc-update add tailscale
|
||||||
|
@ lxc-attach $ID rc-service tailscale start
|
||||||
|
if ! [ -z $TAILSCALE_AUTH_KEY ] ; then
|
||||||
|
@ lxc-attach $ID tailscale up --auth-key="$TAILSCALE_AUTH_KEY" --advertise-exit-node
|
||||||
|
fi
|
||||||
|
|
||||||
|
echo "# Post config..."
|
||||||
|
pctSet $ID "${OPTS_STAGE_2}" $REBOOT
|
||||||
|
pctSetNotes $ID
|
||||||
|
|
||||||
|
saveLastRunConfig
|
||||||
|
|
||||||
|
showNotes
|
||||||
|
echo "# Done."
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#----------------------------------------------------------------------
|
||||||
|
# vim:set ts=4 sw=4 :
|
||||||
Loading…
x
Reference in New Issue
Block a user