X-Git-Url: https://git.llucax.com/mecon/samurai.git/blobdiff_plain/3c702b40a1806798e475c48abb456e5a9c2dac72..52ec6b73aae5937cd9c04e150e6b261b8be98b01:/lib/SAMURAI/Usuario.php
diff --git a/lib/SAMURAI/Usuario.php b/lib/SAMURAI/Usuario.php
index 57c0489..a394091 100644
--- a/lib/SAMURAI/Usuario.php
+++ b/lib/SAMURAI/Usuario.php
@@ -24,8 +24,17 @@
// $Rev$
//
+/** \page page_
+
+\section PRUEBA PRUEBA
+hola esto es una prueba
+
+ */
+
+
require_once 'PEAR.php';
require_once 'Perfil.php';
+require_once 'MECON/Usuario.php';
// +X2C Class 207 :SAMURAI_Usuario
@@ -75,6 +84,14 @@ class SAMURAI_Usuario {
*/
var $_perfiles;
+ /**
+ * Identificador del sistema en el cual se esta trabajando.
+ *
+ * @var int $idSistema
+ * @access protected
+ */
+ var $_idSistema;
+
/**
* Gets Login.
*
@@ -175,15 +192,20 @@ class SAMURAI_Usuario {
*
* @param SAMURAI_DB &$db Objeto conexion.
* @param string $login Login del usuario
+ * @param int $idSistema Identificador del sistema en el cual se esta trabajando
*
* @return void
* @access public
*/
- function SAMURAI_Usuario(&$db, $login = null) // ~X2C
+ function SAMURAI_Usuario(&$db, $login = null, $idSistema = null) // ~X2C
{
$this->_db = $db;
$this->setLogin($login);
+ $this->_idSistema = $idSistema;
if (!is_null($login)) {
+ $tmp =& new MECON_Usuario(null, $login);
+ $this->setNrodoc($tmp->getDni());
+ $this->setNombre($tmp->getNombre());
$this->_obtenerDatosDb();
}
}
@@ -241,7 +263,7 @@ class SAMURAI_Usuario {
//FORECHEO LO QUE ME DEVUELVA GET USUARIOS
$rta = array ();
foreach (SAMURAI_Usuario::getUsuarios($db, $id_sistema) as $Usuario) {
- $rta[$permiso->getLogin()] = $permiso->getNombre();
+ $rta[$Usuario->getLogin()] = $Usuario->getNombre();
}
return $rta;
}
@@ -262,7 +284,7 @@ class SAMURAI_Usuario {
{
$rta = array ();
foreach (SAMURAI_Usuario::_getLoginUsuarios($db, $id_sistema) as $login) {
- $tmp = new SAMURAI_Usuario($db,$login);
+ $tmp = new SAMURAI_Usuario($db, $login, $id_sistema);
array_push($rta, $tmp);
}
return $rta;
@@ -279,30 +301,16 @@ class SAMURAI_Usuario {
function _obtenerDatosDb() // ~X2C
{
$sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
- $tmp = $sql['obtener_datos_usuario'].$sql['obtener_datos_usuario3'];
- $dbh = $this->_db->prepare($tmp);
- $res = $this->_db->execute($dbh,array($this->getLogin()));
-
- if ($re = $res->fetchRow(DB_FETCHMODE_ASSOC)) {
- if (isset($re['nrodoc'])) {
- $this->setNrodoc($re['nrodoc']);
- }
- else {
- $this->setNrodoc();
- }
- if (isset($re['nombre'])) {
- $this->setNombre($re['nombre']);
- }
- else {
- $this->setNombre();
- }
- }
+
$tmp = $sql['obtener_perfiles_usuario'];
$dbh = $this->_db->prepare($tmp);
- $res = $this->_db->execute($dbh,array($this->getLogin(), $_SESSION['samurai']['id_sistema']));
+ $res = $this->_db->execute($dbh,array($this->getLogin(),
+ $this->_idSistema));
$rta = array();
+
while ($re = $res->fetchRow(DB_FETCHMODE_ASSOC)) {
- $tmp = new SAMURAI_Perfil($this->_db, $re['id_perfil']);
+ $tmp = new SAMURAI_Perfil($this->_db, $re['id_perfil'],
+ $this->_idSistema);
$rta[] = $tmp->getId();
}
$this->setPerfiles($rta);
@@ -350,8 +358,8 @@ class SAMURAI_Usuario {
foreach ($this->getPerfiles() as $perfil) {
$datos = array ($this->getLogin(),
$perfil,
- $_SESSION['samurai']['id_sistema'],
- $_SESSION['samurai']['login']);
+ $this->_idSistema,
+ $_SESSION['usuario']);
$res = $this->_db->execute($re, $datos);
if (PEAR::isError($res)) {
return $res;
@@ -372,7 +380,7 @@ class SAMURAI_Usuario {
$sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
$tmp = $sql['borrar'];
$dbh = $this->_db->prepare($tmp);
- $tmp = array ($this->getLogin(), $_SESSION['samurai']['id_sistema']);
+ $tmp = array ($this->getLogin(), $this->_idSistema);
return $this->_db->execute($dbh,$tmp);
}
// -X2C
@@ -399,20 +407,91 @@ class SAMURAI_Usuario {
* @access public
*/
function verificarLogin() // ~X2C
+ {
+ $usu = new MECON_Usuario();
+ $tmp = $usu->verificarLogin($this->getLogin());
+ if ($tmp) {
+ if (PEAR::isError($tmp)) {
+ return $tmp;
+ }
+ else {
+ return true;
+ }
+ }
+ else {
+ return new PEAR_Error('Usuario no reconocido.
Recuerde que éste debe haberse logueado previamente a Intranet');
+ }
+ }
+ // -X2C
+
+ // +X2C Operation 375
+ /**
+ * Verifica si el login actual ya esta asociado en base.
+ *
+ * @return mixed
+ * @access public
+ */
+ function verificarAsociacionExistente() // ~X2C
{
$sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
- $tmp = $sql['verificar_login'];
+ $tmp = $sql['verificar_login2'];
$dbh = $this->_db->prepare($tmp);
- $res = $this->_db->execute($dbh,array($this->getLogin()));
+ $res = $this->_db->execute($dbh,array($this->getLogin(),
+ $this->_idSistema));
$re = $res->fetchRow(DB_FETCHMODE_ASSOC);
- if ($re['cuenta'] == 0) {
- return new PEAR_Error('Usuario no reconocido.
Recuerde que éste debe haberse logueado previamente a Intranet');
+ if ($re['login']) {
+ return new PEAR_Error('El usuario seleccionado ya esta cargado. Modifique sus opciones.');
+ }
+ return 1;
+ }
+ // -X2C
+
+ // +X2C Operation 386
+ /**
+ * Metodo estatico que permite asociar un usuario con un perfil en un sistema determinado.
+ *
+ * @param DB &$db Conexion a la base de datos
+ * @param string $login Login del usuario que se quiere asociar
+ * @param int $id_perfil Identificador del perfil que se quiere asociar
+ * @param int $id_sistema identificador del sistema en el que se esta haciendo la asociacion
+ * @param int $responsable Login del usuario que esta haciendo los cambios
+ *
+ * @return mixed
+ * @access public
+ * @static
+ */
+ function asociarPerfil(&$db, $login, $id_perfil, $id_sistema, $responsable) // ~X2C
+ {
+ $sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
+
+ $usu = new MECON_Usuario();
+ $tmp = $usu->verificarLogin($login);
+ if ($tmp) {
+ if (PEAR::isError($tmp)) {
+ return $tmp;
+ }
+ else {
+ return true;
+ }
}
else {
- return 1;
+ return new PEAR_Error('Usuario no reconocido.
Recuerde que éste debe haberse logueado previamente a Intranet');
+ }
+
+ //Asocio el perfil con el usuario en perfil_sist_usuario
+ $datos = array ('login' => $login,
+ 'id_perfil' => $id_perfil,
+ 'id_sistema' => $id_sistema,
+ 'responsable' => $responsable);
+
+ $res = $db->autoExecute('samurai.perfil_sist_usuario', $datos, DB_AUTOQUERY_INSERT);
+ if (PEAR::isError($res)) {
+ return $res;
}
+
+ return 1;
}
// -X2C
} // -X2C Class :SAMURAI_Usuario
-?>
+?>
\ No newline at end of file