X-Git-Url: https://git.llucax.com/mecon/yatta.git/blobdiff_plain/ac4b40ecf55021f9d6439e0d692b7e598e4d040e..4c66554e7d941b4696e60782dcd708576dc8972d:/lib/YATTA/Controlador.php diff --git a/lib/YATTA/Controlador.php b/lib/YATTA/Controlador.php index dbd5b16..63b1d42 100644 --- a/lib/YATTA/Controlador.php +++ b/lib/YATTA/Controlador.php @@ -28,7 +28,7 @@ require_once 'YATTA/Proceso.php'; require_once 'YATTA/ProcesoDB.php'; require_once 'YATTA/Servidor.php'; -define ('PATH_TACHO', '/var/www/yatta/tacho/'); +define ('PATH_TACHO', '/var/www/sistemas/yatta/tacho/'); /** * Clase para el manejo centralizado de toda la informacion de YATTA. @@ -59,11 +59,12 @@ class YATTA_Controlador { /** * Agrega un proceso a la base de datos - * Los datos a pasar son: + * Recibe un array asociativo con: * Obligatorios * script : Path completo para el require_once. - * id_sistema : Identificador del sistema al que pertenece . - * descripcion: Es lo que permite al usuario identificar al proecso. + * id_sistema : Identificador del sistema al que pertenece. (Es el id que + * asigna SAMURAI) + * descripcion: Es lo que permite al usuario identificar al proceso. * owner : Login@Organismo de la persona responsable del proceso. * * Opcionales @@ -75,6 +76,7 @@ class YATTA_Controlador { * resultado : En caso que el proceso genere archivos resultado, se debe * indicar aqui el nombre del archivo que deben visualizar * los usuarios. + * parametros : Parametros que hay que pasarle al metodo run del script. * * @param DB $db Conexion a la base de datos. * @param mixed $datos Datos necesarios del proceso. @@ -94,10 +96,15 @@ class YATTA_Controlador { elseif (!is_array($datos)) { return new PEAR_Error ("Error con los datos pasados. El segundo". " parametro debe ser un array asociativo o una instancia". - " del objeto YATTA_Proceso."); + " del objeto YATTA_ProcesoDB."); } $res = $this->_obtenerServidor($db); + //Serializo los parametros + if (@$datos['parametros']) { + $datos['parametros'] = serialize($datos['parametros']); + } + if (DB::isError($res)) { return $res; } @@ -195,7 +202,8 @@ class YATTA_Controlador { * @access public */ function obtenerNuevoProceso($db, $id) { - $res = $db->query('SELECT p.id AS id, p.script AS script + $res = $db->query('SELECT p.id AS id, p.script AS script, p.parametros + AS parametros FROM yatta.procesos AS p WHERE p.server = '.$id.' AND status = 0 ORDER BY p.prioridad, p.id'); @@ -251,6 +259,9 @@ class YATTA_Controlador { return $res; } $res = $res->fetchRow(DB_FETCHMODE_ASSOC); + +//@FIXME El email se lo envio al owner y a los destinos, o al owner solamente? + $dest = split (',', @$res['destinos']); $to = $owner.'.gov.ar'; foreach ($dest as $d) { @@ -259,7 +270,7 @@ class YATTA_Controlador { $headers = "From: Intranet - YATTA \r\n"; $subject = "INTRANET - YATTA - Proceso Finalizado"; - $body = "El proceso {$res['descripcion']} ha finalizado ". + $body = "El proceso {$res['descripcion']} ha finalizado "; switch ($status) { case 2: @@ -301,5 +312,55 @@ class YATTA_Controlador { mail($to, $subject, $body, $headers); } + /** + * Verifica si un usuario tiene alguna informacion en la base de yatta para + * mostrarle el icono en la lista de sistemas de la intranet. + * + * @param DB $db Conexion a la base de datos. + * @param string $login Usuario que se esta verificando + * + * @return bool + * @access public + * @static + */ + function visible($DB, $login) { + $res = $db->query('SELECT count (p.id) AS id FROM yatta.procesos AS p'. + ' WHERE (p.owner LIKE \'%'. $login .'%\') OR'. + ' (p.destinos LIKE \'%'. $login .'%\')'); + + if (DB::isError($res)) { + return $res; + } + $res = $res->fetchRow(DB_FETCHMODE_ASSOC); + + return $res['id']; + } + + /** + * Busca los usuarios que tienen al menos una entrada en el mysql como + * owners. + * + * @param DB $db Conexion a la base de datos. + * + * @return mixed + * @access public + */ + function obtenerListaOwners($db) { + return $db->query('SELECT DISTINCT p.owner AS owner + FROM yatta.procesos As p'); + } + + /** + * Obtiene las cuotas especiales de los usuarios. + * + * @param DB $db Conexion a la base de datos. + * + * @return mixed + * @access public + */ + function obtenerListaCuotas($db) { + return $db->query('SELECT login, cuota + FROM yatta.cuotas'); + } } ?> \ No newline at end of file