X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=pxe-server;h=9e74eeb757a030c9a367fabb3c8440597188d043;hb=47b51938ae090a2717cb2ec3f9e547a76e7b2ae7;hp=1f75adb61ebb3a443ae7a2e4e7029adc3a728991;hpb=23bf2f3666becf9d3c219af1eaea08b4cf843492;p=automated-distro-installer diff --git a/pxe-server b/pxe-server index 1f75adb..9e74eeb 100755 --- a/pxe-server +++ b/pxe-server @@ -28,60 +28,76 @@ trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR usage() { cat < tftpboot + + +-r Don't redeploy fai config. For example, if there is a different host + that is mid-install. + +-a Don't setup pxe, just Wait for 2 dhcp acks, then disable the pxe + server after a delay. First ack is for pxe boot, 2nd ack is + for os boot. Sometimes on debian, there is a 3rd one shortly + after the 2nd. I can't remember exactly why this caused a + problem, but I'm hoping the sleep will take care of it. + +-w Setup pxe, then wait like -a. -h|--help Print help and exit --- Subsequent arguments are never treated as options --p Persist. Otherwise, wait for dhcp acks then remove. --r Don't redeploy fai config. --a Wait for 2 dhcp acks instead of the default 3. Some distros - do 2, some do 3. + + +Note: Uses GNU getopt options parsing style EOF exit $1 } ##### begin command line parsing ######## -persist=false args=() redep=true -acks=3 -while [[ $1 ]]; do +acks=2 +wait=false +temp=$(getopt -l help harw "$@") || usage 1 +eval set -- "$temp" +while true; do case $1 in - --) shift; break ;; - -h|--help) usage ;; + -a) wait=true; set=false; shift ;; -r) redep=false; shift ;; - -p) persist=true; shift ;; - -a) acks=2; shift ;; - *) args+=("$1"); shift ;; + -w) wait=true; set=true; shift ;; + -h|--help) usage ;; + --) shift; break ;; + *) echo "$0: Internal error!" ; exit 1 ;; esac done -args+=("$@") +read host type <<<"$@" -read type host <<<"${args[@]}" - -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 host_tag="tag:$host," fi -case $type in - :|true) persist=true ;; - arch) acks=2 ;; -esac - ##### end command line parsing ######## -sv() { +e() { echo "$@" "$@" } @@ -105,7 +121,7 @@ EOF fai() { cat <