127 lines
4.2 KiB
Python
127 lines
4.2 KiB
Python
"""Health Check module for DNS service"""
|
|
|
|
import commands
|
|
import os
|
|
import socket
|
|
import xmlrpclib
|
|
|
|
from compass.actions.health_check import base
|
|
|
|
|
|
class DnsCheck(base.BaseCheck):
|
|
"""dns health check class."""
|
|
NAME = "DNS Check"
|
|
|
|
def run(self):
|
|
"""do health check"""
|
|
installer = self.config.OS_INSTALLER
|
|
method_name = "self.check_" + installer + "_dns()"
|
|
return eval(method_name)
|
|
|
|
def check_cobbler_dns(self):
|
|
"""Checks if Cobbler has taken over DNS service"""
|
|
|
|
try:
|
|
remote = xmlrpclib.Server(
|
|
self.config.COBBLER_INSTALLER_URL,
|
|
allow_none=True)
|
|
remote.login(
|
|
*self.config.COBBLER_INSTALLER_TOKEN)
|
|
except:
|
|
self._set_status(0,
|
|
"[%s]Error: Cannot login to Cobbler "
|
|
"with the tokens provided in the config file"
|
|
% self.NAME)
|
|
return (self.code, self.messages)
|
|
|
|
cobbler_settings = remote.get_settings()
|
|
if cobbler_settings['manage_dns'] == 0:
|
|
self.messages.append('[DNS]Info: DNS is not managed by Compass')
|
|
return (self.code, self.messages)
|
|
self.check_cobbler_dns_template()
|
|
print "[Done]"
|
|
self.check_dns_service()
|
|
print "[Done]"
|
|
if self.code == 1:
|
|
self.messages.append(
|
|
"[%s]Info: DNS health check has complated. "
|
|
"No problems found, all systems go." % self.NAME)
|
|
return (self.code, self.messages)
|
|
|
|
def check_cobbler_dns_template(self):
|
|
"""Validates Cobbler's DNS template file"""
|
|
|
|
print "Checking DNS template......",
|
|
if os.path.exists("/etc/cobbler/named.template"):
|
|
var_map = {
|
|
"match_port": False,
|
|
"match_allow_query": False,
|
|
}
|
|
named_template = open("/etc/cobbler/named.template")
|
|
host_ip = socket.gethostbyname(socket.gethostname())
|
|
missing_query = []
|
|
for line in named_template.readlines():
|
|
if "listen-on port 53" in line and host_ip in line:
|
|
var_map["match_port"] = True
|
|
|
|
if "allow-query" in line:
|
|
for subnet in ["127.0.0.0/8"]:
|
|
if not subnet in line:
|
|
missing_query.append(subnet)
|
|
|
|
named_template.close()
|
|
|
|
if var_map["match_port"] is False:
|
|
self.messages.append(
|
|
"[%s]Error: named service port "
|
|
"and/or IP is misconfigured in "
|
|
"/etc/cobbler/named.template" % self.NAME)
|
|
|
|
if len(missing_query) != 0:
|
|
self.messages.append(
|
|
"[%s]Error: Missing allow_query values in "
|
|
"/etc/cobbler/named.template:%s" % (
|
|
self.NAME,
|
|
', '.join(subnet for subnet in missing_query)))
|
|
else:
|
|
var_map["match_allow_query"] = True
|
|
|
|
fails = []
|
|
for var in var_map.keys():
|
|
if var_map[var] is False:
|
|
fails.append(var)
|
|
|
|
if len(fails) != 0:
|
|
self._set_status(
|
|
0,
|
|
"[%s]Info: DNS template failed components: "
|
|
"%s" % (
|
|
self.NAME,
|
|
' '.join(failed for failed in fails)))
|
|
|
|
else:
|
|
self._set_status(
|
|
0,
|
|
"[%s]Error: named template file doesn't exist, "
|
|
"health check failed." % self.NAME)
|
|
|
|
return True
|
|
|
|
def check_dns_service(self):
|
|
"""Checks if DNS is running on port 53"""
|
|
|
|
print "Checking DNS service......",
|
|
if not 'named' in commands.getoutput('ps -ef'):
|
|
self._set_status(
|
|
0,
|
|
"[%s]Error: named service does not seem to be "
|
|
"running" % self.NAME)
|
|
|
|
if socket.getservbyport(53) != 'domain':
|
|
self._set_status(
|
|
0,
|
|
"[%s]Error: domain service is not listening on port "
|
|
"53" % self.NAME)
|
|
|
|
return None
|