public function crearTablaIndicador(FichaTecnica $fichaTecnica, $duracion = 10)
 {
     $ahora = new \DateTime("now");
     if ($fichaTecnica->getUpdatedAt() != '') {
         $ultimo_calculo = $fichaTecnica->getUpdatedAt()->getTimestamp();
         $diff_minutos = ($ahora->getTimestamp() - $ultimo_calculo) / 60;
         if ($diff_minutos <= $duracion) {
             return;
         }
     }
     $em = $this->getEntityManager();
     $util = new \MINSAL\IndicadoresBundle\Util\Util();
     $campos = str_replace("'", '', $fichaTecnica->getCamposIndicador());
     $nombre_indicador = $util->slug($fichaTecnica->getNombre());
     $tablas_variables = array();
     $sql = '';
     // Crear las tablas para cada variable
     foreach ($fichaTecnica->getVariables() as $variable) {
         //Recuperar la información de los campos para crear la tabla
         $tabla = strtolower($variable->getIniciales());
         $sql .= 'DROP TABLE IF EXISTS tmp_ind_' . $nombre_indicador . '; ';
         $sql .= 'CREATE TEMP TABLE IF NOT EXISTS ' . $tabla . '(';
         foreach ($variable->getOrigenDatos()->getCampos() as $campo) {
             $sql .= $campo->getSignificado()->getCodigo() . ' ' . $campo->getTipoCampo()->getCodigo() . ', ';
         }
         $sql = trim($sql, ', ') . ');';
         //Llenar la tabla con los valores del hstore
         $sql .= "INSERT INTO {$tabla}\n                SELECT (populate_record(null::{$tabla}, datos)).*                 \n                FROM fila_origen_dato \n                WHERE id_origen_dato = " . $variable->getOrigenDatos()->getId() . '
                 ;';
         //Obtener solo los datos que se pueden procesar en el indicador
         $sql .= "SELECT  {$campos}, SUM(calculo::numeric) AS " . $tabla . "\n                INTO TEMP  {$tabla}" . "_var\n                FROM {$tabla}                 \n                GROUP BY {$campos} \n                HAVING  SUM(calculo::numeric) > 0\n                    ;";
         $tablas_variables[] = $tabla;
     }
     $sql .= 'SELECT  ' . $campos . ',' . implode(',', $tablas_variables) . " INTO tmp_ind_" . $nombre_indicador . " FROM  " . array_shift($tablas_variables) . '_var ';
     foreach ($tablas_variables as $tabla) {
         $sql .= " INNER JOIN " . $tabla . "_var USING ({$campos}) ";
     }
     $fichaTecnica->setUpdatedAt($ahora);
     $em->persist($fichaTecnica);
     $em->flush();
     $em->getConnection()->exec($sql);
 }
 public function crearCamposIndicador(FichaTecnica $fichaTecnica)
 {
     $em = $this->_em;
     //Recuperar las variables
     $variables = $fichaTecnica->getVariables();
     $origen_campos = array();
     $origenDato = array();
     foreach ($variables as $k => $variable) {
         //Obtener la información de los campos de cada origen
         $origenDato[$k] = $variable->getOrigenDatos();
         if ($origenDato[$k]->getEsFusionado()) {
             $significados = explode(',', $origenDato[$k]->getCamposFusionados());
             //Los tipos de campos sacarlos de uno de los orígenes de datos que ha sido fusionado
             $fusionados = $origenDato[$k]->getFusiones();
             $fusionado = $fusionados[0];
             $tipos = array();
             foreach ($fusionado->getAllFields() as $campo) {
                 $tipos[$campo->getSignificado()->getCodigo()] = $campo->getTipoCampo()->getCodigo();
             }
             foreach ($significados as $sig) {
                 $sig_ = str_replace("'", '', $sig);
                 $significado = $em->getRepository('IndicadoresBundle:SignificadoCampo')->findOneBy(array('codigo' => $sig_));
                 $llave = $significado->getCodigo() . '-' . $tipos[$sig_];
                 $origen_campos[$origenDato[$k]->getId()][$llave]['significado'] = $sig_;
             }
         } elseif ($origenDato[$k]->getEsPivote()) {
             foreach ($origenDato[$k]->getFusiones() as $or) {
                 foreach ($or->getAllFields() as $campo) {
                     //La llave para considerar campo comun será el mismo significado
                     $llave = $campo->getSignificado()->getCodigo();
                     //$llave = $campo->getSignificado()->getId();
                     $origen_campos[$origenDato[$k]->getId()][$llave]['significado'] = $campo->getSignificado()->getCodigo();
                 }
             }
         } else {
             foreach ($origenDato[$k]->getAllFields() as $campo) {
                 //La llave para considerar campo comun será el mismo tipo y significado
                 $llave = $campo->getSignificado()->getCodigo() . '-' . $campo->getTipoCampo()->getCodigo();
                 //$llave = $campo->getSignificado()->getId();
                 $origen_campos[$origenDato[$k]->getId()][$llave]['significado'] = $campo->getSignificado()->getCodigo();
             }
         }
         //Determinar los campos comunes (con igual significado e igual tipo)
         $aux = $origen_campos;
         $campos_comunes = array_shift($aux);
         foreach ($aux as $a) {
             $campos_comunes = array_intersect_key($campos_comunes, $a);
         }
     }
     $aux = array();
     foreach ($campos_comunes as $campo) {
         $aux[$campo['significado']] = $campo['significado'];
     }
     if (isset($aux['calculo'])) {
         unset($aux['calculo']);
     }
     $campos_comunes = implode(", ", $aux);
     if ($fichaTecnica->getCamposIndicador() != '') {
         //Si ya existen los campos sacar el orden que ya ha especificado el usuario
         $act = explode(',', str_replace(' ', '', $fichaTecnica->getCamposIndicador()));
         $campos_comunes = array_intersect($act, $aux);
         //agregar los posibles campos nuevos
         $campos_comunes = array_merge($campos_comunes, array_diff($aux, $act));
         $campos_comunes = implode(", ", $campos_comunes);
     }
     $fichaTecnica->setCamposIndicador($campos_comunes);
     $em->flush();
 }
 /**
  * @Route("/indicador/dimensiones/{id}", name="indicador_dimensiones", options={"expose"=true})
  */
 public function getDimensiones(FichaTecnica $fichaTec)
 {
     $resp = array();
     $em = $this->getDoctrine()->getManager();
     if ($fichaTec) {
         $resp['nombre_indicador'] = $fichaTec->getNombre();
         $resp['id_indicador'] = $fichaTec->getId();
         $resp['unidad_medida'] = $fichaTec->getUnidadMedida();
         if ($fichaTec->getUpdatedAt() != "") {
             $resp["origen_dato_actualizacion"] = date('d/m/Y H:i:s', $fichaTec->getUpdatedAt()->getTimestamp());
         }
         if ($fichaTec->getCamposIndicador() != '') {
             $campos = explode(',', str_replace(array("'", ' '), array('', ''), $fichaTec->getCamposIndicador()));
         } else {
             $campos = array();
         }
         $dimensiones = array();
         foreach ($campos as $campo) {
             $significado = $em->getRepository('IndicadoresBundle:SignificadoCampo')->findOneByCodigo($campo);
             if (count($significado->getTiposGraficosArray()) > 0) {
                 $dimensiones[$significado->getCodigo()]['descripcion'] = ucfirst(preg_replace('/^Identificador /i', '', $significado->getDescripcion()));
                 $dimensiones[$significado->getCodigo()]['escala'] = $significado->getEscala();
                 $dimensiones[$significado->getCodigo()]['origenX'] = $significado->getOrigenX();
                 $dimensiones[$significado->getCodigo()]['origenY'] = $significado->getOrigenY();
                 $dimensiones[$significado->getCodigo()]['graficos'] = $significado->getTiposGraficosArray();
             }
         }
         $rangos_alertas_aux = array();
         foreach ($fichaTec->getAlertas() as $k => $rango) {
             $rangos_alertas_aux[$rango->getLimiteSuperior()]['limite_sup'] = $rango->getLimiteSuperior();
             $rangos_alertas_aux[$rango->getLimiteSuperior()]['limite_inf'] = $rango->getLimiteInferior();
             $rangos_alertas_aux[$rango->getLimiteSuperior()]['color'] = $rango->getColor()->getCodigo();
             $rangos_alertas_aux[$rango->getLimiteSuperior()]['comentario'] = $rango->getComentario();
         }
         ksort($rangos_alertas_aux);
         $rangos_alertas = array();
         foreach ($rangos_alertas_aux as $rango) {
             $rangos_alertas[] = $rango;
         }
         $resp['rangos'] = $rangos_alertas;
         $resp['formula'] = $fichaTec->getFormula();
         $resp['meta'] = $fichaTec->getMeta();
         $resp['dimensiones'] = $dimensiones;
         //Verificar que se tiene la más antigua de las últimas lecturas de los orígenes
         //de datos del indicador
         $ultima_lectura = new \DateTime("NOW");
         foreach ($fichaTec->getVariables() as $var) {
             $fecha_lectura = $em->getRepository('IndicadoresBundle:OrigenDatos')->getUltimaActualizacion($var->getOrigenDatos());
             if ($fecha_lectura < $ultima_lectura) {
                 $ultima_lectura = $fecha_lectura;
             }
             $conexion = "Excel o csv";
             foreach ($var->getOrigenDatos()->getConexiones() as $od) {
                 $conexion = $od->__toString();
             }
             $fuente = null;
             if (method_exists($var->getIdFuenteDato(), '__toString')) {
                 $fuente = $var->getIdFuenteDato()->__toString();
             }
             $responsable = null;
             if (method_exists($var->getIdResponsableDato(), '__toString')) {
                 $responsable = $var->getIdResponsableDato()->__toString();
             }
             $resp["origen_dato_"][] = array("origen_dato_nombre" => $var->getNombre(), "origen_dato_confiabilidad" => $var->getConfiabilidad(), "origen_dato_fuente" => $fuente, "origen_dato_responsable" => $responsable, "origen_dato_origen" => $var->getOrigenDatos()->getNombre(), "origen_dato_conexion" => $conexion);
         }
         $fichaTec->setUltimaLectura(new \DateTime($ultima_lectura));
         $em->flush();
         $resp['ultima_lectura'] = date('d/m/Y H:i:s', $fichaTec->getUltimaLectura()->getTimestamp());
         $resp['resultado'] = 'ok';
     } else {
         $resp['resultado'] = 'error';
     }
     $response = new Response(json_encode($resp));
     if ($this->get('kernel')->getEnvironment() != 'dev') {
         $response->setMaxAge($this->container->getParameter('indicador_cache_consulta'));
     }
     return $response;
 }
