r11: - reload in postinst
[bind9-cn.git] / debian / postinst
1 #!/bin/sh
2 # postinst script for bind9-cn
3 #
4 # see: dh_installdeb(1)
5
6 set -e
7
8 # summary of how this script can be called:
9 #        * <postinst> `configure' <most-recently-configured-version>
10 #        * <old-postinst> `abort-upgrade' <new version>
11 #        * <conflictor's-postinst> `abort-remove' `in-favour' <package>
12 #          <new-version>
13 #        * <deconfigured's-postinst> `abort-deconfigure' `in-favour'
14 #          <failed-install-package> <version> `removing'
15 #          <conflicting-package> <version>
16 # for details, see http://www.debian.org/doc/debian-policy/ or
17 # the debian-policy package
18 #
19
20 case "$1" in
21     configure|reconfigure)
22       # continue below
23     ;;
24
25     *)
26         exit 0
27     ;;
28 esac
29
30 # import CN-functions
31 . /usr/share/carnet-tools/functions.sh
32
33 echo "CN: Making sample configurations in /usr/share/doc/bind9-cn/examples"
34 echo "CN: Make sure you read them and apply *before* running Bind9 service!"
35
36 #variables
37 cp_get_ifaddr
38 CARNET_IPADDR=$RET
39 cp_get_netaddr
40 CARNET_NETADDR=$RET
41 CARNET_HOSTNAME=`hostname`
42 CARNET_DOMAINNAME=`hostname --domain`
43 CARNET_REV=`echo $CARNET_IPADDR | awk -F. '{ print $3 "." $2 "." $1 ".in-addr.arpa" }'`
44 SERNO=`date +%Y%m%d01`
45 BROJ=`echo $CARNET_IPADDR | cut -d. -f4`
46
47 # make example named.conf.local
48 cat > /usr/share/doc/bind9-cn/examples/named.conf.local <<EOF
49 zone "$CARNET_DOMAINNAME" in {
50     type master;
51     file "/etc/bind/hosts.db";
52 };
53
54 zone "$CARNET_REV" in {
55     type master;
56     file "/etc/bind/hosts.rev";
57 };
58 EOF
59
60 # make example named.conf.options
61 cat > /usr/share/doc/bind9-cn/examples/named.conf.options <<EOF
62 acl "xfer" {
63     161.53.2.70;
64     161.53.123.3;
65     161.53.3.7;
66     127.0.0.1;
67 };
68
69 acl "trusted" {
70     $CARNET_NETADDR;
71     127.0.0.0/8;
72 };
73
74 options {
75     directory "/etc/bind";
76     query-source address * port 53;
77     auth-nxdomain no;
78     allow-transfer { xfer; };
79     allow-recursion { trusted; };
80     version "No version.";
81     transfer-format many-answers;
82     max-transfer-time-in 90;
83     interface-interval 0;
84     notify yes;
85     listen-on-v6 { none; };
86 };
87
88 logging {
89     category lame-servers { null; };
90 };
91 EOF
92
93 # make example hosts.db
94 cat > /usr/share/doc/bind9-cn/examples/hosts.db <<EOF
95 \$TTL 86400
96 @  SOA  $CARNET_HOSTNAME.$CARNET_DOMAINNAME. hostmaster.$CARNET_HOSTNAME.$CARNET_DOMAINNAME. (
97     $SERNO   ; Serial
98     28800    ; Refresh
99     7200     ; Retry
100     604800   ; Expire
101     86400 )  ; Minimum
102     NS  $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
103     NS  bjesomar.srce.hr.
104     A   $CARNET_IPADDR
105     MX  5   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
106
107 localhost.$CARNET_DOMAINNAME.   A       127.0.0.1
108 $CARNET_HOSTNAME.$CARNET_DOMAINNAME.      A     $CARNET_IPADDR
109
110 dns         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
111 ns          CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
112 www         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
113 proxy       CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
114 mail        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
115 smtp        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
116 pop         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
117 imap        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
118 ftp         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
119 ntp         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
120 EOF
121
122 # make example hosts.rev
123 cat > /usr/share/doc/bind9-cn/examples/hosts.rev <<EOF
124 \$TTL 86400
125 @  SOA  $CARNET_HOSTNAME.$CARNET_DOMAINNAME. hostmaster.$CARNET_HOSTNAME.$CARNET_DOMAINNAME. (
126     $SERNO       ; Serial
127     28800   ; Refresh
128     7200    ; Retry
129     604800  ; Expire
130     86400 ) ; Minimum
131     NS  $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
132     NS  bjesomar.srce.hr.
133
134 1   PTR localhost.$CARNET_DOMAINNAME.
135 $BROJ   PTR   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
136 EOF
137
138 # make example hosts
139 cat > /usr/share/doc/bind9-cn/examples/hosts <<EOF
140 # /etc/hosts - names & shortcuts to various hosts
141 127.0.0.1       localhost.$CARNET_DOMAINNAME localhost
142 $CARNET_IPADDR      $CARNET_HOSTNAME.$CARNET_DOMAINNAME $CARNET_HOSTNAME
143 EOF
144
145 # make example resolv.conf
146 cat > /usr/share/doc/bind9-cn/examples/resolv.conf <<EOF
147 search $CARNET_DOMAINNAME
148 nameserver 127.0.0.1
149 nameserver 161.53.2.70
150 EOF
151
152 # check if named.conf has lame server logging
153 script='/^logging/,/^}/ { if ($0 ~ /category lame-servers/) { print "yes"; exit } }'
154 lameconf=
155 if [ -e /etc/bind/named.conf.options -a -e /etc/bind/named.conf ]; then
156   lameconf=$(cat /etc/bind/named.conf /etc/bind/named.conf.options | awk $script)
157 else
158     if [ -e /etc/bind/named.conf ]; then
159       lameconf=$(awk $script /etc/bind/named.conf)
160     fi
161 fi
162 if [ "x$lameconf" != "xyes" ]; then
163   if [ ! -e /etc/bind/named.conf.options ]; then
164     touch /etc/bind/named.conf.options
165   fi
166   cp /etc/bind/named.conf.options /etc/bind/named.conf.options.$$
167   cp-update bind9-cn /etc/bind/named.conf.options.$$ <<EOF
168 logging {
169     category lame-servers { null; };
170 };
171 EOF
172   cp_mv /etc/bind/named.conf.options.$$ /etc/bind/named.conf.options
173     
174   # reload
175   echo "CN: Added lame-servers logging exclusion to named.conf.options"
176   rndc reload || echo "CN: Reload didn't work, please check manually"
177 fi
178
179 # dh_installdeb will replace this with shell code automatically
180 # generated by other debhelper scripts.
181
182 #DEBHELPER#
183
184 exit 0