X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=switch-mail-host;h=5d7a6793388dd76b181b5b893eae590c4f1b1fdb;hb=fbb0315374736f92d950545796beaa79cbdc1f49;hp=a06e1baec6c5abd9bd7ab3bf201fbe1e1524d9f1;hpb=0cc08a73110c15c4e7bbb8c8233a6c122c27490e;p=distro-setup diff --git a/switch-mail-host b/switch-mail-host index a06e1ba..5d7a679 100755 --- a/switch-mail-host +++ b/switch-mail-host @@ -65,8 +65,18 @@ if [[ ! $new_host || ! $old_host ]]; then exit 1 fi +# TODO: turn this home dns update into a separate script that also runs +# as a cronjob for the MAIL_HOST, so it can update dns for a laptop that +# moves to a different network. +# +# This exists because if mail_host is on the home network with a vpn +# tunnel, and another host on the home network tries to connect to the +# public tunnel ip, it won't work because from the public machine's +# perspective, due to nat, both home network machines have the same +# ip. We could solve this by using ipv6 addresses, but not all networks +# i'm on with more than one machine are ipv6 enabled. at_home=false -if [[ $HOSTNAME == tp ]] || [[ $HOSTNAME == frodo ]] || timeout -s 9 5 ssh wrt.b8.nz :; then +if timeout -s 9 5 ssh-keyscan -p 2220 -t rsa 10.0.0.1 2>/dev/null | grep -qFx '[10.0.0.1]:2220 ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCH+/h1dGEfKEusBblndU2e6QT4wLCm5+yqr/sqh/0X9YfjR7BfWWm8nNmuP55cYc+Wuf5ljB1H1acXEcsl1y8e0j3agHfF0V74FE1N1zz5nn2Ep8NHnmqgEhza38ZxMPh+4p3X7zklEKU7+3SzybKBi8sg0wLzlS2LM0JaUN80zR2sK11Kye3dURUXPk78u5wodOkgcEYRwSYaDMJlUzWP+poRXIDJwFaMQnwmxbl/c84yOyaU0x/d6hFwoRscWecihX+vvBNeSyxR4xr2HDOyUWwJkctyAgt2p7w3tfkXOKcCRzTAjGVIMQLTvo0sG/yJbcyHoEFdFybCsgDvfyYn'; then at_home=true fi echo "$0: at_home = $at_home" @@ -89,14 +99,8 @@ source /a/bin/bash_unpublished/source-semi-priv # todo: setup vpn so this is all taken care of. if ! $update_wrt; then wrt_shell=: -elif $at_home; then - wrt_shell="ssh wrt.b8.nz" else - if [[ $old_host == iank.vpn.office.fsf.org || $new_host == iank.vpn.office.fsf.org ]]; then - wrt_shell="ssh iank.vpn.office.fsf.org ssh wrt.b8.nz" - else - wrt_shell="ssh $HOME_DOMAIN ssh wrt.b8.nz" - fi + wrt_shell="ssh wrt.b8.nz" fi btrbk_test="systemctl is-active btrbk.service"