source: admin/WebConsole/includes/tftputils.php @ 60459a1

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 60459a1 was 60459a1, checked in by ramon <ramongomez@…>, 7 years ago

#818: Llamar a la nueva función para modificar la IP del repositorio en todos los ficheros PXE de sus ordenadores asociados.

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

  • Property mode set to 100644
File size: 10.2 KB
Line 
1<?php
2/**
3 * @file      tftptools.php
4 * @brief     Utilidades para menejar ficheros de arranque TFTP/PXE.
5 * @version   1.0.5
6 * @copyright GNU Public License v3+
7 */
8
9
10// Ficheros de inclusión.
11include_once("../includes/ctrlacc.php");
12include_once("../clases/AdoPhp.php");
13
14// Directorio de ficheros PXE.
15define("PXEDIR", "/opt/opengnsys/tftpboot/menu.lst");
16
17
18/**
19 * @brief    Sustituye espacio por "_" y quita acentos y tildes.
20 * @param    cadena   Cadena a modificar.
21 * @return   string   Cadena modificada.
22 * @versión  1.0.5 - Primera versión, adaptada de NetBoot Avanzado.
23 * @author   
24 * @date     
25*/
26function cleanString ($cadena) {
27        return strtr ($cadena, " áéíóúñçÁÉÍÓÚÑÇ", "_aeiouncAEIOUNC");
28}
29
30
31/**
32 * Función que obtiene la versión del Kernel del cliente que se ejecuta durante el
33 * proceso de arranque mediante TFTP/PXE.
34 * @brief    Obtiene la versión del Kernel usada en arranque TFTP/PXE.
35 * @return   float    Versión del Kernel (Versión.Revisión, con 2 decimales).
36 * @versión  1.0.5 - Versión inicial.
37 * @authors  Ramón Gómez - ETSII Universidad de Sevilla
38 * @date     2013-04-11
39 */
40function clientKernelVersion () {
41        $tftpDir = "/opt/opengnsys/tftpboot";           // Directorio TFTP.
42        $kernelFile = "$tftpDir/ogclient/ogvmlinuz";    // Fichero del Kernel
43
44        // Devolver versión del Kernel (Versión.Revisión, con 2 decimales).
45        return exec ("file -bkr $kernelFile 2>/dev/null | awk '/Linux/ {for(i=1;i<=NF;i++) if(\$i~/version/) {v=\$(i+1); printf(\"%d\",v); sub(/[0-9]*\./,\"\",v); printf(\".%02d\",v)}}'");
46}
47
48
49/**
50 *           createBootMode ($cmd, $bootopt, $hostid, $lang)
51 * @brief    Crea un fichero PXE para el ordenador basado en la plantilla indicada y usando
52 *           los datos almacenados en la BD.
53 * @param    {Object}  cmd       Objeto de conexión a la base de datos.
54 * @param    {String}  bootopt   Plantilla de arranque PXE.
55 * @param    {Number}  hostid    Id. del ordenador.
56 * @param    {String}  lang      Idioma de arranque.
57 * @version  1.0.5 - Primera versión, adaptada de NetBoot Avanzado (Antonio J. Doblas Viso - Universidad de Málaga)
58 * @author  Ramón Gómez - ETSII Universidad de Sevilla
59 * @date     2013-04-25
60 * @version  1.1.0 - Se incluye la unidad organizativa como parametro del kernel: ogunit=directorio_unidad (ticket #678).
61 * @author   Irina Gómez - ETSII Universidad de Sevilla
62 * @date     2015-12-16
63 * @version  1.1.0 - La segunda fase de carga del ogLive se define en el SERVER para evitar erores de sincronismo entre versiones (ticket #787).
64 * @author   Antonio J. Doblas Viso - Universidad de Malaga
65 * @date     2017-06-01
66 */
67function createBootMode ($cmd, $bootopt, $hostid, $lang) {     
68
69        // Plantilla con las opciones por defecto.
70        if (empty ($bootopt))  $bootopt = "00unknown";
71
72        // Actualizar opción de arranque para el equipo.
73        $cmd->CreaParametro("@arranque",$bootopt,0);
74        $cmd->CreaParametro("@idordenador",$hostid,1);
75        $cmd->texto="UPDATE ordenadores SET arranque=@arranque WHERE idordenador=@idordenador";
76        $cmd->Ejecutar();
77
78        // Obtener información de la base de datos.
79        $cmd->texto="SELECT ordenadores.nombreordenador AS hostname, ordenadores.ip AS ip,
80                            ordenadores.mac AS mac, ordenadores.netiface AS netiface,
81                            ordenadores.oglivedir AS oglivedir,
82                            aulas.netmask AS netmask, aulas.router AS router,
83                            aulas.ntp AS ntp, aulas.dns AS dns, aulas.proxy AS proxy,
84                            aulas.nombreaula AS grupo, repositorios.ip AS iprepo,
85                            (SELECT ipserveradm FROM entornos LIMIT 1) AS ipserveradm,
86                            menus.resolucion AS vga, perfileshard.winboot AS winboot,
87                            centros.directorio, entidades.ogunit
88                        FROM ordenadores
89                        JOIN aulas USING (idaula)
90                        JOIN centros USING (idcentro)
91                        JOIN entidades USING (identidad)
92                        JOIN repositorios USING (idrepositorio)
93                        LEFT JOIN menus USING (idmenu)
94                        LEFT JOIN perfileshard USING (idperfilhard)
95                        WHERE ordenadores.idordenador='$hostid'";
96
97        $rs=new Recordset;
98        $rs->Comando=&$cmd;
99        if (!$rs->Abrir())  return;
100        $rs->Primero();
101        $hostname=$rs->campos["hostname"];
102        $ip=$rs->campos["ip"];
103        $mac=$rs->campos["mac"];
104        $netiface=$rs->campos["netiface"];
105        $netmask=$rs->campos["netmask"];
106        $router=$rs->campos["router"];
107        $ntp=$rs->campos["ntp"];
108        $dns=$rs->campos["dns"];
109        $proxy=$rs->campos["proxy"];
110        $group=cleanString($rs->campos["grupo"]);
111        $repo=$rs->campos["iprepo"];
112        $server=$rs->campos["ipserveradm"];
113        $vga=$rs->campos["vga"];
114        $winboot=$rs->campos["winboot"];
115        $oglivedir=$rs->campos["oglivedir"];
116        $ogunit=$rs->campos["ogunit"];
117        if ($ogunit == 0 or $rs->campos["directorio"] == null) {
118                $directorio="" ;
119        } else {
120                $directorio=$rs->campos["directorio"];
121        }
122
123        $rs->Cerrar();
124
125        // Componer código de idioma para el parámetro de arranque.
126        switch ($lang) {
127                case "eng":
128                        $lang="en_GB";
129                        break;
130                case "esp":
131                        $lang="es_ES";
132                        break;
133                case "cat":
134                        $lang="ca_ES";
135                        break;
136        }
137
138        // Componer parámetros del kernel.
139        $infohost=" LANG=$lang".
140                  " ip=$ip:$server:$router:$netmask:$hostname:$netiface:none" .
141                  " group=$group" .
142                  " ogrepo=$repo" .
143                  " oglive=$server" .
144                  " oglog=$server" .
145                  " ogshare=$server" .
146                  " oglivedir=$oglivedir";
147        // Añadir parámetros opcionales.
148        if (! empty ($ntp))     { $infohost.=" ogntp=$ntp"; }
149        if (! empty ($dns))     { $infohost.=" ogdns=$dns"; }
150        if (! empty ($proxy))   { $infohost.=" ogproxy=$proxy"; }
151        if (! empty ($winboot)) { $infohost.=" winboot=$winboot"; }
152        // Comprobar si se usa el parámetro "vga" (número de 3 cifras) o "video" (cadena).
153        if (! empty ($vga)) {
154                // UHU - Se sustituye la función is_int por is_numeric, ya que al ser un string no funciona bien con is_int
155                if (is_numeric($vga) && strlen($vga) == 3) {
156                        $infohost.=" vga=$vga";
157                } else {
158                        $infohost.=" video=$vga";
159                }
160        }
161        if (! empty ($directorio)) { $infohost.=" ogunit=$directorio"; }
162       
163        $mac = substr($mac,0,2) . ":" . substr($mac,2,2) . ":" . substr($mac,4,2) . ":" . substr($mac,6,2) . ":" . substr($mac,8,2) . ":" . substr($mac,10,2);
164        $macfile = PXEDIR . "/01-" . str_replace(":", "-", strtoupper($mac));   
165
166        // Crear fichero de arranque a partir de la plantilla y los datos del cliente.
167        // UHU - si el parametro vga no existe, no se quita.
168        if (! empty ($vga)) {
169                exec("sed -e 's|vga=...||g; s|INFOHOST|$infohost|g; s|set ISODIR=.*|set ISODIR=$oglivedir|g' " . PXEDIR . "/templates/$bootopt > $macfile");
170        }
171        else{
172                exec("sed -e 's|INFOHOST|$infohost|g; s|set ISODIR=.*|set ISODIR=$oglivedir|g; s|set ISODIR=.*|set ISODIR=$oglivedir|g' " . PXEDIR . "/templates/$bootopt > $macfile");
173        }
174        chmod($macfile, 0777);
175}
176
177
178/**
179 *           deleteBootFile ($mac)
180 * @brief    Borra el fichero PXE del ordenador con la dirección MAC correspondiente.
181 * @param    {String}  mac     Dirección MAC del ordenador (sin caracteres ":").
182 * @versión  1.0.5 - Primera versión, adaptada de NetBoot Avanzado.
183 * @authors  Ramón Gómez - ETSII Universidad de Sevilla
184 * @date     2013-04-25
185 */
186function deleteBootFile ($mac) {       
187
188        // Obtener nombre de fichero a partir de dirección MAC.
189        $mac = strtoupper($mac);
190        $macfile = PXEDIR . "/01-" . substr($mac, 0, 2) . "-" . substr($mac, 2, 2) . "-" . substr($mac, 4, 2) . "-" . substr($mac, 6, 2) . "-" . substr($mac, 8, 2) . "-" . substr($mac, 10, 2);
191        // Eliminar el fichero.
192        @unlink($macfile);
193}
194
195/**
196 *           updateBootMode ($cmd, $idfield, $idvalue, $lang)
197 * @brief    Ejecuta la función para componer fichero PXE para todos los clientes que cumplan
198 *           con un determinado criterio de búsqueda basado en clave ejena.
199 * @param    {Object}  cmd       Objeto de conexión con la base de datos.
200 * @param    {String}  idfield   Campo identificador de la clave ajena para buscar ordenadores.
201 * @param    {Number}  idvalue   Valor a buscar en el ídentificador de la clave ajena.
202 * @param    {String}  lang      Idioma de arranque.
203 * @versión  1.0.5 - Primera versión, adaptada de NetBoot Avanzado.
204 * @authors  Ramón Gómez - ETSII Universidad de Sevilla
205 * @date     2013-04-25
206 */
207function updateBootMode ($cmd, $idfield, $idvalue, $lang) {
208
209        // Salir si los es nulo el campo de identificador y su valor de índice.
210        if (empty ($idfield) or empty ($idvalue))
211                return;
212        // Control para evitar ataques XSS.
213        $idfield = mysql_real_escape_string ($idfield);
214        $idvalue = mysql_real_escape_string ($idvalue);
215
216        // Obtener los ordenadores asociados al aula y sus plantillas de arranque.
217        $cmd->texto = "SELECT idordenador AS hostid, arranque AS bootopt
218                         FROM ordenadores
219                        WHERE $idfield=$idvalue";
220        $rs = new Recordset;
221        $rs->Comando=&$cmd;
222        if ($rs->Abrir()) {
223                $rs->Primero();
224                while (! $rs->EOF) {
225                        $hostid=$rs->campos["hostid"];
226                        if (! empty ($hostid)) {
227                                $bootopt=$rs->campos["bootopt"];
228                                // Volver a crear el fichero de arranque.
229                                createBootMode ($cmd, $bootopt, $hostid, $lang);
230                        }
231                        $rs->Siguiente();
232                }
233                $rs->Cerrar();
234        }
235}
236
237/**
238 *           updateBootRepo ($cmd, $repoid)
239 * @brief    Actualiza la IP del repositorio en los ficheros PXE de todos sus equipos asociados.
240 * @param    {Object}  cmd      Objeto de conexión con la base de datos
241 * @param    {Integer} repoid   Campo identificador del repositorio
242 * @return   {Integer}          0, sin errores; -1, error acceso a BD; >0, ficheros no modificados
243 * @versión  1.1.0 - Primera versión.
244 * @authors  Ramón Gómez - ETSII Universidad de Sevilla
245 * @date     2018-01-19
246 */
247function updateBootRepo ($cmd, $repoid) {
248        $errors = 0;
249        // Obtener todas las MAC de los ordenadores incluidos en el repositorio.
250        $cmd->texto = "SELECT UPPER(ordenadores.mac) AS mac, repositorios.ip AS iprepo
251                         FROM ordenadores
252                         JOIN repositorios USING (idrepositorio)
253                        WHERE ordenadores.idrepositorio = '$repoid'";
254        $rs = new Recordset;
255        $rs->Comando=&$cmd;
256        if ($rs->Abrir()) {
257                $rs->Primero();
258                while (! $rs->EOF) {
259                        $mac = $rs->campos["mac"];
260                        $repo = $rs->campos["iprepo"];
261                        // Obtener nombre de fichero PXE a partir de la MAC del ordenador cliente.
262                        $macfile = PXEDIR . "/01-" . substr($mac, 0, 2) . "-" . substr($mac, 2, 2) . "-" . substr($mac, 4, 2) . "-" . substr($mac, 6, 2) . "-" . substr($mac, 8, 2) . "-" . substr($mac, 10, 2);
263                        // Actualizar parámetro "ogrepo" en el fichero PXE.
264                        if ($pxecode = @file_get_contents($macfile)) {
265                                $pxecode = preg_replace("/ogrepo=[^ ]*/", "ogrepo=$repo", $pxecode);
266                                if (! @file_put_contents($macfile, $pxecode)) {
267                                        $erros++;
268                                }
269                        }
270                        $rs->Siguiente();
271                }
272                $rs->Cerrar();
273        } else {
274                $errors = -1;
275        }
276        return($errors);
277}
278
279?>
280
Note: See TracBrowser for help on using the repository browser.