1
0
mirror of https://github.com/pi-hole/pi-hole synced 2025-01-18 12:00:55 +00:00

Simplify removal of domain from one list when it is requested for another

Signed-off-by: Adam Warner <me@adamwarner.co.uk>
This commit is contained in:
Adam Warner 2019-11-30 13:13:26 +00:00
parent a1f120b2ff
commit d0de5fda30
No known key found for this signature in database
GPG Key ID: 872950F3ECF2B173

View File

@ -39,6 +39,18 @@ getTypeID() {
fi fi
} }
getListnameFromType() {
if [[ "$1" == "0" ]]; then
echo "whitelist"
elif [[ "$1" == "1" ]]; then
echo "blacklist"
elif [[ "$1" == "2" ]]; then
echo "regex_whitelist"
elif [[ "$1" == "3" ]]; then
echo "regex_blacklist"
fi
}
helpFunc() { helpFunc() {
if [[ "${listType}" == "whitelist" ]]; then if [[ "${listType}" == "whitelist" ]]; then
param="w" param="w"
@ -105,19 +117,15 @@ HandleOther() {
} }
ProcessDomainList() { ProcessDomainList() {
local is_regexlist
if [[ "${listType}" == "regex_blacklist" ]]; then if [[ "${listType}" == "regex_blacklist" ]]; then
# Regex black filter list # Regex black filter list
listname="regex blacklist filters" listname="regex blacklist filters"
is_regexlist=true
elif [[ "${listType}" == "regex_whitelist" ]]; then elif [[ "${listType}" == "regex_whitelist" ]]; then
# Regex white filter list # Regex white filter list
listname="regex whitelist filters" listname="regex whitelist filters"
is_regexlist=true
else else
# Whitelist / Blacklist # Whitelist / Blacklist
listname="${listType}" listname="${listType}"
is_regexlist=false
fi fi
for dom in "${domList[@]}"; do for dom in "${domList[@]}"; do
@ -130,9 +138,6 @@ ProcessDomainList() {
# if delmode then remove from desired list but do not add to the other # if delmode then remove from desired list but do not add to the other
if ${addmode}; then if ${addmode}; then
AddDomain "${dom}" "${listType}" AddDomain "${dom}" "${listType}"
if ! ${is_regexlist}; then
RemoveDomain "${dom}" "${listAlt}"
fi
else else
RemoveDomain "${dom}" "${listType}" RemoveDomain "${dom}" "${listType}"
fi fi
@ -140,18 +145,27 @@ ProcessDomainList() {
} }
AddDomain() { AddDomain() {
local domain list num typeID local domain list num currTypeID currListName typeID
# Use printf to escape domain. %q prints the argument in a form that can be reused as shell input # Use printf to escape domain. %q prints the argument in a form that can be reused as shell input
domain="$1" domain="$1"
list="$2" list="$2"
typeID="$(getTypeID "${list}")" typeID="$(getTypeID "${list}")"
# Is the domain in the list we want to add it to? # Is the domain in the list we want to add it to?
num="$(sqlite3 "${gravityDBfile}" "SELECT COUNT(*) FROM domainlist WHERE domain = '${domain}' AND type = ${typeID};")" num="$(sqlite3 "${gravityDBfile}" "SELECT COUNT(*) FROM domainlist WHERE domain = '${domain}';")"
if [[ "${num}" -ne 0 ]]; then if [[ "${num}" -ne 0 ]]; then
if [[ "${verbose}" == true ]]; then currTypeID="$(sqlite3 "${gravityDBfile}" "SELECT type FROM domainlist WHERE domain = '${domain}';")"
echo -e " ${INFO} ${1} already exists in ${listname}, no need to add!" if [[ "${currTypeID}" == "${typeID}" ]]; then
if [[ "${verbose}" == true ]]; then
echo -e " ${INFO} ${1} already exists in ${listname}, no need to add!"
fi
else
currListName="$(getListnameFromType "${currTypeID}")"
sqlite3 "${gravityDBfile}" "UPDATE domainlist SET type = ${typeID} WHERE domain='${domain}';"
if [[ "${verbose}" == true ]]; then
echo -e " ${INFO} ${1} already exists in ${currListName}, it has been updated to the requested list type."
fi
fi fi
return return
fi fi