from invirt.common import InvirtConfigError
from invirt.config import structs as config
import invirt.database
+from invirt.database import NIC
import psycopg2
import sqlalchemy
import time
if name.endswith(".in-addr.arpa"):
if type in (dns.PTR, dns.ALL_RECORDS):
ip = '.'.join(reversed(name.split('.')[:-2]))
- value = invirt.database.NIC.query.filter_by(ip=ip).first()
+ value = invirt.database.NIC.query.filter((NIC.ip == ip) | (NIC.other_ip == ip)).first()
if value and value.hostname:
hostname = value.hostname
if '.' not in hostname:
+ if ip == value.other_ip:
+ hostname = hostname + ".other"
hostname = hostname + "." + config.dns.domains[0]
record = dns.Record_PTR(hostname, ttl)
results.append(dns.RRHeader(name, dns.PTR, dns.IN,
ttl, self.soa, auth=True))
# FIXME: Should only return success with no records if the name actually exists
- elif name == domain or name == '.'+domain:
+ elif name == domain or name == '.'+domain or name == 'other.'+domain:
if type in (dns.A, dns.ALL_RECORDS):
record = dns.Record_A(config.dns.nameservers[0].ip, ttl)
results.append(dns.RRHeader(name, dns.A, dns.IN,
else:
host = name[:-len(domain)-1]
+ other = False
+ if host.endswith(".other"):
+ host = host[:-len(".other")]
+ other = True
value = invirt.database.NIC.query.filter_by(hostname=host).first()
if value:
- ip = value.ip
+ if other:
+ ip = value.other_ip
+ action = value.other_action
+ else:
+ ip = value.ip
else:
value = invirt.database.Machine.query.filter_by(name=host).first()
if value:
- ip = value.nics[0].ip
+ if other:
+ ip = value.nics[0].other_ip
+ action = value.nics[0].other_action
+ else:
+ ip = value.nics[0].ip
else:
return defer.fail(failure.Failure(dns.AuthoritativeDomainError(name)))
if ip is None:
elif type == dns.SOA:
results.append(dns.RRHeader(domain, dns.SOA, dns.IN,
ttl, self.soa, auth=True))
+ elif other and type == dns.TXT:
+ record = dns.Record_TXT(action if action else '', ttl=ttl)
+ results.append(dns.RRHeader(name, dns.TXT, dns.IN,
+ ttl, record, auth=True))
if len(results) == 0:
authority = []
name = name[name.find('.') + 1 :]
deferredResult = authority.BindAuthority._lookup(self, name, cls,
dns.NS, timeout)
- # If we found somewhere to delegate the query to, our _lookup()
- # for the NS record resulted in it being in the 'results' section.
- # We need to instead return that information in the 'authority'
- # section to delegate, and return an empty 'results' section
- # (because we didn't find the name we were asked about). We
- # leave the 'additional' section as we received it because it
- # may contain A records for the DNS server we're delegating to.
- if maybeDelegate and not isinstance(deferredResult.result,
- failure.Failure):
- (nsResults, nsAuthority, nsAdditional) = deferredResult.result
- deferredResult = defer.succeed(([], nsResults, nsAdditional))
return deferredResult
class TypeLenientResolverChain(resolve.ResolverChain):