mirror of
https://github.com/YunoHost-Apps/pihole_ynh.git
synced 2024-09-03 20:05:58 +02:00
137 lines
4.6 KiB
Bash
137 lines
4.6 KiB
Bash
#!/bin/bash
|
|
|
|
#=================================================
|
|
# IMPORT GENERIC HELPERS
|
|
#=================================================
|
|
|
|
source _common.sh
|
|
source /usr/share/yunohost/helpers
|
|
|
|
#=================================================
|
|
# REMOVE SYSTEM CONFIGURATIONS
|
|
#=================================================
|
|
ynh_script_progression --message="Removing system configurations related to $app..." --weight=1
|
|
|
|
# Remove the service from the list of services known by YunoHost (added from `yunohost service add`)
|
|
if ynh_exec_warn_less yunohost service status "pihole-FTL" >/dev/null; then
|
|
yunohost service remove "pihole-FTL"
|
|
fi
|
|
|
|
ynh_systemd_action --service_name="pihole-FTL" --action="stop"
|
|
|
|
# Restore dnsmasq as main DNS resolver
|
|
# Move dnsmasq back to its original place
|
|
#if [ -e "/usr/sbin/dnsmasq.backup_by_pihole" ]
|
|
#then # Remove dnsmasq only if we have its backup
|
|
# ynh_secure_remove --file="/usr/sbin/dnsmasq"
|
|
# mv /usr/sbin/dnsmasq.backup_by_pihole /usr/sbin/dnsmasq
|
|
#fi
|
|
|
|
# Move back the service configuration for dnsmasq
|
|
#ynh_secure_remove --file="/etc/systemd/system/dnsmasq.service"
|
|
#mv /lib/systemd/system/.dnsmasq.service.backup_by_pihole /lib/systemd/system/dnsmasq.service
|
|
#mv /etc/init.d/.dnsmasq.backup_by_pihole /etc/init.d/dnsmasq
|
|
systemctl unmask dnsmasq.service
|
|
|
|
#ynh_exec_warn_less systemctl enable dnsmasq --quiet
|
|
# Reload systemd config
|
|
systemctl daemon-reload
|
|
|
|
ynh_secure_remove --file="/etc/init.d/pihole-FTL"
|
|
ynh_secure_remove --file="/usr/bin/pihole-FTL"
|
|
ynh_secure_remove --file="/var/run/pihole-FTL.pid"
|
|
ynh_secure_remove --file="/var/run/pihole-FTL.port"
|
|
|
|
# Remove the dedicated NGINX config
|
|
ynh_remove_nginx_config
|
|
|
|
# Remove the dedicated PHP-FPM config
|
|
ynh_remove_fpm_config
|
|
|
|
#=================================================
|
|
# CLOSE A PORT
|
|
#=================================================
|
|
|
|
if yunohost firewall list | grep -q "\- $port$"; then
|
|
ynh_script_progression --message="Closing port $port..." --weight=1
|
|
ynh_exec_warn_less yunohost firewall disallow TCP "$port"
|
|
fi
|
|
|
|
if yunohost firewall list | grep -q "\- 67$"; then
|
|
ynh_script_progression --message="Closing port 67..." --weight=1
|
|
ynh_exec_warn_less yunohost firewall disallow UDP 67
|
|
fi
|
|
|
|
#=================================================
|
|
# REMOVE VARIOUS FILES
|
|
#=================================================
|
|
ynh_script_progression --message="Removing various files..." --weight=1
|
|
|
|
# Remove a cron file
|
|
ynh_secure_remove --file="/etc/cron.d/$app"
|
|
|
|
# Remove the log files
|
|
ynh_secure_remove --file="/var/log/$app"
|
|
|
|
# Remove main script
|
|
ynh_secure_remove --file="$PI_HOLE_BIN_DIR/pihole"
|
|
ynh_secure_remove --file="/etc/bash_completion.d/pihole"
|
|
|
|
# Remove sudoer file
|
|
ynh_secure_remove --file="/etc/sudoers.d/pihole"
|
|
|
|
# Remove storage directory
|
|
ynh_secure_remove --file="$PI_HOLE_CONFIG_DIR"
|
|
# Remove app directory
|
|
ynh_secure_remove --file="$PI_HOLE_INSTALL_DIR"
|
|
# Remove local clone of the repository
|
|
ynh_secure_remove --file="$PI_HOLE_LOCAL_REPO"
|
|
|
|
#=================================================
|
|
# REMOVE DNSMASQ CONFIG
|
|
#=================================================
|
|
ynh_script_progression --message="Removing Dnsmasq config..." --weight=2
|
|
|
|
ynh_secure_remove --file="/etc/dnsmasq.d/03-pihole-wildcard.conf"
|
|
|
|
#=================================================
|
|
# CLEAN /etc/hosts
|
|
#=================================================
|
|
ynh_script_progression --message="Clean /etc/hosts" --weight=1
|
|
|
|
# Uncomment lines in /etc/hosts
|
|
ynh_replace_string --match_string="#Commented by pihole# " --replace_string="" --target_file=/etc/hosts
|
|
|
|
# And remove extra lines, added by PiHole
|
|
sed -i "/#Added by pihole#/d" /etc/hosts
|
|
|
|
#=================================================
|
|
# REMOVE CONF_REGEN HOOK
|
|
#=================================================
|
|
ynh_script_progression --message="Removing conf_regen hook..." --weight=1
|
|
|
|
ynh_systemd_action --service_name=dnsmasq --action=stop
|
|
|
|
ynh_secure_remove --file="/usr/share/yunohost/hooks/conf_regen/50-dnsmasq_$app"
|
|
|
|
ynh_exec_warn_less yunohost tools regen-conf dnsmasq
|
|
|
|
#=================================================
|
|
# RESTART DNSMASQ
|
|
#=================================================
|
|
ynh_script_progression --message="Restarting Dnsmasq..." --weight=1
|
|
|
|
ynh_systemd_action --service_name=dnsmasq --action=restart
|
|
|
|
#=================================================
|
|
# REMOVE DEDICATED USER
|
|
#=================================================
|
|
|
|
# Dirty hack to remove correctly the user
|
|
killall -u "$app"
|
|
|
|
#=================================================
|
|
# END OF SCRIPT
|
|
#=================================================
|
|
|
|
ynh_script_progression --message="Removal of $app completed" --last
|