source: admin/WebConsole/varios/incorporaordenadores.php @ 71cc14f

918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Last change on this file since 71cc14f was 30e0a23, checked in by ramon <ramongomez@…>, 12 years ago

#609: Mejorar rendimiento de acceso a la BD en el formulario de incorporar ordenadores; corregir errata en ficheros SQL.

git-svn-id: https://opengnsys.es/svn/branches/version1.0@3920 a21b9725-9963-47de-94b9-378ad31fedc9

  • Property mode set to 100644
File size: 7.5 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: incorporaordenadores.php
8// Descripción :
9//              Da de alta en la base de datos nuevos ordenadores desde un fichero de configuración dhcp
10// *************************************************************************************************************************************************
11include_once("../includes/ctrlacc.php");
12include_once("../clases/AdoPhp.php");
13include_once("../includes/CreaComando.php");
14include_once("../includes/tftputils.php");
15include_once("../idiomas/php/".$idioma."/incorporaordenadores_".$idioma.".php");
16include_once("../idiomas/php/".$idioma."/avisos_".$idioma.".php");
17//________________________________________________________________________________________________________
18$cmd=CreaComando($cadenaconexion);
19if (!$cmd)
20        Header('Location: '.$pagerror.'?herror=2'); // Error de conexión con servidor B.D.
21//___________________________________________________________________________________________________
22$swf=0;
23$idaula=0;
24$nombreaula="";
25$contenido="";
26
27if (isset($_GET["idaula"])) $idaula=$_GET["idaula"];
28if (isset($_GET["nombreaula"])) $nombreaula=$_GET["nombreaula"];
29
30if (isset($_POST["swf"])) $swf=$_POST["swf"]; // Recoge parametros
31if (isset($_POST["contenido"])) $contenido=$_POST["contenido"];
32if (isset($_POST["idaula"])) $idaula=$_POST["idaula"];
33if (isset($_POST["nombreaula"])) $nombreaula=$_POST["nombreaula"];
34
35$resul=0;
36$ordDup="";
37
38if(!empty($contenido)){ // Se ha introducido contenido en lugar de fichero
39        $resul=procesaLineas($cmd,$idaula,$contenido);
40}
41//___________________________________________________________________________________________________
42?>
43<HTML>
44<TITLE>Administración web de aulas</TITLE>
45<HEAD>
46        <meta http-equiv="Content-Type" content="text/html;charset=UTF-8">
47<LINK rel="stylesheet" type="text/css" href="../estilos.css">
48</HEAD>
49<BODY>
50<FORM action="incorporaordenadores.php" method="post" name="fdatos">
51        <INPUT type=hidden name=swf value=1>
52        <INPUT type=hidden name=idaula value=<?echo $idaula?>>
53        <INPUT type=hidden name=nombreaula value=<?echo $nombreaula?>>
54        <BR>
55        <P align=center class=cabeceras><?echo $TbMsg[0]?><BR>
56        <SPAN align=center class=subcabeceras><IMG src="../images/iconos/aula.gif">&nbsp;<?echo $TbMsg[1].":".$nombreaula ?></SPAN></P>
57<!------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------->
58<table align="center" class="tabla_datos" border="0" cellpadding="0" cellspacing="1">
59<!------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------->
60        <tr>
61            <th>&nbsp;<?php echo $TbMsg[2]?>&nbsp;</th>
62                <td><textarea class="cajatexto" name="contenido" cols="70" rows="18"></textarea></td></tr>
63        <tr><th colspan="2">&nbsp;<?php echo $TbMsg["WARN_NAMELENGTH"]?>&nbsp;</th></tr>
64<!------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------->
65</table>
66 </FORM>
67<TABLE align=center>
68        <TR>
69                <TD><IMG src="../images/boton_cancelar.gif" style="cursor:hand"  onclick=""></TD>
70                <TD width=20></TD>
71                <TD><IMG src="../images/boton_confirmar.gif" style="cursor:hand"  onclick="javascript:document.fdatos.submit();"></TD>
72        </TR>
73</TABLE>
74<?php
75//________________________________________________________________________________________________________
76// Mensaje con el resultado del proceso
77echo '<SCRIPT LANGUAGE="javascript">';
78if (!empty($resul))
79        echo "  alert('".$TbMsg[$resul]."');";
80if (!empty($ordDup))
81        echo "  alert('".$TbMsg[5]."\\n".$ordDup."');";
82echo '</SCRIPT>';
83//________________________________________________________________________________________________________
84?>
85</BODY>
86</HTML>
87<?php
88// *************************************************************************************************************************************************
89function procesaLineas($cmd,$idaula,$buffer)
90{
91        $nombre="";
92        $MAC="";
93        $IP="";
94        $sw=false;
95        $posa=-1;
96
97        while($posa<strlen($buffer)){
98                        if ('host'==substr($buffer,$posa,4)){
99                                $posa=$posa+4;
100                                $posb=$posa;
101                                while(  substr($buffer,$posb,1)!="{") $posb++;
102                                $nombre=substr($buffer,$posa,$posb-$posa);
103                        }
104                        if ('hardware ethernet'==substr($buffer,$posa,17)){
105                                $posa=$posa+17;
106                                $posb=$posa;
107                                while(  substr($buffer,$posb,1)!=";") $posb++;
108                                $MAC=substr($buffer,$posa,$posb-$posa);
109                        }
110
111                        if ('fixed-address'==substr($buffer,$posa,13)){
112                                $posa=$posa+13;
113                                $posb=$posa;
114                                while(  substr($buffer,$posb,1)!=";")
115                                        $posb++;
116                                $IP=substr($buffer,$posa,$posb-$posa);
117                        }
118                        if(!empty($nombre) && !empty($MAC) && !empty($IP)){
119                                if(!Inserta($cmd,$idaula,$nombre,$MAC,$IP))
120                                        return(4);
121                                $sw=true;
122                                $nombre="";
123                                $MAC="";
124                                $IP="";
125                                $resul=true;
126                        }
127                        $posa++;
128        }
129        if($sw)
130                return(3);
131        else
132                return(4);
133
134}
135//________________________________________________________________________________________________________
136function Inserta($cmd,$idaula,$nombre,$lamac,$laip)
137{
138        global $ordDup;
139        global $idioma;
140       
141        $grupoid=0;
142        $nombreordenador=trim($nombre);
143        $ip=trim($laip);
144        $auxmac=trim($lamac);
145        $mac="";
146        for($i=0;$i<strlen($auxmac);$i++)
147                if(substr($auxmac,$i,1)!=":")
148                        $mac.=substr($auxmac,$i,1);
149        if(existeOrdenador($cmd,$nombreordenador,$mac,$ip)){
150                $ordDup.="Nombre=".$nombre.",Mac=".$mac.",Dirección ip=".$ip." \\n";
151                return(true);   
152        }
153
154        $idperfilhard=0;
155## ADV: modificacion para asignar a los ordenadores, cuando se crean desde "incorpoar ordenadores" el repositorio "default"
156        $idrepositorio=1;
157        $idconfiguracion=0;
158        $cmd->CreaParametro("@grupoid",$grupoid,1);
159        $cmd->CreaParametro("@idaula",$idaula,1);
160        $cmd->CreaParametro("@nombreordenador",$nombreordenador,0);
161        $cmd->CreaParametro("@ip",$ip,0);
162        $cmd->CreaParametro("@mac",$mac,0);
163        $cmd->CreaParametro("@idperfilhard",$idperfilhard,1);
164        $cmd->CreaParametro("@idrepositorio",$idrepositorio,1);
165        $cmd->CreaParametro("@idconfiguracion",$idconfiguracion,1);
166
167        $cmd->texto="INSERT INTO ordenadores (nombreordenador, ip, mac, idperfilhard,
168                                 idrepositorio, router, mascara, idaula, grupoid)
169                          SELECT @nombreordenador, @ip, @mac, @idperfilhard,
170                                 @idrepositorio, router, netmask, @idaula, @grupoid
171                            FROM aulas
172                           WHERE idaula=".$idaula;
173        $resul=$cmd->Ejecutar();
174       
175        // Crear fichero de arranque PXE con plantilla por defecto.
176        if ($resul) {
177                $idordenador=$cmd->Autonumerico();
178                createBootMode ($cmd, "", $idordenador, $idioma);
179        }
180        return($resul);
181}
182//________________________________________________________________________________________________________
183//      Recupera los datos de un ordenador
184//              Parametros:
185//              - cmd: Una comando ya operativo (con conexión abierta) 
186//              - ip: Dirección IP
187//________________________________________________________________________________________________________
188function existeOrdenador($cmd,$nombre,$MAC,$IP){
189        $rs=new Recordset;
190        $cmd->texto="SELECT * FROM ordenadores WHERE nombreordenador='".$nombre."' OR mac='".$MAC."' OR ip='".$IP."'";
191        $rs->Comando=&$cmd;
192        if (!$rs->Abrir()) return(false); // Error al abrir recordset
193        $rs->Primero();
194        if (!$rs->EOF){
195                $rs->Cerrar();
196                return(true);
197        }
198        else
199                return(false);
200}
201?>
Note: See TracBrowser for help on using the repository browser.