2015-12-06 13:55:50 +00:00
#!/usr/bin/env bash
2016-01-30 20:12:40 +00:00
# Pi-hole: A black hole for Internet advertisements
2017-02-22 17:55:20 +00:00
# (c) 2017 Pi-hole, LLC (https://pi-hole.net)
# Network-wide ad blocking via your own hardware.
#
2017-04-17 19:25:15 +00:00
# Flushes Pi-hole's log file
2015-12-06 13:55:50 +00:00
#
2017-02-22 17:55:20 +00:00
# This file is copyright under the latest version of the EUPL.
# Please see LICENSE file for your rights under this license.
2017-06-21 11:49:05 +00:00
colfile = "/opt/pihole/COL_TABLE"
source ${ colfile }
2021-07-09 05:06:10 +00:00
# In case we're running at the same time as a system logrotate, use a
# separate logrotate state file to prevent stepping on each other's
# toes.
STATEFILE = "/var/lib/logrotate/pihole"
2018-02-17 11:58:57 +00:00
# Determine database location
# Obtain DBFILE=... setting from pihole-FTL.db
# Constructed to return nothing when
# a) the setting is not present in the config file, or
# b) the setting is commented out (e.g. "#DBFILE=...")
2018-04-13 09:08:02 +00:00
FTLconf = "/etc/pihole/pihole-FTL.conf"
2018-04-13 10:19:55 +00:00
if [ -e " $FTLconf " ] ; then
2018-07-20 20:07:54 +00:00
DBFILE = " $( sed -n -e 's/^\s*DBFILE\s*=\s*//p' ${ FTLconf } ) "
2018-04-13 10:19:55 +00:00
fi
2018-02-17 11:58:57 +00:00
# Test for empty string. Use standard path in this case.
2018-02-17 12:01:00 +00:00
if [ -z " $DBFILE " ] ; then
2018-07-20 20:07:54 +00:00
DBFILE = "/etc/pihole/pihole-FTL.db"
2018-02-17 11:58:57 +00:00
fi
2017-05-17 10:54:43 +00:00
if [ [ " $@ " != *"quiet" * ] ] ; then
2020-09-05 13:15:03 +00:00
echo -ne " ${ INFO } Flushing /var/log/pihole/pihole.log ... "
2017-05-17 10:54:43 +00:00
fi
2017-05-17 10:44:35 +00:00
if [ [ " $@ " = = *"once" * ] ] ; then
2018-07-20 20:07:54 +00:00
# Nightly logrotation
if command -v /usr/sbin/logrotate >/dev/null; then
# Logrotate once
2021-07-09 05:06:10 +00:00
/usr/sbin/logrotate --force --state " ${ STATEFILE } " /etc/pihole/logrotate
2018-07-20 20:07:54 +00:00
else
# Copy pihole.log over to pihole.log.1
# and empty out pihole.log
# Note that moving the file is not an option, as
# dnsmasq would happily continue writing into the
# moved file (it will have the same file handler)
2020-09-05 13:15:03 +00:00
cp -p /var/log/pihole/pihole.log /var/log/pihole/pihole.log.1
echo " " > /var/log/pihole/pihole.log
2022-06-19 21:09:05 +00:00
chmod 640 /var/log/pihole/pihole.log
2018-07-20 20:07:54 +00:00
fi
2017-01-12 19:39:25 +00:00
else
2018-07-20 20:07:54 +00:00
# Manual flushing
if command -v /usr/sbin/logrotate >/dev/null; then
# Logrotate twice to move all data out of sight of FTL
2021-07-09 05:06:10 +00:00
/usr/sbin/logrotate --force --state " ${ STATEFILE } " /etc/pihole/logrotate; sleep 3
/usr/sbin/logrotate --force --state " ${ STATEFILE } " /etc/pihole/logrotate
2018-07-20 20:07:54 +00:00
else
# Flush both pihole.log and pihole.log.1 (if existing)
2020-09-05 13:15:03 +00:00
echo " " > /var/log/pihole/pihole.log
if [ -f /var/log/pihole/pihole.log.1 ] ; then
echo " " > /var/log/pihole/pihole.log.1
2022-06-19 21:09:05 +00:00
chmod 640 /var/log/pihole/pihole.log.1
2018-07-20 20:07:54 +00:00
fi
2017-05-17 10:44:35 +00:00
fi
2018-07-20 20:07:54 +00:00
# Delete most recent 24 hours from FTL's database, leave even older data intact (don't wipe out all history)
2022-02-12 22:33:19 +00:00
deleted = $( pihole-FTL sqlite3 " ${ DBFILE } " "DELETE FROM query_storage WHERE timestamp >= strftime('%s','now')-86400; select changes() from query_storage limit 1" )
2018-01-21 12:48:13 +00:00
2018-08-14 11:14:39 +00:00
# Restart pihole-FTL to force reloading history
sudo pihole restartdns
2017-05-17 10:54:43 +00:00
fi
if [ [ " $@ " != *"quiet" * ] ] ; then
2020-09-05 13:15:03 +00:00
echo -e " ${ OVER } ${ TICK } Flushed /var/log/pihole/pihole.log "
2018-07-20 20:07:54 +00:00
echo -e " ${ TICK } Deleted ${ deleted } queries from database "
2017-01-12 19:39:25 +00:00
fi