X-Git-Url: http://xvm.mit.edu/gitweb/invirt/packages/invirt-dns.git/blobdiff_plain/b8f8534651b1ba734dc184efbf8f2c0e8c6e08bc..be712d887af49474116185bb38bb2afce6527173:/invirt-dns diff --git a/invirt-dns b/invirt-dns index c320e51..8cd8337 100755 --- a/invirt-dns +++ b/invirt-dns @@ -4,6 +4,7 @@ from twisted.names import server from twisted.names import dns from twisted.names import common from twisted.names import authority +from twisted.names import resolve from twisted.internet import defer from twisted.python import failure @@ -220,6 +221,26 @@ class DelegatingQuotingBindAuthority(authority.BindAuthority): deferredResult = defer.succeed(([], nsResults, nsAdditional)) return deferredResult +class TypeLenientResolverChain(resolve.ResolverChain): + """ + This is a ResolverChain which is more lenient in its handling of + queries requesting unimplemented record types. + """ + + def query(self, query, timeout = None): + try: + return self.typeToMethod[query.type](str(query.name), timeout) + except KeyError, e: + # We don't support the requested record type. Twisted would + # have us return SERVFAIL. Instead, we'll check whether the + # name exists in our zone at all and return NXDOMAIN or an empty + # result set with NOERROR as appropriate. + deferredResult = self.lookupAllRecords(str(query.name), timeout) + if isinstance(deferredResult.result, failure.Failure): + return deferredResult + (results, authority, additional) = deferredResult.result + return defer.succeed(([], authority, additional)) + if '__main__' == __name__: resolvers = [] try: @@ -240,7 +261,8 @@ if '__main__' == __name__: resolvers.append(DatabaseAuthority()) verbosity = 0 - f = server.DNSServerFactory(authorities=resolvers, verbose=verbosity) + f = server.DNSServerFactory(verbose=verbosity) + f.resolver = TypeLenientResolverChain(resolvers) p = dns.DNSDatagramProtocol(f) f.noisy = p.noisy = verbosity