[61dbabb] | 1 | #!/bin/bash |
---|
[b5aae72] | 2 | # listclientmode: Lista la plantilla de arranque PXE para los clientes, |
---|
[61dbabb] | 3 | # ya sea un equipo o un aula. |
---|
| 4 | # Nota: Si no existe un enlace entre el fichero PXE con la Ethernet del equipo y su |
---|
| 5 | # archivo plantilla, se considera que la plantilla por omisión es "default". |
---|
[b5aae72] | 6 | # Uso: listclienmode NombrePC | NombreAula |
---|
[61dbabb] | 7 | # Autores: Irina Gomez y Ramon Gomez - Univ. Sevilla, noviembre 2010 |
---|
| 8 | |
---|
| 9 | |
---|
| 10 | # Variables. |
---|
| 11 | PROG=$(basename $0) |
---|
| 12 | OPENGNSYS=${OPENGNSYS:-"/opt/opengnsys"} |
---|
| 13 | SERVERCONF=$OPENGNSYS/etc/ogAdmServer.cfg |
---|
| 14 | PXEDIR=$OPENGNSYS/tftpboot/pxelinux.cfg |
---|
| 15 | |
---|
| 16 | # Control básico de errores. |
---|
| 17 | if [ $# -ne 1 ]; then |
---|
| 18 | echo "$PROG: Error de ejecución" |
---|
| 19 | echo "Formato: $PROG [NOMBRE_PC|NOMBRE_AULA]" |
---|
| 20 | exit 1 |
---|
| 21 | fi |
---|
| 22 | if [ ! -r $SERVERCONF ]; then |
---|
| 23 | echo "$PROG: Sin acceso a fichero de configuración" |
---|
| 24 | exit 2 |
---|
| 25 | fi |
---|
| 26 | |
---|
| 27 | # Obtener datos de acceso a la Base de datos. |
---|
| 28 | source $SERVERCONF |
---|
| 29 | # Comprobar si se recibe nombre de aula o de equipo. |
---|
| 30 | IDAULA=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 31 | "SELECT idaula FROM aulas WHERE nombreaula='$1';") |
---|
| 32 | |
---|
| 33 | if [ -n "$IDAULA" ]; then |
---|
| 34 | # Aula encontrada |
---|
| 35 | ETHERNET=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 36 | "SELECT mac FROM ordenadores WHERE idaula='$IDAULA';") |
---|
| 37 | else |
---|
| 38 | # Buscar ordenador |
---|
| 39 | ETHERNET=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 40 | "SELECT mac FROM ordenadores WHERE nombreordenador='$1';") |
---|
| 41 | fi |
---|
| 42 | if [ -z "$ETHERNET" ]; then |
---|
| 43 | echo "$PROG: No existe ningun aula o equipo con el nombre \"$1\"" |
---|
| 44 | exit 1 |
---|
| 45 | fi |
---|
| 46 | |
---|
| 47 | for ETH in $ETHERNET; do |
---|
| 48 | AUX=$(echo $ETH | awk '{print tolower($0)}') |
---|
| 49 | AUX="01-${AUX:0:2}-${AUX:2:2}-${AUX:4:2}-${AUX:6:2}-${AUX:8:2}-${AUX:10:2}" |
---|
| 50 | PCNAME=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 51 | "SELECT nombreordenador FROM ordenadores WHERE mac='$ETH';") |
---|
| 52 | if [ -f $PXEDIR/$AUX ]; then |
---|
| 53 | INODE=$(ls -i $PXEDIR/$AUX | cut -f1 -d" ") |
---|
| 54 | TMPL=$(ls -i $PXEDIR | grep $INODE | grep -v "01-" | cut -f2 -d" ") |
---|
| 55 | [ -z "$TMPL" ] && TMPL="default" |
---|
| 56 | else |
---|
| 57 | TMPL="default" |
---|
| 58 | fi |
---|
| 59 | echo "Equipo $PCNAME ($ETH) asociado a plantilla \"$TMPL\"" |
---|
| 60 | done |
---|
| 61 | |
---|