summaryrefslogtreecommitdiffstats
path: root/src/lib/Server/Plugins/NagiosGen.py
blob: ca70ba80cd8b8fb6f28d9cca5efac5fb89f2087d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
'''This module implements a Nagios configuration generator'''

import glob
import logging
import lxml.etree
import os
import re
import socket

import Bcfg2.Server.Plugin

LOGGER = logging.getLogger('Bcfg2.Plugins.NagiosGen')

host_config_fmt = \
'''
define host{
        host_name       %s
        alias           %s
        address         %s
'''


class NagiosGen(Bcfg2.Server.Plugin.Plugin,
                Bcfg2.Server.Plugin.Generator):
    """NagiosGen is a Bcfg2 plugin that dynamically generates
       Nagios configuration file based on Bcfg2 data.
    """
    name = 'NagiosGen'
    __version__ = '0.6'
    __author__ = 'bcfg-dev@mcs.anl.gov'

    def __init__(self, core, datastore):
        Bcfg2.Server.Plugin.Plugin.__init__(self, core, datastore)
        Bcfg2.Server.Plugin.Generator.__init__(self)
        self.Entries = {'Path':
                {'/etc/nagiosgen.status': self.createhostconfig,
                '/etc/nagios/nagiosgen.cfg': self.createserverconfig}}

        self.client_attrib = {'encoding': 'ascii',
                              'owner': 'root',
                              'group': 'root',
                              'type': 'file',
                              'perms': '0400'}
        self.server_attrib = {'encoding': 'ascii',
                              'owner': 'nagios',
                              'group': 'nagios',
                              'type': 'file',
                              'perms': '0440'}

    def getparents(self, hostname):
        """Return parents for given hostname."""
        depends = []
        if not os.path.isfile('%s/parents.xml' % (self.data)):
            return depends

        tree = lxml.etree.parse('%s/parents.xml' % (self.data))
        for entry in tree.findall('.//Depend'):
            if entry.attrib['name'] == hostname:
                depends.append(entry.attrib['on'])
        return depends

    def createhostconfig(self, entry, metadata):
        """Build host specific configuration file."""
        host_address = socket.gethostbyname(metadata.hostname)
        host_groups = [grp for grp in metadata.groups if \
                       os.path.isfile('%s/%s-group.cfg' % (self.data, grp))]
        host_config = host_config_fmt % \
                      (metadata.hostname, metadata.hostname, host_address)

        if host_groups:
            host_config += '        hostgroups      %s\n' % (",".join(host_groups))

        xtra = None
        if hasattr(metadata, 'Properties') and \
                'NagiosGen.xml' in metadata.Properties:
            for q in (metadata.hostname, 'default'):
                xtra = metadata.Properties['NagiosGen.xml'].data.find(q)
                if xtra is not None:
                    break

        if xtra is not None:
            directives = list(xtra)
            for item in directives:
                host_config += '        %-32s %s\n' % (item.tag, item.text)

        else:
            host_config += '        use             default\n'

        host_config += '}\n'
        entry.text = host_config
        [entry.attrib.__setitem__(key, value) for \
            (key, value) in list(self.client_attrib.items())]
        try:
            fileh = open("%s/%s-host.cfg" % \
                        (self.data, metadata.hostname), 'w')
            fileh.write(host_config)
            fileh.close()
        except OSError:
            ioerr = sys.exc_info()[1]
            LOGGER.error("Failed to write %s/%s-host.cfg" % \
                        (self.data, metadata.hostname))
            LOGGER.error(ioerr)

    def createserverconfig(self, entry, _):
        """Build monolithic server configuration file."""
        host_configs = glob.glob('%s/*-host.cfg' % self.data)
        group_configs = glob.glob('%s/*-group.cfg' % self.data)
        host_data = ""
        group_data = ""
        for host in host_configs:
            hostfile = open(host, 'r')
            hostname = host.split('/')[-1].replace('-host.cfg', '')
            parents = self.getparents(hostname)
            if parents:
                hostlines = hostfile.readlines()
            else:
                hostdata = hostfile.read()
            hostfile.close()

            if parents:
                hostdata = ''
                addparents = True
                for line in hostlines:
                    line = line.replace('\n', '')
                    if 'parents' in line:
                        line += ',' + ','.join(parents)
                        addparents = False
                    if '}' in line:
                        line = ''
                    hostdata += "%s\n" % line
                if addparents:
                    hostdata += "        parents         %s\n" % ','.join(parents)
                hostdata += "}\n"

            host_data += hostdata
        for group in group_configs:
            group_name = re.sub("(-group.cfg|.*/(?=[^/]+))", "", group)
            if host_data.find(group_name) != -1:
                groupfile = open(group, 'r')
                group_data += groupfile.read()
                groupfile.close()
        entry.text = group_data + host_data
        [entry.attrib.__setitem__(key, value) for \
            (key, value) in list(self.server_attrib.items())]
        try:
            fileh = open("%s/nagiosgen.cfg" % (self.data), 'w')
            fileh.write(group_data + host_data)
            fileh.close()
        except OSError:
            ioerr = sys.exc_info()[1]
            LOGGER.error("Failed to write %s/nagiosgen.cfg" % (self.data))
            LOGGER.error(ioerr)