Split out DNS utilities into their own module.

This commit is contained in:
William Grant
2011-06-03 22:07:42 +10:00
parent b78a41d6bf
commit a82f3110ea
2 changed files with 57 additions and 31 deletions
+2 -31
View File
@@ -34,6 +34,7 @@ from dkim.crypto import (
RSASSA_PKCS1_v1_5_verify, RSASSA_PKCS1_v1_5_verify,
UnparsableKeyError, UnparsableKeyError,
) )
from dkim.dns import get_txt
from dkim.util import ( from dkim.util import (
get_default_logger, get_default_logger,
InvalidTagValueList, InvalidTagValueList,
@@ -180,36 +181,6 @@ def rfc822_parse(message):
def dnstxt_dnspython(name):
"""Return a TXT record associated with a DNS name."""
a = dns.resolver.query(name, dns.rdatatype.TXT)
for r in a.response.answer:
if r.rdtype == dns.rdatatype.TXT:
return b"".join(r.items[0].strings)
return None
def dnstxt_pydns(name):
"""Return a TXT record associated with a DNS name."""
# Older pydns releases don't like a trailing dot.
if name.endswith('.'):
name = name[:-1]
DNS.ParseResolvConf()
response = DNS.DnsRequest(name, qtype='txt').req()
if not response.answers:
return None
return response.answers[0]['data'][0]
# Prefer dnspython if it's there, otherwise use pydns.
try:
import dns.resolver
dnstxt = dnstxt_dnspython
except ImportError:
import DNS
dnstxt = dnstxt_pydns
def fold(header): def fold(header):
"""Fold a header line into multiple crlf-separated lines at column 72.""" """Fold a header line into multiple crlf-separated lines at column 72."""
i = header.rfind(b"\r\n ") i = header.rfind(b"\r\n ")
@@ -315,7 +286,7 @@ def sign(message, selector, domain, privkey, identity=None,
return b'DKIM-Signature: ' + sig_value + b"\r\n" return b'DKIM-Signature: ' + sig_value + b"\r\n"
def verify(message, logger=None, dnsfunc=dnstxt): def verify(message, logger=None, dnsfunc=get_txt):
"""Verify a DKIM signature on an RFC822 formatted message. """Verify a DKIM signature on an RFC822 formatted message.
@param message: an RFC822 formatted message (with either \\n or \\r\\n line endings) @param message: an RFC822 formatted message (with either \\n or \\r\\n line endings)
+55
View File
@@ -0,0 +1,55 @@
# This software is provided 'as-is', without any express or implied
# warranty. In no event will the author be held liable for any damages
# arising from the use of this software.
#
# Permission is granted to anyone to use this software for any purpose,
# including commercial applications, and to alter it and redistribute it
# freely, subject to the following restrictions:
#
# 1. The origin of this software must not be misrepresented; you must not
# claim that you wrote the original software. If you use this software
# in a product, an acknowledgment in the product documentation would be
# appreciated but is not required.
# 2. Altered source versions must be plainly marked as such, and must not be
# misrepresented as being the original software.
# 3. This notice may not be removed or altered from any source distribution.
#
# Copyright (c) 2008 Greg Hewgill http://hewgill.com
#
# This has been modified from the original software.
# Copyright (c) 2011 William Grant <me@williamgrant.id.au>
__all__ = [
'get_txt'
]
def get_txt_dnspython(name):
"""Return a TXT record associated with a DNS name."""
a = dns.resolver.query(name, dns.rdatatype.TXT)
for r in a.response.answer:
if r.rdtype == dns.rdatatype.TXT:
return b"".join(r.items[0].strings)
return None
def get_txt_pydns(name):
"""Return a TXT record associated with a DNS name."""
# Older pydns releases don't like a trailing dot.
if name.endswith('.'):
name = name[:-1]
DNS.ParseResolvConf()
response = DNS.DnsRequest(name, qtype='txt').req()
if not response.answers:
return None
return response.answers[0]['data'][0]
# Prefer dnspython if it's there, otherwise use pydns.
try:
import dns.resolver
get_txt = get_txt_dnspython
except ImportError:
import DNS
get_txt = get_txt_pydns