mirror of
https://github.com/pi-hole/pi-hole.git
synced 2025-01-12 06:54:53 +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:
parent
a1f120b2ff
commit
d0de5fda30
1 changed files with 25 additions and 11 deletions
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue