-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathupdate-rdnszone.sh
executable file
·94 lines (78 loc) · 2.53 KB
/
update-rdnszone.sh
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
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
#!/bin/sh
. ./dns-functions.sh
ReverseDomain="$1"
ReverseZone="${ReverseDomain%*.}"
ForwardZones="$2"
ReverseZoneFile="$3"
TempDir="/tmp/""$ReverseZone"
TTL="${4%% *}"
ReReExMi="${4#* }"
View="$5"
GetIPEntries() {
if [ -z "$RZoneIsIPv6" ]; then
IPPattern="[aA]\s\+\([0-9\.]\+\)"
else
IPPattern="[aA]\{4\}\s\+\([0-9a-f:]\+\)"
fi
sed -ne "s/^\s*\(\S\+\)\s\+\([0-9]*\s\)\?\s*[Ii][Nn]\s\+""$IPPattern"".*/\1\/\3/p" "$1"
}
ReverseEntry() {
if [ -z "$RZoneIsIPv6" ]; then
GetReverseDomains "$1""/32"
else
GetReverseDomains "$1""/128"
fi
}
if [ -z "${ReverseDomain##*.in-addr.arpa.}" ]; then
RZoneIsIPv6=""
elif [ -z "${ReverseDomain##*.ip6.arpa.}" ]; then
RZoneIsIPv6=1
else
TraceErrAndExit "$ReverseDomain"" is no valid reverse domain"
fi
mkdir -p "$TempDir"
for ForwardZone in $ForwardZones; do
ZoneFile="${ForwardZone#*/}"
Serial="$(GetZoneFileSerial "$ZoneFile")"
NewReverseSerial=$((Serial + NewReverseSerial))
done
OldSerial="$(GetZoneFileSerial "$ReverseZoneFile")"
if [ $((NewReverseSerial)) -gt $((OldSerial)) ]; then
{
echo "$ReverseDomain $TTL IN SOA $DNSSCRIPT_SERVER_NAME""."" $DNSSCRIPT_CONTACT_EMAIL $NewReverseSerial $ReReExMi"
echo "$ReverseDomain $TTL IN NS $DNSSCRIPT_SERVER_NAME""."""
Static="/""$ReverseZoneFile"
Static="${Static%/*}""/static.""${Static##*/}"
Static="${Static#*/}"
[ -f "$Static" ] && echo "$(cat "$Static")"
echo
} > "$TempDir/$ReverseZone"
for ForwardZone in $ForwardZones; do
ZoneName="${ForwardZone%%/*}"
ZoneFile="${ForwardZone#*/}"
ZoneRevNSSubnets="$(sed -ne 's/^\s*\S\+\s\+\([0-9]*\s\)\?\s*[Ii][Nn]\s\+[Nn][Ss]\s\+\(\S\+\).*;\s*Subnets:\s*\([^;]*\)\s*\(;[^;]*\s*\)$/\2@\3/p' "$ZoneFile" |
sed -e 's/\(.*[^\.]\)@/\1\.'"$ZoneName"'\.@/;s/@/ /;s/\s\+/@/g')"
for NSSubnets in $ZoneRevNSSubnets; do
Subnets="$(echo "${NSSubnets#*@}" | sed -e 's/@/ /g')"
for Subnet in $Subnets; do
for ReverseNS in $(GetReverseDomains "$Subnet"); do
if [ -n "$ReverseNS" ] && [ -z "${ReverseNS##*$ReverseDomain}" ]; then
echo "$ReverseNS $TTL IN NS ${NSSubnets%%@*}" >> "$TempDir/$ReverseZone"
fi
done
done
done
IPEntries="$(GetIPEntries "$ZoneFile")"
for IPEntry in $IPEntries; do
IP="${IPEntry#*/}"
IP="$(ReverseEntry "$IP")"
if [ -z "${IP##*$ReverseDomain}" ]; then
Host="$(ExpandHostname "${IPEntry%%/*}" "$ZoneName"".")"
echo "$IP $TTL IN PTR $Host" >> "$TempDir/$ReverseZone"
fi
done
done
named-checkzone -o "$ReverseZoneFile" "$ReverseDomain" "$TempDir/$ReverseZone" >/dev/null
ReloadZone "$ReverseDomain" "$View"
fi
rm -r "$TempDir"