mirror of
https://github.com/samba-team/samba.git
synced 2025-01-25 06:04:04 +03:00
samba-tool:dns: Add support for reverse names (PTR records)
This commit is contained in:
parent
1eef73e776
commit
ecbc747ca5
@ -139,6 +139,8 @@ def dns_type_flag(rec_type):
|
|||||||
record_type = dnsp.DNS_TYPE_A
|
record_type = dnsp.DNS_TYPE_A
|
||||||
elif rtype == 'AAAA':
|
elif rtype == 'AAAA':
|
||||||
record_type = dnsp.DNS_TYPE_AAAA
|
record_type = dnsp.DNS_TYPE_AAAA
|
||||||
|
elif rtype == 'PTR':
|
||||||
|
record_type = dnsp.DNS_TYPE_PTR
|
||||||
elif rtype == 'NS':
|
elif rtype == 'NS':
|
||||||
record_type = dnsp.DNS_TYPE_NS
|
record_type = dnsp.DNS_TYPE_NS
|
||||||
elif rtype == 'CNAME':
|
elif rtype == 'CNAME':
|
||||||
@ -326,6 +328,10 @@ def print_dns_record(outf, rec):
|
|||||||
mesg = 'Unknown: '
|
mesg = 'Unknown: '
|
||||||
if rec.wType == dnsp.DNS_TYPE_A:
|
if rec.wType == dnsp.DNS_TYPE_A:
|
||||||
mesg = 'A: %s' % (rec.data)
|
mesg = 'A: %s' % (rec.data)
|
||||||
|
elif rec.wType == dnsp.DNS_TYPE_AAAA:
|
||||||
|
mesg = 'AAAA: %s' % (rec.data)
|
||||||
|
elif rec.wType == dnsp.DNS_TYPE_PTR:
|
||||||
|
mesg = 'PTR: %s' % (rec.data.str)
|
||||||
elif rec.wType == dnsp.DNS_TYPE_NS:
|
elif rec.wType == dnsp.DNS_TYPE_NS:
|
||||||
mesg = 'NS: %s' % (rec.data.str)
|
mesg = 'NS: %s' % (rec.data.str)
|
||||||
elif rec.wType == dnsp.DNS_TYPE_CNAME:
|
elif rec.wType == dnsp.DNS_TYPE_CNAME:
|
||||||
@ -376,6 +382,19 @@ class AAAARecord(dnsserver.DNS_RPC_RECORD):
|
|||||||
self.dwTtlSeconds = ttl
|
self.dwTtlSeconds = ttl
|
||||||
self.data = ip6_addr
|
self.data = ip6_addr
|
||||||
|
|
||||||
|
class PTRRecord(dnsserver.DNS_RPC_RECORD):
|
||||||
|
def __init__(self, ptr, serial=1, ttl=900, rank=dnsp.DNS_RANK_ZONE,
|
||||||
|
node_flag=0):
|
||||||
|
super(PTRRecord, self).__init__()
|
||||||
|
self.wType = dnsp.DNS_TYPE_PTR
|
||||||
|
self.dwFlags = rank | node_flag
|
||||||
|
self.dwSerial = serial
|
||||||
|
self.dwTtleSeconds = ttl
|
||||||
|
ptr_name = dnsserver.DNS_RPC_NAME()
|
||||||
|
ptr_name.str = ptr
|
||||||
|
ptr_name.len = len(ptr)
|
||||||
|
self.data = ptr_name
|
||||||
|
|
||||||
class CNameRecord(dnsserver.DNS_RPC_RECORD):
|
class CNameRecord(dnsserver.DNS_RPC_RECORD):
|
||||||
def __init__(self, cname, serial=1, ttl=900, rank=dnsp.DNS_RANK_ZONE,
|
def __init__(self, cname, serial=1, ttl=900, rank=dnsp.DNS_RANK_ZONE,
|
||||||
node_flag=0):
|
node_flag=0):
|
||||||
@ -471,11 +490,14 @@ def dns_record_match(dns_conn, server, zone, name, record_type, data):
|
|||||||
elif record_type == dnsp.DNS_TYPE_AAAA:
|
elif record_type == dnsp.DNS_TYPE_AAAA:
|
||||||
if rec_match.data == data:
|
if rec_match.data == data:
|
||||||
found = True
|
found = True
|
||||||
|
elif record_type == dnsp.DNS_TYPE_PTR:
|
||||||
|
if rec_match.data.str.rstrip('.') == data.rstrip('.'):
|
||||||
|
found = True
|
||||||
elif record_type == dnsp.DNS_TYPE_CNAME:
|
elif record_type == dnsp.DNS_TYPE_CNAME:
|
||||||
if rec_match.data == data:
|
if rec_match.data.str.rstrip('.') == data.rstrip('.'):
|
||||||
found = True
|
found = True
|
||||||
elif record_type == dnsp.DNS_TYPE_NS:
|
elif record_type == dnsp.DNS_TYPE_NS:
|
||||||
if rec_match.data == data:
|
if rec_match.data.str.rstrip('.') == data.rstrip('.'):
|
||||||
found = True
|
found = True
|
||||||
|
|
||||||
if found:
|
if found:
|
||||||
@ -717,7 +739,7 @@ class cmd_roothints(Command):
|
|||||||
class cmd_add_record(Command):
|
class cmd_add_record(Command):
|
||||||
"""Add a DNS record"""
|
"""Add a DNS record"""
|
||||||
|
|
||||||
synopsis = '%prog <server> <zone> <name> <A|AAAA|CNAME|NS> <data>'
|
synopsis = '%prog <server> <zone> <name> <A|AAAA|PTR|CNAME|NS> <data>'
|
||||||
|
|
||||||
takes_args = [ 'server', 'zone', 'name', 'rtype', 'data' ]
|
takes_args = [ 'server', 'zone', 'name', 'rtype', 'data' ]
|
||||||
|
|
||||||
@ -729,6 +751,8 @@ class cmd_add_record(Command):
|
|||||||
rec = ARecord(data)
|
rec = ARecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_AAAA:
|
elif record_type == dnsp.DNS_TYPE_AAAA:
|
||||||
rec = AAAARecord(data)
|
rec = AAAARecord(data)
|
||||||
|
elif record_type == dnsp.DNS_TYPE_PTR:
|
||||||
|
rec = PTRRecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_CNAME:
|
elif record_type == dnsp.DNS_TYPE_CNAME:
|
||||||
rec = CNameRecord(data)
|
rec = CNameRecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_NS:
|
elif record_type == dnsp.DNS_TYPE_NS:
|
||||||
@ -760,7 +784,7 @@ class cmd_add_record(Command):
|
|||||||
class cmd_update_record(Command):
|
class cmd_update_record(Command):
|
||||||
"""Update a DNS record"""
|
"""Update a DNS record"""
|
||||||
|
|
||||||
synopsis = '%prog <server> <zone> <name> <A|AAAA|CNAME|NS> <olddata> <newdata>'
|
synopsis = '%prog <server> <zone> <name> <A|AAAA|PTR|CNAME|NS> <olddata> <newdata>'
|
||||||
|
|
||||||
takes_args = [ 'server', 'zone', 'name', 'rtype', 'olddata', 'newdata' ]
|
takes_args = [ 'server', 'zone', 'name', 'rtype', 'olddata', 'newdata' ]
|
||||||
|
|
||||||
@ -772,6 +796,8 @@ class cmd_update_record(Command):
|
|||||||
rec = ARecord(newdata)
|
rec = ARecord(newdata)
|
||||||
elif record_type == dnsp.DNS_TYPE_AAAA:
|
elif record_type == dnsp.DNS_TYPE_AAAA:
|
||||||
rec = AAAARecord(newdata)
|
rec = AAAARecord(newdata)
|
||||||
|
elif record_type == dnsp.DNS_TYPE_PTR:
|
||||||
|
rec = PTRRecord(newdata)
|
||||||
elif record_type == dnsp.DNS_TYPE_CNAME:
|
elif record_type == dnsp.DNS_TYPE_CNAME:
|
||||||
rec = CNameRecord(newdata)
|
rec = CNameRecord(newdata)
|
||||||
elif record_type == dnsp.DNS_TYPE_NS:
|
elif record_type == dnsp.DNS_TYPE_NS:
|
||||||
@ -812,7 +838,7 @@ class cmd_update_record(Command):
|
|||||||
class cmd_delete_record(Command):
|
class cmd_delete_record(Command):
|
||||||
"""Delete a DNS record"""
|
"""Delete a DNS record"""
|
||||||
|
|
||||||
synopsis = '%prog <server> <zone> <name> <A|AAAA|CNAME|NS> <data>'
|
synopsis = '%prog <server> <zone> <name> <A|AAAA|PTR|CNAME|NS> <data>'
|
||||||
|
|
||||||
takes_args = [ 'server', 'zone', 'name', 'rtype', 'data' ]
|
takes_args = [ 'server', 'zone', 'name', 'rtype', 'data' ]
|
||||||
|
|
||||||
@ -824,6 +850,8 @@ class cmd_delete_record(Command):
|
|||||||
rec = ARecord(data)
|
rec = ARecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_AAAA:
|
elif record_type == dnsp.DNS_TYPE_AAAA:
|
||||||
rec = AAAARecord(data)
|
rec = AAAARecord(data)
|
||||||
|
elif record_type == dnsp.DNS_TYPE_PTR:
|
||||||
|
rec = PTRRecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_CNAME:
|
elif record_type == dnsp.DNS_TYPE_CNAME:
|
||||||
rec = CNameRecord(data)
|
rec = CNameRecord(data)
|
||||||
elif record_type == dnsp.DNS_TYPE_NS:
|
elif record_type == dnsp.DNS_TYPE_NS:
|
||||||
|
Loading…
x
Reference in New Issue
Block a user