PATH:
usr
/
lib64
/
python2.7
/
site-packages
/
dns
# Copyright (C) 2006, 2007, 2009-2011 Nominum, Inc. # # Permission to use, copy, modify, and distribute this software and its # documentation for any purpose with or without fee is hereby granted, # provided that the above copyright notice and this permission notice # appear in all copies. # # THE SOFTWARE IS PROVIDED "AS IS" AND NOMINUM DISCLAIMS ALL WARRANTIES # WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF # MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL NOMINUM BE LIABLE FOR # ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES # WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN # ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT # OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. """DNS Reverse Map Names. @var ipv4_reverse_domain: The DNS IPv4 reverse-map domain, in-addr.arpa. @type ipv4_reverse_domain: dns.name.Name object @var ipv6_reverse_domain: The DNS IPv6 reverse-map domain, ip6.arpa. @type ipv6_reverse_domain: dns.name.Name object """ import dns.name import dns.ipv6 import dns.ipv4 ipv4_reverse_domain = dns.name.from_text('in-addr.arpa.') ipv6_reverse_domain = dns.name.from_text('ip6.arpa.') def from_address(text): """Convert an IPv4 or IPv6 address in textual form into a Name object whose value is the reverse-map domain name of the address. @param text: an IPv4 or IPv6 address in textual form (e.g. '127.0.0.1', '::1') @type text: str @rtype: dns.name.Name object """ try: v6 = dns.ipv6.inet_aton(text) if dns.ipv6.is_mapped(v6): parts = ['%d' % ord(byte) for byte in v6[12:]] origin = ipv4_reverse_domain else: parts = list(v6.encode('hex_codec')) origin = ipv6_reverse_domain except: parts = ['%d' % ord(byte) for byte in dns.ipv4.inet_aton(text)] origin = ipv4_reverse_domain parts.reverse() return dns.name.from_text('.'.join(parts), origin=origin) def to_address(name): """Convert a reverse map domain name into textual address form. @param name: an IPv4 or IPv6 address in reverse-map form. @type name: dns.name.Name object @rtype: str """ if name.is_subdomain(ipv4_reverse_domain): name = name.relativize(ipv4_reverse_domain) labels = list(name.labels) labels.reverse() text = '.'.join(labels) # run through inet_aton() to check syntax and make pretty. return dns.ipv4.inet_ntoa(dns.ipv4.inet_aton(text)) elif name.is_subdomain(ipv6_reverse_domain): name = name.relativize(ipv6_reverse_domain) labels = list(name.labels) labels.reverse() parts = [] i = 0 l = len(labels) while i < l: parts.append(''.join(labels[i:i+4])) i += 4 text = ':'.join(parts) # run through inet_aton() to check syntax and make pretty. return dns.ipv6.inet_ntoa(dns.ipv6.inet_aton(text)) else: raise dns.exception.SyntaxError('unknown reverse-map address family')
[-] node.pyo
[edit]
[-] tokenizer.pyc
[edit]
[-] tokenizer.py
[edit]
[-] e164.pyc
[edit]
[-] rcode.pyc
[edit]
[-] rdataset.pyc
[edit]
[-] inet.pyc
[edit]
[-] __init__.pyo
[edit]
[-] rdataclass.pyo
[edit]
[-] edns.py
[edit]
[-] flags.py
[edit]
[-] tsig.py
[edit]
[-] update.pyo
[edit]
[-] edns.pyo
[edit]
[-] renderer.py
[edit]
[-] message.py
[edit]
[-] dnssec.py
[edit]
[-] query.py
[edit]
[-] ttl.pyc
[edit]
[-] opcode.py
[edit]
[-] rcode.pyo
[edit]
[+]
..
[-] reversename.py
[edit]
[-] tsig.pyo
[edit]
[-] rdatatype.pyc
[edit]
[-] dnssec.pyo
[edit]
[-] resolver.pyo
[edit]
[-] renderer.pyc
[edit]
[-] e164.pyo
[edit]
[-] rdataset.py
[edit]
[-] inet.pyo
[edit]
[-] rdatatype.py
[edit]
[-] query.pyo
[edit]
[-] zone.py
[edit]
[-] ipv6.py
[edit]
[-] __init__.pyc
[edit]
[-] namedict.py
[edit]
[-] hash.py
[edit]
[-] ipv6.pyo
[edit]
[-] grange.pyc
[edit]
[-] set.pyc
[edit]
[-] inet.py
[edit]
[-] exception.pyc
[edit]
[-] rdataclass.py
[edit]
[-] rrset.pyc
[edit]
[-] edns.pyc
[edit]
[-] zone.pyo
[edit]
[-] ttl.pyo
[edit]
[-] grange.pyo
[edit]
[-] dnssec.pyc
[edit]
[-] e164.py
[edit]
[-] message.pyc
[edit]
[-] rrset.pyo
[edit]
[-] entropy.pyo
[edit]
[-] flags.pyc
[edit]
[-] node.pyc
[edit]
[+]
rdtypes
[-] rdata.py
[edit]
[-] ipv4.pyo
[edit]
[-] hash.pyo
[edit]
[-] rdata.pyo
[edit]
[-] version.pyo
[edit]
[-] exception.py
[edit]
[-] tsigkeyring.pyc
[edit]
[-] rcode.py
[edit]
[-] rdata.pyc
[edit]
[-] wiredata.py
[edit]
[-] opcode.pyo
[edit]
[-] message.pyo
[edit]
[-] name.pyc
[edit]
[-] version.py
[edit]
[-] ttl.py
[edit]
[-] update.py
[edit]
[-] wiredata.pyc
[edit]
[-] grange.py
[edit]
[-] ipv6.pyc
[edit]
[-] tokenizer.pyo
[edit]
[-] name.py
[edit]
[-] version.pyc
[edit]
[-] namedict.pyc
[edit]
[-] hash.pyc
[edit]
[-] name.pyo
[edit]
[-] tsigkeyring.pyo
[edit]
[-] zone.pyc
[edit]
[-] renderer.pyo
[edit]
[-] set.py
[edit]
[-] resolver.py
[edit]
[-] rdataset.pyo
[edit]
[-] reversename.pyc
[edit]
[-] namedict.pyo
[edit]
[-] __init__.py
[edit]
[-] set.pyo
[edit]
[-] entropy.py
[edit]
[-] opcode.pyc
[edit]
[-] flags.pyo
[edit]
[-] resolver.pyc
[edit]
[-] ipv4.pyc
[edit]
[-] wiredata.pyo
[edit]
[-] ipv4.py
[edit]
[-] node.py
[edit]
[-] entropy.pyc
[edit]
[-] tsig.pyc
[edit]
[-] query.pyc
[edit]
[-] tsigkeyring.py
[edit]
[-] rdatatype.pyo
[edit]
[-] rdataclass.pyc
[edit]
[-] update.pyc
[edit]
[-] rrset.py
[edit]
[-] exception.pyo
[edit]
[-] reversename.pyo
[edit]