add some config options
This commit is contained in:
parent
b901cfa034
commit
b74c8b04be
2 changed files with 13 additions and 6 deletions
|
@ -8,4 +8,11 @@ This script requires an ini-style config file named `config.conf` for icinga bas
|
||||||
baseurl = https://example.org:5665
|
baseurl = https://example.org:5665
|
||||||
username = root
|
username = root
|
||||||
password = foobar
|
password = foobar
|
||||||
|
|
||||||
|
[filters]
|
||||||
|
services = "checks_with_sms" in service.groups
|
||||||
|
hosts = "checks_with_sms" in host.groups
|
||||||
|
|
||||||
|
[output]
|
||||||
|
filename = index.html
|
||||||
```
|
```
|
||||||
|
|
|
@ -20,7 +20,7 @@ def do_api_calls(config):
|
||||||
requestbody = {
|
requestbody = {
|
||||||
"attrs": [ "name", "state", "last_check_result", "host_name", "display_name" ],
|
"attrs": [ "name", "state", "last_check_result", "host_name", "display_name" ],
|
||||||
"joins": [ "host.name", "host.state", "host.last_check_result" ],
|
"joins": [ "host.name", "host.state", "host.last_check_result" ],
|
||||||
"filter": "\"checks_with_sms\" in service.groups",
|
"filter": config['filters']['services'],
|
||||||
}
|
}
|
||||||
r = requests.get(request_url,
|
r = requests.get(request_url,
|
||||||
headers=headers,
|
headers=headers,
|
||||||
|
@ -32,7 +32,7 @@ def do_api_calls(config):
|
||||||
data['services'] = r.json()
|
data['services'] = r.json()
|
||||||
else:
|
else:
|
||||||
r.raise_for_status()
|
r.raise_for_status()
|
||||||
print(json.dumps(data['services']))
|
|
||||||
# hosts
|
# hosts
|
||||||
request_url = "{}/v1/objects/hosts".format(config['icinga2_api']['baseurl'])
|
request_url = "{}/v1/objects/hosts".format(config['icinga2_api']['baseurl'])
|
||||||
headers = {
|
headers = {
|
||||||
|
@ -41,7 +41,7 @@ def do_api_calls(config):
|
||||||
}
|
}
|
||||||
requestbody = {
|
requestbody = {
|
||||||
"attrs": [ "name", "state" ],
|
"attrs": [ "name", "state" ],
|
||||||
"filter": "\"checks_with_sms\" in host.groups",
|
"filter": config['filters']['hosts'],
|
||||||
}
|
}
|
||||||
r = requests.get(request_url,
|
r = requests.get(request_url,
|
||||||
headers=headers,
|
headers=headers,
|
||||||
|
@ -158,7 +158,7 @@ def render_service_details(data):
|
||||||
html_output = html_output + render_services_per_host(host, data)
|
html_output = html_output + render_services_per_host(host, data)
|
||||||
return html_output
|
return html_output
|
||||||
|
|
||||||
def render_index_html(host_summary, service_details):
|
def render_index_html(filename, host_summary, service_details):
|
||||||
with open("template.html", "r") as f:
|
with open("template.html", "r") as f:
|
||||||
htmlTemplate = f.read()
|
htmlTemplate = f.read()
|
||||||
|
|
||||||
|
@ -167,7 +167,7 @@ def render_index_html(host_summary, service_details):
|
||||||
services = service_details
|
services = service_details
|
||||||
)
|
)
|
||||||
|
|
||||||
with open("index.html", "w") as f:
|
with open(filename, "w") as f:
|
||||||
f.write(htmlOutput)
|
f.write(htmlOutput)
|
||||||
|
|
||||||
|
|
||||||
|
@ -183,7 +183,7 @@ def main():
|
||||||
data = do_api_calls(config)
|
data = do_api_calls(config)
|
||||||
host_summary = render_hosts(data)
|
host_summary = render_hosts(data)
|
||||||
service_details = render_service_details(data)
|
service_details = render_service_details(data)
|
||||||
render_index_html(host_summary, service_details)
|
render_index_html(config['output']['filename'], host_summary, service_details)
|
||||||
|
|
||||||
if __name__ == "__main__":
|
if __name__ == "__main__":
|
||||||
main()
|
main()
|
Loading…
Reference in a new issue