aboutsummaryrefslogtreecommitdiffstats
path: root/main/dns-root-hints/update-dns-root-hints
blob: 55f3dc77f960eb855451e38c998c7e4950b18c85 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
#!/bin/sh

url=https://www.internic.net/domain
base_dir=/usr/share/dns-root-hints
_tmp=$(mktemp -d -p .)

if [ $(id -u) != "0" ]; then
	echo "Needs to run as root."
	exit 1
fi

_check_sig() {
	local GNUPGHOME="$HOME/.gpg"
	install -d -m 0700 "$GNUPGHOME"
	gpg --import < $base_dir/verisign-grs-nstld-key.asc
	gpg --verify "${_tmp}/named.root.sig" "${_tmp}/named.root"
}

for file in named.root named.root.sig; do
	curl -sLR ${url}/${file} -o "${_tmp}/${file}" || exit 1
done

# compare new and current versions
_drh_new_ver=$(grep "related version of root zone:" ${_tmp}/named.root | egrep -o '[0-9]{10}')
_drh_current_ver=$(grep "related version of root zone:" $base_dir/named.root | egrep -o '[0-9]{10}')

# update to new version if needed
echo "Version $_drh_current_ver <- Installed"
echo "Version $_drh_new_ver <- Downloaded"

if [ "$_drh_new_ver" != "$_drh_current_ver" ]; then
	_check_sig || exit 1
	mv ${_tmp}/named.root $base_dir/named.root || exit 1
	mv ${_tmp}/named.root.sig $base_dir/named.root.sig || exit 1
	echo -e "\nZone file updated.\n"
else
	echo -e "\nZone file already up-to-date.\n"
fi

# cleanup
rm "${_tmp}"/* 2>/dev/null || true
rmdir "${_tmp}" 2>/dev/null || true