#!/bin/bash source /usr/local/lib/err usage() { cat <&2; } mexit() { echo "$pre exiting with status $1"; exit $1; } ##### begin command line parsing ######## force=false mp_args="-m /o,/q,/a" temp=$(getopt -l force,help owh "$@") || usage 1 eval set -- "$temp" while true; do case $1 in --force) force=true ;; -o) mp_args="-m /o"; shift ;; -h|--help) usage ;; --) shift; break ;; *) echo "$0: Internal error! unexpected args: $*" ; mexit 1 ;; esac done (( $# == 2 )) || usage 1 if [[ ! $HOSTNAME ]]; then err '$HOSTNAME is unset' mexit 1 fi case $1 in push) old_host=$HOSTNAME old_hostname=$HOSTNAME new_host=$2 bbk_args="-t $new_host" new_shell="ssh $new_host" new_hostname=$($new_shell hostname) ;; pull) old_host=$2 new_host=$HOSTNAME new_hostname=$HOSTNAME bbk_args="-s $old_host" old_shell="ssh $old_host" # tests ssh connection old_hostname=$($old_shell hostname) ;; *) err invalid first argument mexit 1 ;; esac source /a/bin/bash_unpublished/source-state if [[ $old_hostname != "$MAIL_HOST" ]] && ! $force; then err "\$old_hostname($old_hostname) != \$MAIL_HOST($MAIL_HOST). Rerun with --force if you really want this." mexit 1 fi if [[ ! $new_host || ! $old_host ]]; then echo "$0: bad args. see script" mexit 1 fi ########### end initial processing, begin actually modifying things ########## if $new_shell systemctl is-active btrbk.timer; then m $new_shell sudo systemctl stop btrbk.timer restore_new_btrbk=true fi if $old_shell systemctl is-active btrbk.timer; then m $old_shell sudo systemctl stop btrbk.timer restore_old_btrbk=true fi btrbk_test="systemctl is-active btrbk.service" active=true while $active; do active=false for shell in "$new_shell" "$old_shell"; do e $shell $btrbk_test status=$($shell $btrbk_test) ||: case $status in inactive|failed) : ;; *) # This covers conditions like "activating", which still return 3 from # systemctl is-active. active=true e "btrbk active on shell:$shell, status:$status, sleeping 8 seconds" sleep 8 break ;; esac done done # ensure these are unused before doing anything e "umounting /m and /o via $new_shell" $new_shell bash -xs <<'EOF' set -eE if mountpoint -q /m; then sudo umount /m; fi if mountpoint -q /o; then sudo umount /o; fi EOF # previously, I was checking to see if the new mail host # is on my home network, then changing my home dns # to resolve on the local network, so that I didnt # have to send traffic out to the internet or rely # on that. However, that breaks for a laptop that roams. # So, we could have a cronjob that updates that dns, # however, another solution is to just use ipv6, # and I prefer that. # # TODO: enable ipv6 for email. exim config setting disables it. # need to add vpn support. need to add firewall / routing. # I think exim will try ipv6 first, so no need to disable # ipv6 i think. e Running initial btrbk if ! m btrbk-run -v $bbk_args $mp_args; then ret=$? err "failed initial btrbk" mexit $ret fi m $old_shell /a/exe/primary-setup $new_hostname e Running main btrbk m btrbk-run -v $bbk_args -m /o || ret=$? if (( ret )); then bang="$(printf "$(tput setaf 5)█$(tput sgr0)%.0s" 1 2 3 4 5 6 7)" e $bang failed btrbk of /o. restoring old host as primary m $old_shell /a/exe/primary-setup localhost mexit $ret fi m $new_shell /a/exe/primary-setup localhost mexit 0