diff options
-rw-r--r-- | admin/WebConsole/gestores/gestor_ordenadores.php | 6 | ||||
-rw-r--r-- | admin/WebConsole/gestores/gestor_pxe_grub4dos.php | 22 | ||||
-rw-r--r-- | admin/WebConsole/includes/tftputils.php | 142 | ||||
-rw-r--r-- | admin/WebConsole/jscripts/boot_grub4dos.js | 16 | ||||
-rw-r--r-- | admin/WebConsole/principal/boot_grub4dos.php | 1 | ||||
-rw-r--r-- | admin/WebConsole/varios/incorporaordenadores.php | 3 |
6 files changed, 60 insertions, 130 deletions
diff --git a/admin/WebConsole/gestores/gestor_ordenadores.php b/admin/WebConsole/gestores/gestor_ordenadores.php index 2b517abd..b83c8ba4 100644 --- a/admin/WebConsole/gestores/gestor_ordenadores.php +++ b/admin/WebConsole/gestores/gestor_ordenadores.php @@ -284,7 +284,7 @@ function Gestiona(){ if ($resul){ // Crea una tabla nodo para devolver a la página que llamó ésta $idordenador=$cmd->Autonumerico(); // Crear fichero TFTP/PXE por defecto para el nuevo ordenador. - createBootMode ($cmd, "", $idordenador, $idioma); + createBootMode ($cmd, "", $nombreordenador, $idioma); // Insertar datos en el árbol de configuración. $arbolXML=SubarbolXML_ordenadores($idordenador,$nombreordenador); $baseurlimg="../images/signos"; // Url de las imagenes de signo @@ -299,7 +299,7 @@ function Gestiona(){ WHERE idordenador=@idordenador"; $resul=$cmd->Ejecutar(); // Actualizar fichero TFTP/PXE a partir de la plantilla asociada. - createBootMode ($cmd, $arranque, $idordenador, $idioma); + createBootMode ($cmd, $arranque, $nombreordenador, $idioma); break; case $op_eliminacion : $resul=EliminaOrdenadores($cmd,$idordenador,"idordenador");// Eliminación en cascada @@ -310,7 +310,7 @@ function Gestiona(){ $cmd->texto="UPDATE ordenadores SET idaula=@idaula, grupoid=@grupoid WHERE idordenador=@idordenador"; $resul=$cmd->Ejecutar(); // Actualizar fichero TFTP/PXE a partir de la plantilla asociada. - createBootMode ($cmd, $arranque, $idordenador, $idioma); + createBootMode ($cmd, $arranque, $nombreordenador, $idioma); break; default: break; diff --git a/admin/WebConsole/gestores/gestor_pxe_grub4dos.php b/admin/WebConsole/gestores/gestor_pxe_grub4dos.php index 6c21c2b4..fc21bbdc 100644 --- a/admin/WebConsole/gestores/gestor_pxe_grub4dos.php +++ b/admin/WebConsole/gestores/gestor_pxe_grub4dos.php @@ -1,36 +1,30 @@ <?php -// Version 1.1.1 - Se utiliza el script setclientmode para crear los archivos PXE (ticket #802) +// Version 1.1.1 - Se utiliza createBootMode para crear los archivos PXE (ticket #802 #888) // Autor: Irina Gomez - ETSII Universidad de Sevilla // Fecha: 2019/02/12 include_once("../includes/ctrlacc.php"); +include_once("../includes/CreaComando.php"); +include_once("../includes/tftputils.php"); // Recogemos los parametros $litambito=(isset($_REQUEST["litambito"])) ? $_REQUEST["litambito"] : ""; $idambito=(isset($_REQUEST["idambito"])) ? $_REQUEST["idambito"] : ""; $nombreambito=(isset($_REQUEST["nombreambito"])) ? $_REQUEST["nombreambito"] : ""; +$lista=(isset($_POST['listOfItems'])) ? explode(";",$_POST['listOfItems']) : ""; -// Datos para el acceso a mysql -$strcn=explode(";",$cadenaconexion); -$file=tempnam("/tmp",".server.cnf."); +// Crea objeto comando +$cmd=CreaComando($cadenaconexion); -$lista = explode(";",$_POST['listOfItems']); foreach ($lista as $sublista) { if (! empty ($sublista)) { - // Creo fichero con datos para mysql - $gestor=fopen($file, "w"); - fwrite($gestor, "USUARIO=".$strcn[1]."\nPASSWORD=".$strcn[2]."\n"); - fwrite($gestor, "datasource=".$strcn[0]."\nCATALOG=".$strcn[3]); - fclose($gestor); - $elementos = explode("|",$sublista); $hostname=$elementos[1]; $optboot=$elementos[0]; - // Llamamos al script setclientmode - shell_exec("/opt/opengnsys/bin/setclientmode $optboot $hostname PERM $file"); - unlink($file); + createBootMode ($cmd, $optboot, $hostname, $idioma); } } + header("Location: ../principal/boot.php?idambito=". $idambito ."&nombreambito=" . $nombreambito . "&litambito=" . $litambito); exit(); diff --git a/admin/WebConsole/includes/tftputils.php b/admin/WebConsole/includes/tftputils.php index 5cf2da88..8ce6447f 100644 --- a/admin/WebConsole/includes/tftputils.php +++ b/admin/WebConsole/includes/tftputils.php @@ -12,7 +12,8 @@ include_once("../includes/ctrlacc.php"); include_once("../clases/AdoPhp.php"); // Directorio de ficheros PXE. -define("PXEDIR", "/opt/opengnsys/tftpboot/menu.lst"); +define("PXEDIRBIOS", "/opt/opengnsys/tftpboot/menu.lst"); +define("PXEDIRUEFI", "/opt/opengnsys/tftpboot/grub"); /** @@ -47,12 +48,12 @@ function clientKernelVersion () { /** - * createBootMode ($cmd, $bootopt, $hostid, $lang) + * createBootMode ($cmd, $bootopt, $hostname, $lang) * @brief Crea un fichero PXE para el ordenador basado en la plantilla indicada y usando * los datos almacenados en la BD. * @param {Object} cmd Objeto de conexión a la base de datos. * @param {String} bootopt Plantilla de arranque PXE. - * @param {Number} hostid Id. del ordenador. + * @param {String} hostname Nombre del ordenador. * @param {String} lang Idioma de arranque. * @version 1.0.5 - Primera versión, adaptada de NetBoot Avanzado (Antonio J. Doblas Viso - Universidad de Málaga) * @author Ramón Gómez - ETSII Universidad de Sevilla @@ -66,64 +67,25 @@ function clientKernelVersion () { * @version 1.1.0 - Se incluye el nombre del perfil hardware y se elimina el winboot (ticket #828). * @author Antonio J. Doblas Viso - Universidad de Malaga * @date 2018-01-21 + * @version 1.1.1 - Se utiliza setclientmode. Gestiona plantilla bios y uefi (ticket #802 #888) + * @author Irina Gómez - ETSII Universidad de Sevilla + * @date 2019-03-14 */ -function createBootMode ($cmd, $bootopt, $hostid, $lang) { - - // Plantilla con las opciones por defecto. - if (empty ($bootopt)) $bootopt = "00unknown"; +function createBootMode ($cmd, $bootopt, $hostname, $lang) { + global $cadenaconexion; - // Actualizar opción de arranque para el equipo. - $cmd->CreaParametro("@arranque",$bootopt,0); - $cmd->CreaParametro("@idordenador",$hostid,1); - $cmd->texto="UPDATE ordenadores SET arranque=@arranque WHERE idordenador=@idordenador"; - $cmd->Ejecutar(); + // Datos para el acceso a mysql + $strcn=explode(";",$cadenaconexion); + $file=tempnam("/tmp",".server.cnf."); - // Obtener información de la base de datos. - $cmd->texto="SELECT ordenadores.nombreordenador AS hostname, ordenadores.ip AS ip, - ordenadores.mac AS mac, ordenadores.netiface AS netiface, - ordenadores.oglivedir AS oglivedir, - aulas.netmask AS netmask, aulas.router AS router, - aulas.ntp AS ntp, aulas.dns AS dns, aulas.proxy AS proxy, - aulas.nombreaula AS grupo, IFNULL(repositorios.ip, '') AS iprepo, - (SELECT ipserveradm FROM entornos LIMIT 1) AS ipserveradm, - menus.resolucion AS vga, perfileshard.descripcion AS hardprofile, - centros.directorio, entidades.ogunit - FROM ordenadores - JOIN aulas USING (idaula) - JOIN centros USING (idcentro) - JOIN entidades USING (identidad) - LEFT JOIN repositorios USING (idrepositorio) - LEFT JOIN menus USING (idmenu) - LEFT JOIN perfileshard USING (idperfilhard) - WHERE ordenadores.idordenador='$hostid'"; - - $rs=new Recordset; - $rs->Comando=&$cmd; - if (!$rs->Abrir()) return; - $rs->Primero(); - $hostname=$rs->campos["hostname"]; - $ip=$rs->campos["ip"]; - $mac=$rs->campos["mac"]; - $netiface=$rs->campos["netiface"]; - $netmask=$rs->campos["netmask"]; - $router=$rs->campos["router"]; - $ntp=$rs->campos["ntp"]; - $dns=$rs->campos["dns"]; - $proxy=$rs->campos["proxy"]; - $group=cleanString($rs->campos["grupo"]); - $repo=$rs->campos["iprepo"]; - $server=$rs->campos["ipserveradm"]; - $vga=$rs->campos["vga"]; - $hardprofile=cleanString($rs->campos["hardprofile"]); - $oglivedir=$rs->campos["oglivedir"]; - $ogunit=$rs->campos["ogunit"]; - if ($ogunit == 0 or $rs->campos["directorio"] == null) { - $directorio="" ; - } else { - $directorio=$rs->campos["directorio"]; - } + // Creo fichero con datos para mysql + $gestor=fopen($file, "w"); + fwrite($gestor, "USUARIO=".$strcn[1]."\nPASSWORD=".$strcn[2]."\n"); + fwrite($gestor, "datasource=".$strcn[0]."\nCATALOG=".$strcn[3]); + fclose($gestor); - $rs->Cerrar(); + // Plantilla con las opciones por defecto. + if (empty ($bootopt)) $bootopt = "00unknown"; // Componer código de idioma para el parámetro de arranque. switch ($lang) { @@ -138,42 +100,14 @@ function createBootMode ($cmd, $bootopt, $hostid, $lang) { break; } - // Componer parámetros del kernel. - $infohost=" LANG=$lang". - " ip=$ip:$server:$router:$netmask:$hostname:$netiface:none" . - " group=$group" . - " ogrepo=$repo" . - " oglive=$server" . - " oglog=$server" . - " ogshare=$server"; - // Añadir parámetros opcionales. - if (! empty ($ntp)) { $infohost.=" ogntp=$ntp"; } - if (! empty ($dns)) { $infohost.=" ogdns=$dns"; } - if (! empty ($proxy)) { $infohost.=" ogproxy=$proxy"; } - if (! empty ($hardprofile)) { $infohost.=" hardprofile=$hardprofile"; } - // Comprobar si se usa el parámetro "vga" (número de 3 cifras) o "video" (cadena). - if (! empty ($vga)) { - // UHU - Se sustituye la función is_int por is_numeric, ya que al ser un string no funciona bien con is_int - if (is_numeric($vga) && strlen($vga) == 3) { - $infohost.=" vga=$vga"; - } else { - $infohost.=" video=$vga"; - } - } - if (! empty ($directorio)) { $infohost.=" ogunit=$directorio"; } - - $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); - $macfile = PXEDIR . "/01-" . str_replace(":", "-", strtoupper($mac)); + // Descripción plantilla PXE + $description=exec("awk 'NR==1 {print $2}' ".PXEDIRBIOS."/templates/".$bootopt); + if ($description === "") $description=exec("awk 'NR==1 {print $2}' ".PXEDIRUEFI."/templates/".$bootopt); + // Llamamos al script setclientmode + shell_exec("export LANG=$lang; /opt/opengnsys/bin/setclientmode $description $hostname PERM $file"); - // Crear fichero de arranque a partir de la plantilla y los datos del cliente. - // UHU - si el parametro vga no existe, no se quita. - if (! empty ($vga)) { - exec("sed -e 's|vga=...||g; s|INFOHOST|$infohost|g; s|set ISODIR=.*|set ISODIR=$oglivedir|g' " . PXEDIR . "/templates/$bootopt > $macfile"); - } - else{ - 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"); - } - chmod($macfile, 0777); + // Borro fichero para mysql + unlink($file); } @@ -189,9 +123,10 @@ function deleteBootFile ($mac) { // Obtener nombre de fichero a partir de dirección MAC. $mac = strtoupper($mac); - $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); + $macfile = "/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); // Eliminar el fichero. - @unlink($macfile); + @unlink(PXEDIRBIOS.$macfile); + @unlink(PXEDIRUEFI.$macfile); } /** @@ -216,7 +151,7 @@ function updateBootMode ($cmd, $idfield, $idvalue, $lang) { $idvalue = mysqli_real_escape_string ($cmd->Conexion->controlador, $idvalue); // Obtener los ordenadores asociados al aula y sus plantillas de arranque. - $cmd->texto = "SELECT idordenador AS hostid, arranque AS bootopt + $cmd->texto = "SELECT nombreordenador AS hostname, arranque AS bootopt FROM ordenadores WHERE $idfield=$idvalue"; $rs = new Recordset; @@ -224,11 +159,12 @@ function updateBootMode ($cmd, $idfield, $idvalue, $lang) { if ($rs->Abrir()) { $rs->Primero(); while (! $rs->EOF) { - $hostid=$rs->campos["hostid"]; - if (! empty ($hostid)) { + $hostname=$rs->campos["hostname"]; + if (! empty ($hostname)) { $bootopt=$rs->campos["bootopt"]; + // Volver a crear el fichero de arranque. - createBootMode ($cmd, $bootopt, $hostid, $lang); + createBootMode ($cmd, $bootopt, $hostname, $lang); } $rs->Siguiente(); } @@ -261,13 +197,15 @@ function updateBootRepo ($cmd, $repoid) { $mac = $rs->campos["mac"]; $repo = $rs->campos["iprepo"]; // Obtener nombre de fichero PXE a partir de la MAC del ordenador cliente. - $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); + $macfile = "/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); // Actualizar parámetro "ogrepo" en el fichero PXE. - if ($pxecode = @file_get_contents($macfile)) { + foreach (array (PXEDIRBIOS,PXEDIRUEFI) as $bootdir) { + if ($pxecode = @file_get_contents($bootdir.$macfile)) { $pxecode = preg_replace("/ogrepo=[^ ]*/", "ogrepo=$repo", $pxecode); - if (! @file_put_contents($macfile, $pxecode)) { - $erros++; + if (! @file_put_contents($bootdir.$macfile, $pxecode)) { + $errors++; } + } } $rs->Siguiente(); } diff --git a/admin/WebConsole/jscripts/boot_grub4dos.js b/admin/WebConsole/jscripts/boot_grub4dos.js index 6e91dcb0..e7cd8359 100644 --- a/admin/WebConsole/jscripts/boot_grub4dos.js +++ b/admin/WebConsole/jscripts/boot_grub4dos.js @@ -55,7 +55,7 @@ tbox[c] = no; // Se utiliza al enviar el formulario // Asigna como valor del campo listOfItems un listado // con las correspodendencias nombre plantilla - nombre equipo. -// Version 1.1.1 - Se identifica plantilla y equipo como necesita el script setclienmode (#802) +// Version 1.1.1 - Se identifica plantilla y equipo como necesita la función createBootMode (#802 #888) function allSelect() { var saveString = ""; @@ -63,14 +63,14 @@ function allSelect() var input = document.getElementsByTagName('select'); for(var i=0; i<input.length; i++){ - label = input[i].parentNode.id; - // La plantilla 00unknown no existe, no se incluye en el listado - if (label === "00unknown") continue; + // quitamos L inicial + patron = "L"; + parm = input[i].name; + parm = parm.replace(patron,''); - for (j=0;j<input[i].length;j++) - { - saveString = saveString + label + '|' + input[i].options[j].text + ';'; - } + for (j=0;j<input[i].length;j++) { + saveString = saveString + parm + '|' + input[i].options[j].text + ';'; + } } document.forms[0].listOfItems.value = saveString; } diff --git a/admin/WebConsole/principal/boot_grub4dos.php b/admin/WebConsole/principal/boot_grub4dos.php index d5bef893..fbd7e171 100644 --- a/admin/WebConsole/principal/boot_grub4dos.php +++ b/admin/WebConsole/principal/boot_grub4dos.php @@ -148,7 +148,6 @@ for($i=0; $i<count($pn); $i++) { {$listadopxe=listadesconocido($cmd,$desconocido,$seleccion); // Solo lo mostramos si existen aquipos no asignados. if (isset($existe)){ - $description=$desconocido; echo "<td></td>"; echo "<td><font id='$description' color=red>"; echo $description; diff --git a/admin/WebConsole/varios/incorporaordenadores.php b/admin/WebConsole/varios/incorporaordenadores.php index 2615fbad..8bf52f6b 100644 --- a/admin/WebConsole/varios/incorporaordenadores.php +++ b/admin/WebConsole/varios/incorporaordenadores.php @@ -193,8 +193,7 @@ function Inserta($cmd,$idaula,$nombre,$lamac,$laip) // Crear fichero de arranque PXE con plantilla por defecto. if ($resul) { - $idordenador=$cmd->Autonumerico(); - createBootMode ($cmd, "", $idordenador, $idioma); + createBootMode ($cmd, "", $nombreordenador, $idioma); } return($resul); } |