X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=myfai-chboot-local;h=c631d5699d073e6e27d9ccae8d8454cce7c2b8e5;hb=ceeb4e46d3bb326d01fcc7ed98d94ab0b580eda3;hp=5140f68bb73f349bdf741974b1fbef7e7ba076c5;hpb=659fbf0c0467af986aadb6d76693eb3011e62ac4;p=automated-distro-installer diff --git a/myfai-chboot-local b/myfai-chboot-local index 5140f68..c631d56 100755 --- a/myfai-chboot-local +++ b/myfai-chboot-local @@ -1,9 +1,13 @@ #!/bin/bash # note, this script gets piped to bash, so cant cd to current dir + +[[ $EUID == 0 ]] || exec sudo "${BASH_SOURCE}" "$@" + set -eE -o pipefail trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR kgped16=false +bond=false fai_action=install fai_reboot_arg=,reboot while [[ $1 == -* ]]; do @@ -23,36 +27,56 @@ while [[ $1 == -* ]]; do shift ;; -k) - kgped16=true; + kgped16=true + shift + ;; + -b) + bond=true + shift + ;; + --no-r) + fai_reboot_arg= shift ;; esac done -[[ $EUID == 0 ]] || exec sudo "${BASH_SOURCE}" "$@" - -e() { - echo "$*" - if ! "$@"; then - echo "$0: error: exit code $? from: $*" - exit 1 - fi -} +pre="${0##*/}:" +m() { printf "$pre %s\n" "$*"; "$@"; } +e() { printf "$pre %s\n" "$*"; } +err() { echo "[$(date +'%Y-%m-%d %H:%M:%S%z')]: $pre: $*" >&2; } host=$1 + rm -f /srv/tftp/fai/pxelinux.cfg/* if [[ ! $1 ]]; then echo "$0: clearing pxe config and exiting" exit 0 fi -# assuming ipv4, or else we might need to deal with multiple addresses -# in an ipv4 + ipv6 network. -my_ip=$(ip -4 route get 8.8.8.8 | sed -nr 's,^.*src\s+(\S+).*,\1,p') -if [[ ! $my_ip || $my_ip =~ [[:space:]] ]]; then - echo "$0: error: failed to get \$my_ip, got: $my_ip" - exit 1 +# somewhat duplicated in brc hostip() +case $host in + default) : ;; + [0-9:]) + hostip=$host + ;; + *) + hostip=$(getent ahostsv4 "$host" | awk '{ print $1 }' | head -n1) + ;; +esac + +if [[ $hostip ]]; then + + # assuming ipv4, or else we might need to deal with multiple addresses + # in an ipv4 + ipv6 network. + my_ip=$(ip -4 route get $hostip | sed -nr 's,^.*src\s+(\S+).*,\1,p') + if [[ ! $my_ip || $my_ip =~ [[:space:]] ]]; then + echo "$0: error: failed to get \$my_ip, got: $my_ip" + exit 1 + fi +else + my_ip=$(ip r show default | sed -r 's/.*via ([^ ]*).*/\1/' | head -n1) fi if [[ $host == default ]]; then @@ -67,6 +91,7 @@ else exit 1 fi ip=$ip/32 + echo "$0: found ip of $host: $ip" fi if modprobe nfsd &>/dev/null; then @@ -83,7 +108,7 @@ if modprobe nfsd &>/dev/null; then if [[ -w /etc/exports ]]; then sed -ri --follow-symlinks '\%^/srv/fai/%d' /etc/exports cat >>/etc/exports <