- maybeDelegate = False
- deferredResult = authority.BindAuthority._lookup(self, name, cls,
- type, timeout)
- # If we didn't find an exact match for the name we were seeking,
- # check if it's within a subdomain we're supposed to delegate to
- # some other DNS server.
- while (isinstance(deferredResult.result, failure.Failure)
- and '.' in name):
- maybeDelegate = True
- name = name[name.find('.') + 1 :]
- deferredResult = authority.BindAuthority._lookup(self, name, cls,
- dns.NS, timeout)
- return deferredResult
+ try:
+ result = yield authority.BindAuthority._lookup(self, name, cls,
+ type, timeout)
+ defer.returnValue(result)
+ except dns.AuthoritativeDomainError:
+ # If we didn't find an exact match for the name we were
+ # seeking, check if it's within a subdomain we're supposed
+ # to delegate to some other DNS server.
+ while '.' in name:
+ _, name = name.split('.', 1)
+ try:
+ # BindAuthority puts the NS in the authority
+ # section automatically for us, so just return
+ # it. We override the type to NS.
+ result = yield authority.BindAuthority._lookup(self, name, cls,
+ dns.NS, timeout)
+ defer.returnValue(result)
+ except (dns.DomainError, dns.AuthoritativeDomainError):
+ pass
+ # We didn't find a delegation, so return the original
+ # NXDOMAIN.
+ raise