X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=pxe-server;h=944620ecc6647a2b20295b3d28c6576c1deafc9a;hp=a59e71c5d48676fd61a6cfc78954f01c8de623fe;hb=0d7f79362d601b278236cd1c533c7333e342b54a;hpb=15da839e14b07b30de9c3f7559bd17213e4f193d diff --git a/pxe-server b/pxe-server index a59e71c..944620e 100755 --- a/pxe-server +++ b/pxe-server @@ -21,14 +21,14 @@ x="$(readlink -f "$BASH_SOURCE")"; source "${x%/*}/bash-trace" usage() { - cat < tftpboot +ln -s tftpboot Note: Uses GNU getopt options parsing style EOF - exit $1 + exit $1 } ##### begin command line parsing ######## @@ -69,126 +69,138 @@ chboot_args=() temp=$(getopt -l help adrSkwh "$@") || usage 1 eval set -- "$temp" while true; do - case $1 in - -a) wait=true; set=false; shift ;; - -d) dhcp=false; shift ;; - -r) redep=false; shift ;; - -S) chboot_args+=(-S); shift ;; - -k) chboot_args+=(-k); shift ;; - -w) wait=true; set=true; shift ;; - -h|--help) usage ;; - --) shift; break ;; - *) echo "$0: Internal error!" ; exit 1 ;; - esac + case $1 in + -a) wait=true; set=false; shift ;; + -d) dhcp=false; shift ;; + -r) redep=false; shift ;; + -S) chboot_args+=(-S); shift ;; + -k) chboot_args+=(-k); shift ;; + -w) wait=true; set=true; shift ;; + -h|--help) usage ;; + --) shift; break ;; + *) echo "$0: Internal error!" ; exit 1 ;; + esac done read -r host type <<<"$@" case $# in - 0|2);; - *) - echo "$0: error: expected 0 or 2 arguments" + 0);; + 2) + case $type in + arch|parabola) cmd=archlike ;; + fai) cmd=fai ;; + *) + echo "$0: error expected type of arch|parabola|fai" echo usage 1 ;; + esac + ;; + *) + echo "$0: error: expected 0 or 2 arguments" + echo + usage 1 + ;; esac + if $wait && ! $dhcp; then - echo "$0: error -w conflicts with -d, choose one or other" - exit 1 + echo "$0: error -w conflicts with -d, choose one or other" + exit 1 fi if [[ $host && $host != default ]]; then - host_tag="tag:$host," + host_tag="tag:$host," fi ##### end command line parsing ######## e() { - echo "$@" - "$@" + echo "$@" + "$@" } -arch() { - cat </dev/null ||: + set-pxe + if [[ $type == fai ]]; then + e myfai-chboot ${chboot_args[@]} $host + if $redep; then + e fai-redep fi + else + # This will fail if faiserver is not setup, so ignore any + # failure and don't bother us about it. + myfai-chboot &>/dev/null ||: + fi fi if $wait; then - # fai's debian jessie 8.5ish does 2 dhcp requests when booting, - # roughly 4 seconds apart. Earlier - # versions did just 1. Now testing on a vm, it does 1. - # bleh. - echo "waiting for $acks dhcp acks then disabling pxe" - ack-wait $acks - type= - set-pxe - - # previously tried waiting for one more ack then disabling faiserver, - # since it can contain sensitive info, so turn it off when not in use, - # but disabling that for now as it's inconvenient to clean this - # up and run it in the background etc. - - # if [[ $type == fai ]]; then - # echo "waiting for 1 dhcp ack then disabling fai server" - # ack-wait 1 - # faiserver-disable - # fi + # fai's debian jessie 8.5ish does 2 dhcp requests when booting, + # roughly 4 seconds apart. Earlier + # versions did just 1. Now testing on a vm, it does 1. + # bleh. + echo "waiting for $acks dhcp acks then disabling pxe" + ack-wait $acks + type= + set-pxe + + # previously tried waiting for one more ack then disabling faiserver, + # since it can contain sensitive info, so turn it off when not in use, + # but disabling that for now as it's inconvenient to clean this + # up and run it in the background etc. + + # if [[ $type == fai ]]; then + # echo "waiting for 1 dhcp ack then disabling fai server" + # ack-wait 1 + # faiserver-disable + # fi fi