Compare commits

...

4 Commits

Author SHA1 Message Date
Kevin Brierly
683b2bfb51
Merge 56a6d2f00f into 170c0905e4 2025-08-19 12:34:11 +03:00
Amir Zarrinkafsh
170c0905e4
fix: ability to use default cache in scripts (#274) 2025-08-16 21:05:58 +01:00
Kevin Brierly
56a6d2f00f
Update create-blocky.sh 2022-11-13 21:21:13 -06:00
Kevin Brierly
dec3811066
Create create-blocky.sh
Add create script for blocky custom dns yaml configuration
2022-11-13 20:54:52 -06:00
7 changed files with 95 additions and 13 deletions

View File

@ -11,4 +11,5 @@ insert_final_newline = true
indent_size = 0 indent_size = 0
[*.sh] [*.sh]
indent_style = tab indent_style = tab

View File

@ -13,7 +13,6 @@ if ! command -v jq >/dev/null; then
exit 1 exit 1
fi fi
cachenamedefault="disabled"
combinedoutput=$(jq -r ".combined_output" config.json) combinedoutput=$(jq -r ".combined_output" config.json)
while read -r line; do while read -r line; do
@ -34,7 +33,7 @@ while read -r entry; do
key=$(jq -r ".cache_domains[$entry].name" ${path}) key=$(jq -r ".cache_domains[$entry].name" ${path})
cachename="cachename${key}" cachename="cachename${key}"
if [ -z "${!cachename}" ]; then if [ -z "${!cachename}" ]; then
cachename=${cachenamedefault} cachename="cachenamedefault"
fi fi
if [[ ${cachename} == "disabled" ]]; then if [[ ${cachename} == "disabled" ]]; then
continue continue

88
scripts/create-blocky.sh Normal file
View File

@ -0,0 +1,88 @@
#!/bin/bash
basedir=".."
outputdir="output/blocky"
path="${basedir}/cache_domains.json"
export IFS=' '
test=$(which jq);
out=$?
if [ $out -gt 0 ] ; then
echo "This script requires jq to be installed."
echo "Your package manager should be able to find it"
exit 1
fi
cachenamedefault="disabled"
while read -r line; do
ip=$(jq ".ips[\"${line}\"]" config.json)
declare "cacheip${line}"="${ip}"
done <<< $(jq -r '.ips | to_entries[] | .key' config.json)
while read -r line; do
name=$(jq -r ".cache_domains[\"${line}\"]" config.json)
declare "cachename${line}"="${name}"
done <<< $(jq -r '.cache_domains | to_entries[] | .key' config.json)
rm -rf ${outputdir}
mkdir -p ${outputdir}
outputfile=${outputdir}/custom_dns.yml
cat > $outputfile << EOF
customDNS:
customTTL: 1h
filterUnmappedTypes: true
mapping:
EOF
while read -r entry; do
unset cacheip
unset cachename
unset cacheip_count
unset ciplist
key=$(jq -r ".cache_domains[$entry].name" $path)
cachename="cachename${key}"
if [ -z "${!cachename}" ]; then
cachename="cachenamedefault"
fi
if [[ ${!cachename} == "disabled" ]]; then
continue;
fi
cacheipname="cacheip${!cachename}"
cacheip=$(jq -r 'if type == "array" then .[] else . end' <<< ${!cacheipname} | xargs)
while read -r fileid; do
while read -r filename; do
while read -r fileentry; do
# Ignore comments, newlines and wildcards
if [[ ${fileentry} == \#* ]] || [[ -z ${fileentry} ]]; then
continue
fi
parsed=$(echo ${fileentry} | sed -e "s/^\*\.//")
cacheip_count=1
for i in ${cacheip}; do
if [ $cacheip_count -gt 1 ]
then
ciplist="${ciplist}, ${i}"
else
ciplist="${i}"
fi
cacheip_count=$((cacheip_count+1))
done
if grep -qx " ${parsed}: ${ciplist}" "${outputfile}"; then
continue
fi
echo " ${parsed}: ${ciplist}" >> "${outputfile}"
done <<< $(cat ${basedir}/${filename} | sort);
done <<< $(jq -r ".cache_domains[${entry}].domain_files[$fileid]" ${path})
done <<< $(jq -r ".cache_domains[${entry}].domain_files | to_entries[] | .key" ${path})
done <<< $(jq -r '.cache_domains | to_entries[] | .key' ${path})
cat << EOF
Configuration generation completed.
Please copy output/blocky/custom_dns.yml to your blocky config directory, or integrate
it into your main config.yml
EOF

View File

@ -13,7 +13,6 @@ if ! command -v jq >/dev/null; then
exit 1 exit 1
fi fi
cachenamedefault="disabled"
combinedoutput=$(jq -r ".combined_output" config.json) combinedoutput=$(jq -r ".combined_output" config.json)
while read -r line; do while read -r line; do
@ -34,7 +33,7 @@ while read -r entry; do
key=$(jq -r ".cache_domains[${entry}].name" ${path}) key=$(jq -r ".cache_domains[${entry}].name" ${path})
cachename="cachename${key}" cachename="cachename${key}"
if [ -z "${!cachename}" ]; then if [ -z "${!cachename}" ]; then
cachename=${cachenamedefault} cachename="cachenamedefault"
fi fi
if [[ ${cachename} == "disabled" ]]; then if [[ ${cachename} == "disabled" ]]; then
continue continue

View File

@ -14,8 +14,6 @@ if ! command -v jq >/dev/null; then
exit 1 exit 1
fi fi
cachenamedefault="disabled"
while read -r line; do while read -r line; do
ip=$(jq ".ips[\"${line}\"]" config.json) ip=$(jq ".ips[\"${line}\"]" config.json)
declare "cacheip${line}"="${ip}" declare "cacheip${line}"="${ip}"
@ -50,7 +48,7 @@ while read -r entry; do
key=$(jq -r ".cache_domains[${entry}].name" ${path}) key=$(jq -r ".cache_domains[${entry}].name" ${path})
cachename="cachename${key}" cachename="cachename${key}"
if [ -z "${!cachename}" ]; then if [ -z "${!cachename}" ]; then
cachename=${cachenamedefault} cachename="cachenamedefault"
fi fi
if [[ ${cachename} == "disabled" ]]; then if [[ ${cachename} == "disabled" ]]; then
continue continue

View File

@ -14,8 +14,6 @@ if ! command -v jq >/dev/null; then
exit 1 exit 1
fi fi
cachenamedefault="disabled"
while read -r line; do while read -r line; do
name=$(jq -r ".cache_domains[\"${line}\"]" config.json) name=$(jq -r ".cache_domains[\"${line}\"]" config.json)
declare "cachename${line}"="${name}" declare "cachename${line}"="${name}"
@ -28,7 +26,7 @@ while read -r entry; do
key=$(jq -r ".cache_domains[$entry].name" ${path}) key=$(jq -r ".cache_domains[$entry].name" ${path})
cachename="cachename${key}" cachename="cachename${key}"
if [ -z "${!cachename}" ]; then if [ -z "${!cachename}" ]; then
cachename=${cachenamedefault} cachename="cachenamedefault"
fi fi
if [[ ${cachename} == "disabled" ]]; then if [[ ${cachename} == "disabled" ]]; then
continue continue

View File

@ -13,7 +13,6 @@ if ! command -v jq >/dev/null; then
exit 1 exit 1
fi fi
cachenamedefault="disabled"
combinedoutput=$(jq -r ".combined_output" config.json) combinedoutput=$(jq -r ".combined_output" config.json)
while read -r line; do while read -r line; do
@ -34,7 +33,7 @@ while read -r entry; do
key=$(jq -r ".cache_domains[${entry}].name" ${path}) key=$(jq -r ".cache_domains[${entry}].name" ${path})
cachename="cachename${key}" cachename="cachename${key}"
if [ -z "${!cachename}" ]; then if [ -z "${!cachename}" ]; then
cachename=${cachenamedefault} cachename="cachenamedefault"
fi fi
if [[ ${cachename} == "disabled" ]]; then if [[ ${cachename} == "disabled" ]]; then
continue continue