2019-04-14 21:29:56 +00:00
|
|
|
#!/bin/bash
|
2019-05-09 04:17:28 +00:00
|
|
|
# create a diagnostic footprint of network, and OS settings
|
2019-04-14 21:29:56 +00:00
|
|
|
|
2019-06-21 03:15:43 +00:00
|
|
|
read -p "\n\nPlease provide a name or nickname: (8 characters or less, no spaces) " who
|
2019-04-14 21:29:56 +00:00
|
|
|
if [ -z "$who" ]; then
|
|
|
|
who="noname"
|
|
|
|
fi
|
|
|
|
|
2019-05-09 05:30:54 +00:00
|
|
|
read -p "\n\nIf this is a request for help, what is your email address? " email
|
2019-04-14 21:29:56 +00:00
|
|
|
# Build up a meaningful name for transmission back to the development team
|
|
|
|
OS_VER=`cat /etc/iiab/iiab.env | grep OS_VER | cut -d'=' -f2`
|
|
|
|
pushd /opt/iiab/iiab
|
|
|
|
HASH=`git log --pretty=format:'g%h' -n 1`
|
|
|
|
YMD=$(date +%y%m%d)
|
|
|
|
popd
|
|
|
|
|
|
|
|
SCRIPTDIR=$(cd `dirname $0` pwd)
|
2019-05-09 04:02:33 +00:00
|
|
|
diagnostics_name=${OS_VER}-$YMD-$who
|
|
|
|
basket=$diagnostics_name.$$
|
2019-04-14 21:29:56 +00:00
|
|
|
VARS_VALUES=/tmp/all-vars
|
|
|
|
|
|
|
|
# record all the ansible variables
|
|
|
|
pushd /opt/iiab/iiab > /dev/null
|
|
|
|
./runrole all-vars $VARS_VALUES
|
|
|
|
popd > /dev/null
|
|
|
|
|
|
|
|
# cat files in this direcory
|
|
|
|
function cat_dir(){
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "Printing contents of $1"
|
|
|
|
filelist=$(ls $1)
|
|
|
|
if [ ! -z "$filelist" ]; then
|
|
|
|
pushd $1
|
|
|
|
for f in `ls *`;do
|
|
|
|
echo $f
|
|
|
|
cat $f
|
|
|
|
done
|
|
|
|
popd
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
|
|
|
|
# collect all the network info in one place
|
|
|
|
mkdir -p /tmp/$basket
|
|
|
|
cat << EOF > /tmp/script2overview
|
|
|
|
#!/bin/bash
|
|
|
|
# generate the body overview part diagnostic package about network
|
|
|
|
echo "=========================================================="
|
2019-05-09 04:17:28 +00:00
|
|
|
echo Diagnostics submitted by:
|
2019-04-14 21:29:56 +00:00
|
|
|
echo $who
|
|
|
|
echo $email
|
|
|
|
echo "=========================================================="
|
|
|
|
echo iiab.env
|
|
|
|
cat /etc/iiab/iiab.env
|
|
|
|
echo "=========================================================="
|
2019-05-09 04:25:52 +00:00
|
|
|
echo /etc/iiab/local_vars.yml
|
|
|
|
cat /etc/iiab/local_vars.yml
|
|
|
|
echo "=========================================================="
|
|
|
|
echo /etc/iiab/openvpn_handle
|
|
|
|
cat /etc/iiab/openvpn_handle
|
|
|
|
echo "=========================================================="
|
2019-04-14 21:29:56 +00:00
|
|
|
echo ifconfig
|
|
|
|
ifconfig
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo ip addr
|
|
|
|
ip addr
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-04-15 18:05:24 +00:00
|
|
|
echo Checking for information about raspberry pi base image
|
|
|
|
if [ -f /etc/rpi-issue ];then
|
|
|
|
cat /etc/rpi-issue
|
2019-05-09 05:30:54 +00:00
|
|
|
echo "stage 2 = lite; stage 3 = desktop SEE github.com/RPi-Distro/pi-gen#stage-anatomy"
|
2019-04-15 18:05:24 +00:00
|
|
|
else
|
|
|
|
echo "not a raspberry pi"
|
|
|
|
fi
|
|
|
|
echo "=========================================================="
|
2019-04-14 21:29:56 +00:00
|
|
|
echo "brctl show"
|
|
|
|
brctl show
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "/etc/resolv.conf"
|
|
|
|
cat /etc/resolv.conf
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-05-09 05:30:54 +00:00
|
|
|
echo "/etc/iiab_ini_file "
|
2019-04-14 21:29:56 +00:00
|
|
|
cat /etc/iiab/iiab.ini
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "routing table"
|
|
|
|
netstat -rn
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-05-09 05:30:54 +00:00
|
|
|
echo "iptales-save output"
|
|
|
|
iptables-save
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "/usr/bin/iiab-gen-iptable"
|
|
|
|
cat /usr/bin/iiab-gen-iptables
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-05-09 16:52:31 +00:00
|
|
|
echo "/.iiab-image"
|
|
|
|
cat /.iiab-image
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "systemctl status dnsmasq"
|
|
|
|
systemctl status dnsmasq
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "journalctl -u dnsmasq"
|
|
|
|
journalctl -u dnsmasq
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-04-14 22:07:22 +00:00
|
|
|
echo "port usage"
|
|
|
|
netstat -natp
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
2019-04-14 21:29:56 +00:00
|
|
|
echo "install log -- last 50 lines"
|
|
|
|
tail -50 /opt/iiab/iiab/iiab-install.log
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "iiab-network log -- last 50 lines"
|
|
|
|
if [ -f /opt/iiab/iiab/iiab-network.log ]; then
|
|
|
|
tail -50 /opt/iiab/iiab/iiab-network.log
|
|
|
|
else
|
|
|
|
echo no iiab-network.log
|
|
|
|
fi
|
|
|
|
echo
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "Contents of /etc/network/interfaces"
|
|
|
|
cat /etc/network/interfaces
|
|
|
|
echo "End of Contents of /etc/network/interfaces"
|
|
|
|
echo "=========================================================="
|
|
|
|
# cat files in this direcory
|
|
|
|
function cat_dir(){
|
|
|
|
echo "=========================================================="
|
|
|
|
echo "Printing contents of Directory \$1"
|
|
|
|
filelist=\$(ls \$1)
|
|
|
|
if [ ! -z "\$filelist" ]; then
|
|
|
|
for f in \$filelist;do
|
|
|
|
echo ===== Contents of file: \$base/\$f
|
|
|
|
cat \$1/\$f
|
|
|
|
echo ===== End of Contents of file: \$f
|
|
|
|
done
|
|
|
|
fi
|
|
|
|
}
|
|
|
|
cat_dir /etc/network/interfaces.d
|
|
|
|
cat_dir /etc/systemd/network
|
|
|
|
cat_dir /etc/NetworkManager/system-connections
|
|
|
|
cat_dir /etc/sysconfig/network-scripts/if-cfg*
|
|
|
|
EOF
|
|
|
|
chmod 755 /tmp/script2overview
|
|
|
|
/tmp/script2overview > /tmp/$basket/overview
|
|
|
|
|
|
|
|
if [ -f /opt/iiab/iiab/iiab-debug.log ]; then
|
|
|
|
cp /opt/iiab/iiab/iiab-debug.log /tmp/$basket
|
|
|
|
else
|
|
|
|
touch /tmp/$basket/no_iiab-network.log
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f /opt/iiab/iiab/iiab-install.log ]; then
|
|
|
|
cp -p /opt/iiab/iiab/iiab-install.log /tmp/$basket
|
|
|
|
fi
|
|
|
|
|
|
|
|
if [ -f "$VARS_VALUES" ]; then
|
|
|
|
cp -p "$VARS_VALUES" /tmp/$basket
|
|
|
|
fi
|
|
|
|
|
2019-05-09 04:02:33 +00:00
|
|
|
mkdir -p /etc/iiab/diagnostics
|
|
|
|
if [ ! -z $diagnostics_name ];then
|
2019-04-14 21:29:56 +00:00
|
|
|
pushd /tmp > /dev/null
|
2019-05-09 04:02:33 +00:00
|
|
|
tar czf /etc/iiab/diagnostics/$basket.tgz $basket/*
|
2019-04-14 21:29:56 +00:00
|
|
|
popd > /dev/null
|
|
|
|
rm -rf /tmp/$basket
|
|
|
|
exit 0
|
|
|
|
fi
|