Exemple #4
0
 public function crearCamposIndicador(FichaTecnica $fichaTecnica)
 {
     //Recuperar las variables
     $variables = $fichaTecnica->getVariables();
     $origen_campos = array();
     $origenDato = array();
     foreach ($variables as $k => $variable) {
         //Obtener la información de los campos de cada origen
         $origenDato[$k] = $variable->getOrigenDatos();
         foreach ($origenDato[$k]->getCampos() as $campo) {
             //La llave para considerar campo comun será el mismo tipo y significado
             $llave = $campo->getSignificado()->getId() . '-' . $campo->getTipoCampo()->getId();
             $origen_campos[$origenDato[$k]->getId()][$llave]['significado'] = $campo->getSignificado()->getCodigo();
         }
         //Determinar los campos comunes (con igual significado)
         $aux = $origen_campos;
         $campos_comunes = array_shift($aux);
         foreach ($aux as $a) {
             $campos_comunes = array_intersect_key($campos_comunes, $a);
         }
     }
     $aux = array();
     foreach ($campos_comunes as $campo) {
         $aux[$campo['significado']] = $campo['significado'];
     }
     if (isset($aux['calculo'])) {
         unset($aux['calculo']);
     }
     $campos_comunes = implode(",", $aux);
     if ($fichaTecnica->getCamposIndicador() != '') {
         //Si ya existen los campos sacar el orden que ya ha especificado el usuario
         $act = explode(',', $fichaTecnica->getCamposIndicador());
         $campos_comunes = array_intersect($act, $aux);
         //agregar los posibles campos nuevos
         $campos_comunes = array_merge($campos_comunes, array_diff($aux, $act));
         $campos_comunes = implode(",", $campos_comunes);
     }
     $fichaTecnica->setCamposIndicador($campos_comunes);
 }