mirror of
https://github.com/pi-hole/pi-hole.git
synced 2024-11-28 09:03:17 +00:00
Loop through dependencies as with install, offer user a choice to keep or remove them.
This commit is contained in:
parent
6ff2b04dfb
commit
5eff32f578
1 changed files with 51 additions and 12 deletions
|
@ -10,11 +10,29 @@
|
|||
# the Free Software Foundation, either version 2 of the License, or
|
||||
# (at your option) any later version.
|
||||
|
||||
|
||||
spinner() {
|
||||
local pid=$1
|
||||
|
||||
spin='-\|/'
|
||||
i=0
|
||||
while $SUDO kill -0 $pid 2>/dev/null
|
||||
do
|
||||
i=$(( (i+1) %4 ))
|
||||
printf "\b${spin:$i:1}"
|
||||
sleep .1
|
||||
done
|
||||
printf "\b"
|
||||
}
|
||||
|
||||
echo ":::"
|
||||
echo "::: Sorry to see you go :(..."
|
||||
echo ":::"
|
||||
# Must be root to uninstall
|
||||
if [[ $EUID -eq 0 ]];then
|
||||
echo "You are root."
|
||||
else
|
||||
echo "sudo will be used for the install."
|
||||
echo "::: sudo will be used for the uninstall."
|
||||
# Check if it is actually installed
|
||||
# If it isn't, exit because the unnstall cannot complete
|
||||
if [[ $(dpkg-query -s sudo) ]];then
|
||||
|
@ -27,9 +45,25 @@ fi
|
|||
|
||||
|
||||
######### SCRIPT ###########
|
||||
$SUDO apt-get -y remove --purge dnsutils bc toilet
|
||||
$SUDO apt-get -y remove --purge dnsmasq
|
||||
$SUDO apt-get -y remove --purge lighttpd php5-common php5-cgi php5
|
||||
#Check with user which dependencies to remove. They may be using some of them elsewhere
|
||||
echo ":::"
|
||||
echo "::: Removing dependencies..."
|
||||
dependencies=( dnsutils bc toilet figlet dnsmasq lighttpd php5-common php5-cgi php5 git curl unzip wget )
|
||||
for i in "${dependencies[@]}"
|
||||
do
|
||||
:
|
||||
if [ $(dpkg-query -W -f='${Status}' $i 2>/dev/null | grep -c "ok installed") -eq 1 ]; then
|
||||
while true; do
|
||||
read -p "::: Do you wish to remove this dependency from your system? [$i] (y/n): " yn
|
||||
case $yn in
|
||||
[Yy]* ) echo -n "::: removing $i....";$SUDO apt-get -y -qq remove $i > /dev/null & spinner $!; echo " done."; break;;
|
||||
[Nn]* ) echo "::: Keeping $i installed"; break;;
|
||||
* ) echo "::: Please answer yes or no.";;
|
||||
esac
|
||||
done
|
||||
echo ":::"
|
||||
fi
|
||||
done
|
||||
|
||||
# Only web directories/files that are created by pihole should be removed.
|
||||
echo -n "::: Removing the Pi-hole Web server files..."
|
||||
|
@ -44,12 +78,13 @@ $SUDO rm -rf /etc/.pihole
|
|||
echo " done."
|
||||
|
||||
# If the web directory is empty after removing these files, then the parent html folder can be removed.
|
||||
if [[ ! "$(ls -A /var/www/html)" ]]; then
|
||||
$SUDO rm -rf /var/www/html
|
||||
fi
|
||||
#if [[ ! "$(ls -A /var/www/html)" ]]; then
|
||||
# $SUDO rm -rf /var/www/html
|
||||
#fi
|
||||
|
||||
echo "::: Removing dnsmasq config files..."
|
||||
echo -n "::: Removing pi-hole dnsmasq config file..."
|
||||
$SUDO rm /etc/dnsmasq.d/01-pihole.conf
|
||||
echo " done."
|
||||
|
||||
# Attempt to preserve backwards compatibility with older versions
|
||||
# to guarantee no additional changes were made to /etc/crontab after
|
||||
|
@ -64,16 +99,20 @@ fi
|
|||
|
||||
# Attempt to preserve backwards compatibility with older versions
|
||||
if [[ -f /etc/cron.d/pihole ]];then
|
||||
echo "Removing cron.d/pihole..."
|
||||
echo -n "::: Removing pi-hole cron jobs..."
|
||||
$SUDO rm /etc/cron.d/pihole
|
||||
echo " done."
|
||||
fi
|
||||
|
||||
echo "Removing config files and scripts..."
|
||||
$SUDO rm /etc/dnsmasq.conf
|
||||
$SUDO rm -rf /etc/lighttpd/
|
||||
echo -n "::: Removing config files and scripts..."
|
||||
$SUDO rm -rf /etc/.pihole/
|
||||
#$SUDO rm -rf /etc/lighttpd/
|
||||
$SUDO rm /var/log/pihole.log
|
||||
$SUDO rm /usr/local/bin/gravity.sh
|
||||
$SUDO rm /usr/local/bin/chronometer.sh
|
||||
$SUDO rm /usr/local/bin/whitelist.sh
|
||||
$SUDO rm /usr/local/bin/blacklist.sh
|
||||
$SUDO rm /usr/local/bin/piholeLogFlush.sh
|
||||
$SUDO rm -rf /etc/pihole/
|
||||
$SUDO rm /usr/local/bin/uninstall.sh
|
||||
echo " done."
|
||||
|
|
Loading…
Reference in a new issue