mirror of
				https://github.com/uklans/cache-domains
				synced 2025-11-04 13:08:53 +01:00 
			
		
		
		
	Add unbound generation script
This commit is contained in:
		
							parent
							
								
									6ca6ceb48e
								
							
						
					
					
						commit
						de1ff26b53
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
										Normal file
									
								
							@ -0,0 +1 @@
 | 
				
			|||||||
 | 
					scripts/output
 | 
				
			||||||
							
								
								
									
										19
									
								
								scripts/config.example.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								scripts/config.example.json
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,19 @@
 | 
				
			|||||||
 | 
					{
 | 
				
			||||||
 | 
						"ips": {
 | 
				
			||||||
 | 
							"steam":	"10.10.3.11",
 | 
				
			||||||
 | 
							"origin":	"10.10.3.12",
 | 
				
			||||||
 | 
							"blizzard":	"10.10.3.13",
 | 
				
			||||||
 | 
							"windows":	"10.10.3.14",
 | 
				
			||||||
 | 
							"riot":		"10.10.3.15",
 | 
				
			||||||
 | 
							"generic":	"10.10.3.16"
 | 
				
			||||||
 | 
						},
 | 
				
			||||||
 | 
						"cache_domains": {
 | 
				
			||||||
 | 
							"default": 	"generic",
 | 
				
			||||||
 | 
							"blizzard": 	"blizzard",
 | 
				
			||||||
 | 
							"origin": 	"origin",
 | 
				
			||||||
 | 
							"riot": 	"riot",
 | 
				
			||||||
 | 
							"steam": 	"steam",
 | 
				
			||||||
 | 
							"wsus": 	"windows",
 | 
				
			||||||
 | 
							"xboxlive": 	"windows"
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										63
									
								
								scripts/create-unbound.sh
									
									
									
									
									
										Executable file
									
								
							
							
						
						
									
										63
									
								
								scripts/create-unbound.sh
									
									
									
									
									
										Executable file
									
								
							@ -0,0 +1,63 @@
 | 
				
			|||||||
 | 
					#!/bin/bash
 | 
				
			||||||
 | 
					basedir=".."
 | 
				
			||||||
 | 
					outputdir="output/unbound"
 | 
				
			||||||
 | 
					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 line; do 
 | 
				
			||||||
 | 
						ip=$(jq -r ".ips[\"${line}\"]" config.json)
 | 
				
			||||||
 | 
						declare "cacheip$line"="$ip"
 | 
				
			||||||
 | 
					done <<< $(jq -r '.ips | to_entries[] | .key' config.json)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					while read 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}
 | 
				
			||||||
 | 
					while read 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=${!cacheipname}
 | 
				
			||||||
 | 
						while read fileid; do
 | 
				
			||||||
 | 
							while read filename; do
 | 
				
			||||||
 | 
								destfilename=$(echo $filename | sed -e 's/txt/conf/')
 | 
				
			||||||
 | 
								outputfile=${outputdir}/${destfilename}
 | 
				
			||||||
 | 
								touch $outputfile
 | 
				
			||||||
 | 
								echo "server:" >> $outputfile
 | 
				
			||||||
 | 
								while read fileentry; do
 | 
				
			||||||
 | 
									# Ignore comments
 | 
				
			||||||
 | 
									if [[ $fileentry == \#* ]]; then
 | 
				
			||||||
 | 
										continue
 | 
				
			||||||
 | 
									fi
 | 
				
			||||||
 | 
									parsed=$(echo $fileentry | sed -e "s/^\*\.//")
 | 
				
			||||||
 | 
									if grep -q "$parsed" $outputfile; then
 | 
				
			||||||
 | 
										continue
 | 
				
			||||||
 | 
									fi
 | 
				
			||||||
 | 
									echo "  local-zone: \"${parsed}\" redirect" >> $outputfile
 | 
				
			||||||
 | 
									echo "  local-data: \"${parsed} 30 IN A ${cacheip}\"" >> $outputfile
 | 
				
			||||||
 | 
								done <<< $(cat ${basedir}/$filename);
 | 
				
			||||||
 | 
							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)
 | 
				
			||||||
		Loading…
	
		Reference in New Issue
	
	Block a user