-
Notifications
You must be signed in to change notification settings - Fork 38
/
Copy pathweathermap.py
executable file
·121 lines (98 loc) · 4.46 KB
/
weathermap.py
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
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
# __author__ = 'maximus'
import argparse
import logging
import os
import sys
from config import ConfigLoader, ConfigCreate
from zabbix import ZabbixAgent
class WeathermapCLI(object):
def __init__(self):
self.root_path = str(os.path.dirname(os.path.abspath(__file__)))
self.font_path = self.root_path + '/fonts'
self.font_path_fn = self.root_path + '/fonts/DejaVuSansMono.ttf'
self.icon_path = self.root_path + '/icons'
self.cfg_path = self.root_path + '/mapcfgs'
self.img_path = self.root_path + '/mapimgs'
self.parser = argparse.ArgumentParser(conflict_handler='resolve', description='Network weathermap for Zabbix')
self.parser.add_argument('-v', '--version', action='store_true', help='show version')
self.parser.add_argument('-h', '--help', action='help', help='show help')
self.parser.add_argument('-d', '--debug', action='store_true', help='Enable debug mode')
self.parser.add_argument('-m', '--map', nargs='+', action='store', type=str, help='Config file names')
self.parser.add_argument('-i', '--img', action='store', type=str, help='Image path')
self.parser.add_argument('-u', '--upload', action='store_true', help='Image upload to zabbix')
self.parser.add_argument('-c', '--cfg', action='store', type=str, help='Config path')
# self.parser.add_argument('-a', '--all', action='store_true', help='all')
self.parser.add_argument('-s', '--scan', nargs='+', action='store', type=str, help='Map names in Zabbix')
self.parser.add_argument('-f', '--file', action='store_true', help='Zabbix authentication from map config file')
self.parser.add_argument('-z', '--zabbix', action='store', type=str, help='Zabbix server url')
self.parser.add_argument('-l', '--login', action='store', type=str, help='Login')
self.parser.add_argument('-p', '--pwd', action='store', help='Password')
self.args = self.parser.parse_args()
self._cfg_logging()
if not vars(self.args):
self.parser.print_help()
sys.exit()
if self.args.version:
print('Network weathermap 1.1.5')
sys.exit()
if self.args.map:
self._map_img()
elif self.args.scan and self.args.zabbix and self.args.login and self.args.pwd:
self._map_scan()
elif self.args.scan and self.args.file:
self._map_scan_cfg()
else:
self.parser.print_help()
sys.exit()
def _map_scan(self):
if self.args.cfg:
self.cfg_path = self.args.cfg
for map_n in self.args.scan:
zbx = ZabbixAgent(self.args.zabbix, self.args.login, self.args.pwd)
map_data = zbx.scan_map(map_n)
scan_map = ConfigCreate(map_data, zbx)
scan_map.create()
scan_map.check_map(self.cfg_path)
scan_map.save(self.cfg_path)
del zbx, scan_map, map_data
def _map_scan_cfg(self):
if self.args.cfg:
self.cfg_path = self.args.cfg
for map_n in self.args.scan:
cfg = ConfigLoader(self.cfg_path + '/' + map_n + '.yaml')
map_data = cfg.zbx.scan_map(map_n)
scan_map = ConfigCreate(map_data, cfg.zbx)
scan_map.create()
scan_map.check_map(self.cfg_path)
scan_map.save(self.cfg_path)
del cfg, scan_map, map_data
def _map_img(self):
if self.args.cfg:
self.cfg_path = self.args.cfg
if self.args.img:
self.img_path = self.args.img
for map_fn in self.args.map:
cfg = ConfigLoader(self.cfg_path + '/' + map_fn)
map_obj = cfg.create_map(self.font_path_fn, self.icon_path)
map_obj.do()
# map_obj.show()
map_obj.save_img(self.img_path + '/' + map_fn[:-5] + '.png')
if self.args.upload:
cfg.upload(self.img_path + '/' + map_fn[:-5] + '.png')
del cfg, map_obj
def _cfg_logging(self):
"""
Configure logging output format.
"""
if self.args.debug:
loglevel = logging.DEBUG
else:
loglevel = logging.INFO
logformat = '[%(asctime)s] [%(name)s:%(levelname)s] - %(message)s'
logging.basicConfig(level=loglevel, format=logformat, datefmt='%d/%m/%Y %H:%M:%S')
def main():
WeathermapCLI()
if __name__ == '__main__':
main()