X-Git-Url: https://iankelling.org/git/?a=blobdiff_plain;f=pxe-server;h=b1700beab398c08cdc9b1a9b60b99112209b0008;hb=ba2a6b887fe5a9ed627e9f0947265b37abbcf7aa;hp=fb92d66c82b736692ce2d9849491c4798d83101e;hpb=cf778f7a65037a2a54e2b6008511f0a584326ce9;p=automated-distro-installer diff --git a/pxe-server b/pxe-server index fb92d66..b1700be 100755 --- a/pxe-server +++ b/pxe-server @@ -15,34 +15,23 @@ # along with this program; if not, write to the Free Software # Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. -# Setup dhcp server to point to tftp server, -# and depending on the type, setup the tftp server. -# usage: $0 TYPE -# default distro is the base debian/fedora type. others are fai & arch. -# for no pxe server, use a no-op like : or true. -set -eE -o pipefail -trap 'echo "$0:$LINENO:error: \"$BASH_COMMAND\" returned $?" >&2' ERR +x="$(readlink -f "$BASH_SOURCE")"; source "${x%/*}/bash-trace" usage() { cat < tftpboot - +HOST A hostname known to the dhcp server, or default for all. +TYPE One of arch, plain, fai. +-d Don't alter dhcp config. Only make sense for fai type, and on network + other than home network. -r Don't redeploy fai config. For example, if there is a different host that is mid-install. @@ -51,11 +40,19 @@ ln -s tftpboot 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. - +-S sets FAI_ACTION=sysinfo, see myfai-chboot for more info. -w Setup pxe, then wait like -a. -h|--help Print help and exit +Note, when switching between plain and arch, you will need to +do something like: +ssh wrt +cd /mnt/usb +rm tftpboot +ln -s tftpboot + + Note: Uses GNU getopt options parsing style EOF exit $1 @@ -63,16 +60,18 @@ EOF ##### begin command line parsing ######## -args=() +dhcp=true redep=true acks=2 wait=false -temp=$(getopt -l help harw "$@") || usage 1 +temp=$(getopt -l help adrSwh "$@") || 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_arg=-S; shift ;; -w) wait=true; set=true; shift ;; -h|--help) usage ;; --) shift; break ;; @@ -80,7 +79,7 @@ while true; do esac done -read host type <<<"$@" +read -r host type <<<"$@" case $# in 0|2);; @@ -91,7 +90,13 @@ case $# in ;; esac -if [[ $host ]]; then +if $wait && ! $dhcp; then + echo "$0: error -w conflicts with -d, choose one or other" + exit 1 +fi + + +if [[ $host && $host != default ]]; then host_tag="tag:$host," fi @@ -120,8 +125,7 @@ EOF fai() { cat <