2016-03-20 02:32:11 +01:00
#!/usr/bin/env bash
# Pi-hole: A black hole for Internet advertisements
# (c) 2015, 2016 by Jacob Salmela
# Network-wide ad blocking via your Raspberry Pi
# http://pi-hole.net
2016-03-20 03:34:02 +01:00
# Generates pihole_debug.log in /var/log/ to be used for troubleshooting.
2016-03-20 02:32:11 +01:00
#
# Pi-hole is free software: you can redistribute it and/or modify
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation, either version 2 of the License, or
# (at your option) any later version.
# Nate Brandeburg
# nate@ubiquisoft.com
2016-03-24 22:21:29 +01:00
# 3/24/2016
2016-03-20 02:32:11 +01:00
######## GLOBAL VARS ########
DEBUG_LOG = "/var/log/pihole_debug.log"
2016-03-24 22:21:29 +01:00
DNSMASQFILE = "/etc/dnsmasq.conf"
PIHOLECONFFILE = "/etc/dnsmasq.d/01-pihole.conf"
LIGHTTPDFILE = "/etc/lighttpd/lighttpd.conf"
GRAVITYFILE = "/etc/pihole/gravity.list"
HOSTSFILE = "/etc/hosts"
WHITELISTFILE = "/etc/pihole/whitelist.txt"
BLACKLISTFILE = "/etc/pihole/blacklist.txt"
ADLISTSFILE = "/etc/pihole/adlists.list"
PIHOLELOG = "/var/log/pihole.log"
2016-03-25 22:42:17 +01:00
WHITELISTMATCHES = "/tmp/whitelistmatches.list"
2016-03-24 22:21:29 +01:00
2016-03-20 02:32:11 +01:00
######## FIRST CHECK ########
# Must be root to debug
2016-03-25 22:42:17 +01:00
if [ [ $EUID -eq 0 ] ] ; then
2016-03-27 21:44:42 +02:00
echo "::: You are root... Beginning debug!"
2016-03-20 02:32:11 +01:00
else
2016-03-27 21:44:42 +02:00
echo "::: Sudo will be used for debugging."
2016-03-20 02:32:11 +01:00
# Check if sudo is actually installed
2016-03-25 22:42:17 +01:00
if [ [ $( dpkg-query -s sudo) ] ] ; then
2016-03-20 02:32:11 +01:00
export SUDO = "sudo"
else
2016-03-27 21:44:42 +02:00
echo "::: Please install sudo or run this as root."
2016-03-20 02:32:11 +01:00
exit 1
fi
fi
# Ensure the file exists, create if not, clear if exists.
2016-03-25 22:42:17 +01:00
if [ ! -f " $DEBUG_LOG " ] ; then
2016-03-20 02:32:11 +01:00
$SUDO touch $DEBUG_LOG
$SUDO chmod 644 $DEBUG_LOG
$SUDO chown " $USER " :root $DEBUG_LOG
else
truncate -s 0 $DEBUG_LOG
fi
2016-03-24 22:21:29 +01:00
### Private functions exist here ###
function compareWhitelist {
2016-03-25 22:42:17 +01:00
if [ ! -f " $WHITELISTMATCHES " ] ; then
$SUDO touch $WHITELISTMATCHES
$SUDO chmod 644 $WHITELISTMATCHES
$SUDO chown " $USER " :root $WHITELISTMATCHES
else
truncate -s 0 $WHITELISTMATCHES
fi
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "######## Whitelist Comparison #########" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
while read -r line; do
2016-03-25 22:42:17 +01:00
TMP = $( grep -w " .* $line $" " $GRAVITYFILE " )
2016-03-26 01:04:03 +01:00
if [ ! -z " $TMP " ] ; then
echo " $TMP " >> $DEBUG_LOG
echo " $TMP " >> $WHITELISTMATCHES
fi
2016-03-24 22:21:29 +01:00
done < " $WHITELISTFILE "
echo >> $DEBUG_LOG
}
function compareBlacklist {
echo "#######################################" >> $DEBUG_LOG
echo "######## Blacklist Comparison #########" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
while read -r line; do
2016-03-26 01:04:03 +01:00
if [ ! -z " $line " ] ; then
grep -w " .* $line $" " $GRAVITYFILE " >> $DEBUG_LOG
fi
2016-03-24 22:21:29 +01:00
done < " $BLACKLISTFILE "
echo >> $DEBUG_LOG
}
function testNslookup {
2016-03-26 01:04:03 +01:00
TESTURL = "doubleclick.com"
2016-03-25 22:42:17 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############ NSLookup Test ############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
# Find a blocked url that has not been whitelisted.
2016-03-26 01:04:03 +01:00
if [ -s " $WHITELISTMATCHES " ] ; then
while read -r line; do
CUTURL = ${ line #* " " }
if [ " $CUTURL " != "Pi-Hole.IsWorking.OK" ] ; then
while read -r line2; do
CUTURL2 = ${ line2 #* " " }
if [ " $CUTURL " != " $CUTURL2 " ] ; then
TESTURL = " $CUTURL "
break 2
fi
done < " $WHITELISTMATCHES "
fi
done < " $GRAVITYFILE "
fi
2016-03-25 22:42:17 +01:00
echo " NSLOOKUP of $TESTURL from PiHole: " >> $DEBUG_LOG
2016-03-26 01:04:03 +01:00
nslookup " $TESTURL " >> $DEBUG_LOG
2016-03-25 22:42:17 +01:00
echo >> $DEBUG_LOG
echo " NSLOOKUP of $TESTURL from 8.8.8.8: " >> $DEBUG_LOG
2016-03-26 01:04:03 +01:00
nslookup " $TESTURL " 8.8.8.8 >> $DEBUG_LOG
2016-03-24 22:21:29 +01:00
echo >> $DEBUG_LOG
}
2016-03-20 02:32:11 +01:00
### Check Pi internet connections ###
# Log the IP addresses of this Pi
IPADDR = $( ifconfig | perl -nle 's/dr:(\S+)/print $1/e' )
2016-03-27 21:44:42 +02:00
echo "::: Writing local IPs to debug log"
2016-03-20 02:32:11 +01:00
echo "IP Addresses of this Pi:" >> $DEBUG_LOG
echo " $IPADDR " >> $DEBUG_LOG
echo >> $DEBUG_LOG
# Check if we can connect to the local gateway
GATEWAY_CHECK = $( ping -q -w 1 -c 1 " $( ip r | grep default | cut -d ' ' -f 3) " > /dev/null && echo ok || echo error)
echo "Gateway check:" >> $DEBUG_LOG
echo " $GATEWAY_CHECK " >> $DEBUG_LOG
echo >> $DEBUG_LOG
2016-03-25 22:42:17 +01:00
# Test the nslookup here
2016-03-26 01:04:03 +01:00
compareWhitelist
compareBlacklist
2016-03-25 22:42:17 +01:00
testNslookup
2016-03-27 21:44:42 +02:00
echo "::: Writing dnsmasq.conf to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
echo "############### Dnsmasq ###############" >> $DEBUG_LOG
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $DNSMASQFILE " ]
then
2016-03-24 22:21:29 +01:00
#cat $DNSMASQFILE >> $DEBUG_LOG
while read -r line; do
2016-03-25 00:50:53 +01:00
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
echo " $line " >> $DEBUG_LOG
fi
2016-03-24 22:21:29 +01:00
done < " $DNSMASQFILE "
2016-03-20 02:32:11 +01:00
echo >> $DEBUG_LOG
else
echo "No dnsmasq.conf file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo dnsmasq.conf file found!\n"
2016-03-20 02:32:11 +01:00
fi
2016-03-27 21:44:42 +02:00
echo "::: Writing 01-pihole.conf to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "########### 01-pihole.conf ############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
if [ -e " $PIHOLECONFFILE " ]
then
#cat "$PIHOLECONFFILE" >> $DEBUG_LOG
while read -r line; do
2016-03-25 00:50:53 +01:00
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
echo " $line " >> $DEBUG_LOG
fi
2016-03-24 22:21:29 +01:00
done < " $PIHOLECONFFILE "
echo >> $DEBUG_LOG
else
echo "No 01-pihole.conf file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
echo "::: No 01-pihole.conf file found\n"
2016-03-24 22:21:29 +01:00
fi
2016-03-27 21:44:42 +02:00
echo "::: Writing lighttpd.conf to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############ lighttpd.conf ############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
if [ -e " $LIGHTTPDFILE " ]
then
#cat "$PIHOLECONFFILE" >> $DEBUG_LOG
while read -r line; do
2016-03-25 00:50:53 +01:00
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
echo " $line " >> $DEBUG_LOG
fi
2016-03-24 22:21:29 +01:00
done < " $LIGHTTPDFILE "
echo >> $DEBUG_LOG
else
echo "No lighttpd.conf file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo lighttpd.conf file found\n"
2016-03-24 22:21:29 +01:00
fi
2016-03-27 21:44:42 +02:00
echo "::: Writing size of gravity.list to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############ gravity.list #############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
if [ -e " $GRAVITYFILE " ]
then
wc -l " $GRAVITYFILE " >> $DEBUG_LOG
echo >> $DEBUG_LOG
else
echo "No gravity.list file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo gravity.list file found\n"
2016-03-24 22:21:29 +01:00
fi
# Write the hostname output to compare against entries in /etc/hosts, which is logged next
echo "Hostname of this pihole is: " >> $DEBUG_LOG
hostname >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
echo "::: Writing hosts file to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "################ Hosts ################" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $HOSTSFILE " ]
then
cat " $HOSTSFILE " >> $DEBUG_LOG
echo >> $DEBUG_LOG
else
echo "No hosts file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo hosts file found!\n"
2016-03-20 02:32:11 +01:00
fi
### PiHole application specific logging ###
2016-03-27 21:44:42 +02:00
echo "::: Writing whitelist to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############## Whitelist ##############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $WHITELISTFILE " ]
then
cat " $WHITELISTFILE " >> $DEBUG_LOG
echo >> $DEBUG_LOG
else
echo "No whitelist.txt file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo whitelist.txt file found!\n"
2016-03-20 02:32:11 +01:00
fi
2016-03-27 21:44:42 +02:00
echo "::: Writing blacklist to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############## Blacklist ##############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $BLACKLISTFILE " ]
then
cat " $BLACKLISTFILE " >> $DEBUG_LOG
echo >> $DEBUG_LOG
else
echo "No blacklist.txt file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo blacklist.txt file found!\n"
2016-03-20 02:32:11 +01:00
fi
2016-03-27 21:44:42 +02:00
echo "::: Writing adlists.list to debug log..."
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############ adlists.list #############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $ADLISTSFILE " ]
then
cat " $ADLISTSFILE " >> $DEBUG_LOG
echo >> $DEBUG_LOG
else
echo "No adlists.list file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo adlists.list file found!\n"
2016-03-20 02:32:11 +01:00
fi
# Continuously append the pihole.log file to the pihole_debug.log file
function dumpPiHoleLog {
trap '{ echo -e "\nFinishing debug write from interrupt... Quitting!" ; exit 1; }' INT
2016-03-27 21:44:42 +02:00
echo -e "::: Writing current pihole traffic to debug log...\n:::\tTry loading any/all sites that you are having trouble with now... \n:::\t(Press ctrl+C to finish)"
2016-03-24 22:21:29 +01:00
echo "#######################################" >> $DEBUG_LOG
echo "############# pihole.log ##############" >> $DEBUG_LOG
echo "#######################################" >> $DEBUG_LOG
2016-03-20 02:32:11 +01:00
if [ -e " $PIHOLELOG " ]
then
while true; do
tail -f " $PIHOLELOG " >> $DEBUG_LOG
echo >> $DEBUG_LOG
done
else
echo "No pihole.log file found!" >> $DEBUG_LOG
2016-03-27 21:44:42 +02:00
printf ":::\tNo pihole.log file found!\n"
2016-03-20 02:32:11 +01:00
fi
}
2016-03-24 22:21:29 +01:00
# Anything to be done after capturing of pihole.log terminates
function finalWork {
2016-03-27 21:44:42 +02:00
echo "::: Finshed debugging!"
2016-03-20 02:32:11 +01:00
}
2016-03-24 22:21:29 +01:00
trap finalWork EXIT
2016-03-20 02:32:11 +01:00
2016-03-24 22:21:29 +01:00
### Method calls for additional logging ###
2016-03-20 02:32:11 +01:00
dumpPiHoleLog