X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=pxe-server;h=692ffbbc62f34eec05fe5be2ccb8541030146be1;hp=6137386a1188d9ab9c50e4bee783e7ee57dfc053;hb=6ca069946c8ff88d79d1ae421e0eda60ae1c514c;hpb=3d9cc96092cdc8aa05bc95cf83c07bb1af692013 diff --git a/pxe-server b/pxe-server index 6137386..692ffbb 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" @@ -56,11 +57,33 @@ rm tftpboot ln -s tftpboot +Notes on debugging pxe dhcp tftp: + +For debugging dhcp, add to /etc/dnsmasq.conf: log-dhcp + +Newer openwrt runs dnsmasq with a whitelist of readable files and dirs: + +ps ww : +/sbin/ujail -t 5 -n dnsmasq -u -l -r /bin/ubus -r /etc/TZ -r /etc/dnsmasq.conf -r /etc/ethers -r /etc/group -r /etc/hosts -r /etc/passwd -w /tmp/dhcp.leases -r /tmp/dnsmasq.d -r /tmp/hosts -r /tmp/resolv.conf.d -r /usr/bin/jshn -r /usr/lib/dnsmasq/dhcp-script.sh -r /usr/share/dnsmasq/dhcpbogushostname.conf -r /usr/share/dnsmasq/rfc6761.conf -r /usr/share/dnsmasq/trust-anchors.conf -r /usr/share/libubox/jshn.sh -r /var/etc/dnsmasq.conf.cfg01411c -w /var/run/dnsmasq/ -- /usr/sbin/dnsmasq -C /var/etc/dnsmasq.conf.cfg01411c -k -x /var/run/dnsmasq/dnsmasq.cfg01411c.pid + +logging tftp requests: +/etc/default/tftpd-hpa: +add -vv: +TFTP_OPTIONS="--secure -vv" +jr -u tftpd-hpa -f + Note: Uses GNU getopt options parsing style EOF exit $1 } +pre="${0##*/}:" +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 @@ -70,7 +93,7 @@ wait=false fsf=false case $HOSTNAME in - x2|x3|kw) fsf=true ;; + x3|kw) fsf=true ;; esac chboot_args=() @@ -125,16 +148,11 @@ fi ##### end command line parsing ######## -e() { - echo "$@" - "$@" -} - 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 - e myfai-chboot ${chboot_args[@]} $host if $redep; then - e fai-redep + 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.