2011-01-26 17:18:56 +00:00
#!/bin/bash
# dns.sh next-gen by Fufroma
2011-01-28 15:55:26 +00:00
# Init some vars
2011-01-26 17:18:56 +00:00
. /etc/alternc/local.sh
2011-01-28 15:55:26 +00:00
. /usr/lib/alternc/functions.sh
2011-01-26 17:18:56 +00:00
# Init some other vars
ZONE_TEMPLATE = "/etc/alternc/templates/bind/templates/zone.template"
2011-01-28 15:55:26 +00:00
NAMED_TEMPLATE = "/etc/alternc/templates/bind/templates/named.template"
2013-02-18 15:52:47 +00:00
NAMED_CONF = "/var/lib/alternc/bind/automatic.conf"
2013-02-21 09:54:35 +00:00
RNDC = "/usr/sbin/rndc"
2011-01-26 17:18:56 +00:00
dns_zone_file( ) {
2013-02-18 15:52:47 +00:00
echo " /var/lib/alternc/bind/zones/ $1 "
2011-01-26 17:18:56 +00:00
}
dns_is_locked( ) {
local domain = $1
2011-01-28 15:55:26 +00:00
if [ ! -r " $( dns_zone_file $domain ) " ] ; then
return 1
fi
grep "LOCKED:YES" " $( dns_zone_file $domain ) "
2011-01-26 17:18:56 +00:00
return $?
}
dns_get_serial( ) {
local domain = $1
local serial = $(( $( grep "; serial" $( dns_zone_file $domain ) 2>/dev/null| awk '{ print $1;}' ) + 1 ))
local serial2 = $( date +%Y%m%d00)
if [ $serial -gt $serial2 ] ; then
echo $serial
else
echo $serial2
fi
}
2013-07-04 08:26:19 +00:00
dns_get_zonettl( ) {
local domain = $1
local zonettl = $(
$MYSQL_DO " SELECT zonettl FROM domaines d WHERE d.domaine=' $domain '; "
)
# default value
if [ " $zonettl " = = "" ] ; then
zonettl = "86400"
fi
if [ " $zonettl " -eq "0" ] ; then
zonettl = "86400"
fi
echo $zonettl
}
2011-01-26 17:18:56 +00:00
dns_chmod( ) {
local domain = $1
chgrp bind $( dns_zone_file $domain )
chmod 640 $( dns_zone_file $domain )
return 0
}
2011-01-28 15:55:26 +00:00
dns_named_conf( ) {
local domain = $1
if [ ! -f " $( dns_zone_file $domain ) " ] ; then
echo Error : no file $( dns_zone_file $domain )
return 1
fi
2011-10-18 18:25:47 +00:00
# Add the entry
2011-09-02 15:59:25 +00:00
grep -q " \" $domain \" " " $NAMED_CONF "
2011-01-28 15:55:26 +00:00
if [ $? -ne 0 ] ; then
local tempo = $( cat " $NAMED_TEMPLATE " )
tempo = ${ tempo /@@DOMAINE@@/ $domain }
tempo = ${ tempo /@@ZONE_FILE@@/ $( dns_zone_file $domain ) }
echo $tempo >> " $NAMED_CONF "
2013-08-22 06:13:33 +00:00
# Kindly ask Bind to reload its configuration
# (the zone file is already created and populated)
2013-02-21 09:54:35 +00:00
$RNDC reconfig
# Hook it !
run-parts --arg= dns_reconfig /usr/lib/alternc/reload.d
2011-01-28 15:55:26 +00:00
fi
2011-10-18 18:25:47 +00:00
2011-01-28 15:55:26 +00:00
}
dns_delete( ) {
local domain = $1
# Delete the zone file
2013-02-21 09:54:35 +00:00
if [ -w " $( dns_zone_file $domain ) " ] ; then
rm -f " $( dns_zone_file $domain ) "
2011-01-28 15:55:26 +00:00
fi
# Remove from the named conf
local file = $( cat " $NAMED_CONF " )
echo -e " $file " | grep -v " \" $domain \" " > " $NAMED_CONF "
2011-10-18 18:25:47 +00:00
2013-08-22 06:13:33 +00:00
# Ask the dns server for restart
2013-02-21 09:54:35 +00:00
$RNDC reconfig
# Hook it !
run-parts --arg= dns_reconfig /usr/lib/alternc/reload.d
2011-01-28 15:55:26 +00:00
}
2011-01-26 17:18:56 +00:00
# DNS regenerate
dns_regenerate( ) {
local domain = $1
local manual_tag = ";;; END ALTERNC AUTOGENERATE CONFIGURATION"
local zone_file = $( dns_zone_file $domain )
2011-01-28 15:55:26 +00:00
# Check if locked
2011-01-26 17:18:56 +00:00
dns_is_locked " $domain "
if [ $? -eq 0 ] ; then
echo " DNS $domain LOCKED "
return 1
fi
# Get the serial number if there is one
local serial = $( dns_get_serial " $domain " )
2013-07-04 08:26:19 +00:00
# Get the zone ttl
local zonettl = $( dns_get_zonettl " $domain " )
2011-01-26 17:18:56 +00:00
# Generate the headers with the template
local file = $( cat " $ZONE_TEMPLATE " )
# Add the entry
file = $(
echo -e " $file "
2011-01-29 17:58:19 +00:00
$MYSQL_DO " select distinct replace(replace(dt.entry,'%TARGET%',sd.valeur), '%SUB%', if(length(sd.sub)>0,sd.sub,'@')) as entry from sub_domaines sd,domaines_type dt where sd.type=dt.name and sd.domaine=' $domain ' and sd.enable in ('ENABLE', 'ENABLED') order by entry ; "
2011-01-26 17:18:56 +00:00
)
2013-08-22 06:13:33 +00:00
##### Mail autodetect for thunderbird / outlook - START
# If $file contain DEFAULT_MX
2013-07-22 16:37:44 +00:00
if [ ! -z " $( echo -e " $file " | egrep 'DEFAULT_MX' ) " ] ; then
2013-08-22 06:13:33 +00:00
# If $file ! contain autoconfig -> add entry
2013-07-22 16:37:44 +00:00
if [ -z " $( echo -e " $file " | egrep '^autoconfig' ) " ] ; then
file = " $( echo -e " $file " ; echo -e " autoconfig IN CNAME $FQDN .\n " ) "
fi
# if $file ! contain autodiscover -> add entry
if [ -z " $( echo -e " $file " | egrep '^autodiscover' ) " ] ; then
file = " $( echo -e " $file " ; echo -e " autodiscover IN CNAME $FQDN .\n " ) "
fi
fi # End if containt DEFAULT_MX
2013-08-22 06:13:33 +00:00
##### Mail autodetect for thunderbird / outlook - END
2011-01-26 17:18:56 +00:00
# Replace the vars by their values
# Here we can add dynamic value for the default MX
file = $( echo -e " $file " | sed -e "
s/%%fqdn%%/$FQDN /g;
s/%%ns1%%/$NS1_HOSTNAME /g;
s/%%ns2%%/$NS2_HOSTNAME /g;
2011-03-28 13:15:47 +00:00
s/%%DEFAULT_MX%%/$DEFAULT_MX /g;
s/%%DEFAULT_SECONDARY_MX%%/$DEFAULT_SECONDARY_MX /g;
2011-06-17 10:32:21 +00:00
s/@@fqdn@@/$FQDN /g;
s/@@ns1@@/$NS1_HOSTNAME /g;
s/@@ns2@@/$NS2_HOSTNAME /g;
s/@@DEFAULT_MX@@/$DEFAULT_MX /g;
s/@@DEFAULT_SECONDARY_MX@@/$DEFAULT_SECONDARY_MX /g;
2011-01-26 17:18:56 +00:00
s/@@DOMAINE@@/$domain /g;
s/@@SERIAL@@/$serial /g;
2013-07-04 08:26:19 +00:00
s/@@PUBLIC_IP@@/$PUBLIC_IP /g;
s/@@ZONETTL@@/$zonettl /g;
" )
2011-01-26 17:18:56 +00:00
2013-08-22 06:13:33 +00:00
# Add the manually entered resource records (after the special tag ;;; END ALTERNC AUTOGENERATE CONFIGURATION)
2011-01-26 17:18:56 +00:00
if [ -r " $zone_file " ] ; then
file = $(
echo -e " $file "
grep -A 10000 " $manual_tag " " $zone_file "
)
2013-08-22 06:13:33 +00:00
fi
# Add the special tag at the end of the zone, if it is not here yet:
if ! echo -e " $file " | grep -q " $manual_tag "
then
file = $( echo -e " $file " ; echo " $manual_tag " )
2011-01-26 17:18:56 +00:00
fi
2011-01-28 15:55:26 +00:00
# Init the file
2011-01-26 17:18:56 +00:00
echo -e " $file " > " $zone_file "
2011-01-28 15:55:26 +00:00
2011-01-26 17:18:56 +00:00
# And set his rights
dns_chmod $domain
2011-01-28 15:55:26 +00:00
# Add it to named conf
dns_named_conf $domain
2013-02-21 09:54:35 +00:00
# Hook it !
run-parts --arg= dns_reload_zone --arg= " $domain " /usr/lib/alternc/reload.d
2013-07-22 13:49:40 +00:00
2013-08-22 06:13:33 +00:00
# ask bind to reload the zone
2013-07-22 13:49:40 +00:00
$RNDC reload $domain
2011-01-26 17:18:56 +00:00
}