| 1 | #!/bin/bash |
|---|
| 2 | # setclientmode: Configura el archivo de arranque de PXE para los clientes, |
|---|
| 3 | # ya sea un equipo o un aula, generando enlaces a archivos usados como plantilla. |
|---|
| 4 | # Nota: El archivo PXE por defecto "default" se deja en modo de ejecución "user" |
|---|
| 5 | # y se eliminan los enlaces para equipos con la plantilla por defecto. |
|---|
| 6 | # Uso: clienmode NombrePlatilla { 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/menu.lst |
|---|
| 15 | TEMPLATE="$PXEDIR/templates/$1" |
|---|
| 16 | LOGFILE=$OPENGNSYS/log/opengnsys.log |
|---|
| 17 | |
|---|
| 18 | # Control básico de errores. |
|---|
| 19 | if [ $# -ne 2 ]; then |
|---|
| 20 | echo "$PROG: Error de ejecución" |
|---|
| 21 | echo "Formato: $PROG Archivo_platilla [NOMBRE_PC|NOMBRE_AULA]" |
|---|
| 22 | exit 1 |
|---|
| 23 | fi |
|---|
| 24 | if [ ! -r $SERVERCONF ]; then |
|---|
| 25 | echo "$PROG: Sin acceso a fichero de configuración" |
|---|
| 26 | exit 2 |
|---|
| 27 | fi |
|---|
| 28 | if [ ! -e $TEMPLATE ]; then |
|---|
| 29 | echo "No existe archivo platilla: $TEMPLATE" |
|---|
| 30 | exit |
|---|
| 31 | fi |
|---|
| 32 | |
|---|
| 33 | # Obtener datos de acceso a la Base de datos. |
|---|
| 34 | source $SERVERCONF |
|---|
| 35 | # Comprobar si se recibe nombre de aula o de equipo. |
|---|
| 36 | IDAULA=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
|---|
| 37 | "SELECT idaula FROM aulas WHERE nombreaula=\"$2\";") |
|---|
| 38 | |
|---|
| 39 | if [ -n "$IDAULA" ]; then |
|---|
| 40 | # Aula encontrada |
|---|
| 41 | ETHERNET=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
|---|
| 42 | "SELECT mac FROM ordenadores WHERE idaula=\"$IDAULA\";") |
|---|
| 43 | else |
|---|
| 44 | # Buscar ordenador |
|---|
| 45 | ETHERNET=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
|---|
| 46 | "SELECT mac FROM ordenadores WHERE nombreordenador=\"$2\";") |
|---|
| 47 | fi |
|---|
| 48 | if [ -z "$ETHERNET" ]; then |
|---|
| 49 | date +"%b %d %T $PROG: No existe aula o equipo con el nombre \"$2\"" | tee -a $LOGFILE |
|---|
| 50 | exit 1 |
|---|
| 51 | fi |
|---|
| 52 | |
|---|
| 53 | # Copiar fichero de configuración y actualizar base de datos. |
|---|
| 54 | date +"%b %d %T $PROG: Configurando \"$1\" en \"$2\"" | tee -a $LOGFILE |
|---|
| 55 | NPC=0 |
|---|
| 56 | for AUX in $ETHERNET; do |
|---|
| 57 | date +"%b %d %T $PROG: Detectada ethernet \"$AUX\" en \"$2\"" | tee -a $LOGFILE |
|---|
| 58 | AUX="01-${AUX:0:2}-${AUX:2:2}-${AUX:4:2}-${AUX:6:2}-${AUX:8:2}-${AUX:10:2}" |
|---|
| 59 | # Si existe anteriormente lo borra |
|---|
| 60 | [ -e $PXEDIR/$AUX ] && rm $PXEDIR/$AUX |
|---|
| 61 | if [ "$1" != "default" ]; then |
|---|
| 62 | cp -a $TEMPLATE $PXEDIR/$AUX |
|---|
| 63 | DATOS=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
|---|
| 64 | "SELECT ordenadores.ip, ':', repositorios.ip, ':', |
|---|
| 65 | aulas.router, ':', aulas.netmask, ':', |
|---|
| 66 | ordenadores.netiface, ':none group=', |
|---|
| 67 | REPLACE (aulas.nombreaula, ' ', '_') |
|---|
| 68 | FROM ordenadores |
|---|
| 69 | JOIN aulas ON ordenadores.idaula=aulas.idaula |
|---|
| 70 | JOIN repositorios ON ordenadores.idrepositorio=repositorios.idrepositorio |
|---|
| 71 | WHERE ordenadores.mac=\"$ETHERNET\";") |
|---|
| 72 | DATOS=$(echo ${DATOS// /} | tr 'áéíóúñÁÉÍÓÚÑ' 'aeiounAEIOUN') |
|---|
| 73 | perl -pi -e "s/INFOHOST/$DATOS/g" $PXEDIR/$AUX |
|---|
| 74 | mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
|---|
| 75 | "UPDATE ordenadores SET arranque=\"$1\" WHERE mac=\"$ETHERNET\";" |
|---|
| 76 | fi |
|---|
| 77 | let NPC=NPC+1 |
|---|
| 78 | done |
|---|
| 79 | date +"%b %d %T $PROG: $NPC equipo(s) configurado(s)" | tee -a $LOGFILE |
|---|
| 80 | |
|---|