mirror of
https://github.com/pi-hole/pi-hole.git
synced 2025-01-12 06:54:53 +00:00
Invert logic to use ENABLED instead of DISABLED. We make sure to set "enabled = 1 WHERE enabled IS NULL" in gravity_store_in_database()
Signed-off-by: DL6ER <dl6er@dl6er.de>
This commit is contained in:
parent
b2f4385232
commit
dbbf21071b
3 changed files with 25 additions and 25 deletions
|
@ -1,21 +0,0 @@
|
||||||
CREATE TABLE whitelist (domain TEXT UNIQUE NOT NULL, disabled BOOLEAN DEFAULT 0, comment TEXT, DateAdded DATETIME);
|
|
||||||
CREATE TABLE blacklist (domain TEXT UNIQUE NOT NULL, disabled BOOLEAN DEFAULT 0, comment TEXT, DateAdded DATETIME);
|
|
||||||
CREATE TABLE regex (domain TEXT UNIQUE NOT NULL, disabled BOOLEAN DEFAULT 0, comment TEXT, DateAdded DATETIME);
|
|
||||||
CREATE TABLE gravity (domain TEXT UNIQUE NOT NULL);
|
|
||||||
|
|
||||||
CREATE VIEW vw_gravity AS SELECT DISTINCT a.domain
|
|
||||||
FROM gravity a
|
|
||||||
WHERE a.domain NOT IN (SELECT domain from whitelist WHERE disabled != 1);
|
|
||||||
|
|
||||||
CREATE VIEW vw_blacklist AS SELECT DISTINCT a.domain
|
|
||||||
FROM blacklist a
|
|
||||||
WHERE a.disabled != 1 AND
|
|
||||||
a.domain NOT IN (SELECT domain from whitelist WHERE disabled != 1);
|
|
||||||
|
|
||||||
CREATE VIEW vw_whitelist AS SELECT DISTINCT a.domain
|
|
||||||
FROM whitelist a
|
|
||||||
WHERE a.disabled != 1;
|
|
||||||
|
|
||||||
CREATE VIEW vw_regex AS SELECT DISTINCT a.domain
|
|
||||||
FROM regex a
|
|
||||||
WHERE a.disabled != 1;
|
|
21
advanced/Templates/gravity.db.sql
Normal file
21
advanced/Templates/gravity.db.sql
Normal file
|
@ -0,0 +1,21 @@
|
||||||
|
CREATE TABLE whitelist (domain TEXT UNIQUE NOT NULL, enabled BOOLEAN DEFAULT 1, comment TEXT, DateAdded DATETIME);
|
||||||
|
CREATE TABLE blacklist (domain TEXT UNIQUE NOT NULL, enabled BOOLEAN DEFAULT 1, comment TEXT, DateAdded DATETIME);
|
||||||
|
CREATE TABLE regex (domain TEXT UNIQUE NOT NULL, enabled BOOLEAN DEFAULT 1, comment TEXT, DateAdded DATETIME);
|
||||||
|
CREATE TABLE gravity (domain TEXT UNIQUE NOT NULL);
|
||||||
|
|
||||||
|
CREATE VIEW vw_gravity AS SELECT DISTINCT a.domain
|
||||||
|
FROM gravity a
|
||||||
|
WHERE a.domain NOT IN (SELECT domain from whitelist WHERE enabled == 1);
|
||||||
|
|
||||||
|
CREATE VIEW vw_blacklist AS SELECT DISTINCT a.domain
|
||||||
|
FROM blacklist a
|
||||||
|
WHERE a.enabled == 1 AND
|
||||||
|
a.domain NOT IN (SELECT domain from whitelist WHERE enabled == 1);
|
||||||
|
|
||||||
|
CREATE VIEW vw_whitelist AS SELECT DISTINCT a.domain
|
||||||
|
FROM whitelist a
|
||||||
|
WHERE a.enabled == 1;
|
||||||
|
|
||||||
|
CREATE VIEW vw_regex AS SELECT DISTINCT a.domain
|
||||||
|
FROM regex a
|
||||||
|
WHERE a.enabled == 1;
|
|
@ -38,7 +38,7 @@ VPNList="/etc/openvpn/ipp.txt"
|
||||||
|
|
||||||
piholeGitDir="/etc/.pihole"
|
piholeGitDir="/etc/.pihole"
|
||||||
gravityDBfile="${piholeDir}/gravity.db"
|
gravityDBfile="${piholeDir}/gravity.db"
|
||||||
gravityDBschema="${piholeGitDir}/advanced/Templates/gravity.db.schema"
|
gravityDBschema="${piholeGitDir}/advanced/Templates/gravity.db.sql"
|
||||||
optimize_database=false
|
optimize_database=false
|
||||||
|
|
||||||
domainsExtension="domains"
|
domainsExtension="domains"
|
||||||
|
@ -123,12 +123,12 @@ gravity_store_in_database() {
|
||||||
fi
|
fi
|
||||||
|
|
||||||
if [ "$table" == "whitelist" ] || [ "$table" == "blacklist" ] || [ "$table" == "regex" ]; then
|
if [ "$table" == "whitelist" ] || [ "$table" == "blacklist" ] || [ "$table" == "regex" ]; then
|
||||||
# Set disabled to false
|
# Set enabled to true where it is unspecified
|
||||||
output=$( { sqlite3 "${gravityDBfile}" <<< "UPDATE ${table} SET disabled = 0 WHERE disabled IS NULL;"; } 2>&1 )
|
output=$( { sqlite3 "${gravityDBfile}" <<< "UPDATE ${table} SET enabled = 1 WHERE enabled IS NULL;"; } 2>&1 )
|
||||||
status="$?"
|
status="$?"
|
||||||
|
|
||||||
if [[ "${status}" -ne 0 ]]; then
|
if [[ "${status}" -ne 0 ]]; then
|
||||||
echo -e "\\n ${CROSS} Unable to set disabled states (${table}) in database ${gravityDBfile}\\n ${output}"
|
echo -e "\\n ${CROSS} Unable to set enabled states (${table}) in database ${gravityDBfile}\\n ${output}"
|
||||||
gravity_Cleanup "error"
|
gravity_Cleanup "error"
|
||||||
fi
|
fi
|
||||||
fi
|
fi
|
||||||
|
|
Loading…
Reference in a new issue