X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=pxe-server;h=ec4606012a9703d1f70e2088f051057cbd2e1c44;hb=efcfb463ceda4de1d9953da31a2c0737471e5cf8;hp=0bdd13401e4238995ca0ccec985c0ca88d7ddf73;hpb=2eebb95531424e04797094d622eebdd7ece5b38b;p=automated-distro-installer diff --git a/pxe-server b/pxe-server index 0bdd134..ec46060 100755 --- a/pxe-server +++ b/pxe-server @@ -28,22 +28,36 @@ trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR usage() { cat < tftpboot + + Note: Uses GNU getopt options parsing style EOF exit $1 @@ -51,16 +65,16 @@ EOF ##### begin command line parsing ######## -args=() redep=true acks=2 wait=false -temp=$(getopt -l help harw "$@") || usage 1 +temp=$(getopt -l help harSw "$@") || usage 1 eval set -- "$temp" while true; do case $1 in -a) wait=true; set=false; shift ;; -r) redep=false; shift ;; + -S) chboot_arg=-S; shift ;; -w) wait=true; set=true; shift ;; -h|--help) usage ;; --) shift; break ;; @@ -68,14 +82,18 @@ while true; do esac done -read type host <<<"$@" +read -r host type <<<"$@" -if [[ ! $type ]]; then - echo "$0: error: exptected 1 argument of type" - usage 1 -fi +case $# in + 0|2);; + *) + echo "$0: error: expected 0 or 2 arguments" + echo + usage 1 + ;; +esac -if [[ $host ]]; then +if [[ $host && $host != default ]]; then host_tag="tag:$host," fi @@ -104,8 +122,7 @@ EOF fai() { cat </dev/null ||: fi fi @@ -150,7 +169,8 @@ if $wait; then # bleh. echo "waiting for $acks dhcp acks then disabling pxe" ack-wait $acks - set-pxe : + 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,