author | Tero Marttila <terom@paivola.fi> |
Thu, 19 Dec 2013 01:17:48 +0200 | |
branch | dns-new |
changeset 87 | cb4607af8663 |
parent 85 | 4ad9c9b7cd0e |
child 89 | 51270237a6ff |
permissions | -rwxr-xr-x |
2 | 1 |
#!/bin/bash |
2 |
# vim: set ft=sh : |
|
3 |
||
4 |
set -ue |
|
5 |
||
82 | 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 |
|
2 | 14 |
|
82 | 15 |
# charset for files under etc/ |
16 |
CHARSET='utf-8' |
|
52
b68b8615c512
update: split out code into lib/update.foo
Tero Marttila <terom@paivola.fi>
parents:
51
diff
changeset
|
17 |
|
82 | 18 |
# External bins |
19 |
NAMED_CHECKZONE=/usr/sbin/named-checkzone |
|
52
b68b8615c512
update: split out code into lib/update.foo
Tero Marttila <terom@paivola.fi>
parents:
51
diff
changeset
|
20 |
|
62
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
21 |
DHCPD=/usr/sbin/dhcpd |
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
22 |
DHCPD_CONF=/etc/dhcp/dhcpd.conf |
66
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
23 |
DHCPD_INIT=/etc/init.d/isc-dhcp-server |
61
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:
58
diff
changeset
|
24 |
|
31
2b7aad3466c6
update: log_warn, -q; ensure_dir; link_zone paivola-reverse; indent error exit
Tero Marttila <terom@paivola.fi>
parents:
30
diff
changeset
|
25 |
HG=/usr/bin/hg |
58 | 26 |
HG_ARGS=(--config trusted.users=root) |
27 |
||
27 | 28 |
RNDC=/usr/sbin/rndc |
46
3613e93e4fd7
update: rndc: fail if no read perms on $RNDC_KEY
Tero Marttila <terom@paivola.fi>
parents:
45
diff
changeset
|
29 |
RNDC_KEY=/etc/bind/rndc.key |
10 | 30 |
|
82 | 31 |
# Library includes |
32 |
source lib/update |
|
44 | 33 |
|
66
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
34 |
## Flags |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
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:
64
diff
changeset
|
36 |
RELOAD_ZONES= |
21 | 37 |
|
44 | 38 |
## Site settings, used as arguments to scripts |
39 |
# Origin domain to generate reverse records for in --reverse-zone |
|
40 |
REVERSE_DOMAIN=paivola.fi |
|
28
647f6de0d0ac
update: implement -d for $ROOT
Tero Marttila <terom@paivola.fi>
parents:
27
diff
changeset
|
41 |
|
82 | 42 |
## Do things |
61
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:
58
diff
changeset
|
43 |
function run_hosts { |
27 | 44 |
# test |
13 | 45 |
log "Testing hosts..." |
82 | 46 |
for hosts in $(list_files etc/hosts); do |
47 |
log_warn "TODO: check_hosts $hosts" |
|
48 |
done |
|
36
3208cd6540dc
update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents:
32
diff
changeset
|
49 |
|
84
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
82
diff
changeset
|
50 |
log "Updating forward host zones..." |
82 | 51 |
for hosts in $(list_files etc/hosts); do |
85 | 52 |
update_hosts_forward "var/zones/hosts/$hosts" "$hosts" \ |
53 |
"etc/hosts/$hosts" |
|
82 | 54 |
done |
36
3208cd6540dc
update: restructure zones/, manage .pvl
Tero Marttila <terom@paivola.fi>
parents:
32
diff
changeset
|
55 |
|
82 | 56 |
log "Updating DHCP hosts..." |
57 |
for hosts in $(list_files etc/hosts); do |
|
85 | 58 |
update_hosts_dhcp "var/dhcp/$hosts.conf" \ |
59 |
"etc/hosts/$hosts" |
|
82 | 60 |
done |
84
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
82
diff
changeset
|
61 |
|
77df429f63a3
update: full host forward/dhcp/reverse zones
Tero Marttila <terom@paivola.fi>
parents:
82
diff
changeset
|
62 |
log "Updating reverse host zones..." |
87
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
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:
85
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:
85
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:
85
diff
changeset
|
66 |
done |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
67 |
# for zone in $(list_files etc/zones); do |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
68 |
# for reverse_hosts in $(zone_includes_grep var/include-cache/$zone etc/zones/$zone reverse-hosts/); do |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
69 |
# prefix="${reverse_hosts%_*}" |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
70 |
# hosts="${reverse_hosts#*_}" |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
71 |
# |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
72 |
# update_hosts_reverse "var/zones/reverse-hosts/${prefix}_${hosts}" "$prefix" \ |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
73 |
# "etc/hosts/$hosts" |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
74 |
# done |
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
75 |
# done |
61
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:
58
diff
changeset
|
76 |
} |
62
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
77 |
|
61
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:
58
diff
changeset
|
78 |
function run_zones { |
38
39799fc994e9
update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents:
37
diff
changeset
|
79 |
log "Copying zone includes..." |
82 | 80 |
for zone in $(list_files etc/zones/includes); do |
85 | 81 |
copy "var/zones/includes/$zone" "etc/zones/includes/$zone" |
82 | 82 |
done |
18
826103fe3c8c
update: abspath; fixup serials log; indent log_cmd
Tero Marttila <terom@paivola.fi>
parents:
17
diff
changeset
|
83 |
|
82 | 84 |
log "Updating zone serials..." |
85 |
for zone in $(list_files etc/zones); do |
|
85 | 86 |
update_serial "var/serials/$zone" "etc/zones/$zone" \ |
87
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
87 |
$(zone_includes var/include-cache/$zone etc/zones/$zone var/zones/) |
85 | 88 |
|
82 | 89 |
done |
13 | 90 |
|
38
39799fc994e9
update: unify [check/copy/update/link]_[hosts/zone/serial]
Tero Marttila <terom@paivola.fi>
parents:
37
diff
changeset
|
91 |
log "Updating zones..." |
82 | 92 |
for zone in $(list_files etc/zones); do |
85 | 93 |
update_zone "var/zones/$zone" "etc/zones/$zone" "var/serials/$zone" |
82 | 94 |
done |
10 | 95 |
|
96 |
log "Testing zones..." |
|
82 | 97 |
for zone in $(list_files etc/zones); do |
98 |
# check_zone var/zones/$zone $zone |
|
99 |
log_warn "TODO: check_zone $zone" |
|
100 |
done |
|
66
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
101 |
} |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
102 |
|
61
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:
58
diff
changeset
|
103 |
function run_deploy { |
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:
58
diff
changeset
|
104 |
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:
58
diff
changeset
|
105 |
reload_zones |
44 | 106 |
|
66
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
107 |
log "Reload dhcp..." |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
108 |
reload_dhcp |
482d06935d96
update: cmd_test; check_dhcp_hosts after do_reload_zones; reload_dhcp
Tero Marttila <terom@paivola.fi>
parents:
64
diff
changeset
|
109 |
|
82 | 110 |
log "Commit etc..." |
111 |
commit_data etc |
|
44 | 112 |
} |
113 |
||
114 |
## Main entry point |
|
115 |
function main { |
|
116 |
parse_args "$@" |
|
117 |
||
62
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
118 |
## Input dirs |
87
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
119 |
for dir in etc etc/zones etc/hosts opt; do |
82 | 120 |
[ -d $dir ] || die "Missing directory: $dir" |
121 |
done |
|
44 | 122 |
|
123 |
## Output dirs |
|
85 | 124 |
for dir in var var/dhcp var/zones var/serials var/include-cache; do |
62
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
125 |
ensure_dir $dir |
65bf391fd2f3
update: link + check dhcpd hosts from settings/dhcp/... -> dhcp/...
Tero Marttila <terom@paivola.fi>
parents:
61
diff
changeset
|
126 |
done |
77
b0c0e3e80c39
update: move zones/serials/dhcp to ./var; requires update -FR and bind/dhcpd config update
Tero Marttila <terom@paivola.fi>
parents:
76
diff
changeset
|
127 |
|
b0c0e3e80c39
update: move zones/serials/dhcp to ./var; requires update -FR and bind/dhcpd config update
Tero Marttila <terom@paivola.fi>
parents:
76
diff
changeset
|
128 |
# sub-$ZONES |
87
cb4607af8663
add etc/reverse-zones-hosts support, in preference to a magical include-based mechanism..
Tero Marttila <terom@paivola.fi>
parents:
85
diff
changeset
|
129 |
for dir in var/zones/includes var/zones/hosts var/zones/reverse-hosts; do |
82 | 130 |
ensure_dir $dir |
30
1a8bc67b1eb7
update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents:
29
diff
changeset
|
131 |
done |
1a8bc67b1eb7
update: link_zones for paivola.*.zone -> paivola.zone
Tero Marttila <terom@paivola.fi>
parents:
29
diff
changeset
|
132 |
|
44 | 133 |
## Go |
61
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:
58
diff
changeset
|
134 |
run_hosts |
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:
58
diff
changeset
|
135 |
run_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:
58
diff
changeset
|
136 |
run_deploy |
2 | 137 |
} |
138 |
||
7
f4457348faa0
update: function update { ... }, color logging, update_serial
Tero Marttila <terom@paivola.fi>
parents:
2
diff
changeset
|
139 |
main "$@" |