]> git.llucax.com Git - mecon/samurai.git/blobdiff - lib/SAMURAI/Usuario.php
Agrego las lineas de las consultas.
[mecon/samurai.git] / lib / SAMURAI / Usuario.php
index 8633bc2fd7a9a28ce81f7910bfe4cbee8c238f33..daa3af3f3cdf6c1f2d5b888a4e141f161dd2fbd7 100644 (file)
@@ -196,7 +196,7 @@ class SAMURAI_Usuario {
         $this->setLogin($login);
         $this->_idSistema = $idSistema;
         if (!is_null($login)) {
-            $tmp =& new MECON_Usuario(null, $login);
+            $tmp =& new MECON_Usuario($db, null, $login);
             $this->setNrodoc($tmp->getDni());
             $this->setNombre($tmp->getNombre());
             $this->_obtenerDatosDb();
@@ -319,7 +319,7 @@ class SAMURAI_Usuario {
      * @return mixed
      * @access public
      */
-    function guardarDatos($accion = grabar) // ~X2C
+    function guardarDatos($accion = 'grabar') // ~X2C
     {
         $accion = strtolower($accion); 
         switch ($accion)  {   
@@ -401,7 +401,7 @@ class SAMURAI_Usuario {
      */
     function verificarLogin() // ~X2C
     {
-        $usu = new MECON_Usuario();
+        $usu = new MECON_Usuario($this->_db);
         $tmp = $usu->verificarLogin($this->getLogin()); 
         if ($tmp) {
             if (PEAR::isError($tmp)) {
@@ -457,7 +457,7 @@ class SAMURAI_Usuario {
     {
         $sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
         
-        $usu = new MECON_Usuario();
+        $usu = new MECON_Usuario($db);
         $tmp = $usu->verificarLogin($login); 
         if ($tmp) {
             if (PEAR::isError($tmp)) {
@@ -519,5 +519,62 @@ class SAMURAI_Usuario {
     }
     // -X2C
 
+    // +X2C Operation 398
+    /**
+     * Funcion que obtiene la lista de usuarios que tienen al menos un permiso en la intranet.
+     *
+     * @param  DB &$db Conexion a la base de datos
+     * @param  string $login Parte del login a filtrar
+     *
+     * @return mixed
+     * @access public
+     * @static
+     */
+    function filtrarUsuarios(&$db, $login) // ~X2C
+    {
+        $sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
+        $sql = str_replace ('##?##', $login, $sql['obtener_datos_compartido']);
+        $db->setFetchMode(DB_FETCHMODE_ASSOC);
+        return $db->query($sql);
+    }
+    // -X2C
+
+    /**
+     * Metodo que devuelve los datos necesarios para listar usuarios.
+     *
+     * @param  SAMURAI_DB &$db Base de Datos
+     * @param  int $id_sistema Identificador del sistema
+     * @param  string $nombre Filtro de nombre
+     *
+     * @return mixed
+     * @access public
+     * @static
+     */
+    function getUsuariosPager(&$db, $id_sistema = null, $nombre = null) {
+
+        if ($nombre) {
+            $nombre = ' AND u.nombre LIKE '. $db->quoteSmart("%$nombre%");
+        }
+        if ($id_sistema) {
+            $sql = '
+                SELECT DISTINCT u.login, u.nombre 
+                FROM usuario.Usuario AS u, perfil_sist_usuario AS psu 
+                WHERE u.login = psu.login 
+                AND psu.id_sistema = '. $id_sistema 
+                . $nombre
+                .' ORDER BY login';
+        }
+        else {
+            $sql = '
+                SELECT login, nombre
+                FROM usuario.Usuario'.
+                $nombre
+                .' ORDER BY login
+                ';
+        }
+        return $db->query ($sql);
+    }
+
 } // -X2C Class :SAMURAI_Usuario
-?>
\ No newline at end of file
+?>