mirror of
https://github.com/pi-hole/pi-hole
synced 2025-01-18 03:50:56 +00:00
Improved code, ensure that gravity.sh passes shellcheck as a whole
Signed-off-by: DL6ER <dl6er@dl6er.de>
This commit is contained in:
parent
644ec36e64
commit
491c828661
17
gravity.sh
17
gravity.sh
@ -116,14 +116,15 @@ gravity_store_in_database() {
|
|||||||
gravity_Cleanup "error"
|
gravity_Cleanup "error"
|
||||||
fi
|
fi
|
||||||
|
|
||||||
local tmpFile=$(mktemp -p "/tmp" --suffix=".gravity")
|
local tmpFile
|
||||||
|
tmpFile="$(mktemp -p "/tmp" --suffix=".gravity")"
|
||||||
if [ "$table" == "whitelist" ] || [ "$table" == "blacklist" ] || [ "$table" == "regex" ]; then
|
if [ "$table" == "whitelist" ] || [ "$table" == "blacklist" ] || [ "$table" == "regex" ]; then
|
||||||
# Apply format for white-, blacklist, and regex tables, prevent globbing
|
# Apply format for white-, blacklist, and regex tables
|
||||||
set -f
|
# Read file line by line
|
||||||
for domain in $(cat < "${source}"); do
|
grep -v '^ *#' < "${source}" | while IFS= read -r domain
|
||||||
|
do
|
||||||
echo "\"${domain}\",1,$(date --utc +'%s')," >> "${tmpFile}"
|
echo "\"${domain}\",1,$(date --utc +'%s')," >> "${tmpFile}"
|
||||||
done
|
done
|
||||||
set +f
|
|
||||||
inputfile="${tmpFile}"
|
inputfile="${tmpFile}"
|
||||||
else
|
else
|
||||||
# No need to modify the input data for the gravity table
|
# No need to modify the input data for the gravity table
|
||||||
@ -132,7 +133,7 @@ gravity_store_in_database() {
|
|||||||
# Store domains in gravity database table ${table}
|
# Store domains in gravity database table ${table}
|
||||||
# Use printf as .mode and .import need to be on separate lines
|
# Use printf as .mode and .import need to be on separate lines
|
||||||
# see https://unix.stackexchange.com/a/445615/83260
|
# see https://unix.stackexchange.com/a/445615/83260
|
||||||
output=$( { printf ".mode csv\n.import \"${inputfile}\" ${table}\n" | sqlite3 "${gravityDBfile}"; } 2>&1 )
|
output=$( { printf ".mode csv\n.import \"%s\" ${table}\n" "${inputfile}" | sqlite3 "${gravityDBfile}"; } 2>&1 )
|
||||||
status="$?"
|
status="$?"
|
||||||
|
|
||||||
if [[ "${status}" -ne 0 ]]; then
|
if [[ "${status}" -ne 0 ]]; then
|
||||||
@ -412,10 +413,10 @@ gravity_ParseFileIntoDomains() {
|
|||||||
# Last awk command takes non-commented lines and if they have 2 fields, take the right field (the domain) and leave
|
# Last awk command takes non-commented lines and if they have 2 fields, take the right field (the domain) and leave
|
||||||
# the left (IP address), otherwise grab the single field.
|
# the left (IP address), otherwise grab the single field.
|
||||||
|
|
||||||
< ${source} awk -F '#' '{print $1}' | \
|
< "${source}" awk -F '#' '{print $1}' | \
|
||||||
awk -F '/' '{print $1}' | \
|
awk -F '/' '{print $1}' | \
|
||||||
awk '($1 !~ /^#/) { if (NF>1) {print $2} else {print $1}}' | \
|
awk '($1 !~ /^#/) { if (NF>1) {print $2} else {print $1}}' | \
|
||||||
sed -nr -e 's/\.{2,}/./g' -e '/\./p' > ${destination}
|
sed -nr -e 's/\.{2,}/./g' -e '/\./p' > "${destination}"
|
||||||
return 0
|
return 0
|
||||||
fi
|
fi
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user