author | Tero Marttila <terom@paivola.fi> |
Thu, 19 Dec 2013 02:38:03 +0200 | |
branch | dns-new |
changeset 612 | 51270237a6ff |
parent 610 | cb4607af8663 |
child 613 | 5b33ccac38ad |
permissions | -rwxr-xr-x |
525 | 1 |
#!/bin/bash |
2 |
# vim: set ft=sh : |
|
3 |
||
4 |
set -ue |
|
5 |
||
605 | 6 |
if [ $0 == './update' ]; then |
7 |
SRV=$(pwd) |
|
8 |
OPT=./opt |
|
9 |
else |
|
10 |
SRV=${SRV:-/srv/dns} |
|
11 |
OPT=${SRV:-/srv/dns/opt} |
|
12 |
cd $SRV |
|
13 |
fi |
|
525 | 14 |
|
605 | 15 |
# charset for files under etc/ |
16 |
CHARSET='utf-8' |
|
575
b68b8615c512
update: split out code into lib/update.foo
Tero Marttila <terom@paivola.fi>
parents:
574
diff
changeset
|
17 |
|
605 | 18 |
# External bins |
19 |
NAMED_CHECKZONE=/usr/sbin/named-checkzone |
|
575
b68b8615c512
update: split out code into lib/update.foo
Tero Marttila <terom@paivola.fi>
parents:
574
diff
changeset
|
20 |
|
585
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
21 |
DHCPD=/usr/sbin/dhcpd |
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
22 |
DHCPD_CONF=/etc/dhcp/dhcpd.conf |
589
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
23 |
DHCPD_INIT=/etc/init.d/isc-dhcp-server |
584
22b58b938fd0
update: rename deploy_zones -> reload_zones; move related do_* from lib/update.updates -> lib/update.operations where they belong
Tero Marttila <terom@paivola.fi>
parents:
581
diff
changeset
|
24 |
|
554
2b7aad3466c6
update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents:
553
diff
changeset
|
25 |
HG=/usr/bin/hg |
581 | 26 |
HG_ARGS=(--config trusted.users=root) |
27 |
||
550 | 28 |
RNDC=/usr/sbin/rndc |
569
3613e93e4fd7
update: rndc: fail if no read perms on $RNDC_KEY
Tero Marttila <terom@paivola.fi>
parents:
568
diff
changeset
|
29 |
RNDC_KEY=/etc/bind/rndc.key |
533 | 30 |
|
605 | 31 |
# Library includes |
32 |
source lib/update |
|
567 | 33 |
|
589
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
34 |
## Flags |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
35 |
# set by do_reload_zone if zone data has actually been reloaded |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
36 |
RELOAD_ZONES= |
544 | 37 |
|
567 | 38 |
## Site settings, used as arguments to scripts |
39 |
# Origin domain to generate reverse records for in --reverse-zone |
|
40 |
REVERSE_DOMAIN=paivola.fi |
|
551
647f6de0d0ac
update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents:
550
diff
changeset
|
41 |
|
605 | 42 |
## Do things |
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
43 |
function update { |
536 | 44 |
log "Testing hosts..." |
605 | 45 |
for hosts in $(list_files etc/hosts); do |
46 |
log_warn "TODO: check_hosts $hosts" |
|
47 |
done |
|
559
3208cd6540dc
update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents:
555
diff
changeset
|
48 |
|
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
49 |
## Hosts |
607
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
605
diff
changeset
|
50 |
log "Updating forward host zones..." |
605 | 51 |
for hosts in $(list_files etc/hosts); do |
608 | 52 |
update_hosts_forward "var/zones/hosts/$hosts" "$hosts" \ |
53 |
"etc/hosts/$hosts" |
|
605 | 54 |
done |
559
3208cd6540dc
update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents:
555
diff
changeset
|
55 |
|
605 | 56 |
log "Updating DHCP hosts..." |
57 |
for hosts in $(list_files etc/hosts); do |
|
608 | 58 |
update_hosts_dhcp "var/dhcp/$hosts.conf" \ |
59 |
"etc/hosts/$hosts" |
|
605 | 60 |
done |
607
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
605
diff
changeset
|
61 |
|
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
605
diff
changeset
|
62 |
log "Updating reverse host zones..." |
610
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
63 |
for zone in $(list_dirs etc/reverse-zones-hosts); do |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
64 |
update_hosts_reverse "var/zones/hosts/$zone" "$zone" \ |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
65 |
etc/reverse-zones-hosts/$zone/* |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
66 |
done |
585
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
67 |
|
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
68 |
## Zones |
561
39799fc994e9
update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents:
560
diff
changeset
|
69 |
log "Copying zone includes..." |
605 | 70 |
for zone in $(list_files etc/zones/includes); do |
608 | 71 |
copy "var/zones/includes/$zone" "etc/zones/includes/$zone" |
605 | 72 |
done |
541
826103fe3c8c
update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents:
540
diff
changeset
|
73 |
|
605 | 74 |
log "Updating zone serials..." |
75 |
for zone in $(list_files etc/zones); do |
|
608 | 76 |
update_serial "var/serials/$zone" "etc/zones/$zone" \ |
610
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
77 |
$(zone_includes var/include-cache/$zone etc/zones/$zone var/zones/) |
605 | 78 |
done |
536 | 79 |
|
561
39799fc994e9
update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents:
560
diff
changeset
|
80 |
log "Updating zones..." |
605 | 81 |
for zone in $(list_files etc/zones); do |
608 | 82 |
update_zone "var/zones/$zone" "etc/zones/$zone" "var/serials/$zone" |
605 | 83 |
done |
533 | 84 |
|
85 |
log "Testing zones..." |
|
605 | 86 |
for zone in $(list_files etc/zones); do |
87 |
# check_zone var/zones/$zone $zone |
|
88 |
log_warn "TODO: check_zone $zone" |
|
89 |
done |
|
589
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
90 |
|
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
91 |
## Deploy |
584
22b58b938fd0
update: rename deploy_zones -> reload_zones; move related do_* from lib/update.updates -> lib/update.operations where they belong
Tero Marttila <terom@paivola.fi>
parents:
581
diff
changeset
|
92 |
log "Reload zones..." |
22b58b938fd0
update: rename deploy_zones -> reload_zones; move related do_* from lib/update.updates -> lib/update.operations where they belong
Tero Marttila <terom@paivola.fi>
parents:
581
diff
changeset
|
93 |
reload_zones |
567 | 94 |
|
589
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
95 |
log "Reload dhcp..." |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
96 |
reload_dhcp |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
587
diff
changeset
|
97 |
|
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
98 |
log "Commit..." |
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
99 |
commit etc |
567 | 100 |
} |
101 |
||
102 |
## Main entry point |
|
103 |
function main { |
|
104 |
parse_args "$@" |
|
105 |
||
585
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
106 |
## Input dirs |
610
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
107 |
for dir in etc etc/zones etc/hosts opt; do |
605 | 108 |
[ -d $dir ] || die "Missing directory: $dir" |
109 |
done |
|
567 | 110 |
|
111 |
## Output dirs |
|
608 | 112 |
for dir in var var/dhcp var/zones var/serials var/include-cache; do |
585
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
113 |
ensure_dir $dir |
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
584
diff
changeset
|
114 |
done |
600
b0c0e3e80c39
update: move zones/serials/dhcp to ./var; requires update -FR and bind/dhcpd config update
Tero Marttila <terom@paivola.fi>
parents:
599
diff
changeset
|
115 |
|
b0c0e3e80c39
update: move zones/serials/dhcp to ./var; requires update -FR and bind/dhcpd config update
Tero Marttila <terom@paivola.fi>
parents:
599
diff
changeset
|
116 |
# sub-$ZONES |
610
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
608
diff
changeset
|
117 |
for dir in var/zones/includes var/zones/hosts var/zones/reverse-hosts; do |
605 | 118 |
ensure_dir $dir |
553
1a8bc67b1eb7
update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents:
552
diff
changeset
|
119 |
done |
1a8bc67b1eb7
update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents:
552
diff
changeset
|
120 |
|
567 | 121 |
## Go |
612
51270237a6ff
cleanup update, reintroduce separate hg repo
Tero Marttila <terom@paivola.fi>
parents:
610
diff
changeset
|
122 |
update |
525 | 123 |
} |
124 |
||
530
f4457348faa0
update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents:
525
diff
changeset
|
125 |
main "$@" |