X-Git-Url: https://iankelling.org/git/?p=automated-distro-installer;a=blobdiff_plain;f=pxe-server;h=692ffbbc62f34eec05fe5be2ccb8541030146be1;hp=d40751e811ffb90601854d14eda312bc92694bfb;hb=6ca069946c8ff88d79d1ae421e0eda60ae1c514c;hpb=cef9b6ede5c1e028bed1b4dc7895f5dfa121ad6b diff --git a/pxe-server b/pxe-server index d40751e..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,6 +57,21 @@ 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 @@ -66,6 +82,8 @@ 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 @@ -163,7 +181,7 @@ ack-wait() { if $fsf; then wait_cmd="ssh tarantula.office.fsf.org tail -n0 -f /var/log/syslog" else - wait_cmd="ssh wrt logread -f" + wait_cmd="ssh cmc logread -f" fi wait_count=$1 if [[ $host ]]; then @@ -190,20 +208,20 @@ set-pxe() { if [[ ! $cmd ]]; then e "removing pxe for $host on tarantula" ssh tarantula.office.fsf.org bash -e <