918-git-images-111dconfigfileconfigure-oglivegit-imageslgromero-new-oglivemainmaint-cronmount-efivarfsmultivmmultivm-ogboot-installerogClonningEngineogboot-installer-jenkinsoglive-ipv6test-python-scriptsticket-301ticket-50ticket-50-oldticket-577ticket-585ticket-611ticket-612ticket-693ticket-700ubu24tplunification2use-local-agent-oglivevarios-instalacionwebconsole3
Rev | Line | |
---|
[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 |
---|
[68ced7d] | 35 | PCNAME=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 36 | "SELECT nombreordenador FROM ordenadores WHERE idaula='$IDAULA';") |
---|
[61dbabb] | 37 | else |
---|
| 38 | # Buscar ordenador |
---|
[68ced7d] | 39 | PCNAME=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 40 | "SELECT nombreordenador FROM ordenadores WHERE nombreordenador='$1';") |
---|
[61dbabb] | 41 | fi |
---|
[68ced7d] | 42 | if [ -z "$PCNAME" ]; then |
---|
| 43 | echo "$PROG: No existe ningún aula o equipo con el nombre \"$1\"" |
---|
[61dbabb] | 44 | exit 1 |
---|
| 45 | fi |
---|
| 46 | |
---|
[68ced7d] | 47 | for PC in $PCNAME; do |
---|
| 48 | PXE=$(mysql -u "$USUARIO" -p"$PASSWORD" -D "$CATALOG" -N -e \ |
---|
| 49 | "SELECT arranque FROM ordenadores WHERE nombreordenador='$PC';") |
---|
| 50 | echo "Equipo $PC asociado a arranque tipo \"$PXE\"" |
---|
[61dbabb] | 51 | done |
---|
| 52 | |
---|
Note: See
TracBrowser
for help on using the repository browser.