-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathArborSPReportes.py
68 lines (51 loc) · 2.52 KB
/
ArborSPReportes.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
#!/usr/bin/python
# -*- coding: utf-8 -*-
#Autor: Saul Vargas Leon
import logging
import config
import loadfile
import getcookies
import setoutput
import getreport
import savefile
import cmdparser
from tqdm import tqdm
def main():
logging.basicConfig(format='%(asctime)s %(message)s', level=logging.INFO)
args = cmdparser.loadargs()
logging.info("Cargando configuracion desde %s", args["config_file"])
configuracion = config.load_config(args["config_file"])
if args["start_date"] is 'empty':
args.pop("start_date")
if args["end_date"] is 'empty':
args.pop("end_date")
args.pop("config_file")
configuracion.update(args)
logging.debug(configuracion)
endpoint_uri = 'https://' + configuracion["endpoint"] + '/'
mos_ids = loadfile.loadidnames(configuracion["lista_mo"])
logging.info('Cargados %s Mos de archivo %s', len(mos_ids), configuracion["lista_mo"])
logging.debug(mos_ids)
cookie = getcookies.getcookie(endpoint_uri, configuracion["web_user"], configuracion["web_pass"])
logging.debug('Nombre: %s', cookie["cookie_name"])
logging.debug('Valor: %s', cookie["cookie_value"])
setoutput.checkmkdir(configuracion["output_dir"])
logging.info('Los reportes se depositaran en el directorio %s', configuracion["output_dir"])
logging.info('Descargando reportes Summary, Applications, Alerts y Top Talkers')
logging.info('Del %s al %s para %d MOs', configuracion["start_date"],
configuracion["end_date"], len(mos_ids))
for customer in tqdm(mos_ids, desc='Reportes', unit='MO'):
report_output_dir = configuracion["output_dir"] + '/' + customer[1] + '/'
setoutput.checkmkdir(report_output_dir)
for reporte in tqdm(['summary', 'alerts', 'applications', 'toptalkers'], desc='PDF', unit='pdf'):
logging.debug('Enviando a generar reporte tipo: %s', reporte)
report_data = getreport.getreport(configuracion["endpoint"],
reporte,
cookie,
customer,
configuracion["start_date"],
configuracion["end_date"])
savefile.savefile(report_output_dir + '/' + customer[1] + '_' + reporte + '.pdf', report_data)
logging.info('Se ha finalizado la generacion de reportes')
if __name__ == "__main__":
main()