2020-10-16 11:49:43 +02:00
|
|
|
#!/usr/bin/env bash
|
2020-01-03 08:16:42 +01:00
|
|
|
|
|
|
|
# START
|
|
|
|
set -e
|
|
|
|
|
2020-01-03 10:17:00 +01:00
|
|
|
# VARIABLES
|
2020-03-21 20:26:10 +01:00
|
|
|
NAME_OSX="Darwin"
|
|
|
|
THIS_OS=$(uname -mrs)
|
2020-01-03 08:16:42 +01:00
|
|
|
PROGNAME=$(basename $0)
|
2021-03-09 02:59:20 +01:00
|
|
|
[[ -z "${XDG_CONFIG_HOME}" ]] && CONFIG=$HOME/.maza/ || CONFIG=$XDG_CONFIG_HOME/maza
|
2020-01-03 10:17:00 +01:00
|
|
|
HOST_FILE=(/etc/hosts)
|
|
|
|
COLOR_RED=`tput setaf 1`
|
|
|
|
COLOR_GREEN=`tput setaf 2`
|
|
|
|
COLOR_RESET=`tput sgr0`
|
2020-01-03 08:16:42 +01:00
|
|
|
LIST="list"
|
2020-01-04 08:32:22 +01:00
|
|
|
LIST_DNSMASQ="dnsmasq.conf"
|
2020-01-03 09:50:01 +01:00
|
|
|
START_TAG="## MAZA - List ad blocking"
|
2020-01-03 17:17:54 +01:00
|
|
|
PROJECT="### https://github.com/tanrax/maza-ad-blocking"
|
|
|
|
AUTHOR="### Created by Andros Fenollosa (https://programadorwebvalencia.com/)"
|
2020-01-03 09:50:01 +01:00
|
|
|
END_TAG="## END MAZA"
|
2020-01-03 08:16:42 +01:00
|
|
|
|
2020-03-21 20:26:10 +01:00
|
|
|
|
|
|
|
# Create sed cross system
|
2020-03-21 21:02:04 +01:00
|
|
|
custom-sed() {
|
2020-03-21 20:26:10 +01:00
|
|
|
if [[ $THIS_OS = *$NAME_OSX* ]]; then
|
|
|
|
# Check if OSX and install GSED
|
|
|
|
if [ -x "$(command -v gsed)" ]; then
|
|
|
|
gsed "$@"
|
|
|
|
else
|
|
|
|
echo "${COLOR_RED}ERROR. You must install gsed if you are using OSX${COLOR_RESET}"
|
|
|
|
exit 1
|
|
|
|
fi
|
|
|
|
else
|
|
|
|
# Linux
|
|
|
|
sed "$@"
|
|
|
|
fi
|
|
|
|
}
|
2020-03-21 21:02:04 +01:00
|
|
|
export -f custom-sed
|
2020-03-21 20:26:10 +01:00
|
|
|
|
|
|
|
|
2020-01-03 08:16:42 +01:00
|
|
|
# FUNCTIONS
|
|
|
|
|
|
|
|
## HELP
|
|
|
|
usage() {
|
|
|
|
if [ "$*" != "" ] ; then
|
|
|
|
echo "Error: $*"
|
|
|
|
fi
|
|
|
|
|
|
|
|
cat << EOF
|
|
|
|
Usage: $PROGNAME [OPTION]
|
|
|
|
Simple and efficient local ad blocking throughout the network.
|
|
|
|
|
|
|
|
Options:
|
2020-01-03 10:17:00 +01:00
|
|
|
status Check if it's active or not
|
2020-01-03 08:16:42 +01:00
|
|
|
update Update the list of DNS to be blocked
|
|
|
|
start Activate blocking DNS.
|
|
|
|
stop Stop blocking DNS.
|
|
|
|
--help Display this usage message and exit
|
|
|
|
EOF
|
|
|
|
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
2020-01-03 10:17:00 +01:00
|
|
|
status() {
|
|
|
|
if grep -qF "$START_TAG" "$HOST_FILE";then
|
|
|
|
echo "${COLOR_GREEN}ENABLED${COLOR_RESET}"
|
|
|
|
else
|
|
|
|
echo "${COLOR_RED}DISABLED${COLOR_RESET}"
|
|
|
|
fi
|
|
|
|
}
|
2020-01-03 08:16:42 +01:00
|
|
|
|
|
|
|
update() {
|
2020-01-03 08:22:28 +01:00
|
|
|
# Make conf folder
|
2020-03-21 20:26:10 +01:00
|
|
|
rm -f $CONFIG$LIST
|
|
|
|
rm -f $CONFIG$LIST_DNSMASQ
|
2020-01-03 08:16:42 +01:00
|
|
|
mkdir -p $CONFIG
|
2020-01-03 08:22:28 +01:00
|
|
|
# Download DNS list
|
2020-03-21 20:26:10 +01:00
|
|
|
curl -L -s "https://pgl.yoyo.org/adservers/serverlist.php?showintro=0&mimetype=plaintext" -o "$CONFIG$LIST"
|
2020-01-03 08:22:28 +01:00
|
|
|
# Clear list
|
2020-01-03 17:17:54 +01:00
|
|
|
## Remove comments
|
2020-03-21 21:02:04 +01:00
|
|
|
custom-sed -i.bak '/^#/ d' "$CONFIG$LIST"
|
2020-01-04 08:32:22 +01:00
|
|
|
# Make dnsmasq format
|
|
|
|
## 127.0.0.1 doubleclick.net to address=/doubleclick.net/127.0.0.1
|
2020-03-21 20:26:10 +01:00
|
|
|
cp "$CONFIG$LIST" "$CONFIG$LIST_DNSMASQ"
|
2020-03-21 21:02:04 +01:00
|
|
|
custom-sed -i.bak 's/127.0.0.1 /address=\//g' "$CONFIG$LIST_DNSMASQ"
|
|
|
|
custom-sed -i.bak 's/$/\/127.0.0.1/g' "$CONFIG$LIST_DNSMASQ"
|
2020-01-03 09:50:01 +01:00
|
|
|
## Add start tag DNS list in first line
|
2020-03-21 21:02:04 +01:00
|
|
|
custom-sed -i.bak "1i\\$AUTHOR" "$CONFIG$LIST"
|
|
|
|
custom-sed -i.bak "1i\\$PROJECT" "$CONFIG$LIST"
|
|
|
|
custom-sed -i.bak "1i\\$START_TAG" "$CONFIG$LIST"
|
2020-01-03 09:50:01 +01:00
|
|
|
## Add end tag DNS list in first line
|
|
|
|
echo $END_TAG >> "$CONFIG/$LIST"
|
2020-01-04 08:32:22 +01:00
|
|
|
## Add start tag DNS dnsmasq in first line
|
2020-03-21 21:02:04 +01:00
|
|
|
custom-sed -i.bak "1i\\$AUTHOR" "$CONFIG$LIST_DNSMASQ"
|
|
|
|
custom-sed -i.bak "1i\\$PROJECT" "$CONFIG$LIST_DNSMASQ"
|
|
|
|
custom-sed -i.bak "1i\\$START_TAG" "$CONFIG$LIST_DNSMASQ"
|
2020-01-04 08:32:22 +01:00
|
|
|
## Add end tag DNS DNSMASQ in first line
|
2020-03-21 20:26:10 +01:00
|
|
|
echo $END_TAG >> "$CONFIG$LIST_DNSMASQ"
|
2020-01-04 08:32:22 +01:00
|
|
|
# Remove temp file
|
|
|
|
rm "$CONFIG$LIST.bak"
|
2020-01-04 08:38:33 +01:00
|
|
|
rm "$CONFIG$LIST_DNSMASQ.bak"
|
2020-01-03 09:50:01 +01:00
|
|
|
# Notify user
|
2020-01-04 08:38:33 +01:00
|
|
|
echo "${COLOR_GREEN}List updated!${COLOR_RESET}"
|
2020-01-03 10:17:00 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
start() {
|
2020-01-04 08:38:33 +01:00
|
|
|
update
|
2020-01-03 11:21:06 +01:00
|
|
|
# Add List to host file
|
2020-01-03 10:27:08 +01:00
|
|
|
cat "$CONFIG/$LIST" >> "$HOST_FILE"
|
2020-01-03 10:17:00 +01:00
|
|
|
# Notify user
|
|
|
|
echo "${COLOR_GREEN}ENABLED!${COLOR_RESET}"
|
|
|
|
}
|
|
|
|
|
|
|
|
stop() {
|
2020-01-03 11:21:06 +01:00
|
|
|
# Remove list to host file
|
2020-03-21 21:33:42 +01:00
|
|
|
custom-sed -i "/$START_TAG/,/$END_TAG/d" "$HOST_FILE"
|
2020-01-03 17:17:54 +01:00
|
|
|
|
2020-01-04 08:38:33 +01:00
|
|
|
# Remove DNSMASQ
|
2020-03-21 20:26:10 +01:00
|
|
|
cat /dev/null > $CONFIG$LIST_DNSMASQ
|
2020-01-03 11:21:06 +01:00
|
|
|
|
|
|
|
# Notify user
|
|
|
|
echo "${COLOR_GREEN}DISABLED!${COLOR_RESET}"
|
2020-01-03 08:16:42 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
# CONTROLE ARGUMENTS
|
|
|
|
isArg=""
|
|
|
|
|
|
|
|
while [ $# -gt 0 ] ; do
|
|
|
|
case "$1" in
|
|
|
|
--help)
|
|
|
|
usage
|
|
|
|
;;
|
2020-01-03 10:17:00 +01:00
|
|
|
status)
|
|
|
|
isArg="1"
|
|
|
|
status
|
|
|
|
;;
|
2020-01-03 08:16:42 +01:00
|
|
|
update)
|
|
|
|
isArg="1"
|
|
|
|
update
|
|
|
|
;;
|
|
|
|
start)
|
|
|
|
isArg="1"
|
2020-01-03 10:17:00 +01:00
|
|
|
start
|
2020-01-03 08:16:42 +01:00
|
|
|
;;
|
|
|
|
stop)
|
|
|
|
isArg="1"
|
2020-01-03 10:17:00 +01:00
|
|
|
stop
|
2020-01-03 08:16:42 +01:00
|
|
|
;;
|
|
|
|
*)
|
|
|
|
esac
|
|
|
|
shift
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ -z $isArg ] ; then
|
|
|
|
usage "Not enough arguments"
|
|
|
|
fi
|