Mercurial > hg > anonet-resdb
changeset 1170:44da84ec0c43 draft
forked bind_told_zonefile.sh to do all TLDs in resdb instead of just ano.
author | epoch <epoch@hacking.allowed.ano> |
---|---|
date | Thu, 17 Jul 2014 04:20:09 +0000 |
parents | 474071fa6e61 |
children | 19953e9f422e |
files | scripts/nameserver_autogen/bind_tld_zonefile_all.sh |
diffstat | 1 files changed, 71 insertions(+), 0 deletions(-) [+] |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/scripts/nameserver_autogen/bind_tld_zonefile_all.sh Thu Jul 17 04:20:09 2014 +0000 @@ -0,0 +1,71 @@ +#!/bin/bash +#made for bash. not sure if all /bin/sh work. +#be sure to edit these variables first. + +#zonefiles are named after the TLD they're for. +#make sure not to clobber any files. ;) + +#ZONEFILE_DIR=/etc/namedb +#RDNS_ZONEFILE=/etc/namedb/1.in-addr.arpa +#RESDB_PATH=/var/db/resdb + +if [ ! "$ZONEFILE_DIR" ];then + echo "You forgot to set some variables. read the source plzkthx." + exit 0; +fi + + +echo -n "generating ipv4 reverse lookup zonefile for 1/8..." + +echo "; this zonefile genreated on: `date`" > "$RDNS_ZONEFILE" +echo '$TTL 3600' >> "$RDNS_ZONEFILE" +echo '@ IN SOA localhost. root.localhost. ('`date +" %Y%m%d%H"`' 60 300 3600000 3600 )' >> "$RDNS_ZONEFILE" +echo '@ IN NS localhost.' >> "$RDNS_ZONEFILE" +echo 'localhost. IN A 127.0.0.1' >> "$RDNS_ZONEFILE" + +for i in `ls ${RESDB_PATH}/db/ip/01/*/*/ns/*`;do + f=$(basename $i) + a=$(basename $(dirname $i)) + b=$(basename $(dirname $(dirname $i))) + c=$(basename $(dirname $(dirname $(dirname $i)))) + printf "%d.%d IN NS %s\n" $[0x${b}] $[0x${c}] ${f}. +done >> "$RDNS_ZONEFILE" +echo done. + +for GOHERE in ${RESDB_PATH}/db/dom/*;do + + cd ${GOHERE} + TLD=$(basename ${GOHERE}) + ANO_ZONEFILE=${ZONEFILE_DIR}/${TLD} + echo -n generating .${TLD} TLD zonefile... + echo "; this zonefile genreated on: `date`" > "$ANO_ZONEFILE" + echo '$TTL 3600' >> "$ANO_ZONEFILE" + echo '@ IN SOA localhost. root.localhost. ('`date +" %Y%m%d%H"`' 60 300 3600000 3600 )' >> "$ANO_ZONEFILE" + echo '@ IN NS localhost.' >> "$ANO_ZONEFILE" + echo 'localhost. IN A 127.0.0.1' >> "$ANO_ZONEFILE" + + for name in *;do + if [ -e "${name}/ns/" ];then + for server in "$name"/ns/*;do + if grep '\.ano$' <<< "$name" > /dev/null;then + true + fi + if grep '\.ano$' <<< "$server" > /dev/null;then + true + fi + fqserver=`cut -d/ -f3- <<< $server` + echo -e "${name}\tIN NS\t${fqserver}." + for ip in `cat ${server}`;do + if grep ':' <<< "$ip" > /dev/null;then + echo -e "${fqserver}.\tIN AAAA\t$ip" + else + echo -e "${fqserver}.\tIN A\t$ip" + fi + done + done + fi + done >> "$ANO_ZONEFILE" + echo done with ${TLD} +done + +echo might want to send a sighup to your named now.