X-Git-Url: https://git.llucax.com/mecon/ai.git/blobdiff_plain/174ddcbe91844e4c754eb58b88f645a56952a475..4d96a4e9e14558cb4b0d546041300ae0fa499d65:/sistema/local_lib/Sistema.php diff --git a/sistema/local_lib/Sistema.php b/sistema/local_lib/Sistema.php index f8de809..2d2f63a 100644 --- a/sistema/local_lib/Sistema.php +++ b/sistema/local_lib/Sistema.php @@ -27,11 +27,12 @@ // $Id$ // - - +require_once 'AIError.php'; // +X2C Class 416 :Sistema /** + * Sistema. + * * @access public */ class Sistema { @@ -62,10 +63,10 @@ class Sistema { /** * Enlace a la ayuda del sistema. * - * @var string $linkAyuda + * @var string $link_ayuda * @access public */ - var $linkAyuda = ''; + var $link_ayuda = ''; /** * Indica si esta habilitado. @@ -77,58 +78,130 @@ class Sistema { // ~X2C - - // +X2C Operation 459 + // +X2C Operation 466 /** - * @param DB &$db DB donde guardar. + * @param int $sistema ID del sistema. * - * @return bool + * @return void * @access public */ - function guardar(&$db)// ~X2C + function Sistema($sistema = 0) // ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + $this->sistema = $sistema; } // -X2C // +X2C Operation 460 /** - * @param mixed &$db Base de datos o Resultado a utilizar. + * @param mixed $db Base de datos o Resultado a utilizar. * - * @return bool + * @return PEAR_Error * @access public */ - function cargar(&$db)// ~X2C + function cargar($db) // ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + $sistema = intval($this->sistema); + if (is_a($db, 'db_result')) { + $result = $db; + // Si no es un resultado, hago el query. + } else { + $result = $db->query( + "SELECT * + FROM sistema + WHERE sistema = $sistema" + ); + if (DB::isError($result)) { + return $result; + } + } + // Obtengo la fila. + $row = $result->fetchRow(DB_FETCHMODE_ASSOC); + if (!$row) { + return new AIError(AIERROR_NO_RESULTADOS, + "No hay más resultados en la DB [sistema=$sistema]"); + } + // Asigno valores al objeto. + extract($row); + $this->sistema = $sistema; + $this->icono = $icono; # FIXME - new HTML_Icono (o no?) + $this->link = $link; + $this->link_ayuda = $link_ayuda; + $this->habilitado = $habilitado; + return true; } // -X2C - // +X2C Operation 461 + // +X2C Operation 459 /** - * @param int $db DB de donde borrar. + * @param DB $db DB donde guardar. * - * @return bool + * @return PEAR_Error * @access public */ - function borrar($db)// ~X2C + function guardar($db) // ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + $sistema = intval($this->sistema); + $where = ''; + $datos = array( + 'icono' => $this->icono, + 'link' => $this->link, + 'link_ayuda' => $this->link_ayuda, + 'habilitado' => $this->habilitado ? 1 : 0, + ); + if ($sistema) { + $accion = DB_AUTOQUERY_UPDATE; + $where = "sistema = $sistema"; + } else { + $accion = DB_AUTOQUERY_INSERT; + $sistema = $db->nextId('sistema'); + if (DB::isError($sistema)) { + return $sistema; + } + // Asigno el nuevo id de sistema. + $this->sistema = $sistema; + $datos['sistema'] = $sistema; + } + $res = $db->autoExecute('sistema', $datos, $accion, $where); + if (DB::isError($res)) { + return $res; + } + return true; } // -X2C - // +X2C Operation 466 + // +X2C Operation 461 /** - * @param int $sistema ID del sistema. + * @param DB $db DB de donde borrar. * - * @return void + * @return PEAR_Error + * @access public + */ + function borrar($db) // ~X2C + { + $sistema = intval($this->sistema); + if ($sistema) { + $res = $db->query( + "DELETE FROM sistema WHERE sistema = $sistema"); + if (DB::isError($res)) { + return $res; + } + return true; + } + return PEAR::raiseError("No hay un sistema válido para borrar"); + } + // -X2C + + // +X2C Operation 502 + /** + * @return Sistema * @access public */ - function Sistema($sistema = 0)// ~X2C + function __clone() // ~X2C { - trigger_error('Not implemented!', E_USER_WARNING); + return $this; } // -X2C } // -X2C Class :Sistema + ?> \ No newline at end of file