mirror of
				https://github.com/uklans/cache-domains
				synced 2025-11-04 01:48:52 +01:00 
			
		
		
		
	Merge pull request #194 from NathanAdhitya/master
added AdGuard Home scripts
This commit is contained in:
		
						commit
						9157392408
					
				@ -7,6 +7,7 @@ configuration which can be utilised with:
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
* Dnsmasq
 | 
					* Dnsmasq
 | 
				
			||||||
* Unbound
 | 
					* Unbound
 | 
				
			||||||
 | 
					* AdGuard Home
 | 
				
			||||||
 | 
					
 | 
				
			||||||
## Usage
 | 
					## Usage
 | 
				
			||||||
 | 
					
 | 
				
			||||||
@ -40,3 +41,8 @@ configuration which can be utilised with:
 | 
				
			|||||||
**This also applies to users utilising the script alongside Pi-hole.**
 | 
					**This also applies to users utilising the script alongside Pi-hole.**
 | 
				
			||||||
 | 
					
 | 
				
			||||||
Multi-IP Lancache setups are only supported with Dnsmasq or Pi-hole versions >= 2.86 or 2021.09 respectively.
 | 
					Multi-IP Lancache setups are only supported with Dnsmasq or Pi-hole versions >= 2.86 or 2021.09 respectively.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					### Notes for AdGuard Home users
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					1. In the `config.json`, you may want to add an entry for your non-cached DNS upstreams. You can input this in `ip.adguardhome_upstream` as an array.
 | 
				
			||||||
 | 
					2. Once you have ran the script, you can point the upstream list to the text file generated. For example: `upstream_dns_file: "/root/cache-domains/scripts/output/adguardhome/cache-domains.txt"`
 | 
				
			||||||
@ -1,5 +1,6 @@
 | 
				
			|||||||
{
 | 
					{
 | 
				
			||||||
	"ips": {
 | 
						"ips": {
 | 
				
			||||||
 | 
							"adguardhome_upstream": ["94.140.14.140", "tls://dns.google", "https://dns.google/dns-query"],
 | 
				
			||||||
		"steam":	["10.10.3.10", "10.10.3.11"],
 | 
							"steam":	["10.10.3.10", "10.10.3.11"],
 | 
				
			||||||
		"origin":	"10.10.3.12",
 | 
							"origin":	"10.10.3.12",
 | 
				
			||||||
		"blizzard":	"10.10.3.13",
 | 
							"blizzard":	"10.10.3.13",
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										77
									
								
								scripts/create-adguardhome.sh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										77
									
								
								scripts/create-adguardhome.sh
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,77 @@
 | 
				
			|||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					basedir=".."
 | 
				
			||||||
 | 
					outputdir="output/adguardhome"
 | 
				
			||||||
 | 
					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)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					agh_upstreams=$(jq -r ".ips[\"adguardhome_upstream\"] | .[]" 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}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					# add upstreams
 | 
				
			||||||
 | 
					echo "${agh_upstreams}" >> "${outputdir}/cache-domains.txt"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					while read -r entry; do
 | 
				
			||||||
 | 
					        unset cacheip
 | 
				
			||||||
 | 
					        unset cachename
 | 
				
			||||||
 | 
					        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
 | 
				
			||||||
 | 
					                        destfilename="cache-domains.txt"  #$(echo $filename | sed -e 's/txt/conf/')
 | 
				
			||||||
 | 
					                        outputfile=${outputdir}/${destfilename}
 | 
				
			||||||
 | 
					                        touch ${outputfile}
 | 
				
			||||||
 | 
					                        while read -r fileentry; do
 | 
				
			||||||
 | 
					                                # Ignore comments, newlines and wildcards
 | 
				
			||||||
 | 
					                                if [[ ${fileentry} == \#* ]] || [[ -z ${fileentry} ]]; then
 | 
				
			||||||
 | 
					                                        continue
 | 
				
			||||||
 | 
					                                fi
 | 
				
			||||||
 | 
					                                parsed=$(echo ${fileentry} | sed -e "s/^\*\.//")
 | 
				
			||||||
 | 
					                                for i in ${cacheip}; do
 | 
				
			||||||
 | 
					                                        if grep -qx "\[/${parsed}/\]${i}" "${outputfile}"; then
 | 
				
			||||||
 | 
					                                                continue
 | 
				
			||||||
 | 
					                                        fi
 | 
				
			||||||
 | 
					                                        echo "[/${parsed}/]${i}" >> "${outputfile}"
 | 
				
			||||||
 | 
					                                done
 | 
				
			||||||
 | 
					                        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 point the setting upstream_dns_file in AdGuardHome.yaml to the generated file.
 | 
				
			||||||
 | 
					For example:
 | 
				
			||||||
 | 
					upstream_dns_file: "/root/cache-domains/scripts/output/adguardhome/cache-domains.txt"
 | 
				
			||||||
 | 
					EOF
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user