source: admin/WebConsole/gestores/gestor_usuarios.php

qndtest
Last change on this file was 5cef356, checked in by OpenGnSys Support Team <soporte-og@…>, 5 years ago

#915 Remove all references to SocketHidra?

This patch removes all remaining references to SocketHidra?. The existing
code uses the REST API ogAdmServer.

  • Property mode set to 100644
File size: 7.1 KB
Line 
1<?php
2// *******************************************************************************************************
3// Aplicación WEB: ogAdmWebCon
4// Autor: José Manuel Alonso (E.T.S.I.I.) Universidad de Sevilla
5// Fecha Creación: Año 2009-2010
6// Fecha Última modificación: Agosto-2010
7// Nombre del fichero: gestor_usuarios.php
8// Descripción :
9//              Gestiona el mantenimiento de la tabla de usuarios
10// *******************************************************************************************************
11include_once("../includes/ctrlacc.php");
12include_once("../clases/AdoPhp.php");
13include_once("../clases/XmlPhp.php");
14include_once("../clases/ArbolVistaXML.php");
15include_once("../includes/CreaComando.php");
16include_once("../includes/constantes.php");
17include_once("./relaciones/usuarios_eliminacion.php");
18include_once("../includes/opciones.php");
19//________________________________________________________________________________________________________
20$opcion=0; // Inicializa parametros
21
22$idusuario=0; 
23$usuario="";
24$pasguor="";
25$nombre="";
26$email="";
27$idambito=0;
28$ididioma=0;
29$idtipousuario=0;
30
31if (isset($_POST["opcion"])) $opcion=$_POST["opcion"];
32
33if (isset($_POST["idusuario"])) $idusuario=$_POST["idusuario"];
34if (isset($_POST["usuario"])) $usuario=$_POST["usuario"];
35if (isset($_POST["pasguor"])) $pasguor=$_POST["pasguor"];
36if (isset($_POST["nombre"])) $nombre=$_POST["nombre"];
37if (isset($_POST["email"])) $email=$_POST["email"];
38if (isset($_POST["idambito"])) $idambito=$_POST["idambito"];
39if (isset($_POST["ididioma"])) $ididioma=$_POST["ididioma"];
40if (isset($_POST["idtipousuario"])) $idtipousuario=$_POST["idtipousuario"];
41
42$tablanodo=""; // Arbol para nodos insertados
43
44$cmd=CreaComando($cadenaconexion); // Crea objeto comando
45$resul=false;
46if ($cmd){
47        $resul=Gestiona();
48        $cmd->Conexion->Cerrar();
49}
50// *************************************************************************************************************************************************
51?>
52<HTML>
53<HEAD>
54        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
55<BODY>
56        <SCRIPT language="javascript" src="../jscripts/propiedades_usuarios.js"></SCRIPT>
57<?php
58        $literal="";
59        switch($opcion){
60                case $op_alta :
61                        $literal="resultado_insertar_usuarios";
62                        break;
63                case $op_modificacion:
64                        $literal="resultado_modificar_usuarios";
65                        break;
66                case $op_eliminacion :
67                        $literal="resultado_eliminar_usuarios";
68                        break;
69                case $op_movida :
70                        $literal="resultado_cambiar_usuarios";
71                        break;
72                default:
73                        break;
74        }
75        echo '<P><SPAN style="visibility:hidden" id="arbol_nodo">'.$tablanodo.'</SPAN></P>';
76if ($resul){
77        echo '<SCRIPT language="javascript">'.chr(13);
78        echo 'var oHTML'.chr(13);
79        echo 'var cTBODY=document.getElementsByTagName("TBODY");'.chr(13);
80        echo 'o=cTBODY.item(1);'.chr(13);
81        if ($opcion==$op_alta )
82                echo $literal."(1,'".$cmd->DescripUltimoError()." ',".$idusuario.",o.innerHTML);";
83        else
84                echo $literal."(1,'".$cmd->DescripUltimoError()." ','".$nombre."');";
85        echo '</SCRIPT>';
86}
87else{
88        echo '<SCRIPT language="javascript">';
89        echo $literal."(0,'".$cmd->DescripUltimoError()."',".$idusuario.")";
90        echo '</SCRIPT>';
91}
92?>
93</BODY>
94</HTML>
95<?php
96/*________________________________________________________________________________________________________
97        Inserta, modifica o elimina datos en la tabla usuarios
98________________________________________________________________________________________________________*/
99function Gestiona(){
100        global  $cmd;
101        global  $opcion;
102        global $OPERADOR;
103        global $ADMINISTRADOR;
104
105        global $idusuario;
106        global $usuario;
107        global $pasguor;
108        global $nombre;
109        global $email;
110        global $idambito;
111        global $ididioma;
112        global $idtipousuario;
113
114        global  $op_alta;
115        global  $op_modificacion;
116        global  $op_eliminacion;
117        global  $op_movida;
118        global  $tablanodo;
119
120        $cmd->CreaParametro("@idusuario",$idusuario,1);
121        $cmd->CreaParametro("@usuario",$usuario,0);
122        $cmd->CreaParametro("@pasguor",$pasguor,0);
123        $cmd->CreaParametro("@nombre",$nombre,0);
124        $cmd->CreaParametro("@email",$email,0);
125        $cmd->CreaParametro("@idambito",$idambito,1);
126        $cmd->CreaParametro("@ididioma",$ididioma,1);
127        $cmd->CreaParametro("@idtipousuario",$idtipousuario,1);
128        // Generar clave de acceso a la API REST.
129        $apikey=md5(uniqid(rand(), true));
130        $cmd->CreaParametro("@apikey",$apikey,0);
131
132        switch($opcion){
133                case $op_alta :
134                        $cmd->texto="INSERT INTO usuarios (usuario,pasguor,nombre,email,ididioma,idtipousuario,apikey) VALUES (@usuario,SHA2(@pasguor,224),@nombre,@email,@ididioma,@idtipousuario,@apikey);";
135                        $resul=$cmd->Ejecutar();
136                        if ($resul){ // Crea una tabla nodo para devolver a la página que llamó ésta
137                                $idusuario=$cmd->Autonumerico();
138                                $arbolXML=SubarbolXML_usuarios($idusuario,$nombre,$idtipousuario);
139                                $baseurlimg="../images/signos"; // Url de las imagenes de signo
140                                $clasedefault="texto_arbol"; // Hoja de estilo (Clase por defecto) del árbol
141                                $arbol=new ArbolVistaXML($arbolXML,0,$baseurlimg,$clasedefault);
142                                $tablanodo=$arbol->CreaArbolVistaXML();
143                        }
144                        break;
145                case $op_modificacion:
146                        $cmd->texto="UPDATE usuarios SET usuario=@usuario,pasguor=SHA2(@pasguor,224),nombre=@nombre,email=@email,ididioma=@ididioma WHERE idusuario=@idusuario";
147                        $resul=$cmd->Ejecutar();
148                        break;
149                case $op_eliminacion :
150                        $resul=EliminaUsuarios($cmd,$idusuario,"idusuario");
151                        break;
152                default:
153                        break;
154        }
155        return($resul);
156}
157/*________________________________________________________________________________________________________
158        Busca los datos de un usuario
159                Parametros:
160                - cmd:Una comando ya operativo (con conexión abierta) 
161                - idusuario:El identificador del usuario
162________________________________________________________________________________________________________*/
163function toma_usuario($cmd,$idusuario){
164        global $usuario;
165        global $idambito;
166        global $idtipousuario;
167
168        $rs=new Recordset; 
169        $cmd->texto="SELECT usuario, idambito, idtipousuario FROM usuarios WHERE idusuario=".$idusuario;
170        $rs->Comando=&$cmd; 
171        if (!$rs->Abrir()) return(0); // Error al abrir recordset
172        $rs->Primero(); 
173        if (!$rs->EOF){
174                $usuario=$rs->campos["usuario"];
175                $idambito=$rs->campos["idambito"];
176                $idtipousuario=$rs->campos["idtipousuario"];
177                return(true);
178        }
179        else
180                return(false);
181}
182/*________________________________________________________________________________________________________
183        Crea un arbol XML para el nuevo nodo insertado
184________________________________________________________________________________________________________*/
185function SubarbolXML_usuarios($idusuario,$nombre,$idtipousuario){
186                global $LITAMBITO_USUARIOS;
187                global $SUPERADMINISTRADOR;
188                global $ADMINISTRADOR;
189                global $OPERADOR;
190
191                switch($idtipousuario){
192                        case $SUPERADMINISTRADOR:
193                                $urlimg="../images/iconos/superadministradores.gif";
194                                break;
195                        case $ADMINISTRADOR:
196                                $urlimg="../images/iconos/administradores.gif";
197                                break;
198                        case $OPERADOR:
199                                $urlimg="../images/iconos/operadores.gif";
200                                break;
201                }
202                $cadenaXML='<USUARIO';
203                // Atributos                   
204                $cadenaXML.=' clickcontextualnodo="menu_contextual(this,' ."'flo_".$LITAMBITO_USUARIOS."'" .')"';
205                $cadenaXML.=' imagenodo="'.$urlimg.'"';
206                $cadenaXML.=' infonodo="'.$nombre.'"';
207                $cadenaXML.=' nodoid='.$LITAMBITO_USUARIOS.'-'.$idusuario;
208                $cadenaXML.='></USUARIO>';
209                return($cadenaXML);
210} 
211?>
Note: See TracBrowser for help on using the repository browser.