author | Tero Marttila <terom@paivola.fi> |
Wed, 11 Sep 2013 14:23:26 +0300 | |
changeset 252 | 0ea4450fdd40 |
parent 251 | d250f200dd7e |
child 258 | 1ad9cec4f556 |
permissions | -rwxr-xr-x |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
1 |
#!/usr/bin/env python |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
2 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
3 |
""" |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
4 |
Process bind zonefiles. |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
5 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
6 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
7 |
import codecs |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
8 |
import optparse |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
9 |
|
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
10 |
import pvl.args |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
11 |
import pvl.dns.zone |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
12 |
from pvl.dns import __version__ |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
13 |
from pvl.dns.zone import ZoneRecord, reverse_ipv4, reverse_ipv6, fqdn |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
14 |
|
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
15 |
import logging; log = logging.getLogger('main') |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
16 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
17 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
18 |
def parse_options (argv) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
19 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
20 |
Parse command-line arguments. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
21 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
22 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
23 |
prog = argv[0] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
24 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
25 |
parser = optparse.OptionParser( |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
26 |
prog = prog, |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
27 |
usage = '%prog: [options]', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
28 |
version = __version__, |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
29 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
30 |
# module docstring |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
31 |
description = __doc__, |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
32 |
) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
33 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
34 |
# logging |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
35 |
parser.add_option_group(pvl.args.parser(parser)) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
36 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
37 |
# input/output |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
38 |
parser.add_option('-c', '--input-charset', metavar='CHARSET', default='utf-8', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
39 |
help="Encoding used for input files") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
40 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
41 |
parser.add_option('-o', '--output', metavar='FILE', default='-', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
42 |
help="Write to output file; default stdout") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
43 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
44 |
parser.add_option('--output-charset', metavar='CHARSET', default='utf-8', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
45 |
help="Encoding used for output files") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
46 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
47 |
# check stage |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
48 |
parser.add_option('--check-hosts', action='store_true', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
49 |
help="Check that host/IPs are unique. Use --quiet to silence warnings, and test exit status") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
50 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
51 |
parser.add_option('--check-exempt', metavar='HOST', action='append', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
52 |
help="Allow given names to have multiple records") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
53 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
54 |
# meta stage |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
55 |
parser.add_option('--meta-zone', action='store_true', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
56 |
help="Generate host metadata zone; requires --input-line-date") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
57 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
58 |
parser.add_option('--meta-ignore', metavar='HOST', action='append', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
59 |
help="Ignore given hostnames in metadata output") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
60 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
61 |
parser.add_option('--input-line-date', action='store_true', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
62 |
help="Parse timestamp prefix from each input line (e.g. `hg blame | ...`)") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
63 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
64 |
# forward stage |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
65 |
parser.add_option('--forward-zone', action='store_true', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
66 |
help="Generate forward zone") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
67 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
68 |
parser.add_option('--forward-txt', action='store_true', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
69 |
help="Generate TXT records for forward zone") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
70 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
71 |
parser.add_option('--forward-mx', metavar='MX', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
72 |
help="Generate MX records for forward zone") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
73 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
74 |
# reverse stage |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
75 |
parser.add_option('--reverse-domain', metavar='DOMAIN', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
76 |
help="Domain to use for hosts in reverse zone") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
77 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
78 |
parser.add_option('--reverse-zone', metavar='NET', |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
79 |
help="Generate forward zone for given subnet (x.z.y | a:b:c:d)") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
80 |
|
252 | 81 |
# other |
82 |
parser.add_option('--serial', metavar='YYMMDDXX', |
|
83 |
help="Set serial for SOA record") |
|
84 |
||
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
85 |
# defaults |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
86 |
parser.set_defaults( |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
87 |
# XXX: combine |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
88 |
check_exempt = [], |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
89 |
meta_ignore = [], |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
90 |
) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
91 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
92 |
# parse |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
93 |
options, args = parser.parse_args(argv[1:]) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
94 |
|
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
95 |
# apply |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
96 |
pvl.args.apply(options, prog) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
97 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
98 |
return options, args |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
99 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
100 |
def check_zone_hosts (zone, whitelist=None, whitelist_types=set(['TXT'])) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
101 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
102 |
Parse host/IP pairs from the zone, and verify that they are unique. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
103 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
104 |
As an exception, names listed in the given whitelist may have multiple IPs. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
105 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
106 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
107 |
by_name = {} |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
108 |
by_ip = {} |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
109 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
110 |
fail = None |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
111 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
112 |
last_name = None |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
113 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
114 |
for r in zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
115 |
name = r.name or last_name |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
116 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
117 |
name = (r.origin, name) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
118 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
119 |
# name |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
120 |
if r.type not in whitelist_types : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
121 |
if name not in by_name : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
122 |
by_name[name] = r |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
123 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
124 |
elif r.name in whitelist : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
125 |
log.debug("Duplicate whitelist entry: %s", r) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
126 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
127 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
128 |
# fail! |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
129 |
log.warn("%s: Duplicate name: %s <-> %s", r.line, r, by_name[name]) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
130 |
fail = True |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
131 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
132 |
# ip |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
133 |
if r.type == 'A' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
134 |
ip, = r.data |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
135 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
136 |
if ip not in by_ip : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
137 |
by_ip[ip] = r |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
138 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
139 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
140 |
# fail! |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
141 |
log.warn("%s: Duplicate IP: %s <-> %s", r.line, r, by_ip[ip]) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
142 |
fail = True |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
143 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
144 |
return fail |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
145 |
|
252 | 146 |
def process_zone_soa (soa, serial) : |
147 |
return pvl.dns.zone.SOA( |
|
148 |
soa.master, soa.contact, |
|
149 |
serial, soa.refresh, soa.retry, soa.expire, soa.nxttl |
|
150 |
) |
|
151 |
||
152 |
def process_zone_serial (zone, serial) : |
|
153 |
for rr in zone : |
|
154 |
if rr.type == 'SOA' : |
|
155 |
# XXX: as SOA record.. |
|
156 |
yield process_zone_soa(pvl.dns.zone.SOA.parse(rr.line), serial) |
|
157 |
else : |
|
158 |
yield rr |
|
159 |
||
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
160 |
def process_zone_forwards (zone, txt=False, mx=False) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
161 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
162 |
Process zone data -> forward zone data. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
163 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
164 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
165 |
for r in zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
166 |
yield r |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
167 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
168 |
if r.type == 'A' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
169 |
if txt : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
170 |
# comment? |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
171 |
comment = r.line.comment |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
172 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
173 |
if comment : |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
174 |
yield ZoneRecord.TXT(None, comment, ttl=r.ttl) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
175 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
176 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
177 |
# XXX: RP, do we need it? |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
178 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
179 |
if mx : |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
180 |
# XXX: is this even a good idea? |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
181 |
yield ZoneRecord.MX(None, 10, mx, ttl=r.ttl) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
182 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
183 |
def process_zone_meta (zone, ignore=None) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
184 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
185 |
Process zone metadata -> output. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
186 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
187 |
|
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
188 |
TIMESTAMP_FORMAT = '%Y/%m/%d' |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
189 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
190 |
for r in zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
191 |
if ignore and r.name in ignore : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
192 |
# skip |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
193 |
log.debug("Ignore record: %s", r) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
194 |
continue |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
195 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
196 |
# for hosts.. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
197 |
if r.type == 'A' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
198 |
# timestamp? |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
199 |
timestamp = r.line.timestamp |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
200 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
201 |
if timestamp : |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
202 |
yield ZoneRecord.TXT(r.name, timestamp.strftime(TIMESTAMP_FORMAT), ttl=r.ttl) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
203 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
204 |
def process_zone_reverse (zone, origin, domain) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
205 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
206 |
Process zone data -> reverse zone data. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
207 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
208 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
209 |
name = None |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
210 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
211 |
for r in zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
212 |
# keep name from previous.. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
213 |
if r.name : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
214 |
name = r.name |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
215 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
216 |
if r.type == 'A' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
217 |
ip, = r.data |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
218 |
ptr = reverse_ipv4(ip) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
219 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
220 |
elif r.type == 'AAAA' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
221 |
ip, = r.data |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
222 |
ptr = reverse_ipv6(ip) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
223 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
224 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
225 |
continue |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
226 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
227 |
# verify |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
228 |
if zone and ptr.endswith(origin) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
229 |
ptr = ptr[:-(len(origin) + 1)] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
230 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
231 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
232 |
log.warning("Reverse does not match zone origin, skipping: (%s) -> %s <-> %s", ip, ptr, origin) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
233 |
continue |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
234 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
235 |
# domain to use |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
236 |
host_domain = r.origin or domain |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
237 |
host_fqdn = fqdn(name, host_domain) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
238 |
|
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
239 |
yield ZoneRecord.PTR(ptr, host_fqdn) |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
240 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
241 |
def write_zone_records (file, zone) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
242 |
for r in zone : |
247
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
243 |
file.write(unicode(r)) |
08a63738f2d1
split pvl.dns-zone into pvl.dns.zone
Tero Marttila <terom@paivola.fi>
parents:
233
diff
changeset
|
244 |
file.write('\n') |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
245 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
246 |
def open_file (path, mode, charset) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
247 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
248 |
Open unicode-enabled file from path, with - using stdio. |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
249 |
""" |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
250 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
251 |
if path == '-' : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
252 |
# use stdin/out based on mode |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
253 |
stream, func = { |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
254 |
'r': (sys.stdin, codecs.getreader), |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
255 |
'w': (sys.stdout, codecs.getwriter), |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
256 |
}[mode[0]] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
257 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
258 |
# wrap |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
259 |
return func(charset)(stream) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
260 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
261 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
262 |
# open |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
263 |
return codecs.open(path, mode, charset) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
264 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
265 |
def main (argv) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
266 |
options, args = parse_options(argv) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
267 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
268 |
if args : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
269 |
# open files |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
270 |
input_files = [open_file(path, 'r', options.input_charset) for path in args] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
271 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
272 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
273 |
# default to stdout |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
274 |
input_files = [open_file('-', 'r', options.input_charset)] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
275 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
276 |
# process zone data |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
277 |
zone = [] |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
278 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
279 |
for file in input_files : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
280 |
log.info("Reading zone: %s", file) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
281 |
|
250
65f0272ce458
pvl.dns.zone: move to ZoneLine/Record.load(file)
Tero Marttila <terom@paivola.fi>
parents:
249
diff
changeset
|
282 |
zone += list(pvl.dns.zone.ZoneRecord.load(file, |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
283 |
line_timestamp_prefix = options.input_line_date, |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
284 |
)) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
285 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
286 |
# check? |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
287 |
if options.check_hosts : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
288 |
whitelist = set(options.check_exempt) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
289 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
290 |
log.debug("checking hosts; whitelist=%r", whitelist) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
291 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
292 |
if check_zone_hosts(zone, whitelist=whitelist) : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
293 |
log.warn("Hosts check failed") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
294 |
return 2 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
295 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
296 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
297 |
log.info("Hosts check OK") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
298 |
|
252 | 299 |
if options.serial : |
300 |
log.info("Set zone serial: %s", options.serial) |
|
301 |
||
302 |
zone = list(process_zone_serial(zone, serial=options.serial)) |
|
303 |
||
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
304 |
# output file |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
305 |
output = open_file(options.output, 'w', options.output_charset) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
306 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
307 |
if options.forward_zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
308 |
log.info("Write forward zone: %s", output) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
309 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
310 |
zone = list(process_zone_forwards(zone, txt=options.forward_txt, mx=options.forward_mx)) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
311 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
312 |
elif options.meta_zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
313 |
log.info("Write metadata zone: %s", output) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
314 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
315 |
if not options.input_line_date : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
316 |
log.error("--meta-zone requires --input-line-date") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
317 |
return 1 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
318 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
319 |
zone = list(process_zone_meta(zone, ignore=set(options.meta_ignore))) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
320 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
321 |
elif options.reverse_zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
322 |
if ':' in options.reverse_zone : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
323 |
# IPv6 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
324 |
origin = reverse_ipv6(options.reverse_zone) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
325 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
326 |
else : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
327 |
# IPv4 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
328 |
origin = reverse_ipv4(options.reverse_zone) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
329 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
330 |
domain = options.reverse_domain |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
331 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
332 |
if not domain : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
333 |
log.error("--reverse-zone requires --reverse-domain") |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
334 |
return 1 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
335 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
336 |
zone = list(process_zone_reverse(zone, origin=origin, domain=domain)) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
337 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
338 |
elif options.check_hosts : |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
339 |
# we only did that, done |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
340 |
return 0 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
341 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
342 |
else : |
249
8dfe61659b18
pvl.dns-zone: passthrough zone per default
Tero Marttila <terom@paivola.fi>
parents:
247
diff
changeset
|
343 |
# pass-through |
251
d250f200dd7e
fix process_generate for ZoneRecord.build
Tero Marttila <terom@paivola.fi>
parents:
250
diff
changeset
|
344 |
log.info("Passing through zonefile") |
233
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
345 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
346 |
write_zone_records(output, zone) |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
347 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
348 |
return 0 |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
349 |
|
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
350 |
if __name__ == '__main__': |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
351 |
import sys |
c4941645464c
import pvl.dns-* scripts from pvl-dns
Tero Marttila <terom@paivola.fi>
parents:
diff
changeset
|
352 |
sys.exit(main(sys.argv)) |