-
Notifications
You must be signed in to change notification settings - Fork 1
/
backend.py
106 lines (81 loc) · 3.41 KB
/
backend.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
# -*- coding: utf-8 -*-
__author__ = "Andres Giordano"
__version__ = "0.1.0"
__maintainer__ = "Andres Giordano"
__email__ = "andresgiordano.unlu@gmail.com"
__status__ = "Testing"
from modulos.RadarFT import RadarFT
from modulos.Agenda import Agenda
from modulos.RadarManager import RadarManager
import os
import argparse
import datetime
import subprocess
from modulos.Configurations import getLog,getConfsValue
# Cambio directorio de trabajo al directorio de este script porque es ejecutado desde un Cron
parser = argparse.ArgumentParser(description='Procesamiento de productos.', formatter_class=argparse.RawTextHelpFormatter)
parser.add_argument('-p', type=int, required=True,
help='Producto a procesar.')
args = vars(parser.parse_args())
def cleanTemp():
if len(files)>0:
logger.info('Borrando archivos temporales')
# Borrando los archivos una vez generado el producto
for f in files:
os.remove(f)
rm = RadarManager(getConfsValue('radars_yml_dir'))
rm.loadRadars()
ag = Agenda(getConfsValue('products_yml_dir'))
ag.loadProducts()
prod = ag.getProduct(args['p'])
abspath = os.path.abspath(__file__)
logger = getLog('backend_logger', getConfsValue('logs_dir')+'backend_log_product_' + str(prod.id))
all_vol_found = True
files = []
# Si no existe la carpeta de descarga para este producto se crea
prod_download_dir = getConfsValue('tmp_download_dir')+str(prod.id)
if not os.path.isdir(prod_download_dir):
os.mkdir(prod_download_dir)
prod_out_dir = getConfsValue('products_out_dir')+str(prod.id)
if not os.path.isdir(prod_out_dir):
os.mkdir(prod_out_dir)
prod_out_dir += '/'
for r_id in prod.radares:
logger.info('Generando producto '+str(prod.id)+ ' para radar '+r_id)
# Si no existe la carpeta de descarga para el radar se crea dentro de la del producto
radar_download_dir = prod_download_dir + '/'+r_id
if not os.path.isdir(radar_download_dir):
os.mkdir(radar_download_dir)
radar_download_dir += '/'
radar = rm.getRadar(r_id)
radar_ft = RadarFT(radar)
if radar_ft.isConnected():
start_time = datetime.datetime.today() - datetime.timedelta(minutes = prod.step)
file = radar_ft.searchVol(int(start_time.strftime("%H")),
int(start_time.strftime("%M")),
prod.var,
prod.step)
if file is not None:
logger.info('Volumen encontrado: '+file)
out_filename = radar_download_dir+file
logger.info('Guardando en: ' + out_filename)
radar_ft.downloadVolFile(file, out_filename)
files.append(out_filename)
else:
logger.warn('No se encontro el volumen')
all_vol_found = False
else:
logger.error('No se logro conectar al radar '+r_id)
if prod.m and not all_vol_found:
logger.warn('No se puede generar el mosaico porque no fueron encontrados todos los volumenes.')
cleanTemp()
exit(0)
# Genero el producto
if len(files)>0:
radar_cmd_command = getConfsValue('python_bin')+'python3 '+getConfsValue('radar_cmd_dir')+'radar-cmd.py -pf ' + prod.file + ' -f '+','.join(files)+ ' -do '+getConfsValue('products_out_dir')
logger.info(radar_cmd_command)
res = subprocess.call(radar_cmd_command, shell=True)
logger.info('radar-cmd exit('+str(res)+')')
cleanTemp()
else:
logger.warn('Sin archivos para generar el producto.')