+ additional = []
+ authority.append(dns.RRHeader(domain, dns.NS, dns.IN,
+ 3600, self.ns, auth=True))
+ if cls == dns.IN:
+ if type in (dns.A, dns.ALL_RECORDS):
+ host = name[:-len(domain)-1]
+ if not host:
+ record = dns.Record_CNAME('sipb-xen-dev.mit.edu', ttl)
+ results.append(dns.RRHeader(name, dns.CNAME, dns.IN,
+ ttl, record, auth=True))
+ else:
+ value = sipb_xen_database.Machine.get_by(name=host)
+ if value is None or not value.nics:
+ return defer.fail(failure.Failure(dns.AuthoritativeDomainError(name)))
+ ip = value.nics[0].ip
+ if ip is None: #Deactivated?
+ return defer.fail(failure.Failure(dns.AuthoritativeDomainError(name)))
+ record = dns.Record_A(ip, ttl)
+ results.append(dns.RRHeader(name, dns.A, dns.IN,
+ ttl, record, auth=True))
+ elif type == dns.NS:
+ results.append(dns.RRHeader(domain, dns.NS, dns.IN,
+ ttl, self.ns, auth=True))
+ authority = []
+ record = dns.Record_A(address='18.181.0.62', ttl=ttl)
+ additional.append(dns.RRHeader('ns1.xvm.mit.edu', dns.A, dns.IN,
+ ttl, record, auth=True))
+ elif type == dns.SOA:
+ results.append(dns.RRHeader(domain, dns.SOA, dns.IN,
+ ttl, self.soa, auth=True))
+ return defer.succeed((results, authority, additional))
+ else:
+ #Doesn't exist
+ return defer.fail(failure.Failure(dns.AuthoritativeDomainError(name)))