annotate scripts/nameserver_autogen/bind_tld_zonefile_all.sh @ 1182:135e7c234e24 draft

updated them to have no out-of-zone data.
author epoch <epoch@hacking.allowed.ano>
date Mon, 06 Jul 2015 14:28:19 +0000
parents 44da84ec0c43
children dae39c508416
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
1170
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
1 #!/bin/bash
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
2 #made for bash. not sure if all /bin/sh work.
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
3 #be sure to edit these variables first.
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
4
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
5 #zonefiles are named after the TLD they're for.
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
6 #make sure not to clobber any files. ;)
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
7
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
8 #ZONEFILE_DIR=/etc/namedb
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
9 #RDNS_ZONEFILE=/etc/namedb/1.in-addr.arpa
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
10 #RESDB_PATH=/var/db/resdb
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
11
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
12 if [ ! "$ZONEFILE_DIR" ];then
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
13 echo "You forgot to set some variables. read the source plzkthx."
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
14 exit 0;
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
15 fi
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
16
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
17
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
18 echo -n "generating ipv4 reverse lookup zonefile for 1/8..."
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
19
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
20 echo "; this zonefile genreated on: `date`" > "$RDNS_ZONEFILE"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
21 echo '$TTL 3600' >> "$RDNS_ZONEFILE"
1182
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
22 echo '@ IN SOA @ root ('`date +" %Y%m%d%H"`' 60 300 3600000 3600 )' >> "$RDNS_ZONEFILE"
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
23 echo '@ IN NS @' >> "$RDNS_ZONEFILE"
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
24 echo '@ IN A 127.0.0.1' >> "$RDNS_ZONEFILE"
1170
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
25
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
26 for i in `ls ${RESDB_PATH}/db/ip/01/*/*/ns/*`;do
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
27 f=$(basename $i)
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
28 a=$(basename $(dirname $i))
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
29 b=$(basename $(dirname $(dirname $i)))
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
30 c=$(basename $(dirname $(dirname $(dirname $i))))
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
31 printf "%d.%d IN NS %s\n" $[0x${b}] $[0x${c}] ${f}.
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
32 done >> "$RDNS_ZONEFILE"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
33 echo done.
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
34
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
35 for GOHERE in ${RESDB_PATH}/db/dom/*;do
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
36
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
37 cd ${GOHERE}
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
38 TLD=$(basename ${GOHERE})
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
39 ANO_ZONEFILE=${ZONEFILE_DIR}/${TLD}
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
40 echo -n generating .${TLD} TLD zonefile...
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
41 echo "; this zonefile genreated on: `date`" > "$ANO_ZONEFILE"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
42 echo '$TTL 3600' >> "$ANO_ZONEFILE"
1182
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
43 echo '@ IN SOA @ root ('`date +" %Y%m%d%H"`' 60 300 3600000 3600 )' >> "$ANO_ZONEFILE"
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
44 echo '@ IN NS @' >> "$ANO_ZONEFILE"
135e7c234e24 updated them to have no out-of-zone data.
epoch <epoch@hacking.allowed.ano>
parents: 1170
diff changeset
45 echo '@ IN A 127.0.0.1' >> "$ANO_ZONEFILE"
1170
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
46
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
47 for name in *;do
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
48 if [ -e "${name}/ns/" ];then
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
49 for server in "$name"/ns/*;do
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
50 if grep '\.ano$' <<< "$name" > /dev/null;then
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
51 true
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
52 fi
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
53 if grep '\.ano$' <<< "$server" > /dev/null;then
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
54 true
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
55 fi
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
56 fqserver=`cut -d/ -f3- <<< $server`
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
57 echo -e "${name}\tIN NS\t${fqserver}."
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
58 for ip in `cat ${server}`;do
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
59 if grep ':' <<< "$ip" > /dev/null;then
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
60 echo -e "${fqserver}.\tIN AAAA\t$ip"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
61 else
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
62 echo -e "${fqserver}.\tIN A\t$ip"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
63 fi
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
64 done
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
65 done
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
66 fi
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
67 done >> "$ANO_ZONEFILE"
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
68 echo done with ${TLD}
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
69 done
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
70
44da84ec0c43 forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
epoch <epoch@hacking.allowed.ano>
parents:
diff changeset
71 echo might want to send a sighup to your named now.