2016-03-20 01:32:11 +00: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-09-27 01:06:31 +00:00
# Generates pihole_debug.log to be used for troubleshooting.
2016-03-20 01:32:11 +00: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.
2016-09-28 02:30:37 +00:00
set -o pipefail
2016-03-20 01:32:11 +00:00
######## GLOBAL VARS ########
DEBUG_LOG = "/var/log/pihole_debug.log"
2016-03-24 21:21:29 +00:00
DNSMASQFILE = "/etc/dnsmasq.conf"
PIHOLECONFFILE = "/etc/dnsmasq.d/01-pihole.conf"
LIGHTTPDFILE = "/etc/lighttpd/lighttpd.conf"
2016-04-11 23:35:44 +00:00
LIGHTTPDERRFILE = "/var/log/lighttpd/error.log"
2016-03-24 21:21:29 +00:00
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 21:42:17 +00:00
WHITELISTMATCHES = "/tmp/whitelistmatches.list"
2016-03-24 21:21:29 +00:00
2016-09-27 01:06:31 +00:00
# Header info and introduction
echo " ::: Beginning Pi-hole debug at $( date) ! "
echo "::: This debugging process will collect information from your running configuration,"
echo "::: and optionally upload the generated log to a unique and random directory on"
echo "::: Termbin.com. NOTE: All log files auto-delete after 1 month and you are the only"
echo "::: person who is given the unique URL. Please consider where you post this link."
echo "::: "
2016-03-20 01:32:11 +00:00
######## FIRST CHECK ########
# Must be root to debug
2016-03-25 21:42:17 +00:00
if [ [ $EUID -eq 0 ] ] ; then
2016-09-27 01:06:31 +00:00
echo "::: Script is executing as root user..."
2016-03-20 01:32:11 +00:00
else
2016-09-27 01:06:31 +00:00
echo "::: Non-root user detected..."
2016-03-20 01:32:11 +00:00
# Check if sudo is actually installed
2016-06-10 18:30:43 +00:00
if [ -x " $( command -v sudo) " ] ; then
2016-03-20 01:32:11 +00:00
export SUDO = "sudo"
2016-09-27 01:06:31 +00:00
echo "::: sudo command located, debug will run under sudo."
2016-03-20 01:32:11 +00:00
else
2016-09-27 01:06:31 +00:00
echo "::: Unable to locate sudo command. Please install sudo or run this as root."
2016-03-20 01:32:11 +00:00
exit 1
fi
fi
# Ensure the file exists, create if not, clear if exists.
2016-03-25 21:42:17 +00:00
if [ ! -f " $DEBUG_LOG " ] ; then
2016-08-21 01:12:02 +00:00
${ SUDO } touch ${ DEBUG_LOG }
${ SUDO } chmod 644 ${ DEBUG_LOG }
${ SUDO } chown " $USER " :root ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
else
2016-08-21 01:12:02 +00:00
truncate -s 0 ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
fi
2016-03-24 21:21:29 +00:00
### Private functions exist here ###
2016-04-12 07:47:30 +00:00
function versionCheck {
2016-09-27 01:06:31 +00:00
echo "############################################################" >> ${ DEBUG_LOG }
echo "########## Installed Versions ##########" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
echo "::: Detecting Pi-hole installed versions."
2016-04-12 07:47:30 +00:00
TMP = $( cd /etc/.pihole/ && git describe --tags --abbrev= 0)
2016-08-21 01:12:02 +00:00
echo " Pi-hole Version: $TMP " >> ${ DEBUG_LOG }
2016-09-27 01:06:31 +00:00
echo "::: Writing Pi-hole installed version to logfile."
2016-04-12 07:47:30 +00:00
TMP = $( cd /var/www/html/admin && git describe --tags --abbrev= 0)
2016-08-21 01:12:02 +00:00
echo " WebUI Version: $TMP " >> ${ DEBUG_LOG }
2016-09-27 02:23:30 +00:00
echo "::: Writing lighttpd version to logfile."
light_ver = $( lighttpd -v | head -n1)
if [ -n light_ver ]
then
echo " ${ light_ver } " >> ${ DEBUG_LOG }
else
echo "lighttpd not installed." >> ${ DEBUG_LOG }
fi
2016-09-27 03:39:39 +00:00
echo "::: Writing PHP version to logfile."
php_ver = $( php -v | head -n1)
if [ -n php_ver ]
then
echo " ${ php_ver } " >> ${ DEBUG_LOG }
else
echo "PHP not installed." >> ${ DEBUG_LOG }
fi
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-04-12 07:47:30 +00:00
}
2016-07-14 18:27:47 +00:00
function distroCheck {
2016-09-27 01:06:31 +00:00
echo "############################################################" >> ${ DEBUG_LOG }
echo "######## Installed OS Distribution #########" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
echo "::: Checking installed OS Distribution release."
2016-07-16 05:46:21 +00:00
TMP = $( cat /etc/*release || echo "Failed to find release" )
2016-09-27 01:06:31 +00:00
echo "::: Writing OS Distribution release to logfile."
echo " $TMP " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
}
function ipCheck {
echo "############################################################" >> ${ DEBUG_LOG }
echo "######## IP Address Information #########" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
2016-09-27 01:21:58 +00:00
echo "::: Writing local IPs to logfile"
2016-09-27 01:06:31 +00:00
IPADDR = $( ip a | awk -F " " '{ for(i=1;i<=NF;i++) if ($i == "inet") print $(i+1) }' )
echo " $IPADDR " >> ${ DEBUG_LOG }
2016-09-27 01:27:02 +00:00
2016-09-27 01:06:31 +00:00
IP6ADDR = $( ip a | awk -F " " '{ for(i=1;i<=NF;i++) if ($i == "inet6") print $(i+1) }' )
2016-09-28 02:30:37 +00:00
if [ [ $? = 0 ] ]
2016-09-27 01:27:02 +00:00
then
2016-09-27 01:06:31 +00:00
echo " $IP6ADDR " >> ${ DEBUG_LOG }
2016-09-28 02:30:37 +00:00
else
echo "No IPv6 addresses found." >> ${ DEBUG_LOG }
2016-09-27 01:27:02 +00:00
fi
2016-09-27 01:06:31 +00:00
echo >> ${ DEBUG_LOG }
echo "::: Locating default gateway and checking connectivity"
GATEWAY = $( ip r | grep default | cut -d ' ' -f 3)
2016-09-28 02:30:37 +00:00
if [ [ $? = 0 ] ]
then
echo "::: Pinging default IPv4 gateway..."
GATEWAY_CHECK = $( ping -q -w 3 -c 3 -n " ${ GATEWAY } " | tail -n3)
if [ [ $? = 0 ] ]
then
echo "IPv4 Gateway check:" >> ${ DEBUG_LOG }
else
echo "IPv4 Gateway check failed:" >> ${ DEBUG_LOG }
fi
2016-09-27 01:06:31 +00:00
echo " $GATEWAY_CHECK " >> ${ DEBUG_LOG }
2016-09-28 02:39:28 +00:00
echo >> ${ DEBUG_LOG }
echo "::: Pinging Internet via IPv4..."
INET_CHECK = $( ping -q -w 5 -c 3 -n 8.8.8.8 | tail -n3)
if [ [ $? = 0 ] ]
then
echo "IPv4 Internet check:" >> ${ DEBUG_LOG }
else
echo "IPv4 Internet check failed:" >> ${ DEBUG_LOG }
fi
echo " $INET_CHECK " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-09-28 02:30:37 +00:00
fi
2016-09-27 01:06:31 +00:00
GATEWAY6 = $( ip -6 r | grep default | cut -d ' ' -f 3)
2016-09-28 02:30:37 +00:00
if [ [ $? = 0 ] ]
2016-09-27 01:21:58 +00:00
then
2016-09-28 02:39:28 +00:00
echo "::: Pinging default IPv6 gateway..."
2016-09-28 02:30:37 +00:00
GATEWAY6_CHECK = $( ping6 -q -w 3 -c 3 -n " ${ GATEWAY6 } " | tail -n3)
if [ [ $? = 0 ] ]
then
echo "IPv6 Gateway check:" >> ${ DEBUG_LOG }
else
echo "IPv6 Gateway check failed:" >> ${ DEBUG_LOG }
fi
2016-09-28 02:39:28 +00:00
echo "::: Pinging Internet via IPv6..."
GATEWAY6_CHECK = $( ping6 -q -w 3 -c 3 -n 2001:4860:4860::8888 | tail -n3)
if [ [ $? = 0 ] ]
then
echo "IPv6 Internet check:" >> ${ DEBUG_LOG }
else
echo "IPv6 Internet check failed:" >> ${ DEBUG_LOG }
fi
2016-09-28 02:30:37 +00:00
else
GATEWAY_CHECK = "No IPv6 Gateway Detected"
2016-09-27 01:21:58 +00:00
fi
2016-09-28 02:30:37 +00:00
echo " $GATEWAY_CHECK " >> ${ DEBUG_LOG }
2016-09-28 02:39:28 +00:00
2016-09-27 01:06:31 +00:00
echo >> ${ DEBUG_LOG }
2016-07-15 20:11:10 +00:00
}
2016-09-27 01:52:12 +00:00
function hostnameCheck {
2016-09-27 02:23:30 +00:00
echo "############################################################" >> ${ DEBUG_LOG }
echo "######## Hostname Information #########" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
echo "::: Writing locally configured hostnames to logfile"
2016-09-27 01:52:12 +00:00
# Write the hostname output to compare against entries in /etc/hosts, which is logged next
2016-09-27 02:23:30 +00:00
echo " This Pi-hole is: $( hostname) " >> ${ DEBUG_LOG }
2016-09-27 01:52:12 +00:00
echo "::: Writing hosts file to debug log..."
2016-09-27 02:23:30 +00:00
echo "### Hosts ###" >> ${ DEBUG_LOG }
2016-09-27 01:52:12 +00:00
if [ -e " $HOSTSFILE " ]
then
cat " $HOSTSFILE " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
else
echo "No hosts file found!" >> ${ DEBUG_LOG }
printf ":::\tNo hosts file found!\n"
fi
}
2016-09-27 03:39:39 +00:00
function portCheck {
echo "############################################################" >> ${ DEBUG_LOG }
echo "######## Open Port Information #########" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
2016-09-28 16:51:14 +00:00
echo "::: Detecting local server port 80 and 53 processes."
2016-09-27 03:39:39 +00:00
2016-09-28 16:51:14 +00:00
${ SUDO } lsof -i :80 >> ${ DEBUG_LOG }
${ SUDO } lsof -i :53 >> ${ DEBUG_LOG }
2016-09-27 03:39:39 +00:00
echo >> ${ DEBUG_LOG }
}
2016-09-28 17:14:47 +00:00
function testResolver {
echo "############################################################" >> ${ DEBUG_LOG }
echo "############ Resolver Functions Check ############" >> ${ DEBUG_LOG }
echo "############################################################" >> ${ DEBUG_LOG }
2016-03-25 21:42:17 +00:00
# Find a blocked url that has not been whitelisted.
2016-09-28 17:14:47 +00:00
TESTURL = "doubleclick.com"
2016-03-26 00:04:03 +00: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 21:42:17 +00:00
2016-09-28 17:14:47 +00:00
echo " Resolution of $TESTURL from Pi-hole: " >> ${ DEBUG_LOG }
2016-09-28 17:24:44 +00:00
LOCALDIG = $( dig " $TESTURL " @127.0.0.1)
if [ [ $? = 0 ] ]
then
echo " $LOCALDIG " >> ${ DEBUG_LOG }
else
echo " Failed to resolve $TESTURL on Pi-hole " >> ${ DEBUG_LOG }
fi
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-09-28 17:24:44 +00:00
2016-09-28 17:14:47 +00:00
echo " Resolution of $TESTURL from 8.8.8.8: " >> ${ DEBUG_LOG }
2016-09-28 17:24:44 +00:00
REMOTEDIG = $( dig " $TESTURL " @8.8.8.8)
if [ [ $? = 0 ] ]
then
echo " $REMOTEDIG " >> ${ DEBUG_LOG }
else
echo " Failed to resolve $TESTURL on 8.8.8.8 " >> ${ DEBUG_LOG }
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-09-28 17:14:47 +00:00
echo "Pi-hole dnsmasq specific records lookups" >> ${ DEBUG_LOG }
echo "Cache Size:" >> ${ DEBUG_LOG }
dig +short chaos txt cachesize.bind >> ${ DEBUG_LOG }
2016-09-28 17:24:44 +00:00
echo "Insertions count:" >> ${ DEBUG_LOG }
dig +short chaos txt insertions.bind >> ${ DEBUG_LOG }
echo "Evictions count:" >> ${ DEBUG_LOG }
dig +short chaos txt evictions.bind >> ${ DEBUG_LOG }
echo "Misses count:" >> ${ DEBUG_LOG }
dig +short chaos txt misses.bind >> ${ DEBUG_LOG }
echo "Hits count:" >> ${ DEBUG_LOG }
dig +short chaos txt hits.bind >> ${ DEBUG_LOG }
echo "Auth count:" >> ${ DEBUG_LOG }
dig +short chaos txt auth.bind >> ${ DEBUG_LOG }
2016-09-28 17:14:47 +00:00
echo "Upstream Servers:" >> ${ DEBUG_LOG }
dig +short chaos txt servers.bind >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-24 21:21:29 +00:00
}
2016-04-04 05:59:24 +00:00
function checkProcesses {
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "########### Processes Check ###########" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-04-04 05:59:24 +00:00
echo ":::"
echo "::: Logging status of lighttpd and dnsmasq..."
PROCESSES = ( lighttpd dnsmasq )
for i in " ${ PROCESSES [@] } "
do
2016-08-21 01:12:02 +00:00
echo "" >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
echo -n " $i " >> " $DEBUG_LOG "
2016-08-21 01:12:02 +00:00
echo " processes status:" >> ${ DEBUG_LOG }
${ SUDO } systemctl -l status " $i " >> " $DEBUG_LOG "
2016-04-04 05:59:24 +00:00
done
2016-09-28 17:14:47 +00:00
echo >> ${ DEBUG_LOG }
2016-04-04 05:59:24 +00:00
}
2016-04-11 23:35:44 +00:00
function debugLighttpd {
echo "::: Writing lighttpd to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############ lighttpd.conf ############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
if [ -e " $LIGHTTPDFILE " ]
then
while read -r line; do
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
2016-08-21 01:12:02 +00:00
echo " $line " >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
fi
done < " $LIGHTTPDFILE "
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No lighttpd.conf file found!" >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
printf ":::\tNo lighttpd.conf file found\n"
fi
if [ -e " $LIGHTTPDERRFILE " ]
then
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "######### lighttpd error.log ##########" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
cat " $LIGHTTPDERRFILE " >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No lighttpd error.log file found!" >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
printf ":::\tNo lighttpd error.log file found\n"
fi
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-04-11 23:35:44 +00:00
}
2016-04-04 05:59:24 +00:00
### END FUNCTIONS ###
2016-03-20 01:32:11 +00:00
2016-04-12 07:47:30 +00:00
versionCheck
2016-07-14 18:27:47 +00:00
distroCheck
2016-09-27 01:06:31 +00:00
ipCheck
2016-09-27 01:52:12 +00:00
hostnameCheck
2016-09-27 03:39:39 +00:00
portCheck
2016-04-04 05:59:24 +00:00
checkProcesses
2016-09-28 17:14:47 +00:00
testResolver
2016-04-11 23:35:44 +00:00
debugLighttpd
2016-03-25 21:42:17 +00:00
2016-03-27 19:44:42 +00:00
echo "::: Writing dnsmasq.conf to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############### Dnsmasq ###############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
if [ -e " $DNSMASQFILE " ]
then
2016-03-24 21:21:29 +00:00
#cat $DNSMASQFILE >> $DEBUG_LOG
while read -r line; do
2016-03-24 23:50:53 +00:00
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
2016-08-21 01:12:02 +00:00
echo " $line " >> ${ DEBUG_LOG }
2016-03-24 23:50:53 +00:00
fi
2016-03-24 21:21:29 +00:00
done < " $DNSMASQFILE "
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No dnsmasq.conf file found!" >> ${ DEBUG_LOG }
2016-03-27 19:44:42 +00:00
printf ":::\tNo dnsmasq.conf file found!\n"
2016-03-20 01:32:11 +00:00
fi
2016-03-27 19:44:42 +00:00
echo "::: Writing 01-pihole.conf to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "########### 01-pihole.conf ############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-24 21:21:29 +00:00
if [ -e " $PIHOLECONFFILE " ]
then
while read -r line; do
2016-03-24 23:50:53 +00:00
if [ ! -z " $line " ] ; then
[ [ " $line " = ~ ^#.*$ ] ] && continue
2016-08-21 01:12:02 +00:00
echo " $line " >> ${ DEBUG_LOG }
2016-03-24 23:50:53 +00:00
fi
2016-03-24 21:21:29 +00:00
done < " $PIHOLECONFFILE "
2016-08-21 01:12:02 +00:00
echo >> ${ DEBUG_LOG }
2016-03-24 21:21:29 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No 01-pihole.conf file found!" >> ${ DEBUG_LOG }
2016-03-28 01:36:31 +00:00
printf ":::\tNo 01-pihole.conf file found\n"
2016-03-24 21:21:29 +00:00
fi
2016-03-27 19:44:42 +00:00
echo "::: Writing size of gravity.list to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############ gravity.list #############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-24 21:21:29 +00:00
if [ -e " $GRAVITYFILE " ]
then
2016-08-21 01:12:02 +00:00
wc -l " $GRAVITYFILE " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-24 21:21:29 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No gravity.list file found!" >> ${ DEBUG_LOG }
2016-03-27 19:44:42 +00:00
printf ":::\tNo gravity.list file found\n"
2016-03-24 21:21:29 +00:00
fi
2016-03-20 01:32:11 +00:00
2016-09-27 03:50:03 +00:00
### Pi-hole application specific logging ###
2016-03-27 19:44:42 +00:00
echo "::: Writing whitelist to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############## Whitelist ##############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
if [ -e " $WHITELISTFILE " ]
then
2016-08-21 01:12:02 +00:00
cat " $WHITELISTFILE " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No whitelist.txt file found!" >> ${ DEBUG_LOG }
2016-03-27 19:44:42 +00:00
printf ":::\tNo whitelist.txt file found!\n"
2016-03-20 01:32:11 +00:00
fi
2016-03-27 19:44:42 +00:00
echo "::: Writing blacklist to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############## Blacklist ##############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
if [ -e " $BLACKLISTFILE " ]
then
2016-08-21 01:12:02 +00:00
cat " $BLACKLISTFILE " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No blacklist.txt file found!" >> ${ DEBUG_LOG }
2016-03-27 19:44:42 +00:00
printf ":::\tNo blacklist.txt file found!\n"
2016-03-20 01:32:11 +00:00
fi
2016-03-27 19:44:42 +00:00
echo "::: Writing adlists.list to debug log..."
2016-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############ adlists.list #############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
if [ -e " $ADLISTSFILE " ]
then
2016-08-21 01:12:02 +00:00
cat " $ADLISTSFILE " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
else
2016-08-21 01:12:02 +00:00
echo "No adlists.list file found... using adlists.default!" >> ${ DEBUG_LOG }
2016-03-31 00:49:39 +00:00
printf ":::\tNo adlists.list file found... using adlists.default!\n"
2016-03-20 01:32:11 +00:00
fi
# Continuously append the pihole.log file to the pihole_debug.log file
function dumpPiHoleLog {
2016-04-11 23:35:44 +00:00
trap '{ echo -e "\n::: Finishing debug write from interrupt... Quitting!" ; exit 1; }' INT
2016-09-27 03:50:03 +00:00
echo -e "::: Writing current Pi-hole 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-08-21 01:12:02 +00:00
echo "#######################################" >> ${ DEBUG_LOG }
echo "############# pihole.log ##############" >> ${ DEBUG_LOG }
echo "#######################################" >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
if [ -e " $PIHOLELOG " ]
then
while true; do
2016-08-21 01:12:02 +00:00
tail -f " $PIHOLELOG " >> ${ DEBUG_LOG }
echo >> ${ DEBUG_LOG }
2016-03-20 01:32:11 +00:00
done
else
2016-09-27 03:54:05 +00:00
echo "No pihole.log file found!" >> ${ DEBUG_LOG }
printf ":::\tNo pihole.log file found!\n"
2016-03-20 01:32:11 +00:00
fi
}
2016-03-24 21:21:29 +00:00
# Anything to be done after capturing of pihole.log terminates
function finalWork {
2016-08-01 20:43:13 +00:00
echo "::: Finshed debugging!"
2016-09-15 14:16:06 +00:00
echo "::: The debug log can be uploaded to Termbin.com for easier sharing."
2016-08-01 20:43:13 +00:00
read -r -p "::: Would you like to upload the log? [y/N] " response
2016-08-21 01:12:02 +00:00
case ${ response } in
2016-08-01 20:43:13 +00:00
[ yY] [ eE] [ sS] | [ yY] )
TERMBIN = $( cat /var/log/pihole_debug.log | nc termbin.com 9999)
; ;
*)
echo "::: Log will NOT be uploaded to Termbin."
; ;
esac
2016-07-03 23:50:42 +00:00
2016-08-01 20:43:13 +00:00
# Check if termbin.com is reachable. When it's not, point to local log instead
if [ -n " $TERMBIN " ]
then
echo " ::: Debug log can be found at : $TERMBIN "
else
echo "::: Debug log can be found at : /var/log/pihole_debug.log"
fi
2016-03-20 01:32:11 +00:00
}
2016-08-01 20:43:13 +00:00
2016-03-24 21:21:29 +00:00
trap finalWork EXIT
2016-03-20 01:32:11 +00:00
2016-03-24 21:21:29 +00:00
### Method calls for additional logging ###
2016-03-20 01:32:11 +00:00
dumpPiHoleLog