X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=pxe-server;h=7405f58f3b6a2c3185f8661509a48f95da29d3f1;hp=e6680883201c5f11d4a096120a779e4dfb25c852;hb=bfd6bbd3a188aac6871f8b5e1116a0979682d52b;hpb=cf3b64c21818d0033ffe5447d30e45141c81ee1b diff --git a/pxe-server b/pxe-server index e668088..7405f58 100755 --- a/pxe-server +++ b/pxe-server @@ -16,6 +16,7 @@ # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. +[[ $EUID == 0 ]] || exec sudo -E "${BASH_SOURCE[0]}" "$@" x="$(readlink -f "$BASH_SOURCE")"; source "${x%/*}/bash-trace" @@ -66,6 +67,8 @@ m() { printf "$pre %s\n" "$*"; "$@"; } e() { printf "$pre %s\n" "$*"; } err() { echo "[$(date +'%Y-%m-%d %H:%M:%S%z')]: $pre: $*" >&2; } +PATH="/a/exe:$PATH" + ##### begin command line parsing ######## dhcp=true @@ -132,9 +135,9 @@ fi archlike() { cat </dev/null || sudo apt-get -y install dnsutils +faiserverip=$(host faiserver | sed -rn 's/^\S+ has address //p;T;q' ||:) +if [[ ! $faiserverip || $faiserverip =~ [[:space:]] ]]; then + echo "$0: error: failed to get \$faiserverip, got: $faiserverip" + exit 1 +fi + if $set; then set-pxe if [[ $type == fai ]]; then - m myfai-chboot ${chboot_args[@]} $host if $redep; then m fai-redep fi + m myfai-chboot ${chboot_args[@]} $host else # This will fail if faiserver is not setup, so ignore any # failure and don't bother us about it.