X7ROOT File Manager
Current Path:
/usr/lib64/python2.7/site-packages/dns
usr
/
lib64
/
python2.7
/
site-packages
/
dns
/
📁
..
📄
__init__.py
(1.3 KB)
📄
__init__.pyc
(765 B)
📄
__init__.pyo
(765 B)
📄
dnssec.py
(14.37 KB)
📄
dnssec.pyc
(13.46 KB)
📄
dnssec.pyo
(13.38 KB)
📄
e164.py
(3.01 KB)
📄
e164.pyc
(2.76 KB)
📄
e164.pyo
(2.76 KB)
📄
edns.py
(4.21 KB)
📄
edns.pyc
(5.2 KB)
📄
edns.pyo
(5.2 KB)
📄
entropy.py
(3.79 KB)
📄
entropy.pyc
(3.7 KB)
📄
entropy.pyo
(3.7 KB)
📄
exception.py
(1.29 KB)
📄
exception.pyc
(1.56 KB)
📄
exception.pyo
(1.56 KB)
📄
flags.py
(2.62 KB)
📄
flags.pyc
(2.58 KB)
📄
flags.pyo
(2.58 KB)
📄
grange.py
(1.83 KB)
📄
grange.pyc
(1.15 KB)
📄
grange.pyo
(1.08 KB)
📄
hash.py
(2.34 KB)
📄
hash.pyc
(2.11 KB)
📄
hash.pyo
(2.11 KB)
📄
inet.py
(3.16 KB)
📄
inet.pyc
(2.61 KB)
📄
inet.pyo
(2.61 KB)
📄
ipv4.py
(1.81 KB)
📄
ipv4.pyc
(1.37 KB)
📄
ipv4.pyo
(1.37 KB)
📄
ipv6.py
(4.97 KB)
📄
ipv6.pyc
(3.44 KB)
📄
ipv6.pyo
(3.44 KB)
📄
message.py
(41.63 KB)
📄
message.pyc
(36.39 KB)
📄
message.pyo
(36.39 KB)
📄
name.py
(21.82 KB)
📄
name.pyc
(23 KB)
📄
name.pyo
(23 KB)
📄
namedict.py
(2.06 KB)
📄
namedict.pyc
(1.92 KB)
📄
namedict.pyo
(1.92 KB)
📄
node.py
(5.89 KB)
📄
node.pyc
(6.15 KB)
📄
node.pyo
(6.15 KB)
📄
opcode.py
(2.55 KB)
📄
opcode.pyc
(2.49 KB)
📄
opcode.pyo
(2.49 KB)
📄
query.py
(17.89 KB)
📄
query.pyc
(15.31 KB)
📄
query.pyo
(15.31 KB)
📄
rcode.py
(3.03 KB)
📄
rcode.pyc
(2.92 KB)
📄
rcode.pyo
(2.92 KB)
📄
rdata.py
(15.34 KB)
📄
rdata.pyc
(16.59 KB)
📄
rdata.pyo
(16.59 KB)
📄
rdataclass.py
(3.22 KB)
📄
rdataclass.pyc
(2.96 KB)
📄
rdataclass.pyo
(2.96 KB)
📄
rdataset.py
(11.28 KB)
📄
rdataset.pyc
(11.08 KB)
📄
rdataset.pyo
(11.03 KB)
📄
rdatatype.py
(5.07 KB)
📄
rdatatype.pyc
(5.29 KB)
📄
rdatatype.pyo
(5.29 KB)
📁
rdtypes
📄
renderer.py
(11.63 KB)
📄
renderer.pyc
(10.85 KB)
📄
renderer.pyo
(10.75 KB)
📄
resolver.py
(45.35 KB)
📄
resolver.pyc
(37.16 KB)
📄
resolver.pyo
(37.16 KB)
📄
reversename.py
(3.03 KB)
📄
reversename.pyc
(2.4 KB)
📄
reversename.pyo
(2.4 KB)
📄
rrset.py
(5.76 KB)
📄
rrset.pyc
(6.17 KB)
📄
rrset.pyo
(6.17 KB)
📄
set.py
(7.66 KB)
📄
set.pyc
(9.81 KB)
📄
set.pyo
(9.81 KB)
📄
tokenizer.py
(17.54 KB)
📄
tokenizer.pyc
(16.92 KB)
📄
tokenizer.pyo
(16.92 KB)
📄
tsig.py
(8.1 KB)
📄
tsig.pyc
(8.08 KB)
📄
tsig.pyo
(8.08 KB)
📄
tsigkeyring.py
(1.61 KB)
📄
tsigkeyring.pyc
(1.16 KB)
📄
tsigkeyring.pyo
(1.16 KB)
📄
ttl.py
(2.13 KB)
📄
ttl.pyc
(1.48 KB)
📄
ttl.pyo
(1.48 KB)
📄
update.py
(9.92 KB)
📄
update.pyc
(8.27 KB)
📄
update.pyo
(8.27 KB)
📄
version.py
(1.24 KB)
📄
version.pyc
(560 B)
📄
version.pyo
(560 B)
📄
wiredata.py
(2.53 KB)
📄
wiredata.pyc
(2.19 KB)
📄
wiredata.pyo
(2.19 KB)
📄
zone.py
(37.94 KB)
📄
zone.pyc
(33.52 KB)
📄
zone.pyo
(33.52 KB)
Editing: node.py
# Copyright (C) 2001-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 nodes. A node is a set of rdatasets.""" import StringIO import dns.rdataset import dns.rdatatype import dns.renderer class Node(object): """A DNS node. A node is a set of rdatasets @ivar rdatasets: the node's rdatasets @type rdatasets: list of dns.rdataset.Rdataset objects""" __slots__ = ['rdatasets'] def __init__(self): """Initialize a DNS node. """ self.rdatasets = []; def to_text(self, name, **kw): """Convert a node to text format. Each rdataset at the node is printed. Any keyword arguments to this method are passed on to the rdataset's to_text() method. @param name: the owner name of the rdatasets @type name: dns.name.Name object @rtype: string """ s = StringIO.StringIO() for rds in self.rdatasets: if len(rds) > 0: print >> s, rds.to_text(name, **kw) return s.getvalue()[:-1] def __repr__(self): return '<DNS node ' + str(id(self)) + '>' def __eq__(self, other): """Two nodes are equal if they have the same rdatasets. @rtype: bool """ # # This is inefficient. Good thing we don't need to do it much. # for rd in self.rdatasets: if rd not in other.rdatasets: return False for rd in other.rdatasets: if rd not in self.rdatasets: return False return True def __ne__(self, other): return not self.__eq__(other) def __len__(self): return len(self.rdatasets) def __iter__(self): return iter(self.rdatasets) def find_rdataset(self, rdclass, rdtype, covers=dns.rdatatype.NONE, create=False): """Find an rdataset matching the specified properties in the current node. @param rdclass: The class of the rdataset @type rdclass: int @param rdtype: The type of the rdataset @type rdtype: int @param covers: The covered type. Usually this value is dns.rdatatype.NONE, but if the rdtype is dns.rdatatype.SIG or dns.rdatatype.RRSIG, then the covers value will be the rdata type the SIG/RRSIG covers. The library treats the SIG and RRSIG types as if they were a family of types, e.g. RRSIG(A), RRSIG(NS), RRSIG(SOA). This makes RRSIGs much easier to work with than if RRSIGs covering different rdata types were aggregated into a single RRSIG rdataset. @type covers: int @param create: If True, create the rdataset if it is not found. @type create: bool @raises KeyError: An rdataset of the desired type and class does not exist and I{create} is not True. @rtype: dns.rdataset.Rdataset object """ for rds in self.rdatasets: if rds.match(rdclass, rdtype, covers): return rds if not create: raise KeyError rds = dns.rdataset.Rdataset(rdclass, rdtype) self.rdatasets.append(rds) return rds def get_rdataset(self, rdclass, rdtype, covers=dns.rdatatype.NONE, create=False): """Get an rdataset matching the specified properties in the current node. None is returned if an rdataset of the specified type and class does not exist and I{create} is not True. @param rdclass: The class of the rdataset @type rdclass: int @param rdtype: The type of the rdataset @type rdtype: int @param covers: The covered type. @type covers: int @param create: If True, create the rdataset if it is not found. @type create: bool @rtype: dns.rdataset.Rdataset object or None """ try: rds = self.find_rdataset(rdclass, rdtype, covers, create) except KeyError: rds = None return rds def delete_rdataset(self, rdclass, rdtype, covers=dns.rdatatype.NONE): """Delete the rdataset matching the specified properties in the current node. If a matching rdataset does not exist, it is not an error. @param rdclass: The class of the rdataset @type rdclass: int @param rdtype: The type of the rdataset @type rdtype: int @param covers: The covered type. @type covers: int """ rds = self.get_rdataset(rdclass, rdtype, covers) if not rds is None: self.rdatasets.remove(rds) def replace_rdataset(self, replacement): """Replace an rdataset. It is not an error if there is no rdataset matching I{replacement}. Ownership of the I{replacement} object is transferred to the node; in other words, this method does not store a copy of I{replacement} at the node, it stores I{replacement} itself. """ if not isinstance(replacement, dns.rdataset.Rdataset): raise ValueError, 'replacement is not an rdataset' self.delete_rdataset(replacement.rdclass, replacement.rdtype, replacement.covers) self.rdatasets.append(replacement)
Upload File
Create Folder