Merge pydns support from trunk.
This commit is contained in:
+23
-3
@@ -25,8 +25,6 @@ import logging
|
|||||||
import re
|
import re
|
||||||
import time
|
import time
|
||||||
|
|
||||||
import dns.resolver
|
|
||||||
|
|
||||||
from dkim.crypto import (
|
from dkim.crypto import (
|
||||||
DigestTooLargeError,
|
DigestTooLargeError,
|
||||||
parse_pem_private_key,
|
parse_pem_private_key,
|
||||||
@@ -218,7 +216,8 @@ def rfc822_parse(message):
|
|||||||
return (headers, b"\r\n".join(lines[i:]))
|
return (headers, b"\r\n".join(lines[i:]))
|
||||||
|
|
||||||
|
|
||||||
def dnstxt(name):
|
|
||||||
|
def dnstxt_dnspython(name):
|
||||||
"""Return a TXT record associated with a DNS name."""
|
"""Return a TXT record associated with a DNS name."""
|
||||||
a = dns.resolver.query(name, dns.rdatatype.TXT)
|
a = dns.resolver.query(name, dns.rdatatype.TXT)
|
||||||
for r in a.response.answer:
|
for r in a.response.answer:
|
||||||
@@ -227,6 +226,27 @@ def dnstxt(name):
|
|||||||
return None
|
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 ")
|
||||||
|
|||||||
Reference in New Issue
Block a user