+ // +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($db);
+ $tmp = $usu->verificarLogin($login);
+ if ($tmp) {
+ if (PEAR::isError($tmp)) {
+ return $tmp;
+ }
+ }
+ else {
+ return new PEAR_Error('Usuario no reconocido.<br>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 Operation 396
+ /**
+ * Devuelve la informacion completa del usuario. Sistemas a los que esta asignado, perfiles que tiene dentro de cada sistema y permisos.
+ *
+ * @return mixed
+ * @access public
+ */
+ function informacionGeneral() // ~X2C
+ {
+ $sql = parse_ini_file(dirname(__FILE__) . '/Usuario/consultas.ini', true);
+ $tmp = $sql['obtener_informacion'];
+ $dbh = $this->_db->prepare($tmp);
+ $res = $this->_db->execute($dbh,array($this->getLogin()));
+
+ if (PEAR::isError($res)) {
+ return $res;
+ }
+
+ $rta = array();
+
+ while ($re = $res->fetchRow(DB_FETCHMODE_ASSOC)) {
+ $rta[$re['id_sistema']]['nombre_sistema'] = $re['nombre_sistema'];
+ $rta[$re['id_sistema']]['perfiles'][$re['id_perfil']]['desc_perfil'] =
+ $re['desc_perfil'];
+
+ $rta[$re['id_sistema']]['perfiles'][$re['id_perfil']]['permisos'][$re['id_permiso']]
+ [$re['observaciones']]['desc_permiso'] = $re['desc_permiso'];
+
+ $rta[$re['id_sistema']]['perfiles'][$re['id_perfil']]['permisos'][$re['id_permiso']]
+ [$re['observaciones']]['observaciones'] = $re['observaciones'];
+ }
+
+ return $rta;
+ }
+ // -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);
+
+ }
+