diff options
author | albertogp <albertogp@uma.es> | 2021-05-04 13:26:45 +0200 |
---|---|---|
committer | OpenGnSys Support Team <soporte-og@soleta.eu> | 2021-05-26 17:29:42 +0200 |
commit | c17ffa5d032a82e8eca61481dd8a8adb8b3fc5b1 (patch) | |
tree | 0823cbb3a597b80ae7317f3802fb557d3bd88faf /admin | |
parent | 29c2c73e14d90cfa803b21765c1dc6dc8a7252ad (diff) |
#1037 Add disk type
To help users choosing which preparation a computer needs according to
its disk type, this commit:
* Adds cloning engine support to retrieve disk type data from the
computer when refreshing disks partition schema.
* Adds WebConsole support to read disk type data from the database and
show it on partition drawing.
See also commits with #1037 in ogClient and ogServer repo.
Co-authored-by: Javier Sánchez Parra <jsanchez@soleta.eu>
Diffstat (limited to 'admin')
-rwxr-xr-x | admin/Interface/getConfiguration | 7 | ||||
-rw-r--r-- | admin/WebConsole/includes/pintaParticiones.php | 58 |
2 files changed, 55 insertions, 10 deletions
diff --git a/admin/Interface/getConfiguration b/admin/Interface/getConfiguration index ddfc3821..2173cca3 100755 --- a/admin/Interface/getConfiguration +++ b/admin/Interface/getConfiguration @@ -26,7 +26,9 @@ for ((dsk=1; dsk<=$disks; dsk++)); do *) ptt=0 ;; esac # Información de disco (partición 0) - cfg="$cfg$dsk:0:$ptt:::$(ogGetDiskSize $dsk):0;" + devpath=$(ogDiskToDev "$dsk") + dsktype=$(ogGetDiskType "$devpath") + cfg="$cfg$dsk:$dsktype:0:$ptt:::$(ogGetDiskSize $dsk):0;" for ((par=1;par<=$particiones;par++)); do # Código del identificador de tipo de partición cod=$(ogGetPartitionId $dsk $par 2>/dev/null) @@ -74,6 +76,9 @@ awk '{ n=split($0,sep,";"); c=split (sep[i],dua,":"); if (i==1 && c==1) printf ("ser=%s\n", dua[1]); + else if (c==8) + printf("disk=%s\tdtype=%s\tpar=%s\tcpt=%s\tfsi=%s\tsoi=%s\ttam=%s\tuso=%s\n", + dua[1],dua[2],dua[3],dua[4],dua[5],dua[6],dua[7],dua[8]); else printf ("disk=%s\tpar=%s\tcpt=%s\tfsi=%s\tsoi=%s\ttam=%s\tuso=%s\n", dua[1],dua[2],dua[3],dua[4],dua[5],dua[6],dua[7]); diff --git a/admin/WebConsole/includes/pintaParticiones.php b/admin/WebConsole/includes/pintaParticiones.php index 02c0f570..c789298d 100644 --- a/admin/WebConsole/includes/pintaParticiones.php +++ b/admin/WebConsole/includes/pintaParticiones.php @@ -2,6 +2,30 @@ include_once("../idiomas/php/".$idioma."/pintaParticiones_".$idioma.".php"); +function draw_disk_type($cmd, $computer_id, $disk) +{ + $cmd->texto = "SELECT disk_type " . + "FROM ordenadores_particiones " . + "WHERE idordenador=$computer_id " . + "AND numdisk=$disk " . + "AND numpar=0"; + + $rs = new Recordset; + $rs->Comando=&$cmd; + if (!$rs->Abrir()) return; + $rs->Primero(); + $disk_type = $rs->campos["disk_type"]; + syslog(LOG_ERR, print_r("test".$disk_type,true)); + + if ($disk_type=="NVM") + $html = ' - <span style="color: red"><strong>( ' . $disk_type . + 'e )</span>'; + else + $html = ' - <span><strong>( ' . $disk_type . ' )</span>'; + + return $html; +} + /** * Separa las distintas configuraciones de una cadena por disco. * Ej. 1;0;1@1;1;7@1;2;131@2;0;1@2;1;7 @@ -66,11 +90,15 @@ function pintaParticiones($cmd,$configuraciones,$idordenadores,$cc) $aviso=""; foreach($diskConfigs as $disk => $diskConfig){ $disk = (int)$disk; - echo'<tr height="16">'.chr(13); - echo '<td colspan="'.$columns.'" style="BORDER-TOP: #999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> '.$TbMsg["DISK"].' '.$disk.'</td>'.chr(13); + echo '<tr height="16">'.chr(13); + + $html_disk_type = draw_disk_type($cmd, $idordenadores, $disk); + echo '<td colspan="' . $columns . '" style="BORDER-TOP: " . + "#999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> ' . + $TbMsg["DISK"] . ' ' . $disk . $html_disk_type . + '</td>'.chr(13); - $auxCfg=explode("@",$diskConfig); // Crea lista de particiones for($i=0;$i<sizeof($auxCfg);$i++){ $auxKey=explode(";",$auxCfg[$i]); // Toma clave de configuracion @@ -240,9 +268,15 @@ function pintaParticionesRestaurarImagen($cmd,$configuraciones,$idordenadores,$c foreach($diskConfigs as $disk => $diskConfig){ $disk = (int)$disk; - echo'<tr height="16">'.chr(13); - echo '<td colspan="'.$columns.'" style="BORDER-TOP: #999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> '.$TbMsg["DISK"].' '.$disk.'</td>'.chr(13); - + + echo '<tr height="16">'.chr(13); + + $html_disk_type = draw_disk_type($cmd, $idordenadores, $disk); + echo '<td colspan="' . $columns . '" style="BORDER-TOP: " . + "#999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> ' . + $TbMsg["DISK"] . ' ' . $disk . $html_disk_type . + '</td>'.chr(13); + $auxCfg=explode("@",$diskConfig); // Crea lista de particiones for($i=0;$i<sizeof($auxCfg);$i++){ $auxKey=explode(";",$auxCfg[$i]); // Toma clave de configuracion @@ -439,9 +473,15 @@ function pintaParticionesRestaurarImagenSincronizacion1($cmd,$configuraciones,$i foreach($diskConfigs as $disk => $diskConfig){ $disk = (int)$disk; - echo'<tr height="16">'.chr(13); - echo '<td colspan="'.$columns.'" style="BORDER-TOP: #999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> '.$TbMsg["DISK"].' '.$disk.'</td>'.chr(13); - + + echo '<tr height="16">'.chr(13); + + $html_disk_type = draw_disk_type($cmd, $idordenadores, $disk); + echo '<td colspan="' . $columns . '" style="BORDER-TOP: " . + "#999999 1px solid;BACKGROUND-COLOR: #D4D0C8;"> ' . + $TbMsg["DISK"] . ' ' . $disk . $html_disk_type . + '</td>'.chr(13); + $auxCfg=explode("@",$diskConfig); // Crea lista de particiones for($i=0;$i<sizeof($auxCfg);$i++){ $auxKey=explode(";",$auxCfg[$i]); // Toma clave de configuracion |