1 | #!/bin/bash |
---|
2 | # listclientmode: Lista la plantilla de arranque PXE para los clientes, |
---|
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". |
---|
6 | # Uso: listclienmode NombrePC | NombreAula |
---|
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 | |
---|