summaryrefslogtreecommitdiff
path: root/ChangeLog
diff options
context:
space:
mode:
authorBob Halley <halley@nominum.com>2009-06-19 11:57:39 +0100
committerBob Halley <halley@nominum.com>2009-06-19 11:57:39 +0100
commitf6a2d3d27d0e093458a4f1eeff63f2493cd60a97 (patch)
tree0866a7ace589fafa0dcf71e7c22981ce55d1a2f7 /ChangeLog
parent066101a9d9e27d01c23850fff4720906322aa9ab (diff)
downloaddnspython-f6a2d3d27d0e093458a4f1eeff63f2493cd60a97.tar.gz
Add to_digestable() methods to rdata classes
Diffstat (limited to 'ChangeLog')
-rw-r--r--ChangeLog1012
1 files changed, 510 insertions, 502 deletions
diff --git a/ChangeLog b/ChangeLog
index 0b26bb7..48a5b43 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,956 +1,964 @@
2009-06-19 Bob Halley <halley@dnspython.org>
- * Added support for the HIP RR type.
+ * Added a to_digestable() method to rdata classes; it returns the
+ digestable form (i.e. DNSSEC canonical form) of the rdata. For
+ most rdata types this is the same uncompressed wire form. For
+ certain older DNS RR types, however, domain names in the rdata
+ are downcased.
+
+2009-06-19 Bob Halley <halley@dnspython.org>
+
+ * Added support for the HIP RR type.
2009-06-18 Bob Halley <halley@dnspython.org>
- * Added support for the DLV RR type.
+ * Added support for the DLV RR type.
2009-06-18 Bob Halley <halley@dnspython.org>
- * Added various DNSSEC related constants (e.g. algorithm identifiers,
- flag values).
+ * Added various DNSSEC related constants (e.g. algorithm identifiers,
+ flag values).
2009-06-18 Bob Halley <halley@dnspython.org>
- * dns/tsig.py: Added support for BADTRUNC result code.
+ * dns/tsig.py: Added support for BADTRUNC result code.
2009-06-18 Bob Halley <halley@dnspython.org>
- * dns/query.py (udp): When checking that addresses are the same,
- use the binary form of the address in the comparison. This
- ensures that we don't treat addresses as different if they have
- equivalent but differing textual representations. E.g. "1:00::1"
- and "1::1" represent the same address but are not textually equal.
- Thanks to Kim Davies for reporting this bug.
+ * dns/query.py (udp): When checking that addresses are the same,
+ use the binary form of the address in the comparison. This
+ ensures that we don't treat addresses as different if they have
+ equivalent but differing textual representations. E.g. "1:00::1"
+ and "1::1" represent the same address but are not textually equal.
+ Thanks to Kim Davies for reporting this bug.
2009-06-18 Bob Halley <halley@dnspython.org>
- * The resolver's query() method now has an optional 'source' parameter,
- allowing the source IP address to be specified. Thanks to
- Alexander Lind for suggesting the change and sending a patch.
+ * The resolver's query() method now has an optional 'source' parameter,
+ allowing the source IP address to be specified. Thanks to
+ Alexander Lind for suggesting the change and sending a patch.
2009-06-18 Bob Halley <halley@dnspython.org>
- * Added NSEC3 and NSEC3PARAM support.
+ * Added NSEC3 and NSEC3PARAM support.
2009-06-17 Bob Halley <halley@dnspython.org>
- * Fixed NSEC.to_text(), which was only printing the last window.
- Thanks to Brian Wellington for finding the problem and fixing it.
+ * Fixed NSEC.to_text(), which was only printing the last window.
+ Thanks to Brian Wellington for finding the problem and fixing it.
2009-03-30 Bob Halley <halley@dnspython.org>
- * dns/query.py (xfr): Allow UDP IXFRs. Use "one_rr_per_rrset" mode when
- doing IXFR.
+ * dns/query.py (xfr): Allow UDP IXFRs. Use "one_rr_per_rrset" mode when
+ doing IXFR.
2009-03-30 Bob Halley <halley@dnspython.org>
- * Add "one_rr_per_rrset" mode switch to methods which parse
- messages from wire format (e.g. dns.message.from_wire(),
- dns.query.udp(), dns.query.tcp()). If set, each RR read is
- placed in its own RRset (instead of being coalesced).
+ * Add "one_rr_per_rrset" mode switch to methods which parse
+ messages from wire format (e.g. dns.message.from_wire(),
+ dns.query.udp(), dns.query.tcp()). If set, each RR read is
+ placed in its own RRset (instead of being coalesced).
2009-03-30 Bob Halley <halley@dnspython.org>
- * Added EDNS option support.
+ * Added EDNS option support.
2008-10-16 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/DS.py: The from_text() parser for DS RRs did not
- allow multiple Base64 chunks. Thanks to Rakesh Banka for
- finding this bug and submitting a patch.
+ * dns/rdtypes/ANY/DS.py: The from_text() parser for DS RRs did not
+ allow multiple Base64 chunks. Thanks to Rakesh Banka for
+ finding this bug and submitting a patch.
2008-10-08 Bob Halley <halley@dnspython.org>
- * Add entropy module.
+ * Add entropy module.
- * When validating TSIGs, we need to use the absolute name.
+ * When validating TSIGs, we need to use the absolute name.
2008-06-03 Bob Halley <halley@dnspython.org>
- * dns/message.py (Message.set_rcode): The mask used preserved the
- extended rcode, instead of everything else in ednsflags.
+ * dns/message.py (Message.set_rcode): The mask used preserved the
+ extended rcode, instead of everything else in ednsflags.
- * dns/message.py (Message.use_edns): ednsflags was not kept
- coherent with the specified edns version.
+ * dns/message.py (Message.use_edns): ednsflags was not kept
+ coherent with the specified edns version.
2008-02-06 Bob Halley <halley@dnspython.org>
- * dns/ipv6.py (inet_aton): We could raise an exception other than
- dns.exception.SyntaxError in some cases.
+ * dns/ipv6.py (inet_aton): We could raise an exception other than
+ dns.exception.SyntaxError in some cases.
- * dns/tsig.py: Raise an exception when the peer has set a non-zero
- TSIG error.
+ * dns/tsig.py: Raise an exception when the peer has set a non-zero
+ TSIG error.
2007-11-25 Bob Halley <halley@dnspython.org>
- * (Version 1.6.0 released)
+ * (Version 1.6.0 released)
2007-11-25 Bob Halley <halley@dnspython.org>
- * dns/query.py (_wait_for): if select() raises an exception due to
- EINTR, we should just select() again.
+ * dns/query.py (_wait_for): if select() raises an exception due to
+ EINTR, we should just select() again.
2007-06-13 Bob Halley <halley@dnspython.org>
- * dns/inet.py: Added is_multicast().
+ * dns/inet.py: Added is_multicast().
- * dns/query.py (udp): If the queried address is a multicast address, then
- don't check that the address of the response is the same as the address
- queried.
+ * dns/query.py (udp): If the queried address is a multicast address, then
+ don't check that the address of the response is the same as the address
+ queried.
2007-05-24 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/IN/NAPTR.py: NAPTR comparisons didn't compare the
- preference field due to a typo.
+ * dns/rdtypes/IN/NAPTR.py: NAPTR comparisons didn't compare the
+ preference field due to a typo.
2007-02-07 Bob Halley <halley@dnspython.org>
- * dns/resolver.py: Integrate code submitted by Paul Marks to
- determine whether a Windows NIC is enabled. The way dnspython
- used to do this does not work on Windows Vista.
+ * dns/resolver.py: Integrate code submitted by Paul Marks to
+ determine whether a Windows NIC is enabled. The way dnspython
+ used to do this does not work on Windows Vista.
2006-12-10 Bob Halley <halley@dnspython.org>
- * (Version 1.5.0 released)
-
+ * (Version 1.5.0 released)
+
2006-11-03 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/IN/DHCID.py: Added support for the DHCID RR type.
+ * dns/rdtypes/IN/DHCID.py: Added support for the DHCID RR type.
2006-11-02 Bob Halley <halley@dnspython.org>
- * dns/query.py (udp): Messages from unexpected sources can now be
- ignored by setting ignore_unexpected to True.
+ * dns/query.py (udp): Messages from unexpected sources can now be
+ ignored by setting ignore_unexpected to True.
2006-10-31 Bob Halley <halley@dnspython.org>
- * dns/query.py (udp): When raising UnexpectedSource, add more
- detail about what went wrong to the exception.
+ * dns/query.py (udp): When raising UnexpectedSource, add more
+ detail about what went wrong to the exception.
2006-09-22 Bob Halley <halley@dnspython.org>
- * dns/message.py (Message.use_edns): add reasonable defaults for
- the ednsflags, payload, and request_payload parameters.
+ * dns/message.py (Message.use_edns): add reasonable defaults for
+ the ednsflags, payload, and request_payload parameters.
- * dns/message.py (Message.want_dnssec): add a convenience method for
- enabling/disabling the "DNSSEC desired" flag in requests.
+ * dns/message.py (Message.want_dnssec): add a convenience method for
+ enabling/disabling the "DNSSEC desired" flag in requests.
- * dns/message.py (make_query): add "use_edns" and "want_dnssec"
- parameters.
+ * dns/message.py (make_query): add "use_edns" and "want_dnssec"
+ parameters.
2006-08-17 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver.read_resolv_conf): If /etc/resolv.conf
- doesn't exist, just use the default resolver configuration (i.e.
- the same thing we would have used if resolv.conf had existed and
- been empty).
+ * dns/resolver.py (Resolver.read_resolv_conf): If /etc/resolv.conf
+ doesn't exist, just use the default resolver configuration (i.e.
+ the same thing we would have used if resolv.conf had existed and
+ been empty).
2006-07-26 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver._config_win32_fromkey): fix
- cut-and-paste error where we passed the wrong variable to
- self._config_win32_search(). Thanks to David Arnold for finding
- the bug and submitting a patch.
+ * dns/resolver.py (Resolver._config_win32_fromkey): fix
+ cut-and-paste error where we passed the wrong variable to
+ self._config_win32_search(). Thanks to David Arnold for finding
+ the bug and submitting a patch.
2006-07-20 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Answer): Add more support for the sequence
- protocol, forwarding requests to the answer object's rrset.
- E.g. "for a in answer" is equivalent to "for a in answer.rrset",
- "answer[i]" is equivalent to "answer.rrset[i]", and
- "answer[i:j]" is equivalent to "answer.rrset[i:j]".
+ * dns/resolver.py (Answer): Add more support for the sequence
+ protocol, forwarding requests to the answer object's rrset.
+ E.g. "for a in answer" is equivalent to "for a in answer.rrset",
+ "answer[i]" is equivalent to "answer.rrset[i]", and
+ "answer[i:j]" is equivalent to "answer.rrset[i:j]".
2006-07-19 Bob Halley <halley@dnspython.org>
- * dns/query.py (xfr): Add IXFR support.
+ * dns/query.py (xfr): Add IXFR support.
2006-06-22 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/IN/IPSECKEY.py: Added support for the IPSECKEY RR type.
+ * dns/rdtypes/IN/IPSECKEY.py: Added support for the IPSECKEY RR type.
2006-06-21 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/SPF.py: Added support for the SPF RR type.
+ * dns/rdtypes/ANY/SPF.py: Added support for the SPF RR type.
2006-06-02 Bob Halley <halley@dnspython.org>
- * (Version 1.4.0 released)
+ * (Version 1.4.0 released)
2006-04-25 Bob Halley <halley@dnspython.org>
- * dns/rrset.py (RRset.to_rdataset): Added a convenience method
- to convert an rrset into an rdataset.
+ * dns/rrset.py (RRset.to_rdataset): Added a convenience method
+ to convert an rrset into an rdataset.
2006-03-27 Bob Halley <halley@dnspython.org>
- * Added dns.e164.query(). This function can be used to look for
- NAPTR RRs for a specified number in several domains, e.g.:
+ * Added dns.e164.query(). This function can be used to look for
+ NAPTR RRs for a specified number in several domains, e.g.:
- dns.e164.query('16505551212',
- ['e164.dnspython.org.', 'e164.arpa.'])
+ dns.e164.query('16505551212',
+ ['e164.dnspython.org.', 'e164.arpa.'])
2006-03-26 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver.query): The resolver deleted from
- a list while iterating it, which makes the iterator unhappy.
+ * dns/resolver.py (Resolver.query): The resolver deleted from
+ a list while iterating it, which makes the iterator unhappy.
2006-03-17 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver.query): The resolver needlessly
- delayed responses for successful queries.
+ * dns/resolver.py (Resolver.query): The resolver needlessly
+ delayed responses for successful queries.
2006-01-18 Bob Halley <halley@dnspython.org>
- * dns/rdata.py: added a validate() method to the rdata class. If
- you change an rdata by assigning to its fields, it is a good
- idea to call validate() when you are done making changes.
- For example, if 'r' is an MX record and then you execute:
+ * dns/rdata.py: added a validate() method to the rdata class. If
+ you change an rdata by assigning to its fields, it is a good
+ idea to call validate() when you are done making changes.
+ For example, if 'r' is an MX record and then you execute:
- r.preference = 100000 # invalid, because > 65535
- r.validate()
+ r.preference = 100000 # invalid, because > 65535
+ r.validate()
- The validation will fail and an exception will be raised.
+ The validation will fail and an exception will be raised.
2006-01-11 Bob Halley <halley@dnspython.org>
- * dns/ttl.py: TTLs are now bounds checked to be within the closed
- interval [0, 2^31 - 1].
+ * dns/ttl.py: TTLs are now bounds checked to be within the closed
+ interval [0, 2^31 - 1].
- * The BIND 8 TTL syntax is now accepted in the SOA refresh, retry,
- expire, and minimum fields, and in the original_ttl field of
- SIG and RRSIG records.
+ * The BIND 8 TTL syntax is now accepted in the SOA refresh, retry,
+ expire, and minimum fields, and in the original_ttl field of
+ SIG and RRSIG records.
2006-01-04 Bob Halley <halley@dnspython.org>
- * dns/resolver.py: The windows registry irritatingly changes the
- list element delimiter in between ' ' and ',' (and vice-versa)
- in various versions of windows. We now cope by always looking
- for either one (' ' first).
+ * dns/resolver.py: The windows registry irritatingly changes the
+ list element delimiter in between ' ' and ',' (and vice-versa)
+ in various versions of windows. We now cope by always looking
+ for either one (' ' first).
2005-12-27 Bob Halley <halley@dnspython.org>
- * dns/e164.py: Added routines to convert between E.164 numbers and
- their ENUM domain name equivalents.
+ * dns/e164.py: Added routines to convert between E.164 numbers and
+ their ENUM domain name equivalents.
- * dns/reversename.py: Added routines to convert between IPv4 and
- IPv6 addresses and their DNS reverse-map equivalents.
+ * dns/reversename.py: Added routines to convert between IPv4 and
+ IPv6 addresses and their DNS reverse-map equivalents.
2005-12-18 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/LOC.py (_tuple_to_float): The sign was lost when
- converting a tuple into a float, which broke conversions of
- south latitudes and west longitudes.
+ * dns/rdtypes/ANY/LOC.py (_tuple_to_float): The sign was lost when
+ converting a tuple into a float, which broke conversions of
+ south latitudes and west longitudes.
2005-11-17 Bob Halley <halley@dnspython.org>
- * dns/zone.py: The 'origin' parameter to from_text() and from_file()
- is now optional. If not specified, dnspython will use the
- first $ORIGIN in the text as the zone's origin.
+ * dns/zone.py: The 'origin' parameter to from_text() and from_file()
+ is now optional. If not specified, dnspython will use the
+ first $ORIGIN in the text as the zone's origin.
- * dns/zone.py: Sanity checks of the zone's origin node can now
- be disabled.
+ * dns/zone.py: Sanity checks of the zone's origin node can now
+ be disabled.
2005-11-12 Bob Halley <halley@dnspython.org>
- * dns/name.py: Preliminary Unicode support has been added for
- domain names. Running dns.name.from_text() on a Unicode string
- will now encode each label using the IDN ACE encoding. The
- to_unicode() method may be used to convert a dns.name.Name with
- IDN ACE labels back into a Unicode string. This functionality
- requires Python 2.3 or greater.
+ * dns/name.py: Preliminary Unicode support has been added for
+ domain names. Running dns.name.from_text() on a Unicode string
+ will now encode each label using the IDN ACE encoding. The
+ to_unicode() method may be used to convert a dns.name.Name with
+ IDN ACE labels back into a Unicode string. This functionality
+ requires Python 2.3 or greater.
2005-10-31 Bob Halley <halley@dnspython.org>
- * (Version 1.3.5 released)
+ * (Version 1.3.5 released)
2005-10-12 Bob Halley <halley@dnspython.org>
- * dns/zone.py: Zone.iterate_rdatasets() and Zone.iterate_rdatas()
- did not have a default rdtype of dns.rdatatype.ANY as their
- docstrings said they did. They do now.
+ * dns/zone.py: Zone.iterate_rdatasets() and Zone.iterate_rdatas()
+ did not have a default rdtype of dns.rdatatype.ANY as their
+ docstrings said they did. They do now.
2005-10-06 Bob Halley <halley@dnspython.org>
- * dns/name.py: Added the parent() method, which returns the
- parent of a name.
+ * dns/name.py: Added the parent() method, which returns the
+ parent of a name.
2005-10-01 Bob Halley <halley@dnspython.org>
- * dns/resolver.py: Added zone_for_name() helper, which returns
- the name of the zone which contains the specified name.
+ * dns/resolver.py: Added zone_for_name() helper, which returns
+ the name of the zone which contains the specified name.
- * dns/resolver.py: Added get_default_resolver(), which returns
- the default resolver, initializing it if necessary.
+ * dns/resolver.py: Added get_default_resolver(), which returns
+ the default resolver, initializing it if necessary.
2005-09-29 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver._compute_timeout): If time goes
- backwards a little bit, ignore it.
+ * dns/resolver.py (Resolver._compute_timeout): If time goes
+ backwards a little bit, ignore it.
2005-07-31 Bob Halley <halley@dnspython.org>
- * (Version 1.3.4 released)
+ * (Version 1.3.4 released)
2005-07-31 Bob Halley <halley@dnspython.org>
- * dns/message.py (make_response): Trying to respond to a response
- threw a NameError while trying to throw a FormErr since it used
- the wrong name for the FormErr exception.
+ * dns/message.py (make_response): Trying to respond to a response
+ threw a NameError while trying to throw a FormErr since it used
+ the wrong name for the FormErr exception.
- * dns/query.py (_connect): We needed to ignore EALREADY too.
+ * dns/query.py (_connect): We needed to ignore EALREADY too.
- * dns/query.py: Optional "source" and "source_port" parameters
- have been added to udp(), tcp(), and xfr(). Thanks to Ralf
- Weber for suggesting the change and providing a patch.
+ * dns/query.py: Optional "source" and "source_port" parameters
+ have been added to udp(), tcp(), and xfr(). Thanks to Ralf
+ Weber for suggesting the change and providing a patch.
2005-06-05 Bob Halley <halley@dnspython.org>
- * dns/query.py: The requirement that the "where" parameter be
- an IPv4 or IPv6 address is now documented.
+ * dns/query.py: The requirement that the "where" parameter be
+ an IPv4 or IPv6 address is now documented.
2005-06-04 Bob Halley <halley@dnspython.org>
- * dns/resolver.py: The resolver now does exponential backoff
- each time it runs through all of the nameservers.
+ * dns/resolver.py: The resolver now does exponential backoff
+ each time it runs through all of the nameservers.
- * dns/resolver.py: rcodes which indicate a nameserver is likely
- to be a "permanent failure" for a query cause the nameserver
- to be removed from the mix for that query.
+ * dns/resolver.py: rcodes which indicate a nameserver is likely
+ to be a "permanent failure" for a query cause the nameserver
+ to be removed from the mix for that query.
2005-01-30 Bob Halley <halley@dnspython.org>
- * (Version 1.3.3 released)
+ * (Version 1.3.3 released)
2004-10-25 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/TXT.py (TXT.from_text): The masterfile parser
- incorrectly rejected TXT records where a value was not quoted.
+ * dns/rdtypes/ANY/TXT.py (TXT.from_text): The masterfile parser
+ incorrectly rejected TXT records where a value was not quoted.
2004-10-11 Bob Halley <halley@dnspython.org>
- * dns/message.py: Added make_response(), which creates a skeletal
- response for the specified query. Added opcode() and set_opcode()
- convenience methods to the Message class. Added the request_payload
- attribute to the Message class.
+ * dns/message.py: Added make_response(), which creates a skeletal
+ response for the specified query. Added opcode() and set_opcode()
+ convenience methods to the Message class. Added the request_payload
+ attribute to the Message class.
2004-10-10 Bob Halley <halley@dnspython.org>
- * dns/zone.py (from_xfr): dns.zone.from_xfr() in relativization
- mode incorrectly set zone.origin to the empty name.
+ * dns/zone.py (from_xfr): dns.zone.from_xfr() in relativization
+ mode incorrectly set zone.origin to the empty name.
2004-09-02 Bob Halley <halley@dnspython.org>
- * dns/name.py (Name.to_wire): The 'file' parameter to
- Name.to_wire() is now optional; if omitted, the wire form will
- be returned as the value of the function.
+ * dns/name.py (Name.to_wire): The 'file' parameter to
+ Name.to_wire() is now optional; if omitted, the wire form will
+ be returned as the value of the function.
2004-08-14 Bob Halley <halley@dnspython.org>
- * dns/message.py (Message.find_rrset): find_rrset() now uses an
- index, vastly improving the from_wire() performance of large
- messages such as zone transfers.
+ * dns/message.py (Message.find_rrset): find_rrset() now uses an
+ index, vastly improving the from_wire() performance of large
+ messages such as zone transfers.
2004-08-07 Bob Halley <halley@dnspython.org>
- * (Version 1.3.2 released)
+ * (Version 1.3.2 released)
2004-08-04 Bob Halley <halley@dnspython.org>
- * dns/query.py: sending queries to a nameserver via IPv6 now
- works.
-
- * dns/inet.py (af_for_address): Add af_for_address(), which looks
- at a textual-form address and attempts to determine which address
- family it is.
+ * dns/query.py: sending queries to a nameserver via IPv6 now
+ works.
+
+ * dns/inet.py (af_for_address): Add af_for_address(), which looks
+ at a textual-form address and attempts to determine which address
+ family it is.
- * dns/query.py: the default for the 'af' parameter of the udp(),
- tcp(), and xfr() functions has been changed from AF_INET to None,
- which causes dns.inet.af_for_address() to be used to determine the
- address family. If dns.inet.af_for_address() can't figure it out,
- we fall back to AF_INET and hope for the best.
+ * dns/query.py: the default for the 'af' parameter of the udp(),
+ tcp(), and xfr() functions has been changed from AF_INET to None,
+ which causes dns.inet.af_for_address() to be used to determine the
+ address family. If dns.inet.af_for_address() can't figure it out,
+ we fall back to AF_INET and hope for the best.
2004-07-31 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/NSEC.py (NSEC.from_text): The NSEC text format
- does not allow specifying types by number, so we shouldn't either.
+ * dns/rdtypes/ANY/NSEC.py (NSEC.from_text): The NSEC text format
+ does not allow specifying types by number, so we shouldn't either.
- * dns/renderer.py: the renderer module didn't import random,
- causing an exception to be raised if a query id wasn't provided
- when a Renderer was created.
+ * dns/renderer.py: the renderer module didn't import random,
+ causing an exception to be raised if a query id wasn't provided
+ when a Renderer was created.
- * dns/resolver.py (Resolver.query): the resolver wasn't catching
- dns.exception.Timeout, so a timeout erroneously caused the whole
- resolution to fail instead of just going on to the next server.
+ * dns/resolver.py (Resolver.query): the resolver wasn't catching
+ dns.exception.Timeout, so a timeout erroneously caused the whole
+ resolution to fail instead of just going on to the next server.
2004-06-16 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/LOC.py (LOC.from_text): LOC milliseconds values
- were converted incorrectly if the length of the milliseconds
- string was less than 3.
+ * dns/rdtypes/ANY/LOC.py (LOC.from_text): LOC milliseconds values
+ were converted incorrectly if the length of the milliseconds
+ string was less than 3.
2004-06-06 Bob Halley <halley@dnspython.org>
- * (Version 1.3.1 released)
+ * (Version 1.3.1 released)
2004-05-22 Bob Halley <halley@dnspython.org>
- * dns/update.py (Update.delete): We erroneously specified a
- "deleting" value of dns.rdatatype.NONE instead of
- dns.rdataclass.NONE when the thing being deleted was either an
- Rdataset instance or an Rdata instance.
+ * dns/update.py (Update.delete): We erroneously specified a
+ "deleting" value of dns.rdatatype.NONE instead of
+ dns.rdataclass.NONE when the thing being deleted was either an
+ Rdataset instance or an Rdata instance.
- * dns/rdtypes/ANY/SSHFP.py: Added support for the proposed SSHFP
- RR type.
+ * dns/rdtypes/ANY/SSHFP.py: Added support for the proposed SSHFP
+ RR type.
2004-05-14 Bob Halley <halley@dnspython.org>
- * dns/rdata.py (from_text): The masterfile reader did not
- accept the unknown RR syntax when used with a known RR type.
+ * dns/rdata.py (from_text): The masterfile reader did not
+ accept the unknown RR syntax when used with a known RR type.
2004-05-08 Bob Halley <halley@dnspython.org>
- * dns/name.py (from_text): dns.name.from_text() did not raise
- an exception if a backslash escape ended prematurely.
+ * dns/name.py (from_text): dns.name.from_text() did not raise
+ an exception if a backslash escape ended prematurely.
2004-04-09 Bob Halley <halley@dnspython.org>
- * dns/zone.py (_MasterReader._rr_line): The masterfile reader
- erroneously treated lines starting with leading whitespace but
- not having any RR definition as an error. It now treats
- them like a blank line (which is not an error).
+ * dns/zone.py (_MasterReader._rr_line): The masterfile reader
+ erroneously treated lines starting with leading whitespace but
+ not having any RR definition as an error. It now treats
+ them like a blank line (which is not an error).
2004-04-01 Bob Halley <halley@dnspython.org>
-
- * (Version 1.3.0 released)
+
+ * (Version 1.3.0 released)
2004-03-19 Bob Halley <halley@dnspython.org>
- * Added support for new DNSSEC types RRSIG, NSEC, and DNSKEY.
+ * Added support for new DNSSEC types RRSIG, NSEC, and DNSKEY.
2004-01-16 Bob Halley <halley@dnspython.org>
- * dns/query.py (_connect): Windows returns EWOULDBLOCK instead
- of EINPROGRESS when trying to connect a nonblocking socket.
+ * dns/query.py (_connect): Windows returns EWOULDBLOCK instead
+ of EINPROGRESS when trying to connect a nonblocking socket.
2003-11-13 Bob Halley <halley@dnspython.org>
- * dns/rdtypes/ANY/LOC.py (LOC.to_wire): We encoded and decoded LOC
- incorrectly, since we were interpreting the values of altitiude,
- size, hprec, and vprec in meters instead of centimeters.
+ * dns/rdtypes/ANY/LOC.py (LOC.to_wire): We encoded and decoded LOC
+ incorrectly, since we were interpreting the values of altitiude,
+ size, hprec, and vprec in meters instead of centimeters.
- * dns/rdtypes/IN/WKS.py (WKS.from_wire): The WKS protocol value is
- encoded with just one octet, not two!
+ * dns/rdtypes/IN/WKS.py (WKS.from_wire): The WKS protocol value is
+ encoded with just one octet, not two!
2003-11-09 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Cache.maybe_clean): The cleaner deleted items
- from the dictionary while iterating it, causing a RuntimeError
- to be raised. Thanks to Mark R. Levinson for the bug report,
- regression test, and fix.
+ * dns/resolver.py (Cache.maybe_clean): The cleaner deleted items
+ from the dictionary while iterating it, causing a RuntimeError
+ to be raised. Thanks to Mark R. Levinson for the bug report,
+ regression test, and fix.
2003-11-07 Bob Halley <halley@dnspython.org>
- * (Version 1.2.0 released)
+ * (Version 1.2.0 released)
2003-11-03 Bob Halley <halley@dnspython.org>
- * dns/zone.py (_MasterReader.read): The saved_state now includes
- the default TTL.
+ * dns/zone.py (_MasterReader.read): The saved_state now includes
+ the default TTL.
2003-11-01 Bob Halley <halley@dnspython.org>
- * dns/tokenizer.py (Tokenizer.get): The tokenizer didn't
- handle escaped delimiters.
+ * dns/tokenizer.py (Tokenizer.get): The tokenizer didn't
+ handle escaped delimiters.
2003-10-27 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver.read_resolv_conf): If no nameservers
- are configured in /etc/resolv.conf, the default nameserver
- list should be ['127.0.0.1'].
+ * dns/resolver.py (Resolver.read_resolv_conf): If no nameservers
+ are configured in /etc/resolv.conf, the default nameserver
+ list should be ['127.0.0.1'].
2003-09-08 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver._config_win32_fromkey): We didn't
- catch WindowsError, which can happen if a key is not defined
- in the registry.
+ * dns/resolver.py (Resolver._config_win32_fromkey): We didn't
+ catch WindowsError, which can happen if a key is not defined
+ in the registry.
2003-09-06 Bob Halley <halley@dnspython.org>
- * (Version 1.2.0b1 released)
-
+ * (Version 1.2.0b1 released)
+
2003-09-05 Bob Halley <halley@dnspython.org>
- * dns/query.py: Timeout support has been overhauled to provide
- timeouts under Python 2.2 as well as 2.3, and to provide more
- accurate expiration.
+ * dns/query.py: Timeout support has been overhauled to provide
+ timeouts under Python 2.2 as well as 2.3, and to provide more
+ accurate expiration.
2003-08-30 Bob Halley <halley@dnspython.org>
- * dns/zone.py: dns.exception.SyntaxError is raised for unknown
- master file directives.
+ * dns/zone.py: dns.exception.SyntaxError is raised for unknown
+ master file directives.
2003-08-28 Bob Halley <halley@dnspython.org>
- * dns/zone.py: $INCLUDE processing is now enabled/disabled using
- the allow_include parameter. The default is to process $INCLUDE
- for from_file(), and to disallow $INCLUDE for from_text(). The
- master reader now calls zone.check_origin_node() by default after
- the zone has been read. find_rdataset() called get_node() instead
- of find_node(), which result in an incorrect exception. The
- relativization state of a zone is now remembered and applied
- consistently when looking up names. from_xfr() now supports
- relativization like the _MasterReader.
+ * dns/zone.py: $INCLUDE processing is now enabled/disabled using
+ the allow_include parameter. The default is to process $INCLUDE
+ for from_file(), and to disallow $INCLUDE for from_text(). The
+ master reader now calls zone.check_origin_node() by default after
+ the zone has been read. find_rdataset() called get_node() instead
+ of find_node(), which result in an incorrect exception. The
+ relativization state of a zone is now remembered and applied
+ consistently when looking up names. from_xfr() now supports
+ relativization like the _MasterReader.
2003-08-22 Bob Halley <halley@dnspython.org>
- * dns/zone.py: The _MasterReader now understands $INCLUDE.
+ * dns/zone.py: The _MasterReader now understands $INCLUDE.
2003-08-12 Bob Halley <halley@dnspython.org>
- * dns/zone.py: The _MasterReader now specifies the file and line
- number when a syntax error occurs. The BIND 8 TTL format is now
- understood when loading a zone, though it will never be emitted.
- The from_file() function didn't pass the zone_factory parameter
- to from_text().
+ * dns/zone.py: The _MasterReader now specifies the file and line
+ number when a syntax error occurs. The BIND 8 TTL format is now
+ understood when loading a zone, though it will never be emitted.
+ The from_file() function didn't pass the zone_factory parameter
+ to from_text().
2003-08-10 Bob Halley <halley@dnspython.org>
- * (Version 1.1.0 released)
+ * (Version 1.1.0 released)
2003-08-07 Bob Halley <halley@dnspython.org>
- * dns/update.py (Update._add): A typo meant that _add would
- fail if the thing being added was an Rdata object (as
- opposed to an Rdataset or the textual form of an Rdata).
+ * dns/update.py (Update._add): A typo meant that _add would
+ fail if the thing being added was an Rdata object (as
+ opposed to an Rdataset or the textual form of an Rdata).
2003-08-05 Bob Halley <halley@dnspython.org>
- * dns/set.py: the simple Set class has been moved to its
- own module, and augmented to support more set operations.
+ * dns/set.py: the simple Set class has been moved to its
+ own module, and augmented to support more set operations.
2003-08-04 Bob Halley <halley@dnspython.org>
- * Node and all rdata types have been "slotted". This speeds
- things up a little and reduces memory usage noticeably.
+ * Node and all rdata types have been "slotted". This speeds
+ things up a little and reduces memory usage noticeably.
2003-08-02 Bob Halley <halley@dnspython.org>
- * (Version 1.1.0c1 released)
+ * (Version 1.1.0c1 released)
2003-08-02 Bob Halley <halley@dnspython.org>
- * dns/rdataset.py: SimpleSets now support more set options.
-
- * dns/message.py: Added the get_rrset() method. from_file() now
- allows Unicode filenames and turns on universal newline support if
- it opens the file itself.
+ * dns/rdataset.py: SimpleSets now support more set options.
+
+ * dns/message.py: Added the get_rrset() method. from_file() now
+ allows Unicode filenames and turns on universal newline support if
+ it opens the file itself.
- * dns/node.py: Added the delete_rdataset() and replace_rdataset()
- methods.
+ * dns/node.py: Added the delete_rdataset() and replace_rdataset()
+ methods.
- * dns/zone.py: Added the delete_node(), delete_rdataset(), and
- replace_rdataset() methods. from_file() now allows Unicode
- filenames and turns on universal newline support if it opens the
- file itself. Added a to_file() method.
+ * dns/zone.py: Added the delete_node(), delete_rdataset(), and
+ replace_rdataset() methods. from_file() now allows Unicode
+ filenames and turns on universal newline support if it opens the
+ file itself. Added a to_file() method.
2003-08-01 Bob Halley <halley@dnspython.org>
- * dns/opcode.py: Opcode from/to text converters now understand
- numeric opcodes. The to_text() method will return a numeric opcode
- string if it doesn't know a text name for the opcode.
-
- * dns/message.py: Added set_rcode(). Fixed code where ednsflags
- wasn't treated as a long.
+ * dns/opcode.py: Opcode from/to text converters now understand
+ numeric opcodes. The to_text() method will return a numeric opcode
+ string if it doesn't know a text name for the opcode.
+
+ * dns/message.py: Added set_rcode(). Fixed code where ednsflags
+ wasn't treated as a long.
- * dns/rcode.py: ednsflags wasn't treated as a long. Rcode from/to
- text converters now understand numeric rcodes. The to_text()
- method will return a numeric rcode string if it doesn't know
- a text name for the rcode.
+ * dns/rcode.py: ednsflags wasn't treated as a long. Rcode from/to
+ text converters now understand numeric rcodes. The to_text()
+ method will return a numeric rcode string if it doesn't know
+ a text name for the rcode.
- * examples/reverse.py: Added a new example program that builds a
- reverse (address-to-name) mapping table from the name-to-address
- mapping specified by A RRs in zone files.
+ * examples/reverse.py: Added a new example program that builds a
+ reverse (address-to-name) mapping table from the name-to-address
+ mapping specified by A RRs in zone files.
- * dns/node.py: Added get_rdataset() method.
+ * dns/node.py: Added get_rdataset() method.
- * dns/zone.py: Added get_rdataset() and get_rrset() methods. Added
- iterate_rdatas().
+ * dns/zone.py: Added get_rdataset() and get_rrset() methods. Added
+ iterate_rdatas().
2003-07-31 Bob Halley <halley@dnspython.org>
- * dns/zone.py: Added the iterate_rdatasets() method which returns
- a generator which yields (name, rdataset) tuples for all the
- rdatasets in the zone matching the specified rdatatype.
+ * dns/zone.py: Added the iterate_rdatasets() method which returns
+ a generator which yields (name, rdataset) tuples for all the
+ rdatasets in the zone matching the specified rdatatype.
2003-07-30 Bob Halley <halley@dnspython.org>
- * (Version 1.1.0b2 released)
+ * (Version 1.1.0b2 released)
2003-07-30 Bob Halley <halley@dnspython.org>
- * dns/zone.py: Added find_rrset() and find_rdataset() convenience
- methods. They let you retrieve rdata with the specified name
- and type in one call.
+ * dns/zone.py: Added find_rrset() and find_rdataset() convenience
+ methods. They let you retrieve rdata with the specified name
+ and type in one call.
- * dns/node.py: Nodes no longer have names; owner names are
- associated with nodes in the Zone object's nodes dictionary.
+ * dns/node.py: Nodes no longer have names; owner names are
+ associated with nodes in the Zone object's nodes dictionary.
- * dns/zone.py: Zone objects now implement more of the standard
- mapping interface. __iter__ has been changed to iterate the keys
- rather than values to match the standard mapping interface's
- behavior.
+ * dns/zone.py: Zone objects now implement more of the standard
+ mapping interface. __iter__ has been changed to iterate the keys
+ rather than values to match the standard mapping interface's
+ behavior.
2003-07-20 Bob Halley <halley@dnspython.org>
- * dns/ipv6.py (inet_ntoa): Handle embedded IPv4 addresses.
+ * dns/ipv6.py (inet_ntoa): Handle embedded IPv4 addresses.
2003-07-19 Bob Halley <halley@dnspython.org>
- * (Version 1.1.0b1 released)
+ * (Version 1.1.0b1 released)
2003-07-18 Bob Halley <halley@dnspython.org>
- * dns/tsig.py: The TSIG validation of TCP streams where not
- every message is signed now works correctly.
+ * dns/tsig.py: The TSIG validation of TCP streams where not
+ every message is signed now works correctly.
- * dns/zone.py: Zones can now be compared for equality and
- inequality. If the other object in the comparison is also
- a zone, then "the right thing" happens; i.e. the zones are
- equal iff.: they have the same rdclass, origin, and nodes.
+ * dns/zone.py: Zones can now be compared for equality and
+ inequality. If the other object in the comparison is also
+ a zone, then "the right thing" happens; i.e. the zones are
+ equal iff.: they have the same rdclass, origin, and nodes.
2003-07-17 Bob Halley <halley@dnspython.org>
- * dns/message.py (Message.use_tsig): The method now allows for
- greater control over the various fields in the generated signature
- (e.g. fudge).
- (_WireReader._get_section): UnknownTSIGKey is now raised if an
- unknown key is encountered, or if a signed message has no keyring.
+ * dns/message.py (Message.use_tsig): The method now allows for
+ greater control over the various fields in the generated signature
+ (e.g. fudge).
+ (_WireReader._get_section): UnknownTSIGKey is now raised if an
+ unknown key is encountered, or if a signed message has no keyring.
2003-07-16 Bob Halley <halley@dnspython.org>
- * dns/tokenizer.py (Tokenizer._get_char): get_char and unget_char
- have been renamed to _get_char and _unget_char since they are not
- useful to clients of the tokenizer.
+ * dns/tokenizer.py (Tokenizer._get_char): get_char and unget_char
+ have been renamed to _get_char and _unget_char since they are not
+ useful to clients of the tokenizer.
2003-07-15 Bob Halley <halley@dnspython.org>
- * dns/zone.py (_MasterReader._rr_line): owner names were being
- unconditionally relativized; it makes much more sense for them
- to be relativized according to the relativization setting of
- the reader.
+ * dns/zone.py (_MasterReader._rr_line): owner names were being
+ unconditionally relativized; it makes much more sense for them
+ to be relativized according to the relativization setting of
+ the reader.
2003-07-12 Bob Halley <halley@dnspython.org>
- * dns/resolver.py (Resolver.read_resolv_conf): The resolv.conf
- parser did not allow blank / whitespace-only lines, nor did it
- allow comments. Both are now supported.
+ * dns/resolver.py (Resolver.read_resolv_conf): The resolv.conf
+ parser did not allow blank / whitespace-only lines, nor did it
+ allow comments. Both are now supported.
2003-07-11 Bob Halley <halley@dnspython.org>
- * dns/name.py (Name.to_digestable): to_digestable() now
- requires an origin to be specified if the name is relative.
- It will raise NeedAbsoluteNameOrOrigin if the name is
- relative and there is either no origin or the origin is
- itself relative.
- (Name.split): returned the wrong answer if depth was 0 or depth
- was the length of the name. split() now does bounds checking
- on depth, and raises ValueError if depth < 0 or depth > the length
- of the name.
+ * dns/name.py (Name.to_digestable): to_digestable() now
+ requires an origin to be specified if the name is relative.
+ It will raise NeedAbsoluteNameOrOrigin if the name is
+ relative and there is either no origin or the origin is
+ itself relative.
+ (Name.split): returned the wrong answer if depth was 0 or depth
+ was the length of the name. split() now does bounds checking
+ on depth, and raises ValueError if depth < 0 or depth > the length
+ of the name.
2003-07-10 Bob Halley <halley@dnspython.org>
- * dns/ipv6.py (inet_ntoa): The routine now minimizes its output
- strings. E.g. the IPv6 address
- "0000:0000:0000:0000:0000:0000:0000:0001" is minimized to "::1".
- We do not, however, make any effort to display embedded IPv4
- addresses in the dot-quad notation.
+ * dns/ipv6.py (inet_ntoa): The routine now minimizes its output
+ strings. E.g. the IPv6 address
+ "0000:0000:0000:0000:0000:0000:0000:0001" is minimized to "::1".
+ We do not, however, make any effort to display embedded IPv4
+ addresses in the dot-quad notation.
2003-07-09 Bob Halley <halley@dnspython.org>
- * dns/inet.py: We now supply our own AF_INET and AF_INET6
- constants since AF_INET6 may not always be available. If the
- socket module has AF_INET6, we will use it. If not, we will
- use our own value for the constant.
+ * dns/inet.py: We now supply our own AF_INET and AF_INET6
+ constants since AF_INET6 may not always be available. If the
+ socket module has AF_INET6, we will use it. If not, we will
+ use our own value for the constant.
- * dns/query.py: the functions now take an optional af argument
- specifying the address family to use when creating the socket.
+ * dns/query.py: the functions now take an optional af argument
+ specifying the address family to use when creating the socket.
- * dns/rdatatype.py (is_metatype): a typo caused the function
- return true only for type OPT.
+ * dns/rdatatype.py (is_metatype): a typo caused the function
+ return true only for type OPT.
+
+ * dns/message.py: message section list elements are now RRsets
+ instead of Nodes. This API change makes processing messages
+ easier for many applications.
- * dns/message.py: message section list elements are now RRsets
- instead of Nodes. This API change makes processing messages
- easier for many applications.
-
2003-07-07 Bob Halley <halley@dnspython.org>
- * dns/rrset.py: added. An RRset is a named rdataset.
+ * dns/rrset.py: added. An RRset is a named rdataset.
+
+ * dns/rdataset.py (Rdataset.__eq__): rdatasets may now be compared
+ for equality and inequality with other objects. Rdataset instance
+ variables are now slotted.
- * dns/rdataset.py (Rdataset.__eq__): rdatasets may now be compared
- for equality and inequality with other objects. Rdataset instance
- variables are now slotted.
-
- * dns/message.py: The wire format and text format readers are now
- classes. Variables related to reader state have been moved out
- of the message class.
+ * dns/message.py: The wire format and text format readers are now
+ classes. Variables related to reader state have been moved out
+ of the message class.
2003-07-06 Bob Halley <halley@dnspython.org>
- * dns/name.py (from_text): '@' was not interpreted as the empty
- name.
+ * dns/name.py (from_text): '@' was not interpreted as the empty
+ name.
+
+ * dns/zone.py: the master file reader derelativized names in rdata
+ relative to the zone's origin, not relative to the current origin.
+ The reader now deals with relativization in two steps. The rdata
+ is read and derelativized using the current origin. The rdata's
+ relativity is then chosen using the zone origin and the relativize
+ boolean. Here's an example.
- * dns/zone.py: the master file reader derelativized names in rdata
- relative to the zone's origin, not relative to the current origin.
- The reader now deals with relativization in two steps. The rdata
- is read and derelativized using the current origin. The rdata's
- relativity is then chosen using the zone origin and the relativize
- boolean. Here's an example.
+ $ORIGIN foo.example.
+ $TTL 300
+ bar MX 0 blaz
- $ORIGIN foo.example.
- $TTL 300
- bar MX 0 blaz
+ If the zone origin is example., and relativization is on, then
+ This fragment will become:
- If the zone origin is example., and relativization is on, then
- This fragment will become:
+ bar.foo.example. 300 IN MX 0 blaz.foo.example.
- bar.foo.example. 300 IN MX 0 blaz.foo.example.
+ after the first step (derelativization to current origin), and
- after the first step (derelativization to current origin), and
+ bar.foo 300 IN MX 0 blaz.foo
- bar.foo 300 IN MX 0 blaz.foo
+ after the second step (relativiation to zone origin).
- after the second step (relativiation to zone origin).
-
- * dns/namedict.py: added.
+ * dns/namedict.py: added.
- * dns/zone.py: The master file reader has been made into its
- own class. Reader-related instance variables have been moved
- form the zone class into the reader class.
-
- * dns/zone.py: Add node_factory class attribute. An application
- can now subclass Zone and Node and have a zone whose nodes are of
- the subclassed Node type. The from_text(), from_file(), and
- from_xfr() algorithms now take an optional zone_factory argument.
- This allows the algorithms to be used to create zones whose class
- is a subclass of Zone.
+ * dns/zone.py: The master file reader has been made into its
+ own class. Reader-related instance variables have been moved
+ form the zone class into the reader class.
+
+ * dns/zone.py: Add node_factory class attribute. An application
+ can now subclass Zone and Node and have a zone whose nodes are of
+ the subclassed Node type. The from_text(), from_file(), and
+ from_xfr() algorithms now take an optional zone_factory argument.
+ This allows the algorithms to be used to create zones whose class
+ is a subclass of Zone.
2003-07-04 Bob Halley <halley@dnspython.org>
- * dns/renderer.py: added new wire format rendering module and
- converted message.py to use it. Applications which want
- fine-grained control over the conversion to wire format may call
- the renderer directy, instead of having it called on their behalf
- by the message code.
+ * dns/renderer.py: added new wire format rendering module and
+ converted message.py to use it. Applications which want
+ fine-grained control over the conversion to wire format may call
+ the renderer directy, instead of having it called on their behalf
+ by the message code.
2003-07-02 Bob Halley <halley@dnspython.org>
- * dns/name.py (_validate_labels): The NameTooLong test was
- incorrect.
+ * dns/name.py (_validate_labels): The NameTooLong test was
+ incorrect.
- * dns/message.py (Message.to_wire): dns.exception.TooBig is
- now raised if the wire encoding exceeds the specified
- maximum size.
+ * dns/message.py (Message.to_wire): dns.exception.TooBig is
+ now raised if the wire encoding exceeds the specified
+ maximum size.
2003-07-01 Bob Halley <halley@dnspython.org>
- * dns/message.py: EDNS encoding was broken. from_text()
- didn't parse rcodes, flags, or eflags correctly. Comparing
- messages with other types of objects didn't work.
+ * dns/message.py: EDNS encoding was broken. from_text()
+ didn't parse rcodes, flags, or eflags correctly. Comparing
+ messages with other types of objects didn't work.
2003-06-30 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0 released)
+ * (Version 1.0.0 released)
2003-06-30 Bob Halley <halley@dnspython.org>
- * dns/rdata.py: Rdatas now implement rich comparisons instead of
- __cmp__.
+ * dns/rdata.py: Rdatas now implement rich comparisons instead of
+ __cmp__.
- * dns/name.py: Names now implement rich comparisons instead of
- __cmp__.
+ * dns/name.py: Names now implement rich comparisons instead of
+ __cmp__.
- * dns/inet.py (inet_ntop): Always use our code, since the code
- in the socket module doesn't support AF_INET6 conversions if
- IPv6 sockets are not available on the system.
+ * dns/inet.py (inet_ntop): Always use our code, since the code
+ in the socket module doesn't support AF_INET6 conversions if
+ IPv6 sockets are not available on the system.
- * dns/resolver.py (Answer.__init__): A dangling CNAME chain was
- not raising NoAnswer.
+ * dns/resolver.py (Answer.__init__): A dangling CNAME chain was
+ not raising NoAnswer.
- * Added a simple resolver Cache class.
+ * Added a simple resolver Cache class.
- * Added an expiration attribute to answer instances.
+ * Added an expiration attribute to answer instances.
2003-06-24 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0b3 released)
+ * (Version 1.0.0b3 released)
2003-06-24 Bob Halley <halley@dnspython.org>
- * Renamed module "DNS" to "dns" to avoid conflicting with
- PyDNS.
+ * Renamed module "DNS" to "dns" to avoid conflicting with
+ PyDNS.
2003-06-23 Bob Halley <halley@dnspython.org>
- * The from_text() relativization controls now work the same way as
- the to_text() controls.
+ * The from_text() relativization controls now work the same way as
+ the to_text() controls.
- * DNS/rdata.py: The parsing of generic rdata was broken.
+ * DNS/rdata.py: The parsing of generic rdata was broken.
2003-06-21 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0b2 released)
+ * (Version 1.0.0b2 released)
2003-06-21 Bob Halley <halley@dnspython.org>
- * The Python 2.2 socket.inet_aton() doesn't seem to like
- '255.255.255.255'. We work around this.
+ * The Python 2.2 socket.inet_aton() doesn't seem to like
+ '255.255.255.255'. We work around this.
+
+ * Fixed bugs in rdata to_wire() and from_wire() routines of a few
+ types. These bugs were discovered by running the tests/zone.py
+ Torture1 test.
- * Fixed bugs in rdata to_wire() and from_wire() routines of a few
- types. These bugs were discovered by running the tests/zone.py
- Torture1 test.
-
- * Added implementation of type APL.
+ * Added implementation of type APL.
2003-06-20 Bob Halley <halley@dnspython.org>
- * DNS/rdtypes/IN/AAAA.py: Use our own versions of inet_ntop and
- inet_pton if the socket module doesn't provide them for us.
+ * DNS/rdtypes/IN/AAAA.py: Use our own versions of inet_ntop and
+ inet_pton if the socket module doesn't provide them for us.
+
+ * The resolver now does a better job handling exceptions. In
+ particular, it no longer eats all exceptions; rather it handles
+ those exceptions it understands, and leaves the rest uncaught.
- * The resolver now does a better job handling exceptions. In
- particular, it no longer eats all exceptions; rather it handles
- those exceptions it understands, and leaves the rest uncaught.
-
- * Exceptions have been pulled into their own module. Almost all
- exceptions raised by the code are now subclasses of
- DNS.exception.DNSException. All form errors are subclasses of
- DNS.exception.FormError (which is itself a subclass of
- DNS.exception.DNSException).
+ * Exceptions have been pulled into their own module. Almost all
+ exceptions raised by the code are now subclasses of
+ DNS.exception.DNSException. All form errors are subclasses of
+ DNS.exception.FormError (which is itself a subclass of
+ DNS.exception.DNSException).
2003-06-19 Bob Halley <halley@dnspython.org>
-
- * Added implementations of types DS, NXT, SIG, and WKS.
- * __cmp__ for type A and AAAA could produce incorrect results.
+ * Added implementations of types DS, NXT, SIG, and WKS.
+
+ * __cmp__ for type A and AAAA could produce incorrect results.
2003-06-18 Bob Halley <halley@dnspython.org>
- * Started test suites for zone.py and tokenizer.py.
-
- * Added implementation of type KEY.
-
- * DNS/rdata.py(_base64ify): \n could be emitted erroneously.
+ * Started test suites for zone.py and tokenizer.py.
+
+ * Added implementation of type KEY.
+
+ * DNS/rdata.py(_base64ify): \n could be emitted erroneously.
- * DNS/rdtypes/ANY/SOA.py (SOA.from_text): The SOA RNAME field could
- be set to the value of MNAME in common cases.
+ * DNS/rdtypes/ANY/SOA.py (SOA.from_text): The SOA RNAME field could
+ be set to the value of MNAME in common cases.
- * DNS/rdtypes/ANY/X25.py: __init__ was broken.
+ * DNS/rdtypes/ANY/X25.py: __init__ was broken.
- * DNS/zone.py (from_text): $TTL handling erroneously caused the
- next line to be eaten.
+ * DNS/zone.py (from_text): $TTL handling erroneously caused the
+ next line to be eaten.
- * DNS/tokenizer.py (Tokenizer.get): parsing was broken for empty
- quoted strings. Quoted strings didn't handle \ddd escapes. Such
- escapes are appear not to comply with RFC 1035, but BIND allows
- them and they seem useful, so we allow them too.
+ * DNS/tokenizer.py (Tokenizer.get): parsing was broken for empty
+ quoted strings. Quoted strings didn't handle \ddd escapes. Such
+ escapes are appear not to comply with RFC 1035, but BIND allows
+ them and they seem useful, so we allow them too.
- * DNS/rdtypes/ANY/ISDN.py (ISDN.from_text): parsing was
- broken for ISDN RRs without subaddresses.
+ * DNS/rdtypes/ANY/ISDN.py (ISDN.from_text): parsing was
+ broken for ISDN RRs without subaddresses.
- * DNS/zone.py (from_file): from_file() didn't work because
- some required parameters were not passed to from_text().
+ * DNS/zone.py (from_file): from_file() didn't work because
+ some required parameters were not passed to from_text().
2003-06-17 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0b1 released)
+ * (Version 1.0.0b1 released)
2003-06-17 Bob Halley <halley@dnspython.org>
- * Added implementation of type PX.
-
+ * Added implementation of type PX.
+
2003-06-16 Bob Halley <halley@dnspython.org>
- * Added implementation of types CERT, GPOS, LOC, NSAP, NSAP-PTR.
+ * Added implementation of types CERT, GPOS, LOC, NSAP, NSAP-PTR.
- * DNS/rdatatype.py (_by_value): A cut-and-paste error had broken
- NSAP and NSAP-PTR.
+ * DNS/rdatatype.py (_by_value): A cut-and-paste error had broken
+ NSAP and NSAP-PTR.
2003-06-12 Bob Halley <halley@dnspython.org>
- * Created a tests directory and started adding tests.
-
- * Added "and its documentation" to the permission grant in the
- license.
+ * Created a tests directory and started adding tests.
+
+ * Added "and its documentation" to the permission grant in the
+ license.
2003-06-12 Bob Halley <halley@dnspython.org>
- * DNS/name.py (Name.is_wild): is_wild() erroneously raised IndexError
- if the name was empty.
+ * DNS/name.py (Name.is_wild): is_wild() erroneously raised IndexError
+ if the name was empty.
2003-06-10 Bob Halley <halley@dnspython.org>
- * Added implementations of types AFSDB, X25, and ISDN.
-
- * The documentation associated with the various rdata types has been
- improved. In particular, instance variables are now described.
+ * Added implementations of types AFSDB, X25, and ISDN.
+
+ * The documentation associated with the various rdata types has been
+ improved. In particular, instance variables are now described.
2003-06-09 Bob Halley <halley@dnspython.org>
- * Added implementations of types HINFO, RP, and RT.
-
- * DNS/message.py (make_query): Document that make_query() sets
- flags to DNS.flags.RD, and chooses a random query id.
+ * Added implementations of types HINFO, RP, and RT.
+
+ * DNS/message.py (make_query): Document that make_query() sets
+ flags to DNS.flags.RD, and chooses a random query id.
2003-06-05 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0a2 released)
-
+ * (Version 1.0.0a2 released)
+
2003-06-05 Bob Halley <halley@dnspython.org>
-
- * DNS/node.py: removed __getitem__ and __setitem__, since
- they are not used by the codebase and were not useful in
- general either.
- * DNS/message.py (from_file): from_file() now allows a
- filename to be specified instead of a file object.
+ * DNS/node.py: removed __getitem__ and __setitem__, since
+ they are not used by the codebase and were not useful in
+ general either.
+
+ * DNS/message.py (from_file): from_file() now allows a
+ filename to be specified instead of a file object.
- * DNS/rdataset.py: The is_compatible() method of the
- DNS.rdataset.Rdataset class was deleted.
+ * DNS/rdataset.py: The is_compatible() method of the
+ DNS.rdataset.Rdataset class was deleted.
2003-06-04 Bob Halley <halley@dnspython.org>
- * DNS/name.py (class Name): Names are now immutable.
+ * DNS/name.py (class Name): Names are now immutable.
- * DNS/name.py: the is_comparable() method has been removed, since
- names are always comparable.
+ * DNS/name.py: the is_comparable() method has been removed, since
+ names are always comparable.
- * DNS/resolver.py (Resolver.query): A query could run for up
- to the lifetime + the timeout. This has been corrected and the
- query will now only run up to the lifetime.
+ * DNS/resolver.py (Resolver.query): A query could run for up
+ to the lifetime + the timeout. This has been corrected and the
+ query will now only run up to the lifetime.
2003-06-03 Bob Halley <halley@dnspython.org>
- * DNS/resolver.py: removed the 'new' function since it is not the
- style of the library to have such a function. Call
- DNS.resolver.Resolver() to make a new resolver.
+ * DNS/resolver.py: removed the 'new' function since it is not the
+ style of the library to have such a function. Call
+ DNS.resolver.Resolver() to make a new resolver.
2003-06-03 Bob Halley <halley@dnspython.org>
- * DNS/resolver.py (Resolver._config_win32_fromkey): The DhcpServer
- list is space separated, not comma separated.
+ * DNS/resolver.py (Resolver._config_win32_fromkey): The DhcpServer
+ list is space separated, not comma separated.
2003-06-03 Bob Halley <halley@dnspython.org>
- * DNS/update.py: Added an update module to make generating updates
- easier.
+ * DNS/update.py: Added an update module to make generating updates
+ easier.
2003-06-03 Bob Halley <halley@dnspython.org>
- * Commas were missing in some of the __all__ entries in various
- __init__.py files.
+ * Commas were missing in some of the __all__ entries in various
+ __init__.py files.
2003-05-30 Bob Halley <halley@dnspython.org>
- * (Version 1.0.0a1 released)
+ * (Version 1.0.0a1 released)