- makni 1 PTR iz primjera
[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 change them appropriately *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     auth-nxdomain no;
77     allow-transfer { xfer; };
78     allow-recursion { trusted; };
79     version "No version.";
80     transfer-format many-answers;
81     max-transfer-time-in 90;
82     interface-interval 0;
83     notify yes;
84     listen-on-v6 { none; };
85 };
86
87 logging {
88     category lame-servers { null; };
89 };
90 EOF
91
92 # make example hosts.db
93 cat > /usr/share/doc/bind9-cn/examples/hosts.db <<EOF
94 \$TTL 86400
95 @  SOA  $CARNET_HOSTNAME.$CARNET_DOMAINNAME. hostmaster.$CARNET_HOSTNAME.$CARNET_DOMAINNAME. (
96     $SERNO   ; Serial
97     28800    ; Refresh
98     7200     ; Retry
99     604800   ; Expire
100     86400 )  ; Minimum
101     NS  $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
102     NS  bjesomar.srce.hr.
103     A   $CARNET_IPADDR
104     MX  5   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
105
106 localhost.$CARNET_DOMAINNAME.   A       127.0.0.1
107 $CARNET_HOSTNAME.$CARNET_DOMAINNAME.      A     $CARNET_IPADDR
108
109 dns         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
110 ns          CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
111 www         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
112 proxy       CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
113 mail        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
114 smtp        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
115 pop         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
116 imap        CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
117 ftp         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
118 ntp         CNAME   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
119 EOF
120
121 # make example hosts.rev
122 cat > /usr/share/doc/bind9-cn/examples/hosts.rev <<EOF
123 \$TTL 86400
124 @  SOA  $CARNET_HOSTNAME.$CARNET_DOMAINNAME. hostmaster.$CARNET_HOSTNAME.$CARNET_DOMAINNAME. (
125     $SERNO       ; Serial
126     28800   ; Refresh
127     7200    ; Retry
128     604800  ; Expire
129     86400 ) ; Minimum
130     NS  $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
131     NS  bjesomar.srce.hr.
132
133 $BROJ   PTR   $CARNET_HOSTNAME.$CARNET_DOMAINNAME.
134 EOF
135
136 # make example hosts
137 cat > /usr/share/doc/bind9-cn/examples/hosts <<EOF
138 # /etc/hosts - names & shortcuts to various hosts
139 127.0.0.1       localhost.$CARNET_DOMAINNAME localhost
140 $CARNET_IPADDR      $CARNET_HOSTNAME.$CARNET_DOMAINNAME $CARNET_HOSTNAME
141 EOF
142
143 # make example resolv.conf
144 cat > /usr/share/doc/bind9-cn/examples/resolv.conf <<EOF
145 search $CARNET_DOMAINNAME
146 nameserver 127.0.0.1
147 nameserver 161.53.2.70
148 EOF
149
150 # check if named.conf has lame server logging
151 script='/^logging/,/^}/ { if ($0 ~ /category lame-servers/) { print "yes"; exit } }'
152 lameconf=
153 if [ -e /etc/bind/named.conf.options -a -e /etc/bind/named.conf ]; then
154   lameconf=$(cat /etc/bind/named.conf /etc/bind/named.conf.options | awk "$script")
155 else
156     if [ -e /etc/bind/named.conf ]; then
157       lameconf=$(awk "$script" /etc/bind/named.conf)
158     fi
159 fi
160 if [ "x$lameconf" != "xyes" ]; then
161   if [ ! -e /etc/bind/named.conf.options ]; then
162     touch /etc/bind/named.conf.options
163   fi
164   cp /etc/bind/named.conf.options /etc/bind/named.conf.options.$$
165   cp-update bind9-cn /etc/bind/named.conf.options.$$ <<EOF
166 logging {
167     category lame-servers { null; };
168 };
169 EOF
170   cp_mv /etc/bind/named.conf.options.$$ /etc/bind/named.conf.options
171     
172   # reload
173   echo "CN: Added lame-servers logging exclusion to named.conf.options"
174   rndc reload || echo "CN: Reload didn't work, please check manually"
175 fi
176
177 if [ -e /etc/bind/named.conf.options ] && \
178     fgrep -q 'query-source address * port 53' \
179         /etc/bind/named.conf.options; then
180         fgrep -v 'query-source address * port 53' \
181             /etc/bind/named.conf.options > /etc/bind/named.conf.options.$$
182     cp_mv /etc/bind/named.conf.options.$$ /etc/bind/named.conf.options
183     echo "CN: Removing obsolete query-source directive"
184     rndc reload || echo "CN: Reload didn't work, please check manually"
185 fi
186
187 # dh_installdeb will replace this with shell code automatically
188 # generated by other debhelper scripts.
189
190 #DEBHELPER#
191
192 exit 0