summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: 8df1882)
raw | patch | inline | side by side (parent: 8df1882)
author | Sven Velt <sven@velt.de> | |
Thu, 26 Aug 2010 09:50:24 +0000 (11:50 +0200) | ||
committer | Sven Velt <sven@velt.de> | |
Thu, 26 Aug 2010 09:50:24 +0000 (11:50 +0200) |
Also select if it outputs hosts and/or services
Signed-off-by: Sven Velt <sven@velt.de>
Signed-off-by: Sven Velt <sven@velt.de>
nagixsc_xml2cfg.py | patch | blob | history | |
sample-configs/xml2cfg_tmpl/host.tmpl | [new file with mode: 0644] | patch | blob |
sample-configs/xml2cfg_tmpl/service.tmpl | [new file with mode: 0644] | patch | blob |
diff --git a/nagixsc_xml2cfg.py b/nagixsc_xml2cfg.py
index 9f4a62d85a8948ae0e1813260250873adf2b4b48..284a9d31dc0b14aa7c4ff642b2ff52538a210e37 100755 (executable)
--- a/nagixsc_xml2cfg.py
+++ b/nagixsc_xml2cfg.py
parser.add_option('-S', '', dest='schemacheck', help='Check XML against DTD')
parser.add_option('-H', '', dest='host', help='Hostname to search for in XML file')
parser.add_option('-D', '', dest='service', help='Service description to search for in XML file')
+parser.add_option('', '--host-template', dest='tmpl_host', help='Filename of host template')
+parser.add_option('', '--service-template', dest='tmpl_service', help='Filename of service template')
+parser.add_option('-O', '', dest='output', help='Output "hosts", "services" or "both" (default)')
parser.add_option('-v', '', action='count', dest='verb', help='Verbose output')
parser.set_defaults(url=None)
parser.set_defaults(schemacheck='')
parser.set_defaults(host=None)
parser.set_defaults(service=None)
+parser.set_defaults(output=None)
+parser.set_defaults(tmpl_host=None)
+parser.set_defaults(tmpl_service=None)
parser.set_defaults(verb=0)
(options, args) = parser.parse_args()
+# Hard coded default for host template
HOSTTEMPL='''define host {
use templ_host_default
}
'''
+# Hard coded default for service template
SERVICETEMPL='''define service {
use templ_service_passive
##############################################################################
+# Output
+if not options.output in [None, 'both', 'hosts', 'services']:
+ print 'Unknown output mode "%s"!' % options.output
+ sys.exit(1)
+
+if options.output in [None, 'both']:
+ options.output = ['hosts', 'services']
+else:
+ options.output = [options.output,]
+
+# Read host and/or service template
+if options.tmpl_host and 'hosts' in options.output:
+ HOSTTEMPL = open(options.tmpl_host).read()
+if options.tmpl_service and 'services' in options.output:
+ SERVICETEMPL = open(options.tmpl_service).read()
+
# Get URL or file
doc = read_xml(options)
if not check['host_name'] in foundhosts:
foundhosts.append(check['host_name'])
- print HOSTTEMPL % check
+ if 'hosts' in options.output:
+ print HOSTTEMPL % check
- if check['service_description']:
+ if check['service_description'] and 'services' in options.output:
print SERVICETEMPL % check
diff --git a/sample-configs/xml2cfg_tmpl/host.tmpl b/sample-configs/xml2cfg_tmpl/host.tmpl
--- /dev/null
@@ -0,0 +1,6 @@
+define host {
+ use templ_host_default
+
+ host_name %(host_name)s
+ address 127.0.0.1
+}
diff --git a/sample-configs/xml2cfg_tmpl/service.tmpl b/sample-configs/xml2cfg_tmpl/service.tmpl
--- /dev/null
@@ -0,0 +1,7 @@
+define service {
+ use templ_service_passive
+
+ host_name %(host_name)s
+ service_description %(service_description)s
+ check_command check_passive
+}